first change

This commit is contained in:
2025-07-27 17:40:56 +05:45
commit f8b9a6725b
3152 changed files with 229528 additions and 0 deletions

View File

@@ -0,0 +1,250 @@
@php
$page->section ??= [];
@endphp
@extends('layouts.app')
@section('content')
<x-dashboard.breadcumb :title="$title" />
<div class="container-fluid">
@if ($errors->any())
<x-flash-message type="danger" :messages="$errors->all()" />
@endif
<div class="row">
<div class="col-xl-12">
<div>
<a href="{{ route('page.index') }}" class="btn btn-sm btn-primary mb-4">Page List</a>
<a href="javascript:void(0);" data-link="{{ route('page.edit', $page->id) }}" type="button"
class="btn btn-sm btn-primary mb-4 customize-btn edit-item-btn">Customize Page</a>
</div>
{{ html()->modelForm($page, 'PUT')->route('page.updateContent', $page->id)->class('needs-validation')->attributes(['novalidate'])->open() }}
<div class="row">
<div class="col-xl-8">
<div class="card h-auto">
<div class="card-body">
<div class="row gy-3">
<div class="col-12">
{{ html()->label('Title')->class('form-label')->for('title') }}
{{ html()->span('*')->class('text-danger') }}
{{ html()->text('title')->class('form-control bg-primary-subtle')->isReadonly(true) }}
</div>
<div class="col-12">
{{ html()->label('Description (Short)')->class('form-label')->for('short_description') }}
{{ html()->textarea('short_description')->class('form-control')->placeholder('Enter Description (Short)')->rows(5) }}
</div>
<div class="col-12">
{{ html()->label('Description')->class('form-label')->for('description') }}
{{ html()->textarea('description')->class('form-control ckeditor-classic') }}
</div>
</div>
</div>
</div>
@if ($page->type == 'page')
<div class="card slug-section">
<div class="card-header d-flex jusitfy-content-between align-items-center">
<h6 class="card-title mb-0 fs-14">URL Generator</h6>
</div>
<div class="card-body">
<div class="row">
<div class="col-lg-6">
{{ html()->label('Parent(Optional)')->class('form-label')->for('parent_slug') }}
{{ html()->text('parent_slug')->class('form-control') }}
</div>
<div class="col-lg-6">
{{ html()->label('Slug')->class('form-label')->for('slug') }}
{{ html()->span('*')->class('text-danger') }}
{{ html()->text('slug')->class('form-control')->placeholder('Page Slug')->required() }}
</div>
</div>
</div>
</div>
@endif
@if (in_array('custom-field-section', $page->section))
<x-ccms::custom-form-field :data="$page->custom ?? []" />
@endif
@if (in_array('meta-section', $page->section))
<div class="card meta-section">
<div class="card-header">
<h6 class="card-title mb-0 fs-14">Meta</h6>
</div>
<div class="card-body">
<div class="row">
<div class="col-xl-12 col-sm-12">
{{ html()->label('Meta Title')->class('form-label')->for('meta_title') }}
{{ html()->text('meta_title')->class('form-control mb-3')->placeholder('Meta Title') }}
</div>
<div class="col-xl-12 col-sm-12">
{{ html()->label('Meta Keywords')->class('form-label')->for('meta_keywords') }}
{{ html()->textarea('meta_keywords')->class('form-control mb-3')->placeholder('Meta Keywords') }}
</div>
<div class="col-xl-12 col-sm-12">
{{ html()->label('Meta Description')->class('form-label')->for('meta_description') }}
{{ html()->textarea('meta_description')->class('form-control mb-3')->placeholder('Meta Description')->rows(3) }}
</div>
</div>
</div>
</div>
@endif
</div>
<div class="col-xl-4">
<div class="card">
<div class="card-header">
<h6 class="card-title mb-0 fs-14">
Published
</h6>
</div>
<div class="card-body">
{{ html()->label('Status')->class('form-label visually-hidden')->for('status') }}
{{ html()->select('status', config('constants.page_status_options'))->value($page->status ?? old('status'))->class('form-select choices-select')->required() }}
</div>
<x-form-buttons :href="route('page.index')" label="Update" />
</div>
@if ($page->type == 'page')
<div class="card">
<div class="card-header">
<h6 class="card-title mb-0 fs-14">
Template
</h6>
</div>
<div class="card-body">
{{ html()->label('Template')->class('form-label visually-hidden')->for('template') }}
{{ html()->select('template', getPageTemplateOptions())->class('form-select choices-select')->value($page->template ?? old('template'))->placeholder('Select')->required() }}
</div>
</div>
@endif
@if ($page->type == "widget")
<div class="card">
<div class="card-header">
<h6 class="card-title mb-0 fs-14">
Page Attributes
</h6>
</div>
<div class="card-body">
{{ html()->label('Parent Page')->class('form-label')->for('parent_id') }}
{{ html()->span('*')->class('text-danger') }}
{{ html()->multiselect('parent_id', $pageOptions ?? [], $page->parents()->pluck('parent_page_id') ?? null)->class('form-select choices-select')->attributes(['multiple'])->required() }}
</div>
</div>
@endif
@if (in_array('featured-image-section', $page->section))
<div class="card featured-image-section">
<div class="card-header">
<h6 class="card-title mb-0 fs-14">
Featured Image
</h6>
</div>
<div class="card-body">
<div class="mb-3">
{{ html()->label('Featured')->class('form-label')->for('image') }}
<x-image-input :data="$editable ? $page->getRawOriginal('image') : null" id="image" name="image" :editable="$editable"
:multiple=false />
</div>
{{ html()->label('Banner')->class('form-label')->for('banner') }}
<x-image-input :data="$editable ? $page->getRawOriginal('banner') : null" id="banner" name="banner" :editable="$editable"
:multiple=false />
</div>
</div>
@endif
@if (in_array('media-gallery-section', $page->section))
<div class="card media-gallery-section">
<div class="card-header">
<h6 class="card-title mb-0 fs-14">
Media Gallery
</h6>
</div>
<div class="card-body">
<x-image-input :editable="$editable" id="images" name="images" :data="$editable ? $page->getRawOriginal('images') : null"
:multiple="true" label="Select Images" />
</div>
</div>
@endif
@if (in_array('link-section', $page->section))
<div class="card">
<div class="card-header">
<h6 class="card-title mb-0 fs-14">
Youtube Link
</h6>
</div>
<div class="card-body">
{{ html()->textarea('link')->class('form-control')->rows(3)->placeholder('Enter Youtube Link or Iframe') }}
</div>
</div>
@endif
@if (in_array('sidebar-section', $page->section))
<div class="card sidebar-section">
<div class="card-header d-flex jusitfy-content-between align-items-center">
<h6 class="card-title mb-0 fs-14">Sidebar</h6>
</div>
<div class="card-body">
<div class="row gy-3">
<div class="col-lg-12">
{{ html()->label('Title')->class('form-label')->for('sidebar_title') }}
{{ html()->text('sidebar_title')->class('form-control') }}
</div>
<div class="col-lg-12">
{{ html()->label('Content')->class('form-label')->for('sidebar_content') }}
{{ html()->text('sidebar_content')->class('form-control')->placeholder('Short Content (optional)') }}
</div>
<div class="col-lg-12">
{{ html()->label('Image')->class('form-label')->for('sidebar_content') }}
<x-image-input :data="$editable ? $page->getRawOriginal('sidebar_image') : null" id="sidebar_image" name="sidebar_image"
:editable="$editable" :multiple=false />
</div>
</div>
</div>
</div>
@endif
@if (in_array('button-section', $page->section))
<div class="card button-section">
<div class="card-header d-flex jusitfy-content-between align-items-center">
<h6 class="card-title mb-0 fs-14">Button</h6>
</div>
<div class="card-body">
<div class="row gy-3">
<div class="col-lg-12">
{{ html()->label('Text')->class('form-label')->for('button_text') }}
{{ html()->span('*')->class('text-danger') }}
{{ html()->text('button_text')->class('form-control')->required() }}
</div>
<div class="col-lg-12">
{{ html()->label('Link')->class('form-label')->for('button_url') }}
{{ html()->span('*')->class('text-danger') }}
{{ html()->text('button_url')->class('form-control')->placeholder('Button Link')->required() }}
</div>
<div class="col-lg-12">
{{ html()->label('Target')->class('form-label')->for('button_target') }}
{{ html()->span('*')->class('text-danger') }}
{{ html()->select('button_target', config('constants.redirect_options'))->class('form-select choices-select')->required() }}
</div>
</div>
</div>
</div>
@endif
</div>
</div>
{{ html()->closeModelForm() }}
</div>
</div>
</div>
@include('ccms::page.modal.edit')
@endsection

View File

@@ -0,0 +1,15 @@
<div class="hstack flex-wrap gap-3">
<a href="javascript:void(0)" data-link="{{ route('page.edit', $id) }}" data-bs-toggle="tooltip"
data-bs-placement="bottom" data-bs-title="Edit" class="link-success fs-15 edit-item-btn"><i
class=" ri-edit-2-line"></i></a>
<a data-link="{{ route('page.toggle', $id) }}" data-bs-toggle="tooltip" data-bs-placement="bottom" data-bs-title="Toggle" data-status="{{ $status == 1 ? 'Draft' : 'Published' }}"
class="link-info fs-15 toggle-item"><i class="{{ $status == 1 ? 'ri-toggle-line' : 'ri-toggle-fill' }}"></i></a>
<a href="{{ route('page.editContent', $id) }}" data-bs-toggle="tooltip" data-bs-placement="bottom"
data-bs-title="Update Page Content" class="link-info fs-15"><i class="ri-file-edit-line"></i></a>
<a href="javascript:void(0);" data-link="{{ route('page.destroy', $id) }}" class="link-danger fs-15 remove-item"
data-bs-toggle="tooltip" data-bs-placement="bottom" data-bs-title="Delete"><i class="ri-delete-bin-6-line"></i>
</a>
</div>

View File

@@ -0,0 +1,109 @@
@extends('layouts.app')
@section('content')
<style>
.radio-inputs {
position: relative;
display: flex;
flex-wrap: wrap;
border-radius: 0.5rem;
background-color: #EEE;
box-sizing: border-box;
box-shadow: 0 0 0px 1px rgba(0, 0, 0, 0.06);
padding: 0.25rem;
font-size: 14px;
}
.radio-inputs .radio {
flex: 1 1 auto;
text-align: center;
}
.radio-inputs label {
margin-bottom: 0;
}
.radio-inputs .radio input {
display: none;
}
.radio-inputs .radio .name {
display: flex;
cursor: pointer;
align-items: center;
justify-content: center;
border-radius: 0.5rem;
border: none;
padding: .5rem 0;
color: rgba(51, 65, 85, 1);
transition: all .15s ease-in-out;
}
.radio-inputs .radio input:checked+.name {
background-color: var(--vz-primary);
color: #fff;
font-weight: 600;
}
</style>
<div class="container-fluid">
<x-dashboard.breadcumb :title="$title" />
@if ($errors->any())
<x-flash-message type="danger" :messages="$errors->all()" />
@endif
@if ($parentPages)
@include('ccms::page.partials.parent-page-filter')
@endif
<div class="row">
<div class="col-xl-12">
<div class="card">
<div class="card-header d-flex align-items-center justify-content-between">
<h5 class="card-title mb-0">Page List</h5>
<button class="btn btn-primary waves-effect waves-light text-white" data-bs-toggle="modal"
data-bs-target="#addPageModal"><i class="ri-add-line align-middle"></i> Create</h5>
</div>
<div class="card-body">
@php
$columns = [
[
'title' => 'S.N',
'data' => 'DT_RowIndex',
'name' => 'DT_RowIndex',
'orderable' => false,
'searchable' => false,
'sortable' => false,
],
['title' => 'Image', 'data' => 'image', 'name' => 'image'],
['title' => 'Parent', 'data' => 'parents', 'name' => 'parents'],
['title' => 'Title', 'data' => 'title', 'name' => 'title'],
['title' => 'Slug', 'data' => 'slug', 'name' => 'slug'],
['title' => 'Type', 'data' => 'type', 'name' => 'type'],
['title' => 'Published At', 'data' => 'date', 'name' => 'date'],
['title' => 'Status', 'data' => 'status', 'name' => 'status'],
[
'title' => 'Action',
'data' => 'action',
'orderable' => false,
'searchable' => false,
],
];
@endphp
<x-data-table-script :route="route('page.index')" :reorder="route('page.reorder')"
:columns="$columns" />
</div>
</div>
</div>
</div>
</div>
@include('ccms::page.modal.create')
@include('ccms::page.modal.edit')
@endsection
@push("js")
<script>
$('.page-filter-radio').on('change', function (e) {
e.preventDefault();
$('.ajax-datatable').DataTable().draw();
});
</script>
@endpush

View File

@@ -0,0 +1,14 @@
<div class="modal fade" id="addPageModal" tabindex="-1" aria-labelledby="addPageModalLabel" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered">
<div class="modal-content">
<div class="modal-header bg-light p-3">
<h5 class="modal-title" id="addPageModalLabel">Add Page</h5>
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"
id="close-modal"></button>
</div>
<div class="modal-body">
@include('ccms::page.partials._form')
</div>
</div>
</div>
</div>

View File

@@ -0,0 +1,37 @@
<div class="modal fade" id="editPageModal" tabindex="-1" aria-labelledby="editPageModalLabel" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered">
<div class="modal-content">
<div class="modal-header bg-light p-3">
<h5 class="modal-title" id="editPageModalLabel">Edit Page</h5>
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"
id="close-modal"></button>
</div>
<div class="modal-body">
</div>
</div>
</div>
</div>
@push('js')
<script>
$(document).on('click', '.edit-item-btn', function() {
const url = $(this).attr('data-link');
const myModal = new bootstrap.Modal(document.getElementById("editPageModal"));
$("#editPageModal .modal-body").html(
'<div class="text-center my-5"><i class="spinner-border text-primary" role="status"></i></div>'
);
myModal.show();
$.get(url, function(res, status) {
$("#editPageModal .modal-body").html(res);
document.querySelectorAll(".choices-select").forEach((element) => {
new Choices(element, {
removeItemButton: true,
searchEnabled: true,
});
});
});
});
</script>
@endpush

View File

@@ -0,0 +1,45 @@
{{ html()->modelForm($page ?? null, 'POST', route('page.store'))->class('needs-validation')->attributes(['novalidate', 'enctype' => 'multipart/form-data'])->open() }}
@if (isset($page))
{{ html()->hidden('id', $page->id) }}
@endif
<div class="row g-3">
<div class="col-lg-12">
<div>
{{ html()->label('Title')->class('form-label')->for('title') }}
{{ html()->span('*')->class('text-danger') }}
{{ html()->text('title')->class('form-control')->placeholder('Enter Page Title')->required() }}
</div>
</div>
<div class="col-lg-12">
<div>
{{ html()->label('Type')->class('form-label')->for('type') }}
{{ html()->span('*')->class('text-danger') }}
{{ html()->select('type', config('constants.page_type_options'))->class('form-select choices-select')->required() }}
</div>
</div>
<div class="col-lg-12">
{{ html()->label('Page Content Options')->class('form-label') }}
<div class="event-details border rounded p-4">
<div class="row gy-3">
@foreach (config('constants.page_section_options') as $value => $label)
<div class="col-6">
<div class="form-check form-check-inline">
{{ html()->checkbox('section[]', in_array($value, $page->section ?? []), $value)->class('form-check-input')->id("{$value}Check") }}
{{ html()->label($label)->class('form-check-label mb-0 text-nowrap')->for("{$value}Check") }}
</div>
</div>
@endforeach
</div>
</div>
</div>
<div class="col-lg-12">
<div class="hstack gap-2 justify-content-end">
<button type="button" class="btn btn-sm btn-light" data-bs-dismiss="modal">Close</button>
<button type="submit" class="btn btn-sm btn-success">{{ isset($page) ? 'Update' : 'Create' }}</button>
</div>
</div>
</div>
{{ html()->closeModelForm() }}

View File

@@ -0,0 +1,17 @@
<div class="row mb-3">
<div class="col-xxl-12">
<form id="filter-form" method="POST">
@csrf
<div class="radio-inputs">
@foreach ($parentPages as $page)
<label for="radio-{{ $page->id }}" class="radio">
<input id="radio-{{ $page->id }}" type="radio" name="page_id" value="{{ $page->id }}"
class="page-filter-radio" @checked($loop->first)>
<span class="name">{{ $page->title }}</span>
</label>
@endforeach
<div class="indicator"></div>
</div>
</form>
</div>
</div>