@payloadcms/plugin-redirects 3.0.0-canary.f6e77b8 → 3.0.0-canary.fb04843

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.
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/exports/types.ts"],"sourcesContent":["export type { RedirectsPluginConfig } from '../types.js'\n"],"names":[],"rangeMappings":"","mappings":"AAAA,WAAwD"}
1
+ {"version":3,"sources":["../../src/exports/types.ts"],"sourcesContent":["export type { RedirectsPluginConfig } from '../types.js'\n"],"names":[],"mappings":"AAAA,WAAwD"}
package/dist/index.d.ts CHANGED
@@ -1,4 +1,5 @@
1
- import type { Config } from 'payload/config';
1
+ import type { Config } from 'payload';
2
2
  import type { RedirectsPluginConfig } from './types.js';
3
+ export { redirectOptions, redirectTypes } from './redirectTypes.js';
3
4
  export declare const redirectsPlugin: (pluginConfig: RedirectsPluginConfig) => (incomingConfig: Config) => Config;
4
5
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAA;AAE5C,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAA;AAIvD,eAAO,MAAM,eAAe,iBACX,qBAAqB,sBACnB,MAAM,KAAG,MAuExB,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAoB,MAAM,EAAsB,MAAM,SAAS,CAAA;AAE3E,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAA;AAIvD,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AACnE,eAAO,MAAM,eAAe,iBACX,qBAAqB,sBACnB,MAAM,KAAG,MAyFzB,CAAA"}
package/dist/index.js CHANGED
@@ -1,76 +1,97 @@
1
- import deepMerge from './deepMerge.js';
2
- export const redirectsPlugin = (pluginConfig)=>(incomingConfig)=>({
3
- ...incomingConfig,
4
- collections: [
5
- ...incomingConfig?.collections || [],
6
- deepMerge({
7
- slug: 'redirects',
8
- access: {
9
- read: ()=>true
10
- },
11
- admin: {
12
- defaultColumns: [
13
- 'from',
14
- 'to.type',
15
- 'createdAt'
1
+ import { redirectOptions } from './redirectTypes.js';
2
+ export { redirectOptions, redirectTypes } from './redirectTypes.js';
3
+ export const redirectsPlugin = (pluginConfig)=>(incomingConfig)=>{
4
+ const redirectSelectField = {
5
+ name: 'type',
6
+ type: 'select',
7
+ label: 'Redirect Type',
8
+ options: redirectOptions.filter((option)=>pluginConfig?.redirectTypes?.includes(option.value)),
9
+ required: true,
10
+ ...pluginConfig?.redirectTypeFieldOverride || {}
11
+ };
12
+ const defaultFields = [
13
+ {
14
+ name: 'from',
15
+ type: 'text',
16
+ index: true,
17
+ label: 'From URL',
18
+ required: true
19
+ },
20
+ {
21
+ name: 'to',
22
+ type: 'group',
23
+ fields: [
24
+ {
25
+ name: 'type',
26
+ type: 'radio',
27
+ admin: {
28
+ layout: 'horizontal'
29
+ },
30
+ defaultValue: 'reference',
31
+ label: 'To URL Type',
32
+ options: [
33
+ {
34
+ label: 'Internal link',
35
+ value: 'reference'
36
+ },
37
+ {
38
+ label: 'Custom URL',
39
+ value: 'custom'
40
+ }
16
41
  ]
17
42
  },
18
- fields: [
19
- {
20
- name: 'from',
21
- type: 'text',
22
- index: true,
23
- label: 'From URL',
24
- required: true
43
+ {
44
+ name: 'reference',
45
+ type: 'relationship',
46
+ admin: {
47
+ condition: (_, siblingData)=>siblingData?.type === 'reference'
25
48
  },
26
- {
27
- name: 'to',
28
- type: 'group',
29
- fields: [
30
- {
31
- name: 'type',
32
- type: 'radio',
33
- admin: {
34
- layout: 'horizontal'
35
- },
36
- defaultValue: 'reference',
37
- label: 'To URL Type',
38
- options: [
39
- {
40
- label: 'Internal link',
41
- value: 'reference'
42
- },
43
- {
44
- label: 'Custom URL',
45
- value: 'custom'
46
- }
47
- ]
48
- },
49
- {
50
- name: 'reference',
51
- type: 'relationship',
52
- admin: {
53
- condition: (_, siblingData)=>siblingData?.type === 'reference'
54
- },
55
- label: 'Document to redirect to',
56
- relationTo: pluginConfig?.collections || [],
57
- required: true
58
- },
59
- {
60
- name: 'url',
61
- type: 'text',
62
- admin: {
63
- condition: (_, siblingData)=>siblingData?.type === 'custom'
64
- },
65
- label: 'Custom URL',
66
- required: true
67
- }
68
- ],
69
- label: false
70
- }
71
- ]
72
- }, pluginConfig?.overrides || {})
49
+ label: 'Document to redirect to',
50
+ relationTo: pluginConfig?.collections || [],
51
+ required: true
52
+ },
53
+ {
54
+ name: 'url',
55
+ type: 'text',
56
+ admin: {
57
+ condition: (_, siblingData)=>siblingData?.type === 'custom'
58
+ },
59
+ label: 'Custom URL',
60
+ required: true
61
+ }
62
+ ],
63
+ label: false
64
+ },
65
+ ...pluginConfig?.redirectTypes ? [
66
+ redirectSelectField
67
+ ] : []
68
+ ];
69
+ const redirectsCollection = {
70
+ ...pluginConfig?.overrides || {},
71
+ slug: pluginConfig?.overrides?.slug || 'redirects',
72
+ access: {
73
+ read: ()=>true,
74
+ ...pluginConfig?.overrides?.access || {}
75
+ },
76
+ admin: {
77
+ defaultColumns: [
78
+ 'from',
79
+ 'to.type',
80
+ 'createdAt'
81
+ ],
82
+ ...pluginConfig?.overrides?.admin || {}
83
+ },
84
+ fields: pluginConfig?.overrides?.fields && typeof pluginConfig?.overrides?.fields === 'function' ? pluginConfig?.overrides.fields({
85
+ defaultFields
86
+ }) : defaultFields
87
+ };
88
+ return {
89
+ ...incomingConfig,
90
+ collections: [
91
+ ...incomingConfig?.collections || [],
92
+ redirectsCollection
73
93
  ]
74
- });
94
+ };
95
+ };
75
96
 
76
97
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.ts"],"sourcesContent":["import type { Config } from 'payload/config'\n\nimport type { RedirectsPluginConfig } from './types.js'\n\nimport deepMerge from './deepMerge.js'\n\nexport const redirectsPlugin =\n (pluginConfig: RedirectsPluginConfig) =>\n (incomingConfig: Config): Config => ({\n ...incomingConfig,\n collections: [\n ...(incomingConfig?.collections || []),\n deepMerge(\n {\n slug: 'redirects',\n access: {\n read: (): boolean => true,\n },\n admin: {\n defaultColumns: ['from', 'to.type', 'createdAt'],\n },\n fields: [\n {\n name: 'from',\n type: 'text',\n index: true,\n label: 'From URL',\n required: true,\n },\n {\n name: 'to',\n type: 'group',\n fields: [\n {\n name: 'type',\n type: 'radio',\n admin: {\n layout: 'horizontal',\n },\n defaultValue: 'reference',\n label: 'To URL Type',\n options: [\n {\n label: 'Internal link',\n value: 'reference',\n },\n {\n label: 'Custom URL',\n value: 'custom',\n },\n ],\n },\n {\n name: 'reference',\n type: 'relationship',\n admin: {\n condition: (_, siblingData) => siblingData?.type === 'reference',\n },\n label: 'Document to redirect to',\n relationTo: pluginConfig?.collections || [],\n required: true,\n },\n {\n name: 'url',\n type: 'text',\n admin: {\n condition: (_, siblingData) => siblingData?.type === 'custom',\n },\n label: 'Custom URL',\n required: true,\n },\n ],\n label: false,\n },\n ],\n },\n pluginConfig?.overrides || {},\n ),\n ],\n })\n"],"names":["deepMerge","redirectsPlugin","pluginConfig","incomingConfig","collections","slug","access","read","admin","defaultColumns","fields","name","type","index","label","required","layout","defaultValue","options","value","condition","_","siblingData","relationTo","overrides"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAIA,OAAOA,eAAe,iBAAgB;AAEtC,OAAO,MAAMC,kBACX,CAACC,eACD,CAACC,iBAAoC,CAAA;YACnC,GAAGA,cAAc;YACjBC,aAAa;mBACPD,gBAAgBC,eAAe,EAAE;gBACrCJ,UACE;oBACEK,MAAM;oBACNC,QAAQ;wBACNC,MAAM,IAAe;oBACvB;oBACAC,OAAO;wBACLC,gBAAgB;4BAAC;4BAAQ;4BAAW;yBAAY;oBAClD;oBACAC,QAAQ;wBACN;4BACEC,MAAM;4BACNC,MAAM;4BACNC,OAAO;4BACPC,OAAO;4BACPC,UAAU;wBACZ;wBACA;4BACEJ,MAAM;4BACNC,MAAM;4BACNF,QAAQ;gCACN;oCACEC,MAAM;oCACNC,MAAM;oCACNJ,OAAO;wCACLQ,QAAQ;oCACV;oCACAC,cAAc;oCACdH,OAAO;oCACPI,SAAS;wCACP;4CACEJ,OAAO;4CACPK,OAAO;wCACT;wCACA;4CACEL,OAAO;4CACPK,OAAO;wCACT;qCACD;gCACH;gCACA;oCACER,MAAM;oCACNC,MAAM;oCACNJ,OAAO;wCACLY,WAAW,CAACC,GAAGC,cAAgBA,aAAaV,SAAS;oCACvD;oCACAE,OAAO;oCACPS,YAAYrB,cAAcE,eAAe,EAAE;oCAC3CW,UAAU;gCACZ;gCACA;oCACEJ,MAAM;oCACNC,MAAM;oCACNJ,OAAO;wCACLY,WAAW,CAACC,GAAGC,cAAgBA,aAAaV,SAAS;oCACvD;oCACAE,OAAO;oCACPC,UAAU;gCACZ;6BACD;4BACDD,OAAO;wBACT;qBACD;gBACH,GACAZ,cAAcsB,aAAa,CAAC;aAE/B;QACH,CAAA,EAAE"}
1
+ {"version":3,"sources":["../src/index.ts"],"sourcesContent":["import type { CollectionConfig, Config, Field, SelectField } from 'payload'\n\nimport type { RedirectsPluginConfig } from './types.js'\n\nimport { redirectOptions } from './redirectTypes.js'\n\nexport { redirectOptions, redirectTypes } from './redirectTypes.js'\nexport const redirectsPlugin =\n (pluginConfig: RedirectsPluginConfig) =>\n (incomingConfig: Config): Config => {\n const redirectSelectField: SelectField = {\n name: 'type',\n type: 'select',\n label: 'Redirect Type',\n options: redirectOptions.filter((option) =>\n pluginConfig?.redirectTypes?.includes(option.value),\n ),\n required: true,\n ...((pluginConfig?.redirectTypeFieldOverride || {}) as SelectField),\n }\n\n const defaultFields: Field[] = [\n {\n name: 'from',\n type: 'text',\n index: true,\n label: 'From URL',\n required: true,\n },\n {\n name: 'to',\n type: 'group',\n fields: [\n {\n name: 'type',\n type: 'radio',\n admin: {\n layout: 'horizontal',\n },\n defaultValue: 'reference',\n label: 'To URL Type',\n options: [\n {\n label: 'Internal link',\n value: 'reference',\n },\n {\n label: 'Custom URL',\n value: 'custom',\n },\n ],\n },\n {\n name: 'reference',\n type: 'relationship',\n admin: {\n condition: (_, siblingData) => siblingData?.type === 'reference',\n },\n label: 'Document to redirect to',\n relationTo: pluginConfig?.collections || [],\n required: true,\n },\n {\n name: 'url',\n type: 'text',\n admin: {\n condition: (_, siblingData) => siblingData?.type === 'custom',\n },\n label: 'Custom URL',\n required: true,\n },\n ],\n label: false,\n },\n ...(pluginConfig?.redirectTypes ? [redirectSelectField] : []),\n ]\n\n const redirectsCollection: CollectionConfig = {\n ...(pluginConfig?.overrides || {}),\n slug: pluginConfig?.overrides?.slug || 'redirects',\n access: {\n read: () => true,\n ...(pluginConfig?.overrides?.access || {}),\n },\n admin: {\n defaultColumns: ['from', 'to.type', 'createdAt'],\n ...(pluginConfig?.overrides?.admin || {}),\n },\n fields:\n pluginConfig?.overrides?.fields && typeof pluginConfig?.overrides?.fields === 'function'\n ? pluginConfig?.overrides.fields({ defaultFields })\n : defaultFields,\n }\n\n return {\n ...incomingConfig,\n collections: [...(incomingConfig?.collections || []), redirectsCollection],\n }\n }\n"],"names":["redirectOptions","redirectTypes","redirectsPlugin","pluginConfig","incomingConfig","redirectSelectField","name","type","label","options","filter","option","includes","value","required","redirectTypeFieldOverride","defaultFields","index","fields","admin","layout","defaultValue","condition","_","siblingData","relationTo","collections","redirectsCollection","overrides","slug","access","read","defaultColumns"],"mappings":"AAIA,SAASA,eAAe,QAAQ,qBAAoB;AAEpD,SAASA,eAAe,EAAEC,aAAa,QAAQ,qBAAoB;AACnE,OAAO,MAAMC,kBACX,CAACC,eACD,CAACC;QACC,MAAMC,sBAAmC;YACvCC,MAAM;YACNC,MAAM;YACNC,OAAO;YACPC,SAAST,gBAAgBU,MAAM,CAAC,CAACC,SAC/BR,cAAcF,eAAeW,SAASD,OAAOE,KAAK;YAEpDC,UAAU;YACV,GAAKX,cAAcY,6BAA6B,CAAC,CAAC;QACpD;QAEA,MAAMC,gBAAyB;YAC7B;gBACEV,MAAM;gBACNC,MAAM;gBACNU,OAAO;gBACPT,OAAO;gBACPM,UAAU;YACZ;YACA;gBACER,MAAM;gBACNC,MAAM;gBACNW,QAAQ;oBACN;wBACEZ,MAAM;wBACNC,MAAM;wBACNY,OAAO;4BACLC,QAAQ;wBACV;wBACAC,cAAc;wBACdb,OAAO;wBACPC,SAAS;4BACP;gCACED,OAAO;gCACPK,OAAO;4BACT;4BACA;gCACEL,OAAO;gCACPK,OAAO;4BACT;yBACD;oBACH;oBACA;wBACEP,MAAM;wBACNC,MAAM;wBACNY,OAAO;4BACLG,WAAW,CAACC,GAAGC,cAAgBA,aAAajB,SAAS;wBACvD;wBACAC,OAAO;wBACPiB,YAAYtB,cAAcuB,eAAe,EAAE;wBAC3CZ,UAAU;oBACZ;oBACA;wBACER,MAAM;wBACNC,MAAM;wBACNY,OAAO;4BACLG,WAAW,CAACC,GAAGC,cAAgBA,aAAajB,SAAS;wBACvD;wBACAC,OAAO;wBACPM,UAAU;oBACZ;iBACD;gBACDN,OAAO;YACT;eACIL,cAAcF,gBAAgB;gBAACI;aAAoB,GAAG,EAAE;SAC7D;QAED,MAAMsB,sBAAwC;YAC5C,GAAIxB,cAAcyB,aAAa,CAAC,CAAC;YACjCC,MAAM1B,cAAcyB,WAAWC,QAAQ;YACvCC,QAAQ;gBACNC,MAAM,IAAM;gBACZ,GAAI5B,cAAcyB,WAAWE,UAAU,CAAC,CAAC;YAC3C;YACAX,OAAO;gBACLa,gBAAgB;oBAAC;oBAAQ;oBAAW;iBAAY;gBAChD,GAAI7B,cAAcyB,WAAWT,SAAS,CAAC,CAAC;YAC1C;YACAD,QACEf,cAAcyB,WAAWV,UAAU,OAAOf,cAAcyB,WAAWV,WAAW,aAC1Ef,cAAcyB,UAAUV,OAAO;gBAAEF;YAAc,KAC/CA;QACR;QAEA,OAAO;YACL,GAAGZ,cAAc;YACjBsB,aAAa;mBAAKtB,gBAAgBsB,eAAe,EAAE;gBAAGC;aAAoB;QAC5E;IACF,EAAC"}
@@ -0,0 +1,6 @@
1
+ export declare const redirectTypes: readonly ["301", "302", "303", "307", "308"];
2
+ export declare const redirectOptions: {
3
+ label: string;
4
+ value: (typeof redirectTypes)[number];
5
+ }[];
6
+ //# sourceMappingURL=redirectTypes.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"redirectTypes.d.ts","sourceRoot":"","sources":["../src/redirectTypes.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,aAAa,8CAA+C,CAAA;AAEzE,eAAO,MAAM,eAAe,EAAE;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,CAAC,OAAO,aAAa,CAAC,CAAC,MAAM,CAAC,CAAA;CAAE,EAqBrF,CAAA"}
@@ -0,0 +1,31 @@
1
+ export const redirectTypes = [
2
+ '301',
3
+ '302',
4
+ '303',
5
+ '307',
6
+ '308'
7
+ ];
8
+ export const redirectOptions = [
9
+ {
10
+ label: '301 - Permanent',
11
+ value: '301'
12
+ },
13
+ {
14
+ label: '302 - Temporary',
15
+ value: '302'
16
+ },
17
+ {
18
+ label: '303 - See Other',
19
+ value: '303'
20
+ },
21
+ {
22
+ label: '307 - Temporary Redirect',
23
+ value: '307'
24
+ },
25
+ {
26
+ label: '308 - Permanent Redirect',
27
+ value: '308'
28
+ }
29
+ ];
30
+
31
+ //# sourceMappingURL=redirectTypes.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/redirectTypes.ts"],"sourcesContent":["export const redirectTypes = ['301', '302', '303', '307', '308'] as const\n\nexport const redirectOptions: { label: string; value: (typeof redirectTypes)[number] }[] = [\n {\n label: '301 - Permanent',\n value: '301',\n },\n {\n label: '302 - Temporary',\n value: '302',\n },\n {\n label: '303 - See Other',\n value: '303',\n },\n {\n label: '307 - Temporary Redirect',\n value: '307',\n },\n {\n label: '308 - Permanent Redirect',\n value: '308',\n },\n]\n"],"names":["redirectTypes","redirectOptions","label","value"],"mappings":"AAAA,OAAO,MAAMA,gBAAgB;IAAC;IAAO;IAAO;IAAO;IAAO;CAAM,CAAS;AAEzE,OAAO,MAAMC,kBAA8E;IACzF;QACEC,OAAO;QACPC,OAAO;IACT;IACA;QACED,OAAO;QACPC,OAAO;IACT;IACA;QACED,OAAO;QACPC,OAAO;IACT;IACA;QACED,OAAO;QACPC,OAAO;IACT;IACA;QACED,OAAO;QACPC,OAAO;IACT;CACD,CAAA"}
package/dist/types.d.ts CHANGED
@@ -1,6 +1,14 @@
1
- import type { CollectionConfig } from 'payload/types';
1
+ import type { CollectionConfig, Field, SelectField } from 'payload';
2
+ import type { redirectTypes } from './redirectTypes.js';
3
+ export type FieldsOverride = (args: {
4
+ defaultFields: Field[];
5
+ }) => Field[];
2
6
  export type RedirectsPluginConfig = {
3
7
  collections?: string[];
4
- overrides?: Partial<CollectionConfig>;
8
+ overrides?: {
9
+ fields?: FieldsOverride;
10
+ } & Partial<Omit<CollectionConfig, 'fields'>>;
11
+ redirectTypeFieldOverride?: Partial<SelectField>;
12
+ redirectTypes?: (typeof redirectTypes)[number][];
5
13
  };
6
14
  //# sourceMappingURL=types.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAA;AAErD,MAAM,MAAM,qBAAqB,GAAG;IAClC,WAAW,CAAC,EAAE,MAAM,EAAE,CAAA;IACtB,SAAS,CAAC,EAAE,OAAO,CAAC,gBAAgB,CAAC,CAAA;CACtC,CAAA"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,SAAS,CAAA;AAEnE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AACvD,MAAM,MAAM,cAAc,GAAG,CAAC,IAAI,EAAE;IAAE,aAAa,EAAE,KAAK,EAAE,CAAA;CAAE,KAAK,KAAK,EAAE,CAAA;AAE1E,MAAM,MAAM,qBAAqB,GAAG;IAClC,WAAW,CAAC,EAAE,MAAM,EAAE,CAAA;IACtB,SAAS,CAAC,EAAE;QAAE,MAAM,CAAC,EAAE,cAAc,CAAA;KAAE,GAAG,OAAO,CAAC,IAAI,CAAC,gBAAgB,EAAE,QAAQ,CAAC,CAAC,CAAA;IACnF,yBAAyB,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,CAAA;IAChD,aAAa,CAAC,EAAE,CAAC,OAAO,aAAa,CAAC,CAAC,MAAM,CAAC,EAAE,CAAA;CACjD,CAAA"}
package/dist/types.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/types.ts"],"sourcesContent":["import type { CollectionConfig } from 'payload/types'\n\nexport type RedirectsPluginConfig = {\n collections?: string[]\n overrides?: Partial<CollectionConfig>\n}\n"],"names":[],"rangeMappings":"","mappings":"AAEA,WAGC"}
1
+ {"version":3,"sources":["../src/types.ts"],"sourcesContent":["import type { CollectionConfig, Field, SelectField } from 'payload'\n\nimport type { redirectTypes } from './redirectTypes.js'\nexport type FieldsOverride = (args: { defaultFields: Field[] }) => Field[]\n\nexport type RedirectsPluginConfig = {\n collections?: string[]\n overrides?: { fields?: FieldsOverride } & Partial<Omit<CollectionConfig, 'fields'>>\n redirectTypeFieldOverride?: Partial<SelectField>\n redirectTypes?: (typeof redirectTypes)[number][]\n}\n"],"names":[],"mappings":"AAKA,WAKC"}
package/license.md ADDED
@@ -0,0 +1,22 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2018-2024 Payload CMS, Inc. <info@payloadcms.com>
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining
6
+ a copy of this software and associated documentation files (the
7
+ 'Software'), to deal in the Software without restriction, including
8
+ without limitation the rights to use, copy, modify, merge, publish,
9
+ distribute, sublicense, and/or sell copies of the Software, and to
10
+ permit persons to whom the Software is furnished to do so, subject to
11
+ the following conditions:
12
+
13
+ The above copyright notice and this permission notice shall be
14
+ included in all copies or substantial portions of the Software.
15
+
16
+ THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND,
17
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
19
+ IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
20
+ CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
21
+ TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
22
+ SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@payloadcms/plugin-redirects",
3
- "version": "3.0.0-canary.f6e77b8",
3
+ "version": "3.0.0-canary.fb04843",
4
4
  "description": "Redirects plugin for Payload",
5
5
  "keywords": [
6
6
  "payload",
@@ -18,17 +18,24 @@
18
18
  },
19
19
  "license": "MIT",
20
20
  "author": "Payload <dev@payloadcms.com> (https://payloadcms.com)",
21
+ "maintainers": [
22
+ {
23
+ "name": "Payload",
24
+ "email": "info@payloadcms.com",
25
+ "url": "https://payloadcms.com"
26
+ }
27
+ ],
21
28
  "type": "module",
22
29
  "exports": {
23
30
  ".": {
24
31
  "import": "./dist/index.js",
25
- "require": "./dist/index.js",
26
- "types": "./dist/index.d.ts"
32
+ "types": "./dist/index.d.ts",
33
+ "default": "./dist/index.js"
27
34
  },
28
- "./*": {
29
- "import": "./dist/exports/*.js",
30
- "require": "./dist/exports/*.js",
31
- "types": "./dist/exports/*.d.ts"
35
+ "./types": {
36
+ "import": "./dist/exports/types.js",
37
+ "types": "./dist/exports/types.d.ts",
38
+ "default": "./dist/exports/types.js"
32
39
  }
33
40
  },
34
41
  "main": "./dist/index.js",
@@ -39,20 +46,20 @@
39
46
  "types.d.ts"
40
47
  ],
41
48
  "devDependencies": {
42
- "@types/express": "^4.17.9",
43
- "@types/react": "18.2.74",
44
- "@payloadcms/eslint-config": "1.1.1",
45
- "payload": "3.0.0-canary.f6e77b8"
49
+ "@payloadcms/eslint-config": "3.0.0-beta.112",
50
+ "payload": "3.0.0-canary.fb04843"
46
51
  },
47
52
  "peerDependencies": {
48
- "payload": "3.0.0-canary.f6e77b8"
53
+ "payload": "3.0.0-canary.fb04843"
49
54
  },
50
55
  "homepage:": "https://payloadcms.com",
51
56
  "scripts": {
52
- "build": "pnpm copyfiles && pnpm build:swc && pnpm build:types",
53
- "build:swc": "swc ./src -d ./dist --config-file .swcrc",
57
+ "build": "pnpm copyfiles && pnpm build:types && pnpm build:swc",
58
+ "build:swc": "swc ./src -d ./dist --config-file .swcrc --strip-leading-paths",
54
59
  "build:types": "tsc --emitDeclarationOnly --outDir dist",
55
60
  "clean": "rimraf {dist,*.tsbuildinfo}",
56
- "copyfiles": "copyfiles -u 1 \"src/**/*.{html,css,scss,ttf,woff,woff2,eot,svg,jpg,png,json}\" dist/"
61
+ "copyfiles": "copyfiles -u 1 \"src/**/*.{html,css,scss,ttf,woff,woff2,eot,svg,jpg,png,json}\" dist/",
62
+ "lint": "eslint .",
63
+ "lint:fix": "eslint . --fix"
57
64
  }
58
65
  }
@@ -1,13 +0,0 @@
1
- /**
2
- * Simple object check.
3
- * @param item
4
- * @returns {boolean}
5
- */
6
- export declare function isObject(item: unknown): boolean;
7
- /**
8
- * Deep merge two objects.
9
- * @param target
10
- * @param ...sources
11
- */
12
- export default function deepMerge<T, R>(target: T, source: R): T;
13
- //# sourceMappingURL=deepMerge.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"deepMerge.d.ts","sourceRoot":"","sources":["../src/deepMerge.ts"],"names":[],"mappings":"AAEA;;;;GAIG;AACH,wBAAgB,QAAQ,CAAC,IAAI,EAAE,OAAO,GAAG,OAAO,CAE/C;AAED;;;;GAIG;AACH,MAAM,CAAC,OAAO,UAAU,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,GAAG,CAAC,CAiB/D"}
package/dist/deepMerge.js DELETED
@@ -1,37 +0,0 @@
1
- // @ts-nocheck
2
- /**
3
- * Simple object check.
4
- * @param item
5
- * @returns {boolean}
6
- */ export function isObject(item) {
7
- return item && typeof item === 'object' && !Array.isArray(item);
8
- }
9
- /**
10
- * Deep merge two objects.
11
- * @param target
12
- * @param ...sources
13
- */ export default function deepMerge(target, source) {
14
- const output = {
15
- ...target
16
- };
17
- if (isObject(target) && isObject(source)) {
18
- Object.keys(source).forEach((key)=>{
19
- if (isObject(source[key])) {
20
- if (!(key in target)) {
21
- Object.assign(output, {
22
- [key]: source[key]
23
- });
24
- } else {
25
- output[key] = deepMerge(target[key], source[key]);
26
- }
27
- } else {
28
- Object.assign(output, {
29
- [key]: source[key]
30
- });
31
- }
32
- });
33
- }
34
- return output;
35
- }
36
-
37
- //# sourceMappingURL=deepMerge.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/deepMerge.ts"],"sourcesContent":["// @ts-nocheck\n\n/**\n * Simple object check.\n * @param item\n * @returns {boolean}\n */\nexport function isObject(item: unknown): boolean {\n return item && typeof item === 'object' && !Array.isArray(item)\n}\n\n/**\n * Deep merge two objects.\n * @param target\n * @param ...sources\n */\nexport default function deepMerge<T, R>(target: T, source: R): T {\n const output = { ...target }\n if (isObject(target) && isObject(source)) {\n Object.keys(source).forEach((key) => {\n if (isObject(source[key])) {\n if (!(key in target)) {\n Object.assign(output, { [key]: source[key] })\n } else {\n output[key] = deepMerge(target[key], source[key])\n }\n } else {\n Object.assign(output, { [key]: source[key] })\n }\n })\n }\n\n return output\n}\n"],"names":["isObject","item","Array","isArray","deepMerge","target","source","output","Object","keys","forEach","key","assign"],"rangeMappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","mappings":"AAAA,cAAc;AAEd;;;;CAIC,GACD,OAAO,SAASA,SAASC,IAAa;IACpC,OAAOA,QAAQ,OAAOA,SAAS,YAAY,CAACC,MAAMC,OAAO,CAACF;AAC5D;AAEA;;;;CAIC,GACD,eAAe,SAASG,UAAgBC,MAAS,EAAEC,MAAS;IAC1D,MAAMC,SAAS;QAAE,GAAGF,MAAM;IAAC;IAC3B,IAAIL,SAASK,WAAWL,SAASM,SAAS;QACxCE,OAAOC,IAAI,CAACH,QAAQI,OAAO,CAAC,CAACC;YAC3B,IAAIX,SAASM,MAAM,CAACK,IAAI,GAAG;gBACzB,IAAI,CAAEA,CAAAA,OAAON,MAAK,GAAI;oBACpBG,OAAOI,MAAM,CAACL,QAAQ;wBAAE,CAACI,IAAI,EAAEL,MAAM,CAACK,IAAI;oBAAC;gBAC7C,OAAO;oBACLJ,MAAM,CAACI,IAAI,GAAGP,UAAUC,MAAM,CAACM,IAAI,EAAEL,MAAM,CAACK,IAAI;gBAClD;YACF,OAAO;gBACLH,OAAOI,MAAM,CAACL,QAAQ;oBAAE,CAACI,IAAI,EAAEL,MAAM,CAACK,IAAI;gBAAC;YAC7C;QACF;IACF;IAEA,OAAOJ;AACT"}