webupdate

This commit is contained in:
Local Server
2026-01-18 02:22:05 -06:00
parent 6fc159051a
commit 2a2a3d99e5
135 changed files with 54897 additions and 9825 deletions

View File

@@ -1,4 +1,4 @@
<!DOCTYPE html>
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8" />
@@ -13,11 +13,13 @@
rel="stylesheet"
href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.3/font/bootstrap-icons.min.css"
/>
<link rel="stylesheet" href="/admin/css/admin-style.css" />
<link rel="stylesheet" href="/admin/css/media-library.css" />
<!-- Quill Rich Text Editor -->
<link
href="https://cdn.jsdelivr.net/npm/quill@1.3.6/dist/quill.snow.css"
href="https://cdn.quilljs.com/1.3.7/quill.snow.css"
rel="stylesheet"
/>
<link rel="stylesheet" href="/admin/css/admin-style.css" />
<style>
.section-builder {
background: white;
@@ -33,11 +35,6 @@
border-color: #667eea;
}
.section-builder.disabled {
opacity: 0.6;
background: #f8f9fa;
}
.section-header {
display: flex;
justify-content: space-between;
@@ -59,10 +56,60 @@
align-items: center;
}
/* Slide Management */
.slides-container {
display: flex;
flex-direction: column;
gap: 20px;
}
.slide-card {
background: #f8f9fa;
border: 2px solid #e9ecef;
border-radius: 12px;
padding: 20px;
position: relative;
transition: all 0.3s ease;
}
.slide-card:hover {
border-color: #667eea;
box-shadow: 0 4px 12px rgba(102, 126, 234, 0.15);
}
.slide-card.active {
border-color: #28a745;
background: #f8fff9;
}
.slide-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 15px;
padding-bottom: 10px;
border-bottom: 1px solid #e9ecef;
}
.slide-number {
font-weight: 700;
color: #667eea;
font-size: 1.1rem;
}
.slide-actions {
display: flex;
gap: 8px;
}
.slide-actions .btn {
padding: 5px 10px;
font-size: 0.85rem;
}
.image-preview {
width: 100%;
max-width: 400px;
height: 200px;
height: 150px;
border: 2px dashed #ccc;
border-radius: 8px;
display: flex;
@@ -83,30 +130,23 @@
color: #6c757d;
}
.alignment-selector {
.add-slide-btn {
border: 2px dashed #667eea;
background: transparent;
color: #667eea;
padding: 20px;
border-radius: 12px;
display: flex;
align-items: center;
justify-content: center;
gap: 10px;
margin-top: 10px;
}
.alignment-btn {
flex: 1;
padding: 10px;
border: 2px solid #e9ecef;
background: white;
border-radius: 8px;
cursor: pointer;
transition: all 0.3s ease;
font-weight: 600;
}
.alignment-btn:hover {
border-color: #667eea;
background: #f8f9fa;
}
.alignment-btn.active {
border-color: #667eea;
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
.add-slide-btn:hover {
background: #667eea;
color: white;
}
@@ -118,34 +158,99 @@
box-shadow: 0 4px 12px rgba(102, 126, 234, 0.4);
}
/* Quill Editor Styling */
.ql-container {
min-height: 150px;
border-bottom-left-radius: 8px;
border-bottom-right-radius: 8px;
.drag-handle {
cursor: grab;
color: #adb5bd;
font-size: 1.2rem;
}
.ql-toolbar {
.drag-handle:hover {
color: #667eea;
}
/* Featured Products Section */
.count-selector {
display: flex;
gap: 10px;
flex-wrap: wrap;
}
.count-btn {
padding: 8px 16px;
border: 2px solid #e9ecef;
background: white;
border-radius: 8px;
cursor: pointer;
transition: all 0.3s ease;
font-weight: 600;
}
.count-btn:hover {
border-color: #667eea;
}
.count-btn.active {
border-color: #667eea;
background: #667eea;
color: white;
}
/* Info box */
.info-box {
background: linear-gradient(135deg, #e3f2fd 0%, #bbdefb 100%);
border-left: 4px solid #2196f3;
padding: 15px;
border-radius: 0 8px 8px 0;
margin-bottom: 20px;
}
.info-box i {
color: #2196f3;
}
/* Quill Editor Styles */
.quill-container {
background: white;
border-radius: 8px;
margin-bottom: 10px;
}
.quill-container .ql-toolbar {
border-top-left-radius: 8px;
border-top-right-radius: 8px;
background: #f8f9fa;
border-color: #ced4da;
}
.ql-editor {
min-height: 150px;
font-size: 15px;
line-height: 1.6;
.quill-container .ql-container {
border-bottom-left-radius: 8px;
border-bottom-right-radius: 8px;
border-color: #ced4da;
min-height: 120px;
font-size: 14px;
}
.ql-editor.ql-blank::before {
color: #adb5bd;
font-style: italic;
.quill-container .ql-editor {
min-height: 100px;
}
.quill-container .ql-editor.ql-blank::before {
font-style: normal;
color: #6c757d;
}
.slide-card .quill-container .ql-container {
min-height: 80px;
}
.slide-card .quill-container .ql-editor {
min-height: 60px;
}
</style>
</head>
<body>
<div class="sidebar">
<div class="sidebar-brand">🛍️ Sky Art Shop</div>
<div class="sidebar-brand">Sky Art Shop</div>
<ul class="sidebar-menu">
<li>
<a href="/admin/dashboard"
@@ -161,9 +266,7 @@
<a href="/admin/products"><i class="bi bi-box"></i> Products</a>
</li>
<li>
<a href="/admin/portfolio"
><i class="bi bi-easel"></i> Portfolio</a
>
<a href="/admin/portfolio"><i class="bi bi-easel"></i> Portfolio</a>
</li>
<li>
<a href="/admin/blog"><i class="bi bi-newspaper"></i> Blog</a>
@@ -187,6 +290,11 @@
<li>
<a href="/admin/users"><i class="bi bi-people"></i> Users</a>
</li>
<li>
<a href="/admin/customers"
><i class="bi bi-person-hearts"></i> Customers</a
>
</li>
</ul>
</div>
@@ -197,7 +305,7 @@
<p class="mb-0 text-muted">Customize your homepage sections</p>
</div>
<div>
<a href="/index.html" target="_blank" class="btn btn-info me-2">
<a href="/home" target="_blank" class="btn btn-info me-2">
<i class="bi bi-eye"></i> Preview
</a>
<button class="btn-logout" onclick="logout()">
@@ -207,234 +315,122 @@
</div>
<div id="sectionsContainer">
<!-- Hero Section -->
<div class="section-builder" id="heroSection">
<!-- Hero Slider Section -->
<div class="section-builder" id="heroSliderSection">
<div class="section-header">
<h5><i class="bi bi-stars"></i> Hero Section</h5>
<h5><i class="bi bi-collection-play"></i> Hero Slider</h5>
<div class="section-controls">
<div class="form-check form-switch">
<input
class="form-check-input"
type="checkbox"
id="heroEnabled"
checked
onchange="toggleSection('hero')"
/>
<label class="form-check-label" for="heroEnabled"
>Enabled</label
>
</div>
<span class="badge bg-primary" id="slideCount">0 slides</span>
</div>
</div>
<div class="info-box">
<p class="mb-2">
<i class="bi bi-info-circle me-2"></i>
<strong>Hero Slider:</strong> Create multiple slides with
background images, titles, descriptions, and call-to-action
buttons. Slides will auto-rotate every 10 seconds on the frontend.
</p>
<p
class="mb-0"
style="
background: #fff3cd;
padding: 10px;
border-radius: 6px;
border-left: 4px solid #ffc107;
"
>
<i class="bi bi-image me-2" style="color: #856404"></i>
<strong style="color: #856404">Recommended Image Size:</strong>
<code
style="
background: #ffeeba;
padding: 2px 8px;
border-radius: 4px;
"
>1920 x 600 pixels</code
>
(width x height). Use landscape images for best results. The image
will cover the entire slider area as a background.
</p>
</div>
<div class="section-content">
<div class="row">
<div class="col-md-6 mb-3">
<label class="form-label">Headline *</label>
<input
type="text"
class="form-control"
id="heroHeadline"
placeholder="Welcome to Sky Art Shop"
/>
</div>
<div class="col-md-6 mb-3">
<label class="form-label">Subheading</label>
<input
type="text"
class="form-control"
id="heroSubheading"
placeholder="Your creative destination"
/>
</div>
<div class="slides-container" id="slidesContainer">
<!-- Slides will be rendered here -->
</div>
<div class="mb-3">
<label class="form-label">Description</label>
<div
id="heroDescription"
style="background: white; min-height: 150px"
></div>
</div>
<div class="row">
<div class="col-md-6 mb-3">
<label class="form-label">CTA Button Text</label>
<input
type="text"
class="form-control"
id="heroCtaText"
placeholder="Shop Now"
/>
</div>
<div class="col-md-6 mb-3">
<label class="form-label">CTA Button Link</label>
<input
type="text"
class="form-control"
id="heroCtaLink"
placeholder="/shop"
/>
</div>
</div>
<div class="mb-3">
<label class="form-label">Background Image/Video</label>
<input type="hidden" id="heroBackgroundUrl" />
<button
type="button"
class="btn btn-outline-primary w-100"
onclick="openMediaLibrary('hero', 'background')"
>
<i class="bi bi-folder2-open"></i> Choose from Media Library
</button>
<div class="image-preview empty" id="heroPreview">
<i class="bi bi-image" style="font-size: 3rem"></i>
</div>
<button
type="button"
class="btn btn-sm btn-outline-danger mt-2"
onclick="clearMedia('hero', 'background')"
id="heroBackgroundClear"
style="display: none"
>
<i class="bi bi-x-circle"></i> Clear Background
</button>
</div>
<div class="mb-3">
<label class="form-label">Layout</label>
<div class="alignment-selector">
<button
class="alignment-btn active"
onclick="setLayout('hero', 'text-left')"
>
<i class="bi bi-align-start"></i> Text Left
</button>
<button
class="alignment-btn"
onclick="setLayout('hero', 'text-center')"
>
<i class="bi bi-align-center"></i> Text Center
</button>
<button
class="alignment-btn"
onclick="setLayout('hero', 'text-right')"
>
<i class="bi bi-align-end"></i> Text Right
</button>
</div>
</div>
<button
type="button"
class="add-slide-btn w-100 mt-3"
onclick="addNewSlide()"
>
<i class="bi bi-plus-circle"></i> Add New Slide
</button>
</div>
</div>
<!-- Promotion Section -->
<div class="section-builder" id="promotionSection">
<!-- Featured Products Section -->
<div class="section-builder" id="featuredProductsSection">
<div class="section-header">
<h5><i class="bi bi-gift"></i> Promotion Section</h5>
<h5><i class="bi bi-star"></i> Featured Products</h5>
<div class="section-controls">
<div class="form-check form-switch">
<input
class="form-check-input"
type="checkbox"
id="promotionEnabled"
id="featuredEnabled"
checked
onchange="toggleSection('promotion')"
/>
<label class="form-check-label" for="promotionEnabled"
>Enabled</label
<label class="form-check-label" for="featuredEnabled"
>Show on Homepage</label
>
</div>
</div>
</div>
<div class="info-box">
<p class="mb-0">
<i class="bi bi-info-circle me-2"></i>
Products marked as "Featured" in the Products section will appear
here automatically.
</p>
</div>
<div class="section-content">
<div class="mb-3">
<label class="form-label">Section Title</label>
<input
type="text"
class="form-control"
id="promotionTitle"
placeholder="Special Offers"
/>
</div>
<div class="mb-3">
<label class="form-label">Description</label>
<div
id="promotionDescription"
style="background: white; min-height: 150px"
></div>
</div>
<div class="mb-3">
<label class="form-label">Section Image</label>
<input type="hidden" id="promotionImageUrl" />
<button
type="button"
class="btn btn-outline-primary w-100"
onclick="openMediaLibrary('promotion', 'image')"
>
<i class="bi bi-folder2-open"></i> Choose from Media Library
</button>
<div class="image-preview empty" id="promotionPreview">
<i class="bi bi-image" style="font-size: 3rem"></i>
</div>
<button
type="button"
class="btn btn-sm btn-outline-danger mt-2"
onclick="clearMedia('promotion', 'image')"
id="promotionImageClear"
style="display: none"
>
<i class="bi bi-x-circle"></i> Clear Image
</button>
</div>
<div class="row">
<div class="col-md-6 mb-3">
<label class="form-label">Image Position</label>
<div class="alignment-selector">
<button
class="alignment-btn active"
onclick="setImagePosition('promotion', 'left')"
>
<i class="bi bi-arrow-left"></i> Left
</button>
<button
class="alignment-btn"
onclick="setImagePosition('promotion', 'center')"
>
<i class="bi bi-arrow-down"></i> Center
</button>
<button
class="alignment-btn"
onclick="setImagePosition('promotion', 'right')"
>
<i class="bi bi-arrow-right"></i> Right
</button>
</div>
<label class="form-label">Section Title</label>
<input
type="text"
class="form-control"
id="featuredTitle"
value="Featured Products"
/>
</div>
<div class="col-md-6 mb-3">
<label class="form-label">Text Alignment</label>
<div class="alignment-selector">
<label class="form-label">Number of Products to Display</label>
<div class="count-selector">
<button
class="alignment-btn active"
onclick="setTextAlignment('promotion', 'left')"
class="count-btn"
data-count="4"
onclick="setFeaturedCount(4)"
>
<i class="bi bi-text-left"></i> Left
4
</button>
<button
class="alignment-btn"
onclick="setTextAlignment('promotion', 'center')"
class="count-btn active"
data-count="8"
onclick="setFeaturedCount(8)"
>
<i class="bi bi-text-center"></i> Center
8
</button>
<button
class="alignment-btn"
onclick="setTextAlignment('promotion', 'right')"
class="count-btn"
data-count="12"
onclick="setFeaturedCount(12)"
>
<i class="bi bi-text-right"></i> Right
12
</button>
</div>
</div>
@@ -442,21 +438,81 @@
</div>
</div>
<!-- Portfolio Showcase Section -->
<div class="section-builder" id="portfolioSection">
<!-- Get Inspired / Blog Section -->
<div class="section-builder" id="blogSection">
<div class="section-header">
<h5><i class="bi bi-easel"></i> Portfolio Showcase</h5>
<h5><i class="bi bi-lightbulb"></i> Get Inspired (Blog Posts)</h5>
<div class="section-controls">
<div class="form-check form-switch">
<input
class="form-check-input"
type="checkbox"
id="portfolioEnabled"
id="blogEnabled"
checked
onchange="toggleSection('portfolio')"
/>
<label class="form-check-label" for="portfolioEnabled"
>Enabled</label
<label class="form-check-label" for="blogEnabled"
>Show on Homepage</label
>
</div>
</div>
</div>
<div class="info-box">
<p class="mb-0">
<i class="bi bi-info-circle me-2"></i>
Latest blog posts will be displayed automatically from the Blog
section.
</p>
</div>
<div class="section-content">
<div class="row">
<div class="col-md-6 mb-3">
<label class="form-label">Section Title</label>
<input
type="text"
class="form-control"
id="blogTitle"
value="Get Inspired"
/>
</div>
<div class="col-md-6 mb-3">
<label class="form-label">Number of Posts to Display</label>
<div class="count-selector">
<button
class="count-btn active"
data-count="3"
onclick="setBlogCount(3)"
>
3
</button>
<button
class="count-btn"
data-count="6"
onclick="setBlogCount(6)"
>
6
</button>
</div>
</div>
</div>
</div>
</div>
<!-- About Preview Section -->
<div class="section-builder" id="aboutSection">
<div class="section-header">
<h5><i class="bi bi-info-square"></i> About Preview</h5>
<div class="section-controls">
<div class="form-check form-switch">
<input
class="form-check-input"
type="checkbox"
id="aboutEnabled"
checked
/>
<label class="form-check-label" for="aboutEnabled"
>Show on Homepage</label
>
</div>
</div>
@@ -464,33 +520,33 @@
<div class="section-content">
<div class="mb-3">
<label class="form-label">Section Title</label>
<label class="form-label">About Title</label>
<input
type="text"
class="form-control"
id="portfolioTitle"
placeholder="Our Work"
id="aboutTitle"
value="About Sky Art Shop"
/>
</div>
<div class="mb-3">
<label class="form-label">Description</label>
<div
id="portfolioDescription"
style="background: white; min-height: 150px"
></div>
<label class="form-label">About Description</label>
<div class="quill-container">
<div id="aboutDescriptionEditor"></div>
</div>
</div>
<div class="mb-3">
<label class="form-label">Number of Projects to Display</label>
<input
type="number"
class="form-control"
id="portfolioCount"
value="6"
min="3"
max="12"
/>
<label class="form-label">About Image</label>
<input type="hidden" id="aboutImageUrl" />
<button
type="button"
class="btn btn-outline-primary w-100"
onclick="openMediaLibrary('about')"
>
<i class="bi bi-folder2-open"></i> Choose from Media Library
</button>
<div class="image-preview empty" id="aboutPreview">
<i class="bi bi-image" style="font-size: 2rem"></i>
</div>
</div>
</div>
</div>
@@ -505,8 +561,10 @@
</div>
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/js/bootstrap.bundle.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/quill@1.3.6/dist/quill.js"></script>
<script src="https://cdn.quilljs.com/1.3.7/quill.min.js"></script>
<script src="/admin/js/auth.js"></script>
<script src="/admin/js/admin-utils.js"></script>
<script src="/admin/js/media-library.js"></script>
<script src="/admin/js/homepage.js"></script>
</body>
</html>