@mattisvensson/strapi-plugin-webatlas 0.4.0 → 0.5.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 (55) hide show
  1. package/dist/_chunks/EmptyBox-BM4IscSk.mjs +1 -0
  2. package/dist/_chunks/EmptyBox-BM4IscSk.mjs.map +1 -0
  3. package/dist/_chunks/EmptyBox-T8t29l25.js +1 -0
  4. package/dist/_chunks/EmptyBox-T8t29l25.js.map +1 -0
  5. package/dist/_chunks/FullLoader-Cmsf8xS6.js +1 -0
  6. package/dist/_chunks/FullLoader-Cmsf8xS6.js.map +1 -0
  7. package/dist/_chunks/FullLoader-CrPED_dY.mjs +1 -0
  8. package/dist/_chunks/FullLoader-CrPED_dY.mjs.map +1 -0
  9. package/dist/_chunks/{de-Dn24NwJf.mjs → de-BkirTac9.mjs} +4 -1
  10. package/dist/_chunks/de-BkirTac9.mjs.map +1 -0
  11. package/dist/_chunks/{de-RiCps8UH.js → de-D8LMOTFI.js} +4 -1
  12. package/dist/_chunks/de-D8LMOTFI.js.map +1 -0
  13. package/dist/_chunks/{en-JLW5S3ZC.js → en-BdfmJUs8.js} +4 -1
  14. package/dist/_chunks/en-BdfmJUs8.js.map +1 -0
  15. package/dist/_chunks/{en-D9Lxaugc.mjs → en-DYbDta3m.mjs} +4 -1
  16. package/dist/_chunks/en-DYbDta3m.mjs.map +1 -0
  17. package/dist/_chunks/index-BAN8PGGJ.js +282 -0
  18. package/dist/_chunks/index-BAN8PGGJ.js.map +1 -0
  19. package/dist/_chunks/{index-CKHmlZdc.js → index-BOvKFOKk.js} +1665 -651
  20. package/dist/_chunks/{index-BpvDMe8t.js → index-BfgRvDzx.js} +1 -1
  21. package/dist/_chunks/index-BxnHHgGC.js +12163 -0
  22. package/dist/_chunks/index-BxnHHgGC.js.map +1 -0
  23. package/dist/_chunks/index-C5ejmUpN.mjs +12163 -0
  24. package/dist/_chunks/index-C5ejmUpN.mjs.map +1 -0
  25. package/dist/_chunks/index-CEt9P4TS.mjs +127 -0
  26. package/dist/_chunks/index-CEt9P4TS.mjs.map +1 -0
  27. package/dist/_chunks/{index-C1rj8TbT.js → index-CJNR2c7_.js} +1 -1
  28. package/dist/_chunks/{index-ChDbwEb-.js → index-CJtLrSxU.js} +6 -6
  29. package/dist/_chunks/{index-DJ-Du5aY.mjs → index-CNfpGKSw.mjs} +1666 -652
  30. package/dist/_chunks/index-Ciae_OgQ.js +4177 -0
  31. package/dist/_chunks/index-Ciae_OgQ.js.map +1 -0
  32. package/dist/_chunks/{index-DUxYbDKG.mjs → index-Ctq2vsD5.mjs} +6 -6
  33. package/dist/_chunks/index-CuJP8Fy7.mjs +4161 -0
  34. package/dist/_chunks/index-CuJP8Fy7.mjs.map +1 -0
  35. package/dist/_chunks/index-D4tWVnt1.js +127 -0
  36. package/dist/_chunks/index-D4tWVnt1.js.map +1 -0
  37. package/dist/_chunks/{index-Cce7AGi-.mjs → index-DTz7wDR7.mjs} +1 -1
  38. package/dist/_chunks/index-DtFIVZxq.mjs +282 -0
  39. package/dist/_chunks/index-DtFIVZxq.mjs.map +1 -0
  40. package/dist/_chunks/{index-B3JakJZB.mjs → index-LAGFB7iO.mjs} +1 -1
  41. package/dist/admin/index.js +2 -1
  42. package/dist/admin/index.js.map +1 -0
  43. package/dist/admin/index.mjs +2 -1
  44. package/dist/admin/index.mjs.map +1 -0
  45. package/dist/admin/src/hooks/useApi.d.ts +1 -1
  46. package/dist/admin/src/pages/Navigation/Page.d.ts +2 -0
  47. package/dist/admin/src/pages/Navigation/index.d.ts +2 -2
  48. package/dist/server/index.js +13 -1
  49. package/dist/server/index.js.map +1 -0
  50. package/dist/server/index.mjs +13 -1
  51. package/dist/server/index.mjs.map +1 -0
  52. package/dist/server/src/index.d.ts +1 -1
  53. package/dist/server/src/services/admin.d.ts +1 -1
  54. package/dist/server/src/services/index.d.ts +1 -1
  55. package/package.json +1 -1
@@ -0,0 +1,127 @@
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 index = require("./index-Ciae_OgQ.js");
7
+ const admin = require("@strapi/strapi/admin");
8
+ const FullLoader = require("./FullLoader-Cmsf8xS6.js");
9
+ const EmptyBox = require("./EmptyBox-T8t29l25.js");
10
+ const reactIntl = require("react-intl");
11
+ const icons = require("@strapi/icons");
12
+ function getRouteType(route) {
13
+ if (route.wrapper) {
14
+ return "wrapper";
15
+ } else if (!route.internal) {
16
+ return "external";
17
+ } else {
18
+ return "internal";
19
+ }
20
+ }
21
+ function TableHeader() {
22
+ const { formatMessage } = reactIntl.useIntl();
23
+ return /* @__PURE__ */ jsxRuntime.jsx(designSystem.Thead, { children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Tr, { children: [
24
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Th, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "sigma", children: "ID" }) }),
25
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Th, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "sigma", children: formatMessage({
26
+ id: index.getTranslation("title"),
27
+ defaultMessage: "Title"
28
+ }) }) }),
29
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Th, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "sigma", children: formatMessage({
30
+ id: index.getTranslation("route"),
31
+ defaultMessage: "Route"
32
+ }) }) }),
33
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Th, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "sigma", children: formatMessage({
34
+ id: index.getTranslation("routes.page.column.type"),
35
+ defaultMessage: "Type"
36
+ }) }) }),
37
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Th, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.VisuallyHidden, { children: formatMessage({
38
+ id: index.getTranslation("actions"),
39
+ defaultMessage: "Actions"
40
+ }) }) })
41
+ ] }) });
42
+ }
43
+ function TableRow({ route }) {
44
+ const { formatMessage } = reactIntl.useIntl();
45
+ return /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Tr, { children: [
46
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Td, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { textColor: "neutral800", children: route.id }) }),
47
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Td, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { textColor: "neutral800", children: route.title }) }),
48
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Td, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { textColor: "neutral800", children: route.fullPath }) }),
49
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Td, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { textColor: "neutral800", children: formatMessage({
50
+ id: index.getTranslation(`route.type.${getRouteType(route)}`),
51
+ defaultMessage: "-"
52
+ }) }) }),
53
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Td, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Flex, { gap: 2, justifyContent: "end", children: route.internal && /* @__PURE__ */ jsxRuntime.jsx(
54
+ designSystem.LinkButton,
55
+ {
56
+ variant: "secondary",
57
+ startIcon: /* @__PURE__ */ jsxRuntime.jsx(icons.Pencil, {}),
58
+ href: `/admin/content-manager/collection-types/${route.relatedContentType}/${route.relatedDocumentId}`,
59
+ children: formatMessage({
60
+ id: index.getTranslation("edit"),
61
+ defaultMessage: "Edit"
62
+ })
63
+ }
64
+ ) }) })
65
+ ] });
66
+ }
67
+ function PageWrapper({ children }) {
68
+ const { formatMessage } = reactIntl.useIntl();
69
+ return /* @__PURE__ */ jsxRuntime.jsxs(admin.Page.Main, { children: [
70
+ /* @__PURE__ */ jsxRuntime.jsx(
71
+ admin.Layouts.Header,
72
+ {
73
+ title: formatMessage({
74
+ id: index.getTranslation("routes.page.title"),
75
+ defaultMessage: "Routes"
76
+ }),
77
+ subtitle: formatMessage({
78
+ id: index.getTranslation("routes.page.subtitle"),
79
+ defaultMessage: "Overview of all existing routes"
80
+ })
81
+ }
82
+ ),
83
+ /* @__PURE__ */ jsxRuntime.jsx(admin.Layouts.Content, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Box, { children }) })
84
+ ] });
85
+ }
86
+ const Routes = () => {
87
+ const { getRoutes } = index.useApi();
88
+ const { formatMessage } = reactIntl.useIntl();
89
+ const { toggleNotification } = admin.useNotification();
90
+ const [routes, setRoutes] = React.useState([]);
91
+ const [loading, setLoading] = React.useState(true);
92
+ React.useEffect(() => {
93
+ async function fetchRoutes() {
94
+ try {
95
+ const data = await getRoutes();
96
+ setRoutes(data);
97
+ } catch (err) {
98
+ console.error("Failed to fetch routes:", err);
99
+ toggleNotification({
100
+ type: "danger",
101
+ message: formatMessage({
102
+ id: index.getTranslation("notification.routes.fetchFailed"),
103
+ defaultMessage: "Failed to fetch routes"
104
+ })
105
+ });
106
+ } finally {
107
+ setLoading(false);
108
+ }
109
+ }
110
+ fetchRoutes();
111
+ }, []);
112
+ if (loading) {
113
+ return /* @__PURE__ */ jsxRuntime.jsx(PageWrapper, { children: /* @__PURE__ */ jsxRuntime.jsx(FullLoader.FullLoader, {}) });
114
+ }
115
+ if (routes.length === 0) {
116
+ return /* @__PURE__ */ jsxRuntime.jsx(PageWrapper, { children: /* @__PURE__ */ jsxRuntime.jsx(FullLoader.Center, { height: 400, children: /* @__PURE__ */ jsxRuntime.jsx(EmptyBox.EmptyBox, { msg: formatMessage({
117
+ id: index.getTranslation("routes.page.emptyRoutes"),
118
+ defaultMessage: "No routes found"
119
+ }) }) }) });
120
+ }
121
+ return /* @__PURE__ */ jsxRuntime.jsx(PageWrapper, { children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Table, { colCount: 4, rowCount: routes.length, children: [
122
+ /* @__PURE__ */ jsxRuntime.jsx(TableHeader, {}),
123
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Tbody, { children: routes.map((route) => /* @__PURE__ */ jsxRuntime.jsx(TableRow, { route }, route.id)) })
124
+ ] }) });
125
+ };
126
+ exports.default = Routes;
127
+ //# sourceMappingURL=index-D4tWVnt1.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-D4tWVnt1.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/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 { Typography, Thead, Tr, Th, VisuallyHidden } from '@strapi/design-system';\nimport { getTranslation } from '../../utils';\nimport { useIntl } from 'react-intl';\n\nexport default function TableHeader() {\n const { formatMessage } = useIntl();\n\n return (\n <Thead>\n <Tr>\n <Th>\n <Typography variant=\"sigma\">ID</Typography>\n </Th>\n <Th>\n <Typography variant=\"sigma\">\n {formatMessage({\n id: getTranslation('title'),\n defaultMessage: 'Title',\n })}\n </Typography>\n </Th>\n <Th>\n <Typography variant=\"sigma\">\n {formatMessage({\n id: getTranslation('route'),\n defaultMessage: 'Route',\n })}\n </Typography>\n </Th>\n <Th>\n <Typography variant=\"sigma\">\n {formatMessage({\n id: getTranslation('routes.page.column.type'),\n defaultMessage: 'Type',\n })}\n </Typography>\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.id}</Typography>\n </Td>\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 { Box } from '@strapi/design-system';\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 <Box>\n {children}\n </Box>\n </Layouts.Content>\n </Page.Main>\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 } from '../../../../types';\nimport { useState, useEffect } from 'react';\nimport { Table, Tbody } from '@strapi/design-system';\nimport { useApi } from '../../hooks';\nimport { EmptyBox, Center, 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';\n\nconst Routes = () => {\n const { getRoutes } = useApi();\n const { formatMessage } = useIntl();\n const { toggleNotification } = useNotification();\n \n const [routes, setRoutes] = useState<Route[]>([]);\n const [loading, setLoading] = useState(true);\n\n useEffect(() => {\n async function fetchRoutes() {\n try {\n const data = await getRoutes();\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 if (loading) {\n return <PageWrapper>\n <FullLoader />\n </PageWrapper>\n }\n\n if (routes.length === 0) {\n return <PageWrapper>\n <Center height={400}>\n <EmptyBox msg={formatMessage({\n id: getTranslation('routes.page.emptyRoutes'),\n defaultMessage: 'No routes found',\n })} />\n </Center>\n </PageWrapper>;\n }\n return (\n <PageWrapper>\n <Table colCount={4} rowCount={routes.length}>\n <TableHeader />\n <Tbody>\n {routes.map((route: Route) => (\n <TableRow key={route.id} route={route} />\n ))}\n </Tbody>\n </Table>\n </PageWrapper>\n );\n};\n\nexport default Routes;"],"names":["useIntl","jsx","Thead","jsxs","Tr","Th","Typography","getTranslation","VisuallyHidden","Td","Flex","LinkButton","Pencil","Page","Layouts","Box","useApi","useNotification","useState","useEffect","FullLoader","Center","EmptyBox","Table","Tbody"],"mappings":"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"}
@@ -2,7 +2,7 @@ import { jsxs, jsx } from "react/jsx-runtime";
2
2
  import { useReducer, useState, useEffect } from "react";
3
3
  import { Button, Box, Accordion, Field, SingleSelect, SingleSelectOption, MultiSelect, MultiSelectOption } from "@strapi/design-system";
4
4
  import { Page, Layouts, useNotification } from "@strapi/strapi/admin";
5
- import { P as PLUGIN_NAME, g as getTranslation, T as Tooltip, b as usePluginConfig, c as useAllContentTypes, t as transformToUrl } from "./index-DUxYbDKG.mjs";
5
+ import { P as PLUGIN_NAME, g as getTranslation, T as Tooltip, b as usePluginConfig, c as useAllContentTypes, t as transformToUrl } from "./index-Ctq2vsD5.mjs";
6
6
  import { useIntl } from "react-intl";
7
7
  import "@strapi/icons/symbols";
8
8
  import { F as FullLoader } from "./FullLoader-CrPED_dY.mjs";
@@ -0,0 +1,282 @@
1
+ import { jsxs, jsx } from "react/jsx-runtime";
2
+ import { useReducer, useState, useEffect } from "react";
3
+ import { Button, Box, Accordion, Field, SingleSelect, SingleSelectOption, MultiSelect, MultiSelectOption } from "@strapi/design-system";
4
+ import { Page, Layouts, useNotification } from "@strapi/strapi/admin";
5
+ import { P as PLUGIN_NAME, g as getTranslation, T as Tooltip, b as usePluginConfig, c as useAllContentTypes, t as transformToUrl } from "./index-CuJP8Fy7.mjs";
6
+ import { useIntl } from "react-intl";
7
+ import "@strapi/icons/symbols";
8
+ import { F as FullLoader } from "./FullLoader-CrPED_dY.mjs";
9
+ function PageWrapper({
10
+ settingsState,
11
+ initialState,
12
+ save,
13
+ isSaving,
14
+ children
15
+ }) {
16
+ const { formatMessage } = useIntl();
17
+ return /* @__PURE__ */ jsxs(Page.Main, { children: [
18
+ /* @__PURE__ */ jsx(
19
+ Layouts.Header,
20
+ {
21
+ title: PLUGIN_NAME,
22
+ subtitle: formatMessage({
23
+ id: getTranslation("settings.page.subtitle"),
24
+ defaultMessage: "Settings"
25
+ }),
26
+ primaryAction: settingsState && initialState && save && /* @__PURE__ */ jsx(
27
+ Button,
28
+ {
29
+ type: "submit",
30
+ onClick: () => save(),
31
+ loading: isSaving,
32
+ disabled: JSON.stringify(settingsState) === JSON.stringify(initialState) || settingsState.selectedContentTypes.find((cta) => !cta.default) !== void 0 || isSaving,
33
+ children: formatMessage({
34
+ id: getTranslation("save"),
35
+ defaultMessage: "Save"
36
+ })
37
+ }
38
+ )
39
+ }
40
+ ),
41
+ /* @__PURE__ */ jsx(Layouts.Content, { children: /* @__PURE__ */ jsx(
42
+ Box,
43
+ {
44
+ background: "neutral0",
45
+ borderColor: "neutral150",
46
+ hasRadius: true,
47
+ paddingBottom: 4,
48
+ paddingLeft: 4,
49
+ paddingRight: 4,
50
+ paddingTop: 6,
51
+ shadow: "tableShadow",
52
+ children
53
+ }
54
+ ) })
55
+ ] });
56
+ }
57
+ function ContentTypeAccordion({
58
+ contentType,
59
+ contentTypeSettings,
60
+ dispatch
61
+ }) {
62
+ const { formatMessage } = useIntl();
63
+ if (!contentType) return null;
64
+ return /* @__PURE__ */ jsx(
65
+ Box,
66
+ {
67
+ borderColor: !contentTypeSettings.default && "danger500",
68
+ children: /* @__PURE__ */ jsxs(Accordion.Item, { value: contentType.uid, size: "S", children: [
69
+ /* @__PURE__ */ jsx(Accordion.Header, { children: /* @__PURE__ */ jsx(Accordion.Trigger, { children: contentType?.info.displayName }) }),
70
+ /* @__PURE__ */ jsx(Accordion.Content, { children: /* @__PURE__ */ jsxs(Box, { padding: 3, children: [
71
+ /* @__PURE__ */ jsxs(
72
+ Field.Root,
73
+ {
74
+ name: "selectedContentTypes",
75
+ hint: formatMessage({
76
+ id: getTranslation("settings.page.defaultField.hint"),
77
+ 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".'
78
+ }),
79
+ error: !contentTypeSettings.default && formatMessage({
80
+ id: getTranslation("settings.page.defaultField.error"),
81
+ defaultMessage: "Please select a default field"
82
+ }),
83
+ required: true,
84
+ children: [
85
+ /* @__PURE__ */ jsx(Field.Label, { children: formatMessage({
86
+ id: getTranslation("settings.page.defaultField"),
87
+ defaultMessage: "Default URL Alias field"
88
+ }) }),
89
+ /* @__PURE__ */ jsx(
90
+ SingleSelect,
91
+ {
92
+ name: `defaultField-${contentType.uid}`,
93
+ onClear: () => dispatch({ type: "SET_DEFAULT_FIELD", payload: { ctUid: contentType.uid, field: "" } }),
94
+ value: contentTypeSettings?.default || "",
95
+ onChange: (value) => dispatch({ type: "SET_DEFAULT_FIELD", payload: { ctUid: contentType.uid, field: value } }),
96
+ children: Object.entries(contentType.attributes).map(([key], index) => {
97
+ if (key === "id" || key === "documentId" || key === "createdAt" || key === "updatedAt" || key === "createdBy" || key === "updatedBy" || key === "webatlas_path" || key === "webatlas_override") return null;
98
+ return /* @__PURE__ */ jsx(SingleSelectOption, { value: key, children: key }, index);
99
+ })
100
+ }
101
+ ),
102
+ /* @__PURE__ */ jsx(Field.Hint, {})
103
+ ]
104
+ }
105
+ ),
106
+ /* @__PURE__ */ jsx(Box, { paddingTop: 4, children: /* @__PURE__ */ jsxs(
107
+ Field.Root,
108
+ {
109
+ name: "urlAliasPattern",
110
+ hint: formatMessage({
111
+ id: getTranslation("settings.page.urlAliasPattern.hint"),
112
+ 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.'
113
+ }),
114
+ children: [
115
+ /* @__PURE__ */ jsxs(Field.Label, { children: [
116
+ formatMessage({
117
+ id: getTranslation("settings.page.urlAliasPattern"),
118
+ defaultMessage: "URL Alias Pattern"
119
+ }),
120
+ /* @__PURE__ */ jsx(Tooltip, { description: formatMessage({
121
+ id: getTranslation("settings.page.urlAliasPattern.tooltip"),
122
+ defaultMessage: "Leading and trailing slashes will be removed. Spaces will be replaced with hyphens. Special characters will be encoded."
123
+ }) })
124
+ ] }),
125
+ /* @__PURE__ */ jsx(
126
+ Field.Input,
127
+ {
128
+ value: contentTypeSettings.pattern,
129
+ onChange: (e) => dispatch({ type: "SET_PATTERN", payload: { ctUid: contentType.uid, pattern: e.target.value } }),
130
+ disabled: !contentTypeSettings.default,
131
+ type: "text",
132
+ placeholder: formatMessage({
133
+ id: getTranslation("settings.page.urlAliasPattern.placeholder"),
134
+ defaultMessage: "e.g. blog"
135
+ })
136
+ }
137
+ ),
138
+ /* @__PURE__ */ jsx(Field.Hint, {})
139
+ ]
140
+ }
141
+ ) })
142
+ ] }) })
143
+ ] }, contentType.uid)
144
+ },
145
+ contentType.uid
146
+ );
147
+ }
148
+ function reducer(settingsState, action) {
149
+ let updatedContentTypes;
150
+ switch (action.type) {
151
+ case "SET_SELECTED_CONTENT_TYPES":
152
+ updatedContentTypes = action.payload.map((ct) => {
153
+ return settingsState.selectedContentTypes.find((cta) => cta.uid === ct.uid) || ct;
154
+ });
155
+ return { ...settingsState, selectedContentTypes: updatedContentTypes };
156
+ case "SET_DEFAULT_FIELD":
157
+ updatedContentTypes = settingsState.selectedContentTypes.map(
158
+ (ct) => ct.uid === action.payload.ctUid ? { ...ct, default: action.payload.field } : ct
159
+ );
160
+ return { ...settingsState, selectedContentTypes: updatedContentTypes };
161
+ case "SET_PATTERN":
162
+ updatedContentTypes = settingsState.selectedContentTypes.map(
163
+ (ct) => ct.uid === action.payload.ctUid ? { ...ct, pattern: transformToUrl(action.payload.pattern) } : ct
164
+ );
165
+ return { ...settingsState, selectedContentTypes: updatedContentTypes };
166
+ default:
167
+ throw new Error();
168
+ }
169
+ }
170
+ const Settings = () => {
171
+ const { config, setConfig, loading, fetchError } = usePluginConfig();
172
+ const [settingsState, dispatch] = useReducer(reducer, config || { selectedContentTypes: [] });
173
+ const { contentTypes: allContentTypesData } = useAllContentTypes();
174
+ const allContentTypes = allContentTypesData?.filter((ct) => ct.pluginOptions?.webatlas?.active === true);
175
+ const [initialState, setInitialState] = useState(config || { selectedContentTypes: [] });
176
+ const { toggleNotification } = useNotification();
177
+ const { formatMessage } = useIntl();
178
+ const [isSaving, setIsSaving] = useState(false);
179
+ useEffect(() => {
180
+ setInitialState(config || { selectedContentTypes: [] });
181
+ }, [config]);
182
+ useEffect(() => {
183
+ if (!config) return;
184
+ dispatch({ type: "SET_SELECTED_CONTENT_TYPES", payload: config.selectedContentTypes });
185
+ }, [config]);
186
+ useEffect(() => {
187
+ if (fetchError) {
188
+ toggleNotification({
189
+ type: "danger",
190
+ message: formatMessage({
191
+ id: getTranslation("notification.error"),
192
+ defaultMessage: "An error occurred"
193
+ }) + ": " + fetchError
194
+ });
195
+ }
196
+ }, [fetchError, toggleNotification, formatMessage]);
197
+ async function save() {
198
+ if (!settingsState || settingsState.selectedContentTypes.find((cta) => !cta.default) !== void 0) return;
199
+ setIsSaving(true);
200
+ try {
201
+ await setConfig(settingsState);
202
+ setInitialState(settingsState);
203
+ toggleNotification({
204
+ type: "success",
205
+ message: formatMessage({
206
+ id: getTranslation("notification.settings.saved"),
207
+ defaultMessage: "Settings saved successfully"
208
+ })
209
+ });
210
+ setIsSaving(false);
211
+ } catch (err) {
212
+ setIsSaving(false);
213
+ toggleNotification({
214
+ type: "danger",
215
+ message: formatMessage({
216
+ id: getTranslation("notification.error"),
217
+ defaultMessage: "An error occurred"
218
+ }) + ": " + err
219
+ });
220
+ console.error(err);
221
+ }
222
+ }
223
+ if (loading) {
224
+ return /* @__PURE__ */ jsx(PageWrapper, { children: /* @__PURE__ */ jsx(FullLoader, { height: 200 }) });
225
+ }
226
+ return /* @__PURE__ */ jsxs(PageWrapper, { settingsState, initialState, save, isSaving, children: [
227
+ /* @__PURE__ */ jsxs(
228
+ Field.Root,
229
+ {
230
+ name: "selectedContentTypes",
231
+ hint: formatMessage({
232
+ id: getTranslation("settings.page.enabledContentTypes.hint"),
233
+ defaultMessage: "Select the content types for which you want to enable URL aliases"
234
+ }),
235
+ children: [
236
+ /* @__PURE__ */ jsx(Field.Label, { children: formatMessage({
237
+ id: getTranslation("settings.page.enabledContentTypes"),
238
+ defaultMessage: "Enabled Content Types"
239
+ }) }),
240
+ /* @__PURE__ */ jsx(
241
+ MultiSelect,
242
+ {
243
+ placeholder: formatMessage({
244
+ id: getTranslation("settings.page.enabledContentTypes.placeholder"),
245
+ defaultMessage: "Select content types..."
246
+ }),
247
+ onClear: () => dispatch({ type: "SET_SELECTED_CONTENT_TYPES", payload: [] }),
248
+ value: [...settingsState.selectedContentTypes.map((ct) => ct.uid)],
249
+ onChange: (value) => dispatch({
250
+ type: "SET_SELECTED_CONTENT_TYPES",
251
+ payload: value.map((v) => ({
252
+ uid: v,
253
+ default: "",
254
+ pattern: ""
255
+ }))
256
+ }),
257
+ withTags: true,
258
+ children: allContentTypes && allContentTypes.map(
259
+ (item) => /* @__PURE__ */ jsx(MultiSelectOption, { value: item.uid, children: item.info.displayName }, item.uid)
260
+ )
261
+ }
262
+ ),
263
+ /* @__PURE__ */ jsx(Field.Hint, {})
264
+ ]
265
+ }
266
+ ),
267
+ settingsState.selectedContentTypes && settingsState.selectedContentTypes.length > 0 && /* @__PURE__ */ jsx(Box, { paddingTop: 4, children: /* @__PURE__ */ jsxs(Field.Root, { name: "selectedContentTypesAccordion", children: [
268
+ /* @__PURE__ */ jsx(Field.Label, { children: formatMessage({
269
+ id: getTranslation("settings.page.contentTypeSettings"),
270
+ defaultMessage: "Content Type settings"
271
+ }) }),
272
+ /* @__PURE__ */ jsx(Accordion.Root, { children: settingsState.selectedContentTypes?.map((contentTypeSettings) => {
273
+ const ct = allContentTypes?.find((item) => item.uid === contentTypeSettings.uid);
274
+ return /* @__PURE__ */ jsx(ContentTypeAccordion, { contentType: ct, contentTypeSettings, dispatch }, contentTypeSettings.uid);
275
+ }) })
276
+ ] }) })
277
+ ] });
278
+ };
279
+ export {
280
+ Settings as default
281
+ };
282
+ //# sourceMappingURL=index-DtFIVZxq.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index-DtFIVZxq.mjs","sources":["../../admin/src/pages/Settings/PageWrapper.tsx","../../admin/src/pages/Settings/ContentTypeAccordion.tsx","../../admin/src/pages/Settings/index.tsx"],"sourcesContent":["import { Button, Box } from '@strapi/design-system';\nimport { Page, Layouts} from '@strapi/strapi/admin'\nimport { PLUGIN_NAME } from '../../../../pluginId';\nimport { getTranslation } from '../../utils';\nimport { useIntl } from 'react-intl';\nimport type { ConfigContentType } from '../../../../types';\n\nexport default function PageWrapper({ \n settingsState, \n initialState, \n save, \n isSaving,\n children\n}: { \n settingsState?: any, \n initialState?: any, \n save?: () => void, \n isSaving?: boolean,\n children: React.ReactNode \n}) {\n\n const { formatMessage } = useIntl();\n \n return (\n <Page.Main>\n <Layouts.Header\n title={PLUGIN_NAME}\n subtitle={formatMessage({\n id: getTranslation('settings.page.subtitle'),\n defaultMessage: 'Settings',\n })}\n primaryAction={ settingsState && initialState && save &&\n <Button\n type=\"submit\"\n onClick={() => save()}\n loading={isSaving}\n disabled={\n JSON.stringify(settingsState) === JSON.stringify(initialState)\n || settingsState.selectedContentTypes.find((cta: ConfigContentType) => !cta.default) !== undefined\n || isSaving\n }\n >\n {formatMessage({\n id: getTranslation('save'),\n defaultMessage: 'Save',\n })}\n </Button>\n }\n />\n <Layouts.Content>\n <Box\n background='neutral0'\n borderColor=\"neutral150\"\n hasRadius\n paddingBottom={4}\n paddingLeft={4}\n paddingRight={4}\n paddingTop={6}\n shadow=\"tableShadow\"\n >\n {children}\n </Box>\n </Layouts.Content>\n </Page.Main>\n )\n}","import { SingleSelect, SingleSelectOption } from '@strapi/design-system';\nimport Tooltip from '../../components/Tooltip'\nimport { Box, Accordion, Field } from '@strapi/design-system';\nimport { getTranslation } from '../../utils';\nimport { useIntl } from 'react-intl';\nimport type { ContentType, ConfigContentType } from '../../../../types';\n\nexport default function ContentTypeAccordion({ \n contentType,\n contentTypeSettings,\n dispatch\n}: { \n contentType: ContentType | undefined, \n contentTypeSettings: ConfigContentType, \n dispatch: React.Dispatch<any>\n}) {\n \n const { formatMessage } = useIntl();\n\n if (!contentType) return null\n\n return (\n <Box\n borderColor={!contentTypeSettings.default && 'danger500'}\n key={contentType.uid}\n >\n <Accordion.Item key={contentType.uid} value={contentType.uid} size=\"S\">\n <Accordion.Header>\n <Accordion.Trigger>\n {contentType?.info.displayName}\n </Accordion.Trigger>\n </Accordion.Header>\n <Accordion.Content>\n <Box padding={3}>\n <Field.Root\n name=\"selectedContentTypes\"\n hint={formatMessage({\n id: getTranslation('settings.page.defaultField.hint'),\n 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\".',\n })}\n error={!contentTypeSettings.default && formatMessage({\n id: getTranslation('settings.page.defaultField.error'),\n defaultMessage: 'Please select a default field',\n })}\n required\n >\n <Field.Label>\n {formatMessage({\n id: getTranslation('settings.page.defaultField'),\n defaultMessage: 'Default URL Alias field',\n })}\n </Field.Label>\n <SingleSelect\n name={`defaultField-${contentType.uid}`}\n onClear={() => dispatch({ type: 'SET_DEFAULT_FIELD', payload: { ctUid: contentType.uid, field: '' } })}\n value={contentTypeSettings?.default || ''}\n onChange={(value: string) => dispatch({ type: 'SET_DEFAULT_FIELD', payload: { ctUid: contentType.uid, field: value } })}\n >\n {Object.entries(contentType.attributes).map(([key], index) => {\n if (\n key === 'id' || \n key === 'documentId' ||\n key === 'createdAt' || \n key === 'updatedAt' || \n key === 'createdBy' || \n key === 'updatedBy' ||\n key === 'webatlas_path' ||\n key === 'webatlas_override'\n ) return null\n return <SingleSelectOption key={index} value={key}>{key}</SingleSelectOption>\n })}\n </SingleSelect>\n <Field.Hint/>\n </Field.Root>\n <Box paddingTop={4}>\n <Field.Root\n name=\"urlAliasPattern\"\n hint={formatMessage({\n id: getTranslation('settings.page.urlAliasPattern.hint'),\n 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.',\n })}\n >\n <Field.Label>\n {formatMessage({\n id: getTranslation('settings.page.urlAliasPattern'),\n defaultMessage: 'URL Alias Pattern',\n })}\n <Tooltip description={formatMessage({\n id: getTranslation('settings.page.urlAliasPattern.tooltip'),\n defaultMessage: 'Leading and trailing slashes will be removed. Spaces will be replaced with hyphens. Special characters will be encoded.',\n })} />\n </Field.Label>\n <Field.Input\n value={contentTypeSettings.pattern}\n onChange={(e: React.ChangeEvent<HTMLInputElement>) => dispatch({ type: 'SET_PATTERN', payload: { ctUid: contentType.uid, pattern: e.target.value } })}\n disabled={!contentTypeSettings.default}\n type=\"text\"\n placeholder={formatMessage({\n id: getTranslation('settings.page.urlAliasPattern.placeholder'),\n defaultMessage: 'e.g. blog',\n })}\n />\n <Field.Hint />\n </Field.Root>\n </Box>\n </Box>\n </Accordion.Content>\n </Accordion.Item>\n </Box>\n \n )\n}","/*\n *\n * Settings\n * This file contains the settings page for the Webatlas plugin in Strapi.\n * It allows users to configure which content types are enabled for URL aliases and navigations,\n * as well as setting default fields and the URL alias patterns for each content type. \n *\n*/\n\nimport { useEffect, useState, useReducer } from 'react';\nimport { Box, Accordion, Field } from '@strapi/design-system';\nimport { useNotification } from '@strapi/strapi/admin'\nimport { MultiSelect, MultiSelectOption } from '@strapi/design-system';\nimport usePluginConfig from '../../hooks/usePluginConfig';\nimport type { ContentType, ConfigContentType, PluginConfig } from '../../../../types';\nimport transformToUrl from '../../../../utils/transformToUrl';\nimport useAllContentTypes from '../../hooks/useAllContentTypes';\nimport { getTranslation } from '../../utils';\nimport { useIntl } from 'react-intl';\nimport { FullLoader } from '../../components/UI';\nimport PageWrapper from './PageWrapper';\nimport ContentTypeAccordion from './ContentTypeAccordion';\n\ntype Action =\n | { type: 'SET_SELECTED_CONTENT_TYPES'; payload: ConfigContentType[] }\n | { type: 'SET_DEFAULT_FIELD'; payload: { ctUid: string; field: string } }\n | { type: 'SET_PATTERN'; payload: { ctUid: string; pattern: string } }\n\nfunction reducer(settingsState: PluginConfig, action: Action): PluginConfig {\n let updatedContentTypes\n switch (action.type) {\n case 'SET_SELECTED_CONTENT_TYPES':\n updatedContentTypes = action.payload.map(ct => {\n return settingsState.selectedContentTypes.find((cta: ConfigContentType) => cta.uid === ct.uid) || ct\n })\n return { ...settingsState, selectedContentTypes: updatedContentTypes };\n case 'SET_DEFAULT_FIELD':\n updatedContentTypes = settingsState.selectedContentTypes.map(ct =>\n ct.uid === action.payload.ctUid ? { ...ct, default: action.payload.field } : ct\n );\n return { ...settingsState, selectedContentTypes: updatedContentTypes };\n case 'SET_PATTERN':\n updatedContentTypes = settingsState.selectedContentTypes.map(ct =>\n ct.uid === action.payload.ctUid ? { ...ct, pattern: transformToUrl(action.payload.pattern) } : ct\n );\n return { ...settingsState, selectedContentTypes: updatedContentTypes };\n default:\n throw new Error();\n }\n}\n\nconst Settings = () => {\n const { config, setConfig, loading, fetchError } = usePluginConfig();\n const [settingsState, dispatch] = useReducer(reducer, config || { selectedContentTypes: [] });\n const { contentTypes: allContentTypesData } = useAllContentTypes();\n const allContentTypes = allContentTypesData?.filter((ct: ContentType) => ct.pluginOptions?.webatlas?.active === true);\n const [initialState, setInitialState] = useState(config || { selectedContentTypes: [] })\n const { toggleNotification } = useNotification();\n const { formatMessage } = useIntl();\n const [isSaving, setIsSaving] = useState(false);\n\n useEffect(() => {\n setInitialState(config || { selectedContentTypes: [] })\n }, [config]);\n\n useEffect(() => {\n if (!config) return;\n dispatch({ type: 'SET_SELECTED_CONTENT_TYPES', payload: config.selectedContentTypes });\n }, [config]);\n \n useEffect(() => {\n if (fetchError) {\n toggleNotification({\n type: 'danger',\n message: formatMessage({\n id: getTranslation('notification.error'),\n defaultMessage: 'An error occurred',\n }) + ': ' + fetchError,\n });\n }\n }, [fetchError, toggleNotification, formatMessage]);\n\n async function save() {\n if (\n !settingsState \n || settingsState.selectedContentTypes.find((cta: ConfigContentType) => !cta.default) !== undefined\n ) return\n\n setIsSaving(true);\n try {\n await setConfig(settingsState)\n setInitialState(settingsState)\n\n toggleNotification({\n type: 'success',\n message: formatMessage({\n id: getTranslation('notification.settings.saved'),\n defaultMessage: 'Settings saved successfully',\n }),\n });\n setIsSaving(false);\n } catch (err) {\n setIsSaving(false);\n toggleNotification({\n type: 'danger',\n message: formatMessage({\n id: getTranslation('notification.error'),\n defaultMessage: 'An error occurred',\n }) + ': ' + err,\n });\n console.error(err);\n }\n }\n\n if (loading) {\n return <PageWrapper>\n <FullLoader height={200} />\n </PageWrapper>\n }\n\n return (\n <PageWrapper settingsState={settingsState} initialState={initialState} save={save} isSaving={isSaving}>\n <Field.Root\n name=\"selectedContentTypes\"\n hint={formatMessage({\n id: getTranslation('settings.page.enabledContentTypes.hint'),\n defaultMessage: 'Select the content types for which you want to enable URL aliases',\n })}\n >\n <Field.Label>\n {formatMessage({\n id: getTranslation('settings.page.enabledContentTypes'),\n defaultMessage: 'Enabled Content Types',\n })}\n </Field.Label>\n <MultiSelect\n placeholder={formatMessage({\n id: getTranslation('settings.page.enabledContentTypes.placeholder'),\n defaultMessage: 'Select content types...',\n })}\n onClear={() => dispatch({ type: 'SET_SELECTED_CONTENT_TYPES', payload: [] })}\n value={[...settingsState.selectedContentTypes.map((ct: ConfigContentType) => ct.uid)]}\n onChange={(value: string[]) =>\n dispatch({\n type: 'SET_SELECTED_CONTENT_TYPES',\n payload: value.map(v => ({\n uid: v,\n default: '',\n pattern: '',\n })),\n })\n }\n withTags\n >\n {allContentTypes && allContentTypes.map(item => \n <MultiSelectOption key={item.uid} value={item.uid}>{item.info.displayName}</MultiSelectOption>\n )}\n </MultiSelect>\n <Field.Hint/>\n </Field.Root>\n {settingsState.selectedContentTypes && settingsState.selectedContentTypes.length > 0 && \n <Box paddingTop={4}>\n <Field.Root name=\"selectedContentTypesAccordion\">\n <Field.Label>\n {formatMessage({\n id: getTranslation('settings.page.contentTypeSettings'),\n defaultMessage: 'Content Type settings',\n })}\n </Field.Label>\n <Accordion.Root>\n {settingsState.selectedContentTypes?.map((contentTypeSettings: ConfigContentType) => {\n const ct: ContentType | undefined = allContentTypes?.find((item) => item.uid === contentTypeSettings.uid)\n return <ContentTypeAccordion key={contentTypeSettings.uid} contentType={ct} contentTypeSettings={contentTypeSettings} dispatch={dispatch} />\n })}\n </Accordion.Root>\n </Field.Root>\n </Box>\n }\n </PageWrapper>\n );\n};\n\nexport default Settings;\n"],"names":[],"mappings":"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"}
@@ -1,7 +1,7 @@
1
1
  import { jsx, jsxs } from "react/jsx-runtime";
2
2
  import { useState, useEffect } from "react";
3
3
  import { Thead, Tr, Th, Typography, VisuallyHidden, Td, Flex, LinkButton, Box, Table, Tbody } from "@strapi/design-system";
4
- import { g as getTranslation, u as useApi } from "./index-DUxYbDKG.mjs";
4
+ import { g as getTranslation, u as useApi } from "./index-Ctq2vsD5.mjs";
5
5
  import { Page, Layouts, useNotification } from "@strapi/strapi/admin";
6
6
  import { F as FullLoader, C as Center } from "./FullLoader-CrPED_dY.mjs";
7
7
  import { E as EmptyBox } from "./EmptyBox-BM4IscSk.mjs";
@@ -1,4 +1,5 @@
1
1
  "use strict";
2
- const index = require("../_chunks/index-ChDbwEb-.js");
2
+ const index = require("../_chunks/index-Ciae_OgQ.js");
3
3
  require("react/jsx-runtime");
4
4
  module.exports = index.index;
5
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
@@ -1,5 +1,6 @@
1
- import { i } from "../_chunks/index-DUxYbDKG.mjs";
1
+ import { i } from "../_chunks/index-CuJP8Fy7.mjs";
2
2
  import "react/jsx-runtime";
3
3
  export {
4
4
  i as default
5
5
  };
6
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;"}
@@ -8,7 +8,7 @@ export default function useApi(): {
8
8
  getStructuredNavigation: (documentId: string, variant?: StructuredNavigationVariant) => Promise<any>;
9
9
  getNavigation: ({ documentId, variant }?: {
10
10
  documentId?: string;
11
- variant?: StructuredNavigationVariant;
11
+ variant?: StructuredNavigationVariant | "namesOnly";
12
12
  }) => Promise<any>;
13
13
  deleteNavigation: (documentId: string) => Promise<any>;
14
14
  updateNavigation: (documentId: string, body: NavigationInput) => Promise<any>;
@@ -0,0 +1,2 @@
1
+ declare const Navigation: () => import("react/jsx-runtime").JSX.Element;
2
+ export default Navigation;
@@ -1,2 +1,2 @@
1
- declare const Navigation: () => import("react/jsx-runtime").JSX.Element;
2
- export default Navigation;
1
+ declare const App: () => import("react/jsx-runtime").JSX.Element;
2
+ export default App;
@@ -20,7 +20,7 @@ function transformToUrl(input) {
20
20
  input = input.replace(/-+/g, "-");
21
21
  return input;
22
22
  }
23
- const version = "0.3.1";
23
+ const version = "0.5.0";
24
24
  const keywords = [];
25
25
  const type = "commonjs";
26
26
  const exports$1 = {
@@ -5625,6 +5625,17 @@ const admin = ({ strapi: strapi2 }) => ({
5625
5625
  async getNavigation(documentId, variant) {
5626
5626
  try {
5627
5627
  let navigation2 = null;
5628
+ if (variant === "namesOnly") {
5629
+ if (documentId) {
5630
+ return await strapi2.documents(waNavigation).findOne({
5631
+ documentId,
5632
+ select: ["documentId", "name", "slug", "visible"]
5633
+ });
5634
+ }
5635
+ return await strapi2.documents(waNavigation).findMany({
5636
+ select: ["documentId", "name", "slug", "visible"]
5637
+ });
5638
+ }
5628
5639
  if (documentId) {
5629
5640
  navigation2 = await strapi2.documents(waNavigation).findOne({
5630
5641
  documentId,
@@ -5905,3 +5916,4 @@ const index = {
5905
5916
  middlewares
5906
5917
  };
5907
5918
  module.exports = index;
5919
+ //# sourceMappingURL=index.js.map