2023-02-16 15:38:17 +01:00
|
|
|
<?php use App\Models\UserData; ?>
|
2021-04-16 01:00:00 +02:00
|
|
|
@extends('layouts.sidebar')
|
|
|
|
|
|
|
|
@section('content')
|
|
|
|
|
2023-04-26 15:44:39 +02:00
|
|
|
<div class="conatiner-fluid content-inner mt-n5 py-0">
|
|
|
|
<div class="row">
|
|
|
|
|
|
|
|
<div class="col-lg-12">
|
|
|
|
<div class="card rounded">
|
|
|
|
<div class="card-body">
|
|
|
|
<div class="row">
|
|
|
|
<div class="col-sm-12">
|
2022-11-08 16:11:59 +01:00
|
|
|
|
2023-04-26 15:44:39 +02:00
|
|
|
<style>
|
|
|
|
.ck-editor__editable[role="textbox"] {
|
|
|
|
/* editing area */
|
|
|
|
min-height: 200px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.ck-content .image {
|
|
|
|
/* block images */
|
|
|
|
max-width: 80%;
|
|
|
|
margin: 20px auto;
|
|
|
|
}
|
|
|
|
|
|
|
|
</style>
|
|
|
|
<style>
|
|
|
|
@supports (-webkit-appearance: none) or (-moz-appearance: none) {
|
|
|
|
input[type=checkbox],
|
|
|
|
input[type=radio] {
|
|
|
|
--active: var(--bs-primary);
|
|
|
|
--active-inner: #fff;
|
|
|
|
--focus: 2px var(--bs-primary);
|
|
|
|
--border: #BBC1E1;
|
|
|
|
--border-hover: var(--bs-primary);
|
|
|
|
--background: #fff;
|
|
|
|
--disabled: #F6F8FF;
|
|
|
|
--disabled-inner: #E1E6F9;
|
|
|
|
-webkit-appearance: none;
|
|
|
|
-moz-appearance: none;
|
|
|
|
height: 21px;
|
|
|
|
outline: none;
|
|
|
|
display: inline-block;
|
|
|
|
vertical-align: top;
|
|
|
|
position: relative;
|
|
|
|
margin: 0;
|
|
|
|
cursor: pointer;
|
|
|
|
border: 1px solid var(--bc, var(--border));
|
|
|
|
background: var(--b, var(--background));
|
|
|
|
transition: background 0.3s, border-color 0.3s, box-shadow 0.2s;
|
|
|
|
}
|
|
|
|
input[type=checkbox]:after,
|
|
|
|
input[type=radio]:after {
|
|
|
|
content: "";
|
|
|
|
display: block;
|
|
|
|
left: 0;
|
|
|
|
top: 0;
|
|
|
|
position: absolute;
|
|
|
|
transition: transform var(--d-t, 0.3s) var(--d-t-e, ease), opacity var(--d-o, 0.2s);
|
|
|
|
}
|
|
|
|
input[type=checkbox]:checked,
|
|
|
|
input[type=radio]:checked {
|
|
|
|
--b: var(--active);
|
|
|
|
--bc: var(--active);
|
|
|
|
--d-o: .3s;
|
|
|
|
--d-t: .6s;
|
|
|
|
--d-t-e: cubic-bezier(.2, .85, .32, 1.2);
|
|
|
|
}
|
|
|
|
input[type=checkbox]:disabled,
|
|
|
|
input[type=radio]:disabled {
|
|
|
|
--b: var(--disabled);
|
|
|
|
cursor: not-allowed;
|
|
|
|
opacity: 0.9;
|
|
|
|
}
|
|
|
|
input[type=checkbox]:disabled:checked,
|
|
|
|
input[type=radio]:disabled:checked {
|
|
|
|
--b: var(--disabled-inner);
|
|
|
|
--bc: var(--border);
|
|
|
|
}
|
|
|
|
input[type=checkbox]:disabled + label,
|
|
|
|
input[type=radio]:disabled + label {
|
|
|
|
cursor: not-allowed;
|
|
|
|
}
|
|
|
|
input[type=checkbox]:hover:not(:checked):not(:disabled),
|
|
|
|
input[type=radio]:hover:not(:checked):not(:disabled) {
|
|
|
|
--bc: var(--border-hover);
|
|
|
|
}
|
|
|
|
input[type=checkbox]:focus,
|
|
|
|
input[type=radio]:focus {
|
|
|
|
box-shadow: 0 0 0 var(--focus);
|
|
|
|
}
|
|
|
|
input[type=checkbox]:not(.switch),
|
|
|
|
input[type=radio]:not(.switch) {
|
|
|
|
width: 21px;
|
|
|
|
}
|
|
|
|
input[type=checkbox]:not(.switch):after,
|
|
|
|
input[type=radio]:not(.switch):after {
|
|
|
|
opacity: var(--o, 0);
|
|
|
|
}
|
|
|
|
input[type=checkbox]:not(.switch):checked,
|
|
|
|
input[type=radio]:not(.switch):checked {
|
|
|
|
--o: 1;
|
|
|
|
}
|
|
|
|
input[type=checkbox] + label,
|
|
|
|
input[type=radio] + label {
|
|
|
|
font-size: 14px;
|
|
|
|
line-height: 21px;
|
|
|
|
display: inline-block;
|
|
|
|
vertical-align: top;
|
|
|
|
cursor: pointer;
|
|
|
|
margin-left: 4px;
|
|
|
|
}
|
|
|
|
|
|
|
|
input[type=checkbox]:not(.switch) {
|
|
|
|
border-radius: 7px;
|
|
|
|
}
|
|
|
|
input[type=checkbox]:not(.switch):after {
|
|
|
|
width: 5px;
|
|
|
|
height: 9px;
|
|
|
|
border: 2px solid var(--active-inner);
|
|
|
|
border-top: 0;
|
|
|
|
border-left: 0;
|
|
|
|
left: 7px;
|
|
|
|
top: 4px;
|
|
|
|
transform: rotate(var(--r, 20deg));
|
|
|
|
}
|
|
|
|
input[type=checkbox]:not(.switch):checked {
|
|
|
|
--r: 43deg;
|
|
|
|
}
|
|
|
|
input[type=checkbox].switch {
|
|
|
|
width: 38px;
|
|
|
|
border-radius: 11px;
|
|
|
|
}
|
|
|
|
input[type=checkbox].switch:after {
|
|
|
|
left: 2px;
|
|
|
|
top: 2px;
|
|
|
|
border-radius: 50%;
|
|
|
|
width: 15px;
|
|
|
|
height: 15px;
|
|
|
|
background: var(--ab, var(--border));
|
|
|
|
transform: translateX(var(--x, 0));
|
|
|
|
}
|
|
|
|
input[type=checkbox].switch:checked {
|
|
|
|
--ab: var(--active-inner);
|
|
|
|
--x: 17px;
|
|
|
|
}
|
|
|
|
input[type=checkbox].switch:disabled:not(:checked):after {
|
|
|
|
opacity: 0.6;
|
|
|
|
}
|
|
|
|
|
|
|
|
input[type=radio] {
|
|
|
|
border-radius: 50%;
|
|
|
|
}
|
|
|
|
input[type=radio]:after {
|
|
|
|
width: 19px;
|
|
|
|
height: 19px;
|
|
|
|
border-radius: 50%;
|
|
|
|
background: var(--active-inner);
|
|
|
|
opacity: 0;
|
|
|
|
transform: scale(var(--s, 0.7));
|
|
|
|
}
|
|
|
|
input[type=radio]:checked {
|
|
|
|
--s: .5;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.txt-label{
|
|
|
|
color: white;
|
|
|
|
padding-left: 5px;
|
|
|
|
font-size: 200%;
|
|
|
|
position: relative;
|
|
|
|
}
|
|
|
|
.toggle-btn{
|
|
|
|
padding-left: 20px;
|
|
|
|
}
|
|
|
|
.ch2{
|
|
|
|
padding-top: 60px;
|
|
|
|
}
|
|
|
|
</style>
|
|
|
|
<div class="profile-img position-relative me-3 mb-3 mb-lg-0 profile-logo profile-logo1">
|
|
|
|
@if(file_exists(base_path(findAvatar(Auth::user()->id))))
|
2023-06-02 20:11:04 +02:00
|
|
|
<img src="{{ url(findAvatar(Auth::user()->id)) }}" class="img-fluid rounded-pill avatar-100 bg-white" width="100" height="100" draggable="false" style="object-fit:cover;">
|
2023-05-17 12:35:49 +02:00
|
|
|
@elseif(file_exists(base_path("assets/linkstack/images/").findFile('avatar')))
|
2023-06-02 20:11:04 +02:00
|
|
|
<img src="{{ url("assets/linkstack/images/")."/".findFile('avatar') }}" class="img-fluid rounded-pill avatar-100 bg-white" width="100" height="100" draggable="false">
|
2023-04-26 15:44:39 +02:00
|
|
|
@else
|
2023-06-02 20:11:04 +02:00
|
|
|
<img src="{{ asset('assets/linkstack/images/logo.svg') }}" class="img-fluid rounded-pill avatar-100 bg-white" width="100" height="100" draggable="false">
|
2023-04-26 15:44:39 +02:00
|
|
|
@endif
|
|
|
|
@if(file_exists(base_path(findAvatar(Auth::user()->id))))
|
|
|
|
<div class="upload-icone bg-primary">
|
|
|
|
<a href="{{ route('delProfilePicture') }}" style="top:1px;position:relative;" data-bs-toggle="tooltip" data-bs-placement="right" title="Delete profile picture"><i class="bi bi-trash-fill text-white"></i></a>
|
|
|
|
<input class="file-upload" type="file" accept="image/*">
|
|
|
|
</div>
|
|
|
|
@endif
|
|
|
|
</div>
|
|
|
|
<section class='text-gray-400'>
|
2023-06-16 22:15:29 +02:00
|
|
|
<h3 class="mb-4 card-header"><i class="bi bi-file-earmark-break"> {{__('messages.My Profile')}}</i></h3>
|
2023-07-27 15:45:05 +02:00
|
|
|
@if($errors->any())
|
|
|
|
<div class="alert alert-danger d-flex align-items-center" role="alert">
|
|
|
|
<svg class="bi flex-shrink-0 me-2" width="24" height="24">
|
|
|
|
<use xlink:href="#exclamation-triangle-fill"></use>
|
|
|
|
</svg>
|
|
|
|
<div>
|
|
|
|
@foreach ($errors->all() as $error)
|
|
|
|
{{ $error }}
|
|
|
|
@endforeach
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
@endif
|
2023-04-26 15:44:39 +02:00
|
|
|
<div>
|
|
|
|
|
|
|
|
<div></div>
|
|
|
|
@foreach($pages as $page)
|
|
|
|
<form action="{{ route('editPage') }}" enctype="multipart/form-data" method="post">
|
|
|
|
@csrf
|
|
|
|
@if($page->littlelink_name != '')
|
|
|
|
<div class="form-group col-lg-8">
|
2023-06-09 11:03:41 +02:00
|
|
|
<label class="form-label" for="customFile">{{__('messages.Profile Picture')}}</label>
|
2023-07-27 15:45:05 +02:00
|
|
|
<input type="file" accept="image/jpeg,image/jpg,image/png,image/webp" name="image" class="form-control" id="customFile">
|
2023-04-26 15:44:39 +02:00
|
|
|
</div>
|
|
|
|
@endif
|
|
|
|
|
|
|
|
<!--<div class="form-group col-lg-8">
|
|
|
|
<label>Path name</label>
|
|
|
|
@<input type="text" class="form-control" name="pageName" value="{{ $page->littlelink_name ?? '' }}">
|
|
|
|
</div>-->
|
|
|
|
|
|
|
|
<div class="form-group col-lg-8">
|
|
|
|
<?php
|
|
|
|
$url = $_SERVER['REQUEST_URI'];
|
|
|
|
if( strpos( $url, "no_page_name" ) == true ) echo '<span style="color:#FF0000; font-size:120%;">You do not have a Page URL</span>'; ?>
|
|
|
|
<br>
|
2023-12-18 15:50:27 +01:00
|
|
|
<label for="littlelink_name" class="form-label">{{__('messages.Page URL')}}</label>
|
|
|
|
<div class="input-group mb-3 has-validation">
|
|
|
|
<span class="input-group-text" id="basic-addon3">{{str_replace(['http://', 'https://'], '', url(''))}}/@</span>
|
|
|
|
<input type="littlelink_name" class="form-control" id="littlelink_name" name="littlelink_name" aria-describedby="littlelink_name" value="{{ $page->littlelink_name ?? '' }}" :value="old('littlelink_name')" required autofocus >
|
2023-04-26 15:44:39 +02:00
|
|
|
</div>
|
2023-12-18 15:50:27 +01:00
|
|
|
<script>var exceptionvar = " value="{{ $page->littlelink_name }}";</script>
|
|
|
|
@include('auth.url-validation')
|
2023-04-26 15:44:39 +02:00
|
|
|
|
2023-06-09 11:03:41 +02:00
|
|
|
<label style="margin-top:15px">{{__('messages.Display name')}}</label>
|
2023-04-26 15:44:39 +02:00
|
|
|
<div class="input-group">
|
|
|
|
{{-- <div class="input-group-prepend">
|
2023-06-09 11:03:41 +02:00
|
|
|
<div class="input-group-text">{{__('messages.Name')}}</div>
|
2023-04-26 15:44:39 +02:00
|
|
|
</div> --}}
|
|
|
|
<input type="text" class="form-control" name="name" value="{{ $page->name }}" required>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="form-group col-lg-8">
|
2023-06-09 11:03:41 +02:00
|
|
|
<label>{{__('messages.Page Description')}}</label>
|
2023-04-26 15:44:39 +02:00
|
|
|
<textarea class="form-control @if(env('ALLOW_USER_HTML') === true) ckeditor @endif" name="pageDescription" rows="3">{{ $page->littlelink_description ?? '' }}</textarea>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
@if(auth()->user()->role == 'admin' || auth()->user()->role == 'vip')
|
|
|
|
<div class="form-group col-lg-8">
|
2023-06-09 11:03:41 +02:00
|
|
|
<h5 style="margin-top:50px"> {{__('messages.Show checkmark')}}</h5>
|
|
|
|
<p class="text-muted">{{__('messages.disableverified')}}</p>
|
2023-04-26 15:44:39 +02:00
|
|
|
<div class="mb-3 form-check form-switch">
|
|
|
|
<input name="checkmark" class="switch toggle-btn" type="checkbox" id="checkmark" <?php if(UserData::getData(Auth::user()->id, 'checkmark') == true){echo 'checked';} ?> />
|
2023-06-09 11:03:41 +02:00
|
|
|
<label class="form-check-label" for="checkmark">{{__('messages.Enable')}}</label>
|
2023-04-26 15:44:39 +02:00
|
|
|
</div>
|
|
|
|
<input type="hidden" name="_token" value="{{csrf_token()}}">
|
|
|
|
@endif
|
|
|
|
@endforeach
|
2022-11-08 16:11:59 +01:00
|
|
|
|
2023-04-26 15:44:39 +02:00
|
|
|
<div class="form-group col-lg-8">
|
2023-06-09 11:03:41 +02:00
|
|
|
<h5 style="margin-top:50px">{{__('messages.Show share button')}}</h5>
|
|
|
|
<p class="text-muted">{{__('messages.disablesharebutton')}}</p>
|
2023-04-26 15:44:39 +02:00
|
|
|
<div class="mb-3 form-check form-switch">
|
|
|
|
<input name="sharebtn" class="switch toggle-btn" type="checkbox" id="sharebtn" <?php if(UserData::getData(Auth::user()->id, 'disable-sharebtn') != "true"){echo 'checked';} ?> />
|
2023-06-09 11:03:41 +02:00
|
|
|
<label class="form-check-label" for="sharebtn">{{__('messages.Enable')}}</label>
|
2023-04-26 15:44:39 +02:00
|
|
|
</div>
|
2022-11-08 16:11:59 +01:00
|
|
|
|
2023-12-15 17:56:18 +01:00
|
|
|
<div class="form-group col-lg-8">
|
|
|
|
<h5 style="margin-top:50px">{{__('messages.Open links in new tab')}}</h5>
|
|
|
|
<p class="text-muted">{{__('messages.openlinksnewtab')}}</p>
|
|
|
|
<div class="mb-3 form-check form-switch">
|
|
|
|
<input name="tablinks" class="switch toggle-btn" type="checkbox" id="tablinks" <?php if(UserData::getData(Auth::user()->id, 'links-new-tab') != false){echo 'checked';} ?> />
|
|
|
|
<label class="form-check-label" for="tablinks">{{__('messages.Enable')}}</label>
|
|
|
|
</div>
|
|
|
|
|
2023-12-18 15:50:27 +01:00
|
|
|
<button id="submit-btn" type="submit" class="mt-3 ml-3 btn btn-primary">{{__('messages.Save')}}</button>
|
2023-04-26 15:44:39 +02:00
|
|
|
</form>
|
2022-11-08 16:11:59 +01:00
|
|
|
|
2023-04-26 15:44:39 +02:00
|
|
|
@if(env('ALLOW_USER_HTML') === true)
|
|
|
|
<script src="{{ asset('assets/external-dependencies/ckeditor.js') }}"></script>
|
|
|
|
<script>
|
2023-06-22 21:47:42 +02:00
|
|
|
ClassicEditor
|
|
|
|
.create(document.querySelector('.ckeditor'), {
|
|
|
|
toolbar: {
|
|
|
|
items: [
|
|
|
|
'exportPDF', 'exportWord', '|',
|
|
|
|
'findAndReplace', 'selectAll', '|',
|
|
|
|
'heading', '|',
|
|
|
|
'bold', 'italic', 'strikethrough', 'underline', 'code', 'subscript', 'superscript', 'removeFormat', '|',
|
|
|
|
'bulletedList', 'numberedList', 'todoList', '|',
|
|
|
|
'outdent', 'indent', '|',
|
|
|
|
'undo', 'redo',
|
|
|
|
'fontSize', 'fontFamily', 'fontColor', 'fontBackgroundColor', 'highlight', '|',
|
|
|
|
'alignment', '|',
|
|
|
|
'link', 'blockQuote', '|',
|
|
|
|
'specialCharacters', 'horizontalLine', '|',
|
|
|
|
'textPartLanguage', '|',
|
|
|
|
],
|
|
|
|
shouldNotGroupWhenFull: true
|
|
|
|
},
|
|
|
|
fontFamily: {
|
|
|
|
options: [
|
|
|
|
'default',
|
|
|
|
'Arial, Helvetica, sans-serif',
|
|
|
|
'Courier New, Courier, monospace',
|
|
|
|
'Georgia, serif',
|
|
|
|
'Lucida Sans Unicode, Lucida Grande, sans-serif',
|
|
|
|
'Tahoma, Geneva, sans-serif',
|
|
|
|
'Times New Roman, Times, serif',
|
|
|
|
'Trebuchet MS, Helvetica, sans-serif',
|
|
|
|
'Verdana, Geneva, sans-serif'
|
|
|
|
],
|
|
|
|
supportAllValues: true
|
|
|
|
},
|
|
|
|
fontSize: {
|
|
|
|
options: [10, 12, 14, 'default', 18, 20, 22],
|
|
|
|
supportAllValues: true
|
|
|
|
},
|
|
|
|
link: {
|
|
|
|
addTargetToExternalLinks: true, // Add this option to open external links in a new tab
|
|
|
|
defaultProtocol: 'http://',
|
|
|
|
decorators: {
|
|
|
|
addTargetToExternalLinks: {
|
|
|
|
mode: 'manual',
|
|
|
|
label: 'Open in new tab',
|
|
|
|
attributes: {
|
|
|
|
target: '_blank',
|
|
|
|
rel: 'noopener noreferrer'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.catch(error => {
|
|
|
|
console.error(error);
|
|
|
|
});
|
|
|
|
</script>
|
2023-04-26 15:44:39 +02:00
|
|
|
|
|
|
|
@endif
|
|
|
|
</div>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
</section>
|
2022-11-08 16:11:59 +01:00
|
|
|
|
2023-04-26 15:44:39 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2022-11-08 16:11:59 +01:00
|
|
|
</div>
|
2023-04-26 15:44:39 +02:00
|
|
|
</div>
|
2023-02-16 15:38:17 +01:00
|
|
|
|
2021-04-16 01:00:00 +02:00
|
|
|
@endsection
|