@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 +10 -3
- package/dist/Dashboard/index.d.ts +27 -2
- package/dist/Dashboard/index.d.ts.map +1 -1
- package/dist/Dashboard/index.js +139 -3
- package/dist/Dashboard/index.js.map +1 -1
- package/dist/filters/types/filters-type.d.ts +1 -0
- package/dist/filters/types/filters-type.d.ts.map +1 -1
- package/dist/filters/types/filters-type.js.map +1 -1
- package/dist/lib/utils.d.ts.map +1 -1
- package/dist/lib/utils.js +5 -1
- package/dist/lib/utils.js.map +1 -1
- package/dist/ui/button.d.ts +2 -2
- package/package.json +1 -1
- package/dist/Dashboard/Default/index.d.ts +0 -28
- package/dist/Dashboard/Default/index.d.ts.map +0 -1
- package/dist/Dashboard/Default/index.js +0 -142
- package/dist/Dashboard/Default/index.js.map +0 -1
- package/dist/Dashboard/metadata.d.ts +0 -3
- package/dist/Dashboard/metadata.d.ts.map +0 -1
- package/dist/Dashboard/metadata.js +0 -12
- package/dist/Dashboard/metadata.js.map +0 -1
- package/dist/lib/meta.d.ts +0 -6
- package/dist/lib/meta.d.ts.map +0 -1
- package/dist/lib/meta.js +0 -74
- package/dist/lib/meta.js.map +0 -1
package/README.md
CHANGED
|
@@ -477,12 +477,13 @@ CollectionQuickFilterPlugin({
|
|
|
477
477
|
|
|
478
478
|
</details>
|
|
479
479
|
|
|
480
|
-
### 🧭
|
|
480
|
+
### 🧭 Default Filter from navigation in both Navigator and Dashboard
|
|
481
481
|
|
|
482
482
|
<details>
|
|
483
|
-
<summary>⚙️ <strong>Using
|
|
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
|
|
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
|
-
|
|
2
|
-
|
|
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":"
|
|
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"}
|
package/dist/Dashboard/index.js
CHANGED
|
@@ -1,5 +1,141 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
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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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"filters-type.d.ts","sourceRoot":"","sources":["../../../src/filters/types/filters-type.ts"],"names":[],"mappings":"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
|
|
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;IACf,OAAO,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;CAC5B,CAAC;AAEF,MAAM,WAAW,SAAS;IACxB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,aAAa,EAAE,CAAC;CAC1B"}
|
|
@@ -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":"
|
|
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"}
|
package/dist/lib/utils.d.ts.map
CHANGED
|
@@ -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,
|
|
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
|
package/dist/lib/utils.js.map
CHANGED
|
@@ -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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"}
|
package/dist/ui/button.d.ts
CHANGED
|
@@ -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" | "
|
|
5
|
-
size?: "
|
|
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,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":"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"}
|
|
@@ -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"}
|
package/dist/lib/meta.d.ts
DELETED
package/dist/lib/meta.d.ts.map
DELETED
|
@@ -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
|
package/dist/lib/meta.js.map
DELETED
|
@@ -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"}
|