@qwickapps/cms 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +45 -0
- package/README.md +203 -0
- package/dist/admin/components/AccordionItemRowLabel.d.ts +20 -0
- package/dist/admin/components/AccordionItemRowLabel.d.ts.map +1 -0
- package/dist/admin/components/AccordionItemRowLabel.js +47 -0
- package/dist/admin/components/AccordionItemRowLabel.js.map +1 -0
- package/dist/admin/components/BlockRowLabel.d.ts +19 -0
- package/dist/admin/components/BlockRowLabel.d.ts.map +1 -0
- package/dist/admin/components/BlockRowLabel.js +52 -0
- package/dist/admin/components/BlockRowLabel.js.map +1 -0
- package/dist/admin/components/ButtonRowLabel.d.ts +23 -0
- package/dist/admin/components/ButtonRowLabel.d.ts.map +1 -0
- package/dist/admin/components/ButtonRowLabel.js +63 -0
- package/dist/admin/components/ButtonRowLabel.js.map +1 -0
- package/dist/admin/components/CardRowLabel.d.ts +23 -0
- package/dist/admin/components/CardRowLabel.d.ts.map +1 -0
- package/dist/admin/components/CardRowLabel.js +59 -0
- package/dist/admin/components/CardRowLabel.js.map +1 -0
- package/dist/admin/components/ContentPreview.d.ts +12 -0
- package/dist/admin/components/ContentPreview.d.ts.map +1 -0
- package/dist/admin/components/ContentPreview.js +95 -0
- package/dist/admin/components/ContentPreview.js.map +1 -0
- package/dist/admin/components/Dashboard.d.ts +13 -0
- package/dist/admin/components/Dashboard.d.ts.map +1 -0
- package/dist/admin/components/Dashboard.js +7 -0
- package/dist/admin/components/Dashboard.js.map +1 -0
- package/dist/admin/components/DashboardContent.d.ts +11 -0
- package/dist/admin/components/DashboardContent.d.ts.map +1 -0
- package/dist/admin/components/DashboardContent.js +129 -0
- package/dist/admin/components/DashboardContent.js.map +1 -0
- package/dist/admin/components/FormFieldRowLabel.d.ts +21 -0
- package/dist/admin/components/FormFieldRowLabel.d.ts.map +1 -0
- package/dist/admin/components/FormFieldRowLabel.js +47 -0
- package/dist/admin/components/FormFieldRowLabel.js.map +1 -0
- package/dist/admin/components/Icon.d.ts +10 -0
- package/dist/admin/components/Icon.d.ts.map +1 -0
- package/dist/admin/components/Icon.js +16 -0
- package/dist/admin/components/Icon.js.map +1 -0
- package/dist/admin/components/Logo.d.ts +10 -0
- package/dist/admin/components/Logo.d.ts.map +1 -0
- package/dist/admin/components/Logo.js +16 -0
- package/dist/admin/components/Logo.js.map +1 -0
- package/dist/admin/components/NavigationItemRowLabel.d.ts +21 -0
- package/dist/admin/components/NavigationItemRowLabel.d.ts.map +1 -0
- package/dist/admin/components/NavigationItemRowLabel.js +43 -0
- package/dist/admin/components/NavigationItemRowLabel.js.map +1 -0
- package/dist/admin/components/NavigationSubItemRowLabel.d.ts +19 -0
- package/dist/admin/components/NavigationSubItemRowLabel.d.ts.map +1 -0
- package/dist/admin/components/NavigationSubItemRowLabel.js +32 -0
- package/dist/admin/components/NavigationSubItemRowLabel.js.map +1 -0
- package/dist/admin/components/PagesListHeader.d.ts +13 -0
- package/dist/admin/components/PagesListHeader.d.ts.map +1 -0
- package/dist/admin/components/PagesListHeader.js +48 -0
- package/dist/admin/components/PagesListHeader.js.map +1 -0
- package/dist/admin/components/ProductsListHeader.d.ts +13 -0
- package/dist/admin/components/ProductsListHeader.d.ts.map +1 -0
- package/dist/admin/components/ProductsListHeader.js +55 -0
- package/dist/admin/components/ProductsListHeader.js.map +1 -0
- package/dist/admin/components/styles/CollectionListHeader.css +161 -0
- package/dist/admin/components/styles/ContentPreview.css +416 -0
- package/dist/admin/components/styles/Dashboard.css +338 -0
- package/dist/admin/fields/ColorInput.d.ts +13 -0
- package/dist/admin/fields/ColorInput.d.ts.map +1 -0
- package/dist/admin/fields/ColorInput.js +201 -0
- package/dist/admin/fields/ColorInput.js.map +1 -0
- package/dist/admin/fields/index.d.ts +9 -0
- package/dist/admin/fields/index.d.ts.map +1 -0
- package/dist/admin/fields/index.js +9 -0
- package/dist/admin/fields/index.js.map +1 -0
- package/dist/admin/index.d.ts +24 -0
- package/dist/admin/index.d.ts.map +1 -0
- package/dist/admin/index.js +30 -0
- package/dist/admin/index.js.map +1 -0
- package/dist/blocks/ContentBlocks.d.ts +75 -0
- package/dist/blocks/ContentBlocks.d.ts.map +1 -0
- package/dist/blocks/ContentBlocks.js +1241 -0
- package/dist/blocks/ContentBlocks.js.map +1 -0
- package/dist/blocks/index.d.ts +2 -0
- package/dist/blocks/index.d.ts.map +1 -0
- package/dist/blocks/index.js +3 -0
- package/dist/blocks/index.js.map +1 -0
- package/dist/client/PayloadAPIClient.d.ts +65 -0
- package/dist/client/PayloadAPIClient.d.ts.map +1 -0
- package/dist/client/PayloadAPIClient.js +167 -0
- package/dist/client/PayloadAPIClient.js.map +1 -0
- package/dist/collections/Automations.d.ts +12 -0
- package/dist/collections/Automations.d.ts.map +1 -0
- package/dist/collections/Automations.js +741 -0
- package/dist/collections/Automations.js.map +1 -0
- package/dist/collections/Features.d.ts +3 -0
- package/dist/collections/Features.d.ts.map +1 -0
- package/dist/collections/Features.js +69 -0
- package/dist/collections/Features.js.map +1 -0
- package/dist/collections/Footer.d.ts +11 -0
- package/dist/collections/Footer.d.ts.map +1 -0
- package/dist/collections/Footer.js +130 -0
- package/dist/collections/Footer.js.map +1 -0
- package/dist/collections/FormSubmissions.d.ts +3 -0
- package/dist/collections/FormSubmissions.d.ts.map +1 -0
- package/dist/collections/FormSubmissions.js +119 -0
- package/dist/collections/FormSubmissions.js.map +1 -0
- package/dist/collections/Forms.d.ts +16 -0
- package/dist/collections/Forms.d.ts.map +1 -0
- package/dist/collections/Forms.js +308 -0
- package/dist/collections/Forms.js.map +1 -0
- package/dist/collections/HeroBlocks.d.ts +3 -0
- package/dist/collections/HeroBlocks.d.ts.map +1 -0
- package/dist/collections/HeroBlocks.js +115 -0
- package/dist/collections/HeroBlocks.js.map +1 -0
- package/dist/collections/Media.d.ts +3 -0
- package/dist/collections/Media.d.ts.map +1 -0
- package/dist/collections/Media.js +26 -0
- package/dist/collections/Media.js.map +1 -0
- package/dist/collections/Navigation.d.ts +3 -0
- package/dist/collections/Navigation.d.ts.map +1 -0
- package/dist/collections/Navigation.js +106 -0
- package/dist/collections/Navigation.js.map +1 -0
- package/dist/collections/Pages.d.ts +3 -0
- package/dist/collections/Pages.d.ts.map +1 -0
- package/dist/collections/Pages.js +94 -0
- package/dist/collections/Pages.js.map +1 -0
- package/dist/collections/Posts.d.ts +3 -0
- package/dist/collections/Posts.d.ts.map +1 -0
- package/dist/collections/Posts.js +134 -0
- package/dist/collections/Posts.js.map +1 -0
- package/dist/collections/Products.d.ts +3 -0
- package/dist/collections/Products.d.ts.map +1 -0
- package/dist/collections/Products.js +264 -0
- package/dist/collections/Products.js.map +1 -0
- package/dist/collections/Users.d.ts +3 -0
- package/dist/collections/Users.d.ts.map +1 -0
- package/dist/collections/Users.js +53 -0
- package/dist/collections/Users.js.map +1 -0
- package/dist/collections/hooks/index.d.ts +9 -0
- package/dist/collections/hooks/index.d.ts.map +1 -0
- package/dist/collections/hooks/index.js +9 -0
- package/dist/collections/hooks/index.js.map +1 -0
- package/dist/collections/hooks/loggingHooks.d.ts +45 -0
- package/dist/collections/hooks/loggingHooks.d.ts.map +1 -0
- package/dist/collections/hooks/loggingHooks.js +109 -0
- package/dist/collections/hooks/loggingHooks.js.map +1 -0
- package/dist/collections/index.d.ts +14 -0
- package/dist/collections/index.d.ts.map +1 -0
- package/dist/collections/index.js +16 -0
- package/dist/collections/index.js.map +1 -0
- package/dist/components/index.d.ts +2 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/index.js +4 -0
- package/dist/components/index.js.map +1 -0
- package/dist/globals/AdvancedSettings.d.ts +8 -0
- package/dist/globals/AdvancedSettings.d.ts.map +1 -0
- package/dist/globals/AdvancedSettings.js +157 -0
- package/dist/globals/AdvancedSettings.js.map +1 -0
- package/dist/globals/Integrations.d.ts +8 -0
- package/dist/globals/Integrations.d.ts.map +1 -0
- package/dist/globals/Integrations.js +270 -0
- package/dist/globals/Integrations.js.map +1 -0
- package/dist/globals/SiteSettings.d.ts +8 -0
- package/dist/globals/SiteSettings.d.ts.map +1 -0
- package/dist/globals/SiteSettings.js +258 -0
- package/dist/globals/SiteSettings.js.map +1 -0
- package/dist/globals/ThemeSettings.d.ts +11 -0
- package/dist/globals/ThemeSettings.d.ts.map +1 -0
- package/dist/globals/ThemeSettings.js +92 -0
- package/dist/globals/ThemeSettings.js.map +1 -0
- package/dist/globals/index.d.ts +5 -0
- package/dist/globals/index.d.ts.map +1 -0
- package/dist/globals/index.js +6 -0
- package/dist/globals/index.js.map +1 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +14 -0
- package/dist/index.js.map +1 -0
- package/dist/logging/index.d.ts +73 -0
- package/dist/logging/index.d.ts.map +1 -0
- package/dist/logging/index.js +190 -0
- package/dist/logging/index.js.map +1 -0
- package/dist/nextjs/BlockRenderer.d.ts +227 -0
- package/dist/nextjs/BlockRenderer.d.ts.map +1 -0
- package/dist/nextjs/BlockRenderer.js +358 -0
- package/dist/nextjs/BlockRenderer.js.map +1 -0
- package/dist/nextjs/ClientHomePage.d.ts +6 -0
- package/dist/nextjs/ClientHomePage.d.ts.map +1 -0
- package/dist/nextjs/ClientHomePage.js +17 -0
- package/dist/nextjs/ClientHomePage.js.map +1 -0
- package/dist/nextjs/ClientSideQwickApp.d.ts +23 -0
- package/dist/nextjs/ClientSideQwickApp.d.ts.map +1 -0
- package/dist/nextjs/ClientSideQwickApp.js +50 -0
- package/dist/nextjs/ClientSideQwickApp.js.map +1 -0
- package/dist/nextjs/DynamicQwickApp.d.ts +9 -0
- package/dist/nextjs/DynamicQwickApp.d.ts.map +1 -0
- package/dist/nextjs/DynamicQwickApp.js +19 -0
- package/dist/nextjs/DynamicQwickApp.js.map +1 -0
- package/dist/nextjs/FooterFromSettings.d.ts +6 -0
- package/dist/nextjs/FooterFromSettings.d.ts.map +1 -0
- package/dist/nextjs/FooterFromSettings.js +72 -0
- package/dist/nextjs/FooterFromSettings.js.map +1 -0
- package/dist/nextjs/FormBlockComponent.d.ts +25 -0
- package/dist/nextjs/FormBlockComponent.d.ts.map +1 -0
- package/dist/nextjs/FormBlockComponent.js +110 -0
- package/dist/nextjs/FormBlockComponent.js.map +1 -0
- package/dist/nextjs/HomePageContent.d.ts +6 -0
- package/dist/nextjs/HomePageContent.d.ts.map +1 -0
- package/dist/nextjs/HomePageContent.js +50 -0
- package/dist/nextjs/HomePageContent.js.map +1 -0
- package/dist/nextjs/LivePreviewClient.d.ts +40 -0
- package/dist/nextjs/LivePreviewClient.d.ts.map +1 -0
- package/dist/nextjs/LivePreviewClient.js +35 -0
- package/dist/nextjs/LivePreviewClient.js.map +1 -0
- package/dist/nextjs/RefreshRouteOnSave.d.ts +31 -0
- package/dist/nextjs/RefreshRouteOnSave.d.ts.map +1 -0
- package/dist/nextjs/RefreshRouteOnSave.js +59 -0
- package/dist/nextjs/RefreshRouteOnSave.js.map +1 -0
- package/dist/nextjs/ScriptsInjector.d.ts +2 -0
- package/dist/nextjs/ScriptsInjector.d.ts.map +1 -0
- package/dist/nextjs/ScriptsInjector.js +73 -0
- package/dist/nextjs/ScriptsInjector.js.map +1 -0
- package/dist/nextjs/ServerQwickApp.d.ts +13 -0
- package/dist/nextjs/ServerQwickApp.d.ts.map +1 -0
- package/dist/nextjs/ServerQwickApp.js +159 -0
- package/dist/nextjs/ServerQwickApp.js.map +1 -0
- package/dist/nextjs/SettingsProvider.d.ts +110 -0
- package/dist/nextjs/SettingsProvider.d.ts.map +1 -0
- package/dist/nextjs/SettingsProvider.js +107 -0
- package/dist/nextjs/SettingsProvider.js.map +1 -0
- package/dist/nextjs/SiteLogo.d.ts +35 -0
- package/dist/nextjs/SiteLogo.d.ts.map +1 -0
- package/dist/nextjs/SiteLogo.js +105 -0
- package/dist/nextjs/SiteLogo.js.map +1 -0
- package/dist/nextjs/framework.d.ts +19 -0
- package/dist/nextjs/framework.d.ts.map +1 -0
- package/dist/nextjs/framework.js +35 -0
- package/dist/nextjs/framework.js.map +1 -0
- package/dist/nextjs/index.d.ts +38 -0
- package/dist/nextjs/index.d.ts.map +1 -0
- package/dist/nextjs/index.js +47 -0
- package/dist/nextjs/index.js.map +1 -0
- package/dist/nextjs/metadata.d.ts +20 -0
- package/dist/nextjs/metadata.d.ts.map +1 -0
- package/dist/nextjs/metadata.js +107 -0
- package/dist/nextjs/metadata.js.map +1 -0
- package/dist/plugins/index.d.ts +2 -0
- package/dist/plugins/index.d.ts.map +1 -0
- package/dist/plugins/index.js +3 -0
- package/dist/plugins/index.js.map +1 -0
- package/dist/plugins/qwickapps-plugin.d.ts +78 -0
- package/dist/plugins/qwickapps-plugin.d.ts.map +1 -0
- package/dist/plugins/qwickapps-plugin.js +154 -0
- package/dist/plugins/qwickapps-plugin.js.map +1 -0
- package/dist/providers/PayloadDataProvider.d.ts +72 -0
- package/dist/providers/PayloadDataProvider.d.ts.map +1 -0
- package/dist/providers/PayloadDataProvider.js +222 -0
- package/dist/providers/PayloadDataProvider.js.map +1 -0
- package/dist/providers/index.d.ts +2 -0
- package/dist/providers/index.d.ts.map +1 -0
- package/dist/providers/index.js +3 -0
- package/dist/providers/index.js.map +1 -0
- package/dist/styles/admin-theme.css +352 -0
- package/package.json +104 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PagesListHeader.d.ts","sourceRoot":"","sources":["../../../src/admin/components/PagesListHeader.tsx"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAIH,OAAO,KAA8B,MAAM,OAAO,CAAC;AACnD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAC;AAErD,OAAO,mCAAmC,CAAC;AAE3C,eAAO,MAAM,eAAe,EAAE,KAAK,CAAC,EAAE,CAAC,qBAAqB,CAuF3D,CAAC"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Enhanced Pages List Header Component
|
|
3
|
+
*
|
|
4
|
+
* Adds Material Design-styled header above the Pages list
|
|
5
|
+
* Provides quick stats and actions for better UX
|
|
6
|
+
*
|
|
7
|
+
* Copyright (c) 2025 QwickApps.com. All rights reserved.
|
|
8
|
+
*/
|
|
9
|
+
'use client';
|
|
10
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
11
|
+
import { useState, useEffect } from 'react';
|
|
12
|
+
import { useListQuery, useConfig } from '@payloadcms/ui';
|
|
13
|
+
import './styles/CollectionListHeader.css';
|
|
14
|
+
export const PagesListHeader = () => {
|
|
15
|
+
const { data } = useListQuery();
|
|
16
|
+
const config = useConfig();
|
|
17
|
+
const [publishedCount, setPublishedCount] = useState(null);
|
|
18
|
+
const [draftCount, setDraftCount] = useState(null);
|
|
19
|
+
const totalDocs = data?.totalDocs ?? 0;
|
|
20
|
+
const serverURL = config?.config?.serverURL || '';
|
|
21
|
+
// Fetch accurate counts by status
|
|
22
|
+
useEffect(() => {
|
|
23
|
+
const fetchCounts = async () => {
|
|
24
|
+
try {
|
|
25
|
+
// Fetch published count
|
|
26
|
+
const publishedRes = await fetch(`${serverURL}/api/pages?where[status][equals]=published&limit=0`, { credentials: 'include' });
|
|
27
|
+
if (publishedRes.ok) {
|
|
28
|
+
const publishedData = await publishedRes.json();
|
|
29
|
+
setPublishedCount(publishedData.totalDocs || 0);
|
|
30
|
+
}
|
|
31
|
+
// Fetch draft count
|
|
32
|
+
const draftRes = await fetch(`${serverURL}/api/pages?where[status][equals]=draft&limit=0`, { credentials: 'include' });
|
|
33
|
+
if (draftRes.ok) {
|
|
34
|
+
const draftData = await draftRes.json();
|
|
35
|
+
setDraftCount(draftData.totalDocs || 0);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
catch (error) {
|
|
39
|
+
console.error('Error fetching page counts:', error);
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
if (serverURL) {
|
|
43
|
+
fetchCounts();
|
|
44
|
+
}
|
|
45
|
+
}, [serverURL, data?.totalDocs]);
|
|
46
|
+
return (_jsx("div", { className: "collection-list-header", children: _jsx("div", { className: "collection-list-stats", children: _jsxs("div", { className: "stats-grid", children: [_jsxs("div", { className: "stat-card stat-card-primary", children: [_jsx("div", { className: "stat-icon", children: "\uD83D\uDCC4" }), _jsxs("div", { className: "stat-content", children: [_jsx("div", { className: "stat-label", children: "Total Pages" }), _jsx("div", { className: "stat-value", children: totalDocs })] })] }), _jsxs("div", { className: "stat-card stat-card-success", children: [_jsx("div", { className: "stat-icon", children: "\u2713" }), _jsxs("div", { className: "stat-content", children: [_jsx("div", { className: "stat-label", children: "Published" }), _jsx("div", { className: "stat-value", children: publishedCount === null ? '...' : publishedCount })] })] }), _jsxs("div", { className: "stat-card stat-card-warning", children: [_jsx("div", { className: "stat-icon", children: "\u270E" }), _jsxs("div", { className: "stat-content", children: [_jsx("div", { className: "stat-label", children: "Drafts" }), _jsx("div", { className: "stat-value", children: draftCount === null ? '...' : draftCount })] })] }), _jsxs("div", { className: "stat-card stat-card-info", children: [_jsx("div", { className: "stat-icon", children: "\uD83D\uDCCA" }), _jsxs("div", { className: "stat-content", children: [_jsx("div", { className: "stat-label", children: "Showing" }), _jsxs("div", { className: "stat-value", children: [data?.docs?.length || 0, " of ", totalDocs] })] })] })] }) }) }));
|
|
47
|
+
};
|
|
48
|
+
//# sourceMappingURL=PagesListHeader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PagesListHeader.js","sourceRoot":"","sources":["../../../src/admin/components/PagesListHeader.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Enhanced Products List Header Component
|
|
3
|
+
*
|
|
4
|
+
* Adds Material Design-styled header above the Products list
|
|
5
|
+
* Provides quick stats and actions for better UX
|
|
6
|
+
*
|
|
7
|
+
* Copyright (c) 2025 QwickApps.com. All rights reserved.
|
|
8
|
+
*/
|
|
9
|
+
import React from 'react';
|
|
10
|
+
import type { BeforeListClientProps } from 'payload';
|
|
11
|
+
import './styles/CollectionListHeader.css';
|
|
12
|
+
export declare const ProductsListHeader: React.FC<BeforeListClientProps>;
|
|
13
|
+
//# sourceMappingURL=ProductsListHeader.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ProductsListHeader.d.ts","sourceRoot":"","sources":["../../../src/admin/components/ProductsListHeader.tsx"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAIH,OAAO,KAA8B,MAAM,OAAO,CAAC;AACnD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAC;AAErD,OAAO,mCAAmC,CAAC;AAE3C,eAAO,MAAM,kBAAkB,EAAE,KAAK,CAAC,EAAE,CAAC,qBAAqB,CAkG9D,CAAC"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Enhanced Products List Header Component
|
|
3
|
+
*
|
|
4
|
+
* Adds Material Design-styled header above the Products list
|
|
5
|
+
* Provides quick stats and actions for better UX
|
|
6
|
+
*
|
|
7
|
+
* Copyright (c) 2025 QwickApps.com. All rights reserved.
|
|
8
|
+
*/
|
|
9
|
+
'use client';
|
|
10
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
11
|
+
import { useState, useEffect } from 'react';
|
|
12
|
+
import { useListQuery, useConfig } from '@payloadcms/ui';
|
|
13
|
+
import './styles/CollectionListHeader.css';
|
|
14
|
+
export const ProductsListHeader = () => {
|
|
15
|
+
const { data } = useListQuery();
|
|
16
|
+
const config = useConfig();
|
|
17
|
+
const [activeCount, setActiveCount] = useState(null);
|
|
18
|
+
const [betaCount, setBetaCount] = useState(null);
|
|
19
|
+
const [comingSoonCount, setComingSoonCount] = useState(null);
|
|
20
|
+
const totalDocs = data?.totalDocs ?? 0;
|
|
21
|
+
const serverURL = config?.config?.serverURL || '';
|
|
22
|
+
// Fetch accurate counts by status
|
|
23
|
+
useEffect(() => {
|
|
24
|
+
const fetchCounts = async () => {
|
|
25
|
+
try {
|
|
26
|
+
// Fetch active count
|
|
27
|
+
const activeRes = await fetch(`${serverURL}/api/products?where[status][equals]=active&limit=0`, { credentials: 'include' });
|
|
28
|
+
if (activeRes.ok) {
|
|
29
|
+
const activeData = await activeRes.json();
|
|
30
|
+
setActiveCount(activeData.totalDocs || 0);
|
|
31
|
+
}
|
|
32
|
+
// Fetch beta count
|
|
33
|
+
const betaRes = await fetch(`${serverURL}/api/products?where[status][equals]=beta&limit=0`, { credentials: 'include' });
|
|
34
|
+
if (betaRes.ok) {
|
|
35
|
+
const betaData = await betaRes.json();
|
|
36
|
+
setBetaCount(betaData.totalDocs || 0);
|
|
37
|
+
}
|
|
38
|
+
// Fetch coming-soon count
|
|
39
|
+
const comingSoonRes = await fetch(`${serverURL}/api/products?where[status][equals]=coming-soon&limit=0`, { credentials: 'include' });
|
|
40
|
+
if (comingSoonRes.ok) {
|
|
41
|
+
const comingSoonData = await comingSoonRes.json();
|
|
42
|
+
setComingSoonCount(comingSoonData.totalDocs || 0);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
catch (error) {
|
|
46
|
+
console.error('Error fetching product counts:', error);
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
if (serverURL) {
|
|
50
|
+
fetchCounts();
|
|
51
|
+
}
|
|
52
|
+
}, [serverURL, data?.totalDocs]);
|
|
53
|
+
return (_jsx("div", { className: "collection-list-header", children: _jsx("div", { className: "collection-list-stats", children: _jsxs("div", { className: "stats-grid", children: [_jsxs("div", { className: "stat-card stat-card-primary", children: [_jsx("div", { className: "stat-icon", children: "\uD83D\uDCE6" }), _jsxs("div", { className: "stat-content", children: [_jsx("div", { className: "stat-label", children: "Total Products" }), _jsx("div", { className: "stat-value", children: totalDocs })] })] }), _jsxs("div", { className: "stat-card stat-card-success", children: [_jsx("div", { className: "stat-icon", children: "\u2713" }), _jsxs("div", { className: "stat-content", children: [_jsx("div", { className: "stat-label", children: "Active" }), _jsx("div", { className: "stat-value", children: activeCount === null ? '...' : activeCount })] })] }), _jsxs("div", { className: "stat-card stat-card-info", children: [_jsx("div", { className: "stat-icon", children: "\u26A1" }), _jsxs("div", { className: "stat-content", children: [_jsx("div", { className: "stat-label", children: "Beta" }), _jsx("div", { className: "stat-value", children: betaCount === null ? '...' : betaCount })] })] }), _jsxs("div", { className: "stat-card stat-card-warning", children: [_jsx("div", { className: "stat-icon", children: "\u23F0" }), _jsxs("div", { className: "stat-content", children: [_jsx("div", { className: "stat-label", children: "Coming Soon" }), _jsx("div", { className: "stat-value", children: comingSoonCount === null ? '...' : comingSoonCount })] })] })] }) }) }));
|
|
54
|
+
};
|
|
55
|
+
//# sourceMappingURL=ProductsListHeader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ProductsListHeader.js","sourceRoot":"","sources":["../../../src/admin/components/ProductsListHeader.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Collection List Header Styles
|
|
3
|
+
* Material Design-inspired styling for enhanced list views
|
|
4
|
+
*
|
|
5
|
+
* Copyright (c) 2025 QwickApps.com. All rights reserved.
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
.collection-list-header {
|
|
9
|
+
padding: 0 1.5rem;
|
|
10
|
+
margin-bottom: 1rem;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
.collection-list-stats {
|
|
14
|
+
padding: 0.875rem;
|
|
15
|
+
border-radius: 6px;
|
|
16
|
+
background: var(--theme-elevation-50);
|
|
17
|
+
border: 1px solid var(--theme-elevation-200);
|
|
18
|
+
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
.stats-grid {
|
|
22
|
+
display: grid;
|
|
23
|
+
grid-template-columns: repeat(4, 1fr);
|
|
24
|
+
gap: 0.625rem;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
@media (max-width: 1200px) {
|
|
28
|
+
.stats-grid {
|
|
29
|
+
grid-template-columns: repeat(2, 1fr);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
@media (max-width: 768px) {
|
|
34
|
+
.stats-grid {
|
|
35
|
+
grid-template-columns: 1fr;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
.stat-card {
|
|
40
|
+
display: flex;
|
|
41
|
+
align-items: center;
|
|
42
|
+
gap: 0.75rem;
|
|
43
|
+
padding: 0.75rem 0.875rem;
|
|
44
|
+
border-radius: 4px;
|
|
45
|
+
background: var(--theme-elevation-0);
|
|
46
|
+
border: 1px solid var(--theme-elevation-200);
|
|
47
|
+
transition: all 0.15s ease;
|
|
48
|
+
cursor: default;
|
|
49
|
+
min-height: 56px;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
.stat-card:hover {
|
|
53
|
+
transform: translateY(-1px);
|
|
54
|
+
box-shadow: 0 2px 6px rgba(0, 0, 0, 0.06);
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
.stat-card-primary {
|
|
58
|
+
border-left: 4px solid var(--color-success-500);
|
|
59
|
+
background: linear-gradient(135deg, var(--theme-elevation-0) 0%, var(--color-success-50) 100%);
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
.stat-card-success {
|
|
63
|
+
border-left: 4px solid #10b981;
|
|
64
|
+
background: linear-gradient(135deg, var(--theme-elevation-0) 0%, rgba(16, 185, 129, 0.05) 100%);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
.stat-card-warning {
|
|
68
|
+
border-left: 4px solid #f59e0b;
|
|
69
|
+
background: linear-gradient(135deg, var(--theme-elevation-0) 0%, rgba(245, 158, 11, 0.05) 100%);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
.stat-card-info {
|
|
73
|
+
border-left: 4px solid #3b82f6;
|
|
74
|
+
background: linear-gradient(135deg, var(--theme-elevation-0) 0%, rgba(59, 130, 246, 0.05) 100%);
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
.stat-icon {
|
|
78
|
+
font-size: 1.5rem;
|
|
79
|
+
line-height: 1;
|
|
80
|
+
opacity: 0.85;
|
|
81
|
+
flex-shrink: 0;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
.stat-content {
|
|
85
|
+
flex: 1;
|
|
86
|
+
min-width: 0;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
.stat-label {
|
|
90
|
+
font-size: 0.6875rem;
|
|
91
|
+
font-weight: 600;
|
|
92
|
+
text-transform: uppercase;
|
|
93
|
+
letter-spacing: 0.03em;
|
|
94
|
+
color: var(--theme-text);
|
|
95
|
+
opacity: 0.55;
|
|
96
|
+
margin-bottom: 0.125rem;
|
|
97
|
+
line-height: 1.2;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
.stat-value {
|
|
101
|
+
font-size: 1.375rem;
|
|
102
|
+
font-weight: 700;
|
|
103
|
+
color: var(--theme-text);
|
|
104
|
+
line-height: 1.1;
|
|
105
|
+
letter-spacing: -0.01em;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
/* Dark mode adjustments */
|
|
109
|
+
html[data-theme='dark'] .collection-list-stats {
|
|
110
|
+
background: var(--theme-elevation-100) !important;
|
|
111
|
+
border-color: var(--theme-elevation-400) !important;
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
html[data-theme='dark'] .stat-card {
|
|
115
|
+
background: var(--theme-elevation-50);
|
|
116
|
+
border-color: var(--theme-elevation-400);
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
html[data-theme='dark'] .stat-card-primary {
|
|
120
|
+
background: linear-gradient(135deg, var(--theme-elevation-50) 0%, rgba(0, 123, 255, 0.1) 100%);
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
html[data-theme='dark'] .stat-card-success {
|
|
124
|
+
background: linear-gradient(135deg, var(--theme-elevation-50) 0%, rgba(16, 185, 129, 0.1) 100%);
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
html[data-theme='dark'] .stat-card-warning {
|
|
128
|
+
background: linear-gradient(135deg, var(--theme-elevation-50) 0%, rgba(245, 158, 11, 0.1) 100%);
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
html[data-theme='dark'] .stat-card-info {
|
|
132
|
+
background: linear-gradient(135deg, var(--theme-elevation-50) 0%, rgba(59, 130, 246, 0.1) 100%);
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
/* Responsive adjustments */
|
|
136
|
+
@media (max-width: 768px) {
|
|
137
|
+
.collection-list-header {
|
|
138
|
+
padding: 0 1rem;
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
.collection-list-stats {
|
|
142
|
+
padding: 0.75rem;
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
.stat-card {
|
|
146
|
+
padding: 0.625rem 0.75rem;
|
|
147
|
+
min-height: 52px;
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
.stat-icon {
|
|
151
|
+
font-size: 1.25rem;
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
.stat-label {
|
|
155
|
+
font-size: 0.625rem;
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
.stat-value {
|
|
159
|
+
font-size: 1.125rem;
|
|
160
|
+
}
|
|
161
|
+
}
|