@mattisvensson/strapi-plugin-webatlas 0.8.0 → 0.8.2

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 (84) hide show
  1. package/dist/_chunks/FullLoader-Cmsf8xS6.js +12 -0
  2. package/dist/_chunks/FullLoader-Cmsf8xS6.js.map +1 -0
  3. package/dist/_chunks/FullLoader-CrPED_dY.mjs +1 -0
  4. package/dist/_chunks/FullLoader-CrPED_dY.mjs.map +1 -0
  5. package/dist/_chunks/SettingTitle-BaaQ_99D.mjs +69 -0
  6. package/dist/_chunks/SettingTitle-BaaQ_99D.mjs.map +1 -0
  7. package/dist/_chunks/SettingTitle-D5oNwpzC.js +67 -0
  8. package/dist/_chunks/SettingTitle-DDZxIqee.js +68 -0
  9. package/dist/_chunks/SettingTitle-DDZxIqee.js.map +1 -0
  10. package/dist/_chunks/SettingTitle-IwvX4Kb5.mjs +68 -0
  11. package/dist/_chunks/{de-C1QgkRoj.mjs → de-B9pq-AJZ.mjs} +11 -2
  12. package/dist/_chunks/de-B9pq-AJZ.mjs.map +1 -0
  13. package/dist/_chunks/de-DlQxM8Tg.js +131 -0
  14. package/dist/_chunks/de-DlQxM8Tg.js.map +1 -0
  15. package/dist/_chunks/{en--8p5hbLP.mjs → en-Dmbcf7gp.mjs} +11 -2
  16. package/dist/_chunks/en-Dmbcf7gp.mjs.map +1 -0
  17. package/dist/_chunks/en-DrhxIwOr.js +131 -0
  18. package/dist/_chunks/en-DrhxIwOr.js.map +1 -0
  19. package/dist/_chunks/index--XAogZgv.js +247 -0
  20. package/dist/_chunks/index--XAogZgv.js.map +1 -0
  21. package/dist/_chunks/index-2lVgPz4a.js +128 -0
  22. package/dist/_chunks/index-B1dEY-gs.js +246 -0
  23. package/dist/_chunks/index-B1mbYb2_.js +293 -0
  24. package/dist/_chunks/index-B2tjc_lG.mjs +247 -0
  25. package/dist/_chunks/index-B2tjc_lG.mjs.map +1 -0
  26. package/dist/_chunks/index-BFuwbmZy.js +12241 -0
  27. package/dist/_chunks/{index-DSPh-fHL.mjs → index-D2Meknib.mjs} +11 -9
  28. package/dist/_chunks/index-D2SIGcj3.mjs +12242 -0
  29. package/dist/_chunks/index-D2SIGcj3.mjs.map +1 -0
  30. package/dist/_chunks/index-DH0mFrgH.js +129 -0
  31. package/dist/_chunks/index-DH0mFrgH.js.map +1 -0
  32. package/dist/_chunks/index-DKtlnMlv.js +12242 -0
  33. package/dist/_chunks/index-DKtlnMlv.js.map +1 -0
  34. package/dist/_chunks/index-DOMrViWi.js +4207 -0
  35. package/dist/_chunks/index-DOMrViWi.js.map +1 -0
  36. package/dist/_chunks/index-DXRtXlZW.mjs +129 -0
  37. package/dist/_chunks/index-DXRtXlZW.mjs.map +1 -0
  38. package/dist/_chunks/index-Df365kgY.js +294 -0
  39. package/dist/_chunks/index-Df365kgY.js.map +1 -0
  40. package/dist/_chunks/{index-VcxUbdMO.mjs → index-Dm_GIRd4.mjs} +35 -30
  41. package/dist/_chunks/index-Dt-mlR1F.mjs +4191 -0
  42. package/dist/_chunks/index-Dt-mlR1F.mjs.map +1 -0
  43. package/dist/_chunks/index-QFbHwlyj.mjs +294 -0
  44. package/dist/_chunks/index-QFbHwlyj.mjs.map +1 -0
  45. package/dist/_chunks/{index-7rox7tGX.mjs → index-QU9SZ_H9.mjs} +93 -52
  46. package/dist/_chunks/{index-Z3qq1ab8.mjs → index-_49Fvwqq.mjs} +47 -36
  47. package/dist/_chunks/{index-DGSjLYNl.mjs → index-aAKsnALd.mjs} +1 -1
  48. package/dist/_chunks/index-g8wz2qoC.js +4206 -0
  49. package/dist/admin/index.js +5 -0
  50. package/dist/admin/index.js.map +1 -0
  51. package/dist/admin/index.mjs +2 -1
  52. package/dist/admin/index.mjs.map +1 -0
  53. package/dist/admin/src/components/modals/NavEdit.d.ts +1 -1
  54. package/dist/admin/src/pages/Navigation/RouteItem.d.ts +1 -0
  55. package/dist/admin/src/pages/Settings/ContentBox.d.ts +5 -0
  56. package/dist/admin/src/pages/Settings/PageWrapper.d.ts +2 -1
  57. package/dist/admin/src/pages/Settings/SettingTitle.d.ts +4 -0
  58. package/dist/admin/src/pages/Settings/index.d.ts +4 -0
  59. package/dist/pluginId.d.ts +2 -1
  60. package/dist/server/index.js +63 -45
  61. package/dist/server/index.js.map +1 -0
  62. package/dist/server/index.mjs +63 -45
  63. package/dist/server/index.mjs.map +1 -0
  64. package/dist/server/src/utils/index.d.ts +6 -0
  65. package/dist/server/src/utils/navItemHandler.d.ts +1 -1
  66. package/dist/server/src/utils/reduceDepthOfOrphanedItems.d.ts +2 -0
  67. package/package.json +1 -1
  68. package/dist/_chunks/PageWrapper-B6nLPFak.mjs +0 -55
  69. package/dist/_chunks/PageWrapper-BMzPDWn4.js +0 -0
  70. package/dist/_chunks/PageWrapper-BMzPDWn4.js.map +0 -0
  71. package/dist/_chunks/de-DYxCPOdb.js +0 -0
  72. package/dist/_chunks/de-DYxCPOdb.js.map +0 -0
  73. package/dist/_chunks/en-Be-athEA.js +0 -0
  74. package/dist/_chunks/en-Be-athEA.js.map +0 -0
  75. package/dist/_chunks/index-Bu-uQ9jA.js +0 -0
  76. package/dist/_chunks/index-Bu-uQ9jA.js.map +0 -0
  77. package/dist/_chunks/index-C53yDU_z.js +0 -0
  78. package/dist/_chunks/index-C53yDU_z.js.map +0 -0
  79. package/dist/_chunks/index-CAz59RSr.js +0 -0
  80. package/dist/_chunks/index-CAz59RSr.js.map +0 -0
  81. package/dist/_chunks/index-DKfUSLPc.js +0 -0
  82. package/dist/_chunks/index-DKfUSLPc.js.map +0 -0
  83. package/dist/_chunks/index-DPMhcaxW.js +0 -0
  84. package/dist/_chunks/index-DPMhcaxW.js.map +0 -0
@@ -0,0 +1,131 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const en = {
4
+ "webatlas.navigation.page.title": "Navigation",
5
+ "webatlas.navigation.page.subtitle.noNavigationSelected": "No navigation selected",
6
+ "webatlas.navigation.page.emptyNavigation": "You have no navigations yet...",
7
+ "webatlas.navigation.page.createNewNavigation": "Create new navigation",
8
+ "webatlas.navigation.page.createNewItem": "Create new item",
9
+ "webatlas.navigation.page.newItemButton": "New Item",
10
+ "webatlas.navigation.page.selectNavigation": "Select Navigation",
11
+ "webatlas.navigation.page.navItem.addChildren": "Add children",
12
+ "webatlas.routes.page.title": "Routes",
13
+ "webatlas.routes.page.subtitle": "Overview of all existing routes",
14
+ "webatlas.routes.page.emptyRoutes": "No routes found",
15
+ "webatlas.routes.page.column.type": "Type",
16
+ "webatlas.routes.page.searchPlaceholder": "Search routes",
17
+ "webatlas.settings.page.general.subtitle": "Configure general settings",
18
+ "webatlas.settings.page.general.webatlasVersion": "Webatlas Version",
19
+ "webatlas.settings.page.general.contentTypes": "Content Types",
20
+ "webatlas.settings.page.general.details": "Details",
21
+ "webatlas.settings.page.enabledContentTypes": "Enabled Content Types",
22
+ "webatlas.settings.page.enabledContentTypes.hint": "Select the content types for which you want to enable URL aliases",
23
+ "webatlas.settings.page.enabledContentTypes.placeholder": "Select content types...",
24
+ "webatlas.settings.page.contentTypeSettings": "Content Type settings",
25
+ "webatlas.settings.page.defaultField": "Default URL Alias field",
26
+ "webatlas.settings.page.defaultField.hint": '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".',
27
+ "webatlas.settings.page.defaultField.error": "Please select a default field",
28
+ "webatlas.settings.page.urlAliasPattern": "URL Alias Pattern",
29
+ "webatlas.settings.page.urlAliasPattern.hint": '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.',
30
+ "webatlas.settings.page.urlAliasPattern.tooltip": "Leading and trailing slashes will be removed. Spaces will be replaced with hyphens. Special characters will be encoded.",
31
+ "webatlas.settings.page.urlAliasPattern.placeholder": "e.g. blog",
32
+ "webatlas.settings.page.navigation.subtitle": "Configure navigation settings",
33
+ "webatlas.settings.page.navigation.navigation": "Navigation",
34
+ "webatlas.settings.page.navigation.maxNavDepth.label": "Max depth of navigation tree",
35
+ "webatlas.modal.navOverview.confirmText": "New navigation",
36
+ "webatlas.modal.navOverview.closeText": "Cancel",
37
+ "webatlas.modal.navOverview.titleText": "Navigation overview",
38
+ "webatlas.modal.navOverview.loadingText": "Creating",
39
+ "webatlas.modal.navModal.internalItem": "Internal item",
40
+ "webatlas.modal.navModal.externalItem": "External item",
41
+ "webatlas.modal.navModal.wrapperItem": "Wrapper item",
42
+ "webatlas.modal.navEdit.confirmText": "Update",
43
+ "webatlas.modal.navEdit.closeText": "Cancel",
44
+ "webatlas.modal.navEdit.titleText": "Edit navigation:",
45
+ "webatlas.modal.navEdit.loadingText": "Updating",
46
+ "webatlas.modal.delete.cancelText": "No, keep",
47
+ "webatlas.modal.delete.confirmText": "Yes, delete",
48
+ "webatlas.modal.delete.message.start": "You are about to delete the following",
49
+ "webatlas.modal.delete.message.navItem": "navigation item",
50
+ "webatlas.modal.delete.message.navigation": "navigation",
51
+ "webatlas.modal.delete.message.end": "This can not be undone. Are you sure?",
52
+ "webatlas.modal.nameField.label": "Name",
53
+ "webatlas.modal.activeField.label": "Active",
54
+ "webatlas.modal.activeField.onLabel": "Yes",
55
+ "webatlas.modal.activeField.offLabel": "No",
56
+ "webatlas.modal.wrapperItem.titleText.create": "Create new wrapper item",
57
+ "webatlas.modal.wrapperItem.titleText.edit": "Edit wrapper item:",
58
+ "webatlas.modal.wrapperItem.loadingText.create": "Adding",
59
+ "webatlas.modal.wrapperItem.loadingText.edit": "Saving",
60
+ "webatlas.modal.wrapperItem.titleField.label": "Title",
61
+ "webatlas.modal.wrapperItem.titleField.placeholder": "e.g. About us",
62
+ "webatlas.modal.internalItem.titleText.create": "Add new navigation item",
63
+ "webatlas.modal.internalItem.loadingText.create": "Creating",
64
+ "webatlas.modal.internalItem.contentType.label": "Content Type",
65
+ "webatlas.modal.internalItem.contentType.placeholder": "Select a content type",
66
+ "webatlas.modal.internalItem.entity.label": "Entity",
67
+ "webatlas.modal.internalItem.entity.placeholder": "Select an entity",
68
+ "webatlas.modal.internalItem.loadingText.edit": "Saving",
69
+ "webatlas.modal.externalItem.titleText.create": "Create new external item",
70
+ "webatlas.modal.externalItem.loadingText.create": "Adding",
71
+ "webatlas.modal.externalItem.titleText.edit": "Edit external route:",
72
+ "webatlas.modal.externalItem.loadingText.edit": "Saving",
73
+ "webatlas.modal.externalItem.routeField.placeholder": "e.g. https://example.com",
74
+ "webatlas.modal.item.titleField.label": "Title",
75
+ "webatlas.modal.item.titleField.placeholder": "e.g. About Us",
76
+ "webatlas.modal.item.routeField.label": "Route",
77
+ "webatlas.modal.item.routeField.placeholder": "e.g. about/",
78
+ "webatlas.components.URLInfo.checking": "Checking if URL is available...",
79
+ "webatlas.components.URLInfo.available": "URL is available",
80
+ "webatlas.components.URLInfo.notAvailable": "URL is not available. Replaced with",
81
+ "webatlas.components.CMEditViewAside.notAllowed.start": "This content type is not allowed for",
82
+ "webatlas.components.CMEditViewAside.notAllowed.end": "If you wish to use it, please contact your administrator",
83
+ "webatlas.components.CMEditViewAside.notConfigured.start": "This content type is not configured for",
84
+ "webatlas.components.CMEditViewAside.notConfigured.middle": "If you wish to use it, please configure it in the",
85
+ "webatlas.components.CMEditViewAside.notConfigured.end": "settings",
86
+ "webatlas.components.CMEditViewAside.alias.urlInput.tooltip": "The following characters are valid: A-Z, a-z, 0-9, /, -, _, $, ., +, !, *, ', (, )",
87
+ "webatlas.components.CMEditViewAside.alias.urlInput.label": "URL",
88
+ "webatlas.components.CMEditViewAside.alias.urlInput.start": "Edit the",
89
+ "webatlas.components.CMEditViewAside.alias.urlInput.end": "field to generate a URL",
90
+ "webatlas.components.CMEditViewAside.alias.overrideCheckbox": "Override automatic URL generation",
91
+ "webatlas.components.CMEditViewAside.alias.uidRoute.label": "UID route",
92
+ "webatlas.components.CMEditViewAside.alias.uidRoute.hint": "Permanent UID route, cannot be changed",
93
+ "webatlas.components.CMEditViewAside.alias.documentIdRoute.label": "Document ID route",
94
+ "webatlas.components.CMEditViewAside.alias.documentIdRoute.hint": "Permanent Document ID route, cannot be changed",
95
+ "webatlas.components.CMEditViewAside.alias.newRouteInfo": "A new URL route will be created upon saving this entry.",
96
+ "webatlas.route.type.internal": "Internal",
97
+ "webatlas.route.type.external": "External",
98
+ "webatlas.route.type.wrapper": "Wrapper",
99
+ "webatlas.link.navigation": "Navigation",
100
+ "webatlas.link.routes": "Routes",
101
+ "webatlas.title": "Title",
102
+ "webatlas.route": "Route",
103
+ "webatlas.actions": "Actions",
104
+ "webatlas.delete": "Delete",
105
+ "webatlas.edit": "Edit",
106
+ "webatlas.add": "Add",
107
+ "webatlas.cancel": "Cancel",
108
+ "webatlas.save": "Save",
109
+ "webatlas.select": "Select",
110
+ "webatlas.manage": "Manage",
111
+ "webatlas.published": "Published",
112
+ "webatlas.draft": "Draft",
113
+ "webatlas.modified": "Modified",
114
+ "webatlas.deleted": "Deleted",
115
+ "webatlas.restore": "Restore",
116
+ "webatlas.loading": "Loading...",
117
+ "webatlas.version": "Version",
118
+ "webatlas.notification.error": "An error occurred",
119
+ "webatlas.notification.settings.saved": "Settings saved successfully",
120
+ "webatlas.notification.routes.fetchFailed": "Failed to fetch routes",
121
+ "webatlas.notification.navigation.saveNavigationFailed": "Error updating navigation item",
122
+ "webatlas.notification.navigation.navigationSaved": "Navigation updated successfully",
123
+ "webatlas.notification.navigation.fetchFailed": "Failed to fetch navigations",
124
+ "webatlas.notification.navigation.notFound": "Navigation not found. Redirected to navigation",
125
+ "webatlas.notification.navigation.creationFailed": "Creation of navigation failed",
126
+ "webatlas.notification.navigation.updateFailed": "Updating navigation failed",
127
+ "webatlas.settings.section.general": "General",
128
+ "webatlas.settings.section.navigation": "Navigation"
129
+ };
130
+ exports.default = en;
131
+ //# sourceMappingURL=en-DrhxIwOr.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"en-DrhxIwOr.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,247 @@
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 icons = require("@strapi/icons");
7
+ const index = require("./index-DOMrViWi.js");
8
+ const admin = require("@strapi/strapi/admin");
9
+ require("@strapi/icons/symbols");
10
+ const FullLoader = require("./FullLoader-Cmsf8xS6.js");
11
+ const reactIntl = require("react-intl");
12
+ const reactRouterDom = require("react-router-dom");
13
+ function getRouteType(route) {
14
+ if (route.wrapper) {
15
+ return "wrapper";
16
+ } else if (!route.internal) {
17
+ return "external";
18
+ } else {
19
+ return "internal";
20
+ }
21
+ }
22
+ function TableHeader({
23
+ sortKey,
24
+ handleSort
25
+ }) {
26
+ const { formatMessage } = reactIntl.useIntl();
27
+ return /* @__PURE__ */ jsxRuntime.jsx(designSystem.Thead, { children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Tr, { children: [
28
+ /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Th, { onClick: () => handleSort("title"), cursor: "pointer", children: [
29
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "sigma", children: formatMessage({
30
+ id: index.getTranslation("title"),
31
+ defaultMessage: "Title"
32
+ }) }),
33
+ sortKey === "title" && /* @__PURE__ */ jsxRuntime.jsx(icons.ChevronDown, {})
34
+ ] }),
35
+ /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Th, { onClick: () => handleSort("fullPath"), cursor: "pointer", children: [
36
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "sigma", children: formatMessage({
37
+ id: index.getTranslation("route"),
38
+ defaultMessage: "Route"
39
+ }) }),
40
+ sortKey === "fullPath" && /* @__PURE__ */ jsxRuntime.jsx(icons.ChevronDown, {})
41
+ ] }),
42
+ /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Th, { onClick: () => handleSort("type"), cursor: "pointer", children: [
43
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "sigma", children: formatMessage({
44
+ id: index.getTranslation("routes.page.column.type"),
45
+ defaultMessage: "Type"
46
+ }) }),
47
+ sortKey === "type" && /* @__PURE__ */ jsxRuntime.jsx(icons.ChevronDown, {})
48
+ ] }),
49
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Th, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.VisuallyHidden, { children: formatMessage({
50
+ id: index.getTranslation("actions"),
51
+ defaultMessage: "Actions"
52
+ }) }) })
53
+ ] }) });
54
+ }
55
+ function TableRow({ route }) {
56
+ const { formatMessage } = reactIntl.useIntl();
57
+ return /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Tr, { children: [
58
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Td, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { textColor: "neutral800", children: route.title }) }),
59
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Td, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { textColor: "neutral800", children: route.fullPath }) }),
60
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Td, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { textColor: "neutral800", children: formatMessage({
61
+ id: index.getTranslation(`route.type.${getRouteType(route)}`),
62
+ defaultMessage: "-"
63
+ }) }) }),
64
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Td, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Flex, { gap: 2, justifyContent: "end", children: route.internal && /* @__PURE__ */ jsxRuntime.jsx(
65
+ designSystem.LinkButton,
66
+ {
67
+ variant: "secondary",
68
+ startIcon: /* @__PURE__ */ jsxRuntime.jsx(icons.Pencil, {}),
69
+ href: `/admin/content-manager/collection-types/${route.relatedContentType}/${route.relatedDocumentId}`,
70
+ children: formatMessage({
71
+ id: index.getTranslation("edit"),
72
+ defaultMessage: "Edit"
73
+ })
74
+ }
75
+ ) }) })
76
+ ] });
77
+ }
78
+ function PageWrapper({ children }) {
79
+ const { formatMessage } = reactIntl.useIntl();
80
+ return /* @__PURE__ */ jsxRuntime.jsxs(admin.Page.Main, { children: [
81
+ /* @__PURE__ */ jsxRuntime.jsx(
82
+ admin.Layouts.Header,
83
+ {
84
+ title: formatMessage({
85
+ id: index.getTranslation("routes.page.title"),
86
+ defaultMessage: "Routes"
87
+ }),
88
+ subtitle: formatMessage({
89
+ id: index.getTranslation("routes.page.subtitle"),
90
+ defaultMessage: "Overview of all existing routes"
91
+ })
92
+ }
93
+ ),
94
+ /* @__PURE__ */ jsxRuntime.jsx(admin.Layouts.Content, { children: /* @__PURE__ */ jsxRuntime.jsx(jsxRuntime.Fragment, { children }) })
95
+ ] });
96
+ }
97
+ function compareBy(field, direction) {
98
+ if (!field) {
99
+ return () => 0;
100
+ }
101
+ if (field === "type") {
102
+ return (a, b) => {
103
+ const typeA = a.internal ? "internal" : "external";
104
+ const typeB = b.internal ? "internal" : "external";
105
+ return direction === "asc" ? typeA.localeCompare(typeB) : typeB.localeCompare(typeA);
106
+ };
107
+ }
108
+ return (a, b) => {
109
+ const aValue = a[field];
110
+ const bValue = b[field];
111
+ if (typeof aValue === "string" && typeof bValue === "string") {
112
+ return direction === "asc" ? aValue.localeCompare(bValue) : bValue.localeCompare(aValue);
113
+ }
114
+ return 0;
115
+ };
116
+ }
117
+ function SearchInput({
118
+ searchQuery,
119
+ handleSearchChange
120
+ }) {
121
+ const { formatMessage } = reactIntl.useIntl();
122
+ return /* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Root, { style: { marginBottom: "16px" }, children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Item, { col: 4, s: 12, children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Box, { width: "100%", children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Root, { children: /* @__PURE__ */ jsxRuntime.jsx(
123
+ designSystem.Field.Input,
124
+ {
125
+ name: "search",
126
+ placeholder: formatMessage({
127
+ id: index.getTranslation("routes.page.searchPlaceholder"),
128
+ defaultMessage: "Search routes"
129
+ }),
130
+ value: searchQuery,
131
+ onChange: handleSearchChange,
132
+ endAction: searchQuery ? /* @__PURE__ */ jsxRuntime.jsx(
133
+ "button",
134
+ {
135
+ type: "button",
136
+ onClick: () => handleSearchChange({ target: { value: "" } }),
137
+ style: { color: "inherit", background: "none", border: "none", cursor: "pointer" },
138
+ "aria-label": "Clear search",
139
+ children: /* @__PURE__ */ jsxRuntime.jsx(icons.Cross, {})
140
+ }
141
+ ) : null
142
+ }
143
+ ) }) }) }) });
144
+ }
145
+ function RouteTable({
146
+ routes,
147
+ sortKey,
148
+ handleSort
149
+ }) {
150
+ const { formatMessage } = reactIntl.useIntl();
151
+ return /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Table, { colCount: 4, rowCount: routes.length, children: [
152
+ /* @__PURE__ */ jsxRuntime.jsx(TableHeader, { sortKey, handleSort }),
153
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Tbody, { children: routes.length > 0 ? routes.map((route) => /* @__PURE__ */ jsxRuntime.jsx(TableRow, { route }, route.id)) : /* @__PURE__ */ jsxRuntime.jsx(designSystem.Tr, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Td, { colSpan: 4, children: /* @__PURE__ */ jsxRuntime.jsx(
154
+ designSystem.EmptyStateLayout,
155
+ {
156
+ content: formatMessage({
157
+ id: index.getTranslation("routes.page.emptyRoutes"),
158
+ defaultMessage: "No routes found"
159
+ }),
160
+ shadow: false
161
+ }
162
+ ) }) }) })
163
+ ] });
164
+ }
165
+ const Routes = () => {
166
+ const { getRoutes } = index.useApi();
167
+ const { formatMessage } = reactIntl.useIntl();
168
+ const { toggleNotification } = admin.useNotification();
169
+ const [allRoutes, setAllRoutes] = React.useState([]);
170
+ const [routes, setRoutes] = React.useState([]);
171
+ const [loading, setLoading] = React.useState(true);
172
+ const [searchParams, setSearchParams] = reactRouterDom.useSearchParams();
173
+ const initialQuery = searchParams.get("search") || "";
174
+ const [searchQuery, setSearchQuery] = React.useState(initialQuery);
175
+ const [sortKey, setSortKey] = React.useState(void 0);
176
+ const [sortDirection, setSortDirection] = React.useState("asc");
177
+ React.useEffect(() => {
178
+ const query = searchQuery.toLowerCase();
179
+ setRoutes(
180
+ allRoutes.filter(
181
+ (route) => JSON.stringify(route.id).toLowerCase().includes(query) || route.title.toLowerCase().includes(query) || route.fullPath.toLowerCase().includes(query) || route.relatedDocumentId.toLowerCase().includes(query) || route.relatedContentType.toLowerCase().includes(query)
182
+ )
183
+ );
184
+ }, [searchQuery, allRoutes]);
185
+ const debouncedSetSearchParams = React.useMemo(
186
+ () => index.debounce((value) => {
187
+ value ? setSearchParams({ search: value }) : setSearchParams({});
188
+ }, 300),
189
+ [setSearchParams]
190
+ );
191
+ const handleSearchChange = (e) => {
192
+ const value = e.target.value;
193
+ setSearchQuery(value);
194
+ debouncedSetSearchParams(value);
195
+ };
196
+ React.useEffect(() => {
197
+ async function fetchRoutes() {
198
+ try {
199
+ const data = await getRoutes();
200
+ setAllRoutes(data);
201
+ setRoutes(data);
202
+ } catch (err) {
203
+ console.error("Failed to fetch routes:", err);
204
+ toggleNotification({
205
+ type: "danger",
206
+ message: formatMessage({
207
+ id: index.getTranslation("notification.routes.fetchFailed"),
208
+ defaultMessage: "Failed to fetch routes"
209
+ })
210
+ });
211
+ } finally {
212
+ setLoading(false);
213
+ }
214
+ }
215
+ fetchRoutes();
216
+ }, []);
217
+ const handleSort = (key) => {
218
+ setSortDirection((prev) => prev === "asc" ? "desc" : "asc");
219
+ setSortKey(key);
220
+ };
221
+ React.useEffect(() => {
222
+ const sortedRoutes = sortKey ? [...routes].sort(compareBy(sortKey, sortDirection)) : routes;
223
+ setRoutes(sortedRoutes);
224
+ }, [sortKey, sortDirection]);
225
+ if (loading) {
226
+ return /* @__PURE__ */ jsxRuntime.jsx(PageWrapper, { children: /* @__PURE__ */ jsxRuntime.jsx(FullLoader.FullLoader, {}) });
227
+ }
228
+ return /* @__PURE__ */ jsxRuntime.jsxs(PageWrapper, { children: [
229
+ /* @__PURE__ */ jsxRuntime.jsx(
230
+ SearchInput,
231
+ {
232
+ handleSearchChange,
233
+ searchQuery
234
+ }
235
+ ),
236
+ /* @__PURE__ */ jsxRuntime.jsx(
237
+ RouteTable,
238
+ {
239
+ routes,
240
+ sortKey,
241
+ handleSort
242
+ }
243
+ )
244
+ ] });
245
+ };
246
+ exports.default = Routes;
247
+ //# sourceMappingURL=index--XAogZgv.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index--XAogZgv.js","sources":["../../admin/src/utils/getRouteType.ts","../../admin/src/pages/Routes/TableHeader.tsx","../../admin/src/pages/Routes/TableRow.tsx","../../admin/src/pages/Routes/PageWrapper.tsx","../../admin/src/pages/Routes/compareBy.ts","../../admin/src/pages/Routes/index.tsx"],"sourcesContent":["import type { Route } from \"../../../types\";\n\nexport default function getRouteType(route: Route): 'internal' | 'external' | 'wrapper' {\n if (route.wrapper) {\n return 'wrapper';\n } else if (!route.internal) {\n return 'external';\n } else {\n return 'internal';\n }\n}","import type { RouteSortKey } from '../../../../types';\nimport { Typography, Thead, Tr, Th, VisuallyHidden } from '@strapi/design-system';\nimport { getTranslation } from '../../utils';\nimport { useIntl } from 'react-intl';\nimport { ChevronDown } from '@strapi/icons';\n\nexport default function TableHeader({\n sortKey,\n handleSort\n}: {\n sortKey: RouteSortKey,\n handleSort: (key: RouteSortKey) => void\n}) {\n const { formatMessage } = useIntl();\n\n return (\n <Thead>\n <Tr>\n <Th onClick={() => handleSort('title')} cursor=\"pointer\">\n <Typography variant=\"sigma\">\n {formatMessage({\n id: getTranslation('title'),\n defaultMessage: 'Title',\n })}\n </Typography>\n {sortKey === 'title' && <ChevronDown />}\n </Th>\n <Th onClick={() => handleSort('fullPath')} cursor=\"pointer\">\n <Typography variant=\"sigma\">\n {formatMessage({\n id: getTranslation('route'),\n defaultMessage: 'Route',\n })}\n </Typography>\n {sortKey === 'fullPath' && <ChevronDown />}\n </Th>\n <Th onClick={() => handleSort('type')} cursor=\"pointer\">\n <Typography variant=\"sigma\">\n {formatMessage({\n id: getTranslation('routes.page.column.type'),\n defaultMessage: 'Type',\n })}\n </Typography>\n {sortKey === 'type' && <ChevronDown />}\n </Th>\n <Th>\n <VisuallyHidden>\n {formatMessage({\n id: getTranslation('actions'),\n defaultMessage: 'Actions',\n })}\n </VisuallyHidden>\n </Th>\n </Tr>\n </Thead>\n )\n}","import type { Route } from '../../../../types';\nimport { Typography, Tr, Td, Flex, LinkButton } from '@strapi/design-system';\nimport { getTranslation, getRouteType } from '../../utils';\nimport { useIntl } from 'react-intl';\nimport { Pencil } from '@strapi/icons';\n\nexport default function TableRow({ route }: { route: Route }) {\n const { formatMessage } = useIntl();\n \n return (\n <Tr>\n <Td>\n <Typography textColor=\"neutral800\">{route.title}</Typography>\n </Td>\n <Td>\n <Typography textColor=\"neutral800\">{route.fullPath}</Typography>\n </Td>\n <Td>\n <Typography textColor=\"neutral800\">\n {formatMessage({\n id: getTranslation(`route.type.${getRouteType(route)}`),\n defaultMessage: '-',\n })}\n </Typography>\n </Td>\n <Td>\n <Flex gap={2} justifyContent=\"end\">\n {route.internal && \n <LinkButton\n variant=\"secondary\"\n startIcon={<Pencil />} \n href={`/admin/content-manager/collection-types/${route.relatedContentType}/${route.relatedDocumentId}`}\n >\n {formatMessage({\n id: getTranslation('edit'),\n defaultMessage: 'Edit',\n })}\n </LinkButton>\n }\n </Flex>\n </Td>\n </Tr>\n )\n}","import { Layouts, Page } from '@strapi/strapi/admin';\nimport { getTranslation } from '../../utils';\nimport { useIntl } from 'react-intl';\n\nexport default function PageWrapper({ children }: { children: React.ReactNode }) {\n const { formatMessage } = useIntl();\n\n return (\n <Page.Main>\n <Layouts.Header\n title={formatMessage({\n id: getTranslation('routes.page.title'),\n defaultMessage: 'Routes',\n })}\n subtitle={formatMessage({\n id: getTranslation('routes.page.subtitle'),\n defaultMessage: 'Overview of all existing routes',\n })}\n />\n <Layouts.Content>\n <>\n {children}\n </>\n </Layouts.Content>\n </Page.Main>\n );\n}","import type { Route, RouteSortKey } from '../../../../types';\n\nexport default function compareBy(field: RouteSortKey, direction: 'asc' | 'desc') {\n if (!field) {\n return () => 0;\n }\n if (field === 'type') {\n return (a: Route, b: Route) => {\n const typeA = a.internal ? 'internal' : 'external';\n const typeB = b.internal ? 'internal' : 'external';\n return direction === 'asc'\n ? typeA.localeCompare(typeB)\n : typeB.localeCompare(typeA);\n };\n }\n return (a: Route, b: Route) => {\n const aValue = a[field];\n const bValue = b[field];\n if (typeof aValue === 'string' && typeof bValue === 'string') {\n return direction === 'asc'\n ? aValue.localeCompare(bValue)\n : bValue.localeCompare(aValue);\n }\n return 0;\n };\n}","/*\n *\n * Routes\n * This file contains the Routes page of the Webatlas plugin for Strapi.\n * It displays a table of all existing routes with their details and allows editing.\n *\n*/\n\nimport type { Route, RouteSortKey } from '../../../../types';\nimport { useState, useEffect } from 'react';\nimport { Table, Tbody, Box, Grid, Field, EmptyStateLayout, Tr, Td } from '@strapi/design-system';\nimport { Cross } from '@strapi/icons';\nimport { useApi } from '../../hooks';\nimport { FullLoader } from '../../components/UI';\nimport { getTranslation } from '../../utils';\nimport { useIntl } from 'react-intl';\nimport TableHeader from './TableHeader';\nimport TableRow from './TableRow';\nimport { useNotification } from '@strapi/strapi/admin'\nimport PageWrapper from './PageWrapper';\nimport { useSearchParams } from 'react-router-dom';\nimport debounce from '../../utils/debounce';\nimport { useMemo } from 'react';\nimport compareBy from './compareBy';\n\nfunction SearchInput({\n searchQuery,\n handleSearchChange\n}: {\n searchQuery: string;\n handleSearchChange: (e: React.ChangeEvent<HTMLInputElement>) => void;\n}) {\n\n const { formatMessage } = useIntl();\n\n return (\n <Grid.Root style={{ marginBottom: '16px' }}>\n <Grid.Item col={4} s={12}>\n <Box width=\"100%\">\n <Field.Root>\n <Field.Input\n name=\"search\"\n placeholder={formatMessage({\n id: getTranslation('routes.page.searchPlaceholder'),\n defaultMessage: 'Search routes',\n })}\n value={searchQuery}\n onChange={handleSearchChange}\n endAction={\n searchQuery ? (\n <button\n type=\"button\"\n onClick={() => handleSearchChange({ target: { value: '' } } as React.ChangeEvent<HTMLInputElement>)}\n style={{ color: 'inherit', background: 'none', border: 'none', cursor: 'pointer' }}\n aria-label=\"Clear search\"\n >\n <Cross />\n </button>\n ) : null\n }\n />\n </Field.Root>\n </Box>\n </Grid.Item>\n </Grid.Root>\n );\n}\n\nfunction RouteTable({\n routes, \n sortKey, \n handleSort\n}: { \n routes: Route[], \n sortKey: RouteSortKey, \n handleSort: (key: RouteSortKey) => void\n}) {\n \n const { formatMessage } = useIntl();\n\n return (\n <Table colCount={4} rowCount={routes.length}>\n <TableHeader sortKey={sortKey} handleSort={handleSort} />\n <Tbody>\n {routes.length > 0 ? routes.map((route: Route) => (\n <TableRow key={route.id} route={route} />\n )) : \n <Tr>\n <Td colSpan={4}>\n <EmptyStateLayout \n content={\n formatMessage({\n id: getTranslation('routes.page.emptyRoutes'),\n defaultMessage: 'No routes found',\n })\n } \n shadow={false}\n />\n </Td>\n </Tr>\n }\n </Tbody>\n </Table>\n )\n}\n\nconst Routes = () => {\n const { getRoutes } = useApi();\n const { formatMessage } = useIntl();\n const { toggleNotification } = useNotification();\n \n const [allRoutes, setAllRoutes] = useState<Route[]>([]);\n const [routes, setRoutes] = useState<Route[]>([]);\n const [loading, setLoading] = useState(true);\n const [searchParams, setSearchParams] = useSearchParams();\n const initialQuery = searchParams.get('search') || '';\n const [searchQuery, setSearchQuery] = useState(initialQuery);\n const [sortKey, setSortKey] = useState<RouteSortKey>(undefined);\n const [sortDirection, setSortDirection] = useState<'asc' | 'desc'>('asc');\n\n useEffect(() => {\n const query = searchQuery.toLowerCase()\n setRoutes(\n allRoutes.filter((route) =>\n JSON.stringify(route.id).toLowerCase().includes(query) ||\n route.title.toLowerCase().includes(query) ||\n route.fullPath.toLowerCase().includes(query) ||\n route.relatedDocumentId.toLowerCase().includes(query) ||\n route.relatedContentType.toLowerCase().includes(query)\n )\n )\n }, [searchQuery, allRoutes]);\n\n const debouncedSetSearchParams = useMemo(() =>\n debounce((value: string) => {\n value\n ? setSearchParams({ search: value })\n : setSearchParams({});\n }, 300),\n [setSearchParams]);\n\n const handleSearchChange = (e: React.ChangeEvent<HTMLInputElement>) => {\n const value = e.target.value\n setSearchQuery(value);\n debouncedSetSearchParams(value);\n }\n\n useEffect(() => {\n async function fetchRoutes() {\n try {\n const data = await getRoutes();\n setAllRoutes(data);\n setRoutes(data);\n } catch (err) {\n console.error('Failed to fetch routes:', err);\n toggleNotification({\n type: 'danger',\n message: formatMessage({\n id: getTranslation('notification.routes.fetchFailed'),\n defaultMessage: 'Failed to fetch routes',\n }),\n });\n } finally {\n setLoading(false);\n }\n }\n fetchRoutes();\n }, [])\n\n const handleSort = (key: RouteSortKey) => {\n setSortDirection(prev => (prev === 'asc' ? 'desc' : 'asc'));\n setSortKey(key);\n };\n\n useEffect(() => {\n const sortedRoutes = sortKey\n ? [...routes].sort(compareBy(sortKey, sortDirection))\n : routes; \n setRoutes(sortedRoutes);\n }, [sortKey, sortDirection]);\n\n if (loading) {\n return <PageWrapper>\n <FullLoader />\n </PageWrapper>\n }\n\n return (\n <PageWrapper>\n <SearchInput\n handleSearchChange={handleSearchChange}\n searchQuery={searchQuery}\n />\n <RouteTable\n routes={routes} \n sortKey={sortKey}\n handleSort={handleSort}\n />\n </PageWrapper>\n );\n};\n\nexport default Routes;"],"names":["useIntl","jsx","Thead","jsxs","Tr","Th","Typography","getTranslation","ChevronDown","VisuallyHidden","Td","Flex","LinkButton","Pencil","Page","Layouts","Fragment","Grid","Box","Field","Cross","Table","Tbody","EmptyStateLayout","useApi","useNotification","useState","useSearchParams","useEffect","useMemo","debounce","FullLoader"],"mappings":"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"}
@@ -0,0 +1,128 @@
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-g8wz2qoC.js");
8
+ const reactIntl = require("react-intl");
9
+ require("@strapi/icons/symbols");
10
+ const FullLoader = require("./FullLoader-Cmsf8xS6.js");
11
+ const SettingTitle = require("./SettingTitle-D5oNwpzC.js");
12
+ function reducer(newConfig, action) {
13
+ switch (action.type) {
14
+ case "SET_MAX_DEPTH":
15
+ if (!newConfig) return null;
16
+ return {
17
+ ...newConfig,
18
+ navigation: { ...newConfig.navigation, maxDepth: action.payload },
19
+ selectedContentTypes: newConfig.selectedContentTypes || []
20
+ };
21
+ case "SET_CONFIG":
22
+ return action.payload;
23
+ default:
24
+ throw new Error();
25
+ }
26
+ }
27
+ const Settings = () => {
28
+ const { config: fetchedConfig, setConfig, loading, fetchError } = index.usePluginConfig();
29
+ const [config, dispatch] = React.useReducer(reducer, fetchedConfig);
30
+ const { toggleNotification } = admin.useNotification();
31
+ const { formatMessage } = reactIntl.useIntl();
32
+ const [isSaving, setIsSaving] = React.useState(false);
33
+ const initialConfig = React.useRef(fetchedConfig);
34
+ React.useEffect(() => {
35
+ initialConfig.current = fetchedConfig;
36
+ if (fetchedConfig)
37
+ dispatch({ type: "SET_CONFIG", payload: fetchedConfig });
38
+ }, [fetchedConfig]);
39
+ React.useEffect(() => {
40
+ if (fetchError) {
41
+ toggleNotification({
42
+ type: "danger",
43
+ message: formatMessage({
44
+ id: index.getTranslation("notification.error"),
45
+ defaultMessage: "An error occurred"
46
+ }) + ": " + fetchError
47
+ });
48
+ }
49
+ }, [fetchError, toggleNotification, formatMessage]);
50
+ async function save() {
51
+ if (!config) return;
52
+ setIsSaving(true);
53
+ try {
54
+ await setConfig({ navigation: config.navigation });
55
+ initialConfig.current = config;
56
+ toggleNotification({
57
+ type: "success",
58
+ message: formatMessage({
59
+ id: index.getTranslation("notification.settings.saved"),
60
+ defaultMessage: "Settings saved successfully"
61
+ })
62
+ });
63
+ setIsSaving(false);
64
+ } catch (err) {
65
+ setIsSaving(false);
66
+ toggleNotification({
67
+ type: "danger",
68
+ message: formatMessage({
69
+ id: index.getTranslation("notification.error"),
70
+ defaultMessage: "An error occurred"
71
+ }) + ": " + err
72
+ });
73
+ console.error(err);
74
+ }
75
+ }
76
+ if (loading) {
77
+ return /* @__PURE__ */ jsxRuntime.jsx(
78
+ SettingTitle.PageWrapper,
79
+ {
80
+ isSaving,
81
+ subtitle: formatMessage({
82
+ id: index.getTranslation("loading"),
83
+ defaultMessage: "Loading..."
84
+ }),
85
+ disabledCondition: true,
86
+ children: /* @__PURE__ */ jsxRuntime.jsx(FullLoader.FullLoader, { height: 200 })
87
+ }
88
+ );
89
+ }
90
+ return /* @__PURE__ */ jsxRuntime.jsx(
91
+ SettingTitle.PageWrapper,
92
+ {
93
+ save,
94
+ isSaving,
95
+ subtitle: formatMessage({
96
+ id: index.getTranslation("settings.page.navigation.subtitle"),
97
+ defaultMessage: "Configure navigation settings"
98
+ }),
99
+ disabledCondition: JSON.stringify(config) === JSON.stringify(initialConfig.current),
100
+ children: /* @__PURE__ */ jsxRuntime.jsx(SettingTitle.ContentBox, { title: formatMessage({
101
+ id: index.getTranslation("settings.page.navigation.navigation"),
102
+ defaultMessage: "Navigation"
103
+ }), children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Field.Root, { name: "maxNavDepth", children: [
104
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { children: /* @__PURE__ */ jsxRuntime.jsx(SettingTitle.SettingTitle, { children: formatMessage({
105
+ id: index.getTranslation("settings.page.navigation.maxNavDepth.label"),
106
+ defaultMessage: "Max depth of navigation tree"
107
+ }) }) }),
108
+ /* @__PURE__ */ jsxRuntime.jsx(
109
+ designSystem.Field.Input,
110
+ {
111
+ id: "maxNavDepth",
112
+ type: "number",
113
+ min: 0,
114
+ step: 1,
115
+ value: config?.navigation?.maxDepth !== void 0 ? config.navigation.maxDepth + 1 : "",
116
+ onChange: (e) => dispatch({ type: "SET_MAX_DEPTH", payload: Number(e.target.value) - 1 }),
117
+ onBlur: (e) => {
118
+ if (e.target.value === "") return;
119
+ dispatch({ type: "SET_MAX_DEPTH", payload: Number(e.target.value) - 1 });
120
+ }
121
+ }
122
+ ),
123
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Hint, {})
124
+ ] }) })
125
+ }
126
+ );
127
+ };
128
+ exports.default = Settings;