strapi-plugin-navigation 3.0.0-beta.0 → 3.0.0-beta.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.
- package/README.md +23 -28
- package/dist/_chunks/ca-Bjfh0w36.js +480 -0
- package/dist/_chunks/ca-DIZHA0OL.mjs +480 -0
- package/dist/_chunks/en-BPYZYsnc.mjs +490 -0
- package/dist/_chunks/en-CT7eKHZS.js +490 -0
- package/dist/_chunks/fr-BTVWPkax.mjs +490 -0
- package/dist/_chunks/fr-ybbSdjZO.js +490 -0
- package/dist/admin/index.js +55426 -0
- package/dist/admin/index.mjs +55408 -0
- package/dist/admin/src/api/client.d.ts +192 -0
- package/dist/admin/src/api/validators.d.ts +1828 -0
- package/dist/admin/src/components/ConfirmationDialog/index.d.ts +20 -0
- package/dist/admin/src/components/Initializer.d.ts +5 -0
- package/dist/admin/src/components/RestartAlert/index.d.ts +2 -0
- package/dist/admin/src/components/TextArrayInput/index.d.ts +12 -0
- package/dist/admin/src/components/icons/navigation.d.ts +4 -0
- package/dist/admin/src/components/icons/pluginIcon.d.ts +7 -0
- package/dist/admin/src/index.d.ts +10 -0
- package/dist/admin/src/pages/App.d.ts +2 -0
- package/dist/admin/src/pages/HomePage/components/AdditionalFieldInput/index.d.ts +12 -0
- package/dist/admin/src/pages/HomePage/components/CollapseButton/index.d.ts +8 -0
- package/dist/admin/src/pages/HomePage/components/DragButton/index.d.ts +5 -0
- package/dist/admin/src/pages/HomePage/components/I18nCopyNavigationItems/index.d.ts +13 -0
- package/dist/admin/src/pages/HomePage/components/NavigationContentHeader/index.d.ts +7 -0
- package/dist/admin/src/pages/HomePage/components/NavigationHeader/hooks.d.ts +5 -0
- package/dist/admin/src/pages/HomePage/components/NavigationHeader/index.d.ts +23 -0
- package/dist/admin/src/pages/HomePage/components/NavigationHeader/styles.d.ts +2 -0
- package/dist/admin/src/pages/HomePage/components/NavigationItemForm/index.d.ts +22 -0
- package/dist/admin/src/pages/HomePage/components/NavigationItemForm/types.d.ts +45 -0
- package/dist/admin/src/pages/HomePage/components/NavigationItemForm/utils/form.d.ts +184 -0
- package/dist/admin/src/pages/HomePage/components/NavigationItemForm/utils/hooks.d.ts +1 -0
- package/dist/admin/src/pages/HomePage/components/NavigationItemForm/utils/properties.d.ts +33 -0
- package/dist/admin/src/pages/HomePage/components/NavigationItemList/Wrapper.d.ts +5 -0
- package/dist/admin/src/pages/HomePage/components/NavigationItemList/index.d.ts +25 -0
- package/dist/admin/src/pages/HomePage/components/NavigationItemListItem/ItemCardBadge/index.d.ts +2 -0
- package/dist/admin/src/pages/HomePage/components/NavigationItemListItem/ItemCardHeader/Wrapper.d.ts +2 -0
- package/dist/admin/src/pages/HomePage/components/NavigationItemListItem/ItemCardHeader/icons.d.ts +5 -0
- package/dist/admin/src/pages/HomePage/components/NavigationItemListItem/ItemCardHeader/index.d.ts +16 -0
- package/dist/admin/src/pages/HomePage/components/NavigationItemListItem/ItemCardRemovedOverlay/index.d.ts +2 -0
- package/dist/admin/src/pages/HomePage/components/NavigationItemListItem/Wrapper.d.ts +6 -0
- package/dist/admin/src/pages/HomePage/components/NavigationItemListItem/index.d.ts +44 -0
- package/dist/admin/src/pages/HomePage/components/NavigationItemPopup/NavigationItemPopupFooter.d.ts +10 -0
- package/dist/admin/src/pages/HomePage/components/NavigationItemPopup/NavigationItemPopupHeader.d.ts +4 -0
- package/dist/admin/src/pages/HomePage/components/NavigationItemPopup/index.d.ts +19 -0
- package/dist/admin/src/pages/HomePage/components/NavigationManager/AllNavigations/icons.d.ts +3 -0
- package/dist/admin/src/pages/HomePage/components/NavigationManager/AllNavigations/index.d.ts +7 -0
- package/dist/admin/src/pages/HomePage/components/NavigationManager/DeletionConfirm/index.d.ts +7 -0
- package/dist/admin/src/pages/HomePage/components/NavigationManager/ErrorDetails/index.d.ts +7 -0
- package/dist/admin/src/pages/HomePage/components/NavigationManager/Footer/index.d.ts +26 -0
- package/dist/admin/src/pages/HomePage/components/NavigationManager/Form/hooks.d.ts +13 -0
- package/dist/admin/src/pages/HomePage/components/NavigationManager/Form/index.d.ts +10 -0
- package/dist/admin/src/pages/HomePage/components/NavigationManager/NavigationUpdate/index.d.ts +7 -0
- package/dist/admin/src/pages/HomePage/components/NavigationManager/NewNavigation/index.d.ts +8 -0
- package/dist/admin/src/pages/HomePage/components/NavigationManager/PurgeCacheConfirm/index.d.ts +7 -0
- package/dist/admin/src/pages/HomePage/components/NavigationManager/index.d.ts +9 -0
- package/dist/admin/src/pages/HomePage/components/NavigationManager/types.d.ts +46 -0
- package/dist/admin/src/pages/HomePage/components/Search/index.d.ts +11 -0
- package/dist/admin/src/pages/HomePage/hooks/index.d.ts +144 -0
- package/dist/admin/src/pages/HomePage/index.d.ts +2 -0
- package/dist/admin/src/pages/HomePage/utils/index.d.ts +5 -0
- package/dist/admin/src/pages/HomePage/utils/parsers.d.ts +46 -0
- package/dist/admin/src/pages/SettingsPage/common/const.d.ts +1 -0
- package/dist/admin/src/pages/SettingsPage/components/CustomFieldForm/index.d.ts +11 -0
- package/dist/admin/src/pages/SettingsPage/components/CustomFieldModal/index.d.ts +11 -0
- package/dist/admin/src/pages/SettingsPage/components/CustomFieldTable/index.d.ts +11 -0
- package/dist/admin/src/pages/SettingsPage/hooks/index.d.ts +369 -0
- package/dist/admin/src/pages/SettingsPage/index.d.ts +1 -0
- package/dist/admin/src/pages/SettingsPage/types.d.ts +7 -0
- package/dist/admin/src/pages/SettingsPage/utils/index.d.ts +9 -0
- package/dist/admin/src/pluginId.d.ts +1 -0
- package/dist/admin/src/schemas/config.d.ts +453 -0
- package/dist/admin/src/schemas/content-type.d.ts +49 -0
- package/dist/admin/src/translations/ca.d.ts +478 -0
- package/dist/admin/src/translations/en.d.ts +489 -0
- package/dist/admin/src/translations/fr.d.ts +488 -0
- package/dist/admin/src/translations/index.d.ts +14 -0
- package/dist/admin/src/types.d.ts +6 -0
- package/dist/admin/src/utils/constants.d.ts +1 -0
- package/dist/admin/src/utils/getTranslation.d.ts +3 -0
- package/dist/admin/src/utils/permissions.d.ts +15 -0
- package/dist/admin/src/utils/prefixPluginTranslations.d.ts +3 -0
- package/dist/assets/configuration.png +0 -0
- package/dist/assets/logo.png +0 -0
- package/dist/assets/manager-view.png +0 -0
- package/dist/assets/marketplace.png +0 -0
- package/dist/assets/preview.png +0 -0
- package/dist/server/index.js +16171 -0
- package/dist/server/index.mjs +16135 -0
- package/dist/server/src/app-errors.d.ts +11 -0
- package/dist/server/src/bootstrap.d.ts +5 -0
- package/dist/server/src/cache/index.d.ts +4 -0
- package/dist/server/src/config/index.d.ts +20 -0
- package/dist/server/src/config/setup.d.ts +41 -0
- package/dist/server/src/content-types/audience/index.d.ts +26 -0
- package/dist/server/src/content-types/audience/schema.d.ts +24 -0
- package/dist/server/src/content-types/index.d.ts +190 -0
- package/dist/server/src/content-types/navigation/index.d.ts +56 -0
- package/dist/server/src/content-types/navigation/lifecycles.d.ts +2 -0
- package/dist/server/src/content-types/navigation/schema.d.ts +53 -0
- package/dist/server/src/content-types/navigation-item/index.d.ts +108 -0
- package/dist/server/src/content-types/navigation-item/lifecycles.d.ts +2 -0
- package/dist/server/src/content-types/navigation-item/schema.d.ts +105 -0
- package/dist/server/src/controllers/admin.d.ts +241 -0
- package/dist/server/src/controllers/client.d.ts +192 -0
- package/dist/server/src/controllers/index.d.ts +7 -0
- package/dist/server/src/controllers/utils.d.ts +4 -0
- package/dist/server/src/controllers/validators.d.ts +62 -0
- package/dist/server/src/destroy.d.ts +5 -0
- package/dist/server/src/dtos/config.d.ts +28 -0
- package/dist/server/src/dtos/index.d.ts +3 -0
- package/dist/server/src/dtos/navigation-item.d.ts +52 -0
- package/dist/server/src/dtos/navigation.d.ts +5 -0
- package/dist/server/src/graphql/config.d.ts +5 -0
- package/dist/server/src/graphql/index.d.ts +1 -0
- package/dist/server/src/graphql/queries/index.d.ts +1 -0
- package/dist/server/src/graphql/queries/render-navigation-child.d.ts +31 -0
- package/dist/server/src/graphql/queries/render-navigation.d.ts +32 -0
- package/dist/server/src/graphql/resolvers-config.d.ts +8 -0
- package/dist/server/src/graphql/setup.d.ts +4 -0
- package/dist/server/src/graphql/types/content-types-name-fields.d.ts +2 -0
- package/dist/server/src/graphql/types/content-types.d.ts +2 -0
- package/dist/server/src/graphql/types/create-navigation-item.d.ts +2 -0
- package/dist/server/src/graphql/types/create-navigation-related.d.ts +2 -0
- package/dist/server/src/graphql/types/create-navigation.d.ts +2 -0
- package/dist/server/src/graphql/types/index.d.ts +1 -0
- package/dist/server/src/graphql/types/navigation-config.d.ts +2 -0
- package/dist/server/src/graphql/types/navigation-details.d.ts +2 -0
- package/dist/server/src/graphql/types/navigation-item-additional-field-media.d.ts +2 -0
- package/dist/server/src/graphql/types/navigation-item-additional-fields.d.ts +2 -0
- package/dist/server/src/graphql/types/navigation-item-related-data.d.ts +2 -0
- package/dist/server/src/graphql/types/navigation-item-related.d.ts +2 -0
- package/dist/server/src/graphql/types/navigation-item.d.ts +2 -0
- package/dist/server/src/graphql/types/navigation-render-type.d.ts +2 -0
- package/dist/server/src/graphql/types/navigation.d.ts +2 -0
- package/dist/server/src/i18n/index.d.ts +4 -0
- package/dist/server/src/index.d.ts +582 -0
- package/dist/server/src/middlewares/index.d.ts +2 -0
- package/dist/server/src/permissions/index.d.ts +3 -0
- package/dist/server/src/permissions/permissions.d.ts +9 -0
- package/dist/server/src/permissions/setup.d.ts +4 -0
- package/dist/server/src/permissions.d.ts +13 -0
- package/dist/server/src/policies/index.d.ts +2 -0
- package/dist/server/src/register.d.ts +5 -0
- package/dist/server/src/repositories/audience.d.ts +11 -0
- package/dist/server/src/repositories/generic.d.ts +23 -0
- package/dist/server/src/repositories/index.d.ts +4 -0
- package/dist/server/src/repositories/navigation-item.d.ts +24 -0
- package/dist/server/src/repositories/navigation.d.ts +47 -0
- package/dist/server/src/routes/admin.d.ts +24 -0
- package/dist/server/src/routes/client.d.ts +17 -0
- package/dist/server/src/routes/index.d.ts +37 -0
- package/dist/server/src/schemas/config.d.ts +424 -0
- package/dist/server/src/schemas/content-type.d.ts +918 -0
- package/dist/server/src/schemas/index.d.ts +3 -0
- package/dist/server/src/schemas/navigation.d.ts +237 -0
- package/dist/server/src/services/admin/admin.d.ts +32 -0
- package/dist/server/src/services/admin/index.d.ts +3 -0
- package/dist/server/src/services/admin/types.d.ts +47 -0
- package/dist/server/src/services/admin/utils.d.ts +32 -0
- package/dist/server/src/services/client/client.d.ts +93 -0
- package/dist/server/src/services/client/index.d.ts +3 -0
- package/dist/server/src/services/client/types.d.ts +66 -0
- package/dist/server/src/services/client/utils.d.ts +12 -0
- package/dist/server/src/services/common/common.d.ts +31 -0
- package/dist/server/src/services/common/index.d.ts +3 -0
- package/dist/server/src/services/common/types.d.ts +68 -0
- package/dist/server/src/services/common/utils.d.ts +12 -0
- package/dist/server/src/services/index.d.ts +320 -0
- package/dist/server/src/services/migration/index.d.ts +3 -0
- package/dist/server/src/services/migration/migration.d.ts +8 -0
- package/dist/server/src/types.d.ts +40 -0
- package/dist/server/src/utils/constants.d.ts +13 -0
- package/dist/server/src/utils/functions.d.ts +30 -0
- package/dist/server/src/utils/index.d.ts +2 -0
- package/package.json +116 -35
- package/admin/api/client.js +0 -107
- package/admin/api/validators.js +0 -248
- package/admin/components/ConfirmationDialog/index.js +0 -21
- package/admin/components/Initializer.js +0 -10
- package/admin/components/RestartAlert/index.js +0 -7
- package/admin/components/TextArrayInput/index.js +0 -18
- package/admin/components/icons/navigation.js +0 -9
- package/admin/components/icons/pluginIcon.js +0 -9
- package/admin/index.js +0 -48
- package/admin/pages/App.js +0 -10
- package/admin/pages/HomePage/components/AdditionalFieldInput/index.js +0 -58
- package/admin/pages/HomePage/components/CollapseButton/index.js +0 -15
- package/admin/pages/HomePage/components/DragButton/index.js +0 -55
- package/admin/pages/HomePage/components/I18nCopyNavigationItems/index.js +0 -9
- package/admin/pages/HomePage/components/NavigationContentHeader/index.js +0 -5
- package/admin/pages/HomePage/components/NavigationHeader/hooks.js +0 -14
- package/admin/pages/HomePage/components/NavigationHeader/index.js +0 -29
- package/admin/pages/HomePage/components/NavigationHeader/styles.js +0 -11
- package/admin/pages/HomePage/components/NavigationItemForm/index.js +0 -277
- package/admin/pages/HomePage/components/NavigationItemForm/types.js +0 -1
- package/admin/pages/HomePage/components/NavigationItemForm/utils/form.js +0 -105
- package/admin/pages/HomePage/components/NavigationItemForm/utils/hooks.js +0 -12
- package/admin/pages/HomePage/components/NavigationItemForm/utils/properties.js +0 -51
- package/admin/pages/HomePage/components/NavigationItemList/Wrapper.js +0 -21
- package/admin/pages/HomePage/components/NavigationItemList/index.js +0 -6
- package/admin/pages/HomePage/components/NavigationItemListItem/ItemCardBadge/index.js +0 -20
- package/admin/pages/HomePage/components/NavigationItemListItem/ItemCardHeader/Wrapper.js +0 -14
- package/admin/pages/HomePage/components/NavigationItemListItem/ItemCardHeader/icons.js +0 -6
- package/admin/pages/HomePage/components/NavigationItemListItem/ItemCardHeader/index.js +0 -19
- package/admin/pages/HomePage/components/NavigationItemListItem/ItemCardRemovedOverlay/index.js +0 -11
- package/admin/pages/HomePage/components/NavigationItemListItem/Wrapper.js +0 -38
- package/admin/pages/HomePage/components/NavigationItemListItem/index.js +0 -165
- package/admin/pages/HomePage/components/NavigationItemPopup/NavigationItemPopupFooter.js +0 -11
- package/admin/pages/HomePage/components/NavigationItemPopup/NavigationItemPopupHeader.js +0 -12
- package/admin/pages/HomePage/components/NavigationItemPopup/index.js +0 -34
- package/admin/pages/HomePage/components/NavigationManager/AllNavigations/icons.js +0 -5
- package/admin/pages/HomePage/components/NavigationManager/AllNavigations/index.js +0 -79
- package/admin/pages/HomePage/components/NavigationManager/DeletionConfirm/index.js +0 -25
- package/admin/pages/HomePage/components/NavigationManager/ErrorDetails/index.js +0 -29
- package/admin/pages/HomePage/components/NavigationManager/Footer/index.js +0 -6
- package/admin/pages/HomePage/components/NavigationManager/Form/hooks.js +0 -19
- package/admin/pages/HomePage/components/NavigationManager/Form/index.js +0 -26
- package/admin/pages/HomePage/components/NavigationManager/NavigationUpdate/index.js +0 -32
- package/admin/pages/HomePage/components/NavigationManager/NewNavigation/index.js +0 -35
- package/admin/pages/HomePage/components/NavigationManager/PurgeCacheConfirm/index.js +0 -25
- package/admin/pages/HomePage/components/NavigationManager/index.js +0 -236
- package/admin/pages/HomePage/components/NavigationManager/types.js +0 -1
- package/admin/pages/HomePage/components/Search/index.js +0 -58
- package/admin/pages/HomePage/hooks/index.js +0 -165
- package/admin/pages/HomePage/index.js +0 -231
- package/admin/pages/HomePage/utils/index.js +0 -16
- package/admin/pages/HomePage/utils/parsers.js +0 -187
- package/admin/pages/SettingsPage/common/const.js +0 -1
- package/admin/pages/SettingsPage/components/CustomFieldForm/hooks/index.js +0 -10
- package/admin/pages/SettingsPage/components/CustomFieldForm/index.js +0 -36
- package/admin/pages/SettingsPage/components/CustomFieldModal/index.js +0 -16
- package/admin/pages/SettingsPage/components/CustomFieldTable/index.js +0 -45
- package/admin/pages/SettingsPage/hooks/index.js +0 -111
- package/admin/pages/SettingsPage/index.js +0 -189
- package/admin/pages/SettingsPage/types.js +0 -1
- package/admin/pages/SettingsPage/utils/index.js +0 -25
- package/admin/pluginId.js +0 -1
- package/admin/schemas/config.js +0 -53
- package/admin/schemas/content-type.js +0 -14
- package/admin/translations/ca.json +0 -199
- package/admin/translations/en.json +0 -218
- package/admin/translations/fr.json +0 -48
- package/admin/translations/index.js +0 -15
- package/admin/types.js +0 -1
- package/admin/utils/constants.js +0 -1
- package/admin/utils/getTranslation.js +0 -4
- package/admin/utils/permissions.js +0 -16
- package/admin/utils/prefixPluginTranslations.js +0 -3
- package/server/app-errors.js +0 -20
- package/server/bootstrap.js +0 -13
- package/server/cache/index.js +0 -37
- package/server/config/index.js +0 -39
- package/server/config/setup.js +0 -59
- package/server/content-types/audience/index.js +0 -9
- package/server/content-types/audience/schema.js +0 -25
- package/server/content-types/index.js +0 -13
- package/server/content-types/navigation/index.js +0 -11
- package/server/content-types/navigation/lifecycles.js +0 -6
- package/server/content-types/navigation/schema.js +0 -54
- package/server/content-types/navigation-item/index.js +0 -11
- package/server/content-types/navigation-item/lifecycles.js +0 -6
- package/server/content-types/navigation-item/schema.js +0 -106
- package/server/controllers/admin.js +0 -125
- package/server/controllers/client.js +0 -86
- package/server/controllers/index.js +0 -11
- package/server/controllers/utils.js +0 -22
- package/server/controllers/validators.js +0 -48
- package/server/destroy.js +0 -6
- package/server/dtos/config.js +0 -2
- package/server/dtos/index.js +0 -19
- package/server/dtos/navigation-item.js +0 -2
- package/server/dtos/navigation.js +0 -2
- package/server/graphql/config.js +0 -26
- package/server/graphql/index.js +0 -17
- package/server/graphql/queries/index.js +0 -21
- package/server/graphql/queries/render-navigation-child.js +0 -36
- package/server/graphql/queries/render-navigation.js +0 -48
- package/server/graphql/resolvers-config.js +0 -8
- package/server/graphql/setup.js +0 -14
- package/server/graphql/types/content-types-name-fields.js +0 -15
- package/server/graphql/types/content-types.js +0 -18
- package/server/graphql/types/create-navigation-item.js +0 -19
- package/server/graphql/types/create-navigation-related.js +0 -10
- package/server/graphql/types/create-navigation.js +0 -9
- package/server/graphql/types/index.js +0 -38
- package/server/graphql/types/navigation-config.js +0 -11
- package/server/graphql/types/navigation-details.js +0 -12
- package/server/graphql/types/navigation-item-additional-field-media.js +0 -13
- package/server/graphql/types/navigation-item-related-data.js +0 -9
- package/server/graphql/types/navigation-item-related.js +0 -25
- package/server/graphql/types/navigation-item.js +0 -58
- package/server/graphql/types/navigation-render-type.js +0 -6
- package/server/graphql/types/navigation.js +0 -11
- package/server/i18n/index.js +0 -32
- package/server/index.js +0 -33
- package/server/middlewares/index.js +0 -3
- package/server/permissions/index.js +0 -10
- package/server/permissions/permissions.js +0 -12
- package/server/permissions/setup.js +0 -32
- package/server/permissions.js +0 -39
- package/server/policies/index.js +0 -3
- package/server/register.js +0 -6
- package/server/repositories/audience.js +0 -12
- package/server/repositories/generic.js +0 -20
- package/server/repositories/index.js +0 -11
- package/server/repositories/navigation-item.js +0 -51
- package/server/repositories/navigation.js +0 -65
- package/server/routes/admin.js +0 -216
- package/server/routes/client.js +0 -32
- package/server/routes/index.js +0 -12
- package/server/schemas/config.js +0 -68
- package/server/schemas/content-type.js +0 -140
- package/server/schemas/index.js +0 -19
- package/server/schemas/navigation.js +0 -107
- package/server/services/admin/admin.js +0 -483
- package/server/services/admin/index.js +0 -7
- package/server/services/admin/types.js +0 -2
- package/server/services/admin/utils.js +0 -84
- package/server/services/client/client.js +0 -397
- package/server/services/client/index.js +0 -7
- package/server/services/client/types.js +0 -2
- package/server/services/client/utils.js +0 -88
- package/server/services/common/common.js +0 -307
- package/server/services/common/index.js +0 -7
- package/server/services/common/types.js +0 -2
- package/server/services/common/utils.js +0 -24
- package/server/services/index.js +0 -13
- package/server/types.js +0 -2
- package/server/utils/constants.js +0 -35
- package/server/utils/functions.js +0 -111
- package/server/utils/index.js +0 -18
- package/strapi-admin.js +0 -5
- package/strapi-server.js +0 -3
- package/tsconfig.tsbuildinfo +0 -1
- /package/{admin/api/index.js → dist/admin/src/api/index.d.ts} +0 -0
- /package/{admin/components/icons/index.js → dist/admin/src/components/icons/index.d.ts} +0 -0
- /package/{admin/pages/HomePage/components/index.js → dist/admin/src/pages/HomePage/components/index.d.ts} +0 -0
- /package/{admin/pages/SettingsPage/common/index.js → dist/admin/src/pages/SettingsPage/common/index.d.ts} +0 -0
- /package/{admin/schemas/index.js → dist/admin/src/schemas/index.d.ts} +0 -0
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
-
import { Box, Button, Field, Flex, Grid, SingleSelect, SingleSelectOption, Tag, } from '@strapi/design-system';
|
|
3
|
-
import { Check, Information } from '@strapi/icons';
|
|
4
|
-
import { Layouts, Page } from '@strapi/strapi/admin';
|
|
5
|
-
import { useIntl } from 'react-intl';
|
|
6
|
-
import { getTrad } from '../../../../translations';
|
|
7
|
-
import { useConfig } from '../../hooks';
|
|
8
|
-
import { useNavigationManager } from './hooks';
|
|
9
|
-
const submitIcon = _jsx(Check, {});
|
|
10
|
-
export const NavigationHeader = ({ activeNavigation, availableNavigations, structureHasErrors, structureHasChanged, handleChangeSelection, handleLocalizationSelection, handleSave, handleCachePurge, permissions = {}, locale, currentLocale, }) => {
|
|
11
|
-
const { formatMessage } = useIntl();
|
|
12
|
-
const { openNavigationManagerModal, navigationManagerModal } = useNavigationManager();
|
|
13
|
-
const hasLocalizations = !!locale.restLocale;
|
|
14
|
-
const { canUpdate } = permissions;
|
|
15
|
-
const configQuery = useConfig();
|
|
16
|
-
return (_jsxs(_Fragment, { children: [_jsx(Page.Title, { children: formatMessage(getTrad('header.title', 'UI Navigation')) }), _jsx(Layouts.Header, { title: formatMessage(getTrad('header.title', 'UI Navigation')), subtitle: formatMessage(getTrad('header.description')), primaryAction: _jsxs(Flex, { direction: "row", size: 2, children: [_jsx(Box, { children: _jsxs(Grid.Root, { gap: 4, style: configQuery.data?.isCacheEnabled ? { display: 'flex' } : undefined, children: [!hasLocalizations ? _jsx(Grid.Item, { col: 2 }) : null, canUpdate && (_jsx(Grid.Item, { col: 3, children: _jsx(Button, { onClick: openNavigationManagerModal, startIcon: null, type: "button", variant: "secondary", fullWidth: true, size: "S", children: formatMessage(getTrad('header.action.manage')) }) })), _jsx(Grid.Item, { col: canUpdate ? 4 : 10, children: _jsx(Field.Root, { width: "100%", children: _jsx(SingleSelect, { type: "select", placeholder: "Change navigation", name: "navigationSelect", onChange: (nextId) => {
|
|
17
|
-
const nextNavigation = availableNavigations.find(({ id }) => nextId === id);
|
|
18
|
-
if (nextNavigation) {
|
|
19
|
-
handleChangeSelection(nextNavigation);
|
|
20
|
-
}
|
|
21
|
-
}, value: activeNavigation?.id, size: "S", style: null, children: availableNavigations
|
|
22
|
-
.filter(({ localeCode }) => localeCode === currentLocale)
|
|
23
|
-
.map(({ id, name }) => (_jsx(SingleSelectOption, { value: id, children: name }, id))) }) }) }), hasLocalizations ? (_jsx(Grid.Item, { col: 2, children: _jsx(SingleSelect, { type: "select", placeholder: formatMessage(getTrad('pages.main.header.localization.select.placeholder')), name: "navigationLocalizationSelect", onChange: handleLocalizationSelection, value: currentLocale, size: "S", children: [locale.defaultLocale, ...locale.restLocale].map((code) => (_jsx(SingleSelectOption, { value: code, children: code }, code))) }) })) : null, canUpdate && (_jsx(Grid.Item, { col: 3, children: _jsx(Button, { onClick: handleSave, startIcon: submitIcon, disabled: structureHasErrors || !structureHasChanged, type: "submit", fullWidth: true, size: "S", children: formatMessage(getTrad('submit.cta.save')) }) })), configQuery.data?.isCacheEnabled && (_jsx(Grid.Item, { col: 3, children: _jsx(Button, { onClick: handleCachePurge, startIcon: submitIcon, variant: "danger", type: "submit", fullWidth: true, size: "S", children: formatMessage(getTrad('submit.cta.cache.purge')) }) }))] }) }), canUpdate && navigationManagerModal] }), secondaryAction: _jsx(Tag, { icon: _jsx(Information, { "aria-hidden": true }), children: activeNavigation
|
|
24
|
-
? formatMessage(getTrad('header.meta'), {
|
|
25
|
-
id: activeNavigation?.id,
|
|
26
|
-
key: activeNavigation?.slug,
|
|
27
|
-
})
|
|
28
|
-
: null }) })] }));
|
|
29
|
-
};
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import styled from 'styled-components';
|
|
2
|
-
import { IconButton } from '@strapi/design-system';
|
|
3
|
-
export const MoreButton = styled(IconButton) `
|
|
4
|
-
margin: ${({ theme }) => `0 ${theme.spaces[2]}`};
|
|
5
|
-
padding: ${({ theme }) => theme.spaces[2]};
|
|
6
|
-
|
|
7
|
-
svg {
|
|
8
|
-
width: ${18 / 16}rem;
|
|
9
|
-
height: ${18 / 16}rem;
|
|
10
|
-
}
|
|
11
|
-
`;
|
|
@@ -1,277 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
-
import { Button, Field, Grid, Modal } from '@strapi/design-system';
|
|
3
|
-
import { useNotification } from '@strapi/strapi/admin';
|
|
4
|
-
import { isEmpty, isNil, sortBy } from 'lodash';
|
|
5
|
-
import { useCallback, useEffect, useMemo, useState } from 'react';
|
|
6
|
-
import { Controller } from 'react-hook-form';
|
|
7
|
-
import { useIntl } from 'react-intl';
|
|
8
|
-
import { Box, MultiSelect, MultiSelectOption, SingleSelect, SingleSelectOption, TextInput, Toggle, } from '@strapi/design-system';
|
|
9
|
-
import { getTrad } from '../../../../translations';
|
|
10
|
-
import { RELATED_ITEM_SEPARATOR } from '../../../../utils/constants';
|
|
11
|
-
import { useConfig, useContentTypeItems, useCopyNavigationItemI18n, useNavigations, } from '../../hooks';
|
|
12
|
-
import { extractRelatedItemLabel } from '../../utils';
|
|
13
|
-
import { AdditionalFieldInput } from '../AdditionalFieldInput';
|
|
14
|
-
import { NavigationItemPopupFooter } from '../NavigationItemPopup/NavigationItemPopupFooter';
|
|
15
|
-
import { useNavigationItemForm } from './utils/form';
|
|
16
|
-
import { useSlug } from './utils/hooks';
|
|
17
|
-
import { generatePreviewPath, generateUiRouterKey } from './utils/properties';
|
|
18
|
-
import { Divider } from '@strapi/design-system';
|
|
19
|
-
export const NavigationItemForm = ({ availableLocale, isLoading: isPreloading, current, onSubmit, onCancel, appendLabelPublicationStatus = appendLabelPublicationStatusFallback, locale, permissions = {}, currentNavigation, }) => {
|
|
20
|
-
const { formatMessage } = useIntl();
|
|
21
|
-
const [isLoading, setIsLoading] = useState(isPreloading);
|
|
22
|
-
const { canUpdate } = permissions;
|
|
23
|
-
const [isSingleSelected, setIsSingleSelected] = useState(false);
|
|
24
|
-
const [itemLocaleCopyValue, setItemLocaleCopyValue] = useState();
|
|
25
|
-
const configQuery = useConfig();
|
|
26
|
-
const availableAudiences = configQuery.data?.availableAudience ?? [];
|
|
27
|
-
const contentTypes = configQuery.data?.contentTypes ?? [];
|
|
28
|
-
const { control, watch, handleSubmit, setValue } = useNavigationItemForm({
|
|
29
|
-
input: {
|
|
30
|
-
isSingleSelected,
|
|
31
|
-
additionalFields: configQuery.data?.additionalFields ?? [],
|
|
32
|
-
},
|
|
33
|
-
current: current,
|
|
34
|
-
});
|
|
35
|
-
const { toggleNotification } = useNotification();
|
|
36
|
-
const copyItemFromLocaleMutation = useCopyNavigationItemI18n();
|
|
37
|
-
const navigationsQuery = useNavigations();
|
|
38
|
-
const submit = handleSubmit(async (payload) => {
|
|
39
|
-
const title = !!payload.title.trim()
|
|
40
|
-
? payload.title
|
|
41
|
-
: getDefaultTitle(payload.related, payload.relatedType, isSingleSelected);
|
|
42
|
-
setIsLoading(true);
|
|
43
|
-
const uiRouterKey = await generateUiRouterKey({
|
|
44
|
-
slugify: slugifyMutation.mutateAsync,
|
|
45
|
-
title,
|
|
46
|
-
related: payload.related,
|
|
47
|
-
relatedType: payload.relatedType,
|
|
48
|
-
});
|
|
49
|
-
slugifyMutation.reset();
|
|
50
|
-
setIsLoading(false);
|
|
51
|
-
if (!uiRouterKey) {
|
|
52
|
-
toggleNotification({
|
|
53
|
-
type: 'warning',
|
|
54
|
-
message: formatMessage(getTrad('popup.item.form.uiRouter.unableToRender')),
|
|
55
|
-
});
|
|
56
|
-
return;
|
|
57
|
-
}
|
|
58
|
-
onSubmit(payload.type === 'INTERNAL'
|
|
59
|
-
? {
|
|
60
|
-
...payload,
|
|
61
|
-
title,
|
|
62
|
-
uiRouterKey,
|
|
63
|
-
}
|
|
64
|
-
: {
|
|
65
|
-
...payload,
|
|
66
|
-
title,
|
|
67
|
-
uiRouterKey,
|
|
68
|
-
});
|
|
69
|
-
});
|
|
70
|
-
const initialRelatedTypeSelected = current.relatedType;
|
|
71
|
-
const [currentRelatedType, currentRelated, currentPath, currentType, currentTitle, autoSyncEnabled,] = watch(['relatedType', 'related', 'path', 'type', 'title', 'autoSync']);
|
|
72
|
-
const isExternal = currentType === 'EXTERNAL';
|
|
73
|
-
const pathSourceName = isExternal ? 'externalPath' : 'path';
|
|
74
|
-
const submitDisabled = (!isExternal && !isSingleSelected && isNil(currentRelated)) || isLoading;
|
|
75
|
-
const contentTypeItemsQuery = useContentTypeItems({
|
|
76
|
-
uid: currentRelatedType ?? '',
|
|
77
|
-
locale,
|
|
78
|
-
});
|
|
79
|
-
const slugifyMutation = useSlug();
|
|
80
|
-
const availableLocaleOptions = useMemo(() => availableLocale.map((locale, index) => ({
|
|
81
|
-
key: `${locale}-${index}`,
|
|
82
|
-
value: locale,
|
|
83
|
-
label: locale,
|
|
84
|
-
})), [availableLocale]);
|
|
85
|
-
const audienceOptions = useMemo(() => availableAudiences.map((item) => ({
|
|
86
|
-
value: item.id ?? 0,
|
|
87
|
-
label: item.name ?? ' ',
|
|
88
|
-
})), [availableAudiences]);
|
|
89
|
-
const getDefaultTitle = useCallback((related, relatedType, isSingleSelected) => {
|
|
90
|
-
let selectedEntity;
|
|
91
|
-
if (isSingleSelected) {
|
|
92
|
-
selectedEntity = contentTypeItemsQuery.data?.find((_) => _.uid === relatedType || _.__collectionUid === relatedType);
|
|
93
|
-
if (!selectedEntity) {
|
|
94
|
-
return contentTypes.find((_) => _.uid === relatedType)?.contentTypeName;
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
else {
|
|
98
|
-
const entity = contentTypeItemsQuery.data?.find(({ id }) => id === related);
|
|
99
|
-
selectedEntity = {
|
|
100
|
-
...(entity || {
|
|
101
|
-
id: -1,
|
|
102
|
-
}),
|
|
103
|
-
__collectionUid: relatedType,
|
|
104
|
-
};
|
|
105
|
-
}
|
|
106
|
-
return extractRelatedItemLabel(selectedEntity, configQuery.data);
|
|
107
|
-
}, [contentTypeItemsQuery.data, configQuery.data, contentTypes]);
|
|
108
|
-
const navigationItemTypeOptions = ['INTERNAL', 'EXTERNAL'].map((key) => {
|
|
109
|
-
return {
|
|
110
|
-
key,
|
|
111
|
-
value: key,
|
|
112
|
-
label: formatMessage(getTrad(`popup.item.form.type.${key.toLowerCase()}.label`)),
|
|
113
|
-
};
|
|
114
|
-
});
|
|
115
|
-
const relatedSelectOptions = sortBy(contentTypeItemsQuery.data?.map((item) => {
|
|
116
|
-
const label = appendLabelPublicationStatus(extractRelatedItemLabel({
|
|
117
|
-
...item,
|
|
118
|
-
__collectionUid: currentRelatedType,
|
|
119
|
-
}, configQuery.data), item, false);
|
|
120
|
-
return {
|
|
121
|
-
key: item?.id.toString(),
|
|
122
|
-
value: item.id.toString(),
|
|
123
|
-
label: label,
|
|
124
|
-
};
|
|
125
|
-
}) ?? [], (item) => item.key);
|
|
126
|
-
const relatedTypeSelectOptions = useMemo(() => sortBy(configQuery.data?.contentTypes
|
|
127
|
-
?.filter((contentType) => {
|
|
128
|
-
if (contentType.isSingle) {
|
|
129
|
-
return !!(currentRelatedType &&
|
|
130
|
-
[currentRelatedType, initialRelatedTypeSelected].includes(contentType.uid));
|
|
131
|
-
}
|
|
132
|
-
return true;
|
|
133
|
-
})
|
|
134
|
-
.map((item) => {
|
|
135
|
-
return {
|
|
136
|
-
key: item.uid,
|
|
137
|
-
value: item.uid,
|
|
138
|
-
label: item.contentTypeName,
|
|
139
|
-
};
|
|
140
|
-
}), (item) => item.key), [configQuery.data, currentRelatedType]);
|
|
141
|
-
const thereAreNoMoreContentTypes = isEmpty(relatedSelectOptions);
|
|
142
|
-
const onCopyFromLocale = useCallback(async (event) => {
|
|
143
|
-
event.preventDefault();
|
|
144
|
-
event.stopPropagation();
|
|
145
|
-
const source = navigationsQuery.data?.find(({ localeCode }) => localeCode === itemLocaleCopyValue);
|
|
146
|
-
if (source) {
|
|
147
|
-
setIsLoading(true);
|
|
148
|
-
copyItemFromLocaleMutation.mutate({
|
|
149
|
-
target: currentNavigation.id,
|
|
150
|
-
structureId: current.structureId,
|
|
151
|
-
source: source.id,
|
|
152
|
-
}, {
|
|
153
|
-
onSuccess(data) {
|
|
154
|
-
copyItemFromLocaleMutation.reset();
|
|
155
|
-
const { type, externalPath, path, related, title, uiRouterKey } = data;
|
|
156
|
-
const [contentType, id] = related?.split(RELATED_ITEM_SEPARATOR) ?? [];
|
|
157
|
-
setValue('type', type);
|
|
158
|
-
setValue('externalPath', externalPath ?? undefined);
|
|
159
|
-
setValue('path', path ?? undefined);
|
|
160
|
-
setValue('title', title);
|
|
161
|
-
setValue('uiRouterKey', uiRouterKey);
|
|
162
|
-
if (contentType && id) {
|
|
163
|
-
setValue('related', parseInt(id));
|
|
164
|
-
setValue('relatedType', contentType);
|
|
165
|
-
}
|
|
166
|
-
},
|
|
167
|
-
onSettled() {
|
|
168
|
-
setIsLoading(false);
|
|
169
|
-
},
|
|
170
|
-
});
|
|
171
|
-
}
|
|
172
|
-
}, [setIsLoading, copyItemFromLocaleMutation, navigationsQuery]);
|
|
173
|
-
useEffect(() => {
|
|
174
|
-
if (currentRelatedType) {
|
|
175
|
-
const relatedType = configQuery.data?.contentTypes.find((contentType) => contentType.uid === currentRelatedType);
|
|
176
|
-
if (relatedType) {
|
|
177
|
-
setIsSingleSelected(relatedType.isSingle);
|
|
178
|
-
if (relatedType.isSingle && contentTypeItemsQuery.data?.length) {
|
|
179
|
-
const nextRelated = contentTypeItemsQuery.data[0];
|
|
180
|
-
if (nextRelated) {
|
|
181
|
-
setValue('related', nextRelated.id);
|
|
182
|
-
}
|
|
183
|
-
}
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
}, [currentRelatedType, configQuery.data, contentTypeItemsQuery.data, setValue]);
|
|
187
|
-
useEffect(() => {
|
|
188
|
-
if (autoSyncEnabled &&
|
|
189
|
-
currentType === 'INTERNAL' &&
|
|
190
|
-
currentRelated &&
|
|
191
|
-
currentRelatedType &&
|
|
192
|
-
configQuery.data) {
|
|
193
|
-
const relatedItem = contentTypeItemsQuery.data?.find((item) => {
|
|
194
|
-
return item.id === currentRelated;
|
|
195
|
-
});
|
|
196
|
-
if (relatedItem) {
|
|
197
|
-
const { contentTypesNameFields, pathDefaultFields } = configQuery.data;
|
|
198
|
-
const nextPath = pathDefaultFields[currentRelatedType]?.reduce((acc, field) => {
|
|
199
|
-
return acc ? acc : relatedItem?.[field];
|
|
200
|
-
}, undefined);
|
|
201
|
-
const nextTitle = (contentTypesNameFields[currentRelatedType] ?? [])
|
|
202
|
-
.concat(contentTypesNameFields.default ?? [])
|
|
203
|
-
.reduce((acc, field) => {
|
|
204
|
-
return acc ? acc : relatedItem?.[field];
|
|
205
|
-
}, undefined);
|
|
206
|
-
const batch = [];
|
|
207
|
-
if (nextPath && nextPath !== currentPath) {
|
|
208
|
-
batch.push({ name: 'path', value: nextPath });
|
|
209
|
-
}
|
|
210
|
-
if (nextTitle && nextTitle !== currentTitle) {
|
|
211
|
-
batch.push({ name: 'title', value: nextTitle });
|
|
212
|
-
}
|
|
213
|
-
setTimeout(() => {
|
|
214
|
-
batch.forEach((next) => {
|
|
215
|
-
setValue(next.name, next.value);
|
|
216
|
-
});
|
|
217
|
-
}, 100);
|
|
218
|
-
}
|
|
219
|
-
}
|
|
220
|
-
}, [
|
|
221
|
-
currentTitle,
|
|
222
|
-
currentPath,
|
|
223
|
-
autoSyncEnabled,
|
|
224
|
-
currentType,
|
|
225
|
-
currentRelated,
|
|
226
|
-
currentRelatedType,
|
|
227
|
-
configQuery.data,
|
|
228
|
-
contentTypeItemsQuery.data,
|
|
229
|
-
]);
|
|
230
|
-
return (_jsxs(_Fragment, { children: [_jsxs(Modal.Body, { children: [_jsxs(Grid.Root, { gap: 5, children: [_jsx(Grid.Item, { alignItems: "flex-start", col: 12, children: _jsx(Controller, { control: control, name: "title", render: ({ field: { value, onChange, name }, fieldState }) => (_jsxs(Field.Root, { width: "100%", error: fieldState.error?.message, hint: formatMessage(getTrad('popup.item.form.title.placeholder', 'e.g. Blog')), children: [_jsx(Field.Label, { children: formatMessage(getTrad('popup.item.form.title.label', 'Title')) }), _jsx(TextInput, { type: "string", disabled: !canUpdate, name: name, onChange: onChange, value: value }), _jsx(Field.Hint, {}), _jsx(Field.Error, {})] })) }) }, "title"), _jsx(Grid.Item, { alignItems: "flex-start", col: currentType === 'INTERNAL' ? 4 : 7, lg: 12, children: _jsx(Controller, { control: control, name: "type", render: ({ field: { value, onChange, name }, fieldState }) => (_jsxs(Field.Root, { error: fieldState.error?.message, hint: formatMessage(getTrad('popup.item.form.title.placeholder', 'e.g. Blog')), width: "100%", children: [_jsx(Field.Label, { children: formatMessage(getTrad('popup.item.form.type.label', 'Internal link')) }), _jsx(SingleSelect, { onChange: onChange, value: value, name: name, disabled: !configQuery.data?.contentTypes.length || !canUpdate, width: "100%", children: navigationItemTypeOptions.map(({ key, label, value }) => (_jsx(SingleSelectOption, { value: value, children: label }, key))) }), _jsx(Field.Hint, {}), _jsx(Field.Error, {})] })) }) }, "type"), _jsx(Grid.Item, { alignItems: "flex-start", col: currentType === 'INTERNAL' ? 4 : 5, lg: 12, children: _jsx(Controller, { control: control, name: "menuAttached", render: ({ field: { value, onChange, name }, fieldState }) => (_jsxs(Field.Root, { width: "100%", error: fieldState.error?.message, hint: formatMessage(getTrad('popup.item.form.menuAttached.placeholder', 'is menu item attached to menu')), children: [_jsx(Field.Label, { children: formatMessage(getTrad('popup.item.form.menuAttached.label', 'MenuAttached')) }), _jsx(Toggle, { name: name, checked: value, onChange: ({ currentTarget: { checked }, }) => {
|
|
231
|
-
onChange(checked);
|
|
232
|
-
}, value: value, onLabel: "true", offLabel: "false", disabled: !canUpdate ||
|
|
233
|
-
(configQuery.data?.cascadeMenuAttached
|
|
234
|
-
? !(current.isMenuAllowedLevel && current.parentAttachedToMenu)
|
|
235
|
-
: false), width: "100%" }), _jsx(Field.Hint, {}), _jsx(Field.Error, {})] })) }) }, "menuAttached"), currentType === 'INTERNAL' && (_jsx(Grid.Item, { alignItems: "flex-start", col: 4, lg: 12, children: _jsx(Controller, { control: control, name: "autoSync", render: ({ field: { value, onChange, name }, fieldState }) => (_jsxs(Field.Root, { error: fieldState.error?.message, width: "230px", children: [_jsx(Field.Label, { children: formatMessage(getTrad('popup.item.form.autoSync.label', 'Read fields from related')) }), _jsx(Toggle, { name: name, checked: value, onChange: ({ currentTarget: { checked }, }) => {
|
|
236
|
-
onChange(checked);
|
|
237
|
-
}, onLabel: "Enabled", offLabel: "Disabled" }), _jsx(Field.Error, {})] })) }) }, "autoSync")), _jsx(Grid.Item, { alignItems: "flex-start", col: 12, children: _jsx(Controller, { control: control, name: pathSourceName, render: ({ field: { value, onChange, name }, fieldState }) => {
|
|
238
|
-
const pathDefault = generatePreviewPath({
|
|
239
|
-
currentPath,
|
|
240
|
-
isExternal,
|
|
241
|
-
current,
|
|
242
|
-
currentType,
|
|
243
|
-
config: configQuery.data,
|
|
244
|
-
contentTypeItems: contentTypeItemsQuery.data,
|
|
245
|
-
currentRelated,
|
|
246
|
-
currentRelatedType,
|
|
247
|
-
isSingleSelected,
|
|
248
|
-
});
|
|
249
|
-
return (_jsxs(Field.Root, { error: fieldState.error?.message, hint: [
|
|
250
|
-
formatMessage(getTrad(`popup.item.form.${pathSourceName}.placeholder`, 'e.g. Blog')),
|
|
251
|
-
pathDefault
|
|
252
|
-
? formatMessage(getTrad('popup.item.form.type.external.description'), {
|
|
253
|
-
value: pathDefault,
|
|
254
|
-
})
|
|
255
|
-
: '',
|
|
256
|
-
].join(' '), width: "100%", children: [_jsx(Field.Label, { children: formatMessage(getTrad(`popup.item.form.${pathSourceName}.label`, 'Path')) }), _jsx(TextInput, { disabled: !canUpdate, name: name, onChange: onChange, value: value, width: "100%" }), _jsx(Field.Hint, {}), _jsx(Field.Error, {})] }));
|
|
257
|
-
} }) }, "path"), currentType === 'INTERNAL' && (_jsxs(_Fragment, { children: [_jsx(Grid.Item, { alignItems: "flex-start", col: 6, lg: 12, children: _jsx(Controller, { control: control, name: "relatedType", render: ({ field: { value, onChange, name }, fieldState }) => (_jsxs(Field.Root, { width: "100%", error: fieldState.error?.message, hint: !isLoading && isEmpty(relatedTypeSelectOptions)
|
|
258
|
-
? formatMessage(getTrad('popup.item.form.relatedType.empty', 'There are no more content types'))
|
|
259
|
-
: undefined, children: [_jsx(Field.Label, { children: formatMessage(getTrad('popup.item.form.relatedType.label', 'Related Type')) }), _jsx(SingleSelect, { name: name, onChange: (nextType) => {
|
|
260
|
-
onChange(nextType);
|
|
261
|
-
setValue('related', undefined);
|
|
262
|
-
}, value: value, disabled: !configQuery.data?.contentTypes.length || !canUpdate, width: "100%", children: configQuery.data?.contentTypes.map((contentType) => (_jsx(SingleSelectOption, { value: contentType.uid, children: contentType.contentTypeName }, contentType.uid))) }), _jsx(Field.Hint, {}), _jsx(Field.Error, {})] })) }) }), currentRelatedType && !isSingleSelected && (_jsx(Grid.Item, { alignItems: "flex-start", col: 6, lg: 12, children: _jsx(Controller, { control: control, name: "related", render: ({ field: { value, onChange, name }, fieldState }) => (_jsxs(Field.Root, { error: fieldState.error?.message, hint: !isLoading && thereAreNoMoreContentTypes
|
|
263
|
-
? formatMessage(getTrad('popup.item.form.related.empty', 'There are no more entities'), { contentTypeName: currentRelatedType })
|
|
264
|
-
: undefined, width: "100%", children: [_jsx(Field.Label, { children: formatMessage(getTrad('popup.item.form.related.label', 'Related')) }), _jsx(SingleSelect, { name: name, onChange: (next) => {
|
|
265
|
-
onChange(parseInt(next, 10));
|
|
266
|
-
}, value: value, options: relatedSelectOptions, disabled: isLoading || thereAreNoMoreContentTypes || !canUpdate, width: "100%", children: relatedSelectOptions.map(({ key, label, value }) => (_jsx(SingleSelectOption, { value: value, children: label }, key))) }), _jsx(Field.Hint, {}), _jsx(Field.Error, {})] })) }) }))] })), configQuery.data?.additionalFields.map((additionalField) => {
|
|
267
|
-
if (additionalField === 'audience') {
|
|
268
|
-
return (_jsx(Grid.Item, { alignItems: "flex-start", col: 6, lg: 12, children: _jsx(Controller, { control: control, name: "audience", render: ({ field: { value, onChange, name }, fieldState }) => (_jsxs(Field.Root, { error: fieldState.error?.message, hint: !isLoading && isEmpty(audienceOptions)
|
|
269
|
-
? formatMessage(getTrad('popup.item.form.title.placeholder', 'e.g. Blog'))
|
|
270
|
-
: undefined, width: "100%", children: [_jsx(Field.Label, { children: formatMessage(getTrad('popup.item.form.audience.label')) }), _jsx(MultiSelect, { name: name, value: value?.map((x) => x.toString()), onChange: (next) => onChange(next.map(Number)), width: "100%", children: audienceOptions.map(({ value, label }) => (_jsx(MultiSelectOption, { value: value.toString(), children: label }, value))) }), _jsx(Field.Hint, {}), _jsx(Field.Error, {})] })) }) }, "audience"));
|
|
271
|
-
}
|
|
272
|
-
else {
|
|
273
|
-
return (_jsxs(Grid.Item, { alignItems: "flex-start", col: 6, lg: 12, children: [additionalField.name, _jsx(Controller, { control: control, name: `additionalFields.${additionalField.name}`, render: ({ field: { value, onChange }, fieldState }) => (_jsxs(Field.Root, { error: fieldState.error?.message, children: [_jsx(AdditionalFieldInput, { field: additionalField, isLoading: isLoading, onChange: onChange, value: value, disabled: !canUpdate }), _jsx(Field.Error, {})] })) })] }, additionalField.name));
|
|
274
|
-
}
|
|
275
|
-
})] }), availableLocaleOptions && (availableLocaleOptions.length > 1) && (_jsxs(_Fragment, { children: [_jsx(Divider, { marginTop: 5, marginBottom: 5 }), _jsxs(Grid.Root, { gap: 5, children: [_jsx(Grid.Item, { alignItems: "flex-start", col: 6, lg: 12, children: _jsxs(Field.Root, { width: "100%", children: [_jsx(Field.Label, { children: formatMessage(getTrad('popup.item.form.i18n.locale.label', 'Copy details from')) }), _jsx(SingleSelect, { name: "i18n.locale", onChange: setItemLocaleCopyValue, value: itemLocaleCopyValue, disabled: isLoading || !canUpdate, placeholder: formatMessage(getTrad('popup.item.form.i18n.locale.placeholder', 'locale')), children: availableLocaleOptions.map(({ key, label, value }) => (_jsx(SingleSelectOption, { value: value, children: label }, key))) })] }) }), canUpdate && (_jsx(Grid.Item, { alignItems: "flex-start", col: 6, lg: 12, paddingTop: 6, children: _jsx(Box, { children: _jsx(Button, { variant: "tertiary", onClick: onCopyFromLocale, disabled: isLoading || !itemLocaleCopyValue, children: formatMessage(getTrad('popup.item.form.i18n.locale.button')) }) }) }))] })] }))] }), _jsx(NavigationItemPopupFooter, { handleSubmit: submit, handleCancel: onCancel, submitDisabled: submitDisabled, canUpdate: canUpdate })] }));
|
|
276
|
-
};
|
|
277
|
-
const appendLabelPublicationStatusFallback = () => '';
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
import { zodResolver } from '@hookform/resolvers/zod';
|
|
2
|
-
import { useForm } from 'react-hook-form';
|
|
3
|
-
import { z } from 'zod';
|
|
4
|
-
const externalPathRegexps = [
|
|
5
|
-
/^mailto:[\w-\.]+@([\w-]+\.)+[\w-]{2,}$/,
|
|
6
|
-
/^tel:(\+\d{1,3})?[\s]?(\(?\d{2,3}\)?)?[\s.-]?(\d{3})?[\s.-]?\d{3,4}$/,
|
|
7
|
-
/^#.*/,
|
|
8
|
-
/(https?:\/\/(?:www\.|(?!www))[a-zA-Z0-9][a-zA-Z0-9-]+[a-zA-Z0-9]\.[^\s]{2,}|www\.[a-zA-Z0-9][a-zA-Z0-9-]+[a-zA-Z0-9]\.[^\s]{2,}|https?:\/\/(?:www\.|(?!www))[a-zA-Z0-9]+\.[^\s]{2,}|www\.[a-zA-Z0-9]+\.[^\s]{2,})/,
|
|
9
|
-
];
|
|
10
|
-
const navigationItemCommon = ({ additionalFields }) => z.object({
|
|
11
|
-
title: z.string(),
|
|
12
|
-
autoSync: z.boolean().optional(),
|
|
13
|
-
removed: z.boolean().optional(),
|
|
14
|
-
updated: z.boolean().optional(),
|
|
15
|
-
uiRouterKey: z.string(),
|
|
16
|
-
levelPath: z.string().optional(),
|
|
17
|
-
isMenuAllowedLevel: z.boolean().optional(),
|
|
18
|
-
parentAttachedToMenu: z.boolean().optional(),
|
|
19
|
-
viewId: z.number().optional(),
|
|
20
|
-
structureId: z.string().optional(),
|
|
21
|
-
menuAttached: z.boolean().optional(),
|
|
22
|
-
collapsed: z.boolean().optional(),
|
|
23
|
-
isSearchActive: z.boolean().optional(),
|
|
24
|
-
viewParentId: z.number().optional(),
|
|
25
|
-
id: z.number().optional(),
|
|
26
|
-
audience: z.number().array().optional(),
|
|
27
|
-
order: z.number().optional(),
|
|
28
|
-
items: z.any().array().optional(),
|
|
29
|
-
additionalFields: z.object(additionalFields.reduce((acc, field) => {
|
|
30
|
-
if (typeof field === 'string') {
|
|
31
|
-
return acc;
|
|
32
|
-
}
|
|
33
|
-
switch (field.type) {
|
|
34
|
-
case 'string':
|
|
35
|
-
acc[field.name] = field.required ? z.string() : z.string().optional();
|
|
36
|
-
break;
|
|
37
|
-
case 'boolean':
|
|
38
|
-
acc[field.name] = field.required ? z.boolean() : z.boolean().optional();
|
|
39
|
-
case 'media':
|
|
40
|
-
acc[field.name] = field.required ? z.any() : z.any().optional();
|
|
41
|
-
case 'select': {
|
|
42
|
-
if (field.multi) {
|
|
43
|
-
acc[field.name] = field.required ? z.string().array() : z.string().array().optional();
|
|
44
|
-
}
|
|
45
|
-
else {
|
|
46
|
-
acc[field.name] = field.required ? z.string() : z.string().optional();
|
|
47
|
-
}
|
|
48
|
-
break;
|
|
49
|
-
}
|
|
50
|
-
default:
|
|
51
|
-
break;
|
|
52
|
-
}
|
|
53
|
-
return acc;
|
|
54
|
-
}, {})),
|
|
55
|
-
});
|
|
56
|
-
const navigationInternalItemFormSchema = ({ additionalFields, isSingleSelected, }) => navigationItemCommon({
|
|
57
|
-
additionalFields,
|
|
58
|
-
isSingleSelected,
|
|
59
|
-
}).extend({
|
|
60
|
-
type: z.literal('INTERNAL'),
|
|
61
|
-
path: z.string(),
|
|
62
|
-
externalPath: z.string().optional(),
|
|
63
|
-
relatedType: z.string(),
|
|
64
|
-
related: isSingleSelected ? z.number().optional() : z.number(),
|
|
65
|
-
});
|
|
66
|
-
const navigationExternalItemFormSchema = ({ isSingleSelected, additionalFields, }) => navigationItemCommon({
|
|
67
|
-
additionalFields,
|
|
68
|
-
isSingleSelected,
|
|
69
|
-
}).extend({
|
|
70
|
-
type: z.literal('EXTERNAL'),
|
|
71
|
-
path: z.string().or(z.null()).optional(),
|
|
72
|
-
externalPath: z
|
|
73
|
-
.string()
|
|
74
|
-
.min(1)
|
|
75
|
-
.refine((path) => externalPathRegexps.some((re) => re.test(path))),
|
|
76
|
-
relatedType: z.string().optional(),
|
|
77
|
-
related: z.number().optional(),
|
|
78
|
-
});
|
|
79
|
-
const navigationItemFormSchema = (input) => z.discriminatedUnion('type', [
|
|
80
|
-
navigationExternalItemFormSchema(input),
|
|
81
|
-
navigationInternalItemFormSchema(input),
|
|
82
|
-
]);
|
|
83
|
-
export const useNavigationItemForm = ({ input, current = defaultValues, }) => {
|
|
84
|
-
return useForm({
|
|
85
|
-
resolver: zodResolver(navigationItemFormSchema(input)),
|
|
86
|
-
values: {
|
|
87
|
-
...defaultValues,
|
|
88
|
-
...current,
|
|
89
|
-
updated: !!current.id,
|
|
90
|
-
},
|
|
91
|
-
});
|
|
92
|
-
};
|
|
93
|
-
export const defaultValues = {
|
|
94
|
-
autoSync: true,
|
|
95
|
-
type: 'INTERNAL',
|
|
96
|
-
relatedType: '',
|
|
97
|
-
menuAttached: false,
|
|
98
|
-
title: '',
|
|
99
|
-
externalPath: '',
|
|
100
|
-
path: '',
|
|
101
|
-
additionalFields: {},
|
|
102
|
-
audience: [],
|
|
103
|
-
updated: false,
|
|
104
|
-
uiRouterKey: '',
|
|
105
|
-
};
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { getFetchClient } from '@strapi/strapi/admin';
|
|
2
|
-
import { useMutation } from '@tanstack/react-query';
|
|
3
|
-
import { getApiClient } from '../../../../../api';
|
|
4
|
-
export const useSlug = () => {
|
|
5
|
-
const fetch = getFetchClient();
|
|
6
|
-
const apiClient = getApiClient(fetch);
|
|
7
|
-
return useMutation({
|
|
8
|
-
mutationFn(query) {
|
|
9
|
-
return apiClient.slugify(query);
|
|
10
|
-
},
|
|
11
|
-
});
|
|
12
|
-
};
|
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
import { first, isEmpty } from 'lodash';
|
|
2
|
-
import { extractRelatedItemLabel } from '../../../../HomePage/utils';
|
|
3
|
-
export const generateUiRouterKey = async ({ slugify, title, config, related, relatedType, contentTypeItems, }) => {
|
|
4
|
-
if (title) {
|
|
5
|
-
return title ? await slugify(title) : undefined;
|
|
6
|
-
}
|
|
7
|
-
else if (related) {
|
|
8
|
-
const relationTitle = extractRelatedItemLabel({
|
|
9
|
-
...(contentTypeItems?.find((_) => _.id === related) ?? {
|
|
10
|
-
id: -1,
|
|
11
|
-
}),
|
|
12
|
-
__collectionUid: relatedType,
|
|
13
|
-
}, config);
|
|
14
|
-
return relationTitle ? await slugify(relationTitle) : undefined;
|
|
15
|
-
}
|
|
16
|
-
return undefined;
|
|
17
|
-
};
|
|
18
|
-
export const getDefaultPath = ({ currentType, config, contentTypeItems, currentRelated, currentRelatedType, isSingleSelected, }) => {
|
|
19
|
-
if (currentType !== 'INTERNAL')
|
|
20
|
-
return '';
|
|
21
|
-
if (!currentRelatedType) {
|
|
22
|
-
return '';
|
|
23
|
-
}
|
|
24
|
-
const pathDefaultFields = config?.pathDefaultFields[currentRelatedType] ?? [];
|
|
25
|
-
if (isEmpty(currentType) && !isEmpty(pathDefaultFields)) {
|
|
26
|
-
const selectedEntity = isSingleSelected
|
|
27
|
-
? first(contentTypeItems ?? [])
|
|
28
|
-
: contentTypeItems?.find(({ id }) => id === currentRelated);
|
|
29
|
-
const pathDefaultValues = pathDefaultFields
|
|
30
|
-
.map((field) => selectedEntity?.[field] ?? '')
|
|
31
|
-
.filter((value) => !!value.toString().trim());
|
|
32
|
-
return pathDefaultValues[0] ?? '';
|
|
33
|
-
}
|
|
34
|
-
return '';
|
|
35
|
-
};
|
|
36
|
-
export const generatePreviewPath = ({ currentPath, isExternal, current, currentType, config, contentTypeItems, currentRelated, currentRelatedType, isSingleSelected, }) => {
|
|
37
|
-
if (!isExternal) {
|
|
38
|
-
const itemPath = isEmpty(currentPath) || currentPath === '/'
|
|
39
|
-
? getDefaultPath({
|
|
40
|
-
currentType,
|
|
41
|
-
config,
|
|
42
|
-
contentTypeItems,
|
|
43
|
-
currentRelated,
|
|
44
|
-
currentRelatedType,
|
|
45
|
-
isSingleSelected,
|
|
46
|
-
})
|
|
47
|
-
: currentPath || '';
|
|
48
|
-
return `${current.levelPath !== '/' ? `${current.levelPath}` : ''}/${itemPath}`;
|
|
49
|
-
}
|
|
50
|
-
return undefined;
|
|
51
|
-
};
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import styled from 'styled-components';
|
|
2
|
-
const Wrapper = styled.div `
|
|
3
|
-
position: relative;
|
|
4
|
-
${({ level, theme }) => level &&
|
|
5
|
-
`
|
|
6
|
-
&::before {
|
|
7
|
-
content: "";
|
|
8
|
-
display: block;
|
|
9
|
-
height: ${theme.spaces[3]};
|
|
10
|
-
width: 19px;
|
|
11
|
-
|
|
12
|
-
position: absolute;
|
|
13
|
-
top: -${theme.spaces[2]};
|
|
14
|
-
left: 30px;
|
|
15
|
-
|
|
16
|
-
border: 0px solid transparent;
|
|
17
|
-
border-left: 4px solid ${theme.colors.neutral300};
|
|
18
|
-
}
|
|
19
|
-
`};
|
|
20
|
-
`;
|
|
21
|
-
export default Wrapper;
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
-
import { Item, } from '../NavigationItemListItem';
|
|
3
|
-
import Wrapper from './Wrapper';
|
|
4
|
-
export const List = ({ isParentAttachedToMenu = false, items, level = 0, levelPath = '', onItemEdit, onItemLevelAdd, onItemRemove, onItemRestore, onItemReOrder, onItemToggleCollapse, displayFlat, permissions, structurePrefix, viewParentId, }) => (_jsx(Wrapper, { "data-level": level, children: items?.map((item, index) => {
|
|
5
|
-
return (_jsx(Item, { item: item, isLast: index === items.length - 1, level: level, levelPath: levelPath, isParentAttachedToMenu: isParentAttachedToMenu, onItemRestore: onItemRestore, onItemLevelAdd: onItemLevelAdd, onItemRemove: onItemRemove, onItemEdit: onItemEdit, onItemReOrder: onItemReOrder, onItemToggleCollapse: onItemToggleCollapse, displayChildren: displayFlat, permissions: permissions, structureId: structurePrefix ? `${structurePrefix}.${index}` : index.toString(), viewParentId: viewParentId }, `list-item-${item.viewId || index}`));
|
|
6
|
-
}) }));
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import { Badge } from '@strapi/design-system';
|
|
2
|
-
import styled from 'styled-components';
|
|
3
|
-
export const ItemCardBadge = styled(Badge) `
|
|
4
|
-
border: 1px solid ${({ theme, borderColor }) => theme.colors[borderColor]};
|
|
5
|
-
|
|
6
|
-
${({ small, theme }) => small &&
|
|
7
|
-
`
|
|
8
|
-
padding: ${theme.spaces[1]} ${theme.spaces[2]};
|
|
9
|
-
margin: 0px ${theme.spaces[3]};
|
|
10
|
-
vertical-align: middle;
|
|
11
|
-
|
|
12
|
-
cursor: default;
|
|
13
|
-
|
|
14
|
-
span {
|
|
15
|
-
font-size: .65rem;
|
|
16
|
-
line-height: 1;
|
|
17
|
-
vertical-align: middle;
|
|
18
|
-
}
|
|
19
|
-
`}
|
|
20
|
-
`;
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { CardTitle } from '@strapi/design-system';
|
|
2
|
-
import styled from 'styled-components';
|
|
3
|
-
export const CardItemTitle = styled(CardTitle) `
|
|
4
|
-
width: 100%;
|
|
5
|
-
|
|
6
|
-
display: flex;
|
|
7
|
-
flex-direction: row;
|
|
8
|
-
justify-content: space-between;
|
|
9
|
-
align-items: center;
|
|
10
|
-
|
|
11
|
-
> div > * {
|
|
12
|
-
margin: 0px ${({ theme }) => theme.spaces[1]};
|
|
13
|
-
}
|
|
14
|
-
`;
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
-
import { Eye, Pencil, Trash, Typhoon } from '@strapi/icons';
|
|
3
|
-
export const pencilIcon = _jsx(Pencil, {});
|
|
4
|
-
export const refreshIcon = _jsx(Typhoon, {});
|
|
5
|
-
export const trashIcon = _jsx(Trash, {});
|
|
6
|
-
export const eyeIcon = _jsx(Eye, {});
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
-
import { IconButton as BaseIconButton, Flex, Typography } from '@strapi/design-system';
|
|
3
|
-
import { useIntl } from 'react-intl';
|
|
4
|
-
import styled from 'styled-components';
|
|
5
|
-
import { getTrad } from '../../../../../translations';
|
|
6
|
-
import DragButton from '../../DragButton';
|
|
7
|
-
import { ItemCardBadge } from '../ItemCardBadge';
|
|
8
|
-
import { CardItemTitle } from './Wrapper';
|
|
9
|
-
import { eyeIcon, pencilIcon, refreshIcon, trashIcon } from './icons';
|
|
10
|
-
const wrapperStyle = { zIndex: 2 };
|
|
11
|
-
const pathWrapperStyle = { maxWidth: '425px' };
|
|
12
|
-
export const ItemCardHeader = ({ title, path, icon, removed, canUpdate, onItemRemove, onItemEdit, onItemRestore, dragRef, isSearchActive, }) => {
|
|
13
|
-
const { formatMessage } = useIntl();
|
|
14
|
-
return (_jsxs(CardItemTitle, { children: [_jsxs(Flex, { alignItems: "center", children: [canUpdate && _jsx(DragButton, { ref: dragRef, isActive: isSearchActive }), _jsx(Typography, { variant: "omega", fontWeight: "bold", children: title }), _jsx(Typography, { variant: "omega", fontWeight: "bold", textColor: "neutral500", ellipsis: true, style: pathWrapperStyle, children: path }), _jsx(Flex, { children: icon })] }), _jsxs(Flex, { alignItems: "center", style: wrapperStyle, children: [removed && (_jsx(ItemCardBadge, { borderColor: "danger200", backgroundColor: "danger100", textColor: "danger600", children: formatMessage(getTrad('components.navigationItem.badge.removed')) })), _jsx(IconButton, { isActive: isSearchActive, disabled: removed, onClick: onItemEdit, label: formatMessage(getTrad(`components.navigationItem.action.${canUpdate ? 'edit' : 'view'}`, canUpdate ? 'Edit' : 'View')), children: canUpdate ? pencilIcon : eyeIcon }), canUpdate && (_jsx(_Fragment, { children: removed ? (_jsx(IconButton, { isActive: isSearchActive, onClick: onItemRestore, label: formatMessage(getTrad('components.navigationItem.action.restore', 'Restore')), children: refreshIcon })) : (_jsx(IconButton, { isActive: isSearchActive, onClick: onItemRemove, label: formatMessage(getTrad('components.navigationItem.action.remove', 'Remove')), children: trashIcon })) }))] })] }));
|
|
15
|
-
};
|
|
16
|
-
const IconButton = styled(BaseIconButton) `
|
|
17
|
-
transition: background-color 0.3s ease-in;
|
|
18
|
-
${({ isActive, theme }) => (isActive ? `background-color: ${theme.colors.neutral150} ;` : '')}
|
|
19
|
-
`;
|