@loadspark/core 0.0.1 → 0.0.3
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/dist/collections/users/config.d.ts.map +1 -1
- package/dist/collections/users/config.js +1 -4
- package/dist/collections/users/config.js.map +1 -1
- package/dist/collections/users/fields.d.ts.map +1 -1
- package/dist/collections/users/fields.js +1 -38
- package/dist/collections/users/fields.js.map +1 -1
- package/dist/collections/users/types.d.ts +1 -3
- package/dist/collections/users/types.d.ts.map +1 -1
- package/dist/collections/users/types.js.map +1 -1
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../../src/collections/users/config.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,KAAK,gBAAgB,EAAa,MAAM,SAAS,CAAA;AAE1D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,YAAY,CAAA;AAM/C;;;;GAIG;AACH,eAAO,MAAM,cAAc,cAAe,aAAa,KAAG,
|
|
1
|
+
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../../src/collections/users/config.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,KAAK,gBAAgB,EAAa,MAAM,SAAS,CAAA;AAE1D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,YAAY,CAAA;AAM/C;;;;GAIG;AACH,eAAO,MAAM,cAAc,cAAe,aAAa,KAAG,gBAuCzD,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/collections/users/config.ts"],"sourcesContent":["import type { TFunction } from '@payloadcms/translations'\nimport type { loadsparkCoreTranslationsKeys } from 'src/translations/index.js'\n\nimport { type CollectionConfig, deepMerge } from 'payload'\n\nimport type { UserOverrides } from './types.js'\n\nimport { createUserAccess, deleteUserAccess, readUserAccess, updateUserAccess } from './access.js'\nimport { getUserFields } from './fields.js'\nimport { firstUserIsAdmin, usersBeforeCreateOperation } from './hooks.js'\n\n/**\n * Default config for the Users Collection\n *\n * @param overrides\n */\nexport const getUsersConfig = (overrides: UserOverrides): CollectionConfig => {\n const config = deepMerge<CollectionConfig, UserOverrides['collectionOverrides']>(\n {\n slug: 'users',\n access: {\n create: createUserAccess,\n delete: deleteUserAccess,\n read: readUserAccess,\n update: updateUserAccess,\n },\n admin: {\n defaultColumns: ['email', 'role'],\n group:
|
|
1
|
+
{"version":3,"sources":["../../../src/collections/users/config.ts"],"sourcesContent":["import type { TFunction } from '@payloadcms/translations'\nimport type { loadsparkCoreTranslationsKeys } from 'src/translations/index.js'\n\nimport { type CollectionConfig, deepMerge } from 'payload'\n\nimport type { UserOverrides } from './types.js'\n\nimport { createUserAccess, deleteUserAccess, readUserAccess, updateUserAccess } from './access.js'\nimport { getUserFields } from './fields.js'\nimport { firstUserIsAdmin, usersBeforeCreateOperation } from './hooks.js'\n\n/**\n * Default config for the Users Collection\n *\n * @param overrides\n */\nexport const getUsersConfig = (overrides: UserOverrides): CollectionConfig => {\n const config = deepMerge<CollectionConfig, UserOverrides['collectionOverrides']>(\n {\n slug: 'users',\n access: {\n create: createUserAccess,\n delete: deleteUserAccess,\n read: readUserAccess,\n update: updateUserAccess,\n },\n admin: {\n defaultColumns: ['email', 'role'],\n group: 'Auth',\n useAsTitle: 'email',\n },\n auth: true,\n fields: [...getUserFields(overrides.fieldOverrides), ...(overrides?.additionalFields ?? [])],\n hooks: {\n beforeOperation: [usersBeforeCreateOperation],\n beforeValidate: [firstUserIsAdmin],\n },\n labels: {\n plural: ({ t }) => {\n return (t as TFunction<loadsparkCoreTranslationsKeys>)(\n 'loadspark-core:users:labels:plural',\n )\n },\n singular: ({ t }) => {\n return (t as TFunction<loadsparkCoreTranslationsKeys>)(\n 'loadspark-core:users:labels:singular',\n )\n },\n },\n timestamps: true,\n },\n overrides.collectionOverrides ?? {},\n )\n\n return config\n}\n"],"names":["deepMerge","createUserAccess","deleteUserAccess","readUserAccess","updateUserAccess","getUserFields","firstUserIsAdmin","usersBeforeCreateOperation","getUsersConfig","overrides","config","slug","access","create","delete","read","update","admin","defaultColumns","group","useAsTitle","auth","fields","fieldOverrides","additionalFields","hooks","beforeOperation","beforeValidate","labels","plural","t","singular","timestamps","collectionOverrides"],"mappings":"AAGA,SAAgCA,SAAS,QAAQ,UAAS;AAI1D,SAASC,gBAAgB,EAAEC,gBAAgB,EAAEC,cAAc,EAAEC,gBAAgB,QAAQ,cAAa;AAClG,SAASC,aAAa,QAAQ,cAAa;AAC3C,SAASC,gBAAgB,EAAEC,0BAA0B,QAAQ,aAAY;AAEzE;;;;CAIC,GACD,OAAO,MAAMC,iBAAiB,CAACC;IAC7B,MAAMC,SAASV,UACb;QACEW,MAAM;QACNC,QAAQ;YACNC,QAAQZ;YACRa,QAAQZ;YACRa,MAAMZ;YACNa,QAAQZ;QACV;QACAa,OAAO;YACLC,gBAAgB;gBAAC;gBAAS;aAAO;YACjCC,OAAO;YACPC,YAAY;QACd;QACAC,MAAM;QACNC,QAAQ;eAAIjB,cAAcI,UAAUc,cAAc;eAAOd,WAAWe,oBAAoB,EAAE;SAAE;QAC5FC,OAAO;YACLC,iBAAiB;gBAACnB;aAA2B;YAC7CoB,gBAAgB;gBAACrB;aAAiB;QACpC;QACAsB,QAAQ;YACNC,QAAQ,CAAC,EAAEC,CAAC,EAAE;gBACZ,OAAO,AAACA,EACN;YAEJ;YACAC,UAAU,CAAC,EAAED,CAAC,EAAE;gBACd,OAAO,AAACA,EACN;YAEJ;QACF;QACAE,YAAY;IACd,GACAvB,UAAUwB,mBAAmB,IAAI,CAAC;IAGpC,OAAOvB;AACT,EAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fields.d.ts","sourceRoot":"","sources":["../../../src/collections/users/fields.ts"],"names":[],"mappings":"AAEA,OAAO,EAAa,KAAK,KAAK,
|
|
1
|
+
{"version":3,"file":"fields.d.ts","sourceRoot":"","sources":["../../../src/collections/users/fields.ts"],"names":[],"mappings":"AAEA,OAAO,EAAa,KAAK,KAAK,EAAoB,MAAM,SAAS,CAAA;AAGjE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAA;AAKpD,eAAO,MAAM,aAAa,eAAgB,kBAAkB,KAAG,KAAK,EAuEnE,CAAA"}
|
|
@@ -52,45 +52,8 @@ export const getUserFields = (overrides)=>{
|
|
|
52
52
|
],
|
|
53
53
|
required: true
|
|
54
54
|
}, overrides?.roleOverrides ?? {});
|
|
55
|
-
const generalTab = deepMerge({
|
|
56
|
-
custom: {
|
|
57
|
-
loadspark: {
|
|
58
|
-
core: {
|
|
59
|
-
users: {
|
|
60
|
-
wrapper: {
|
|
61
|
-
isTab: true,
|
|
62
|
-
tabName: 'general'
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
},
|
|
68
|
-
fields: [],
|
|
69
|
-
label: {
|
|
70
|
-
de: 'Allgemein',
|
|
71
|
-
en: 'General'
|
|
72
|
-
}
|
|
73
|
-
}, overrides?.generalTabOverrides ?? {});
|
|
74
|
-
const loadsparkTabField = deepMerge({
|
|
75
|
-
type: 'tabs',
|
|
76
|
-
custom: {
|
|
77
|
-
loadspark: {
|
|
78
|
-
core: {
|
|
79
|
-
users: {
|
|
80
|
-
wrapper: {
|
|
81
|
-
isWrapper: true
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
},
|
|
87
|
-
tabs: [
|
|
88
|
-
generalTab
|
|
89
|
-
]
|
|
90
|
-
}, overrides?.tabOverrides ?? {});
|
|
91
55
|
return [
|
|
92
|
-
roleField
|
|
93
|
-
loadsparkTabField
|
|
56
|
+
roleField
|
|
94
57
|
];
|
|
95
58
|
};
|
|
96
59
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/collections/users/fields.ts"],"sourcesContent":["import type { TFunction } from '@payloadcms/translations'\n\nimport { deepMerge, type Field, type SelectField
|
|
1
|
+
{"version":3,"sources":["../../../src/collections/users/fields.ts"],"sourcesContent":["import type { TFunction } from '@payloadcms/translations'\n\nimport { deepMerge, type Field, type SelectField } from 'payload'\n\nimport type { loadsparkCoreTranslationsKeys } from '../../translations/index.js'\nimport type { UserFieldOverrides } from './types.js'\n\nimport { hasAdminRole, hasSuperAdminRole } from '../../access/index.js'\nimport { UserRole } from './types.js'\n\nexport const getUserFields = (overrides?: UserFieldOverrides): Field[] => {\n const roleField = deepMerge<SelectField, UserFieldOverrides['roleOverrides']>(\n {\n name: 'role',\n type: 'select',\n access: {\n create: (ctx) => {\n if (!ctx.data?.role) {\n return false\n }\n\n if (hasSuperAdminRole(ctx.req.user)) {\n return true\n }\n\n if (hasAdminRole(ctx.req.user)) {\n return ctx.data.role === UserRole.User\n }\n\n return false\n },\n update: (ctx) => {\n if (!ctx.doc) {\n return false\n }\n\n if (!hasSuperAdminRole(ctx.req.user)) {\n return false\n }\n\n // Super-admins should never be able to update their own role.\n if (ctx.doc.id === ctx.req.user?.id) {\n return false\n }\n\n return true\n },\n },\n defaultValue: 'user',\n label: ({ t }) => {\n return (t as TFunction<loadsparkCoreTranslationsKeys>)('loadspark-core:users:roles:label')\n },\n options: [\n {\n label: ({ t }) =>\n (t as TFunction<loadsparkCoreTranslationsKeys>)(\n 'loadspark-core:users:roles:options:user',\n ),\n value: UserRole.User,\n },\n {\n label: ({ t }) =>\n (t as TFunction<loadsparkCoreTranslationsKeys>)(\n 'loadspark-core:users:roles:options:admin',\n ),\n value: UserRole.Admin,\n },\n {\n label: ({ t }) =>\n (t as TFunction<loadsparkCoreTranslationsKeys>)(\n 'loadspark-core:users:roles:options:superAdmin',\n ),\n value: UserRole.SuperAdmin,\n },\n ],\n required: true,\n },\n overrides?.roleOverrides ?? {},\n )\n\n return [roleField]\n}\n"],"names":["deepMerge","hasAdminRole","hasSuperAdminRole","UserRole","getUserFields","overrides","roleField","name","type","access","create","ctx","data","role","req","user","User","update","doc","id","defaultValue","label","t","options","value","Admin","SuperAdmin","required","roleOverrides"],"mappings":"AAEA,SAASA,SAAS,QAAsC,UAAS;AAKjE,SAASC,YAAY,EAAEC,iBAAiB,QAAQ,wBAAuB;AACvE,SAASC,QAAQ,QAAQ,aAAY;AAErC,OAAO,MAAMC,gBAAgB,CAACC;IAC5B,MAAMC,YAAYN,UAChB;QACEO,MAAM;QACNC,MAAM;QACNC,QAAQ;YACNC,QAAQ,CAACC;gBACP,IAAI,CAACA,IAAIC,IAAI,EAAEC,MAAM;oBACnB,OAAO;gBACT;gBAEA,IAAIX,kBAAkBS,IAAIG,GAAG,CAACC,IAAI,GAAG;oBACnC,OAAO;gBACT;gBAEA,IAAId,aAAaU,IAAIG,GAAG,CAACC,IAAI,GAAG;oBAC9B,OAAOJ,IAAIC,IAAI,CAACC,IAAI,KAAKV,SAASa,IAAI;gBACxC;gBAEA,OAAO;YACT;YACAC,QAAQ,CAACN;gBACP,IAAI,CAACA,IAAIO,GAAG,EAAE;oBACZ,OAAO;gBACT;gBAEA,IAAI,CAAChB,kBAAkBS,IAAIG,GAAG,CAACC,IAAI,GAAG;oBACpC,OAAO;gBACT;gBAEA,8DAA8D;gBAC9D,IAAIJ,IAAIO,GAAG,CAACC,EAAE,KAAKR,IAAIG,GAAG,CAACC,IAAI,EAAEI,IAAI;oBACnC,OAAO;gBACT;gBAEA,OAAO;YACT;QACF;QACAC,cAAc;QACdC,OAAO,CAAC,EAAEC,CAAC,EAAE;YACX,OAAO,AAACA,EAA+C;QACzD;QACAC,SAAS;YACP;gBACEF,OAAO,CAAC,EAAEC,CAAC,EAAE,GACX,AAACA,EACC;gBAEJE,OAAOrB,SAASa,IAAI;YACtB;YACA;gBACEK,OAAO,CAAC,EAAEC,CAAC,EAAE,GACX,AAACA,EACC;gBAEJE,OAAOrB,SAASsB,KAAK;YACvB;YACA;gBACEJ,OAAO,CAAC,EAAEC,CAAC,EAAE,GACX,AAACA,EACC;gBAEJE,OAAOrB,SAASuB,UAAU;YAC5B;SACD;QACDC,UAAU;IACZ,GACAtB,WAAWuB,iBAAiB,CAAC;IAG/B,OAAO;QAACtB;KAAU;AACpB,EAAC"}
|
|
@@ -1,8 +1,6 @@
|
|
|
1
|
-
import type { CollectionConfig, Field, SelectField
|
|
1
|
+
import type { CollectionConfig, Field, SelectField } from 'payload';
|
|
2
2
|
export type UserFieldOverrides = {
|
|
3
|
-
generalTabOverrides?: Omit<Tab, 'name' | 'type'>;
|
|
4
3
|
roleOverrides?: Omit<SelectField, 'hasMany' | 'name' | 'required' | 'type'>;
|
|
5
|
-
tabOverrides?: Omit<TabsField, 'label' | 'name' | 'type'>;
|
|
6
4
|
};
|
|
7
5
|
export type UserCollectionOverrides = Omit<CollectionConfig, 'auth' | 'fields' | 'slug'>;
|
|
8
6
|
export type UserOverrides = {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/collections/users/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,KAAK,EAAE,WAAW,EAAE,
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/collections/users/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AAEnE,MAAM,MAAM,kBAAkB,GAAG;IAC/B,aAAa,CAAC,EAAE,IAAI,CAAC,WAAW,EAAE,SAAS,GAAG,MAAM,GAAG,UAAU,GAAG,MAAM,CAAC,CAAA;CAC5E,CAAA;AAED,MAAM,MAAM,uBAAuB,GAAG,IAAI,CAAC,gBAAgB,EAAE,MAAM,GAAG,QAAQ,GAAG,MAAM,CAAC,CAAA;AACxF,MAAM,MAAM,aAAa,GAAG;IAC1B,gBAAgB,CAAC,EAAE,KAAK,EAAE,CAAA;IAC1B,mBAAmB,CAAC,EAAE,uBAAuB,CAAA;IAC7C,cAAc,CAAC,EAAE,kBAAkB,CAAA;CACpC,CAAA;AAED,oBAAY,QAAQ;IAClB,KAAK,UAAU;IACf,UAAU,gBAAgB;IAC1B,IAAI,SAAS;CACd"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/collections/users/types.ts"],"sourcesContent":["import type { CollectionConfig, Field, SelectField
|
|
1
|
+
{"version":3,"sources":["../../../src/collections/users/types.ts"],"sourcesContent":["import type { CollectionConfig, Field, SelectField } from 'payload'\n\nexport type UserFieldOverrides = {\n roleOverrides?: Omit<SelectField, 'hasMany' | 'name' | 'required' | 'type'>\n}\n\nexport type UserCollectionOverrides = Omit<CollectionConfig, 'auth' | 'fields' | 'slug'>\nexport type UserOverrides = {\n additionalFields?: Field[]\n collectionOverrides?: UserCollectionOverrides\n fieldOverrides?: UserFieldOverrides\n}\n\nexport enum UserRole {\n Admin = 'admin',\n SuperAdmin = 'super-admin',\n User = 'user',\n}\n"],"names":["UserRole"],"mappings":"AAaA,OAAO,IAAA,AAAKA,kCAAAA;;;;WAAAA;MAIX"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@loadspark/core",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.3",
|
|
4
4
|
"description": "!!!Payload version: 3.69.0!!! Core package for loadspark. It contains custom PayloadCMS V3 fields, access control and more to make life easier.",
|
|
5
5
|
"license": "Custom",
|
|
6
6
|
"type": "module",
|