@mattisvensson/strapi-plugin-webatlas 0.3.0 → 0.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (82) hide show
  1. package/dist/_chunks/{EmptyBox-7D4LrvdH.mjs → EmptyBox-BM4IscSk.mjs} +2 -6
  2. package/dist/_chunks/{EmptyBox-DT6D5gcf.js → EmptyBox-T8t29l25.js} +1 -5
  3. package/dist/_chunks/FullLoader-Cmsf8xS6.js +11 -0
  4. package/dist/_chunks/FullLoader-CrPED_dY.mjs +12 -0
  5. package/dist/_chunks/{de-C8PE3n3B.mjs → de-Dn24NwJf.mjs} +11 -1
  6. package/dist/_chunks/{de-4tL_cJTC.js → de-RiCps8UH.js} +11 -1
  7. package/dist/_chunks/{en-CR1YZvJo.mjs → en-D9Lxaugc.mjs} +11 -1
  8. package/dist/_chunks/{en-Bg4z3fR7.js → en-JLW5S3ZC.js} +11 -1
  9. package/dist/_chunks/index-B3JakJZB.mjs +126 -0
  10. package/dist/_chunks/index-BpvDMe8t.js +126 -0
  11. package/dist/_chunks/index-C1rj8TbT.js +281 -0
  12. package/dist/_chunks/{index-B0XE_zRP.js → index-CKHmlZdc.js} +1381 -363
  13. package/dist/_chunks/index-Cce7AGi-.mjs +281 -0
  14. package/dist/_chunks/{index-B85fJxGa.js → index-ChDbwEb-.js} +43 -61
  15. package/dist/_chunks/{index-C7B8QHDT.mjs → index-DJ-Du5aY.mjs} +1375 -357
  16. package/dist/_chunks/{index-CCiDvLAC.mjs → index-DUxYbDKG.mjs} +43 -61
  17. package/dist/admin/index.js +1 -1
  18. package/dist/admin/index.mjs +1 -1
  19. package/dist/admin/src/components/UI/FullLoader.d.ts +3 -0
  20. package/dist/admin/src/components/UI/index.d.ts +2 -1
  21. package/dist/admin/src/components/modals/Delete.d.ts +3 -3
  22. package/dist/admin/src/components/modals/NavEdit.d.ts +2 -2
  23. package/dist/admin/src/components/modals/externalItem/index.d.ts +10 -4
  24. package/dist/admin/src/components/modals/internalItem/internalItemCreate.d.ts +1 -1
  25. package/dist/admin/src/components/modals/wrapperItem/index.d.ts +11 -5
  26. package/dist/admin/src/hooks/useApi.d.ts +6 -5
  27. package/dist/admin/src/hooks/useNavigations.d.ts +2 -0
  28. package/dist/admin/src/hooks/usePluginConfig.d.ts +3 -3
  29. package/dist/admin/src/pages/Navigation/PageWrapper.d.ts +7 -0
  30. package/dist/admin/src/pages/Navigation/index.d.ts +1 -1
  31. package/dist/admin/src/pages/Routes/PageWrapper.d.ts +4 -0
  32. package/dist/admin/src/pages/Routes/TableHeader.d.ts +1 -0
  33. package/dist/admin/src/pages/Routes/TableRow.d.ts +4 -0
  34. package/dist/admin/src/pages/Settings/ContentTypeAccordion.d.ts +7 -0
  35. package/dist/admin/src/pages/Settings/PageWrapper.d.ts +8 -0
  36. package/dist/admin/src/utils/createTempNavItemObject.d.ts +25 -0
  37. package/dist/admin/src/utils/index.d.ts +2 -1
  38. package/dist/server/index.js +228 -177
  39. package/dist/server/index.mjs +228 -177
  40. package/dist/server/src/controllers/admin.d.ts +1 -4
  41. package/dist/server/src/controllers/index.d.ts +1 -4
  42. package/dist/server/src/index.d.ts +2 -8
  43. package/dist/server/src/services/admin.d.ts +2 -5
  44. package/dist/server/src/services/index.d.ts +1 -4
  45. package/dist/server/src/utils/navItemHandler.d.ts +5 -0
  46. package/dist/server/src/utils/routeHandler.d.ts +3 -0
  47. package/package.json +1 -1
  48. package/dist/_chunks/EmptyBox-7D4LrvdH.mjs.map +0 -1
  49. package/dist/_chunks/EmptyBox-DT6D5gcf.js.map +0 -1
  50. package/dist/_chunks/_baseConvert-B84_vf8X.js +0 -864
  51. package/dist/_chunks/_baseConvert-B84_vf8X.js.map +0 -1
  52. package/dist/_chunks/_baseConvert-C2SW1VHq.mjs +0 -865
  53. package/dist/_chunks/_baseConvert-C2SW1VHq.mjs.map +0 -1
  54. package/dist/_chunks/de-4tL_cJTC.js.map +0 -1
  55. package/dist/_chunks/de-C8PE3n3B.mjs.map +0 -1
  56. package/dist/_chunks/en-Bg4z3fR7.js.map +0 -1
  57. package/dist/_chunks/en-CR1YZvJo.mjs.map +0 -1
  58. package/dist/_chunks/index-B2Tiv3EK.mjs +0 -92
  59. package/dist/_chunks/index-B48CGofU.mjs +0 -17170
  60. package/dist/_chunks/index-B48CGofU.mjs.map +0 -1
  61. package/dist/_chunks/index-BbM9Sn1t.js +0 -17195
  62. package/dist/_chunks/index-BocSkZOu.mjs +0 -17176
  63. package/dist/_chunks/index-CXzNr2cH.mjs +0 -93
  64. package/dist/_chunks/index-CXzNr2cH.mjs.map +0 -1
  65. package/dist/_chunks/index-Cd6y6nuf.js +0 -93
  66. package/dist/_chunks/index-Cd6y6nuf.js.map +0 -1
  67. package/dist/_chunks/index-Cf9ZIBLd.js +0 -4195
  68. package/dist/_chunks/index-Cf9ZIBLd.js.map +0 -1
  69. package/dist/_chunks/index-D981K4TK.mjs +0 -4179
  70. package/dist/_chunks/index-D981K4TK.mjs.map +0 -1
  71. package/dist/_chunks/index-DGb8ESH-.js +0 -92
  72. package/dist/_chunks/index-DYiJBXKE.js +0 -10131
  73. package/dist/_chunks/index-DYiJBXKE.js.map +0 -1
  74. package/dist/_chunks/index-DjZ3ZaVB.js +0 -17189
  75. package/dist/_chunks/index-DjZ3ZaVB.js.map +0 -1
  76. package/dist/_chunks/index-DkhJl5mF.mjs +0 -10131
  77. package/dist/_chunks/index-DkhJl5mF.mjs.map +0 -1
  78. package/dist/admin/index.js.map +0 -1
  79. package/dist/admin/index.mjs.map +0 -1
  80. package/dist/admin/src/pages/Navigation/Header.d.ts +0 -6
  81. package/dist/server/index.js.map +0 -1
  82. package/dist/server/index.mjs.map +0 -1
@@ -0,0 +1,281 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const jsxRuntime = require("react/jsx-runtime");
4
+ const React = require("react");
5
+ const designSystem = require("@strapi/design-system");
6
+ const admin = require("@strapi/strapi/admin");
7
+ const index = require("./index-ChDbwEb-.js");
8
+ const reactIntl = require("react-intl");
9
+ require("@strapi/icons/symbols");
10
+ const FullLoader = require("./FullLoader-Cmsf8xS6.js");
11
+ function PageWrapper({
12
+ settingsState,
13
+ initialState,
14
+ save,
15
+ isSaving,
16
+ children
17
+ }) {
18
+ const { formatMessage } = reactIntl.useIntl();
19
+ return /* @__PURE__ */ jsxRuntime.jsxs(admin.Page.Main, { children: [
20
+ /* @__PURE__ */ jsxRuntime.jsx(
21
+ admin.Layouts.Header,
22
+ {
23
+ title: index.PLUGIN_NAME,
24
+ subtitle: formatMessage({
25
+ id: index.getTranslation("settings.page.subtitle"),
26
+ defaultMessage: "Settings"
27
+ }),
28
+ primaryAction: settingsState && initialState && save && /* @__PURE__ */ jsxRuntime.jsx(
29
+ designSystem.Button,
30
+ {
31
+ type: "submit",
32
+ onClick: () => save(),
33
+ loading: isSaving,
34
+ disabled: JSON.stringify(settingsState) === JSON.stringify(initialState) || settingsState.selectedContentTypes.find((cta) => !cta.default) !== void 0 || isSaving,
35
+ children: formatMessage({
36
+ id: index.getTranslation("save"),
37
+ defaultMessage: "Save"
38
+ })
39
+ }
40
+ )
41
+ }
42
+ ),
43
+ /* @__PURE__ */ jsxRuntime.jsx(admin.Layouts.Content, { children: /* @__PURE__ */ jsxRuntime.jsx(
44
+ designSystem.Box,
45
+ {
46
+ background: "neutral0",
47
+ borderColor: "neutral150",
48
+ hasRadius: true,
49
+ paddingBottom: 4,
50
+ paddingLeft: 4,
51
+ paddingRight: 4,
52
+ paddingTop: 6,
53
+ shadow: "tableShadow",
54
+ children
55
+ }
56
+ ) })
57
+ ] });
58
+ }
59
+ function ContentTypeAccordion({
60
+ contentType,
61
+ contentTypeSettings,
62
+ dispatch
63
+ }) {
64
+ const { formatMessage } = reactIntl.useIntl();
65
+ if (!contentType) return null;
66
+ return /* @__PURE__ */ jsxRuntime.jsx(
67
+ designSystem.Box,
68
+ {
69
+ borderColor: !contentTypeSettings.default && "danger500",
70
+ children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Accordion.Item, { value: contentType.uid, size: "S", children: [
71
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Accordion.Header, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Accordion.Trigger, { children: contentType?.info.displayName }) }),
72
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Accordion.Content, { children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Box, { padding: 3, children: [
73
+ /* @__PURE__ */ jsxRuntime.jsxs(
74
+ designSystem.Field.Root,
75
+ {
76
+ name: "selectedContentTypes",
77
+ hint: formatMessage({
78
+ id: index.getTranslation("settings.page.defaultField.hint"),
79
+ defaultMessage: 'The selected field from the content type will be used to generate the URL alias. Use a field that is unique and descriptive, such as a "title" or "name".'
80
+ }),
81
+ error: !contentTypeSettings.default && formatMessage({
82
+ id: index.getTranslation("settings.page.defaultField.error"),
83
+ defaultMessage: "Please select a default field"
84
+ }),
85
+ required: true,
86
+ children: [
87
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { children: formatMessage({
88
+ id: index.getTranslation("settings.page.defaultField"),
89
+ defaultMessage: "Default URL Alias field"
90
+ }) }),
91
+ /* @__PURE__ */ jsxRuntime.jsx(
92
+ designSystem.SingleSelect,
93
+ {
94
+ name: `defaultField-${contentType.uid}`,
95
+ onClear: () => dispatch({ type: "SET_DEFAULT_FIELD", payload: { ctUid: contentType.uid, field: "" } }),
96
+ value: contentTypeSettings?.default || "",
97
+ onChange: (value) => dispatch({ type: "SET_DEFAULT_FIELD", payload: { ctUid: contentType.uid, field: value } }),
98
+ children: Object.entries(contentType.attributes).map(([key], index2) => {
99
+ if (key === "id" || key === "documentId" || key === "createdAt" || key === "updatedAt" || key === "createdBy" || key === "updatedBy" || key === "webatlas_path" || key === "webatlas_override") return null;
100
+ return /* @__PURE__ */ jsxRuntime.jsx(designSystem.SingleSelectOption, { value: key, children: key }, index2);
101
+ })
102
+ }
103
+ ),
104
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Hint, {})
105
+ ]
106
+ }
107
+ ),
108
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Box, { paddingTop: 4, children: /* @__PURE__ */ jsxRuntime.jsxs(
109
+ designSystem.Field.Root,
110
+ {
111
+ name: "urlAliasPattern",
112
+ hint: formatMessage({
113
+ id: index.getTranslation("settings.page.urlAliasPattern.hint"),
114
+ defaultMessage: 'The pattern to prepend to the generated URL alias. For example, if you enter "blog" and the value of default field is "My First Post", the generated URL alias will be "blog/my-first-post". Leave empty for no prefix.'
115
+ }),
116
+ children: [
117
+ /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Field.Label, { children: [
118
+ formatMessage({
119
+ id: index.getTranslation("settings.page.urlAliasPattern"),
120
+ defaultMessage: "URL Alias Pattern"
121
+ }),
122
+ /* @__PURE__ */ jsxRuntime.jsx(index.Tooltip, { description: formatMessage({
123
+ id: index.getTranslation("settings.page.urlAliasPattern.tooltip"),
124
+ defaultMessage: "Leading and trailing slashes will be removed. Spaces will be replaced with hyphens. Special characters will be encoded."
125
+ }) })
126
+ ] }),
127
+ /* @__PURE__ */ jsxRuntime.jsx(
128
+ designSystem.Field.Input,
129
+ {
130
+ value: contentTypeSettings.pattern,
131
+ onChange: (e) => dispatch({ type: "SET_PATTERN", payload: { ctUid: contentType.uid, pattern: e.target.value } }),
132
+ disabled: !contentTypeSettings.default,
133
+ type: "text",
134
+ placeholder: formatMessage({
135
+ id: index.getTranslation("settings.page.urlAliasPattern.placeholder"),
136
+ defaultMessage: "e.g. blog"
137
+ })
138
+ }
139
+ ),
140
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Hint, {})
141
+ ]
142
+ }
143
+ ) })
144
+ ] }) })
145
+ ] }, contentType.uid)
146
+ },
147
+ contentType.uid
148
+ );
149
+ }
150
+ function reducer(settingsState, action) {
151
+ let updatedContentTypes;
152
+ switch (action.type) {
153
+ case "SET_SELECTED_CONTENT_TYPES":
154
+ updatedContentTypes = action.payload.map((ct) => {
155
+ return settingsState.selectedContentTypes.find((cta) => cta.uid === ct.uid) || ct;
156
+ });
157
+ return { ...settingsState, selectedContentTypes: updatedContentTypes };
158
+ case "SET_DEFAULT_FIELD":
159
+ updatedContentTypes = settingsState.selectedContentTypes.map(
160
+ (ct) => ct.uid === action.payload.ctUid ? { ...ct, default: action.payload.field } : ct
161
+ );
162
+ return { ...settingsState, selectedContentTypes: updatedContentTypes };
163
+ case "SET_PATTERN":
164
+ updatedContentTypes = settingsState.selectedContentTypes.map(
165
+ (ct) => ct.uid === action.payload.ctUid ? { ...ct, pattern: index.transformToUrl(action.payload.pattern) } : ct
166
+ );
167
+ return { ...settingsState, selectedContentTypes: updatedContentTypes };
168
+ default:
169
+ throw new Error();
170
+ }
171
+ }
172
+ const Settings = () => {
173
+ const { config, setConfig, loading, fetchError } = index.usePluginConfig();
174
+ const [settingsState, dispatch] = React.useReducer(reducer, config || { selectedContentTypes: [] });
175
+ const { contentTypes: allContentTypesData } = index.useAllContentTypes();
176
+ const allContentTypes = allContentTypesData?.filter((ct) => ct.pluginOptions?.webatlas?.active === true);
177
+ const [initialState, setInitialState] = React.useState(config || { selectedContentTypes: [] });
178
+ const { toggleNotification } = admin.useNotification();
179
+ const { formatMessage } = reactIntl.useIntl();
180
+ const [isSaving, setIsSaving] = React.useState(false);
181
+ React.useEffect(() => {
182
+ setInitialState(config || { selectedContentTypes: [] });
183
+ }, [config]);
184
+ React.useEffect(() => {
185
+ if (!config) return;
186
+ dispatch({ type: "SET_SELECTED_CONTENT_TYPES", payload: config.selectedContentTypes });
187
+ }, [config]);
188
+ React.useEffect(() => {
189
+ if (fetchError) {
190
+ toggleNotification({
191
+ type: "danger",
192
+ message: formatMessage({
193
+ id: index.getTranslation("notification.error"),
194
+ defaultMessage: "An error occurred"
195
+ }) + ": " + fetchError
196
+ });
197
+ }
198
+ }, [fetchError, toggleNotification, formatMessage]);
199
+ async function save() {
200
+ if (!settingsState || settingsState.selectedContentTypes.find((cta) => !cta.default) !== void 0) return;
201
+ setIsSaving(true);
202
+ try {
203
+ await setConfig(settingsState);
204
+ setInitialState(settingsState);
205
+ toggleNotification({
206
+ type: "success",
207
+ message: formatMessage({
208
+ id: index.getTranslation("notification.settings.saved"),
209
+ defaultMessage: "Settings saved successfully"
210
+ })
211
+ });
212
+ setIsSaving(false);
213
+ } catch (err) {
214
+ setIsSaving(false);
215
+ toggleNotification({
216
+ type: "danger",
217
+ message: formatMessage({
218
+ id: index.getTranslation("notification.error"),
219
+ defaultMessage: "An error occurred"
220
+ }) + ": " + err
221
+ });
222
+ console.error(err);
223
+ }
224
+ }
225
+ if (loading) {
226
+ return /* @__PURE__ */ jsxRuntime.jsx(PageWrapper, { children: /* @__PURE__ */ jsxRuntime.jsx(FullLoader.FullLoader, { height: 200 }) });
227
+ }
228
+ return /* @__PURE__ */ jsxRuntime.jsxs(PageWrapper, { settingsState, initialState, save, isSaving, children: [
229
+ /* @__PURE__ */ jsxRuntime.jsxs(
230
+ designSystem.Field.Root,
231
+ {
232
+ name: "selectedContentTypes",
233
+ hint: formatMessage({
234
+ id: index.getTranslation("settings.page.enabledContentTypes.hint"),
235
+ defaultMessage: "Select the content types for which you want to enable URL aliases"
236
+ }),
237
+ children: [
238
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { children: formatMessage({
239
+ id: index.getTranslation("settings.page.enabledContentTypes"),
240
+ defaultMessage: "Enabled Content Types"
241
+ }) }),
242
+ /* @__PURE__ */ jsxRuntime.jsx(
243
+ designSystem.MultiSelect,
244
+ {
245
+ placeholder: formatMessage({
246
+ id: index.getTranslation("settings.page.enabledContentTypes.placeholder"),
247
+ defaultMessage: "Select content types..."
248
+ }),
249
+ onClear: () => dispatch({ type: "SET_SELECTED_CONTENT_TYPES", payload: [] }),
250
+ value: [...settingsState.selectedContentTypes.map((ct) => ct.uid)],
251
+ onChange: (value) => dispatch({
252
+ type: "SET_SELECTED_CONTENT_TYPES",
253
+ payload: value.map((v) => ({
254
+ uid: v,
255
+ default: "",
256
+ pattern: ""
257
+ }))
258
+ }),
259
+ withTags: true,
260
+ children: allContentTypes && allContentTypes.map(
261
+ (item) => /* @__PURE__ */ jsxRuntime.jsx(designSystem.MultiSelectOption, { value: item.uid, children: item.info.displayName }, item.uid)
262
+ )
263
+ }
264
+ ),
265
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Hint, {})
266
+ ]
267
+ }
268
+ ),
269
+ settingsState.selectedContentTypes && settingsState.selectedContentTypes.length > 0 && /* @__PURE__ */ jsxRuntime.jsx(designSystem.Box, { paddingTop: 4, children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Field.Root, { name: "selectedContentTypesAccordion", children: [
270
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { children: formatMessage({
271
+ id: index.getTranslation("settings.page.contentTypeSettings"),
272
+ defaultMessage: "Content Type settings"
273
+ }) }),
274
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Accordion.Root, { children: settingsState.selectedContentTypes?.map((contentTypeSettings) => {
275
+ const ct = allContentTypes?.find((item) => item.uid === contentTypeSettings.uid);
276
+ return /* @__PURE__ */ jsxRuntime.jsx(ContentTypeAccordion, { contentType: ct, contentTypeSettings, dispatch }, contentTypeSettings.uid);
277
+ }) })
278
+ ] }) })
279
+ ] });
280
+ };
281
+ exports.default = Settings;