@shefing/quickfilter 1.0.43 → 1.0.45

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/README.md CHANGED
@@ -477,12 +477,13 @@ CollectionQuickFilterPlugin({
477
477
 
478
478
  </details>
479
479
 
480
- ### 🧭 NavDefaultFilter Component
480
+ ### 🧭 Default Filter from navigation in both Navigator and Dashboard
481
481
 
482
482
  <details>
483
- <summary>⚙️ <strong>Using NavDefaultFilter in your admin UI</strong></summary>
483
+ <summary>⚙️ <strong>Using Default Filter in your admin UI</strong></summary>
484
484
 
485
- The NavDefaultFilter component allows you to apply default filters to collection views directly from the navigation menu. This means users will see filtered data immediately when they click on a collection.
485
+ The NavDefaultFilter/DashBoard component allows you to apply default filters to collection views directly from the navigation menu or the dashboard.
486
+ This means users will see filtered data immediately when they click on a collection.
486
487
 
487
488
  ```typescript
488
489
  // payload.config.ts
@@ -490,6 +491,11 @@ export default buildConfig({
490
491
  admin: {
491
492
  components: {
492
493
  Nav: '@shefing/quickfilter/nav',
494
+ views: {
495
+ dashboard: {
496
+ Component: '@shefing/quickfilter/Dashboard',
497
+ },
498
+ },
493
499
  },
494
500
  },
495
501
  // ... rest of your config
@@ -534,6 +540,7 @@ export const Tasks: CollectionConfig = {
534
540
  - 🎯 **Context-aware navigation**: Users see the most relevant data immediately
535
541
  - ⏱️ **Time-saving**: No need to manually apply filters after navigation
536
542
  - 🧠 **Smart defaults**: Configure different default views for different collections
543
+ - 🔄 **Consistent experience**: Both Nav and Dashboard components are aligned with default filters for all collections
537
544
 
538
545
  </details>
539
546
 
@@ -1,3 +1,28 @@
1
- export { DefaultDashboard, type DashboardViewClientProps, type DashboardViewServerProps, type DashboardViewServerPropsOnly } from './Default';
2
- export { default } from './Default';
1
+ import type { groupNavItems } from '@payloadcms/ui/shared';
2
+ import type { ClientUser, Locale, ServerProps } from 'payload';
3
+ import React from 'react';
4
+ export type DashboardViewClientProps = {
5
+ locale: Locale;
6
+ };
7
+ export type DashboardViewServerPropsOnly = {
8
+ globalData: Array<{
9
+ data: {
10
+ _isLocked: boolean;
11
+ _lastEditedAt: string;
12
+ _userEditing: ClientUser | number | string;
13
+ };
14
+ lockDuration?: number;
15
+ slug: string;
16
+ }>;
17
+ /**
18
+ * @deprecated
19
+ * This prop is deprecated and will be removed in the next major version.
20
+ * Components now import their own `Link` directly from `next/link`.
21
+ */
22
+ Link?: React.ComponentType;
23
+ navGroups?: ReturnType<typeof groupNavItems>;
24
+ } & ServerProps;
25
+ export type DashboardViewServerProps = DashboardViewClientProps & DashboardViewServerPropsOnly;
26
+ export declare function DefaultDashboard(props: DashboardViewServerProps): React.JSX.Element;
27
+ export default DefaultDashboard;
3
28
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/Dashboard/index.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,KAAK,wBAAwB,EAAE,KAAK,wBAAwB,EAAE,KAAK,4BAA4B,EAAE,MAAM,WAAW,CAAA;AAC7I,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/Dashboard/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAA;AAC1D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AAO9D,OAAO,KAAmB,MAAM,OAAO,CAAA;AAOvC,MAAM,MAAM,wBAAwB,GAAG;IACrC,MAAM,EAAE,MAAM,CAAA;CACf,CAAA;AAED,MAAM,MAAM,4BAA4B,GAAG;IACzC,UAAU,EAAE,KAAK,CAAC;QAChB,IAAI,EAAE;YAAE,SAAS,EAAE,OAAO,CAAC;YAAC,aAAa,EAAE,MAAM,CAAC;YAAC,YAAY,EAAE,UAAU,GAAG,MAAM,GAAG,MAAM,CAAA;SAAE,CAAA;QAC/F,YAAY,CAAC,EAAE,MAAM,CAAA;QACrB,IAAI,EAAE,MAAM,CAAA;KACb,CAAC,CAAA;IACF;;;;OAIG;IACH,IAAI,CAAC,EAAE,KAAK,CAAC,aAAa,CAAA;IAC1B,SAAS,CAAC,EAAE,UAAU,CAAC,OAAO,aAAa,CAAC,CAAA;CAC7C,GAAG,WAAW,CAAA;AAEf,MAAM,MAAM,wBAAwB,GAAG,wBAAwB,GAAG,4BAA4B,CAAA;AAG9F,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,wBAAwB,qBAkK/D;AAED,eAAe,gBAAgB,CAAA"}
@@ -1,5 +1,141 @@
1
- // Re-export DefaultDashboard from Default
2
- export { DefaultDashboard } from './Default';
3
- export { default } from './Default';
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { getTranslation } from '@payloadcms/translations';
3
+ import { Button, Card, Gutter, Locked } from '@payloadcms/ui';
4
+ import { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent';
5
+ import { EntityType } from '@payloadcms/ui/shared';
6
+ import { formatAdminURL } from 'payload/shared';
7
+ import React, { Fragment } from 'react';
8
+ import { processNavGroups } from '../lib/utils';
9
+ const baseClass = 'dashboard';
10
+ export function DefaultDashboard(props) {
11
+ const { globalData, i18n, i18n: { t }, locale, navGroups: originalNavGroups, params, payload: { config: { admin: { components: { afterDashboard, beforeDashboard } }, routes: { admin: adminRoute }, collections } }, payload, permissions, searchParams, user } = props;
12
+ // Process navGroups to calculate href values
13
+ const navGroups = originalNavGroups ? processNavGroups(originalNavGroups, collections, payload, i18n) : [];
14
+ return /*#__PURE__*/ _jsx("div", {
15
+ className: baseClass,
16
+ children: /*#__PURE__*/ _jsxs(Gutter, {
17
+ className: `${baseClass}__wrap`,
18
+ children: [
19
+ beforeDashboard && RenderServerComponent({
20
+ Component: beforeDashboard,
21
+ importMap: payload.importMap,
22
+ serverProps: {
23
+ i18n,
24
+ locale,
25
+ params,
26
+ payload,
27
+ permissions,
28
+ searchParams,
29
+ user
30
+ }
31
+ }),
32
+ /*#__PURE__*/ _jsx(Fragment, {
33
+ children: !navGroups || navGroups?.length === 0 ? /*#__PURE__*/ _jsx("p", {
34
+ children: "no nav groups...."
35
+ }) : navGroups.map(({ entities, label }, groupIndex)=>{
36
+ return /*#__PURE__*/ _jsxs("div", {
37
+ className: `${baseClass}__group`,
38
+ children: [
39
+ /*#__PURE__*/ _jsx("h2", {
40
+ className: `${baseClass}__label`,
41
+ children: label
42
+ }),
43
+ /*#__PURE__*/ _jsx("ul", {
44
+ className: `${baseClass}__card-list`,
45
+ children: entities.map(({ slug, type, label, href: entityHref }, entityIndex)=>{
46
+ let title;
47
+ let buttonAriaLabel;
48
+ let createHREF;
49
+ let href;
50
+ let hasCreatePermission;
51
+ let isLocked = null;
52
+ let userEditing = null;
53
+ if (type === EntityType.collection) {
54
+ title = getTranslation(label, i18n);
55
+ buttonAriaLabel = t('general:showAllLabel', {
56
+ label: title
57
+ });
58
+ // Use the processed href if available, otherwise use the default
59
+ href = entityHref || formatAdminURL({
60
+ adminRoute,
61
+ path: `/collections/${slug}`
62
+ });
63
+ createHREF = formatAdminURL({
64
+ adminRoute,
65
+ path: `/collections/${slug}/create`
66
+ });
67
+ hasCreatePermission = permissions?.collections?.[slug]?.create;
68
+ }
69
+ if (type === EntityType.global) {
70
+ buttonAriaLabel = t('general:editLabel', {
71
+ label: getTranslation(label, i18n)
72
+ });
73
+ href = formatAdminURL({
74
+ adminRoute,
75
+ path: `/globals/${slug}`
76
+ });
77
+ // Find the lock status for the global
78
+ const globalLockData = globalData.find((global)=>global.slug === slug);
79
+ if (globalLockData) {
80
+ isLocked = globalLockData.data._isLocked;
81
+ userEditing = globalLockData.data._userEditing;
82
+ // Check if the lock is expired
83
+ const lockDuration = globalLockData?.lockDuration;
84
+ const lastEditedAt = new Date(globalLockData.data?._lastEditedAt).getTime();
85
+ const lockDurationInMilliseconds = lockDuration * 1000;
86
+ const lockExpirationTime = lastEditedAt + lockDurationInMilliseconds;
87
+ if (new Date().getTime() > lockExpirationTime) {
88
+ isLocked = false;
89
+ userEditing = null;
90
+ }
91
+ }
92
+ }
93
+ return /*#__PURE__*/ _jsx("li", {
94
+ children: /*#__PURE__*/ _jsx(Card, {
95
+ actions: isLocked && user?.id !== userEditing?.id ? /*#__PURE__*/ _jsx(Locked, {
96
+ className: `${baseClass}__locked`,
97
+ user: userEditing
98
+ }) : hasCreatePermission && type === EntityType.collection ? /*#__PURE__*/ _jsx(Button, {
99
+ "aria-label": t('general:createNewLabel', {
100
+ label
101
+ }),
102
+ buttonStyle: "icon-label",
103
+ el: "link",
104
+ icon: "plus",
105
+ iconStyle: "with-border",
106
+ round: true,
107
+ to: createHREF
108
+ }) : undefined,
109
+ buttonAriaLabel: buttonAriaLabel,
110
+ href: href,
111
+ id: `card-${slug}`,
112
+ title: getTranslation(label, i18n),
113
+ titleAs: "h3"
114
+ })
115
+ }, entityIndex);
116
+ })
117
+ })
118
+ ]
119
+ }, groupIndex);
120
+ })
121
+ }),
122
+ afterDashboard && RenderServerComponent({
123
+ Component: afterDashboard,
124
+ importMap: payload.importMap,
125
+ serverProps: {
126
+ i18n,
127
+ locale,
128
+ params,
129
+ payload,
130
+ permissions,
131
+ searchParams,
132
+ user
133
+ }
134
+ })
135
+ ]
136
+ })
137
+ });
138
+ }
139
+ export default DefaultDashboard;
4
140
 
5
141
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/Dashboard/index.tsx"],"sourcesContent":["// Re-export DefaultDashboard from Default\nexport { DefaultDashboard, type DashboardViewClientProps, type DashboardViewServerProps, type DashboardViewServerPropsOnly } from './Default'\nexport { default } from './Default'\n\n"],"names":["DefaultDashboard","default"],"mappings":"AAAA,0CAA0C;AAC1C,SAASA,gBAAgB,QAAyG,YAAW;AAC7I,SAASC,OAAO,QAAQ,YAAW"}
1
+ {"version":3,"sources":["../../src/Dashboard/index.tsx"],"sourcesContent":["import type { groupNavItems } from '@payloadcms/ui/shared'\nimport type { ClientUser, Locale, ServerProps } from 'payload'\n\nimport { getTranslation } from '@payloadcms/translations'\nimport { Button, Card, Gutter, Locked } from '@payloadcms/ui'\nimport { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent'\nimport { EntityType } from '@payloadcms/ui/shared'\nimport { formatAdminURL } from 'payload/shared'\nimport React, { Fragment } from 'react'\n\nimport {EntityWithHref} from \"../types\";\nimport { processNavGroups } from '../lib/utils';\n\nconst baseClass = 'dashboard'\n\nexport type DashboardViewClientProps = {\n locale: Locale\n}\n\nexport type DashboardViewServerPropsOnly = {\n globalData: Array<{\n data: { _isLocked: boolean; _lastEditedAt: string; _userEditing: ClientUser | number | string }\n lockDuration?: number\n slug: string\n }>\n /**\n * @deprecated\n * This prop is deprecated and will be removed in the next major version.\n * Components now import their own `Link` directly from `next/link`.\n */\n Link?: React.ComponentType\n navGroups?: ReturnType<typeof groupNavItems>\n} & ServerProps\n\nexport type DashboardViewServerProps = DashboardViewClientProps & DashboardViewServerPropsOnly\n\n\nexport function DefaultDashboard(props: DashboardViewServerProps) {\n const {\n globalData,\n i18n,\n i18n: { t },\n locale,\n navGroups: originalNavGroups,\n params,\n payload: {\n config: {\n admin: {\n components: { afterDashboard, beforeDashboard },\n },\n routes: { admin: adminRoute },\n collections,\n },\n },\n payload,\n permissions,\n searchParams,\n user,\n } = props\n\n // Process navGroups to calculate href values\n const navGroups = originalNavGroups ? processNavGroups(originalNavGroups, collections, payload, i18n) : []\n\n return (\n <div className={baseClass}>\n <Gutter className={`${baseClass}__wrap`}>\n {beforeDashboard &&\n RenderServerComponent({\n Component: beforeDashboard,\n importMap: payload.importMap,\n serverProps: {\n i18n,\n locale,\n params,\n payload,\n permissions,\n searchParams,\n user,\n } satisfies ServerProps,\n })}\n\n <Fragment>\n {!navGroups || navGroups?.length === 0 ? (\n <p>no nav groups....</p>\n ) : (\n navGroups.map(({ entities, label }, groupIndex) => {\n return (\n <div className={`${baseClass}__group`} key={groupIndex}>\n <h2 className={`${baseClass}__label`}>{label}</h2>\n <ul className={`${baseClass}__card-list`}>\n {entities.map(({ slug, type, label, href: entityHref }:EntityWithHref, entityIndex) => {\n let title: string\n let buttonAriaLabel: string\n let createHREF: string\n let href: string\n let hasCreatePermission: boolean\n let isLocked = null\n let userEditing = null\n\n if (type === EntityType.collection) {\n title = getTranslation(label, i18n)\n\n buttonAriaLabel = t('general:showAllLabel', { label: title })\n\n // Use the processed href if available, otherwise use the default\n href = entityHref || formatAdminURL({ adminRoute, path: `/collections/${slug}` })\n\n createHREF = formatAdminURL({\n adminRoute,\n path: `/collections/${slug}/create`,\n })\n\n hasCreatePermission = permissions?.collections?.[slug]?.create\n }\n\n if (type === EntityType.global) {\n buttonAriaLabel = t('general:editLabel', {\n label: getTranslation(label, i18n),\n })\n\n href = formatAdminURL({\n adminRoute,\n path: `/globals/${slug}`,\n })\n\n // Find the lock status for the global\n const globalLockData = globalData.find((global) => global.slug === slug)\n if (globalLockData) {\n isLocked = globalLockData.data._isLocked\n userEditing = globalLockData.data._userEditing\n\n // Check if the lock is expired\n const lockDuration = globalLockData?.lockDuration\n const lastEditedAt = new Date(\n globalLockData.data?._lastEditedAt,\n ).getTime()\n\n const lockDurationInMilliseconds = lockDuration * 1000\n const lockExpirationTime = lastEditedAt + lockDurationInMilliseconds\n\n if (new Date().getTime() > lockExpirationTime) {\n isLocked = false\n userEditing = null\n }\n }\n }\n\n return (\n <li key={entityIndex}>\n <Card\n actions={\n isLocked && user?.id !== userEditing?.id ? (\n <Locked className={`${baseClass}__locked`} user={userEditing} />\n ) : hasCreatePermission && type === EntityType.collection ? (\n <Button\n aria-label={t('general:createNewLabel', {\n label,\n })}\n buttonStyle=\"icon-label\"\n el=\"link\"\n icon=\"plus\"\n iconStyle=\"with-border\"\n round\n to={createHREF}\n />\n ) : undefined\n }\n buttonAriaLabel={buttonAriaLabel}\n href={href}\n id={`card-${slug}`}\n title={getTranslation(label, i18n)}\n titleAs=\"h3\"\n />\n </li>\n )\n })}\n </ul>\n </div>\n )\n })\n )}\n </Fragment>\n {afterDashboard &&\n RenderServerComponent({\n Component: afterDashboard,\n importMap: payload.importMap,\n serverProps: {\n i18n,\n locale,\n params,\n payload,\n permissions,\n searchParams,\n user,\n } satisfies ServerProps,\n })}\n </Gutter>\n </div>\n )\n}\n\nexport default DefaultDashboard\n"],"names":["getTranslation","Button","Card","Gutter","Locked","RenderServerComponent","EntityType","formatAdminURL","React","Fragment","processNavGroups","baseClass","DefaultDashboard","props","globalData","i18n","t","locale","navGroups","originalNavGroups","params","payload","config","admin","components","afterDashboard","beforeDashboard","routes","adminRoute","collections","permissions","searchParams","user","div","className","Component","importMap","serverProps","length","p","map","entities","label","groupIndex","h2","ul","slug","type","href","entityHref","entityIndex","title","buttonAriaLabel","createHREF","hasCreatePermission","isLocked","userEditing","collection","path","create","global","globalLockData","find","data","_isLocked","_userEditing","lockDuration","lastEditedAt","Date","_lastEditedAt","getTime","lockDurationInMilliseconds","lockExpirationTime","li","actions","id","aria-label","buttonStyle","el","icon","iconStyle","round","to","undefined","titleAs"],"mappings":"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"}
@@ -91,6 +91,7 @@ export type FilterDetaild = {
91
91
  options?: Array<any>;
92
92
  row?: number | undefined;
93
93
  width?: string;
94
+ virtual?: string | boolean;
94
95
  };
95
96
  export interface FilterRow {
96
97
  rowNumber: number;
@@ -1 +1 @@
1
- {"version":3,"file":"filters-type.d.ts","sourceRoot":"","sources":["../../../src/filters/types/filters-type.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,SAAS;IACxB,IAAI,EAAE,IAAI,GAAG,SAAS,CAAC;IACvB,EAAE,EAAE,IAAI,GAAG,SAAS,CAAC;CACtB;AAED,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,YAAY,GAAG,QAAQ,CAAC;IAC9B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,WAAW,CAAC,EAAE,SAAS,CAAC;CACzB;AAED,MAAM,WAAW,kBAAkB;IACjC,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,iBAAiB;IAChC,IAAI,EAAE,KAAK,GAAG,MAAM,GAAG,MAAM,CAAC;IAC9B,cAAc,EAAE,MAAM,EAAE,CAAC;CAC1B;AAED,MAAM,WAAW,iBAAiB;IAChC,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,sBAAsB;IACrC,cAAc,EAAE,MAAM,EAAE,CAAC;CAC1B;AAED,MAAM,MAAM,mBAAmB,GAAG,SAAS,GAAG,WAAW,GAAG,eAAe,CAAC;AAE5E,MAAM,WAAW,MAAM;IACrB,IAAI,EAAE,IAAI,GAAG,IAAI,CAAC;IAClB,SAAS,EAAE,KAAK,GAAG,KAAK,CAAC;CAC1B;AAGD,MAAM,MAAM,UAAU,GAAG,MAAM,GAAG,QAAQ,GAAG,UAAU,GAAG,cAAc,CAAC;AAEzE,MAAM,WAAW,gBAAgB;IAC/B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,UAAU,CAAC;IACjB,KAAK,EAAE;QACL,EAAE,EAAE,MAAM,CAAC;QACX,EAAE,EAAE,MAAM,CAAC;KACZ,CAAC;IACF,KAAK,EAAE;QACL,EAAE,EAAE,MAAM,CAAC;QACX,EAAE,EAAE,MAAM,CAAC;KACZ,CAAC;CACH;AAED,MAAM,WAAW,gBAAiB,SAAQ,gBAAgB;IACxD,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,CAAC,EAAE;QACZ,EAAE,EAAE,MAAM,CAAC;QACX,EAAE,EAAE,MAAM,CAAC;KACZ,CAAC;CACH;AAED,MAAM,WAAW,kBAAmB,SAAQ,gBAAgB;IAC1D,IAAI,EAAE,QAAQ,CAAC;IACf,OAAO,EAAE;QACP,EAAE,EAAE,kBAAkB,EAAE,CAAC;QACzB,EAAE,EAAE,kBAAkB,EAAE,CAAC;KAC1B,CAAC;IACF,WAAW,CAAC,EAAE;QACZ,EAAE,EAAE,MAAM,CAAC;QACX,EAAE,EAAE,MAAM,CAAC;KACZ,CAAC;IACF,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,MAAM,WAAW,oBAAqB,SAAQ,gBAAgB;IAC5D,IAAI,EAAE,UAAU,CAAC;IACjB,aAAa,EAAE;QACb,EAAE,EAAE,MAAM,CAAC;QACX,EAAE,EAAE,MAAM,CAAC;KACZ,CAAC;CACH;AAED,MAAM,WAAW,uBAAwB,SAAQ,gBAAgB;IAC/D,IAAI,EAAE,cAAc,CAAC;IACrB,OAAO,EAAE;QACP,EAAE,EAAE,iBAAiB,EAAE,CAAC;QACxB,EAAE,EAAE,iBAAiB,EAAE,CAAC;KACzB,CAAC;IACF,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,MAAM,YAAY,GACpB,gBAAgB,GAChB,kBAAkB,GAClB,oBAAoB,GACpB,uBAAuB,CAAC;AAE5B,MAAM,WAAW,WAAW;IAC1B,CAAC,QAAQ,EAAE,MAAM,GACb,eAAe,GACf,iBAAiB,GACjB,mBAAmB,GACnB,sBAAsB,GACtB,SAAS,CAAC;CACf;AAED,MAAM,MAAM,aAAa,GAAG;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,GAAG,CAAC;IACV,OAAO,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC;IACrB,GAAG,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IACzB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,MAAM,WAAW,SAAS;IACxB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,aAAa,EAAE,CAAC;CAC1B"}
1
+ {"version":3,"file":"filters-type.d.ts","sourceRoot":"","sources":["../../../src/filters/types/filters-type.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/filters/types/filters-type.ts"],"sourcesContent":["export interface DateFilterOption {\n value: string;\n label: string;\n}\n\nexport interface DateRange {\n from: Date | undefined;\n to: Date | undefined;\n}\n\nexport interface DateFilterValue {\n type: 'predefined' | 'custom';\n predefinedValue?: string;\n customRange?: DateRange;\n}\n\nexport interface SelectFilterOption {\n value: string;\n label: string;\n}\n\nexport interface SelectFilterValue {\n type: 'all' | 'some' | 'none';\n selectedValues: string[];\n}\n\nexport interface SmallSelectOption {\n value: string;\n label: string;\n}\n\nexport interface SmallSelectFilterValue {\n selectedValues: string[];\n}\n\nexport type CheckboxFilterState = 'checked' | 'unchecked' | 'indeterminate';\n\nexport interface Locale {\n code: 'he' | 'en';\n direction: 'rtl' | 'ltr';\n}\n\n// New filter configuration types\nexport type FilterType = 'date' | 'select' | 'checkbox' | 'small-select';\n\nexport interface BaseFilterConfig {\n id: string;\n type: FilterType;\n label: {\n he: string;\n en: string;\n };\n title: {\n he: string;\n en: string;\n };\n}\n\nexport interface DateFilterConfig extends BaseFilterConfig {\n type: 'date';\n placeholder?: {\n he: string;\n en: string;\n };\n}\n\nexport interface SelectFilterConfig extends BaseFilterConfig {\n type: 'select';\n options: {\n he: SelectFilterOption[];\n en: SelectFilterOption[];\n };\n placeholder?: {\n he: string;\n en: string;\n };\n multiSelect?: boolean;\n showSearch?: boolean;\n}\n\nexport interface CheckboxFilterConfig extends BaseFilterConfig {\n type: 'checkbox';\n checkboxLabel: {\n he: string;\n en: string;\n };\n}\n\nexport interface SmallSelectFilterConfig extends BaseFilterConfig {\n type: 'small-select';\n options: {\n he: SmallSelectOption[];\n en: SmallSelectOption[];\n };\n multiSelect?: boolean;\n maxOptions?: number;\n}\n\nexport type FilterConfig =\n | DateFilterConfig\n | SelectFilterConfig\n | CheckboxFilterConfig\n | SmallSelectFilterConfig;\n\nexport interface FilterState {\n [filterId: string]:\n | DateFilterValue\n | SelectFilterValue\n | CheckboxFilterState\n | SmallSelectFilterValue\n | undefined;\n}\n\nexport type FilterDetaild = {\n name: string;\n label: string;\n type: any;\n options?: Array<any>; // Replace `any` with a more specific type if known\n row?: number | undefined;\n width?: string;\n};\n\nexport interface FilterRow {\n rowNumber: number;\n filters: FilterDetaild[];\n}\n"],"names":[],"mappings":"AA0HA,WAGC"}
1
+ {"version":3,"sources":["../../../src/filters/types/filters-type.ts"],"sourcesContent":["export interface DateFilterOption {\n value: string;\n label: string;\n}\n\nexport interface DateRange {\n from: Date | undefined;\n to: Date | undefined;\n}\n\nexport interface DateFilterValue {\n type: 'predefined' | 'custom';\n predefinedValue?: string;\n customRange?: DateRange;\n}\n\nexport interface SelectFilterOption {\n value: string;\n label: string;\n}\n\nexport interface SelectFilterValue {\n type: 'all' | 'some' | 'none';\n selectedValues: string[];\n}\n\nexport interface SmallSelectOption {\n value: string;\n label: string;\n}\n\nexport interface SmallSelectFilterValue {\n selectedValues: string[];\n}\n\nexport type CheckboxFilterState = 'checked' | 'unchecked' | 'indeterminate';\n\nexport interface Locale {\n code: 'he' | 'en';\n direction: 'rtl' | 'ltr';\n}\n\n// New filter configuration types\nexport type FilterType = 'date' | 'select' | 'checkbox' | 'small-select';\n\nexport interface BaseFilterConfig {\n id: string;\n type: FilterType;\n label: {\n he: string;\n en: string;\n };\n title: {\n he: string;\n en: string;\n };\n}\n\nexport interface DateFilterConfig extends BaseFilterConfig {\n type: 'date';\n placeholder?: {\n he: string;\n en: string;\n };\n}\n\nexport interface SelectFilterConfig extends BaseFilterConfig {\n type: 'select';\n options: {\n he: SelectFilterOption[];\n en: SelectFilterOption[];\n };\n placeholder?: {\n he: string;\n en: string;\n };\n multiSelect?: boolean;\n showSearch?: boolean;\n}\n\nexport interface CheckboxFilterConfig extends BaseFilterConfig {\n type: 'checkbox';\n checkboxLabel: {\n he: string;\n en: string;\n };\n}\n\nexport interface SmallSelectFilterConfig extends BaseFilterConfig {\n type: 'small-select';\n options: {\n he: SmallSelectOption[];\n en: SmallSelectOption[];\n };\n multiSelect?: boolean;\n maxOptions?: number;\n}\n\nexport type FilterConfig =\n | DateFilterConfig\n | SelectFilterConfig\n | CheckboxFilterConfig\n | SmallSelectFilterConfig;\n\nexport interface FilterState {\n [filterId: string]:\n | DateFilterValue\n | SelectFilterValue\n | CheckboxFilterState\n | SmallSelectFilterValue\n | undefined;\n}\n\nexport type FilterDetaild = {\n name: string;\n label: string;\n type: any;\n options?: Array<any>; // Replace `any` with a more specific type if known\n row?: number | undefined;\n width?: string;\n virtual?: string | boolean;\n};\n\nexport interface FilterRow {\n rowNumber: number;\n filters: FilterDetaild[];\n}\n"],"names":[],"mappings":"AA2HA,WAGC"}
@@ -1 +1 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/lib/utils.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,UAAU,EAAQ,MAAM,MAAM,CAAA;AAE5C,OAAO,KAAK,EAGV,aAAa,EAEd,MAAM,+BAA+B,CAAA;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAA;AAM3C,OAAO,KAAK,EAAC,KAAK,EAA4C,MAAM,SAAS,CAAA;AAK7E,wBAAgB,EAAE,CAAC,GAAG,MAAM,EAAE,UAAU,EAAE,UAEzC;AAGD,eAAO,MAAM,8BAA8B,UAClC,GAAG,UACF,aAAa,EAAE,UACf,eAAe,KACtB,MAAM,CAAC,MAAM,EAAE,GAAG,CAqGpB,CAAA;AAED,eAAO,MAAM,0BAA0B,WAC7B,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,aAChB,aAAa,EAAE,UAClB,eAAe,KACtB,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EA6DrB,CAAA;AAGD,wBAAgB,eAAe,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,SAAS,EAAE,MAAM,GAAG,KAAK,CAuCzE;AAGD,wBAAgB,gBAAgB,CAC9B,MAAM,EAAE,GAAG,EAAE,EACb,WAAW,EAAE,GAAG,EAAE,EAClB,OAAO,EAAE,GAAG,EACZ,IAAI,EAAE,GAAG,GACR,GAAG,EAAE,CA+DP"}
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/lib/utils.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,UAAU,EAAQ,MAAM,MAAM,CAAA;AAE5C,OAAO,KAAK,EAGV,aAAa,EAEd,MAAM,+BAA+B,CAAA;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,WAAW,CAAA;AAM3C,OAAO,KAAK,EAAC,KAAK,EAA4C,MAAM,SAAS,CAAA;AAK7E,wBAAgB,EAAE,CAAC,GAAG,MAAM,EAAE,UAAU,EAAE,UAEzC;AAGD,eAAO,MAAM,8BAA8B,UAClC,GAAG,UACF,aAAa,EAAE,UACf,eAAe,KACtB,MAAM,CAAC,MAAM,EAAE,GAAG,CAqGpB,CAAA;AAED,eAAO,MAAM,0BAA0B,WAC7B,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,aAChB,aAAa,EAAE,UAClB,eAAe,KACtB,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,EAgErB,CAAA;AAGD,wBAAgB,eAAe,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,SAAS,EAAE,MAAM,GAAG,KAAK,CAuCzE;AAGD,wBAAgB,gBAAgB,CAC9B,MAAM,EAAE,GAAG,EAAE,EACb,WAAW,EAAE,GAAG,EAAE,EAClB,OAAO,EAAE,GAAG,EACZ,IAAI,EAAE,GAAG,GACR,GAAG,EAAE,CAgEP"}
package/dist/lib/utils.js CHANGED
@@ -120,6 +120,9 @@ export const buildQuickFilterConditions = (values, fieldDefs, locale)=>{
120
120
  if (!value) return;
121
121
  const fieldDef = fieldDefs.find((f)=>f.name === fieldName);
122
122
  if (!fieldDef) return;
123
+ if (typeof fieldDef.virtual == 'string') {
124
+ fieldName = fieldDef.virtual;
125
+ }
123
126
  let condition = null;
124
127
  switch(fieldDef.type){
125
128
  case 'date':
@@ -242,7 +245,8 @@ export function processNavGroups(groups, collections, payload, i18n) {
242
245
  type: fieldConfig?.type,
243
246
  options: fieldConfig?.options,
244
247
  label: fieldConfig?.label || fieldName,
245
- row: 0
248
+ row: 0,
249
+ virtual: 'virtual' in fieldConfig && fieldConfig.virtual
246
250
  };
247
251
  }).filter(Boolean) || [];
248
252
  // If we have fields and a defaultFilter, calculate the URL with where clause
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/lib/utils.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { type ClassValue, clsx } from 'clsx'\nimport { twMerge } from 'tailwind-merge'\nimport type {\n CheckboxFilterState,\n DateFilterValue,\n FilterDetaild,\n SelectFilterValue,\n} from '../filters/types/filters-type'\nimport { SupportedLocale } from '../labels'\nimport {\n futureOptionKeys,\n pastOptionKeys,\n} from '../filters/constants/date-filter-options'\nimport { getDateRangeForOption } from '../filters/utils/date-helpers'\nimport type {Field, FieldAffectingData, SelectField, UIField} from 'payload'\nimport { formatAdminURL } from 'payload/shared'\nimport { stringify } from 'qs-esm'\nimport { EntityType } from '@payloadcms/ui/shared'\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs))\n}\n\n// Translates URL query conditions to the quick filter's internal state\nexport const parseWhereClauseToFilterValues = (\n where: any,\n fields: FilterDetaild[],\n locale: SupportedLocale,\n): Record<string, any> => {\n const values: Record<string, any> = {}\n const fieldNames = new Set(fields.map((f) => f.name))\n\n const recursiveParse = (clause: any) => {\n if (!clause || typeof clause !== 'object') return\n\n if (clause.and) {\n clause.and.forEach(recursiveParse)\n return\n }\n if (clause.or) {\n if (clause.or.length > 1) {\n return\n }\n clause.or.forEach(recursiveParse)\n return\n }\n for (const fieldName in clause) {\n if (fieldNames.has(fieldName)) {\n const fieldDef = fields.find((f) => f.name === fieldName)\n const condition = clause[fieldName]\n\n // Handle string values for date fields (e.g., 'todayAndFuture')\n if (fieldDef && fieldDef.type === 'date' && typeof condition === 'string') {\n const predefinedValue = condition\n if ([...pastOptionKeys, ...futureOptionKeys].includes(predefinedValue as any)) {\n values[fieldName] = {\n type: 'predefined',\n predefinedValue,\n }\n continue\n }\n }\n\n if (fieldDef && condition && typeof condition === 'object') {\n if ('equals' in condition) {\n if (fieldDef.type === 'checkbox') {\n values[fieldName] = (condition.equals == 'true' || condition.equals === true) ? 'checked' : 'unchecked'\n } else if (fieldDef.type === 'select') {\n values[fieldName] = { selectedValues: [condition.equals] }\n }\n } else if ('in' in condition && Array.isArray(condition.in)) {\n if (fieldDef.type === 'select') {\n values[fieldName] = { selectedValues: condition.in }\n }\n } else if ('greater_than_equal' in condition || 'less_than_equal' in condition) {\n if (fieldDef.type === 'date') {\n const fromDate = condition.greater_than_equal\n ? new Date(condition.greater_than_equal)\n : null\n const toDate = condition.less_than_equal ? new Date(condition.less_than_equal) : null\n const allDateOptions = [...pastOptionKeys, ...futureOptionKeys]\n let matchedOption = null\n\n for (const option of allDateOptions) {\n const range = getDateRangeForOption(option, locale)\n let isFromMatch : boolean\n if (fromDate) {\n isFromMatch = range.from?.toDateString() === fromDate.toDateString()\n } else if (fromDate == null && range.to == undefined) {\n // all future: fromDate == null & range.to == undefined\n isFromMatch = true\n }\n let isToMatch: boolean\n if (toDate) {\n isToMatch = range.to?.toDateString() === toDate.toDateString()\n } else if (toDate == null && range.to == undefined) {\n // all future: fromDate == null & range.to == undefined\n isToMatch = true\n }\n\n if (isFromMatch && isToMatch) {\n matchedOption = option\n break\n }\n }\n\n if (matchedOption) {\n values[fieldName] = {\n type: 'predefined',\n predefinedValue: matchedOption,\n }\n } else {\n values[fieldName] = {\n type: 'custom',\n customRange: {\n from: fromDate,\n to: toDate,\n },\n }\n }\n }\n }\n }\n }\n }\n }\n\n recursiveParse(where)\n return values\n}\n// Builds an array of condition objects from the quick filter values\nexport const buildQuickFilterConditions = (\n values: Record<string, any>,\n fieldDefs: FilterDetaild[],\n locale: SupportedLocale,\n): Record<string, any>[] => {\n const conditions: Record<string, any>[] = []\n\n Object.entries(values).forEach(([fieldName, value]) => {\n if (!value) return\n const fieldDef = fieldDefs.find((f) => f.name === fieldName)\n if (!fieldDef) return\n\n let condition: Record<string, any> | null = null\n\n switch (fieldDef.type) {\n case 'date': {\n const dateValue = value as DateFilterValue\n let from: Date | undefined\n let to: Date | undefined\n\n if (dateValue.predefinedValue) {\n const range = getDateRangeForOption(dateValue.predefinedValue, locale)\n from = range.from\n to = range.to\n } else if (dateValue.customRange) {\n if (dateValue.customRange.from) from = new Date(dateValue.customRange.from)\n if (dateValue.customRange.to) to = new Date(dateValue.customRange.to)\n }\n\n if (from || to) {\n const dateQuery: any = {}\n if (from) dateQuery.greater_than_equal = from\n if (to) dateQuery.less_than_equal = to\n if (Object.keys(dateQuery).length > 0) {\n condition = { [fieldName]: dateQuery }\n }\n }\n break\n }\n case 'select': {\n const selectValue = value as SelectFilterValue\n if (selectValue.selectedValues && selectValue.selectedValues.length > 0) {\n if (selectValue.selectedValues.length === 1) {\n condition = { [fieldName]: { equals: selectValue.selectedValues[0] } }\n } else {\n condition = { [fieldName]: { in: selectValue.selectedValues } }\n }\n }\n break\n }\n case 'checkbox': {\n const checkboxState = value as CheckboxFilterState\n if (checkboxState === 'checked') {\n condition = { [fieldName]: { equals: 'true' } }\n } else if (checkboxState === 'unchecked') {\n condition = { [fieldName]: { equals: 'false' } }\n }\n break\n }\n }\n if (condition) {\n conditions.push(condition)\n }\n })\n return conditions\n}\n\n// Recursive function to find a field by name\nexport function findFieldByName(fields: Field[], fieldName: string): Field {\n // First check at the current level\n const directMatch = fields.find(\n (f) => (f as FieldAffectingData).name === fieldName,\n )\n if (directMatch) return directMatch\n\n // If not found, search recursively in nested structures\n for (const item of fields) {\n // Check in array, row, or collapsible fields\n if (\n (item.type === 'array' || item.type === 'row' || item.type === 'collapsible') &&\n 'fields' in item &&\n Array.isArray(item.fields)\n ) {\n const nestedMatch = findFieldByName(item.fields, fieldName)\n if (nestedMatch) return nestedMatch\n } \n // Check in tabs\n else if (item.type === 'tabs' && Array.isArray(item.tabs)) {\n for (const tab of item.tabs) {\n if ('fields' in tab && Array.isArray(tab.fields)) {\n const tabMatch = findFieldByName(tab.fields, fieldName)\n if (tabMatch) return tabMatch\n }\n }\n } \n // Check in blocks\n else if (item.type === 'blocks' && Array.isArray(item.blocks)) {\n for (const block of item.blocks) {\n if ('fields' in block && Array.isArray(block.fields)) {\n const blockMatch = findFieldByName(block.fields, fieldName)\n if (blockMatch) return blockMatch\n }\n }\n }\n }\n\n return null\n}\n\n// Process nav groups to add href with defaultFilter query parameters\nexport function processNavGroups(\n groups: any[], \n collections: any[], \n payload: any, \n i18n: any\n): any[] {\n return groups.map(group => {\n const processedEntities = group.entities.map(entity => {\n if (entity.type === EntityType.collection) {\n const collection = collections.find(c => c.slug === entity.slug);\n\n // Check if collection has defaultFilter in custom props\n if (collection?.custom?.defaultFilter) {\n // Base URL without query parameters\n const baseHref = formatAdminURL({ \n adminRoute: payload.config.routes.admin, \n path: `/collections/${entity.slug}` \n });\n\n // Get the fields from the collection for parsing the where clause\n const fields: FilterDetaild[] =\n Object.keys(collection.custom.defaultFilter)\n ?.flat()\n .map((fieldName: string) => {\n const fieldConfig = findFieldByName(collection.fields, fieldName)\n return {\n name: fieldName,\n type: fieldConfig?.type,\n options: (fieldConfig as SelectField)?.options,\n label: (fieldConfig as UIField)?.label || fieldName,\n row: 0,\n } as FilterDetaild\n })\n .filter(Boolean) || []\n\n // If we have fields and a defaultFilter, calculate the URL with where clause\n if (fields.length > 0) {\n // Parse the defaultFilter to get filter values\n const filterValues = parseWhereClauseToFilterValues(\n collection.custom.defaultFilter,\n fields,\n i18n.language as SupportedLocale\n );\n // If we have filter values, add them to the URL\n if (Object.keys(filterValues).length > 0) {\n const quickFilterConditions = buildQuickFilterConditions(filterValues, fields, i18n.language as SupportedLocale)\n\n const whereCondition = quickFilterConditions.length === 1 ? quickFilterConditions[0] : { and: quickFilterConditions };\n const query = {\n where: whereCondition,\n };\n const stringifiedQuery = stringify(query, { addQueryPrefix: true });\n return {\n ...entity,\n href: `${baseHref}${stringifiedQuery}`\n };\n }\n }\n }\n }\n return entity;\n });\n\n return {\n ...group,\n entities: processedEntities\n };\n });\n}\n"],"names":["clsx","twMerge","futureOptionKeys","pastOptionKeys","getDateRangeForOption","formatAdminURL","stringify","EntityType","cn","inputs","parseWhereClauseToFilterValues","where","fields","locale","values","fieldNames","Set","map","f","name","recursiveParse","clause","and","forEach","or","length","fieldName","has","fieldDef","find","condition","type","predefinedValue","includes","equals","selectedValues","Array","isArray","in","fromDate","greater_than_equal","Date","toDate","less_than_equal","allDateOptions","matchedOption","option","range","isFromMatch","from","toDateString","to","undefined","isToMatch","customRange","buildQuickFilterConditions","fieldDefs","conditions","Object","entries","value","dateValue","dateQuery","keys","selectValue","checkboxState","push","findFieldByName","directMatch","item","nestedMatch","tabs","tab","tabMatch","blocks","block","blockMatch","processNavGroups","groups","collections","payload","i18n","group","processedEntities","entities","entity","collection","c","slug","custom","defaultFilter","baseHref","adminRoute","config","routes","admin","path","flat","fieldConfig","options","label","row","filter","Boolean","filterValues","language","quickFilterConditions","whereCondition","query","stringifiedQuery","addQueryPrefix","href"],"mappings":"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"}
1
+ {"version":3,"sources":["../../src/lib/utils.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { type ClassValue, clsx } from 'clsx'\nimport { twMerge } from 'tailwind-merge'\nimport type {\n CheckboxFilterState,\n DateFilterValue,\n FilterDetaild,\n SelectFilterValue,\n} from '../filters/types/filters-type'\nimport { SupportedLocale } from '../labels'\nimport {\n futureOptionKeys,\n pastOptionKeys,\n} from '../filters/constants/date-filter-options'\nimport { getDateRangeForOption } from '../filters/utils/date-helpers'\nimport type {Field, FieldAffectingData, SelectField, UIField} from 'payload'\nimport { formatAdminURL } from 'payload/shared'\nimport { stringify } from 'qs-esm'\nimport { EntityType } from '@payloadcms/ui/shared'\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs))\n}\n\n// Translates URL query conditions to the quick filter's internal state\nexport const parseWhereClauseToFilterValues = (\n where: any,\n fields: FilterDetaild[],\n locale: SupportedLocale,\n): Record<string, any> => {\n const values: Record<string, any> = {}\n const fieldNames = new Set(fields.map((f) => f.name))\n\n const recursiveParse = (clause: any) => {\n if (!clause || typeof clause !== 'object') return\n\n if (clause.and) {\n clause.and.forEach(recursiveParse)\n return\n }\n if (clause.or) {\n if (clause.or.length > 1) {\n return\n }\n clause.or.forEach(recursiveParse)\n return\n }\n for (const fieldName in clause) {\n if (fieldNames.has(fieldName)) {\n const fieldDef = fields.find((f) => f.name === fieldName)\n const condition = clause[fieldName]\n\n // Handle string values for date fields (e.g., 'todayAndFuture')\n if (fieldDef && fieldDef.type === 'date' && typeof condition === 'string') {\n const predefinedValue = condition\n if ([...pastOptionKeys, ...futureOptionKeys].includes(predefinedValue as any)) {\n values[fieldName] = {\n type: 'predefined',\n predefinedValue,\n }\n continue\n }\n }\n\n if (fieldDef && condition && typeof condition === 'object') {\n if ('equals' in condition) {\n if (fieldDef.type === 'checkbox') {\n values[fieldName] = (condition.equals == 'true' || condition.equals === true) ? 'checked' : 'unchecked'\n } else if (fieldDef.type === 'select') {\n values[fieldName] = { selectedValues: [condition.equals] }\n }\n } else if ('in' in condition && Array.isArray(condition.in)) {\n if (fieldDef.type === 'select') {\n values[fieldName] = { selectedValues: condition.in }\n }\n } else if ('greater_than_equal' in condition || 'less_than_equal' in condition) {\n if (fieldDef.type === 'date') {\n const fromDate = condition.greater_than_equal\n ? new Date(condition.greater_than_equal)\n : null\n const toDate = condition.less_than_equal ? new Date(condition.less_than_equal) : null\n const allDateOptions = [...pastOptionKeys, ...futureOptionKeys]\n let matchedOption = null\n\n for (const option of allDateOptions) {\n const range = getDateRangeForOption(option, locale)\n let isFromMatch : boolean\n if (fromDate) {\n isFromMatch = range.from?.toDateString() === fromDate.toDateString()\n } else if (fromDate == null && range.to == undefined) {\n // all future: fromDate == null & range.to == undefined\n isFromMatch = true\n }\n let isToMatch: boolean\n if (toDate) {\n isToMatch = range.to?.toDateString() === toDate.toDateString()\n } else if (toDate == null && range.to == undefined) {\n // all future: fromDate == null & range.to == undefined\n isToMatch = true\n }\n\n if (isFromMatch && isToMatch) {\n matchedOption = option\n break\n }\n }\n\n if (matchedOption) {\n values[fieldName] = {\n type: 'predefined',\n predefinedValue: matchedOption,\n }\n } else {\n values[fieldName] = {\n type: 'custom',\n customRange: {\n from: fromDate,\n to: toDate,\n },\n }\n }\n }\n }\n }\n }\n }\n }\n\n recursiveParse(where)\n return values\n}\n// Builds an array of condition objects from the quick filter values\nexport const buildQuickFilterConditions = (\n values: Record<string, any>,\n fieldDefs: FilterDetaild[],\n locale: SupportedLocale,\n): Record<string, any>[] => {\n const conditions: Record<string, any>[] = []\n\n Object.entries(values).forEach(([fieldName, value]) => {\n if (!value) return\n const fieldDef = fieldDefs.find((f) => f.name === fieldName)\n if (!fieldDef) return\n if (typeof fieldDef.virtual == 'string'){\n fieldName = fieldDef.virtual\n }\n\n let condition: Record<string, any> | null = null\n\n switch (fieldDef.type) {\n case 'date': {\n const dateValue = value as DateFilterValue\n let from: Date | undefined\n let to: Date | undefined\n\n if (dateValue.predefinedValue) {\n const range = getDateRangeForOption(dateValue.predefinedValue, locale)\n from = range.from\n to = range.to\n } else if (dateValue.customRange) {\n if (dateValue.customRange.from) from = new Date(dateValue.customRange.from)\n if (dateValue.customRange.to) to = new Date(dateValue.customRange.to)\n }\n\n if (from || to) {\n const dateQuery: any = {}\n if (from) dateQuery.greater_than_equal = from\n if (to) dateQuery.less_than_equal = to\n if (Object.keys(dateQuery).length > 0) {\n condition = { [fieldName]: dateQuery }\n }\n }\n break\n }\n case 'select': {\n const selectValue = value as SelectFilterValue\n if (selectValue.selectedValues && selectValue.selectedValues.length > 0) {\n if (selectValue.selectedValues.length === 1) {\n condition = { [fieldName]: { equals: selectValue.selectedValues[0] } }\n } else {\n condition = { [fieldName]: { in: selectValue.selectedValues } }\n }\n }\n break\n }\n case 'checkbox': {\n const checkboxState = value as CheckboxFilterState\n if (checkboxState === 'checked') {\n condition = { [fieldName]: { equals: 'true' } }\n } else if (checkboxState === 'unchecked') {\n condition = { [fieldName]: { equals: 'false' } }\n }\n break\n }\n }\n if (condition) {\n conditions.push(condition)\n }\n })\n return conditions\n}\n\n// Recursive function to find a field by name\nexport function findFieldByName(fields: Field[], fieldName: string): Field {\n // First check at the current level\n const directMatch = fields.find(\n (f) => (f as FieldAffectingData).name === fieldName,\n )\n if (directMatch) return directMatch\n\n // If not found, search recursively in nested structures\n for (const item of fields) {\n // Check in array, row, or collapsible fields\n if (\n (item.type === 'array' || item.type === 'row' || item.type === 'collapsible') &&\n 'fields' in item &&\n Array.isArray(item.fields)\n ) {\n const nestedMatch = findFieldByName(item.fields, fieldName)\n if (nestedMatch) return nestedMatch\n } \n // Check in tabs\n else if (item.type === 'tabs' && Array.isArray(item.tabs)) {\n for (const tab of item.tabs) {\n if ('fields' in tab && Array.isArray(tab.fields)) {\n const tabMatch = findFieldByName(tab.fields, fieldName)\n if (tabMatch) return tabMatch\n }\n }\n } \n // Check in blocks\n else if (item.type === 'blocks' && Array.isArray(item.blocks)) {\n for (const block of item.blocks) {\n if ('fields' in block && Array.isArray(block.fields)) {\n const blockMatch = findFieldByName(block.fields, fieldName)\n if (blockMatch) return blockMatch\n }\n }\n }\n }\n\n return null\n}\n\n// Process nav groups to add href with defaultFilter query parameters\nexport function processNavGroups(\n groups: any[], \n collections: any[], \n payload: any, \n i18n: any\n): any[] {\n return groups.map(group => {\n const processedEntities = group.entities.map(entity => {\n if (entity.type === EntityType.collection) {\n const collection = collections.find(c => c.slug === entity.slug);\n\n // Check if collection has defaultFilter in custom props\n if (collection?.custom?.defaultFilter) {\n // Base URL without query parameters\n const baseHref = formatAdminURL({ \n adminRoute: payload.config.routes.admin, \n path: `/collections/${entity.slug}` \n });\n\n // Get the fields from the collection for parsing the where clause\n const fields: FilterDetaild[] =\n Object.keys(collection.custom.defaultFilter)\n ?.flat()\n .map((fieldName: string) => {\n const fieldConfig = findFieldByName(collection.fields, fieldName)\n return {\n name: fieldName,\n type: fieldConfig?.type,\n options: (fieldConfig as SelectField)?.options,\n label: (fieldConfig as UIField)?.label || fieldName,\n row: 0,\n virtual: 'virtual' in fieldConfig && fieldConfig.virtual\n } as FilterDetaild\n })\n .filter(Boolean) || []\n\n // If we have fields and a defaultFilter, calculate the URL with where clause\n if (fields.length > 0) {\n // Parse the defaultFilter to get filter values\n const filterValues = parseWhereClauseToFilterValues(\n collection.custom.defaultFilter,\n fields,\n i18n.language as SupportedLocale\n );\n // If we have filter values, add them to the URL\n if (Object.keys(filterValues).length > 0) {\n const quickFilterConditions = buildQuickFilterConditions(filterValues, fields, i18n.language as SupportedLocale)\n\n const whereCondition = quickFilterConditions.length === 1 ? quickFilterConditions[0] : { and: quickFilterConditions };\n const query = {\n where: whereCondition,\n };\n const stringifiedQuery = stringify(query, { addQueryPrefix: true });\n return {\n ...entity,\n href: `${baseHref}${stringifiedQuery}`\n };\n }\n }\n }\n }\n return entity;\n });\n\n return {\n ...group,\n entities: processedEntities\n };\n });\n}\n"],"names":["clsx","twMerge","futureOptionKeys","pastOptionKeys","getDateRangeForOption","formatAdminURL","stringify","EntityType","cn","inputs","parseWhereClauseToFilterValues","where","fields","locale","values","fieldNames","Set","map","f","name","recursiveParse","clause","and","forEach","or","length","fieldName","has","fieldDef","find","condition","type","predefinedValue","includes","equals","selectedValues","Array","isArray","in","fromDate","greater_than_equal","Date","toDate","less_than_equal","allDateOptions","matchedOption","option","range","isFromMatch","from","toDateString","to","undefined","isToMatch","customRange","buildQuickFilterConditions","fieldDefs","conditions","Object","entries","value","virtual","dateValue","dateQuery","keys","selectValue","checkboxState","push","findFieldByName","directMatch","item","nestedMatch","tabs","tab","tabMatch","blocks","block","blockMatch","processNavGroups","groups","collections","payload","i18n","group","processedEntities","entities","entity","collection","c","slug","custom","defaultFilter","baseHref","adminRoute","config","routes","admin","path","flat","fieldConfig","options","label","row","filter","Boolean","filterValues","language","quickFilterConditions","whereCondition","query","stringifiedQuery","addQueryPrefix","href"],"mappings":"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"}
@@ -1,8 +1,8 @@
1
1
  import * as React from 'react';
2
2
  import { type VariantProps } from 'class-variance-authority';
3
3
  declare const buttonVariants: (props?: {
4
- variant?: "link" | "icon" | "default" | "defaultHover" | "destructive" | "outline" | "secondary" | "ghost";
5
- size?: "icon" | "default" | "lg" | "sm";
4
+ variant?: "link" | "default" | "defaultHover" | "destructive" | "outline" | "secondary" | "ghost" | "icon";
5
+ size?: "sm" | "lg" | "default" | "icon";
6
6
  } & import("class-variance-authority/types").ClassProp) => string;
7
7
  export interface ButtonProps extends React.ButtonHTMLAttributes<HTMLButtonElement>, VariantProps<typeof buttonVariants> {
8
8
  asChild?: boolean;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@shefing/quickfilter",
3
- "version": "1.0.43",
3
+ "version": "1.0.45",
4
4
  "private": false,
5
5
  "bugs": "https://github.com/shefing/payload-tools/issues",
6
6
  "repository": "https://github.com/shefing/payload-tools",
@@ -1,28 +0,0 @@
1
- import type { groupNavItems } from '@payloadcms/ui/shared';
2
- import type { ClientUser, Locale, ServerProps } from 'payload';
3
- import React from 'react';
4
- export type DashboardViewClientProps = {
5
- locale: Locale;
6
- };
7
- export type DashboardViewServerPropsOnly = {
8
- globalData: Array<{
9
- data: {
10
- _isLocked: boolean;
11
- _lastEditedAt: string;
12
- _userEditing: ClientUser | number | string;
13
- };
14
- lockDuration?: number;
15
- slug: string;
16
- }>;
17
- /**
18
- * @deprecated
19
- * This prop is deprecated and will be removed in the next major version.
20
- * Components now import their own `Link` directly from `next/link`.
21
- */
22
- Link?: React.ComponentType;
23
- navGroups?: ReturnType<typeof groupNavItems>;
24
- } & ServerProps;
25
- export type DashboardViewServerProps = DashboardViewClientProps & DashboardViewServerPropsOnly;
26
- export declare function DefaultDashboard(props: DashboardViewServerProps): React.JSX.Element;
27
- export default DefaultDashboard;
28
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/Dashboard/Default/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAA;AAC1D,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AAO9D,OAAO,KAAmB,MAAM,OAAO,CAAA;AAOvC,MAAM,MAAM,wBAAwB,GAAG;IACrC,MAAM,EAAE,MAAM,CAAA;CACf,CAAA;AAED,MAAM,MAAM,4BAA4B,GAAG;IACzC,UAAU,EAAE,KAAK,CAAC;QAChB,IAAI,EAAE;YAAE,SAAS,EAAE,OAAO,CAAC;YAAC,aAAa,EAAE,MAAM,CAAC;YAAC,YAAY,EAAE,UAAU,GAAG,MAAM,GAAG,MAAM,CAAA;SAAE,CAAA;QAC/F,YAAY,CAAC,EAAE,MAAM,CAAA;QACrB,IAAI,EAAE,MAAM,CAAA;KACb,CAAC,CAAA;IACF;;;;OAIG;IACH,IAAI,CAAC,EAAE,KAAK,CAAC,aAAa,CAAA;IAC1B,SAAS,CAAC,EAAE,UAAU,CAAC,OAAO,aAAa,CAAC,CAAA;CAC7C,GAAG,WAAW,CAAA;AAEf,MAAM,MAAM,wBAAwB,GAAG,wBAAwB,GAAG,4BAA4B,CAAA;AAG9F,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,wBAAwB,qBAoK/D;AAED,eAAe,gBAAgB,CAAA"}
@@ -1,142 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { getTranslation } from '@payloadcms/translations';
3
- import { Button, Card, Gutter, Locked } from '@payloadcms/ui';
4
- import { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent';
5
- import { EntityType } from '@payloadcms/ui/shared';
6
- import { formatAdminURL } from 'payload/shared';
7
- import React, { Fragment } from 'react';
8
- import { processNavGroups } from '../../lib/utils';
9
- const baseClass = 'dashboard';
10
- export function DefaultDashboard(props) {
11
- const { globalData, i18n, i18n: { t }, locale, navGroups: originalNavGroups, params, payload: { config: { admin: { components: { afterDashboard, beforeDashboard } }, routes: { admin: adminRoute }, collections } }, payload, permissions, searchParams, user } = props;
12
- // Process navGroups to calculate href values
13
- const navGroups = originalNavGroups ? processNavGroups(originalNavGroups, collections, payload, i18n) : [];
14
- return /*#__PURE__*/ _jsx("div", {
15
- className: baseClass,
16
- children: /*#__PURE__*/ _jsxs(Gutter, {
17
- className: `${baseClass}__wrap`,
18
- children: [
19
- beforeDashboard && RenderServerComponent({
20
- Component: beforeDashboard,
21
- importMap: payload.importMap,
22
- serverProps: {
23
- i18n,
24
- locale,
25
- params,
26
- payload,
27
- permissions,
28
- searchParams,
29
- user
30
- }
31
- }),
32
- /*#__PURE__*/ _jsx(Fragment, {
33
- children: !navGroups || navGroups?.length === 0 ? /*#__PURE__*/ _jsx("p", {
34
- children: "no nav groups...."
35
- }) : navGroups.map(({ entities, label }, groupIndex)=>{
36
- return /*#__PURE__*/ _jsxs("div", {
37
- className: `${baseClass}__group`,
38
- children: [
39
- /*#__PURE__*/ _jsx("h2", {
40
- className: `${baseClass}__label`,
41
- children: label
42
- }),
43
- /*#__PURE__*/ _jsx("ul", {
44
- className: `${baseClass}__card-list`,
45
- children: entities.map(({ slug, type, label, href: entityHref }, entityIndex)=>{
46
- let title;
47
- let buttonAriaLabel;
48
- let createHREF;
49
- let href;
50
- let hasCreatePermission;
51
- let isLocked = null;
52
- let userEditing = null;
53
- if (type === EntityType.collection) {
54
- title = getTranslation(label, i18n);
55
- buttonAriaLabel = t('general:showAllLabel', {
56
- label: title
57
- });
58
- // Use the processed href if available, otherwise use the default
59
- href = entityHref || formatAdminURL({
60
- adminRoute,
61
- path: `/collections/${slug}`
62
- });
63
- createHREF = formatAdminURL({
64
- adminRoute,
65
- path: `/collections/${slug}/create`
66
- });
67
- hasCreatePermission = permissions?.collections?.[slug]?.create;
68
- }
69
- if (type === EntityType.global) {
70
- title = getTranslation(label, i18n);
71
- buttonAriaLabel = t('general:editLabel', {
72
- label: getTranslation(label, i18n)
73
- });
74
- href = formatAdminURL({
75
- adminRoute,
76
- path: `/globals/${slug}`
77
- });
78
- // Find the lock status for the global
79
- const globalLockData = globalData.find((global)=>global.slug === slug);
80
- if (globalLockData) {
81
- isLocked = globalLockData.data._isLocked;
82
- userEditing = globalLockData.data._userEditing;
83
- // Check if the lock is expired
84
- const lockDuration = globalLockData?.lockDuration;
85
- const lastEditedAt = new Date(globalLockData.data?._lastEditedAt).getTime();
86
- const lockDurationInMilliseconds = lockDuration * 1000;
87
- const lockExpirationTime = lastEditedAt + lockDurationInMilliseconds;
88
- if (new Date().getTime() > lockExpirationTime) {
89
- isLocked = false;
90
- userEditing = null;
91
- }
92
- }
93
- }
94
- return /*#__PURE__*/ _jsx("li", {
95
- children: /*#__PURE__*/ _jsx(Card, {
96
- actions: isLocked && user?.id !== userEditing?.id ? /*#__PURE__*/ _jsx(Locked, {
97
- className: `${baseClass}__locked`,
98
- user: userEditing
99
- }) : hasCreatePermission && type === EntityType.collection ? /*#__PURE__*/ _jsx(Button, {
100
- "aria-label": t('general:createNewLabel', {
101
- label
102
- }),
103
- buttonStyle: "icon-label",
104
- el: "link",
105
- icon: "plus",
106
- iconStyle: "with-border",
107
- round: true,
108
- to: createHREF
109
- }) : undefined,
110
- buttonAriaLabel: buttonAriaLabel,
111
- href: href,
112
- id: `card-${slug}`,
113
- title: getTranslation(label, i18n),
114
- titleAs: "h3"
115
- })
116
- }, entityIndex);
117
- })
118
- })
119
- ]
120
- }, groupIndex);
121
- })
122
- }),
123
- afterDashboard && RenderServerComponent({
124
- Component: afterDashboard,
125
- importMap: payload.importMap,
126
- serverProps: {
127
- i18n,
128
- locale,
129
- params,
130
- payload,
131
- permissions,
132
- searchParams,
133
- user
134
- }
135
- })
136
- ]
137
- })
138
- });
139
- }
140
- export default DefaultDashboard;
141
-
142
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../src/Dashboard/Default/index.tsx"],"sourcesContent":["import type { groupNavItems } from '@payloadcms/ui/shared'\nimport type { ClientUser, Locale, ServerProps } from 'payload'\n\nimport { getTranslation } from '@payloadcms/translations'\nimport { Button, Card, Gutter, Locked } from '@payloadcms/ui'\nimport { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent'\nimport { EntityType } from '@payloadcms/ui/shared'\nimport { formatAdminURL } from 'payload/shared'\nimport React, { Fragment } from 'react'\n\nimport {EntityWithHref} from \"../../types\";\nimport { processNavGroups } from '../../lib/utils';\n\nconst baseClass = 'dashboard'\n\nexport type DashboardViewClientProps = {\n locale: Locale\n}\n\nexport type DashboardViewServerPropsOnly = {\n globalData: Array<{\n data: { _isLocked: boolean; _lastEditedAt: string; _userEditing: ClientUser | number | string }\n lockDuration?: number\n slug: string\n }>\n /**\n * @deprecated\n * This prop is deprecated and will be removed in the next major version.\n * Components now import their own `Link` directly from `next/link`.\n */\n Link?: React.ComponentType\n navGroups?: ReturnType<typeof groupNavItems>\n} & ServerProps\n\nexport type DashboardViewServerProps = DashboardViewClientProps & DashboardViewServerPropsOnly\n\n\nexport function DefaultDashboard(props: DashboardViewServerProps) {\n const {\n globalData,\n i18n,\n i18n: { t },\n locale,\n navGroups: originalNavGroups,\n params,\n payload: {\n config: {\n admin: {\n components: { afterDashboard, beforeDashboard },\n },\n routes: { admin: adminRoute },\n collections,\n },\n },\n payload,\n permissions,\n searchParams,\n user,\n } = props\n\n // Process navGroups to calculate href values\n const navGroups = originalNavGroups ? processNavGroups(originalNavGroups, collections, payload, i18n) : []\n\n return (\n <div className={baseClass}>\n <Gutter className={`${baseClass}__wrap`}>\n {beforeDashboard &&\n RenderServerComponent({\n Component: beforeDashboard,\n importMap: payload.importMap,\n serverProps: {\n i18n,\n locale,\n params,\n payload,\n permissions,\n searchParams,\n user,\n } satisfies ServerProps,\n })}\n\n <Fragment>\n {!navGroups || navGroups?.length === 0 ? (\n <p>no nav groups....</p>\n ) : (\n navGroups.map(({ entities, label }, groupIndex) => {\n return (\n <div className={`${baseClass}__group`} key={groupIndex}>\n <h2 className={`${baseClass}__label`}>{label}</h2>\n <ul className={`${baseClass}__card-list`}>\n {entities.map(({ slug, type, label, href: entityHref }:EntityWithHref, entityIndex) => {\n let title: string\n let buttonAriaLabel: string\n let createHREF: string\n let href: string\n let hasCreatePermission: boolean\n let isLocked = null\n let userEditing = null\n\n if (type === EntityType.collection) {\n title = getTranslation(label, i18n)\n\n buttonAriaLabel = t('general:showAllLabel', { label: title })\n\n // Use the processed href if available, otherwise use the default\n href = entityHref || formatAdminURL({ adminRoute, path: `/collections/${slug}` })\n\n createHREF = formatAdminURL({\n adminRoute,\n path: `/collections/${slug}/create`,\n })\n\n hasCreatePermission = permissions?.collections?.[slug]?.create\n }\n\n if (type === EntityType.global) {\n title = getTranslation(label, i18n)\n\n buttonAriaLabel = t('general:editLabel', {\n label: getTranslation(label, i18n),\n })\n\n href = formatAdminURL({\n adminRoute,\n path: `/globals/${slug}`,\n })\n\n // Find the lock status for the global\n const globalLockData = globalData.find((global) => global.slug === slug)\n if (globalLockData) {\n isLocked = globalLockData.data._isLocked\n userEditing = globalLockData.data._userEditing\n\n // Check if the lock is expired\n const lockDuration = globalLockData?.lockDuration\n const lastEditedAt = new Date(\n globalLockData.data?._lastEditedAt,\n ).getTime()\n\n const lockDurationInMilliseconds = lockDuration * 1000\n const lockExpirationTime = lastEditedAt + lockDurationInMilliseconds\n\n if (new Date().getTime() > lockExpirationTime) {\n isLocked = false\n userEditing = null\n }\n }\n }\n\n return (\n <li key={entityIndex}>\n <Card\n actions={\n isLocked && user?.id !== userEditing?.id ? (\n <Locked className={`${baseClass}__locked`} user={userEditing} />\n ) : hasCreatePermission && type === EntityType.collection ? (\n <Button\n aria-label={t('general:createNewLabel', {\n label,\n })}\n buttonStyle=\"icon-label\"\n el=\"link\"\n icon=\"plus\"\n iconStyle=\"with-border\"\n round\n to={createHREF}\n />\n ) : undefined\n }\n buttonAriaLabel={buttonAriaLabel}\n href={href}\n id={`card-${slug}`}\n title={getTranslation(label, i18n)}\n titleAs=\"h3\"\n />\n </li>\n )\n })}\n </ul>\n </div>\n )\n })\n )}\n </Fragment>\n {afterDashboard &&\n RenderServerComponent({\n Component: afterDashboard,\n importMap: payload.importMap,\n serverProps: {\n i18n,\n locale,\n params,\n payload,\n permissions,\n searchParams,\n user,\n } satisfies ServerProps,\n })}\n </Gutter>\n </div>\n )\n}\n\nexport default DefaultDashboard\n"],"names":["getTranslation","Button","Card","Gutter","Locked","RenderServerComponent","EntityType","formatAdminURL","React","Fragment","processNavGroups","baseClass","DefaultDashboard","props","globalData","i18n","t","locale","navGroups","originalNavGroups","params","payload","config","admin","components","afterDashboard","beforeDashboard","routes","adminRoute","collections","permissions","searchParams","user","div","className","Component","importMap","serverProps","length","p","map","entities","label","groupIndex","h2","ul","slug","type","href","entityHref","entityIndex","title","buttonAriaLabel","createHREF","hasCreatePermission","isLocked","userEditing","collection","path","create","global","globalLockData","find","data","_isLocked","_userEditing","lockDuration","lastEditedAt","Date","_lastEditedAt","getTime","lockDurationInMilliseconds","lockExpirationTime","li","actions","id","aria-label","buttonStyle","el","icon","iconStyle","round","to","undefined","titleAs"],"mappings":";AAGA,SAASA,cAAc,QAAQ,2BAA0B;AACzD,SAASC,MAAM,EAAEC,IAAI,EAAEC,MAAM,EAAEC,MAAM,QAAQ,iBAAgB;AAC7D,SAASC,qBAAqB,QAAQ,gDAA+C;AACrF,SAASC,UAAU,QAAQ,wBAAuB;AAClD,SAASC,cAAc,QAAQ,iBAAgB;AAC/C,OAAOC,SAASC,QAAQ,QAAQ,QAAO;AAGvC,SAASC,gBAAgB,QAAQ,kBAAkB;AAEnD,MAAMC,YAAY;AAwBlB,OAAO,SAASC,iBAAiBC,KAA+B;IAC9D,MAAM,EACJC,UAAU,EACVC,IAAI,EACJA,MAAM,EAAEC,CAAC,EAAE,EACXC,MAAM,EACNC,WAAWC,iBAAiB,EAC5BC,MAAM,EACNC,SAAS,EACPC,QAAQ,EACNC,OAAO,EACLC,YAAY,EAAEC,cAAc,EAAEC,eAAe,EAAE,EAChD,EACDC,QAAQ,EAAEJ,OAAOK,UAAU,EAAE,EAC7BC,WAAW,EACZ,EACF,EACDR,OAAO,EACPS,WAAW,EACXC,YAAY,EACZC,IAAI,EACL,GAAGnB;IAEJ,6CAA6C;IAC7C,MAAMK,YAAYC,oBAAoBT,iBAAiBS,mBAAmBU,aAAaR,SAASN,QAAQ,EAAE;IAE1G,qBACE,KAACkB;QAAIC,WAAWvB;kBACd,cAAA,MAACR;YAAO+B,WAAW,GAAGvB,UAAU,MAAM,CAAC;;gBACpCe,mBACCrB,sBAAsB;oBACpB8B,WAAWT;oBACXU,WAAWf,QAAQe,SAAS;oBAC5BC,aAAa;wBACXtB;wBACAE;wBACAG;wBACAC;wBACAS;wBACAC;wBACAC;oBACF;gBACF;8BAEF,KAACvB;8BACE,CAACS,aAAaA,WAAWoB,WAAW,kBACnC,KAACC;kCAAE;yBAEHrB,UAAUsB,GAAG,CAAC,CAAC,EAAEC,QAAQ,EAAEC,KAAK,EAAE,EAAEC;wBAClC,qBACE,MAACV;4BAAIC,WAAW,GAAGvB,UAAU,OAAO,CAAC;;8CACnC,KAACiC;oCAAGV,WAAW,GAAGvB,UAAU,OAAO,CAAC;8CAAG+B;;8CACvC,KAACG;oCAAGX,WAAW,GAAGvB,UAAU,WAAW,CAAC;8CACnC8B,SAASD,GAAG,CAAC,CAAC,EAAEM,IAAI,EAAEC,IAAI,EAAEL,KAAK,EAAEM,MAAMC,UAAU,EAAiB,EAAEC;wCACvE,IAAIC;wCACJ,IAAIC;wCACJ,IAAIC;wCACJ,IAAIL;wCACJ,IAAIM;wCACJ,IAAIC,WAAW;wCACf,IAAIC,cAAc;wCAElB,IAAIT,SAASzC,WAAWmD,UAAU,EAAE;4CAClCN,QAAQnD,eAAe0C,OAAO3B;4CAE9BqC,kBAAkBpC,EAAE,wBAAwB;gDAAE0B,OAAOS;4CAAM;4CAE3D,iEAAiE;4CACjEH,OAAOC,cAAc1C,eAAe;gDAAEqB;gDAAY8B,MAAM,CAAC,aAAa,EAAEZ,MAAM;4CAAC;4CAE/EO,aAAa9C,eAAe;gDAC1BqB;gDACA8B,MAAM,CAAC,aAAa,EAAEZ,KAAK,OAAO,CAAC;4CACrC;4CAEAQ,sBAAsBxB,aAAaD,aAAa,CAACiB,KAAK,EAAEa;wCAC1D;wCAEA,IAAIZ,SAASzC,WAAWsD,MAAM,EAAE;4CAC9BT,QAAQnD,eAAe0C,OAAO3B;4CAE9BqC,kBAAkBpC,EAAE,qBAAqB;gDACvC0B,OAAO1C,eAAe0C,OAAO3B;4CAC/B;4CAEAiC,OAAOzC,eAAe;gDACpBqB;gDACA8B,MAAM,CAAC,SAAS,EAAEZ,MAAM;4CAC1B;4CAEA,sCAAsC;4CACtC,MAAMe,iBAAiB/C,WAAWgD,IAAI,CAAC,CAACF,SAAWA,OAAOd,IAAI,KAAKA;4CACnE,IAAIe,gBAAgB;gDAClBN,WAAWM,eAAeE,IAAI,CAACC,SAAS;gDACxCR,cAAcK,eAAeE,IAAI,CAACE,YAAY;gDAE9C,+BAA+B;gDAC/B,MAAMC,eAAeL,gBAAgBK;gDACrC,MAAMC,eAAe,IAAIC,KACvBP,eAAeE,IAAI,EAAEM,eACrBC,OAAO;gDAET,MAAMC,6BAA6BL,eAAe;gDAClD,MAAMM,qBAAqBL,eAAeI;gDAE1C,IAAI,IAAIH,OAAOE,OAAO,KAAKE,oBAAoB;oDAC7CjB,WAAW;oDACXC,cAAc;gDAChB;4CACF;wCACF;wCAEA,qBACE,KAACiB;sDACC,cAAA,KAACvE;gDACCwE,SACEnB,YAAYvB,MAAM2C,OAAOnB,aAAamB,mBACpC,KAACvE;oDAAO8B,WAAW,GAAGvB,UAAU,QAAQ,CAAC;oDAAEqB,MAAMwB;qDAC/CF,uBAAuBP,SAASzC,WAAWmD,UAAU,iBACvD,KAACxD;oDACC2E,cAAY5D,EAAE,0BAA0B;wDACtC0B;oDACF;oDACAmC,aAAY;oDACZC,IAAG;oDACHC,MAAK;oDACLC,WAAU;oDACVC,KAAK;oDACLC,IAAI7B;qDAEJ8B;gDAEN/B,iBAAiBA;gDACjBJ,MAAMA;gDACN2B,IAAI,CAAC,KAAK,EAAE7B,MAAM;gDAClBK,OAAOnD,eAAe0C,OAAO3B;gDAC7BqE,SAAQ;;2CAvBHlC;oCA2Bb;;;2BA1FwCP;oBA8FhD;;gBAGHlB,kBACCpB,sBAAsB;oBACpB8B,WAAWV;oBACXW,WAAWf,QAAQe,SAAS;oBAC5BC,aAAa;wBACXtB;wBACAE;wBACAG;wBACAC;wBACAS;wBACAC;wBACAC;oBACF;gBACF;;;;AAIV;AAEA,eAAepB,iBAAgB"}
@@ -1,3 +0,0 @@
1
- import type { GenerateViewMetadata } from '@payloadcms/next/views';
2
- export declare const generateDashboardViewMetadata: GenerateViewMetadata;
3
- //# sourceMappingURL=metadata.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"metadata.d.ts","sourceRoot":"","sources":["../../src/Dashboard/metadata.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAA;AAIlE,eAAO,MAAM,6BAA6B,EAAE,oBAYxC,CAAA"}
@@ -1,12 +0,0 @@
1
- import { generateMetadata } from '../lib/meta';
2
- export const generateDashboardViewMetadata = async ({ config, i18n: { t } })=>generateMetadata({
3
- serverURL: config.serverURL,
4
- title: t('general:dashboard'),
5
- ...config.admin.meta,
6
- openGraph: {
7
- title: t('general:dashboard'),
8
- ...config.admin.meta?.openGraph || {}
9
- }
10
- });
11
-
12
- //# sourceMappingURL=metadata.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/Dashboard/metadata.ts"],"sourcesContent":["import type { GenerateViewMetadata } from '@payloadcms/next/views'\n\nimport { generateMetadata } from '../lib/meta'\n\nexport const generateDashboardViewMetadata: GenerateViewMetadata = async ({\n config,\n i18n: { t },\n}) =>\n generateMetadata({\n serverURL: config.serverURL,\n title: t('general:dashboard'),\n ...config.admin.meta,\n openGraph: {\n title: t('general:dashboard'),\n ...(config.admin.meta?.openGraph || {}),\n },\n })\n"],"names":["generateMetadata","generateDashboardViewMetadata","config","i18n","t","serverURL","title","admin","meta","openGraph"],"mappings":"AAEA,SAASA,gBAAgB,QAAQ,cAAa;AAE9C,OAAO,MAAMC,gCAAsD,OAAO,EACxEC,MAAM,EACNC,MAAM,EAAEC,CAAC,EAAE,EACZ,GACCJ,iBAAiB;QACfK,WAAWH,OAAOG,SAAS;QAC3BC,OAAOF,EAAE;QACT,GAAGF,OAAOK,KAAK,CAACC,IAAI;QACpBC,WAAW;YACTH,OAAOF,EAAE;YACT,GAAIF,OAAOK,KAAK,CAACC,IAAI,EAAEC,aAAa,CAAC,CAAC;QACxC;IACF,GAAE"}
@@ -1,6 +0,0 @@
1
- import type { Metadata } from 'next';
2
- import type { MetaConfig } from 'payload';
3
- export declare const generateMetadata: (args: {
4
- serverURL: string;
5
- } & MetaConfig) => Promise<Metadata>;
6
- //# sourceMappingURL=meta.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"meta.d.ts","sourceRoot":"","sources":["../../src/lib/meta.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAA;AAEpC,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAA;AAYzC,eAAO,MAAM,gBAAgB,SACrB;IAAE,SAAS,EAAE,MAAM,CAAA;CAAE,GAAG,UAAU,KACvC,OAAO,CAAC,QAAQ,CAqFlB,CAAA"}
package/dist/lib/meta.js DELETED
@@ -1,74 +0,0 @@
1
- import { payloadFaviconDark, payloadFaviconLight, staticOGImage } from '@payloadcms/ui/assets';
2
- import * as qs from 'qs-esm';
3
- const defaultOpenGraph = {
4
- description: 'Payload is a headless CMS and application framework built with TypeScript, Node.js, and React.',
5
- siteName: 'Payload App',
6
- title: 'Payload App'
7
- };
8
- export const generateMetadata = async (args)=>{
9
- const { defaultOGImageType, serverURL, titleSuffix, ...rest } = args;
10
- /**
11
- * @todo find a way to remove the type assertion here.
12
- * It is a result of needing to `DeepCopy` the `MetaConfig` type from Payload.
13
- * This is required for the `DeepRequired` from `Config` to `SanitizedConfig`.
14
- */ const incomingMetadata = rest;
15
- const icons = incomingMetadata.icons || [
16
- {
17
- type: 'image/png',
18
- rel: 'icon',
19
- sizes: '32x32',
20
- url: typeof payloadFaviconDark === 'object' ? payloadFaviconDark?.src : payloadFaviconDark
21
- },
22
- {
23
- type: 'image/png',
24
- media: '(prefers-color-scheme: dark)',
25
- rel: 'icon',
26
- sizes: '32x32',
27
- url: typeof payloadFaviconLight === 'object' ? payloadFaviconLight?.src : payloadFaviconLight
28
- }
29
- ];
30
- const metaTitle = [
31
- incomingMetadata.title,
32
- titleSuffix
33
- ].filter(Boolean).join(' ');
34
- const ogTitle = `${typeof incomingMetadata.openGraph?.title === 'string' ? incomingMetadata.openGraph.title : incomingMetadata.title} ${titleSuffix}`;
35
- const mergedOpenGraph = {
36
- ...defaultOpenGraph || {},
37
- ...defaultOGImageType === 'dynamic' ? {
38
- images: [
39
- {
40
- alt: ogTitle,
41
- height: 630,
42
- url: `/api/og${qs.stringify({
43
- description: incomingMetadata.openGraph?.description || defaultOpenGraph.description,
44
- title: ogTitle
45
- }, {
46
- addQueryPrefix: true
47
- })}`,
48
- width: 1200
49
- }
50
- ]
51
- } : {},
52
- ...defaultOGImageType === 'static' ? {
53
- images: [
54
- {
55
- alt: ogTitle,
56
- height: 480,
57
- url: typeof staticOGImage === 'object' ? staticOGImage?.src : staticOGImage,
58
- width: 640
59
- }
60
- ]
61
- } : {},
62
- title: ogTitle,
63
- ...incomingMetadata.openGraph || {}
64
- };
65
- return Promise.resolve({
66
- ...incomingMetadata,
67
- icons,
68
- metadataBase: new URL(serverURL || process.env.PAYLOAD_PUBLIC_SERVER_URL || `http://localhost:${process.env.PORT || 3000}`),
69
- openGraph: mergedOpenGraph,
70
- title: metaTitle
71
- });
72
- };
73
-
74
- //# sourceMappingURL=meta.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/lib/meta.ts"],"sourcesContent":["import type { Metadata } from 'next'\nimport type { Icon } from 'next/dist/lib/metadata/types/metadata-types.js'\nimport type { MetaConfig } from 'payload'\n\nimport { payloadFaviconDark, payloadFaviconLight, staticOGImage } from '@payloadcms/ui/assets'\nimport * as qs from 'qs-esm'\n\nconst defaultOpenGraph: Metadata['openGraph'] = {\n description:\n 'Payload is a headless CMS and application framework built with TypeScript, Node.js, and React.',\n siteName: 'Payload App',\n title: 'Payload App',\n}\n\nexport const generateMetadata = async (\n args: { serverURL: string } & MetaConfig,\n): Promise<Metadata> => {\n const { defaultOGImageType, serverURL, titleSuffix, ...rest } = args\n\n /**\n * @todo find a way to remove the type assertion here.\n * It is a result of needing to `DeepCopy` the `MetaConfig` type from Payload.\n * This is required for the `DeepRequired` from `Config` to `SanitizedConfig`.\n */\n const incomingMetadata = rest as unknown as Metadata;\n\n const icons: Metadata['icons'] =\n incomingMetadata.icons ||\n ([\n {\n type: 'image/png',\n rel: 'icon',\n sizes: '32x32',\n url: typeof payloadFaviconDark === 'object' ? payloadFaviconDark?.src : payloadFaviconDark,\n },\n {\n type: 'image/png',\n media: '(prefers-color-scheme: dark)',\n rel: 'icon',\n sizes: '32x32',\n url:\n typeof payloadFaviconLight === 'object' ? payloadFaviconLight?.src : payloadFaviconLight,\n },\n ] satisfies Array<Icon>)\n\n const metaTitle: Metadata['title'] = [incomingMetadata.title, titleSuffix]\n .filter(Boolean)\n .join(' ')\n\n const ogTitle = `${typeof incomingMetadata.openGraph?.title === 'string' ? incomingMetadata.openGraph.title : incomingMetadata.title} ${titleSuffix}`\n\n const mergedOpenGraph: Metadata['openGraph'] = {\n ...(defaultOpenGraph || {}),\n ...(defaultOGImageType === 'dynamic'\n ? {\n images: [\n {\n alt: ogTitle,\n height: 630,\n url: `/api/og${qs.stringify(\n {\n description:\n incomingMetadata.openGraph?.description || defaultOpenGraph.description,\n title: ogTitle,\n },\n {\n addQueryPrefix: true,\n },\n )}`,\n width: 1200,\n },\n ],\n }\n : {}),\n ...(defaultOGImageType === 'static'\n ? {\n images: [\n {\n alt: ogTitle,\n height: 480,\n url: typeof staticOGImage === 'object' ? staticOGImage?.src : staticOGImage,\n width: 640,\n },\n ],\n }\n : {}),\n title: ogTitle,\n ...(incomingMetadata.openGraph || {}),\n }\n\n return Promise.resolve({\n ...incomingMetadata,\n icons,\n metadataBase: new URL(\n serverURL ||\n process.env.PAYLOAD_PUBLIC_SERVER_URL ||\n `http://localhost:${process.env.PORT || 3000}`,\n ),\n openGraph: mergedOpenGraph,\n title: metaTitle,\n })\n}\n"],"names":["payloadFaviconDark","payloadFaviconLight","staticOGImage","qs","defaultOpenGraph","description","siteName","title","generateMetadata","args","defaultOGImageType","serverURL","titleSuffix","rest","incomingMetadata","icons","type","rel","sizes","url","src","media","metaTitle","filter","Boolean","join","ogTitle","openGraph","mergedOpenGraph","images","alt","height","stringify","addQueryPrefix","width","Promise","resolve","metadataBase","URL","process","env","PAYLOAD_PUBLIC_SERVER_URL","PORT"],"mappings":"AAIA,SAASA,kBAAkB,EAAEC,mBAAmB,EAAEC,aAAa,QAAQ,wBAAuB;AAC9F,YAAYC,QAAQ,SAAQ;AAE5B,MAAMC,mBAA0C;IAC9CC,aACE;IACFC,UAAU;IACVC,OAAO;AACT;AAEA,OAAO,MAAMC,mBAAmB,OAC9BC;IAEA,MAAM,EAAEC,kBAAkB,EAAEC,SAAS,EAAEC,WAAW,EAAE,GAAGC,MAAM,GAAGJ;IAEhE;;;;GAIC,GACD,MAAMK,mBAAmBD;IAEzB,MAAME,QACJD,iBAAiBC,KAAK,IACrB;QACC;YACEC,MAAM;YACNC,KAAK;YACLC,OAAO;YACPC,KAAK,OAAOnB,uBAAuB,WAAWA,oBAAoBoB,MAAMpB;QAC1E;QACA;YACEgB,MAAM;YACNK,OAAO;YACPJ,KAAK;YACLC,OAAO;YACPC,KACE,OAAOlB,wBAAwB,WAAWA,qBAAqBmB,MAAMnB;QACzE;KACD;IAEH,MAAMqB,YAA+B;QAACR,iBAAiBP,KAAK;QAAEK;KAAY,CACvEW,MAAM,CAACC,SACPC,IAAI,CAAC;IAER,MAAMC,UAAU,GAAG,OAAOZ,iBAAiBa,SAAS,EAAEpB,UAAU,WAAWO,iBAAiBa,SAAS,CAACpB,KAAK,GAAGO,iBAAiBP,KAAK,CAAC,CAAC,EAAEK,aAAa;IAErJ,MAAMgB,kBAAyC;QAC7C,GAAIxB,oBAAoB,CAAC,CAAC;QAC1B,GAAIM,uBAAuB,YACvB;YACEmB,QAAQ;gBACN;oBACEC,KAAKJ;oBACLK,QAAQ;oBACRZ,KAAK,CAAC,OAAO,EAAEhB,GAAG6B,SAAS,CACzB;wBACE3B,aACES,iBAAiBa,SAAS,EAAEtB,eAAeD,iBAAiBC,WAAW;wBACzEE,OAAOmB;oBACT,GACA;wBACEO,gBAAgB;oBAClB,IACC;oBACHC,OAAO;gBACT;aACD;QACH,IACA,CAAC,CAAC;QACN,GAAIxB,uBAAuB,WACvB;YACEmB,QAAQ;gBACN;oBACEC,KAAKJ;oBACLK,QAAQ;oBACRZ,KAAK,OAAOjB,kBAAkB,WAAWA,eAAekB,MAAMlB;oBAC9DgC,OAAO;gBACT;aACD;QACH,IACA,CAAC,CAAC;QACN3B,OAAOmB;QACP,GAAIZ,iBAAiBa,SAAS,IAAI,CAAC,CAAC;IACtC;IAEA,OAAOQ,QAAQC,OAAO,CAAC;QACrB,GAAGtB,gBAAgB;QACnBC;QACAsB,cAAc,IAAIC,IAChB3B,aACE4B,QAAQC,GAAG,CAACC,yBAAyB,IACrC,CAAC,iBAAiB,EAAEF,QAAQC,GAAG,CAACE,IAAI,IAAI,MAAM;QAElDf,WAAWC;QACXrB,OAAOe;IACT;AACF,EAAC"}