@vendure/admin-ui 2.1.1 → 2.1.3
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/catalog/catalog.module.d.ts +1 -0
- package/core/common/generated-types.d.ts +2 -1
- package/core/common/version.d.ts +1 -1
- package/core/extension/add-nav-menu-item.d.ts +5 -1
- package/customer/customer.module.d.ts +1 -2
- package/esm2022/catalog/catalog.module.mjs +6 -1
- package/esm2022/catalog/components/create-product-variant-dialog/create-product-variant-dialog.component.mjs +2 -2
- package/esm2022/core/common/generated-types.mjs +1 -1
- package/esm2022/core/common/version.mjs +2 -2
- package/esm2022/core/data/utils/add-custom-fields.mjs +5 -1
- package/esm2022/core/extension/add-nav-menu-item.mjs +6 -2
- package/esm2022/core/extension/register-route-component.mjs +10 -2
- package/esm2022/core/providers/alerts/alerts.service.mjs +1 -1
- package/esm2022/core/shared/components/radio-card/radio-card-fieldset.component.mjs +2 -2
- package/esm2022/core/shared/components/tabbed-custom-fields/tabbed-custom-fields.component.mjs +2 -2
- package/esm2022/customer/components/customer-detail/customer-detail.component.mjs +3 -3
- package/esm2022/customer/customer.module.mjs +6 -3
- package/esm2022/login/components/login/login.component.mjs +12 -7
- package/esm2022/marketing/components/promotion-list/promotion-list.component.mjs +3 -3
- package/esm2022/marketing/marketing.module.mjs +6 -2
- package/esm2022/order/order.module.mjs +6 -2
- package/esm2022/react/react-hooks/use-query.mjs +2 -2
- package/esm2022/react/register-react-data-table-component.mjs +3 -3
- package/esm2022/settings/components/channel-list/channel-list-bulk-actions.mjs +11 -4
- package/esm2022/settings/settings.module.mjs +6 -2
- package/esm2022/system/system.module.mjs +1 -1
- package/fesm2022/vendure-admin-ui-catalog.mjs +6 -1
- package/fesm2022/vendure-admin-ui-catalog.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-core.mjs +23 -7
- package/fesm2022/vendure-admin-ui-core.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-customer.mjs +7 -4
- package/fesm2022/vendure-admin-ui-customer.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-login.mjs +11 -6
- package/fesm2022/vendure-admin-ui-login.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-marketing.mjs +7 -3
- package/fesm2022/vendure-admin-ui-marketing.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-order.mjs +5 -1
- package/fesm2022/vendure-admin-ui-order.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-react.mjs +3 -3
- package/fesm2022/vendure-admin-ui-react.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-settings.mjs +13 -2
- package/fesm2022/vendure-admin-ui-settings.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-system.mjs.map +1 -1
- package/login/components/login/login.component.d.ts +7 -3
- package/marketing/marketing.module.d.ts +1 -1
- package/order/order.module.d.ts +1 -1
- package/package.json +2 -2
- package/react/react-hooks/use-query.d.ts +8 -0
- package/react/register-react-data-table-component.d.ts +4 -4
- package/settings/settings.module.d.ts +1 -1
- package/static/styles/global/_overrides.scss +4 -0
- package/static/theme.min.css +1 -1
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
// Auto-generated by the set-version.js script.
|
|
2
|
-
export const ADMIN_UI_VERSION = '2.1.
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
export const ADMIN_UI_VERSION = '2.1.3';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvY29yZS9zcmMvY29tbW9uL3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsK0NBQStDO0FBQy9DLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLE9BQU8sQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIEF1dG8tZ2VuZXJhdGVkIGJ5IHRoZSBzZXQtdmVyc2lvbi5qcyBzY3JpcHQuXG5leHBvcnQgY29uc3QgQURNSU5fVUlfVkVSU0lPTiA9ICcyLjEuMyc7XG4iXX0=
|
|
@@ -12,6 +12,10 @@ export function addCustomFields(documentNode, customFields) {
|
|
|
12
12
|
// so we treat it as an alias
|
|
13
13
|
entityType = 'Address';
|
|
14
14
|
}
|
|
15
|
+
if (entityType === 'Country') {
|
|
16
|
+
// Country is an alias of Region
|
|
17
|
+
entityType = 'Region';
|
|
18
|
+
}
|
|
15
19
|
const customFieldsForType = customFields[entityType];
|
|
16
20
|
if (customFieldsForType && customFieldsForType.length) {
|
|
17
21
|
fragmentDef.selectionSet.selections.push({
|
|
@@ -77,4 +81,4 @@ function isFragmentDefinition(value) {
|
|
|
77
81
|
function isFieldNode(value) {
|
|
78
82
|
return value.kind === Kind.FIELD;
|
|
79
83
|
}
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-custom-fields.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/data/utils/add-custom-fields.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    DefinitionNode,\r\n    DocumentNode,\r\n    FieldNode,\r\n    FragmentDefinitionNode,\r\n    Kind,\r\n    SelectionNode,\r\n} from 'graphql';\r\n\r\nimport { CustomFields, RelationCustomFieldFragment } from '../../common/generated-types';\r\n\r\n/**\r\n * Given a GraphQL AST (DocumentNode), this function looks for fragment definitions and adds and configured\r\n * custom fields to those fragments.\r\n */\r\nexport function addCustomFields(documentNode: DocumentNode, customFields: CustomFields): DocumentNode {\r\n    const fragmentDefs = documentNode.definitions.filter(isFragmentDefinition);\r\n\r\n    for (const fragmentDef of fragmentDefs) {\r\n        let entityType = fragmentDef.typeCondition.name.value as keyof Pick<\r\n            CustomFields,\r\n            Exclude<keyof CustomFields, '__typename'>\r\n        >;\r\n\r\n        if (entityType === ('OrderAddress' as any)) {\r\n            // OrderAddress is a special case of the Address entity, and shares its custom fields\r\n            // so we treat it as an alias\r\n            entityType = 'Address';\r\n        }\r\n\r\n        const customFieldsForType = customFields[entityType];\r\n        if (customFieldsForType && customFieldsForType.length) {\r\n            (fragmentDef.selectionSet.selections as SelectionNode[]).push({\r\n                name: {\r\n                    kind: Kind.NAME,\r\n                    value: 'customFields',\r\n                },\r\n                kind: Kind.FIELD,\r\n                selectionSet: {\r\n                    kind: Kind.SELECTION_SET,\r\n                    selections: customFieldsForType.map(\r\n                        customField =>\r\n                            ({\r\n                                kind: Kind.FIELD,\r\n                                name: {\r\n                                    kind: Kind.NAME,\r\n                                    value: customField.name,\r\n                                },\r\n                                // For \"relation\" custom fields, we need to also select\r\n                                // all the scalar fields of the related type\r\n                                ...(customField.type === 'relation'\r\n                                    ? {\r\n                                          selectionSet: {\r\n                                              kind: Kind.SELECTION_SET,\r\n                                              selections: (\r\n                                                  customField as RelationCustomFieldFragment\r\n                                              ).scalarFields.map(f => ({\r\n                                                  kind: Kind.FIELD,\r\n                                                  name: { kind: Kind.NAME, value: f },\r\n                                              })),\r\n                                          },\r\n                                      }\r\n                                    : {}),\r\n                            } as FieldNode),\r\n                    ),\r\n                },\r\n            });\r\n\r\n            const localizedFields = customFieldsForType.filter(\r\n                field => field.type === 'localeString' || field.type === 'localeText',\r\n            );\r\n\r\n            const translationsField = fragmentDef.selectionSet.selections\r\n                .filter(isFieldNode)\r\n                .find(field => field.name.value === 'translations');\r\n\r\n            if (localizedFields.length && translationsField && translationsField.selectionSet) {\r\n                (translationsField.selectionSet.selections as SelectionNode[]).push({\r\n                    name: {\r\n                        kind: Kind.NAME,\r\n                        value: 'customFields',\r\n                    },\r\n                    kind: Kind.FIELD,\r\n                    selectionSet: {\r\n                        kind: Kind.SELECTION_SET,\r\n                        selections: localizedFields.map(\r\n                            customField =>\r\n                                ({\r\n                                    kind: Kind.FIELD,\r\n                                    name: {\r\n                                        kind: Kind.NAME,\r\n                                        value: customField.name,\r\n                                    },\r\n                                } as FieldNode),\r\n                        ),\r\n                    },\r\n                });\r\n            }\r\n        }\r\n    }\r\n\r\n    return documentNode;\r\n}\r\n\r\nfunction isFragmentDefinition(value: DefinitionNode): value is FragmentDefinitionNode {\r\n    return value.kind === Kind.FRAGMENT_DEFINITION;\r\n}\r\n\r\nfunction isFieldNode(value: SelectionNode): value is FieldNode {\r\n    return value.kind === Kind.FIELD;\r\n}\r\n"]}
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-custom-fields.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/data/utils/add-custom-fields.ts"],"names":[],"mappings":"AAAA,OAAO,EAKH,IAAI,GAEP,MAAM,SAAS,CAAC;AAIjB;;;GAGG;AACH,MAAM,UAAU,eAAe,CAAC,YAA0B,EAAE,YAA0B;IAClF,MAAM,YAAY,GAAG,YAAY,CAAC,WAAW,CAAC,MAAM,CAAC,oBAAoB,CAAC,CAAC;IAE3E,KAAK,MAAM,WAAW,IAAI,YAAY,EAAE;QACpC,IAAI,UAAU,GAAG,WAAW,CAAC,aAAa,CAAC,IAAI,CAAC,KAG/C,CAAC;QAEF,IAAI,UAAU,KAAM,cAAsB,EAAE;YACxC,qFAAqF;YACrF,6BAA6B;YAC7B,UAAU,GAAG,SAAS,CAAC;SAC1B;QAED,IAAI,UAAU,KAAM,SAAiB,EAAE;YACnC,gCAAgC;YAChC,UAAU,GAAG,QAAQ,CAAC;SACzB;QAED,MAAM,mBAAmB,GAAG,YAAY,CAAC,UAAU,CAAC,CAAC;QACrD,IAAI,mBAAmB,IAAI,mBAAmB,CAAC,MAAM,EAAE;YAClD,WAAW,CAAC,YAAY,CAAC,UAA8B,CAAC,IAAI,CAAC;gBAC1D,IAAI,EAAE;oBACF,IAAI,EAAE,IAAI,CAAC,IAAI;oBACf,KAAK,EAAE,cAAc;iBACxB;gBACD,IAAI,EAAE,IAAI,CAAC,KAAK;gBAChB,YAAY,EAAE;oBACV,IAAI,EAAE,IAAI,CAAC,aAAa;oBACxB,UAAU,EAAE,mBAAmB,CAAC,GAAG,CAC/B,WAAW,CAAC,EAAE,CACV,CAAC;wBACG,IAAI,EAAE,IAAI,CAAC,KAAK;wBAChB,IAAI,EAAE;4BACF,IAAI,EAAE,IAAI,CAAC,IAAI;4BACf,KAAK,EAAE,WAAW,CAAC,IAAI;yBAC1B;wBACD,uDAAuD;wBACvD,4CAA4C;wBAC5C,GAAG,CAAC,WAAW,CAAC,IAAI,KAAK,UAAU;4BAC/B,CAAC,CAAC;gCACI,YAAY,EAAE;oCACV,IAAI,EAAE,IAAI,CAAC,aAAa;oCACxB,UAAU,EACN,WACH,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;wCACrB,IAAI,EAAE,IAAI,CAAC,KAAK;wCAChB,IAAI,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,EAAE;qCACtC,CAAC,CAAC;iCACN;6BACJ;4BACH,CAAC,CAAC,EAAE,CAAC;qBACE,CAAA,CACtB;iBACJ;aACJ,CAAC,CAAC;YAEH,MAAM,eAAe,GAAG,mBAAmB,CAAC,MAAM,CAC9C,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,KAAK,cAAc,IAAI,KAAK,CAAC,IAAI,KAAK,YAAY,CACxE,CAAC;YAEF,MAAM,iBAAiB,GAAG,WAAW,CAAC,YAAY,CAAC,UAAU;iBACxD,MAAM,CAAC,WAAW,CAAC;iBACnB,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,KAAK,cAAc,CAAC,CAAC;YAExD,IAAI,eAAe,CAAC,MAAM,IAAI,iBAAiB,IAAI,iBAAiB,CAAC,YAAY,EAAE;gBAC9E,iBAAiB,CAAC,YAAY,CAAC,UAA8B,CAAC,IAAI,CAAC;oBAChE,IAAI,EAAE;wBACF,IAAI,EAAE,IAAI,CAAC,IAAI;wBACf,KAAK,EAAE,cAAc;qBACxB;oBACD,IAAI,EAAE,IAAI,CAAC,KAAK;oBAChB,YAAY,EAAE;wBACV,IAAI,EAAE,IAAI,CAAC,aAAa;wBACxB,UAAU,EAAE,eAAe,CAAC,GAAG,CAC3B,WAAW,CAAC,EAAE,CACV,CAAC;4BACG,IAAI,EAAE,IAAI,CAAC,KAAK;4BAChB,IAAI,EAAE;gCACF,IAAI,EAAE,IAAI,CAAC,IAAI;gCACf,KAAK,EAAE,WAAW,CAAC,IAAI;6BAC1B;yBACU,CAAA,CACtB;qBACJ;iBACJ,CAAC,CAAC;aACN;SACJ;KACJ;IAED,OAAO,YAAY,CAAC;AACxB,CAAC;AAED,SAAS,oBAAoB,CAAC,KAAqB;IAC/C,OAAO,KAAK,CAAC,IAAI,KAAK,IAAI,CAAC,mBAAmB,CAAC;AACnD,CAAC;AAED,SAAS,WAAW,CAAC,KAAoB;IACrC,OAAO,KAAK,CAAC,IAAI,KAAK,IAAI,CAAC,KAAK,CAAC;AACrC,CAAC","sourcesContent":["import {\r\n    DefinitionNode,\r\n    DocumentNode,\r\n    FieldNode,\r\n    FragmentDefinitionNode,\r\n    Kind,\r\n    SelectionNode,\r\n} from 'graphql';\r\n\r\nimport { CustomFields, RelationCustomFieldFragment } from '../../common/generated-types';\r\n\r\n/**\r\n * Given a GraphQL AST (DocumentNode), this function looks for fragment definitions and adds and configured\r\n * custom fields to those fragments.\r\n */\r\nexport function addCustomFields(documentNode: DocumentNode, customFields: CustomFields): DocumentNode {\r\n    const fragmentDefs = documentNode.definitions.filter(isFragmentDefinition);\r\n\r\n    for (const fragmentDef of fragmentDefs) {\r\n        let entityType = fragmentDef.typeCondition.name.value as keyof Pick<\r\n            CustomFields,\r\n            Exclude<keyof CustomFields, '__typename'>\r\n        >;\r\n\r\n        if (entityType === ('OrderAddress' as any)) {\r\n            // OrderAddress is a special case of the Address entity, and shares its custom fields\r\n            // so we treat it as an alias\r\n            entityType = 'Address';\r\n        }\r\n\r\n        if (entityType === ('Country' as any)) {\r\n            // Country is an alias of Region\r\n            entityType = 'Region';\r\n        }\r\n\r\n        const customFieldsForType = customFields[entityType];\r\n        if (customFieldsForType && customFieldsForType.length) {\r\n            (fragmentDef.selectionSet.selections as SelectionNode[]).push({\r\n                name: {\r\n                    kind: Kind.NAME,\r\n                    value: 'customFields',\r\n                },\r\n                kind: Kind.FIELD,\r\n                selectionSet: {\r\n                    kind: Kind.SELECTION_SET,\r\n                    selections: customFieldsForType.map(\r\n                        customField =>\r\n                            ({\r\n                                kind: Kind.FIELD,\r\n                                name: {\r\n                                    kind: Kind.NAME,\r\n                                    value: customField.name,\r\n                                },\r\n                                // For \"relation\" custom fields, we need to also select\r\n                                // all the scalar fields of the related type\r\n                                ...(customField.type === 'relation'\r\n                                    ? {\r\n                                          selectionSet: {\r\n                                              kind: Kind.SELECTION_SET,\r\n                                              selections: (\r\n                                                  customField as RelationCustomFieldFragment\r\n                                              ).scalarFields.map(f => ({\r\n                                                  kind: Kind.FIELD,\r\n                                                  name: { kind: Kind.NAME, value: f },\r\n                                              })),\r\n                                          },\r\n                                      }\r\n                                    : {}),\r\n                            } as FieldNode),\r\n                    ),\r\n                },\r\n            });\r\n\r\n            const localizedFields = customFieldsForType.filter(\r\n                field => field.type === 'localeString' || field.type === 'localeText',\r\n            );\r\n\r\n            const translationsField = fragmentDef.selectionSet.selections\r\n                .filter(isFieldNode)\r\n                .find(field => field.name.value === 'translations');\r\n\r\n            if (localizedFields.length && translationsField && translationsField.selectionSet) {\r\n                (translationsField.selectionSet.selections as SelectionNode[]).push({\r\n                    name: {\r\n                        kind: Kind.NAME,\r\n                        value: 'customFields',\r\n                    },\r\n                    kind: Kind.FIELD,\r\n                    selectionSet: {\r\n                        kind: Kind.SELECTION_SET,\r\n                        selections: localizedFields.map(\r\n                            customField =>\r\n                                ({\r\n                                    kind: Kind.FIELD,\r\n                                    name: {\r\n                                        kind: Kind.NAME,\r\n                                        value: customField.name,\r\n                                    },\r\n                                } as FieldNode),\r\n                        ),\r\n                    },\r\n                });\r\n            }\r\n        }\r\n    }\r\n\r\n    return documentNode;\r\n}\r\n\r\nfunction isFragmentDefinition(value: DefinitionNode): value is FragmentDefinitionNode {\r\n    return value.kind === Kind.FRAGMENT_DEFINITION;\r\n}\r\n\r\nfunction isFieldNode(value: SelectionNode): value is FieldNode {\r\n    return value.kind === Kind.FIELD;\r\n}\r\n"]}
|
|
@@ -10,6 +10,8 @@ import { NavBuilderService } from '../providers/nav-builder/nav-builder.service'
|
|
|
10
10
|
*
|
|
11
11
|
* @example
|
|
12
12
|
* ```ts title="providers.ts"
|
|
13
|
+
* import { addNavMenuSection } from '\@vendure/admin-ui/core';
|
|
14
|
+
*
|
|
13
15
|
* export default [
|
|
14
16
|
* addNavMenuSection({
|
|
15
17
|
* id: 'reports',
|
|
@@ -45,6 +47,8 @@ export function addNavMenuSection(config, before) {
|
|
|
45
47
|
*
|
|
46
48
|
* @example
|
|
47
49
|
* ```ts title="providers.ts"
|
|
50
|
+
* import { addNavMenuItem } from '\@vendure/admin-ui/core';
|
|
51
|
+
*
|
|
48
52
|
* export default [
|
|
49
53
|
* addNavMenuItem({
|
|
50
54
|
* id: 'reviews',
|
|
@@ -54,7 +58,7 @@ export function addNavMenuSection(config, before) {
|
|
|
54
58
|
* },
|
|
55
59
|
* 'marketing'),
|
|
56
60
|
* ];
|
|
57
|
-
*
|
|
61
|
+
* ```
|
|
58
62
|
*
|
|
59
63
|
* @docsCategory nav-menu
|
|
60
64
|
*/
|
|
@@ -68,4 +72,4 @@ export function addNavMenuItem(config, sectionId, before) {
|
|
|
68
72
|
deps: [NavBuilderService],
|
|
69
73
|
};
|
|
70
74
|
}
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRkLW5hdi1tZW51LWl0ZW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvc3JjL2V4dGVuc2lvbi9hZGQtbmF2LW1lbnUtaXRlbS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFZLE1BQU0sZUFBZSxDQUFDO0FBRTFELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDhDQUE4QyxDQUFDO0FBRWpGOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0F3Qkc7QUFDSCxNQUFNLFVBQVUsaUJBQWlCLENBQUMsTUFBc0IsRUFBRSxNQUFlO0lBQ3JFLE9BQU87UUFDSCxPQUFPLEVBQUUsZUFBZTtRQUN4QixLQUFLLEVBQUUsSUFBSTtRQUNYLFVBQVUsRUFBRSxDQUFDLGlCQUFvQyxFQUFFLEVBQUUsQ0FBQyxHQUFHLEVBQUU7WUFDdkQsaUJBQWlCLENBQUMsaUJBQWlCLENBQUMsTUFBTSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQ3hELENBQUM7UUFDRCxJQUFJLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztLQUM1QixDQUFDO0FBQ04sQ0FBQztBQUVEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQTBCRztBQUNILE1BQU0sVUFBVSxjQUFjLENBQUMsTUFBbUIsRUFBRSxTQUFpQixFQUFFLE1BQWU7SUFDbEYsT0FBTztRQUNILE9BQU8sRUFBRSxlQUFlO1FBQ3hCLEtBQUssRUFBRSxJQUFJO1FBQ1gsVUFBVSxFQUFFLENBQUMsaUJBQW9DLEVBQUUsRUFBRSxDQUFDLEdBQUcsRUFBRTtZQUN2RCxpQkFBaUIsQ0FBQyxjQUFjLENBQUMsTUFBTSxFQUFFLFNBQVMsRUFBRSxNQUFNLENBQUMsQ0FBQztRQUNoRSxDQUFDO1FBQ0QsSUFBSSxFQUFFLENBQUMsaUJBQWlCLENBQUM7S0FDNUIsQ0FBQztBQUNOLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBUFBfSU5JVElBTElaRVIsIFByb3ZpZGVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE5hdk1lbnVJdGVtLCBOYXZNZW51U2VjdGlvbiB9IGZyb20gJy4uL3Byb3ZpZGVycy9uYXYtYnVpbGRlci9uYXYtYnVpbGRlci10eXBlcyc7XHJcbmltcG9ydCB7IE5hdkJ1aWxkZXJTZXJ2aWNlIH0gZnJvbSAnLi4vcHJvdmlkZXJzL25hdi1idWlsZGVyL25hdi1idWlsZGVyLnNlcnZpY2UnO1xyXG5cclxuLyoqXHJcbiAqIEBkZXNjcmlwdGlvblxyXG4gKiBBZGQgYSBzZWN0aW9uIHRvIHRoZSBtYWluIG5hdiBtZW51LiBQcm92aWRpbmcgdGhlIGBiZWZvcmVgIGFyZ3VtZW50IHdpbGxcclxuICogbW92ZSB0aGUgc2VjdGlvbiBiZWZvcmUgYW55IGV4aXN0aW5nIHNlY3Rpb24gd2l0aCB0aGUgc3BlY2lmaWVkIGlkLiBJZlxyXG4gKiBvbWl0dGVkIChvciBpZiB0aGUgaWQgaXMgbm90IGZvdW5kKSB0aGUgc2VjdGlvbiB3aWxsIGJlIGFwcGVuZGVkIHRvIHRoZVxyXG4gKiBleGlzdGluZyBzZXQgb2Ygc2VjdGlvbnMuXHJcbiAqIFRoaXMgc2hvdWxkIGJlIHVzZWQgaW4gdGhlIE5nTW9kdWxlIGBwcm92aWRlcnNgIGFycmF5IG9mIHlvdXIgdWkgZXh0ZW5zaW9uIG1vZHVsZS5cclxuICpcclxuICogQGV4YW1wbGVcclxuICogYGBgdHMgdGl0bGU9XCJwcm92aWRlcnMudHNcIlxyXG4gKiBpbXBvcnQgeyBhZGROYXZNZW51U2VjdGlvbiB9IGZyb20gJ1xcQHZlbmR1cmUvYWRtaW4tdWkvY29yZSc7XHJcbiAqXHJcbiAqIGV4cG9ydCBkZWZhdWx0IFtcclxuICogICAgIGFkZE5hdk1lbnVTZWN0aW9uKHtcclxuICogICAgICAgICBpZDogJ3JlcG9ydHMnLFxyXG4gKiAgICAgICAgIGxhYmVsOiAnUmVwb3J0cycsXHJcbiAqICAgICAgICAgaXRlbXM6IFt7XHJcbiAqICAgICAgICAgICAgIC8vIC4uLlxyXG4gKiAgICAgICAgIH1dLFxyXG4gKiAgICAgfSxcclxuICogICAgICdzZXR0aW5ncycpLFxyXG4gKiBdO1xyXG4gKiBgYGBcclxuICogQGRvY3NDYXRlZ29yeSBuYXYtbWVudVxyXG4gKi9cclxuZXhwb3J0IGZ1bmN0aW9uIGFkZE5hdk1lbnVTZWN0aW9uKGNvbmZpZzogTmF2TWVudVNlY3Rpb24sIGJlZm9yZT86IHN0cmluZyk6IFByb3ZpZGVyIHtcclxuICAgIHJldHVybiB7XHJcbiAgICAgICAgcHJvdmlkZTogQVBQX0lOSVRJQUxJWkVSLFxyXG4gICAgICAgIG11bHRpOiB0cnVlLFxyXG4gICAgICAgIHVzZUZhY3Rvcnk6IChuYXZCdWlsZGVyU2VydmljZTogTmF2QnVpbGRlclNlcnZpY2UpID0+ICgpID0+IHtcclxuICAgICAgICAgICAgbmF2QnVpbGRlclNlcnZpY2UuYWRkTmF2TWVudVNlY3Rpb24oY29uZmlnLCBiZWZvcmUpO1xyXG4gICAgICAgIH0sXHJcbiAgICAgICAgZGVwczogW05hdkJ1aWxkZXJTZXJ2aWNlXSxcclxuICAgIH07XHJcbn1cclxuXHJcbi8qKlxyXG4gKiBAZGVzY3JpcHRpb25cclxuICogQWRkIGEgbWVudSBpdGVtIHRvIGFuIGV4aXN0aW5nIHNlY3Rpb24gc3BlY2lmaWVkIGJ5IGBzZWN0aW9uSWRgLiBUaGUgaWQgb2YgdGhlIHNlY3Rpb25cclxuICogY2FuIGJlIGZvdW5kIGJ5IGluc3BlY3RpbmcgdGhlIERPTSBhbmQgZmluZGluZyB0aGUgYGRhdGEtc2VjdGlvbi1pZGAgYXR0cmlidXRlLlxyXG4gKiBQcm92aWRpbmcgdGhlIGBiZWZvcmVgIGFyZ3VtZW50IHdpbGwgbW92ZSB0aGUgaXRlbSBiZWZvcmUgYW55IGV4aXN0aW5nIGl0ZW0gd2l0aCB0aGUgc3BlY2lmaWVkIGlkLlxyXG4gKiBJZiBvbWl0dGVkIChvciBpZiB0aGUgbmFtZSBpcyBub3QgZm91bmQpIHRoZSBpdGVtIHdpbGwgYmUgYXBwZW5kZWQgdG8gdGhlXHJcbiAqIGVuZCBvZiB0aGUgc2VjdGlvbi5cclxuICpcclxuICogVGhpcyBzaG91bGQgYmUgdXNlZCBpbiB0aGUgTmdNb2R1bGUgYHByb3ZpZGVyc2AgYXJyYXkgb2YgeW91ciB1aSBleHRlbnNpb24gbW9kdWxlLlxyXG4gKlxyXG4gKiBAZXhhbXBsZVxyXG4gKiBgYGB0cyB0aXRsZT1cInByb3ZpZGVycy50c1wiXHJcbiAqIGltcG9ydCB7IGFkZE5hdk1lbnVJdGVtIH0gZnJvbSAnXFxAdmVuZHVyZS9hZG1pbi11aS9jb3JlJztcclxuICpcclxuICogZXhwb3J0IGRlZmF1bHQgW1xyXG4gKiAgICAgYWRkTmF2TWVudUl0ZW0oe1xyXG4gKiAgICAgICAgIGlkOiAncmV2aWV3cycsXHJcbiAqICAgICAgICAgbGFiZWw6ICdQcm9kdWN0IFJldmlld3MnLFxyXG4gKiAgICAgICAgIHJvdXRlckxpbms6IFsnL2V4dGVuc2lvbnMvcmV2aWV3cyddLFxyXG4gKiAgICAgICAgIGljb246ICdzdGFyJyxcclxuICogICAgIH0sXHJcbiAqICAgICAnbWFya2V0aW5nJyksXHJcbiAqIF07XHJcbiAqIGBgYFxyXG4gKlxyXG4gKiBAZG9jc0NhdGVnb3J5IG5hdi1tZW51XHJcbiAqL1xyXG5leHBvcnQgZnVuY3Rpb24gYWRkTmF2TWVudUl0ZW0oY29uZmlnOiBOYXZNZW51SXRlbSwgc2VjdGlvbklkOiBzdHJpbmcsIGJlZm9yZT86IHN0cmluZyk6IFByb3ZpZGVyIHtcclxuICAgIHJldHVybiB7XHJcbiAgICAgICAgcHJvdmlkZTogQVBQX0lOSVRJQUxJWkVSLFxyXG4gICAgICAgIG11bHRpOiB0cnVlLFxyXG4gICAgICAgIHVzZUZhY3Rvcnk6IChuYXZCdWlsZGVyU2VydmljZTogTmF2QnVpbGRlclNlcnZpY2UpID0+ICgpID0+IHtcclxuICAgICAgICAgICAgbmF2QnVpbGRlclNlcnZpY2UuYWRkTmF2TWVudUl0ZW0oY29uZmlnLCBzZWN0aW9uSWQsIGJlZm9yZSk7XHJcbiAgICAgICAgfSxcclxuICAgICAgICBkZXBzOiBbTmF2QnVpbGRlclNlcnZpY2VdLFxyXG4gICAgfTtcclxufVxyXG4iXX0=
|
|
@@ -47,6 +47,14 @@ export function registerRouteComponent(options) {
|
|
|
47
47
|
const { query, entityKey, variables, getBreadcrumbs } = options;
|
|
48
48
|
const breadcrumbSubject$ = new BehaviorSubject(options.breadcrumb ?? '');
|
|
49
49
|
const titleSubject$ = new BehaviorSubject(options.title);
|
|
50
|
+
if (getBreadcrumbs != null && (query == null || entityKey == null)) {
|
|
51
|
+
console.error([
|
|
52
|
+
`[${options.path ?? 'custom'} route] When using the "getBreadcrumbs" option, the "query" and "entityKey" options must also be provided.`,
|
|
53
|
+
``,
|
|
54
|
+
`Alternatively, use the "breadcrumb" option instead, or use the "PageMetadataService" inside your Angular component`,
|
|
55
|
+
`or the "usePageMetadata" React hook to set the breadcrumb.`,
|
|
56
|
+
].join('\n'));
|
|
57
|
+
}
|
|
50
58
|
const resolveFn = query && entityKey
|
|
51
59
|
? createBaseDetailResolveFn({
|
|
52
60
|
query,
|
|
@@ -72,7 +80,7 @@ export function registerRouteComponent(options) {
|
|
|
72
80
|
data: {
|
|
73
81
|
breadcrumb: breadcrumbSubject$,
|
|
74
82
|
...(options.routeConfig?.data ?? {}),
|
|
75
|
-
...(getBreadcrumbs
|
|
83
|
+
...(getBreadcrumbs && query && entityKey
|
|
76
84
|
? {
|
|
77
85
|
breadcrumb: data => data.detail.entity.pipe(map((entity) => getBreadcrumbs(entity))),
|
|
78
86
|
}
|
|
@@ -82,4 +90,4 @@ export function registerRouteComponent(options) {
|
|
|
82
90
|
component: AngularRouteComponent,
|
|
83
91
|
};
|
|
84
92
|
}
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"register-route-component.js","sourceRoot":"","sources":["../../../../src/lib/core/src/extension/register-route-component.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,eAAe,EAAc,MAAM,MAAM,CAAC;AACnD,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAuB,yBAAyB,EAAE,MAAM,iCAAiC,CAAC;AAEjG,OAAO,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAC;AAC7E,OAAO,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AA2BvE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuCG;AACH,MAAM,UAAU,sBAAsB,CAMpC,OAAsE;IACpE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,cAAc,EAAE,GAAG,OAAO,CAAC;IAEhE,MAAM,kBAAkB,GAAG,IAAI,eAAe,CAAkB,OAAO,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC;IAC1F,MAAM,aAAa,GAAG,IAAI,eAAe,CAAqB,OAAO,CAAC,KAAK,CAAC,CAAC;IAE7E,MAAM,SAAS,GAMX,KAAK,IAAI,SAAS;QACd,CAAC,CAAC,yBAAyB,CAAC;YACtB,KAAK;YACL,SAAS;YACT,SAAS;SACZ,CAAC;QACJ,CAAC,CAAC,SAAS,CAAC;IAEpB,OAAO;QACH,IAAI,EAAE,OAAO,CAAC,IAAI,IAAI,EAAE;QACxB,SAAS,EAAE;YACP;gBACI,OAAO,EAAE,uBAAuB;gBAChC,QAAQ,EAAE;oBACN,SAAS,EAAE,OAAO,CAAC,SAAS;oBAC5B,MAAM,EAAE,aAAa;oBACrB,WAAW,EAAE,kBAAkB;iBACF;aACpC;YACD,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,SAAS,IAAI,EAAE,CAAC;SAC5C;QACD,GAAG,CAAC,OAAO,CAAC,WAAW,IAAI,EAAE,CAAC;QAC9B,OAAO,EAAE,EAAE,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,OAAO,IAAI,EAAE,CAAC,EAAE;QACjG,IAAI,EAAE;YACF,UAAU,EAAE,kBAAkB;YAC9B,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC;YACpC,GAAG,CAAC,cAAc;gBACd,CAAC,CAAC;oBACI,UAAU,EAAE,IAAI,CAAC,EAAE,CACf,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,MAAW,EAAE,EAAE,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC;iBAC5E;gBACH,CAAC,CAAC,EAAE,CAAC;YACT,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC;SACvC;QACD,SAAS,EAAE,qBAAqB;KACnB,CAAC;AACtB,CAAC","sourcesContent":["import { Type } from '@angular/core';\r\nimport { ResolveFn, Route } from '@angular/router';\r\nimport { ResultOf, TypedDocumentNode } from '@graphql-typed-document-node/core';\r\nimport { DocumentNode } from 'graphql';\r\nimport { BehaviorSubject, Observable } from 'rxjs';\r\nimport { map } from 'rxjs/operators';\r\nimport { BaseDetailComponent, createBaseDetailResolveFn } from '../common/base-detail.component';\r\nimport { BreadcrumbValue } from '../providers/breadcrumb/breadcrumb.service';\r\nimport { AngularRouteComponent } from './components/angular-route.component';\r\nimport { ROUTE_COMPONENT_OPTIONS } from './components/route.component';\r\nimport { RouteComponentOptions } from './types';\r\n\r\n/**\r\n * @description\r\n * Configuration for a route component.\r\n *\r\n * @docsCategory routes\r\n */\r\nexport type RegisterRouteComponentOptions<\r\n    Component extends any | BaseDetailComponent<Entity>,\r\n    Entity extends { id: string; updatedAt?: string },\r\n    T extends DocumentNode | TypedDocumentNode<any, { id: string }>,\r\n    Field extends keyof ResultOf<T>,\r\n    R extends Field,\r\n> = {\r\n    component: Type<Component> | Component;\r\n    title?: string;\r\n    breadcrumb?: BreadcrumbValue;\r\n    path?: string;\r\n    query?: T;\r\n    getBreadcrumbs?: (entity: Exclude<ResultOf<T>[R], 'Query'>) => BreadcrumbValue;\r\n    entityKey?: Component extends BaseDetailComponent<any> ? R : undefined;\r\n    variables?: T extends TypedDocumentNode<any, infer V> ? Omit<V, 'id'> : never;\r\n    routeConfig?: Route;\r\n} & (Component extends BaseDetailComponent<any> ? { entityKey: R } : unknown);\r\n\r\n/**\r\n * @description\r\n * Registers an Angular standalone component to be rendered in a route.\r\n *\r\n * @example\r\n * ```ts title=\"routes.ts\"\r\n * import { registerRouteComponent } from '\\@vendure/admin-ui/core';\r\n * import { registerReactRouteComponent } from '\\@vendure/admin-ui/react';\r\n *\r\n * import { ProductReviewDetailComponent } from './components/product-review-detail/product-review-detail.component';\r\n * import { AllProductReviewsList } from './components/all-product-reviews-list/all-product-reviews-list.component';\r\n * import { GetReviewDetailDocument } from './generated-types';\r\n *\r\n * export default [\r\n *     registerRouteComponent({\r\n *         path: '',\r\n *         component: AllProductReviewsList,\r\n *         breadcrumb: 'Product reviews',\r\n *     }),\r\n *     registerRouteComponent({\r\n *         path: ':id',\r\n *         component: ProductReviewDetailComponent,\r\n *         query: GetReviewDetailDocument,\r\n *         entityKey: 'productReview',\r\n *         getBreadcrumbs: entity => [\r\n *             {\r\n *                 label: 'Product reviews',\r\n *                 link: ['/extensions', 'product-reviews'],\r\n *             },\r\n *             {\r\n *                 label: `#${entity?.id} (${entity?.product.name})`,\r\n *                 link: [],\r\n *             },\r\n *         ],\r\n *     }),\r\n * ];\r\n * ```\r\n *\r\n * @docsCategory routes\r\n */\r\nexport function registerRouteComponent<\r\n    Component extends any | BaseDetailComponent<Entity>,\r\n    Entity extends { id: string; updatedAt?: string },\r\n    T extends DocumentNode | TypedDocumentNode<any, { id: string }>,\r\n    Field extends keyof ResultOf<T>,\r\n    R extends Field,\r\n>(options: RegisterRouteComponentOptions<Component, Entity, T, Field, R>) {\r\n    const { query, entityKey, variables, getBreadcrumbs } = options;\r\n\r\n    const breadcrumbSubject$ = new BehaviorSubject<BreadcrumbValue>(options.breadcrumb ?? '');\r\n    const titleSubject$ = new BehaviorSubject<string | undefined>(options.title);\r\n\r\n    const resolveFn:\r\n        | ResolveFn<{\r\n              entity: Observable<ResultOf<T>[Field] | null>;\r\n              result?: ResultOf<T>;\r\n          }>\r\n        | undefined =\r\n        query && entityKey\r\n            ? createBaseDetailResolveFn({\r\n                  query,\r\n                  entityKey,\r\n                  variables,\r\n              })\r\n            : undefined;\r\n\r\n    return {\r\n        path: options.path ?? '',\r\n        providers: [\r\n            {\r\n                provide: ROUTE_COMPONENT_OPTIONS,\r\n                useValue: {\r\n                    component: options.component,\r\n                    title$: titleSubject$,\r\n                    breadcrumb$: breadcrumbSubject$,\r\n                } satisfies RouteComponentOptions,\r\n            },\r\n            ...(options.routeConfig?.providers ?? []),\r\n        ],\r\n        ...(options.routeConfig ?? {}),\r\n        resolve: { ...(resolveFn ? { detail: resolveFn } : {}), ...(options.routeConfig?.resolve ?? {}) },\r\n        data: {\r\n            breadcrumb: breadcrumbSubject$,\r\n            ...(options.routeConfig?.data ?? {}),\r\n            ...(getBreadcrumbs\r\n                ? {\r\n                      breadcrumb: data =>\r\n                          data.detail.entity.pipe(map((entity: any) => getBreadcrumbs(entity))),\r\n                  }\r\n                : {}),\r\n            ...(options.routeConfig?.data ?? {}),\r\n        },\r\n        component: AngularRouteComponent,\r\n    } satisfies Route;\r\n}\r\n"]}
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"register-route-component.js","sourceRoot":"","sources":["../../../../src/lib/core/src/extension/register-route-component.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,eAAe,EAAc,MAAM,MAAM,CAAC;AACnD,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAuB,yBAAyB,EAAE,MAAM,iCAAiC,CAAC;AAEjG,OAAO,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAC;AAC7E,OAAO,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AA2BvE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuCG;AACH,MAAM,UAAU,sBAAsB,CAMpC,OAAsE;IACpE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,EAAE,cAAc,EAAE,GAAG,OAAO,CAAC;IAEhE,MAAM,kBAAkB,GAAG,IAAI,eAAe,CAAkB,OAAO,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC;IAC1F,MAAM,aAAa,GAAG,IAAI,eAAe,CAAqB,OAAO,CAAC,KAAK,CAAC,CAAC;IAE7E,IAAI,cAAc,IAAI,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,IAAI,SAAS,IAAI,IAAI,CAAC,EAAE;QAChE,OAAO,CAAC,KAAK,CACT;YACI,IACI,OAAO,CAAC,IAAI,IAAI,QACpB,4GAA4G;YAC5G,EAAE;YACF,oHAAoH;YACpH,4DAA4D;SAC/D,CAAC,IAAI,CAAC,IAAI,CAAC,CACf,CAAC;KACL;IAED,MAAM,SAAS,GAMX,KAAK,IAAI,SAAS;QACd,CAAC,CAAC,yBAAyB,CAAC;YACtB,KAAK;YACL,SAAS;YACT,SAAS;SACZ,CAAC;QACJ,CAAC,CAAC,SAAS,CAAC;IAEpB,OAAO;QACH,IAAI,EAAE,OAAO,CAAC,IAAI,IAAI,EAAE;QACxB,SAAS,EAAE;YACP;gBACI,OAAO,EAAE,uBAAuB;gBAChC,QAAQ,EAAE;oBACN,SAAS,EAAE,OAAO,CAAC,SAAS;oBAC5B,MAAM,EAAE,aAAa;oBACrB,WAAW,EAAE,kBAAkB;iBACF;aACpC;YACD,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,SAAS,IAAI,EAAE,CAAC;SAC5C;QACD,GAAG,CAAC,OAAO,CAAC,WAAW,IAAI,EAAE,CAAC;QAC9B,OAAO,EAAE,EAAE,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,OAAO,IAAI,EAAE,CAAC,EAAE;QACjG,IAAI,EAAE;YACF,UAAU,EAAE,kBAAkB;YAC9B,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC;YACpC,GAAG,CAAC,cAAc,IAAI,KAAK,IAAI,SAAS;gBACpC,CAAC,CAAC;oBACI,UAAU,EAAE,IAAI,CAAC,EAAE,CACf,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,MAAW,EAAE,EAAE,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC;iBAC5E;gBACH,CAAC,CAAC,EAAE,CAAC;YACT,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC;SACvC;QACD,SAAS,EAAE,qBAAqB;KACnB,CAAC;AACtB,CAAC","sourcesContent":["import { Type } from '@angular/core';\r\nimport { ResolveFn, Route } from '@angular/router';\r\nimport { ResultOf, TypedDocumentNode } from '@graphql-typed-document-node/core';\r\nimport { DocumentNode } from 'graphql';\r\nimport { BehaviorSubject, Observable } from 'rxjs';\r\nimport { map } from 'rxjs/operators';\r\nimport { BaseDetailComponent, createBaseDetailResolveFn } from '../common/base-detail.component';\r\nimport { BreadcrumbValue } from '../providers/breadcrumb/breadcrumb.service';\r\nimport { AngularRouteComponent } from './components/angular-route.component';\r\nimport { ROUTE_COMPONENT_OPTIONS } from './components/route.component';\r\nimport { RouteComponentOptions } from './types';\r\n\r\n/**\r\n * @description\r\n * Configuration for a route component.\r\n *\r\n * @docsCategory routes\r\n */\r\nexport type RegisterRouteComponentOptions<\r\n    Component extends any | BaseDetailComponent<Entity>,\r\n    Entity extends { id: string; updatedAt?: string },\r\n    T extends DocumentNode | TypedDocumentNode<any, { id: string }>,\r\n    Field extends keyof ResultOf<T>,\r\n    R extends Field,\r\n> = {\r\n    component: Type<Component> | Component;\r\n    title?: string;\r\n    breadcrumb?: BreadcrumbValue;\r\n    path?: string;\r\n    query?: T;\r\n    getBreadcrumbs?: (entity: Exclude<ResultOf<T>[R], 'Query'>) => BreadcrumbValue;\r\n    entityKey?: Component extends BaseDetailComponent<any> ? R : undefined;\r\n    variables?: T extends TypedDocumentNode<any, infer V> ? Omit<V, 'id'> : never;\r\n    routeConfig?: Route;\r\n} & (Component extends BaseDetailComponent<any> ? { entityKey: R } : unknown);\r\n\r\n/**\r\n * @description\r\n * Registers an Angular standalone component to be rendered in a route.\r\n *\r\n * @example\r\n * ```ts title=\"routes.ts\"\r\n * import { registerRouteComponent } from '\\@vendure/admin-ui/core';\r\n * import { registerReactRouteComponent } from '\\@vendure/admin-ui/react';\r\n *\r\n * import { ProductReviewDetailComponent } from './components/product-review-detail/product-review-detail.component';\r\n * import { AllProductReviewsList } from './components/all-product-reviews-list/all-product-reviews-list.component';\r\n * import { GetReviewDetailDocument } from './generated-types';\r\n *\r\n * export default [\r\n *     registerRouteComponent({\r\n *         path: '',\r\n *         component: AllProductReviewsList,\r\n *         breadcrumb: 'Product reviews',\r\n *     }),\r\n *     registerRouteComponent({\r\n *         path: ':id',\r\n *         component: ProductReviewDetailComponent,\r\n *         query: GetReviewDetailDocument,\r\n *         entityKey: 'productReview',\r\n *         getBreadcrumbs: entity => [\r\n *             {\r\n *                 label: 'Product reviews',\r\n *                 link: ['/extensions', 'product-reviews'],\r\n *             },\r\n *             {\r\n *                 label: `#${entity?.id} (${entity?.product.name})`,\r\n *                 link: [],\r\n *             },\r\n *         ],\r\n *     }),\r\n * ];\r\n * ```\r\n *\r\n * @docsCategory routes\r\n */\r\nexport function registerRouteComponent<\r\n    Component extends any | BaseDetailComponent<Entity>,\r\n    Entity extends { id: string; updatedAt?: string },\r\n    T extends DocumentNode | TypedDocumentNode<any, { id: string }>,\r\n    Field extends keyof ResultOf<T>,\r\n    R extends Field,\r\n>(options: RegisterRouteComponentOptions<Component, Entity, T, Field, R>) {\r\n    const { query, entityKey, variables, getBreadcrumbs } = options;\r\n\r\n    const breadcrumbSubject$ = new BehaviorSubject<BreadcrumbValue>(options.breadcrumb ?? '');\r\n    const titleSubject$ = new BehaviorSubject<string | undefined>(options.title);\r\n\r\n    if (getBreadcrumbs != null && (query == null || entityKey == null)) {\r\n        console.error(\r\n            [\r\n                `[${\r\n                    options.path ?? 'custom'\r\n                } route] When using the \"getBreadcrumbs\" option, the \"query\" and \"entityKey\" options must also be provided.`,\r\n                ``,\r\n                `Alternatively, use the \"breadcrumb\" option instead, or use the \"PageMetadataService\" inside your Angular component`,\r\n                `or the \"usePageMetadata\" React hook to set the breadcrumb.`,\r\n            ].join('\\n'),\r\n        );\r\n    }\r\n\r\n    const resolveFn:\r\n        | ResolveFn<{\r\n              entity: Observable<ResultOf<T>[Field] | null>;\r\n              result?: ResultOf<T>;\r\n          }>\r\n        | undefined =\r\n        query && entityKey\r\n            ? createBaseDetailResolveFn({\r\n                  query,\r\n                  entityKey,\r\n                  variables,\r\n              })\r\n            : undefined;\r\n\r\n    return {\r\n        path: options.path ?? '',\r\n        providers: [\r\n            {\r\n                provide: ROUTE_COMPONENT_OPTIONS,\r\n                useValue: {\r\n                    component: options.component,\r\n                    title$: titleSubject$,\r\n                    breadcrumb$: breadcrumbSubject$,\r\n                } satisfies RouteComponentOptions,\r\n            },\r\n            ...(options.routeConfig?.providers ?? []),\r\n        ],\r\n        ...(options.routeConfig ?? {}),\r\n        resolve: { ...(resolveFn ? { detail: resolveFn } : {}), ...(options.routeConfig?.resolve ?? {}) },\r\n        data: {\r\n            breadcrumb: breadcrumbSubject$,\r\n            ...(options.routeConfig?.data ?? {}),\r\n            ...(getBreadcrumbs && query && entityKey\r\n                ? {\r\n                      breadcrumb: data =>\r\n                          data.detail.entity.pipe(map((entity: any) => getBreadcrumbs(entity))),\r\n                  }\r\n                : {}),\r\n            ...(options.routeConfig?.data ?? {}),\r\n        },\r\n        component: AngularRouteComponent,\r\n    } satisfies Route;\r\n}\r\n"]}
|
|
@@ -95,4 +95,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImpor
|
|
|
95
95
|
providedIn: 'root',
|
|
96
96
|
}]
|
|
97
97
|
}], ctorParameters: function () { return [{ type: i1.DataService }]; } });
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alerts.service.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/providers/alerts/alerts.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { notNullOrUndefined } from '@vendure/common/lib/shared-utils';\nimport {\n    BehaviorSubject,\n    combineLatest,\n    interval,\n    isObservable,\n    Observable,\n    of,\n    Subject,\n    switchMap,\n} from 'rxjs';\nimport { filter, first, map, mapTo, startWith, take } from 'rxjs/operators';\nimport { Permission } from '../../common/generated-types';\nimport { DataService } from '../../data/providers/data.service';\n\nexport interface AlertConfig<T = any> {\n    id: string;\n    check: () => T | Promise<T> | Observable<T>;\n    recheckIntervalMs?: number;\n    isAlert: (value: T) => boolean;\n    action: (data: T) => void;\n    label: (data: T) => { text: string; translationVars?: { [key: string]: string | number } };\n    requiredPermissions?: Permission[];\n}\n\nexport interface ActiveAlert {\n    id: string;\n    runAction: () => void;\n    hasRun: boolean;\n    label: { text: string; translationVars?: { [key: string]: string | number } };\n}\n\nexport class Alert<T> {\n    activeAlert$: Observable<ActiveAlert | undefined>;\n    private hasRun$ = new BehaviorSubject(false);\n    private data$ = new BehaviorSubject<T | undefined>(undefined);\n    constructor(private config: AlertConfig<T>) {\n        if (this.config.recheckIntervalMs) {\n            interval(this.config.recheckIntervalMs).subscribe(() => this.runCheck());\n        }\n        this.activeAlert$ = combineLatest(this.data$, this.hasRun$).pipe(\n            map(([data, hasRun]) => {\n                if (!data) {\n                    return;\n                }\n                const isAlert = this.config.isAlert(data);\n                if (!isAlert) {\n                    return;\n                }\n                return {\n                    id: this.config.id,\n                    runAction: () => {\n                        if (!hasRun) {\n                            this.config.action(data);\n                            this.hasRun$.next(true);\n                        }\n                    },\n                    hasRun,\n                    label: this.config.label(data),\n                };\n            }),\n        );\n    }\n    get id() {\n        return this.config.id;\n    }\n    runCheck() {\n        const result = this.config.check();\n        if (result instanceof Promise) {\n            result.then(data => this.data$.next(data));\n        } else if (isObservable(result)) {\n            result.pipe(take(1)).subscribe(data => this.data$.next(data));\n        } else {\n            this.data$.next(result);\n        }\n        this.hasRun$.next(false);\n    }\n}\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class AlertsService {\n    activeAlerts$: Observable<ActiveAlert[]>;\n    private alertsMap = new Map<string, Alert<any>>();\n    private configUpdated = new Subject<void>();\n\n    constructor(private dataService: DataService) {\n        const alerts$ = this.configUpdated.pipe(\n            mapTo([...this.alertsMap.values()]),\n            startWith([...this.alertsMap.values()]),\n        );\n\n        this.activeAlerts$ = alerts$.pipe(\n            switchMap(() => {\n                const alerts = [...this.alertsMap.values()];\n                const isAlertStreams = alerts.map(alert => alert.activeAlert$);\n                return combineLatest(isAlertStreams);\n            }),\n            map(alertStates => alertStates.filter(notNullOrUndefined)),\n        );\n    }\n\n    configureAlert<T>(config: AlertConfig<T>) {\n        this.hasSufficientPermissions(config.requiredPermissions)\n            .pipe(first())\n            .subscribe(hasSufficientPermissions => {\n                if (hasSufficientPermissions) {\n                    this.alertsMap.set(config.id, new Alert(config));\n                    this.configUpdated.next();\n                }\n            });\n    }\n\n    hasSufficientPermissions(permissions?: Permission[]) {\n        if (!permissions || permissions.length === 0) {\n            return of(true);\n        }\n        return this.dataService.client.userStatus().stream$.pipe(\n            filter(({ userStatus }) => userStatus.isLoggedIn),\n            map(({ userStatus }) =>\n                permissions.some(permission => userStatus.permissions.includes(permission)),\n            ),\n        );\n    }\n\n    refresh(id?: string) {\n        if (id) {\n            this.alertsMap.get(id)?.runCheck();\n        } else {\n            this.alertsMap.forEach(config => config.runCheck());\n        }\n    }\n}\n"]}
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alerts.service.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/providers/alerts/alerts.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { notNullOrUndefined } from '@vendure/common/lib/shared-utils';\r\nimport {\r\n    BehaviorSubject,\r\n    combineLatest,\r\n    interval,\r\n    isObservable,\r\n    Observable,\r\n    of,\r\n    Subject,\r\n    switchMap,\r\n} from 'rxjs';\r\nimport { filter, first, map, mapTo, startWith, take } from 'rxjs/operators';\r\nimport { Permission } from '../../common/generated-types';\r\nimport { DataService } from '../../data/providers/data.service';\r\n\r\nexport interface AlertConfig<T = any> {\r\n    id: string;\r\n    check: () => T | Promise<T> | Observable<T>;\r\n    recheckIntervalMs?: number;\r\n    isAlert: (value: T) => boolean;\r\n    action: (data: T) => void;\r\n    label: (data: T) => { text: string; translationVars?: { [key: string]: string | number } };\r\n    requiredPermissions?: Permission[];\r\n}\r\n\r\nexport interface ActiveAlert {\r\n    id: string;\r\n    runAction: () => void;\r\n    hasRun: boolean;\r\n    label: { text: string; translationVars?: { [key: string]: string | number } };\r\n}\r\n\r\nexport class Alert<T> {\r\n    activeAlert$: Observable<ActiveAlert | undefined>;\r\n    private hasRun$ = new BehaviorSubject(false);\r\n    private data$ = new BehaviorSubject<T | undefined>(undefined);\r\n    constructor(private config: AlertConfig<T>) {\r\n        if (this.config.recheckIntervalMs) {\r\n            interval(this.config.recheckIntervalMs).subscribe(() => this.runCheck());\r\n        }\r\n        this.activeAlert$ = combineLatest(this.data$, this.hasRun$).pipe(\r\n            map(([data, hasRun]) => {\r\n                if (!data) {\r\n                    return;\r\n                }\r\n                const isAlert = this.config.isAlert(data);\r\n                if (!isAlert) {\r\n                    return;\r\n                }\r\n                return {\r\n                    id: this.config.id,\r\n                    runAction: () => {\r\n                        if (!hasRun) {\r\n                            this.config.action(data);\r\n                            this.hasRun$.next(true);\r\n                        }\r\n                    },\r\n                    hasRun,\r\n                    label: this.config.label(data),\r\n                };\r\n            }),\r\n        );\r\n    }\r\n    get id() {\r\n        return this.config.id;\r\n    }\r\n    runCheck() {\r\n        const result = this.config.check();\r\n        if (result instanceof Promise) {\r\n            result.then(data => this.data$.next(data));\r\n        } else if (isObservable(result)) {\r\n            result.pipe(take(1)).subscribe(data => this.data$.next(data));\r\n        } else {\r\n            this.data$.next(result);\r\n        }\r\n        this.hasRun$.next(false);\r\n    }\r\n}\r\n\r\n@Injectable({\r\n    providedIn: 'root',\r\n})\r\nexport class AlertsService {\r\n    activeAlerts$: Observable<ActiveAlert[]>;\r\n    private alertsMap = new Map<string, Alert<any>>();\r\n    private configUpdated = new Subject<void>();\r\n\r\n    constructor(private dataService: DataService) {\r\n        const alerts$ = this.configUpdated.pipe(\r\n            mapTo([...this.alertsMap.values()]),\r\n            startWith([...this.alertsMap.values()]),\r\n        );\r\n\r\n        this.activeAlerts$ = alerts$.pipe(\r\n            switchMap(() => {\r\n                const alerts = [...this.alertsMap.values()];\r\n                const isAlertStreams = alerts.map(alert => alert.activeAlert$);\r\n                return combineLatest(isAlertStreams);\r\n            }),\r\n            map(alertStates => alertStates.filter(notNullOrUndefined)),\r\n        );\r\n    }\r\n\r\n    configureAlert<T>(config: AlertConfig<T>) {\r\n        this.hasSufficientPermissions(config.requiredPermissions)\r\n            .pipe(first())\r\n            .subscribe(hasSufficientPermissions => {\r\n                if (hasSufficientPermissions) {\r\n                    this.alertsMap.set(config.id, new Alert(config));\r\n                    this.configUpdated.next();\r\n                }\r\n            });\r\n    }\r\n\r\n    hasSufficientPermissions(permissions?: Permission[]) {\r\n        if (!permissions || permissions.length === 0) {\r\n            return of(true);\r\n        }\r\n        return this.dataService.client.userStatus().stream$.pipe(\r\n            filter(({ userStatus }) => userStatus.isLoggedIn),\r\n            map(({ userStatus }) =>\r\n                permissions.some(permission => userStatus.permissions.includes(permission)),\r\n            ),\r\n        );\r\n    }\r\n\r\n    refresh(id?: string) {\r\n        if (id) {\r\n            this.alertsMap.get(id)?.runCheck();\r\n        } else {\r\n            this.alertsMap.forEach(config => config.runCheck());\r\n        }\r\n    }\r\n}\r\n"]}
|
|
@@ -39,11 +39,11 @@ export class RadioCardFieldsetComponent {
|
|
|
39
39
|
this.focussedId = item && this.idFn(item);
|
|
40
40
|
}
|
|
41
41
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: RadioCardFieldsetComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
42
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.2", type: RadioCardFieldsetComponent, selector: "vdr-radio-card-fieldset", inputs: { selectedItemId: "selectedItemId", idFn: "idFn" }, outputs: { selectItem: "selectItem" }, usesOnChanges: true, ngImport: i0, template: `<fieldset><ng-content></ng-content></fieldset> `, isInline: true, styles: ["fieldset{display:flex;align-items:flex-start}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
42
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.2", type: RadioCardFieldsetComponent, selector: "vdr-radio-card-fieldset", inputs: { selectedItemId: "selectedItemId", idFn: "idFn" }, outputs: { selectItem: "selectItem" }, usesOnChanges: true, ngImport: i0, template: `<fieldset><ng-content></ng-content></fieldset> `, isInline: true, styles: ["fieldset{display:flex;align-items:flex-start;overflow-x:auto}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
43
43
|
}
|
|
44
44
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: RadioCardFieldsetComponent, decorators: [{
|
|
45
45
|
type: Component,
|
|
46
|
-
args: [{ selector: 'vdr-radio-card-fieldset', template: `<fieldset><ng-content></ng-content></fieldset> `, changeDetection: ChangeDetectionStrategy.OnPush, styles: ["fieldset{display:flex;align-items:flex-start}\n"] }]
|
|
46
|
+
args: [{ selector: 'vdr-radio-card-fieldset', template: `<fieldset><ng-content></ng-content></fieldset> `, changeDetection: ChangeDetectionStrategy.OnPush, styles: ["fieldset{display:flex;align-items:flex-start;overflow-x:auto}\n"] }]
|
|
47
47
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { selectedItemId: [{
|
|
48
48
|
type: Input
|
|
49
49
|
}], idFn: [{
|
package/esm2022/core/shared/components/tabbed-custom-fields/tabbed-custom-fields.component.mjs
CHANGED
|
@@ -49,11 +49,11 @@ export class TabbedCustomFieldsComponent {
|
|
|
49
49
|
.map(([tabName, customFields]) => ({ tabName, customFields }));
|
|
50
50
|
}
|
|
51
51
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: TabbedCustomFieldsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
52
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.2", type: TabbedCustomFieldsComponent, selector: "vdr-tabbed-custom-fields", inputs: { entityName: "entityName", customFields: "customFields", customFieldsFormGroup: "customFieldsFormGroup", readonly: "readonly", compact: "compact", showLabel: "showLabel" }, ngImport: i0, template: "<ng-container *ngIf=\"1 < tabbedCustomFields.length; else singleGroup\">\r\n <clr-tabs>\r\n <clr-tab *ngFor=\"let group of tabbedCustomFields\">\r\n <button clrTabLink>\r\n {{\r\n group.tabName === defaultTabName\r\n ? ('common.general' | translate)\r\n : (group.tabName | translate)\r\n }}\r\n </button>\r\n <clr-tab-content *clrIfActive>\r\n <div class=\"mt-2 form-grid\">\r\n <ng-container *ngFor=\"let customField of group.customFields\">\r\n <vdr-custom-field-control\r\n *ngIf=\"customFieldIsSet(customField.name)\"\r\n [entityName]=\"entityName\"\r\n [class.form-grid-span]=\"componentShouldSpanGrid(customField)\"\r\n [customFieldsFormGroup]=\"customFieldsFormGroup\"\r\n [customField]=\"customField\"\r\n [readonly]=\"readonly\"\r\n [compact]=\"compact\"\r\n [showLabel]=\"showLabel\"\r\n ></vdr-custom-field-control>\r\n </ng-container>\r\n </div>\r\n </clr-tab-content>\r\n </clr-tab>\r\n </clr-tabs>\r\n</ng-container>\r\n<ng-template #singleGroup>\r\n <div class=\"form-grid\">\r\n <ng-container *ngFor=\"let customField of tabbedCustomFields[0]?.customFields\">\r\n <vdr-custom-field-control\r\n *ngIf=\"customFieldIsSet(customField.name)\"\r\n [entityName]=\"entityName\"\r\n [class.form-grid-span]=\"componentShouldSpanGrid(customField)\"\r\n [customFieldsFormGroup]=\"customFieldsFormGroup\"\r\n [customField]=\"customField\"\r\n [readonly]=\"readonly\"\r\n [compact]=\"compact\"\r\n [showLabel]=\"showLabel\"\r\n ></vdr-custom-field-control>\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n", styles: [":host{display:contents}
|
|
52
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.2", type: TabbedCustomFieldsComponent, selector: "vdr-tabbed-custom-fields", inputs: { entityName: "entityName", customFields: "customFields", customFieldsFormGroup: "customFieldsFormGroup", readonly: "readonly", compact: "compact", showLabel: "showLabel" }, ngImport: i0, template: "<ng-container *ngIf=\"1 < tabbedCustomFields.length; else singleGroup\">\r\n <clr-tabs>\r\n <clr-tab *ngFor=\"let group of tabbedCustomFields\">\r\n <button clrTabLink>\r\n {{\r\n group.tabName === defaultTabName\r\n ? ('common.general' | translate)\r\n : (group.tabName | translate)\r\n }}\r\n </button>\r\n <clr-tab-content *clrIfActive>\r\n <div class=\"mt-2 form-grid\">\r\n <ng-container *ngFor=\"let customField of group.customFields\">\r\n <vdr-custom-field-control\r\n *ngIf=\"customFieldIsSet(customField.name)\"\r\n [entityName]=\"entityName\"\r\n [class.form-grid-span]=\"componentShouldSpanGrid(customField)\"\r\n [customFieldsFormGroup]=\"customFieldsFormGroup\"\r\n [customField]=\"customField\"\r\n [readonly]=\"readonly\"\r\n [compact]=\"compact\"\r\n [showLabel]=\"showLabel\"\r\n ></vdr-custom-field-control>\r\n </ng-container>\r\n </div>\r\n </clr-tab-content>\r\n </clr-tab>\r\n </clr-tabs>\r\n</ng-container>\r\n<ng-template #singleGroup>\r\n <div class=\"form-grid\">\r\n <ng-container *ngFor=\"let customField of tabbedCustomFields[0]?.customFields\">\r\n <vdr-custom-field-control\r\n *ngIf=\"customFieldIsSet(customField.name)\"\r\n [entityName]=\"entityName\"\r\n [class.form-grid-span]=\"componentShouldSpanGrid(customField)\"\r\n [customFieldsFormGroup]=\"customFieldsFormGroup\"\r\n [customField]=\"customField\"\r\n [readonly]=\"readonly\"\r\n [compact]=\"compact\"\r\n [showLabel]=\"showLabel\"\r\n ></vdr-custom-field-control>\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n", styles: [":host{display:contents}\n"], dependencies: [{ kind: "directive", type: i1.ClrIfActive, selector: "[clrIfActive]", inputs: ["clrIfActive"], outputs: ["clrIfActiveChange"] }, { kind: "component", type: i1.ClrTabContent, selector: "clr-tab-content", inputs: ["id"] }, { kind: "component", type: i1.ClrTab, selector: "clr-tab" }, { kind: "component", type: i1.ClrTabs, selector: "clr-tabs", inputs: ["clrLayout"] }, { kind: "directive", type: i1.ClrTabLink, selector: "[clrTabLink]", inputs: ["id", "clrTabLinkInOverflow"] }, { kind: "directive", type: i1.ÇlrTabsWillyWonka, selector: "clr-tabs" }, { kind: "directive", type: i1.ÇlrActiveOompaLoompa, selector: "[clrTabLink], clr-tab-content" }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.CustomFieldControlComponent, selector: "vdr-custom-field-control", inputs: ["entityName", "customFieldsFormGroup", "customField", "compact", "showLabel", "readonly"] }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
53
53
|
}
|
|
54
54
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImport: i0, type: TabbedCustomFieldsComponent, decorators: [{
|
|
55
55
|
type: Component,
|
|
56
|
-
args: [{ selector: 'vdr-tabbed-custom-fields', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"1 < tabbedCustomFields.length; else singleGroup\">\r\n <clr-tabs>\r\n <clr-tab *ngFor=\"let group of tabbedCustomFields\">\r\n <button clrTabLink>\r\n {{\r\n group.tabName === defaultTabName\r\n ? ('common.general' | translate)\r\n : (group.tabName | translate)\r\n }}\r\n </button>\r\n <clr-tab-content *clrIfActive>\r\n <div class=\"mt-2 form-grid\">\r\n <ng-container *ngFor=\"let customField of group.customFields\">\r\n <vdr-custom-field-control\r\n *ngIf=\"customFieldIsSet(customField.name)\"\r\n [entityName]=\"entityName\"\r\n [class.form-grid-span]=\"componentShouldSpanGrid(customField)\"\r\n [customFieldsFormGroup]=\"customFieldsFormGroup\"\r\n [customField]=\"customField\"\r\n [readonly]=\"readonly\"\r\n [compact]=\"compact\"\r\n [showLabel]=\"showLabel\"\r\n ></vdr-custom-field-control>\r\n </ng-container>\r\n </div>\r\n </clr-tab-content>\r\n </clr-tab>\r\n </clr-tabs>\r\n</ng-container>\r\n<ng-template #singleGroup>\r\n <div class=\"form-grid\">\r\n <ng-container *ngFor=\"let customField of tabbedCustomFields[0]?.customFields\">\r\n <vdr-custom-field-control\r\n *ngIf=\"customFieldIsSet(customField.name)\"\r\n [entityName]=\"entityName\"\r\n [class.form-grid-span]=\"componentShouldSpanGrid(customField)\"\r\n [customFieldsFormGroup]=\"customFieldsFormGroup\"\r\n [customField]=\"customField\"\r\n [readonly]=\"readonly\"\r\n [compact]=\"compact\"\r\n [showLabel]=\"showLabel\"\r\n ></vdr-custom-field-control>\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n", styles: [":host{display:contents}
|
|
56
|
+
args: [{ selector: 'vdr-tabbed-custom-fields', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"1 < tabbedCustomFields.length; else singleGroup\">\r\n <clr-tabs>\r\n <clr-tab *ngFor=\"let group of tabbedCustomFields\">\r\n <button clrTabLink>\r\n {{\r\n group.tabName === defaultTabName\r\n ? ('common.general' | translate)\r\n : (group.tabName | translate)\r\n }}\r\n </button>\r\n <clr-tab-content *clrIfActive>\r\n <div class=\"mt-2 form-grid\">\r\n <ng-container *ngFor=\"let customField of group.customFields\">\r\n <vdr-custom-field-control\r\n *ngIf=\"customFieldIsSet(customField.name)\"\r\n [entityName]=\"entityName\"\r\n [class.form-grid-span]=\"componentShouldSpanGrid(customField)\"\r\n [customFieldsFormGroup]=\"customFieldsFormGroup\"\r\n [customField]=\"customField\"\r\n [readonly]=\"readonly\"\r\n [compact]=\"compact\"\r\n [showLabel]=\"showLabel\"\r\n ></vdr-custom-field-control>\r\n </ng-container>\r\n </div>\r\n </clr-tab-content>\r\n </clr-tab>\r\n </clr-tabs>\r\n</ng-container>\r\n<ng-template #singleGroup>\r\n <div class=\"form-grid\">\r\n <ng-container *ngFor=\"let customField of tabbedCustomFields[0]?.customFields\">\r\n <vdr-custom-field-control\r\n *ngIf=\"customFieldIsSet(customField.name)\"\r\n [entityName]=\"entityName\"\r\n [class.form-grid-span]=\"componentShouldSpanGrid(customField)\"\r\n [customFieldsFormGroup]=\"customFieldsFormGroup\"\r\n [customField]=\"customField\"\r\n [readonly]=\"readonly\"\r\n [compact]=\"compact\"\r\n [showLabel]=\"showLabel\"\r\n ></vdr-custom-field-control>\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n", styles: [":host{display:contents}\n"] }]
|
|
57
57
|
}], propDecorators: { entityName: [{
|
|
58
58
|
type: Input
|
|
59
59
|
}], customFields: [{
|