id; $littlelink_name = Auth::user()->littlelink_name; $userinfo = User::find($userId); $links = Link::where('user_id', $userId)->select('link')->count(); $clicks = Link::where('user_id', $userId)->sum('click_number'); $topLinks = Link::where('user_id', $userId)->orderby('click_number', 'desc') ->whereNotNull('link')->where('link', '<>', '') ->take(5)->get(); $pageStats = [ 'visitors' => [ 'all' => visits('App\Models\User', $littlelink_name)->count(), 'day' => visits('App\Models\User', $littlelink_name)->period('day')->count(), 'week' => visits('App\Models\User', $littlelink_name)->period('week')->count(), 'month' => visits('App\Models\User', $littlelink_name)->period('month')->count(), 'year' => visits('App\Models\User', $littlelink_name)->period('year')->count(), ], 'os' => visits('App\Models\User', $littlelink_name)->operatingSystems(), 'referers' => visits('App\Models\User', $littlelink_name)->refs(), 'countries' => visits('App\Models\User', $littlelink_name)->countries(), ]; return view('studio/index', ['greeting' => $userinfo->name, 'toplinks' => $topLinks, 'links' => $links, 'clicks' => $clicks, 'pageStats' => $pageStats]); } //Show littlelink page. example => http://127.0.0.1:8000/+admin public function littlelink(request $request) { $littlelink_name = $request->littlelink; $id = User::select('id')->where('littlelink_name', $littlelink_name)->value('id'); if (empty($id)) { return abort(404); } $userinfo = User::select('id', 'name', 'littlelink_name', 'littlelink_description', 'theme', 'role')->where('id', $id)->first(); $information = User::select('name', 'littlelink_name', 'littlelink_description', 'theme')->where('id', $id)->get(); $links = DB::table('links')->join('buttons', 'buttons.id', '=', 'links.button_id')->select('links.link', 'links.id', 'links.button_id', 'links.title', 'links.custom_css', 'links.custom_icon', 'buttons.name')->where('user_id', $id)->orderBy('up_link', 'asc')->orderBy('order', 'asc')->get(); return view('littlelink', ['userinfo' => $userinfo, 'information' => $information, 'links' => $links, 'littlelink_name' => $littlelink_name]); } //Show littlelink page as home page if set in config public function littlelinkhome(request $request) { $littlelink_name = env('HOME_URL'); $id = User::select('id')->where('littlelink_name', $littlelink_name)->value('id'); if (empty($id)) { return abort(404); } $userinfo = User::select('id', 'name', 'littlelink_name', 'littlelink_description', 'theme', 'role')->where('id', $id)->first(); $information = User::select('name', 'littlelink_name', 'littlelink_description', 'theme')->where('id', $id)->get(); $links = DB::table('links')->join('buttons', 'buttons.id', '=', 'links.button_id')->select('links.link', 'links.id', 'links.button_id', 'links.title', 'links.custom_css', 'links.custom_icon', 'buttons.name')->where('user_id', $id)->orderBy('up_link', 'asc')->orderBy('order', 'asc')->get(); return view('littlelink', ['userinfo' => $userinfo, 'information' => $information, 'links' => $links, 'littlelink_name' => $littlelink_name]); } //Show add/update form public function AddUpdateLink($id = 0) { if ($id !== 0) { $linkData = Link::find($id); } elseif ($id == 0) { $linkData = new Link(['typename' => 'link', 'id'=>'0']); } else { $linkData = new Link(['typename' => 'link', 'id'=>'0']); } $data['LinkTypes'] = LinkType::get(); $data['LinkData'] = $linkData; $data['LinkID'] = $id; $data['linkTypeID'] = "1"; $data['title'] = "Predefined Site"; if (Route::currentRouteName() != 'showButtons') { $links = DB::table('links')->where('id', $id)->first(); $bid = $links->button_id; if($bid == 1 or $bid == 2){ $data['linkTypeID'] = "2"; } elseif ($bid == 42) { $data['linkTypeID'] = "3"; } elseif ($bid == 43) { $data['linkTypeID'] = "4"; } elseif ($bid == 93) { $data['linkTypeID'] = "5"; } elseif ($bid == 6 or $bid == 7) { $data['linkTypeID'] = "6"; } elseif ($bid == 44) { $data['linkTypeID'] = "7"; } elseif ($bid == 96) { $data['linkTypeID'] = "8"; } else { $data['linkTypeID'] = "1"; } $data['title'] = LinkType::where('id', $data['linkTypeID'])->value('title'); } foreach ($data['LinkTypes']->toArray() as $key => $val) { if ($val['typename'] === $linkData['typename']) { $data['SelectedLinkType'] = $val; break; } } return view('studio/edit-link', $data); } //Save add link public function saveLink(request $request) { $linkType = LinkType::find($request->linktype_id); $LinkTitle = ($request->link_text ?? $request->link_title) ?? $request->title; $LinkURL = $request->link_url ?? $request->link; $OrigLink = Link::find($request->linkid); $customParams = []; foreach ($request->all() as $key => $param) { //echo $key . " = " . $param . "
"; if (str_starts_with($key, "_") || in_array($key, ['linktype_id', 'linktype_title', 'link_text', 'link_url'])) continue; $customParams[$key] = $param; } $userId = Auth::user()->id; $button = Button::where('name', $request->button)->first(); if ($button && empty($LinkTitle)) $LinkTitle = ucwords($button->name); if ($linkType->typename == 'video' && empty($LinkTitle)) { $embed = OEmbed::get($LinkURL); if ($embed) { $LinkTitle = $embed->data()['title']; } } $message = (ucwords($button?->name) ?? ucwords($linkType->typename)). " has been "; if ($OrigLink) { //EDITING EXISTING $isCustomWebsite = $customParams['GetSiteIcon'] ?? null; $SpacerHeight = $customParams['height'] ?? null; if($linkType->typename == "link" and $isCustomWebsite == "1"){ $OrigLink->update([ 'link' => $LinkURL, 'title' => $LinkTitle, 'button_id' => "2", ]); }elseif($linkType->typename == "link"){ $OrigLink->update([ 'link' => $LinkURL, 'title' => $LinkTitle, 'button_id' => "1", ]); }elseif($linkType->typename == "spacer"){ $OrigLink->update([ 'link' => $LinkURL, 'title' => $customParams['height'] ?? null, 'button_id' => "43", ]); }elseif($linkType->typename == "heading"){ $OrigLink->update([ 'link' => $LinkURL, 'title' => $LinkTitle, 'button_id' => "42", ]); }elseif($linkType->typename == "text"){ $OrigLink->update([ 'button_id' => "93", 'title' => $request->text, ]); }elseif($linkType->typename == "email"){ $LinkURL = "mailto:".$LinkURL; $OrigLink->update([ 'link' => $LinkURL, 'button_id' => $button?->id, 'title' => $LinkTitle, ]); }elseif($linkType->typename == "telephone"){ $LinkURL = "tel:".$LinkURL; $OrigLink->update([ 'link' => $LinkURL, 'button_id' => $button?->id, 'title' => $LinkTitle, ]); }elseif($linkType->typename == "vcard"){ $prefix = $request->input('prefix'); $firstName = $request->input('first_name'); $middleName = $request->input('middle_name'); $lastName = $request->input('last_name'); $suffix = $request->input('suffix'); $nickname = $request->input('nickname'); $organization = $request->input('organization'); $title = $request->input('title'); $role = $request->input('role'); $workUrl = $request->input('work_url'); $email = $request->input('email'); $workEmail = $request->input('work_email'); $homePhone = $request->input('home_phone'); $workPhone = $request->input('work_phone'); $cellPhone = $request->input('cell_phone'); $homeAddressLabel = $request->input('home_address_label'); $homeAddressStreet = $request->input('home_address_street'); $homeAddressCity = $request->input('home_address_city'); $homeAddressState = $request->input('home_address_state'); $homeAddressZip = $request->input('home_address_zip'); $homeAddressCountry = $request->input('home_address_country'); $workAddressLabel = $request->input('work_address_label'); $workAddressStreet = $request->input('work_address_street'); $workAddressCity = $request->input('work_address_city'); $workAddressState = $request->input('work_address_state'); $workAddressZip = $request->input('work_address_zip'); $workAddressCountry = $request->input('work_address_country'); // Create a new vCard instance $vCard = new VCard(); // Set the personal information $vCard->addName($lastName, $firstName, $middleName, $prefix, $suffix); $vCard->addRole($role); // Set the organization information $vCard->addCompany($organization); $vCard->addJobtitle($title); $vCard->addUrl($workUrl); // Set the phone numbers $vCard->addPhoneNumber($homePhone, 'HOME'); $vCard->addPhoneNumber($workPhone, 'WORK'); $vCard->addPhoneNumber($cellPhone, 'CELL'); // Set the email addresses $vCard->addEmail($email, 'HOME'); $vCard->addEmail($workEmail, 'WORK'); // Set the addresses $vCard->addAddress($homeAddressStreet, null, null, $homeAddressCity, $homeAddressState, $homeAddressZip, $homeAddressCountry, 'HOME', $homeAddressLabel); $vCard->addAddress($workAddressStreet, null, null, $workAddressCity, $workAddressState, $workAddressZip, $workAddressCountry, 'WORK', $workAddressLabel); // Generate the vCard file content $LinkURL = $vCard->getOutput(); $OrigLink->update([ 'link' => $LinkURL, 'button_id' => 96, 'title' => $LinkTitle, ]); }else{ $OrigLink->update([ 'link' => $LinkURL, 'title' => $LinkTitle, 'button_id' => $button?->id, ]); } $message .="updated"; } else { // ADDING NEW $isCustomWebsite = $customParams['GetSiteIcon'] ?? null; $SpacerHeight = $customParams['height'] ?? null; $links = new Link; $links->link = $LinkURL; $links->user_id = $userId; if($linkType->typename == "spacer"){ $links->title = $SpacerHeight; }else{ $links->title = $LinkTitle; } if($linkType->typename == "link" and $isCustomWebsite == "1"){ $links->button_id = "2"; }elseif($linkType->typename == "link"){ $links->button_id = "1"; }elseif($linkType->typename == "spacer"){ $links->button_id = "43"; }elseif($linkType->typename == "heading"){ $links->button_id = "42"; }elseif($linkType->typename == "text"){ $links->button_id = "93"; $links->title = $request->text; }elseif($linkType->typename == "email"){ $links->link = "mailto:".$links->link; $links->button_id = $button?->id; }elseif($linkType->typename == "telephone"){ $links->link = "tel:".$links->link; $links->button_id = $button?->id; }elseif($linkType->typename == "vcard"){ $prefix = $request->input('prefix'); $firstName = $request->input('first_name'); $middleName = $request->input('middle_name'); $lastName = $request->input('last_name'); $suffix = $request->input('suffix'); $nickname = $request->input('nickname'); $organization = $request->input('organization'); $title = $request->input('title'); $role = $request->input('role'); $workUrl = $request->input('work_url'); $email = $request->input('email'); $workEmail = $request->input('work_email'); $homePhone = $request->input('home_phone'); $workPhone = $request->input('work_phone'); $cellPhone = $request->input('cell_phone'); $homeAddressLabel = $request->input('home_address_label'); $homeAddressStreet = $request->input('home_address_street'); $homeAddressCity = $request->input('home_address_city'); $homeAddressState = $request->input('home_address_state'); $homeAddressZip = $request->input('home_address_zip'); $homeAddressCountry = $request->input('home_address_country'); $workAddressLabel = $request->input('work_address_label'); $workAddressStreet = $request->input('work_address_street'); $workAddressCity = $request->input('work_address_city'); $workAddressState = $request->input('work_address_state'); $workAddressZip = $request->input('work_address_zip'); $workAddressCountry = $request->input('work_address_country'); // Create a new vCard instance $vCard = new VCard(); // Set the personal information $vCard->addName($lastName, $firstName, $middleName, $prefix, $suffix); $vCard->addRole($role); // Set the organization information $vCard->addCompany($organization); $vCard->addJobtitle($title); $vCard->addUrl($workUrl); // Set the phone numbers $vCard->addPhoneNumber($homePhone, 'HOME'); $vCard->addPhoneNumber($workPhone, 'WORK'); $vCard->addPhoneNumber($cellPhone, 'CELL'); // Set the email addresses $vCard->addEmail($email, 'HOME'); $vCard->addEmail($workEmail, 'WORK'); // Set the addresses $vCard->addAddress($homeAddressStreet, null, null, $homeAddressCity, $homeAddressState, $homeAddressZip, $homeAddressCountry, 'HOME', $homeAddressLabel); $vCard->addAddress($workAddressStreet, null, null, $workAddressCity, $workAddressState, $workAddressZip, $workAddressCountry, 'WORK', $workAddressLabel); // Generate the vCard file content $links->link = $vCard->getOutput(); $links->button_id = 96; }else{ $links->button_id = $button?->id; } $links->save(); $links->order = ($links->id - 1); $links->save(); $message .= "added"; } return Redirect('studio/links') ->with('success', $message); } public function sortLinks(Request $request) { $linkOrders = $request->input("linkOrders", []); $currentPage = $request->input("currentPage", 1); $perPage = $request->input("perPage", 0); if ($perPage == 0) { $currentPage = 1; } $linkOrders = array_unique(array_filter($linkOrders)); if (!$linkOrders || $currentPage < 1) { return response()->json([ 'status' => 'ERROR', ]); } $newOrder = $perPage * ($currentPage - 1); $linkNewOrders = []; foreach ($linkOrders as $linkId) { if ($linkId < 0) { continue; } $linkNewOrders[$linkId] = $newOrder; Link::where("id", $linkId) ->update([ 'order' => $newOrder ]); $newOrder++; } return response()->json([ 'status' => 'OK', 'linkOrders' => $linkNewOrders, ]); } //Count the number of clicks and redirect to link public function clickNumber(request $request) { $linkId = $request->id; $link = Link::find($linkId); $link = $link->link; Link::where('id', $linkId)->increment('click_number', 1); return redirect()->away($link); } //Download Vcard public function vcard(Request $request) { $linkId = $request->id; $link = Link::findOrFail($linkId); // find the link with the given ID or throw an exception $buttonValue = $link->button_value; $content = $link->content; Link::where('id', $linkId)->increment('click_number', 1); // build the vCard string $vCard = "BEGIN:VCARD\r\nVERSION:3.0\r\n"; $vCard .= "FN:$buttonValue\r\n"; $vCard .= "NOTE:$content\r\n"; $vCard .= "END:VCARD\r\n"; // return the vCard content as a downloadable response return response($vCard) ->header('Content-Type', 'text/vcard') ->header('Content-Disposition', 'attachment; filename=vcard.vcf'); } //Show link, click number, up link in links page public function showLinks() { $userId = Auth::user()->id; $data['pagePage'] = 10; $data['links'] = Link::select('id', 'link', 'title', 'order', 'click_number', 'up_link', 'links.button_id')->where('user_id', $userId)->orderBy('up_link', 'asc')->orderBy('order', 'asc')->paginate(99999); return view('studio/links', $data); } //Delete link public function deleteLink(request $request) { $linkId = $request->id; Link::where('id', $linkId)->delete(); $directory = base_path("studio/favicon/icons"); $files = scandir($directory); foreach($files as $file) { if (strpos($file, $linkId.".") !== false) { $pathinfo = pathinfo($file, PATHINFO_EXTENSION);}} if (isset($pathinfo)) { try{File::delete(base_path("studio/favicon/icons")."/".$linkId.".".$pathinfo);} catch (exception $e) {} } return redirect('/studio/links'); } //Delete icon public function clearIcon(request $request) { $linkId = $request->id; $directory = base_path("studio/favicon/icons"); $files = scandir($directory); foreach($files as $file) { if (strpos($file, $linkId.".") !== false) { $pathinfo = pathinfo($file, PATHINFO_EXTENSION);}} if (isset($pathinfo)) { try{File::delete(base_path("studio/favicon/icons")."/".$linkId.".".$pathinfo);} catch (exception $e) {} } return redirect('/studio/links'); } //Raise link on the littlelink page public function upLink(request $request) { $linkId = $request->id; $upLink = $request->up; if ($upLink == 'yes') { $up = 'no'; } elseif ($upLink == 'no') { $up = 'yes'; } Link::where('id', $linkId)->update(['up_link' => $up]); return back(); } //Show link to edit public function showLink(request $request) { $linkId = $request->id; $link = Link::where('id', $linkId)->value('link'); $title = Link::where('id', $linkId)->value('title'); $order = Link::where('id', $linkId)->value('order'); $custom_css = Link::where('id', $linkId)->value('custom_css'); $buttonId = Link::where('id', $linkId)->value('button_id'); $buttonName = Button::where('id', $buttonId)->value('name'); $buttons = Button::select('id', 'name')->orderBy('name', 'asc')->get(); return view('studio/edit-link', ['custom_css' => $custom_css, 'buttonId' => $buttonId, 'buttons' => $buttons, 'link' => $link, 'title' => $title, 'order' => $order, 'id' => $linkId, 'buttonName' => $buttonName]); } //Show custom CSS + custom icon public function showCSS(request $request) { $linkId = $request->id; $link = Link::where('id', $linkId)->value('link'); $title = Link::where('id', $linkId)->value('title'); $order = Link::where('id', $linkId)->value('order'); $custom_css = Link::where('id', $linkId)->value('custom_css'); $custom_icon = Link::where('id', $linkId)->value('custom_icon'); $buttonId = Link::where('id', $linkId)->value('button_id'); $buttons = Button::select('id', 'name')->get(); return view('studio/button-editor', ['custom_icon' => $custom_icon, 'custom_css' => $custom_css, 'buttonId' => $buttonId, 'buttons' => $buttons, 'link' => $link, 'title' => $title, 'order' => $order, 'id' => $linkId]); } //Save edit link public function editLink(request $request) { $request->validate([ 'link' => 'required', 'title' => 'required', 'button' => 'required', ]); if (stringStartsWith($request->link, 'http://') == 'true' or stringStartsWith($request->link, 'https://') == 'true' or stringStartsWith($request->link, 'mailto:') == 'true') $link1 = $request->link; else $link1 = 'https://' . $request->link; if (stringEndsWith($request->link, '/') == 'true') $link = rtrim($link1, "/ "); else $link = $link1; $title = $request->title; $order = $request->order; $button = $request->button; $linkId = $request->id; $buttonId = Button::select('id')->where('name', $button)->value('id'); Link::where('id', $linkId)->update(['link' => $link, 'title' => $title, 'order' => $order, 'button_id' => $buttonId]); return redirect('/studio/links'); } //Save edit custom CSS + custom icon public function editCSS(request $request) { $linkId = $request->id; $custom_icon = $request->custom_icon; $custom_css = $request->custom_css; if ($request->custom_css == "" and $request->custom_icon = !"") { Link::where('id', $linkId)->update(['custom_icon' => $custom_icon]); } elseif ($request->custom_icon == "" and $request->custom_css = !"") { Link::where('id', $linkId)->update(['custom_css' => $custom_css]); } else { Link::where('id', $linkId)->update([]); } return Redirect('#result'); } //Show littlelinke page for edit public function showPage(request $request) { $userId = Auth::user()->id; $data['pages'] = User::where('id', $userId)->select('littlelink_name', 'littlelink_description', 'image', 'name')->get(); return view('/studio/page', $data); } //Save littlelink page (name, description, logo) public function editPage(request $request) { $request->validate([ 'littlelink_name' => 'sometimes|max:255|string|isunique:users,id,'.Auth::id(), 'name' => 'sometimes|max:255|string', ]); $userId = Auth::user()->id; $littlelink_name = Auth::user()->littlelink_name; $profilePhoto = $request->file('image'); $pageName = $request->littlelink_name; $pageDescription = strip_tags($request->pageDescription,'