@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.
Files changed (259) hide show
  1. package/LICENSE +45 -0
  2. package/README.md +203 -0
  3. package/dist/admin/components/AccordionItemRowLabel.d.ts +20 -0
  4. package/dist/admin/components/AccordionItemRowLabel.d.ts.map +1 -0
  5. package/dist/admin/components/AccordionItemRowLabel.js +47 -0
  6. package/dist/admin/components/AccordionItemRowLabel.js.map +1 -0
  7. package/dist/admin/components/BlockRowLabel.d.ts +19 -0
  8. package/dist/admin/components/BlockRowLabel.d.ts.map +1 -0
  9. package/dist/admin/components/BlockRowLabel.js +52 -0
  10. package/dist/admin/components/BlockRowLabel.js.map +1 -0
  11. package/dist/admin/components/ButtonRowLabel.d.ts +23 -0
  12. package/dist/admin/components/ButtonRowLabel.d.ts.map +1 -0
  13. package/dist/admin/components/ButtonRowLabel.js +63 -0
  14. package/dist/admin/components/ButtonRowLabel.js.map +1 -0
  15. package/dist/admin/components/CardRowLabel.d.ts +23 -0
  16. package/dist/admin/components/CardRowLabel.d.ts.map +1 -0
  17. package/dist/admin/components/CardRowLabel.js +59 -0
  18. package/dist/admin/components/CardRowLabel.js.map +1 -0
  19. package/dist/admin/components/ContentPreview.d.ts +12 -0
  20. package/dist/admin/components/ContentPreview.d.ts.map +1 -0
  21. package/dist/admin/components/ContentPreview.js +95 -0
  22. package/dist/admin/components/ContentPreview.js.map +1 -0
  23. package/dist/admin/components/Dashboard.d.ts +13 -0
  24. package/dist/admin/components/Dashboard.d.ts.map +1 -0
  25. package/dist/admin/components/Dashboard.js +7 -0
  26. package/dist/admin/components/Dashboard.js.map +1 -0
  27. package/dist/admin/components/DashboardContent.d.ts +11 -0
  28. package/dist/admin/components/DashboardContent.d.ts.map +1 -0
  29. package/dist/admin/components/DashboardContent.js +129 -0
  30. package/dist/admin/components/DashboardContent.js.map +1 -0
  31. package/dist/admin/components/FormFieldRowLabel.d.ts +21 -0
  32. package/dist/admin/components/FormFieldRowLabel.d.ts.map +1 -0
  33. package/dist/admin/components/FormFieldRowLabel.js +47 -0
  34. package/dist/admin/components/FormFieldRowLabel.js.map +1 -0
  35. package/dist/admin/components/Icon.d.ts +10 -0
  36. package/dist/admin/components/Icon.d.ts.map +1 -0
  37. package/dist/admin/components/Icon.js +16 -0
  38. package/dist/admin/components/Icon.js.map +1 -0
  39. package/dist/admin/components/Logo.d.ts +10 -0
  40. package/dist/admin/components/Logo.d.ts.map +1 -0
  41. package/dist/admin/components/Logo.js +16 -0
  42. package/dist/admin/components/Logo.js.map +1 -0
  43. package/dist/admin/components/NavigationItemRowLabel.d.ts +21 -0
  44. package/dist/admin/components/NavigationItemRowLabel.d.ts.map +1 -0
  45. package/dist/admin/components/NavigationItemRowLabel.js +43 -0
  46. package/dist/admin/components/NavigationItemRowLabel.js.map +1 -0
  47. package/dist/admin/components/NavigationSubItemRowLabel.d.ts +19 -0
  48. package/dist/admin/components/NavigationSubItemRowLabel.d.ts.map +1 -0
  49. package/dist/admin/components/NavigationSubItemRowLabel.js +32 -0
  50. package/dist/admin/components/NavigationSubItemRowLabel.js.map +1 -0
  51. package/dist/admin/components/PagesListHeader.d.ts +13 -0
  52. package/dist/admin/components/PagesListHeader.d.ts.map +1 -0
  53. package/dist/admin/components/PagesListHeader.js +48 -0
  54. package/dist/admin/components/PagesListHeader.js.map +1 -0
  55. package/dist/admin/components/ProductsListHeader.d.ts +13 -0
  56. package/dist/admin/components/ProductsListHeader.d.ts.map +1 -0
  57. package/dist/admin/components/ProductsListHeader.js +55 -0
  58. package/dist/admin/components/ProductsListHeader.js.map +1 -0
  59. package/dist/admin/components/styles/CollectionListHeader.css +161 -0
  60. package/dist/admin/components/styles/ContentPreview.css +416 -0
  61. package/dist/admin/components/styles/Dashboard.css +338 -0
  62. package/dist/admin/fields/ColorInput.d.ts +13 -0
  63. package/dist/admin/fields/ColorInput.d.ts.map +1 -0
  64. package/dist/admin/fields/ColorInput.js +201 -0
  65. package/dist/admin/fields/ColorInput.js.map +1 -0
  66. package/dist/admin/fields/index.d.ts +9 -0
  67. package/dist/admin/fields/index.d.ts.map +1 -0
  68. package/dist/admin/fields/index.js +9 -0
  69. package/dist/admin/fields/index.js.map +1 -0
  70. package/dist/admin/index.d.ts +24 -0
  71. package/dist/admin/index.d.ts.map +1 -0
  72. package/dist/admin/index.js +30 -0
  73. package/dist/admin/index.js.map +1 -0
  74. package/dist/blocks/ContentBlocks.d.ts +75 -0
  75. package/dist/blocks/ContentBlocks.d.ts.map +1 -0
  76. package/dist/blocks/ContentBlocks.js +1241 -0
  77. package/dist/blocks/ContentBlocks.js.map +1 -0
  78. package/dist/blocks/index.d.ts +2 -0
  79. package/dist/blocks/index.d.ts.map +1 -0
  80. package/dist/blocks/index.js +3 -0
  81. package/dist/blocks/index.js.map +1 -0
  82. package/dist/client/PayloadAPIClient.d.ts +65 -0
  83. package/dist/client/PayloadAPIClient.d.ts.map +1 -0
  84. package/dist/client/PayloadAPIClient.js +167 -0
  85. package/dist/client/PayloadAPIClient.js.map +1 -0
  86. package/dist/collections/Automations.d.ts +12 -0
  87. package/dist/collections/Automations.d.ts.map +1 -0
  88. package/dist/collections/Automations.js +741 -0
  89. package/dist/collections/Automations.js.map +1 -0
  90. package/dist/collections/Features.d.ts +3 -0
  91. package/dist/collections/Features.d.ts.map +1 -0
  92. package/dist/collections/Features.js +69 -0
  93. package/dist/collections/Features.js.map +1 -0
  94. package/dist/collections/Footer.d.ts +11 -0
  95. package/dist/collections/Footer.d.ts.map +1 -0
  96. package/dist/collections/Footer.js +130 -0
  97. package/dist/collections/Footer.js.map +1 -0
  98. package/dist/collections/FormSubmissions.d.ts +3 -0
  99. package/dist/collections/FormSubmissions.d.ts.map +1 -0
  100. package/dist/collections/FormSubmissions.js +119 -0
  101. package/dist/collections/FormSubmissions.js.map +1 -0
  102. package/dist/collections/Forms.d.ts +16 -0
  103. package/dist/collections/Forms.d.ts.map +1 -0
  104. package/dist/collections/Forms.js +308 -0
  105. package/dist/collections/Forms.js.map +1 -0
  106. package/dist/collections/HeroBlocks.d.ts +3 -0
  107. package/dist/collections/HeroBlocks.d.ts.map +1 -0
  108. package/dist/collections/HeroBlocks.js +115 -0
  109. package/dist/collections/HeroBlocks.js.map +1 -0
  110. package/dist/collections/Media.d.ts +3 -0
  111. package/dist/collections/Media.d.ts.map +1 -0
  112. package/dist/collections/Media.js +26 -0
  113. package/dist/collections/Media.js.map +1 -0
  114. package/dist/collections/Navigation.d.ts +3 -0
  115. package/dist/collections/Navigation.d.ts.map +1 -0
  116. package/dist/collections/Navigation.js +106 -0
  117. package/dist/collections/Navigation.js.map +1 -0
  118. package/dist/collections/Pages.d.ts +3 -0
  119. package/dist/collections/Pages.d.ts.map +1 -0
  120. package/dist/collections/Pages.js +94 -0
  121. package/dist/collections/Pages.js.map +1 -0
  122. package/dist/collections/Posts.d.ts +3 -0
  123. package/dist/collections/Posts.d.ts.map +1 -0
  124. package/dist/collections/Posts.js +134 -0
  125. package/dist/collections/Posts.js.map +1 -0
  126. package/dist/collections/Products.d.ts +3 -0
  127. package/dist/collections/Products.d.ts.map +1 -0
  128. package/dist/collections/Products.js +264 -0
  129. package/dist/collections/Products.js.map +1 -0
  130. package/dist/collections/Users.d.ts +3 -0
  131. package/dist/collections/Users.d.ts.map +1 -0
  132. package/dist/collections/Users.js +53 -0
  133. package/dist/collections/Users.js.map +1 -0
  134. package/dist/collections/hooks/index.d.ts +9 -0
  135. package/dist/collections/hooks/index.d.ts.map +1 -0
  136. package/dist/collections/hooks/index.js +9 -0
  137. package/dist/collections/hooks/index.js.map +1 -0
  138. package/dist/collections/hooks/loggingHooks.d.ts +45 -0
  139. package/dist/collections/hooks/loggingHooks.d.ts.map +1 -0
  140. package/dist/collections/hooks/loggingHooks.js +109 -0
  141. package/dist/collections/hooks/loggingHooks.js.map +1 -0
  142. package/dist/collections/index.d.ts +14 -0
  143. package/dist/collections/index.d.ts.map +1 -0
  144. package/dist/collections/index.js +16 -0
  145. package/dist/collections/index.js.map +1 -0
  146. package/dist/components/index.d.ts +2 -0
  147. package/dist/components/index.d.ts.map +1 -0
  148. package/dist/components/index.js +4 -0
  149. package/dist/components/index.js.map +1 -0
  150. package/dist/globals/AdvancedSettings.d.ts +8 -0
  151. package/dist/globals/AdvancedSettings.d.ts.map +1 -0
  152. package/dist/globals/AdvancedSettings.js +157 -0
  153. package/dist/globals/AdvancedSettings.js.map +1 -0
  154. package/dist/globals/Integrations.d.ts +8 -0
  155. package/dist/globals/Integrations.d.ts.map +1 -0
  156. package/dist/globals/Integrations.js +270 -0
  157. package/dist/globals/Integrations.js.map +1 -0
  158. package/dist/globals/SiteSettings.d.ts +8 -0
  159. package/dist/globals/SiteSettings.d.ts.map +1 -0
  160. package/dist/globals/SiteSettings.js +258 -0
  161. package/dist/globals/SiteSettings.js.map +1 -0
  162. package/dist/globals/ThemeSettings.d.ts +11 -0
  163. package/dist/globals/ThemeSettings.d.ts.map +1 -0
  164. package/dist/globals/ThemeSettings.js +92 -0
  165. package/dist/globals/ThemeSettings.js.map +1 -0
  166. package/dist/globals/index.d.ts +5 -0
  167. package/dist/globals/index.d.ts.map +1 -0
  168. package/dist/globals/index.js +6 -0
  169. package/dist/globals/index.js.map +1 -0
  170. package/dist/index.d.ts +9 -0
  171. package/dist/index.d.ts.map +1 -0
  172. package/dist/index.js +14 -0
  173. package/dist/index.js.map +1 -0
  174. package/dist/logging/index.d.ts +73 -0
  175. package/dist/logging/index.d.ts.map +1 -0
  176. package/dist/logging/index.js +190 -0
  177. package/dist/logging/index.js.map +1 -0
  178. package/dist/nextjs/BlockRenderer.d.ts +227 -0
  179. package/dist/nextjs/BlockRenderer.d.ts.map +1 -0
  180. package/dist/nextjs/BlockRenderer.js +358 -0
  181. package/dist/nextjs/BlockRenderer.js.map +1 -0
  182. package/dist/nextjs/ClientHomePage.d.ts +6 -0
  183. package/dist/nextjs/ClientHomePage.d.ts.map +1 -0
  184. package/dist/nextjs/ClientHomePage.js +17 -0
  185. package/dist/nextjs/ClientHomePage.js.map +1 -0
  186. package/dist/nextjs/ClientSideQwickApp.d.ts +23 -0
  187. package/dist/nextjs/ClientSideQwickApp.d.ts.map +1 -0
  188. package/dist/nextjs/ClientSideQwickApp.js +50 -0
  189. package/dist/nextjs/ClientSideQwickApp.js.map +1 -0
  190. package/dist/nextjs/DynamicQwickApp.d.ts +9 -0
  191. package/dist/nextjs/DynamicQwickApp.d.ts.map +1 -0
  192. package/dist/nextjs/DynamicQwickApp.js +19 -0
  193. package/dist/nextjs/DynamicQwickApp.js.map +1 -0
  194. package/dist/nextjs/FooterFromSettings.d.ts +6 -0
  195. package/dist/nextjs/FooterFromSettings.d.ts.map +1 -0
  196. package/dist/nextjs/FooterFromSettings.js +72 -0
  197. package/dist/nextjs/FooterFromSettings.js.map +1 -0
  198. package/dist/nextjs/FormBlockComponent.d.ts +25 -0
  199. package/dist/nextjs/FormBlockComponent.d.ts.map +1 -0
  200. package/dist/nextjs/FormBlockComponent.js +110 -0
  201. package/dist/nextjs/FormBlockComponent.js.map +1 -0
  202. package/dist/nextjs/HomePageContent.d.ts +6 -0
  203. package/dist/nextjs/HomePageContent.d.ts.map +1 -0
  204. package/dist/nextjs/HomePageContent.js +50 -0
  205. package/dist/nextjs/HomePageContent.js.map +1 -0
  206. package/dist/nextjs/LivePreviewClient.d.ts +40 -0
  207. package/dist/nextjs/LivePreviewClient.d.ts.map +1 -0
  208. package/dist/nextjs/LivePreviewClient.js +35 -0
  209. package/dist/nextjs/LivePreviewClient.js.map +1 -0
  210. package/dist/nextjs/RefreshRouteOnSave.d.ts +31 -0
  211. package/dist/nextjs/RefreshRouteOnSave.d.ts.map +1 -0
  212. package/dist/nextjs/RefreshRouteOnSave.js +59 -0
  213. package/dist/nextjs/RefreshRouteOnSave.js.map +1 -0
  214. package/dist/nextjs/ScriptsInjector.d.ts +2 -0
  215. package/dist/nextjs/ScriptsInjector.d.ts.map +1 -0
  216. package/dist/nextjs/ScriptsInjector.js +73 -0
  217. package/dist/nextjs/ScriptsInjector.js.map +1 -0
  218. package/dist/nextjs/ServerQwickApp.d.ts +13 -0
  219. package/dist/nextjs/ServerQwickApp.d.ts.map +1 -0
  220. package/dist/nextjs/ServerQwickApp.js +159 -0
  221. package/dist/nextjs/ServerQwickApp.js.map +1 -0
  222. package/dist/nextjs/SettingsProvider.d.ts +110 -0
  223. package/dist/nextjs/SettingsProvider.d.ts.map +1 -0
  224. package/dist/nextjs/SettingsProvider.js +107 -0
  225. package/dist/nextjs/SettingsProvider.js.map +1 -0
  226. package/dist/nextjs/SiteLogo.d.ts +35 -0
  227. package/dist/nextjs/SiteLogo.d.ts.map +1 -0
  228. package/dist/nextjs/SiteLogo.js +105 -0
  229. package/dist/nextjs/SiteLogo.js.map +1 -0
  230. package/dist/nextjs/framework.d.ts +19 -0
  231. package/dist/nextjs/framework.d.ts.map +1 -0
  232. package/dist/nextjs/framework.js +35 -0
  233. package/dist/nextjs/framework.js.map +1 -0
  234. package/dist/nextjs/index.d.ts +38 -0
  235. package/dist/nextjs/index.d.ts.map +1 -0
  236. package/dist/nextjs/index.js +47 -0
  237. package/dist/nextjs/index.js.map +1 -0
  238. package/dist/nextjs/metadata.d.ts +20 -0
  239. package/dist/nextjs/metadata.d.ts.map +1 -0
  240. package/dist/nextjs/metadata.js +107 -0
  241. package/dist/nextjs/metadata.js.map +1 -0
  242. package/dist/plugins/index.d.ts +2 -0
  243. package/dist/plugins/index.d.ts.map +1 -0
  244. package/dist/plugins/index.js +3 -0
  245. package/dist/plugins/index.js.map +1 -0
  246. package/dist/plugins/qwickapps-plugin.d.ts +78 -0
  247. package/dist/plugins/qwickapps-plugin.d.ts.map +1 -0
  248. package/dist/plugins/qwickapps-plugin.js +154 -0
  249. package/dist/plugins/qwickapps-plugin.js.map +1 -0
  250. package/dist/providers/PayloadDataProvider.d.ts +72 -0
  251. package/dist/providers/PayloadDataProvider.d.ts.map +1 -0
  252. package/dist/providers/PayloadDataProvider.js +222 -0
  253. package/dist/providers/PayloadDataProvider.js.map +1 -0
  254. package/dist/providers/index.d.ts +2 -0
  255. package/dist/providers/index.d.ts.map +1 -0
  256. package/dist/providers/index.js +3 -0
  257. package/dist/providers/index.js.map +1 -0
  258. package/dist/styles/admin-theme.css +352 -0
  259. 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
+ }