@vendure/admin-ui 2.0.0 → 2.0.1
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/components/product-options-editor/product-options-editor.component.d.ts +6 -0
- package/core/common/base-detail.component.d.ts +28 -0
- package/core/common/version.d.ts +1 -1
- package/core/data/providers/interceptor.d.ts +11 -1
- package/core/providers/page/page.service.d.ts +7 -0
- package/esm2022/catalog/catalog.module.mjs +2 -2
- package/esm2022/catalog/components/create-product-variant-dialog/create-product-variant-dialog.component.mjs +3 -3
- package/esm2022/catalog/components/product-options-editor/product-options-editor.component.mjs +13 -5
- package/esm2022/core/common/base-detail.component.mjs +29 -1
- package/esm2022/core/common/base-list.component.mjs +1 -1
- package/esm2022/core/common/component-registry-types.mjs +1 -1
- package/esm2022/core/common/title-setter.mjs +1 -1
- package/esm2022/core/common/version.mjs +2 -2
- package/esm2022/core/data/providers/interceptor.mjs +32 -11
- package/esm2022/core/providers/bulk-action-registry/bulk-action-types.mjs +1 -1
- package/esm2022/core/providers/custom-field-component/custom-field-component.service.mjs +1 -1
- package/esm2022/core/providers/local-storage/local-storage.service.mjs +1 -4
- package/esm2022/core/providers/page/page.service.mjs +5 -2
- package/esm2022/core/shared/components/action-bar-items/action-bar-items.component.mjs +1 -1
- package/esm2022/core/shared/components/asset-file-input/asset-file-input.component.mjs +1 -1
- package/esm2022/core/shared/components/assign-to-channel-dialog/assign-to-channel-dialog.component.mjs +1 -1
- package/esm2022/core/shared/components/currency-code-selector/currency-code-selector.component.mjs +1 -1
- package/esm2022/core/shared/components/data-table/data-table.component.mjs +1 -1
- package/esm2022/core/shared/components/language-code-selector/language-code-selector.component.mjs +1 -1
- package/esm2022/core/shared/components/select-toggle/select-toggle.component.mjs +3 -3
- package/esm2022/core/shared/dynamic-form-inputs/register-dynamic-input-components.mjs +1 -1
- package/esm2022/core/shared/pipes/state-i18n-token.pipe.mjs +1 -1
- package/esm2022/customer/components/address-card/address-card.component.mjs +3 -3
- package/esm2022/customer/components/customer-list/customer-list.component.mjs +14 -10
- package/esm2022/customer/customer.module.mjs +1 -1
- package/esm2022/customer/customer.routes.mjs +2 -2
- package/esm2022/dashboard/components/dashboard/dashboard.component.mjs +1 -1
- package/esm2022/marketing/marketing.module.mjs +1 -1
- package/esm2022/order/components/add-manual-payment-dialog/add-manual-payment-dialog.component.mjs +3 -3
- package/esm2022/order/components/draft-order-detail/draft-order-detail.component.mjs +3 -3
- package/esm2022/order/components/order-detail/order-detail.component.mjs +2 -4
- package/esm2022/order/components/select-customer-dialog/select-customer-dialog.component.mjs +3 -3
- package/esm2022/order/order.module.mjs +1 -1
- package/esm2022/order/order.routes.mjs +1 -1
- package/esm2022/settings/components/channel-detail/channel-detail.component.mjs +2 -3
- package/esm2022/settings/components/tax-rate-detail/tax-rate-detail.component.mjs +8 -8
- package/esm2022/settings/settings.module.mjs +1 -1
- package/fesm2022/vendure-admin-ui-catalog.mjs +15 -7
- package/fesm2022/vendure-admin-ui-catalog.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-core.mjs +65 -16
- package/fesm2022/vendure-admin-ui-core.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-customer.mjs +16 -12
- package/fesm2022/vendure-admin-ui-customer.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-dashboard.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-marketing.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-order.mjs +7 -9
- package/fesm2022/vendure-admin-ui-order.mjs.map +1 -1
- package/fesm2022/vendure-admin-ui-settings.mjs +8 -9
- package/fesm2022/vendure-admin-ui-settings.mjs.map +1 -1
- package/package.json +14 -14
- package/static/i18n-messages/cs.json +770 -768
- package/static/i18n-messages/de.json +771 -769
- package/static/i18n-messages/en.json +771 -769
- package/static/i18n-messages/es.json +770 -768
- package/static/i18n-messages/fr.json +770 -768
- package/static/i18n-messages/it.json +770 -768
- package/static/i18n-messages/pl.json +770 -768
- package/static/i18n-messages/pt_BR.json +770 -768
- package/static/i18n-messages/pt_PT.json +770 -768
- package/static/i18n-messages/ru.json +770 -768
- package/static/i18n-messages/uk.json +770 -768
- package/static/i18n-messages/zh_Hans.json +770 -768
- package/static/i18n-messages/zh_Hant.json +770 -768
- package/static/styles/global/_buttons.scss +24 -0
- package/static/theme.min.css +1 -1
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50LXJlZ2lzdHJ5LXR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9jb3JlL3NyYy9jb21tb24vY29tcG9uZW50LXJlZ2lzdHJ5LXR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBVbnR5cGVkRm9ybUNvbnRyb2wgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcblxyXG4vKipcclxuICogQGRlc2NyaXB0aW9uXHJcbiAqIFRoaXMgaW50ZXJmYWNlIHNob3VsZCBiZSBpbXBsZW1lbnRlZCBieSBhbnkgY29tcG9uZW50IGJlaW5nIHVzZWQgYXMgYSBjdXN0b20gaW5wdXQuIEZvciBleGFtcGxlLFxyXG4gKiBpbnB1dHMgZm9yIGN1c3RvbSBmaWVsZHMsIG9yIGZvciBjb25maWd1cmFibGUgYXJndW1lbnRzLlxyXG4gKlxyXG4gKiBAZG9jc0NhdGVnb3J5IGN1c3RvbS1pbnB1dC1jb21wb25lbnRzXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIEZvcm1JbnB1dENvbXBvbmVudDxDID0gSW5wdXRDb21wb25lbnRDb25maWc+IHtcclxuICAgIC8qKlxyXG4gICAgICogQGRlc2NyaXB0aW9uXHJcbiAgICAgKiBTaG91bGQgYmUgc2V0IHRvIGB0cnVlYCBpZiB0aGlzIGNvbXBvbmVudCBpcyBkZXNpZ25lZCB0byBoYW5kbGUgbGlzdHMuXHJcbiAgICAgKiBJZiBgdHJ1ZWAgdGhlbiB0aGUgZm9ybUNvbnRyb2wgdmFsdWUgd2lsbCBiZSBhbiBhcnJheSBvZiBhbGwgdGhlXHJcbiAgICAgKiB2YWx1ZXMgaW4gdGhlIGxpc3QuXHJcbiAgICAgKi9cclxuICAgIGlzTGlzdElucHV0PzogYm9vbGVhbjtcclxuICAgIC8qKlxyXG4gICAgICogQGRlc2NyaXB0aW9uXHJcbiAgICAgKiBUaGlzIGlzIHNldCBieSB0aGUgQWRtaW4gVUkgd2hlbiBjb25zdW1pbmcgdGhpcyBjb21wb25lbnQsIGluZGljYXRpbmcgdGhhdCB0aGVcclxuICAgICAqIGNvbXBvbmVudCBzaG91bGQgYmUgcmVuZGVyZWQgaW4gYSByZWFkLW9ubHkgc3RhdGUuXHJcbiAgICAgKi9cclxuICAgIHJlYWRvbmx5OiBib29sZWFuO1xyXG4gICAgLyoqXHJcbiAgICAgKiBAZGVzY3JpcHRpb25cclxuICAgICAqIFRoaXMgY29udHJvbHMgdGhlIGFjdHVhbCB2YWx1ZSBvZiB0aGUgZm9ybSBpdGVtLiBUaGUgY3VycmVudCB2YWx1ZSBpcyBhdmFpbGFibGVcclxuICAgICAqIGFzIGB0aGlzLmZvcm1Db250cm9sLnZhbHVlYCwgYW5kIGFuIE9ic2VydmFibGUgc3RyZWFtIG9mIHZhbHVlIGNoYW5nZXMgaXMgYXZhaWxhYmxlXHJcbiAgICAgKiBhcyBgdGhpcy5mb3JtQ29udHJvbC52YWx1ZUNoYW5nZXNgLiBUbyB1cGRhdGUgdGhlIHZhbHVlLCB1c2UgYC5zZXRWYWx1ZSh2YWwpYCBhbmQgdGhlblxyXG4gICAgICogYC5tYXJrQXNEaXJ0eSgpYC5cclxuICAgICAqXHJcbiAgICAgKiBGdWxsIGRvY3VtZW50YXRpb24gY2FuIGJlIGZvdW5kIGluIHRoZSBbQW5ndWxhciBkb2NzXShodHRwczovL2FuZ3VsYXIuaW8vYXBpL2Zvcm1zL0Zvcm1Db250cm9sKS5cclxuICAgICAqL1xyXG4gICAgZm9ybUNvbnRyb2w6IFVudHlwZWRGb3JtQ29udHJvbDtcclxuICAgIC8qKlxyXG4gICAgICogQGRlc2NyaXB0aW9uXHJcbiAgICAgKiBUaGUgYGNvbmZpZ2AgcHJvcGVydHkgY29udGFpbnMgdGhlIGZ1bGwgY29uZmlndXJhdGlvbiBvYmplY3Qgb2YgdGhlIGN1c3RvbSBmaWVsZCBvciBjb25maWd1cmFibGUgYXJndW1lbnQuXHJcbiAgICAgKi9cclxuICAgIGNvbmZpZzogQztcclxufVxyXG5cclxuZXhwb3J0IHR5cGUgSW5wdXRDb21wb25lbnRDb25maWcgPSB7XHJcbiAgICBbcHJvcDogc3RyaW5nXTogYW55O1xyXG59O1xyXG5cclxuLyoqXHJcbiAqIEBkZXNjcmlwdGlvblxyXG4gKiBUaGUgdmFsaWQgbG9jYXRpb25JZHMgZm9yIHJlZ2lzdGVyaW5nIGFjdGlvbiBiYXIgaXRlbXMgb3IgdGFicy5cclxuICpcclxuICogQGRvY3NDYXRlZ29yeSBhY3Rpb24tYmFyXHJcbiAqL1xyXG5leHBvcnQgdHlwZSBQYWdlTG9jYXRpb25JZCA9XHJcbiAgICB8ICdhZG1pbmlzdHJhdG9yLWRldGFpbCdcclxuICAgIHwgJ2FkbWluaXN0cmF0b3ItbGlzdCdcclxuICAgIHwgJ2Fzc2V0LWRldGFpbCdcclxuICAgIHwgJ2Fzc2V0LWxpc3QnXHJcbiAgICB8ICdjaGFubmVsLWRldGFpbCdcclxuICAgIHwgJ2NoYW5uZWwtbGlzdCdcclxuICAgIHwgJ2NvbGxlY3Rpb24tZGV0YWlsJ1xyXG4gICAgfCAnY29sbGVjdGlvbi1saXN0J1xyXG4gICAgfCAnY291bnRyeS1kZXRhaWwnXHJcbiAgICB8ICdjb3VudHJ5LWxpc3QnXHJcbiAgICB8ICdjdXN0b21lci1kZXRhaWwnXHJcbiAgICB8ICdjdXN0b21lci1saXN0J1xyXG4gICAgfCAnY3VzdG9tZXItZ3JvdXAtbGlzdCdcclxuICAgIHwgJ2N1c3RvbWVyLWdyb3VwLWRldGFpbCdcclxuICAgIHwgJ2RyYWZ0LW9yZGVyLWRldGFpbCdcclxuICAgIHwgJ2ZhY2V0LWRldGFpbCdcclxuICAgIHwgJ2ZhY2V0LWxpc3QnXHJcbiAgICB8ICdnbG9iYWwtc2V0dGluZy1kZXRhaWwnXHJcbiAgICB8ICdzeXN0ZW0tc3RhdHVzJ1xyXG4gICAgfCAnam9iLWxpc3QnXHJcbiAgICB8ICdvcmRlci1kZXRhaWwnXHJcbiAgICB8ICdvcmRlci1saXN0J1xyXG4gICAgfCAncGF5bWVudC1tZXRob2QtZGV0YWlsJ1xyXG4gICAgfCAncGF5bWVudC1tZXRob2QtbGlzdCdcclxuICAgIHwgJ3Byb2R1Y3QtZGV0YWlsJ1xyXG4gICAgfCAncHJvZHVjdC1saXN0J1xyXG4gICAgfCAncHJvZHVjdC12YXJpYW50LWRldGFpbCdcclxuICAgIHwgJ3Byb2ZpbGUnXHJcbiAgICB8ICdwcm9tb3Rpb24tZGV0YWlsJ1xyXG4gICAgfCAncHJvbW90aW9uLWxpc3QnXHJcbiAgICB8ICdyb2xlLWRldGFpbCdcclxuICAgIHwgJ3JvbGUtbGlzdCdcclxuICAgIHwgJ3NlbGxlci1kZXRhaWwnXHJcbiAgICB8ICdzZWxsZXItbGlzdCdcclxuICAgIHwgJ3NoaXBwaW5nLW1ldGhvZC1kZXRhaWwnXHJcbiAgICB8ICdzaGlwcGluZy1tZXRob2QtbGlzdCdcclxuICAgIHwgJ3N0b2NrLWxvY2F0aW9uLWRldGFpbCdcclxuICAgIHwgJ3N0b2NrLWxvY2F0aW9uLWxpc3QnXHJcbiAgICB8ICd0YXgtY2F0ZWdvcnktZGV0YWlsJ1xyXG4gICAgfCAndGF4LWNhdGVnb3J5LWxpc3QnXHJcbiAgICB8ICd0YXgtcmF0ZS1kZXRhaWwnXHJcbiAgICB8ICd0YXgtcmF0ZS1saXN0J1xyXG4gICAgfCAnem9uZS1kZXRhaWwnXHJcbiAgICB8ICd6b25lLWxpc3QnO1xyXG5cclxuLyoqXHJcbiAqIEBkZXNjcmlwdGlvblxyXG4gKiBUaGUgdmFsaWQgbG9jYXRpb25JZHMgZm9yIHJlZ2lzdGVyaW5nIGFjdGlvbiBiYXIgaXRlbXMuXHJcbiAqXHJcbiAqIEBkb2NzQ2F0ZWdvcnkgYWN0aW9uLWJhclxyXG4gKi9cclxuZXhwb3J0IHR5cGUgQWN0aW9uQmFyTG9jYXRpb25JZCA9IFBhZ2VMb2NhdGlvbklkO1xyXG5cclxuLyoqXHJcbiAqIEBkZXNjcmlwdGlvblxyXG4gKiBUaGUgdmFsaWQgbG9jYXRpb25zIGZvciBlbWJlZGRpbmcgYSB7QGxpbmsgQ3VzdG9tRGV0YWlsQ29tcG9uZW50fS5cclxuICpcclxuICogQGRvY3NDYXRlZ29yeSBjdXN0b20tZGV0YWlsLWNvbXBvbmVudHNcclxuICovXHJcbmV4cG9ydCB0eXBlIEN1c3RvbURldGFpbENvbXBvbmVudExvY2F0aW9uSWQgPVxyXG4gICAgfCAnYWRtaW5pc3RyYXRvci1wcm9maWxlJ1xyXG4gICAgfCAnYWRtaW5pc3RyYXRvci1kZXRhaWwnXHJcbiAgICB8ICdjaGFubmVsLWRldGFpbCdcclxuICAgIHwgJ2NvbGxlY3Rpb24tZGV0YWlsJ1xyXG4gICAgfCAnY291bnRyeS1kZXRhaWwnXHJcbiAgICB8ICdjdXN0b21lci1kZXRhaWwnXHJcbiAgICB8ICdjdXN0b21lci1ncm91cC1kZXRhaWwnXHJcbiAgICB8ICdmYWNldC1kZXRhaWwnXHJcbiAgICB8ICdnbG9iYWwtc2V0dGluZ3MtZGV0YWlsJ1xyXG4gICAgfCAnb3JkZXItZGV0YWlsJ1xyXG4gICAgfCAncGF5bWVudC1tZXRob2QtZGV0YWlsJ1xyXG4gICAgfCAncHJvZHVjdC1kZXRhaWwnXHJcbiAgICB8ICdwcm9kdWN0LXZhcmlhbnQtZGV0YWlsJ1xyXG4gICAgfCAncHJvbW90aW9uLWRldGFpbCdcclxuICAgIHwgJ3NlbGxlci1kZXRhaWwnXHJcbiAgICB8ICdzaGlwcGluZy1tZXRob2QtZGV0YWlsJ1xyXG4gICAgfCAnc3RvY2stbG9jYXRpb24tZGV0YWlsJ1xyXG4gICAgfCAndGF4LWNhdGVnb3J5LWRldGFpbCdcclxuICAgIHwgJ3RheC1yYXRlLWRldGFpbCdcclxuICAgIHwgJ3pvbmUtZGV0YWlsJztcclxuXHJcbmV4cG9ydCB0eXBlIFVJRXh0ZW5zaW9uTG9jYXRpb25JZCA9IEFjdGlvbkJhckxvY2F0aW9uSWQgfCBDdXN0b21EZXRhaWxDb21wb25lbnRMb2NhdGlvbklkO1xyXG4iXX0=
|
|
@@ -11,4 +11,4 @@ export function titleSetter() {
|
|
|
11
11
|
const brand = getAppConfig().brand || 'Vendure';
|
|
12
12
|
return (title) => titleService.setTitle(`${i18nService.translate(title)} • ${brand}`);
|
|
13
13
|
}
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGl0bGUtc2V0dGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9jb3JlL3NyYy9jb21tb24vdGl0bGUtc2V0dGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ2xELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDN0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBRTdEOztHQUVHO0FBQ0gsTUFBTSxVQUFVLFdBQVc7SUFDdkIsTUFBTSxZQUFZLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ25DLE1BQU0sV0FBVyxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUN4QyxNQUFNLEtBQUssR0FBRyxZQUFZLEVBQUUsQ0FBQyxLQUFLLElBQUksU0FBUyxDQUFDO0lBQ2hELE9BQU8sQ0FBQyxLQUFhLEVBQUUsRUFBRSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsR0FBRyxXQUFXLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxNQUFNLEtBQUssRUFBRSxDQUFDLENBQUM7QUFDbEcsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBUaXRsZSB9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xyXG5pbXBvcnQgeyBnZXRBcHBDb25maWcgfSBmcm9tICcuLi9hcHAuY29uZmlnJztcclxuaW1wb3J0IHsgSTE4blNlcnZpY2UgfSBmcm9tICcuLi9wcm92aWRlcnMvaTE4bi9pMThuLnNlcnZpY2UnO1xyXG5cclxuLyoqXHJcbiAqIENyZWF0ZXMgYSBmdW5jdGlvbiB0aGF0IGNhbiBiZSB1c2VkIHRvIHNldCB0aGUgbWV0YSB0aXRsZSBvZiB0aGUgY3VycmVudCBwYWdlLlxyXG4gKi9cclxuZXhwb3J0IGZ1bmN0aW9uIHRpdGxlU2V0dGVyKCkge1xyXG4gICAgY29uc3QgdGl0bGVTZXJ2aWNlID0gaW5qZWN0KFRpdGxlKTtcclxuICAgIGNvbnN0IGkxOG5TZXJ2aWNlID0gaW5qZWN0KEkxOG5TZXJ2aWNlKTtcclxuICAgIGNvbnN0IGJyYW5kID0gZ2V0QXBwQ29uZmlnKCkuYnJhbmQgfHwgJ1ZlbmR1cmUnO1xyXG4gICAgcmV0dXJuICh0aXRsZTogc3RyaW5nKSA9PiB0aXRsZVNlcnZpY2Uuc2V0VGl0bGUoYCR7aTE4blNlcnZpY2UudHJhbnNsYXRlKHRpdGxlKX0g4oCiICR7YnJhbmR9YCk7XHJcbn1cclxuIl19
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
// Auto-generated by the set-version.js script.
|
|
2
|
-
export const ADMIN_UI_VERSION = '2.0.
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
export const ADMIN_UI_VERSION = '2.0.1';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvY29yZS9zcmMvY29tbW9uL3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsK0NBQStDO0FBQy9DLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLE9BQU8sQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIEF1dG8tZ2VuZXJhdGVkIGJ5IHRoZSBzZXQtdmVyc2lvbi5qcyBzY3JpcHQuXG5leHBvcnQgY29uc3QgQURNSU5fVUlfVkVSU0lPTiA9ICcyLjAuMSc7XG4iXX0=
|
|
@@ -6,7 +6,7 @@ import { switchMap, tap } from 'rxjs/operators';
|
|
|
6
6
|
import { getAppConfig } from '../../app.config';
|
|
7
7
|
import { NotificationService } from '../../providers/notification/notification.service';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
|
-
import * as i1 from "
|
|
9
|
+
import * as i1 from "./data.service";
|
|
10
10
|
import * as i2 from "../../providers/auth/auth.service";
|
|
11
11
|
import * as i3 from "@angular/router";
|
|
12
12
|
import * as i4 from "../../providers/local-storage/local-storage.service";
|
|
@@ -69,21 +69,25 @@ export class DefaultInterceptor {
|
|
|
69
69
|
else {
|
|
70
70
|
// GraphQL errors still return 200 OK responses, but have the actual error message
|
|
71
71
|
// inside the body of the response.
|
|
72
|
-
const
|
|
73
|
-
if (
|
|
74
|
-
const firstCode =
|
|
72
|
+
const graphQLErrors = response.body.errors;
|
|
73
|
+
if (graphQLErrors && Array.isArray(graphQLErrors)) {
|
|
74
|
+
const firstCode = graphQLErrors[0]?.extensions?.code;
|
|
75
75
|
if (firstCode === 'FORBIDDEN') {
|
|
76
76
|
this.authService.logOut().subscribe(() => {
|
|
77
77
|
const { loginUrl } = getAppConfig();
|
|
78
|
-
|
|
78
|
+
// If there is a `loginUrl` which is external to the AdminUI, redirect to it (with no query parameters)
|
|
79
|
+
if (loginUrl && !this.areUrlsOnSameOrigin(loginUrl, window.location.origin)) {
|
|
79
80
|
window.location.href = loginUrl;
|
|
80
81
|
return;
|
|
81
82
|
}
|
|
82
|
-
if
|
|
83
|
-
|
|
83
|
+
// Else, we build the login path from the login url if one is provided or fallback to `/login`
|
|
84
|
+
const loginPath = loginUrl ? this.getPathFromLoginUrl(loginUrl) : '/login';
|
|
85
|
+
if (!window.location.pathname.includes(loginPath)) {
|
|
86
|
+
const path = graphQLErrors[0].path.join(' > ');
|
|
84
87
|
this.displayErrorNotification(_(`error.403-forbidden`), { path });
|
|
85
88
|
}
|
|
86
|
-
|
|
89
|
+
// Navigate to the `loginPath` route by ensuring the query param in charge of the redirection is provided
|
|
90
|
+
this.router.navigate([loginPath], {
|
|
87
91
|
queryParams: {
|
|
88
92
|
[AUTH_REDIRECT_PARAM]: btoa(this.router.url),
|
|
89
93
|
},
|
|
@@ -91,12 +95,12 @@ export class DefaultInterceptor {
|
|
|
91
95
|
});
|
|
92
96
|
}
|
|
93
97
|
else if (firstCode === 'CHANNEL_NOT_FOUND') {
|
|
94
|
-
const message =
|
|
98
|
+
const message = graphQLErrors.map(err => err.message).join('\n');
|
|
95
99
|
this.displayErrorNotification(message);
|
|
96
100
|
this.localStorageService.remove('activeChannelToken');
|
|
97
101
|
}
|
|
98
102
|
else {
|
|
99
|
-
const message =
|
|
103
|
+
const message = graphQLErrors.map(err => err.message).join('\n');
|
|
100
104
|
this.displayErrorNotification(message);
|
|
101
105
|
}
|
|
102
106
|
}
|
|
@@ -132,10 +136,27 @@ export class DefaultInterceptor {
|
|
|
132
136
|
}
|
|
133
137
|
}
|
|
134
138
|
}
|
|
139
|
+
/**
|
|
140
|
+
* Determine if two urls are on the same origin.
|
|
141
|
+
*/
|
|
142
|
+
areUrlsOnSameOrigin(urlA, urlB) {
|
|
143
|
+
return new URL(urlA).origin === new URL(urlB).origin;
|
|
144
|
+
}
|
|
145
|
+
/**
|
|
146
|
+
* If the provided `loginUrl` is on the same origin than the AdminUI, return the path
|
|
147
|
+
* after the `/admin`.
|
|
148
|
+
* Else, return the whole login url.
|
|
149
|
+
*/
|
|
150
|
+
getPathFromLoginUrl(loginUrl) {
|
|
151
|
+
if (!this.areUrlsOnSameOrigin(loginUrl, window.location.origin)) {
|
|
152
|
+
return loginUrl;
|
|
153
|
+
}
|
|
154
|
+
return loginUrl.split('/admin')[1];
|
|
155
|
+
}
|
|
135
156
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: DefaultInterceptor, deps: [{ token: i1.DataService }, { token: i0.Injector }, { token: i2.AuthService }, { token: i3.Router }, { token: i4.LocalStorageService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
136
157
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: DefaultInterceptor }); }
|
|
137
158
|
}
|
|
138
159
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImport: i0, type: DefaultInterceptor, decorators: [{
|
|
139
160
|
type: Injectable
|
|
140
161
|
}], ctorParameters: function () { return [{ type: i1.DataService }, { type: i0.Injector }, { type: i2.AuthService }, { type: i3.Router }, { type: i4.LocalStorageService }]; } });
|
|
141
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"interceptor.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/data/providers/interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    HttpErrorResponse,\n    HttpEvent,\n    HttpHandler,\n    HttpInterceptor,\n    HttpRequest,\n    HttpResponse,\n} from '@angular/common/http';\nimport { Injectable, Injector } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';\nimport { DEFAULT_AUTH_TOKEN_HEADER_KEY } from '@vendure/common/lib/shared-constants';\nimport { AdminUiConfig } from '@vendure/common/lib/shared-types';\nimport { Observable } from 'rxjs';\nimport { switchMap, tap } from 'rxjs/operators';\n\nimport { getAppConfig } from '../../app.config';\nimport { AuthService } from '../../providers/auth/auth.service';\nimport { LocalStorageService } from '../../providers/local-storage/local-storage.service';\nimport { NotificationService } from '../../providers/notification/notification.service';\nimport { DataService } from '../providers/data.service';\n\nexport const AUTH_REDIRECT_PARAM = 'redirectTo';\n\n/**\n * The default interceptor examines all HTTP requests & responses and automatically updates the requesting state\n * and shows error notifications.\n */\n@Injectable()\nexport class DefaultInterceptor implements HttpInterceptor {\n    private readonly tokenMethod: AdminUiConfig['tokenMethod'] = 'cookie';\n    private readonly authTokenHeaderKey: string;\n\n    constructor(\n        private dataService: DataService,\n        private injector: Injector,\n        private authService: AuthService,\n        private router: Router,\n        private localStorageService: LocalStorageService,\n    ) {\n        this.tokenMethod = getAppConfig().tokenMethod;\n        this.authTokenHeaderKey = getAppConfig().authTokenHeaderKey || DEFAULT_AUTH_TOKEN_HEADER_KEY;\n    }\n\n    intercept(req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\n        this.dataService.client.startRequest().subscribe();\n        return this.dataService.client.uiState().single$.pipe(\n            switchMap(({ uiState }) => {\n                const request = req.clone({\n                    setParams: {\n                        languageCode: uiState?.contentLanguage ?? '',\n                    },\n                });\n                return next.handle(request);\n            }),\n            tap(\n                event => {\n                    if (event instanceof HttpResponse) {\n                        this.checkForAuthToken(event);\n                        this.notifyOnError(event);\n                        this.dataService.client.completeRequest().subscribe();\n                    }\n                },\n                err => {\n                    if (err instanceof HttpErrorResponse) {\n                        this.notifyOnError(err);\n                        this.dataService.client.completeRequest().subscribe();\n                    } else {\n                        this.displayErrorNotification(err.message);\n                    }\n                },\n            ),\n        );\n    }\n\n    private notifyOnError(response: HttpResponse<any> | HttpErrorResponse) {\n        if (response instanceof HttpErrorResponse) {\n            if (response.status === 0) {\n                const { apiHost, apiPort } = getAppConfig();\n                this.displayErrorNotification(_(`error.could-not-connect-to-server`), {\n                    url: `${apiHost}:${apiPort}`,\n                });\n            } else if (response.status === 503 && response.url?.endsWith('/health')) {\n                this.displayErrorNotification(_(`error.health-check-failed`));\n            } else {\n                this.displayErrorNotification(this.extractErrorFromHttpResponse(response));\n            }\n        } else {\n            // GraphQL errors still return 200 OK responses, but have the actual error message\n            // inside the body of the response.\n            const graqhQLErrors = response.body.errors;\n            if (graqhQLErrors && Array.isArray(graqhQLErrors)) {\n                const firstCode: string = graqhQLErrors[0]?.extensions?.code;\n                if (firstCode === 'FORBIDDEN') {\n                    this.authService.logOut().subscribe(() => {\n                        const { loginUrl } = getAppConfig();\n                        if (loginUrl) {\n                            window.location.href = loginUrl;\n                            return;\n                        }\n\n                        if (!window.location.pathname.includes('login')) {\n                            const path = graqhQLErrors[0].path.join(' > ');\n                            this.displayErrorNotification(_(`error.403-forbidden`), { path });\n                        }\n                        this.router.navigate(['/login'], {\n                            queryParams: {\n                                [AUTH_REDIRECT_PARAM]: btoa(this.router.url),\n                            },\n                        });\n                    });\n                } else if (firstCode === 'CHANNEL_NOT_FOUND') {\n                    const message = graqhQLErrors.map(err => err.message).join('\\n');\n                    this.displayErrorNotification(message);\n                    this.localStorageService.remove('activeChannelToken');\n                } else {\n                    const message = graqhQLErrors.map(err => err.message).join('\\n');\n                    this.displayErrorNotification(message);\n                }\n            }\n        }\n    }\n\n    private extractErrorFromHttpResponse(response: HttpErrorResponse): string {\n        const errors = response.error.errors;\n        if (Array.isArray(errors)) {\n            return errors.map(e => e.message).join('\\n');\n        } else {\n            return response.message;\n        }\n    }\n\n    /**\n     * We need to lazily inject the NotificationService since it depends on the I18nService which\n     * eventually depends on the HttpClient (used to load messages from json files). If we were to\n     * directly inject NotificationService into the constructor, we get a cyclic dependency.\n     */\n    private displayErrorNotification(message: string, vars?: Record<string, any>): void {\n        const notificationService = this.injector.get<NotificationService>(NotificationService);\n        notificationService.error(message, vars);\n    }\n\n    /**\n     * If the server is configured to use the \"bearer\" tokenMethod, each response should be checked\n     * for the existence of an auth token.\n     */\n    private checkForAuthToken(response: HttpResponse<any>) {\n        if (this.tokenMethod === 'bearer') {\n            const authToken = response.headers.get(this.authTokenHeaderKey);\n            if (authToken) {\n                this.localStorageService.set('authToken', authToken);\n            }\n        }\n    }\n}\n"]}
|
|
162
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"interceptor.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/data/providers/interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    HttpErrorResponse,\r\n    HttpEvent,\r\n    HttpHandler,\r\n    HttpInterceptor,\r\n    HttpRequest,\r\n    HttpResponse,\r\n} from '@angular/common/http';\r\nimport { Injectable, Injector } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { marker as _ } from '@biesbjerg/ngx-translate-extract-marker';\r\nimport { DEFAULT_AUTH_TOKEN_HEADER_KEY } from '@vendure/common/lib/shared-constants';\r\nimport { AdminUiConfig } from '@vendure/common/lib/shared-types';\r\nimport { Observable } from 'rxjs';\r\nimport { switchMap, tap } from 'rxjs/operators';\r\n\r\nimport { getAppConfig } from '../../app.config';\r\nimport { AuthService } from '../../providers/auth/auth.service';\r\nimport { LocalStorageService } from '../../providers/local-storage/local-storage.service';\r\nimport { NotificationService } from '../../providers/notification/notification.service';\r\n\r\nimport { DataService } from './data.service';\r\n\r\nexport const AUTH_REDIRECT_PARAM = 'redirectTo';\r\n\r\n/**\r\n * The default interceptor examines all HTTP requests & responses and automatically updates the requesting state\r\n * and shows error notifications.\r\n */\r\n@Injectable()\r\nexport class DefaultInterceptor implements HttpInterceptor {\r\n    private readonly tokenMethod: AdminUiConfig['tokenMethod'] = 'cookie';\r\n    private readonly authTokenHeaderKey: string;\r\n\r\n    constructor(\r\n        private dataService: DataService,\r\n        private injector: Injector,\r\n        private authService: AuthService,\r\n        private router: Router,\r\n        private localStorageService: LocalStorageService,\r\n    ) {\r\n        this.tokenMethod = getAppConfig().tokenMethod;\r\n        this.authTokenHeaderKey = getAppConfig().authTokenHeaderKey || DEFAULT_AUTH_TOKEN_HEADER_KEY;\r\n    }\r\n\r\n    intercept(req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\r\n        this.dataService.client.startRequest().subscribe();\r\n        return this.dataService.client.uiState().single$.pipe(\r\n            switchMap(({ uiState }) => {\r\n                const request = req.clone({\r\n                    setParams: {\r\n                        languageCode: uiState?.contentLanguage ?? '',\r\n                    },\r\n                });\r\n                return next.handle(request);\r\n            }),\r\n            tap(\r\n                event => {\r\n                    if (event instanceof HttpResponse) {\r\n                        this.checkForAuthToken(event);\r\n                        this.notifyOnError(event);\r\n                        this.dataService.client.completeRequest().subscribe();\r\n                    }\r\n                },\r\n                err => {\r\n                    if (err instanceof HttpErrorResponse) {\r\n                        this.notifyOnError(err);\r\n                        this.dataService.client.completeRequest().subscribe();\r\n                    } else {\r\n                        this.displayErrorNotification(err.message);\r\n                    }\r\n                },\r\n            ),\r\n        );\r\n    }\r\n\r\n    private notifyOnError(response: HttpResponse<any> | HttpErrorResponse) {\r\n        if (response instanceof HttpErrorResponse) {\r\n            if (response.status === 0) {\r\n                const { apiHost, apiPort } = getAppConfig();\r\n                this.displayErrorNotification(_(`error.could-not-connect-to-server`), {\r\n                    url: `${apiHost}:${apiPort}`,\r\n                });\r\n            } else if (response.status === 503 && response.url?.endsWith('/health')) {\r\n                this.displayErrorNotification(_(`error.health-check-failed`));\r\n            } else {\r\n                this.displayErrorNotification(this.extractErrorFromHttpResponse(response));\r\n            }\r\n        } else {\r\n            // GraphQL errors still return 200 OK responses, but have the actual error message\r\n            // inside the body of the response.\r\n            const graphQLErrors = response.body.errors;\r\n            if (graphQLErrors && Array.isArray(graphQLErrors)) {\r\n                const firstCode: string = graphQLErrors[0]?.extensions?.code;\r\n\r\n                if (firstCode === 'FORBIDDEN') {\r\n                    this.authService.logOut().subscribe(() => {\r\n                        const { loginUrl } = getAppConfig();\r\n                        // If there is a `loginUrl` which is external to the AdminUI, redirect to it (with no query parameters)\r\n                        if (loginUrl && !this.areUrlsOnSameOrigin(loginUrl, window.location.origin)) {\r\n                            window.location.href = loginUrl;\r\n                            return;\r\n                        }\r\n\r\n                        // Else, we build the login path from the login url if one is provided or fallback to `/login`\r\n                        const loginPath = loginUrl ? this.getPathFromLoginUrl(loginUrl) : '/login';\r\n\r\n                        if (!window.location.pathname.includes(loginPath)) {\r\n                            const path = graphQLErrors[0].path.join(' > ');\r\n                            this.displayErrorNotification(_(`error.403-forbidden`), { path });\r\n                        }\r\n\r\n                        // Navigate to the `loginPath` route by ensuring the query param in charge of the redirection is provided\r\n                        this.router.navigate([loginPath], {\r\n                            queryParams: {\r\n                                [AUTH_REDIRECT_PARAM]: btoa(this.router.url),\r\n                            },\r\n                        });\r\n                    });\r\n                } else if (firstCode === 'CHANNEL_NOT_FOUND') {\r\n                    const message = graphQLErrors.map(err => err.message).join('\\n');\r\n                    this.displayErrorNotification(message);\r\n                    this.localStorageService.remove('activeChannelToken');\r\n                } else {\r\n                    const message = graphQLErrors.map(err => err.message).join('\\n');\r\n                    this.displayErrorNotification(message);\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    private extractErrorFromHttpResponse(response: HttpErrorResponse): string {\r\n        const errors = response.error.errors;\r\n        if (Array.isArray(errors)) {\r\n            return errors.map(e => e.message).join('\\n');\r\n        } else {\r\n            return response.message;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * We need to lazily inject the NotificationService since it depends on the I18nService which\r\n     * eventually depends on the HttpClient (used to load messages from json files). If we were to\r\n     * directly inject NotificationService into the constructor, we get a cyclic dependency.\r\n     */\r\n    private displayErrorNotification(message: string, vars?: Record<string, any>): void {\r\n        const notificationService = this.injector.get<NotificationService>(NotificationService);\r\n        notificationService.error(message, vars);\r\n    }\r\n\r\n    /**\r\n     * If the server is configured to use the \"bearer\" tokenMethod, each response should be checked\r\n     * for the existence of an auth token.\r\n     */\r\n    private checkForAuthToken(response: HttpResponse<any>) {\r\n        if (this.tokenMethod === 'bearer') {\r\n            const authToken = response.headers.get(this.authTokenHeaderKey);\r\n            if (authToken) {\r\n                this.localStorageService.set('authToken', authToken);\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Determine if two urls are on the same origin.\r\n     */\r\n    private areUrlsOnSameOrigin(urlA: string, urlB: string): boolean {\r\n        return new URL(urlA).origin === new URL(urlB).origin;\r\n    }\r\n\r\n    /**\r\n     * If the provided `loginUrl` is on the same origin than the AdminUI, return the path\r\n     * after the `/admin`.\r\n     * Else, return the whole login url.\r\n     */\r\n    private getPathFromLoginUrl(loginUrl: string): string {\r\n        if (!this.areUrlsOnSameOrigin(loginUrl, window.location.origin)) {\r\n            return loginUrl;\r\n        }\r\n        return loginUrl.split('/admin')[1];\r\n    }\r\n}\r\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bulk-action-types.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/providers/bulk-action-registry/bulk-action-types.ts"],"names":[],"mappings":"","sourcesContent":["import { Injector } from '@angular/core';\r\nimport { ActivatedRoute } from '@angular/router';\r\n\r\n/**\r\n * @description\r\n * A valid location of a list view that supports the bulk actions API.\r\n *\r\n * @since 1.8.0\r\n * @docsCategory bulk-actions\r\n * @docsPage BulkAction\r\n */\r\nexport type BulkActionLocationId =\r\n    | 'product-list'\r\n    | 'facet-list'\r\n    | 'collection-list'\r\n    | 'customer-list'\r\n    | 'customer-group-list'\r\n    | 'customer-group-members-list'\r\n    | 'customer-group-members-picker-list'\r\n    | 'promotion-list'\r\n    | 'seller-list'\r\n    | 'channel-list'\r\n    | 'administrator-list'\r\n    | 'role-list'\r\n    | 'shipping-method-list'\r\n    | 'stock-location-list'\r\n    | 'payment-method-list'\r\n    | 'tax-category-list'\r\n    | 'tax-rate-list'\r\n    | 'zone-list'\r\n    | 'zone-members-list'\r\n    | string;\r\n\r\n/**\r\n * @description\r\n * This is the argument which gets passed to the `getTranslationVars` and `isVisible` functions\r\n * of the BulkAction definition.\r\n *\r\n * @since 1.8.0\r\n * @docsCategory bulk-actions\r\n * @docsPage BulkAction\r\n */\r\nexport interface BulkActionFunctionContext<ItemType, ComponentType> {\r\n    /**\r\n     * @description\r\n     * An array of the selected items from the list.\r\n     */\r\n    selection: ItemType[];\r\n    /**\r\n     * @description\r\n     * The component instance that is hosting the list view. For instance,\r\n     * `ProductListComponent`. This can be used to call methods on the instance,\r\n     * e.g. calling `hostComponent.refresh()` to force a list refresh after\r\n     * deleting the selected items.\r\n     */\r\n    hostComponent: ComponentType;\r\n    /**\r\n     * @description\r\n     * The Angular [Injector](https://angular.io/api/core/Injector) which can be used\r\n     * to get service instances which might be needed in the click handler.\r\n     */\r\n    injector: Injector;\r\n    route: ActivatedRoute;\r\n}\r\n\r\n/**\r\n * @description\r\n * This is the argument which gets passed to the `onClick` function of a BulkAction.\r\n *\r\n * @since 1.8.0\r\n * @docsCategory bulk-actions\r\n * @docsPage BulkAction\r\n */\r\nexport interface BulkActionClickContext<ItemType, ComponentType>\r\n    extends BulkActionFunctionContext<ItemType, ComponentType> {\r\n    /**\r\n     * @description\r\n     * Clears the selection in the active list view.\r\n     */\r\n    clearSelection: () => void;\r\n    /**\r\n     * @description\r\n     * The click event itself.\r\n     */\r\n    event: MouseEvent;\r\n}\r\n\r\n/**\r\n * @description\r\n * Configures a bulk action which can be performed on all selected items in a list view.\r\n *\r\n * For a full example, see the {@link registerBulkAction} docs.\r\n *\r\n * @since 1.8.0\r\n * @docsCategory bulk-actions\r\n * @docsPage BulkAction\r\n * @docsWeight 0\r\n */\r\nexport interface BulkAction<ItemType = any, ComponentType = any> {\r\n    location: BulkActionLocationId;\r\n    label: string;\r\n    /**\r\n     * @description\r\n     * An optional function that should resolve to a map of translation variables which can be\r\n     * used when translating the `label` string.\r\n     */\r\n    getTranslationVars?: (\r\n        context: BulkActionFunctionContext<ItemType, ComponentType>,\r\n    ) => Record<string, string | number> | Promise<Record<string, string | number>>;\r\n    /**\r\n     * @description\r\n     * A valid [Clarity Icons](https://core.clarity.design/foundation/icons/shapes/) icon shape, e.g.\r\n     * \"cog\", \"user\", \"info-standard\".\r\n     */\r\n    icon?: string;\r\n    /**\r\n     * @description\r\n     * A class to be added to the icon element. Examples:\r\n     *\r\n     * - is-success\r\n     * - is-danger\r\n     * - is-warning\r\n     * - is-info\r\n     * - is-highlight\r\n     */\r\n    iconClass?: string;\r\n    /**\r\n     * @description\r\n     * Defines the logic that executes when the bulk action button is clicked.\r\n     */\r\n    onClick: (context: BulkActionClickContext<ItemType, ComponentType>) => void;\r\n    /**\r\n     * @description\r\n     * A function that determines whether this bulk action item should be displayed in the menu.\r\n     * If not defined, the item will always be displayed.\r\n     *\r\n     * This function will be invoked each time the selection is changed, so try to avoid expensive code\r\n     * running here.\r\n     *\r\n     * @example\r\n     * ```TypeScript\r\n     * import { registerBulkAction, DataService } from '\\@vendure/admin-ui/core';\r\n     *\r\n     * registerBulkAction({\r\n     *   location: 'product-list',\r\n     *   label: 'Assign to channel',\r\n     *   // Only display this action if there are multiple channels\r\n     *   isVisible: ({ injector }) => injector.get(DataService).client\r\n     *     .userStatus()\r\n     *     .mapSingle(({ userStatus }) => 1 < userStatus.channels.length)\r\n     *     .toPromise(),\r\n     *   // ...\r\n     * });\r\n     * ```\r\n     */\r\n    isVisible?: (context: BulkActionFunctionContext<ItemType, ComponentType>) => boolean | Promise<boolean>;\r\n    /**\r\n     * @description\r\n     * Control the display of this item based on the user permissions.\r\n     *\r\n     * @example\r\n     * ```TypeScript\r\n     * registerBulkAction({\r\n     *   // Can be specified as a simple string\r\n     *   requiresPermission: Permission.UpdateProduct,\r\n     *\r\n     *   // Or as a function that returns a boolean if permissions are satisfied\r\n     *   requiresPermission: userPermissions =>\r\n     *     userPermissions.includes(Permission.UpdateCatalog) ||\r\n     *     userPermissions.includes(Permission.UpdateProduct),\r\n     *   // ...\r\n     * })\r\n     * ```\r\n     */\r\n    requiresPermission?: string | ((userPermissions: string[]) => boolean);\r\n}\r\n"]}
|
|
@@ -35,4 +35,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImpor
|
|
|
35
35
|
providedIn: 'root',
|
|
36
36
|
}]
|
|
37
37
|
}], ctorParameters: function () { return [{ type: i1.ComponentRegistryService }]; } });
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLWZpZWxkLWNvbXBvbmVudC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb3JlL3NyYy9wcm92aWRlcnMvY3VzdG9tLWZpZWxkLWNvbXBvbmVudC9jdXN0b20tZmllbGQtY29tcG9uZW50LnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBWTNDOzs7O0dBSUc7QUFJSCxNQUFNLE9BQU8sMkJBQTJCO0lBQ3BDLFlBQW9CLHdCQUFrRDtRQUFsRCw2QkFBd0IsR0FBeEIsd0JBQXdCLENBQTBCO0lBQUcsQ0FBQztJQUUxRTs7O09BR0c7SUFDSCwwQkFBMEIsQ0FBQyxNQUE2QixFQUFFLFNBQWlCO1FBQ3ZFLE1BQU0sRUFBRSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTSxFQUFFLFNBQVMsRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNwRCxPQUFPLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxpQkFBaUIsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7SUFDaEYsQ0FBQztJQUVPLFVBQVUsQ0FBQyxNQUE2QixFQUFFLFNBQWlCLEVBQUUsYUFBc0I7UUFDdkYsSUFBSSxFQUFFLEdBQUcsTUFBTSxDQUFDO1FBQ2hCLElBQUksYUFBYSxFQUFFO1lBQ2YsRUFBRSxJQUFJLGVBQWUsQ0FBQztTQUN6QjtRQUNELEVBQUUsSUFBSSxHQUFHLEdBQUcsU0FBUyxDQUFDO1FBQ3RCLE9BQU8sRUFBRSxDQUFDO0lBQ2QsQ0FBQzs4R0FuQlEsMkJBQTJCO2tIQUEzQiwyQkFBMkIsY0FGeEIsTUFBTTs7MkZBRVQsMkJBQTJCO2tCQUh2QyxVQUFVO21CQUFDO29CQUNSLFVBQVUsRUFBRSxNQUFNO2lCQUNyQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IEZvcm1JbnB1dENvbXBvbmVudCB9IGZyb20gJy4uLy4uL2NvbW1vbi9jb21wb25lbnQtcmVnaXN0cnktdHlwZXMnO1xyXG5pbXBvcnQgeyBDdXN0b21GaWVsZHMsIEN1c3RvbUZpZWxkc0ZyYWdtZW50IH0gZnJvbSAnLi4vLi4vY29tbW9uL2dlbmVyYXRlZC10eXBlcyc7XHJcbmltcG9ydCB7IENvbXBvbmVudFJlZ2lzdHJ5U2VydmljZSB9IGZyb20gJy4uL2NvbXBvbmVudC1yZWdpc3RyeS9jb21wb25lbnQtcmVnaXN0cnkuc2VydmljZSc7XHJcblxyXG5leHBvcnQgdHlwZSBDdXN0b21GaWVsZENvbmZpZ1R5cGUgPSBDdXN0b21GaWVsZHNGcmFnbWVudDtcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQ3VzdG9tRmllbGRDb250cm9sIGV4dGVuZHMgRm9ybUlucHV0Q29tcG9uZW50PEN1c3RvbUZpZWxkQ29uZmlnVHlwZT4ge31cclxuXHJcbmV4cG9ydCB0eXBlIEN1c3RvbUZpZWxkRW50aXR5TmFtZSA9IEV4Y2x1ZGU8a2V5b2YgQ3VzdG9tRmllbGRzLCAnX190eXBlbmFtZSc+O1xyXG5cclxuLyoqXHJcbiAqIFRoaXMgc2VydmljZSBhbGxvd3MgdGhlIHJlZ2lzdHJhdGlvbiBvZiBjdXN0b20gY29udHJvbHMgZm9yIGN1c3RvbUZpZWxkcy5cclxuICpcclxuICogQGRlcHJlY2F0ZWQgVGhlIENvbXBvbmVudFJlZ2lzdHJ5U2VydmljZSBub3cgaGFuZGxlcyBjdXN0b20gZmllbGQgY29tcG9uZW50cyBkaXJlY3RseS5cclxuICovXHJcbkBJbmplY3RhYmxlKHtcclxuICAgIHByb3ZpZGVkSW46ICdyb290JyxcclxufSlcclxuZXhwb3J0IGNsYXNzIEN1c3RvbUZpZWxkQ29tcG9uZW50U2VydmljZSB7XHJcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGNvbXBvbmVudFJlZ2lzdHJ5U2VydmljZTogQ29tcG9uZW50UmVnaXN0cnlTZXJ2aWNlKSB7fVxyXG5cclxuICAgIC8qKlxyXG4gICAgICogQ2hlY2tzIHdoZXRoZXIgYSBjdXN0b20gY29tcG9uZW50IGlzIHJlZ2lzdGVyZWQgZm9yIHRoZSBnaXZlbiBlbnRpdHkgY3VzdG9tIGZpZWxkLFxyXG4gICAgICogYW5kIGlmIHNvIHJldHVybnMgdGhlIElEIG9mIHRoYXQgY29tcG9uZW50LlxyXG4gICAgICovXHJcbiAgICBjdXN0b21GaWVsZENvbXBvbmVudEV4aXN0cyhlbnRpdHk6IEN1c3RvbUZpZWxkRW50aXR5TmFtZSwgZmllbGROYW1lOiBzdHJpbmcpOiBzdHJpbmcgfCB1bmRlZmluZWQge1xyXG4gICAgICAgIGNvbnN0IGlkID0gdGhpcy5nZW5lcmF0ZUlkKGVudGl0eSwgZmllbGROYW1lLCB0cnVlKTtcclxuICAgICAgICByZXR1cm4gdGhpcy5jb21wb25lbnRSZWdpc3RyeVNlcnZpY2UuZ2V0SW5wdXRDb21wb25lbnQoaWQpID8gaWQgOiB1bmRlZmluZWQ7XHJcbiAgICB9XHJcblxyXG4gICAgcHJpdmF0ZSBnZW5lcmF0ZUlkKGVudGl0eTogQ3VzdG9tRmllbGRFbnRpdHlOYW1lLCBmaWVsZE5hbWU6IHN0cmluZywgaXNDdXN0b21GaWVsZDogYm9vbGVhbikge1xyXG4gICAgICAgIGxldCBpZCA9IGVudGl0eTtcclxuICAgICAgICBpZiAoaXNDdXN0b21GaWVsZCkge1xyXG4gICAgICAgICAgICBpZCArPSAnLWN1c3RvbUZpZWxkcyc7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlkICs9ICctJyArIGZpZWxkTmFtZTtcclxuICAgICAgICByZXR1cm4gaWQ7XHJcbiAgICB9XHJcbn1cclxuIl19
|
|
@@ -7,9 +7,6 @@ import * as i1 from "@angular/common";
|
|
|
7
7
|
*/
|
|
8
8
|
const ADMIN_SPECIFIC_KEYS = [
|
|
9
9
|
'activeTheme',
|
|
10
|
-
'uiLanguageCode',
|
|
11
|
-
'uiLocale',
|
|
12
|
-
'contentLanguageCode',
|
|
13
10
|
'dashboardWidgetLayout',
|
|
14
11
|
'activeTheme',
|
|
15
12
|
'livePreviewCollectionContents',
|
|
@@ -97,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImpor
|
|
|
97
94
|
providedIn: 'root',
|
|
98
95
|
}]
|
|
99
96
|
}], ctorParameters: function () { return [{ type: i1.Location }]; } });
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"local-storage.service.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/providers/local-storage/local-storage.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Location } from '@angular/common';\r\nimport { Injectable, Injector } from '@angular/core';\r\n\r\nimport { LanguageCode } from '../../common/generated-types';\r\nimport { DataService } from '../../data/providers/data.service';\r\nimport { WidgetLayoutDefinition } from '../dashboard-widget/dashboard-widget-types';\r\n\r\nexport type DataTableConfig = {\r\n    [id: string]: {\r\n        visibility: string[];\r\n        order: { [id: string]: number };\r\n        showSearchFilterRow: boolean;\r\n    };\r\n};\r\n\r\nexport type LocalStorageTypeMap = {\r\n    activeChannelToken: string;\r\n    authToken: string;\r\n    uiLanguageCode: LanguageCode;\r\n    uiLocale: string | undefined;\r\n    contentLanguageCode: LanguageCode;\r\n    dashboardWidgetLayout: WidgetLayoutDefinition;\r\n    activeTheme: string;\r\n    livePreviewCollectionContents: boolean;\r\n    dataTableConfig: DataTableConfig;\r\n};\r\n\r\nexport type LocalStorageLocationBasedTypeMap = {\r\n    shippingTestOrder: any;\r\n    shippingTestAddress: any;\r\n};\r\n\r\n/**\r\n * These keys are stored specific to a particular AdminId, so that multiple\r\n * admins can use the same browser without interfering with each other's data.\r\n */\r\nconst ADMIN_SPECIFIC_KEYS: Array<keyof LocalStorageTypeMap> = [\r\n    'activeTheme',\r\n    'dashboardWidgetLayout',\r\n    'activeTheme',\r\n    'livePreviewCollectionContents',\r\n    'dataTableConfig',\r\n];\r\n\r\nconst PREFIX = 'vnd_';\r\n\r\n/**\r\n * Wrapper around the browser's LocalStorage / SessionStorage object, for persisting data to the browser.\r\n */\r\n@Injectable({\r\n    providedIn: 'root',\r\n})\r\nexport class LocalStorageService {\r\n    private adminId = '__global__';\r\n    constructor(private location: Location) {}\r\n\r\n    public setAdminId(adminId?: string | null) {\r\n        this.adminId = adminId ?? '__global__';\r\n    }\r\n\r\n    /**\r\n     * Set a key-value pair in the browser's LocalStorage\r\n     */\r\n    public set<K extends keyof LocalStorageTypeMap>(key: K, value: LocalStorageTypeMap[K]): void {\r\n        const keyName = this.keyName(key);\r\n        localStorage.setItem(keyName, JSON.stringify(value));\r\n    }\r\n\r\n    /**\r\n     * Set a key-value pair specific to the current location (url)\r\n     */\r\n    public setForCurrentLocation<K extends keyof LocalStorageLocationBasedTypeMap>(\r\n        key: K,\r\n        value: LocalStorageLocationBasedTypeMap[K],\r\n    ) {\r\n        const compositeKey = this.getLocationBasedKey(key);\r\n        this.set(compositeKey as any, value);\r\n    }\r\n\r\n    /**\r\n     * Set a key-value pair in the browser's SessionStorage\r\n     */\r\n    public setForSession<K extends keyof LocalStorageTypeMap>(key: K, value: LocalStorageTypeMap[K]): void {\r\n        const keyName = this.keyName(key);\r\n        sessionStorage.setItem(keyName, JSON.stringify(value));\r\n    }\r\n\r\n    /**\r\n     * Get the value of the given key from the SessionStorage or LocalStorage.\r\n     */\r\n    public get<K extends keyof LocalStorageTypeMap>(key: K): LocalStorageTypeMap[K] | null {\r\n        const keyName = this.keyName(key);\r\n        const item = sessionStorage.getItem(keyName) || localStorage.getItem(keyName);\r\n        let result: any;\r\n        try {\r\n            result = JSON.parse(item || 'null');\r\n        } catch (e: any) {\r\n            // eslint-disable-next-line no-console\r\n            console.error(`Could not parse the localStorage value for \"${key}\" (${item})`);\r\n        }\r\n        return result;\r\n    }\r\n\r\n    /**\r\n     * Get the value of the given key for the current location (url)\r\n     */\r\n    public getForCurrentLocation<K extends keyof LocalStorageLocationBasedTypeMap>(\r\n        key: K,\r\n    ): LocalStorageLocationBasedTypeMap[K] {\r\n        const compositeKey = this.getLocationBasedKey(key);\r\n        return this.get(compositeKey as any);\r\n    }\r\n\r\n    public remove(key: keyof LocalStorageTypeMap): void {\r\n        const keyName = this.keyName(key);\r\n        sessionStorage.removeItem(keyName);\r\n        localStorage.removeItem(keyName);\r\n    }\r\n\r\n    private getLocationBasedKey(key: string) {\r\n        const path = this.location.path();\r\n        return key + path;\r\n    }\r\n\r\n    private keyName(key: keyof LocalStorageTypeMap): string {\r\n        if (ADMIN_SPECIFIC_KEYS.includes(key)) {\r\n            return `${PREFIX}_${this.adminId}_${key}`;\r\n        } else {\r\n            return `${PREFIX}_${key}`;\r\n        }\r\n    }\r\n}\r\n"]}
|
|
@@ -62,7 +62,7 @@ export class PageService {
|
|
|
62
62
|
if (isComponentWithResolver(config.component)) {
|
|
63
63
|
const { component: cmp, breadcrumbFn, resolveFn } = config.component;
|
|
64
64
|
component = cmp;
|
|
65
|
-
route.resolve = { detail:
|
|
65
|
+
route.resolve = { detail: resolveFn };
|
|
66
66
|
route.data = {
|
|
67
67
|
breadcrumb: data => data.detail.entity.pipe(map(entity => breadcrumbFn(entity))),
|
|
68
68
|
};
|
|
@@ -73,6 +73,9 @@ export class PageService {
|
|
|
73
73
|
const guards = typeof component.prototype.canDeactivate === 'function' ? [CanDeactivateDetailGuard] : [];
|
|
74
74
|
route.component = component;
|
|
75
75
|
route.canDeactivate = guards;
|
|
76
|
+
if (config.routeConfig) {
|
|
77
|
+
Object.assign(route, config.routeConfig);
|
|
78
|
+
}
|
|
76
79
|
return route;
|
|
77
80
|
});
|
|
78
81
|
}
|
|
@@ -91,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImpor
|
|
|
91
94
|
function isComponentWithResolver(input) {
|
|
92
95
|
return input && input.hasOwnProperty('resolveFn');
|
|
93
96
|
}
|
|
94
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page.service.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/providers/page/page.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { APP_INITIALIZER, Injectable, Provider, Type } from '@angular/core';\nimport { Route } from '@angular/router';\nimport { map } from 'rxjs/operators';\nimport { detailComponentWithResolver } from '../../common/base-detail.component';\nimport { PageLocationId } from '../../common/component-registry-types';\nimport { CanDeactivateDetailGuard } from '../../shared/providers/routing/can-deactivate-detail-guard';\n\n/**\n * @description\n * The object used to configure a new page tab.\n *\n * @docsCategory tabs\n */\nexport interface PageTabConfig {\n    /**\n     * @description\n     * A valid location representing a list or detail page.\n     */\n    location: PageLocationId;\n    /**\n     * @description\n     * An optional icon to display in the tab. The icon\n     * should be a valid shape name from the [Clarity Icons](https://core.clarity.design/foundation/icons/shapes/)\n     * set.\n     */\n    tabIcon?: string;\n    /**\n     * @description\n     * The route path to the tab. This will be appended to the\n     * route of the parent page.\n     */\n    route: string;\n    /**\n     * @description\n     * The name of the tab to display in the UI.\n     */\n    tab: string;\n    /**\n     * @description\n     * The priority of the tab. Tabs with a lower priority will be displayed first.\n     */\n    priority?: number;\n    /**\n     * @description\n     * The component to render at the route of the tab.\n     */\n    component: Type<any> | ReturnType<typeof detailComponentWithResolver>;\n}\n\n/**\n * @description\n * Add a tab to an existing list or detail page.\n *\n * @example\n * ```TypeScript\n * \\@NgModule({\n *   imports: [SharedModule],\n *   providers: [\n *     registerPageTab({\n *       location: 'product-list',\n *       tab: 'Deleted Products',\n *       route: 'deleted',\n *       component: DeletedProductListComponent,\n *     }),\n *   ],\n * })\n * export class MyUiExtensionModule {}\n * ```\n * @docsCategory tabs\n */\nexport function registerPageTab(config: PageTabConfig): Provider {\n    return {\n        provide: APP_INITIALIZER,\n        multi: true,\n        useFactory: (pageService: PageService) => () => {\n            pageService.registerPageTab({\n                ...config,\n                priority: config.priority || 1,\n            });\n        },\n        deps: [PageService],\n    };\n}\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class PageService {\n    private registry = new Map<PageLocationId, PageTabConfig[]>();\n\n    registerPageTab(config: PageTabConfig) {\n        if (!this.registry.has(config.location)) {\n            this.registry.set(config.location, []);\n        }\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n        const pages = this.registry.get(config.location)!;\n        if (pages.find(p => p.tab === config.tab)) {\n            throw new Error(`A page with the tab \"${config.tab}\" has already been registered`);\n        }\n        pages.push(config);\n    }\n\n    getPageTabRoutes(location: PageLocationId): Route[] {\n        const configs = this.registry.get(location) || [];\n        return configs.map(config => {\n            const route: Route = {\n                path: config.route || '',\n                pathMatch: config.route ? 'prefix' : 'full',\n            };\n\n            let component: Type<any>;\n            if (isComponentWithResolver(config.component)) {\n                const { component: cmp, breadcrumbFn, resolveFn } = config.component;\n                component = cmp;\n                route.resolve = { detail: config.component.resolveFn };\n                route.data = {\n                    breadcrumb: data => data.detail.entity.pipe(map(entity => breadcrumbFn(entity))),\n                };\n            } else {\n                component = config.component;\n            }\n            const guards =\n                typeof component.prototype.canDeactivate === 'function' ? [CanDeactivateDetailGuard] : [];\n            route.component = component;\n            route.canDeactivate = guards;\n\n            return route;\n        });\n    }\n\n    getPageTabs(location: PageLocationId): PageTabConfig[] {\n        return this.registry.get(location)?.sort((a, b) => (a.priority ?? 0) - (b.priority ?? 0)) || [];\n    }\n}\n\nfunction isComponentWithResolver(input: any): input is ReturnType<typeof detailComponentWithResolver> {\n    return input && input.hasOwnProperty('resolveFn');\n}\n"]}
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page.service.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/providers/page/page.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { APP_INITIALIZER, Injectable, Provider, Type } from '@angular/core';\r\nimport { Route } from '@angular/router';\r\nimport { map } from 'rxjs/operators';\r\nimport { detailComponentWithResolver } from '../../common/base-detail.component';\r\nimport { PageLocationId } from '../../common/component-registry-types';\r\nimport { CanDeactivateDetailGuard } from '../../shared/providers/routing/can-deactivate-detail-guard';\r\n\r\n/**\r\n * @description\r\n * The object used to configure a new page tab.\r\n *\r\n * @docsCategory tabs\r\n */\r\nexport interface PageTabConfig {\r\n    /**\r\n     * @description\r\n     * A valid location representing a list or detail page.\r\n     */\r\n    location: PageLocationId;\r\n    /**\r\n     * @description\r\n     * An optional icon to display in the tab. The icon\r\n     * should be a valid shape name from the [Clarity Icons](https://core.clarity.design/foundation/icons/shapes/)\r\n     * set.\r\n     */\r\n    tabIcon?: string;\r\n    /**\r\n     * @description\r\n     * The route path to the tab. This will be appended to the\r\n     * route of the parent page.\r\n     */\r\n    route: string;\r\n    /**\r\n     * @description\r\n     * The name of the tab to display in the UI.\r\n     */\r\n    tab: string;\r\n    /**\r\n     * @description\r\n     * The priority of the tab. Tabs with a lower priority will be displayed first.\r\n     */\r\n    priority?: number;\r\n    /**\r\n     * @description\r\n     * The component to render at the route of the tab.\r\n     */\r\n    component: Type<any> | ReturnType<typeof detailComponentWithResolver>;\r\n    /**\r\n     * @description\r\n     * You can optionally provide any native Angular route configuration options here.\r\n     * Any values provided here will take precedence over the values generated\r\n     * by the `route` and `component` properties.\r\n     */\r\n    routeConfig?: Route;\r\n}\r\n\r\n/**\r\n * @description\r\n * Add a tab to an existing list or detail page.\r\n *\r\n * @example\r\n * ```TypeScript\r\n * \\@NgModule({\r\n *   imports: [SharedModule],\r\n *   providers: [\r\n *     registerPageTab({\r\n *       location: 'product-list',\r\n *       tab: 'Deleted Products',\r\n *       route: 'deleted',\r\n *       component: DeletedProductListComponent,\r\n *     }),\r\n *   ],\r\n * })\r\n * export class MyUiExtensionModule {}\r\n * ```\r\n * @docsCategory tabs\r\n */\r\nexport function registerPageTab(config: PageTabConfig): Provider {\r\n    return {\r\n        provide: APP_INITIALIZER,\r\n        multi: true,\r\n        useFactory: (pageService: PageService) => () => {\r\n            pageService.registerPageTab({\r\n                ...config,\r\n                priority: config.priority || 1,\r\n            });\r\n        },\r\n        deps: [PageService],\r\n    };\r\n}\r\n\r\n@Injectable({\r\n    providedIn: 'root',\r\n})\r\nexport class PageService {\r\n    private registry = new Map<PageLocationId, PageTabConfig[]>();\r\n\r\n    registerPageTab(config: PageTabConfig) {\r\n        if (!this.registry.has(config.location)) {\r\n            this.registry.set(config.location, []);\r\n        }\r\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\r\n        const pages = this.registry.get(config.location)!;\r\n        if (pages.find(p => p.tab === config.tab)) {\r\n            throw new Error(`A page with the tab \"${config.tab}\" has already been registered`);\r\n        }\r\n        pages.push(config);\r\n    }\r\n\r\n    getPageTabRoutes(location: PageLocationId): Route[] {\r\n        const configs = this.registry.get(location) || [];\r\n        return configs.map(config => {\r\n            const route: Route = {\r\n                path: config.route || '',\r\n                pathMatch: config.route ? 'prefix' : 'full',\r\n            };\r\n\r\n            let component: Type<any>;\r\n            if (isComponentWithResolver(config.component)) {\r\n                const { component: cmp, breadcrumbFn, resolveFn } = config.component;\r\n                component = cmp;\r\n                route.resolve = { detail: resolveFn };\r\n                route.data = {\r\n                    breadcrumb: data => data.detail.entity.pipe(map(entity => breadcrumbFn(entity))),\r\n                };\r\n            } else {\r\n                component = config.component;\r\n            }\r\n            const guards =\r\n                typeof component.prototype.canDeactivate === 'function' ? [CanDeactivateDetailGuard] : [];\r\n            route.component = component;\r\n            route.canDeactivate = guards;\r\n            if (config.routeConfig) {\r\n                Object.assign(route, config.routeConfig);\r\n            }\r\n\r\n            return route;\r\n        });\r\n    }\r\n\r\n    getPageTabs(location: PageLocationId): PageTabConfig[] {\r\n        return this.registry.get(location)?.sort((a, b) => (a.priority ?? 0) - (b.priority ?? 0)) || [];\r\n    }\r\n}\r\n\r\nfunction isComponentWithResolver(input: any): input is ReturnType<typeof detailComponentWithResolver> {\r\n    return input && input.hasOwnProperty('resolveFn');\r\n}\r\n"]}
|
|
@@ -76,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImpor
|
|
|
76
76
|
}, {
|
|
77
77
|
type: Input
|
|
78
78
|
}] } });
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-bar-items.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/action-bar-items/action-bar-items.component.ts","../../../../../../src/lib/core/src/shared/components/action-bar-items/action-bar-items.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,WAAW,EACX,KAAK,GAIR,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,WAAW,EAAE,MAAM,kCAAkC,CAAC;AAC/D,OAAO,EAAE,eAAe,EAAE,aAAa,EAAkB,MAAM,MAAM,CAAC;AACtE,OAAO,EAAU,GAAG,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;;;;AAc7C,MAAM,OAAO,uBAAuB;IAQhC,YACY,iBAAoC,EACpC,KAAqB,EACrB,WAAwB,EACxB,mBAAwC;QAHxC,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,UAAK,GAAL,KAAK,CAAgB;QACrB,gBAAW,GAAX,WAAW,CAAa;QACxB,wBAAmB,GAAnB,mBAAmB,CAAqB;QAN5C,gBAAW,GAAG,IAAI,eAAe,CAAS,EAAE,CAAC,CAAC;IAOnD,CAAC;IAEJ,QAAQ;QACJ,IAAI,CAAC,MAAM,GAAG,aAAa,CAAC,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,IAAI,CACvF,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,UAAU,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,UAAU,KAAK,UAAU,CAAC,CAAC,CACzF,CAAC;IACN,CAAC;IAED,WAAW,CAAC,OAAsB;QAC9B,IAAI,YAAY,IAAI,OAAO,EAAE;YACzB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,CAAC;SAC7D;IACL,CAAC;IAED,WAAW,CAAC,KAAiB,EAAE,IAAmB;QAC9C,IAAI,OAAO,IAAI,CAAC,OAAO,KAAK,UAAU,EAAE;YACpC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE;gBAChB,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,WAAW,EAAE,IAAI,CAAC,WAAW;gBAC7B,mBAAmB,EAAE,IAAI,CAAC,mBAAmB;aAChD,CAAC,CAAC;SACN;IACL,CAAC;IAED,aAAa,CAAC,IAAmB;QAC7B,OAAO,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;IAClE,CAAC;IAED,eAAe,CAAC,IAAmB;QAC/B,MAAM,MAAM,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC1B,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,KAAK,MAAM,EAAE;YACjD,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACxB,OAAO,MAAM,CAAC;SACjB;QACD,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC,CAAC;QAC5C,OAAO,MAAM,CAAC;IAClB,CAAC;IAEO,mBAAmB,CAAC,IAAmB;QAC3C,QAAQ,IAAI,CAAC,WAAW,EAAE;YACtB,KAAK,SAAS;gBACV,OAAO,EAAE,CAAC;YACd,KAAK,SAAS;gBACV,OAAO,IAAI,CAAC,WAAW,KAAK,SAAS,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC;YACtE,KAAK,SAAS;gBACV,OAAO,IAAI,CAAC,WAAW,KAAK,SAAS,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,SAAS,CAAC;YAC9E,KAAK,SAAS;gBACV,OAAO,IAAI,CAAC,WAAW,KAAK,SAAS,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,SAAS,CAAC;YAC9E;gBACI,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;gBAC9B,OAAO,EAAE,CAAC;SACjB;IACL,CAAC;8GAjEQ,uBAAuB;kGAAvB,uBAAuB,6LC1BpC,srBAeA;;2FDWa,uBAAuB;kBANnC,SAAS;+BACI,sBAAsB,mBAGf,uBAAuB,CAAC,MAAM;iMAK/C,UAAU;sBAFT,WAAW;uBAAC,uBAAuB;;sBACnC,KAAK","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    HostBinding,\r\n    Input,\r\n    OnChanges,\r\n    OnInit,\r\n    SimpleChanges,\r\n} from '@angular/core';\r\nimport { ActivatedRoute } from '@angular/router';\r\nimport { assertNever } from '@vendure/common/lib/shared-utils';\r\nimport { BehaviorSubject, combineLatest, Observable, of } from 'rxjs';\r\nimport { filter, map } from 'rxjs/operators';\r\n\r\nimport { ActionBarLocationId } from '../../../common/component-registry-types';\r\nimport { DataService } from '../../../data/providers/data.service';\r\nimport { ActionBarItem } from '../../../providers/nav-builder/nav-builder-types';\r\nimport { NavBuilderService } from '../../../providers/nav-builder/nav-builder.service';\r\nimport { NotificationService } from '../../../providers/notification/notification.service';\r\n\r\n@Component({\r\n    selector: 'vdr-action-bar-items',\r\n    templateUrl: './action-bar-items.component.html',\r\n    styleUrls: ['./action-bar-items.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class ActionBarItemsComponent implements OnInit, OnChanges {\r\n    @HostBinding('attr.data-location-id')\r\n    @Input()\r\n    locationId: ActionBarLocationId;\r\n\r\n    items$: Observable<ActionBarItem[]>;\r\n    private locationId$ = new BehaviorSubject<string>('');\r\n\r\n    constructor(\r\n        private navBuilderService: NavBuilderService,\r\n        private route: ActivatedRoute,\r\n        private dataService: DataService,\r\n        private notificationService: NotificationService,\r\n    ) {}\r\n\r\n    ngOnInit() {\r\n        this.items$ = combineLatest(this.navBuilderService.actionBarConfig$, this.locationId$).pipe(\r\n            map(([items, locationId]) => items.filter(config => config.locationId === locationId)),\r\n        );\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        if ('locationId' in changes) {\r\n            this.locationId$.next(changes['locationId'].currentValue);\r\n        }\r\n    }\r\n\r\n    handleClick(event: MouseEvent, item: ActionBarItem) {\r\n        if (typeof item.onClick === 'function') {\r\n            item.onClick(event, {\r\n                route: this.route,\r\n                dataService: this.dataService,\r\n                notificationService: this.notificationService,\r\n            });\r\n        }\r\n    }\r\n\r\n    getRouterLink(item: ActionBarItem): any[] | null {\r\n        return this.navBuilderService.getRouterLink(item, this.route);\r\n    }\r\n\r\n    getButtonStyles(item: ActionBarItem): string[] {\r\n        const styles = ['button'];\r\n        if (item.buttonStyle && item.buttonStyle === 'link') {\r\n            styles.push('btn-link');\r\n            return styles;\r\n        }\r\n        styles.push(this.getButtonColorClass(item));\r\n        return styles;\r\n    }\r\n\r\n    private getButtonColorClass(item: ActionBarItem): string {\r\n        switch (item.buttonColor) {\r\n            case undefined:\r\n                return '';\r\n            case 'primary':\r\n                return item.buttonStyle === 'outline' ? 'btn-outline' : 'primary';\r\n            case 'success':\r\n                return item.buttonStyle === 'outline' ? 'btn-success-outline' : 'success';\r\n            case 'warning':\r\n                return item.buttonStyle === 'outline' ? 'btn-warning-outline' : 'warning';\r\n            default:\r\n                assertNever(item.buttonColor);\r\n                return '';\r\n        }\r\n    }\r\n}\r\n","<vdr-ui-extension-point [locationId]=\"locationId\" api=\"actionBar\">\r\n    <ng-container *ngFor=\"let item of items$ | async\">\r\n        <button\r\n            *vdrIfPermissions=\"item.requiresPermission\"\r\n            [routerLink]=\"getRouterLink(item)\"\r\n            [disabled]=\"item.disabled ? (item.disabled | async) : false\"\r\n            (click)=\"handleClick($event, item)\"\r\n            [ngClass]=\"getButtonStyles(item)\"\r\n            class=\"mr-2\"\r\n        >\r\n            <clr-icon *ngIf=\"item.icon\" [attr.shape]=\"item.icon\"></clr-icon>\r\n            {{ item.label | translate }}\r\n        </button>\r\n    </ng-container>\r\n</vdr-ui-extension-point>\r\n"]}
|
|
@@ -94,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImpor
|
|
|
94
94
|
type: HostListener,
|
|
95
95
|
args: ['document:dragleave', ['$event']]
|
|
96
96
|
}] } });
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asset-file-input.component.js","sourceRoot":"","sources":["../../../../../../src/lib/core/src/shared/components/asset-file-input/asset-file-input.component.ts","../../../../../../src/lib/core/src/shared/components/asset-file-input/asset-file-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    HostListener,\n    Input,\n    OnInit,\n    Output,\n} from '@angular/core';\nimport { notNullOrUndefined } from '@vendure/common/lib/shared-utils';\n\nimport { ServerConfigService } from '../../../data/server-config';\n\n/**\n * A component for selecting files to upload as new Assets.\n */\n@Component({\n    selector: 'vdr-asset-file-input',\n    templateUrl: './asset-file-input.component.html',\n    styleUrls: ['./asset-file-input.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AssetFileInputComponent implements OnInit {\n    /**\n     * CSS selector of the DOM element which will be masked by the file\n     * drop zone. Defaults to `body`.\n     */\n    @Input() dropZoneTarget = 'body';\n    @Input() uploading = false;\n    @Output() selectFiles = new EventEmitter<File[]>();\n    dragging = false;\n    overDropZone = false;\n    dropZoneStyle = {\n        'width.px': 0,\n        'height.px': 0,\n        'top.px': 0,\n        'left.px': 0,\n    };\n    accept: string;\n\n    constructor(private serverConfig: ServerConfigService) {}\n\n    ngOnInit() {\n        this.accept = this.serverConfig.serverConfig.permittedAssetTypes.join(',');\n        this.fitDropZoneToTarget();\n    }\n\n    @HostListener('document:dragenter')\n    onDragEnter() {\n        this.dragging = true;\n        this.fitDropZoneToTarget();\n    }\n\n    // DragEvent is not supported in Safari, see https://github.com/vendure-ecommerce/vendure/pull/284\n    @HostListener('document:dragleave', ['$event'])\n    onDragLeave(event: any) {\n        if (!event.clientX && !event.clientY) {\n            this.dragging = false;\n        }\n    }\n\n    /**\n     * Preventing this event is required to make dropping work.\n     * See https://developer.mozilla.org/en-US/docs/Web/API/HTML_Drag_and_Drop_API#Define_a_drop_zone\n     */\n    onDragOver(event: any) {\n        event.preventDefault();\n    }\n\n    // DragEvent is not supported in Safari, see https://github.com/vendure-ecommerce/vendure/pull/284\n    onDrop(event: any) {\n        event.preventDefault();\n        this.dragging = false;\n        this.overDropZone = false;\n        const files = Array.from<DataTransferItem>(event.dataTransfer ? event.dataTransfer.items : [])\n            .map(i => i.getAsFile())\n            .filter(notNullOrUndefined);\n        this.selectFiles.emit(files);\n    }\n\n    select(event: Event) {\n        const files = (event.target as HTMLInputElement).files;\n        if (files) {\n            this.selectFiles.emit(Array.from(files));\n        }\n    }\n\n    private fitDropZoneToTarget() {\n        const target = document.querySelector(this.dropZoneTarget) as HTMLElement;\n        if (target) {\n            const rect = target.getBoundingClientRect();\n            this.dropZoneStyle['width.px'] = rect.width;\n            this.dropZoneStyle['height.px'] = rect.height;\n            this.dropZoneStyle['top.px'] = rect.top;\n            this.dropZoneStyle['left.px'] = rect.left;\n        }\n    }\n}\n","<input type=\"file\" class=\"file-input\" #fileInput (change)=\"select($event)\" multiple [accept]=\"accept\" />\r\n<button class=\"btn btn-primary\" (click)=\"fileInput.click()\" [disabled]=\"uploading\">\r\n    <ng-container *ngIf=\"uploading; else selectable\">\r\n        <clr-spinner clrInline></clr-spinner>\r\n        {{ 'asset.uploading' | translate }}\r\n    </ng-container>\r\n    <ng-template #selectable>\r\n        <clr-icon shape=\"upload-cloud\"></clr-icon>\r\n        {{ 'asset.upload-assets' | translate }}\r\n    </ng-template>\r\n</button>\r\n<div\r\n    class=\"drop-zone\"\r\n    [ngStyle]=\"dropZoneStyle\"\r\n    [class.visible]=\"dragging\"\r\n    [class.dragging-over]=\"overDropZone\"\r\n    (dragenter)=\"overDropZone = true\"\r\n    (dragleave)=\"overDropZone = false\"\r\n    (dragover)=\"onDragOver($event)\"\r\n    (drop)=\"onDrop($event)\"\r\n    #dropZone\r\n>\r\n    <div class=\"drop-label\" (dragenter)=\"overDropZone = true\">\r\n        <clr-icon shape=\"upload-cloud\" size=\"32\"></clr-icon>\r\n        {{ 'catalog.drop-files-to-upload' | translate }}\r\n    </div>\r\n</div>\r\n"]}
|
|
@@ -52,4 +52,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImpor
|
|
|
52
52
|
type: Component,
|
|
53
53
|
args: [{ selector: 'vdr-assign-to-channel-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-template vdrDialogTitle>\r\n {{ 'common.confirm-bulk-assign-to-channel' | translate }}\r\n</ng-template>\r\n<div class=\"form-grid\">\r\n <vdr-form-item>\r\n <div *ngIf=\"0 < nMore\">\r\n {{\r\n 'common.list-items-and-n-more'\r\n | translate\r\n : {\r\n items: itemNames,\r\n nMore: nMore\r\n }\r\n }}\r\n </div>\r\n <div *ngIf=\"nMore === 0\">\r\n {{ itemNames }}\r\n </div>\r\n </vdr-form-item>\r\n <vdr-form-field [label]=\"'common.channel' | translate\" class=\"mb-4\">\r\n <vdr-channel-assignment-control\r\n clrInput\r\n [multiple]=\"false\"\r\n [includeDefaultChannel]=\"false\"\r\n [formControl]=\"selectedChannelIdControl\"\r\n ></vdr-channel-assignment-control>\r\n </vdr-form-field>\r\n</div>\r\n\r\n<ng-template vdrDialogButtons>\r\n <button type=\"button\" class=\"btn\" (click)=\"cancel()\">{{ 'common.cancel' | translate }}</button>\r\n <button type=\"submit\" (click)=\"assign()\" [disabled]=\"!selectedChannel\" class=\"btn btn-primary\">\r\n <ng-template [ngIf]=\"selectedChannel\" [ngIfElse]=\"noSelection\">\r\n {{ 'catalog.assign-to-named-channel' | translate : { channelCode: selectedChannel?.code } }}\r\n </ng-template>\r\n <ng-template #noSelection>\r\n {{ 'catalog.no-channel-selected' | translate }}\r\n </ng-template>\r\n </button>\r\n</ng-template>\r\n", styles: ["vdr-channel-assignment-control{min-width:200px}\n"] }]
|
|
54
54
|
}], ctorParameters: function () { return [{ type: i1.DataService }, { type: i2.NotificationService }]; } });
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXNzaWduLXRvLWNoYW5uZWwtZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29yZS9zcmMvc2hhcmVkL2NvbXBvbmVudHMvYXNzaWduLXRvLWNoYW5uZWwtZGlhbG9nL2Fzc2lnbi10by1jaGFubmVsLWRpYWxvZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvc3JjL3NoYXJlZC9jb21wb25lbnRzL2Fzc2lnbi10by1jaGFubmVsLWRpYWxvZy9hc3NpZ24tdG8tY2hhbm5lbC1kaWFsb2cuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUMzRSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNwRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sTUFBTSxDQUFDOzs7Ozs7Ozs7Ozs7O0FBZXJDLE1BQU0sT0FBTyw4QkFBOEI7SUFVdkMsWUFBb0IsV0FBd0IsRUFBVSxtQkFBd0M7UUFBMUUsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFBVSx3QkFBbUIsR0FBbkIsbUJBQW1CLENBQXFCO1FBTDlGLDZCQUF3QixHQUFHLElBQUksa0JBQWtCLEVBQUUsQ0FBQztJQUs2QyxDQUFDO0lBRWxHLFFBQVE7UUFDSixNQUFNLGdCQUFnQixHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTTthQUMzQyxVQUFVLEVBQUU7YUFDWixTQUFTLENBQUMsQ0FBQyxFQUFFLFVBQVUsRUFBRSxFQUFFLEVBQUUsQ0FBQyxVQUFVLENBQUMsZUFBZSxDQUFDLENBQUM7UUFDL0QsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsV0FBVyxFQUFFLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRTlGLGFBQWEsQ0FBQyxnQkFBZ0IsRUFBRSxZQUFZLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLGVBQWUsRUFBRSxRQUFRLENBQUMsRUFBRSxFQUFFO1lBQ3BGLG9FQUFvRTtZQUNwRSxJQUFJLENBQUMsY0FBYyxHQUFHLFFBQVEsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxlQUFlLENBQUUsQ0FBQztZQUMxRSxJQUFJLENBQUMsaUJBQWlCLEdBQUcsUUFBUSxDQUFDLEtBQUssQ0FBQztRQUM1QyxDQUFDLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQ3ZELElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDNUIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsYUFBYSxDQUFDLFVBQW9CO1FBQzlCLElBQUksQ0FBQyxlQUFlLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLEtBQUssVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDcEYsQ0FBQztJQUVELE1BQU07UUFDRixNQUFNLGVBQWUsR0FBRyxJQUFJLENBQUMsZUFBZSxDQUFDO1FBQzdDLElBQUksZUFBZSxFQUFFO1lBQ2pCLElBQUksQ0FBQyxXQUFXLENBQUMsZUFBZSxDQUFDLENBQUM7U0FDckM7SUFDTCxDQUFDO0lBRUQsTUFBTTtRQUNGLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUN2QixDQUFDOzhHQTFDUSw4QkFBOEI7a0dBQTlCLDhCQUE4QixvRUNqQjNDLG9sREF3Q0E7OzJGRHZCYSw4QkFBOEI7a0JBTjFDLFNBQVM7K0JBQ0ksOEJBQThCLG1CQUd2Qix1QkFBdUIsQ0FBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFVudHlwZWRGb3JtQ29udHJvbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgY29tYmluZUxhdGVzdCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBJdGVtT2YgfSBmcm9tICcuLi8uLi8uLi9jb21tb24vYmFzZS1saXN0LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEdldENoYW5uZWxzUXVlcnkgfSBmcm9tICcuLi8uLi8uLi9jb21tb24vZ2VuZXJhdGVkLXR5cGVzJztcclxuaW1wb3J0IHsgRGF0YVNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9kYXRhL3Byb3ZpZGVycy9kYXRhLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBEaWFsb2cgfSBmcm9tICcuLi8uLi8uLi9wcm92aWRlcnMvbW9kYWwvbW9kYWwudHlwZXMnO1xyXG5pbXBvcnQgeyBOb3RpZmljYXRpb25TZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vcHJvdmlkZXJzL25vdGlmaWNhdGlvbi9ub3RpZmljYXRpb24uc2VydmljZSc7XHJcblxyXG50eXBlIENoYW5uZWwgPSBJdGVtT2Y8R2V0Q2hhbm5lbHNRdWVyeSwgJ2NoYW5uZWxzJz47XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAndmRyLWFzc2lnbi10by1jaGFubmVsLWRpYWxvZycsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vYXNzaWduLXRvLWNoYW5uZWwtZGlhbG9nLmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL2Fzc2lnbi10by1jaGFubmVsLWRpYWxvZy5jb21wb25lbnQuc2NzcyddLFxyXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBc3NpZ25Ub0NoYW5uZWxEaWFsb2dDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIERpYWxvZzxDaGFubmVsPiB7XHJcbiAgICBzZWxlY3RlZENoYW5uZWw6IENoYW5uZWwgfCBudWxsIHwgdW5kZWZpbmVkO1xyXG4gICAgY3VycmVudENoYW5uZWw6IENoYW5uZWw7XHJcbiAgICBhdmFpbGFibGVDaGFubmVsczogQ2hhbm5lbFtdO1xyXG4gICAgcmVzb2x2ZVdpdGg6IChyZXN1bHQ/OiBDaGFubmVsKSA9PiB2b2lkO1xyXG4gICAgc2VsZWN0ZWRDaGFubmVsSWRDb250cm9sID0gbmV3IFVudHlwZWRGb3JtQ29udHJvbCgpO1xyXG5cclxuICAgIGl0ZW1OYW1lczogc3RyaW5nO1xyXG4gICAgbk1vcmU6IG51bWJlcjtcclxuXHJcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGRhdGFTZXJ2aWNlOiBEYXRhU2VydmljZSwgcHJpdmF0ZSBub3RpZmljYXRpb25TZXJ2aWNlOiBOb3RpZmljYXRpb25TZXJ2aWNlKSB7fVxyXG5cclxuICAgIG5nT25Jbml0KCkge1xyXG4gICAgICAgIGNvbnN0IGFjdGl2ZUNoYW5uZWxJZCQgPSB0aGlzLmRhdGFTZXJ2aWNlLmNsaWVudFxyXG4gICAgICAgICAgICAudXNlclN0YXR1cygpXHJcbiAgICAgICAgICAgIC5tYXBTaW5nbGUoKHsgdXNlclN0YXR1cyB9KSA9PiB1c2VyU3RhdHVzLmFjdGl2ZUNoYW5uZWxJZCk7XHJcbiAgICAgICAgY29uc3QgYWxsQ2hhbm5lbHMkID0gdGhpcy5kYXRhU2VydmljZS5zZXR0aW5ncy5nZXRDaGFubmVscygpLm1hcFNpbmdsZShkYXRhID0+IGRhdGEuY2hhbm5lbHMpO1xyXG5cclxuICAgICAgICBjb21iaW5lTGF0ZXN0KGFjdGl2ZUNoYW5uZWxJZCQsIGFsbENoYW5uZWxzJCkuc3Vic2NyaWJlKChbYWN0aXZlQ2hhbm5lbElkLCBjaGFubmVsc10pID0+IHtcclxuICAgICAgICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1ub24tbnVsbC1hc3NlcnRpb25cclxuICAgICAgICAgICAgdGhpcy5jdXJyZW50Q2hhbm5lbCA9IGNoYW5uZWxzLml0ZW1zLmZpbmQoYyA9PiBjLmlkID09PSBhY3RpdmVDaGFubmVsSWQpITtcclxuICAgICAgICAgICAgdGhpcy5hdmFpbGFibGVDaGFubmVscyA9IGNoYW5uZWxzLml0ZW1zO1xyXG4gICAgICAgIH0pO1xyXG5cclxuICAgICAgICB0aGlzLnNlbGVjdGVkQ2hhbm5lbElkQ29udHJvbC52YWx1ZUNoYW5nZXMuc3Vic2NyaWJlKGlkcyA9PiB7XHJcbiAgICAgICAgICAgIHRoaXMuc2VsZWN0Q2hhbm5lbChpZHMpO1xyXG4gICAgICAgIH0pO1xyXG4gICAgfVxyXG5cclxuICAgIHNlbGVjdENoYW5uZWwoY2hhbm5lbElkczogc3RyaW5nW10pIHtcclxuICAgICAgICB0aGlzLnNlbGVjdGVkQ2hhbm5lbCA9IHRoaXMuYXZhaWxhYmxlQ2hhbm5lbHMuZmluZChjID0+IGMuaWQgPT09IGNoYW5uZWxJZHNbMF0pO1xyXG4gICAgfVxyXG5cclxuICAgIGFzc2lnbigpIHtcclxuICAgICAgICBjb25zdCBzZWxlY3RlZENoYW5uZWwgPSB0aGlzLnNlbGVjdGVkQ2hhbm5lbDtcclxuICAgICAgICBpZiAoc2VsZWN0ZWRDaGFubmVsKSB7XHJcbiAgICAgICAgICAgIHRoaXMucmVzb2x2ZVdpdGgoc2VsZWN0ZWRDaGFubmVsKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgY2FuY2VsKCkge1xyXG4gICAgICAgIHRoaXMucmVzb2x2ZVdpdGgoKTtcclxuICAgIH1cclxufVxyXG4iLCI8bmctdGVtcGxhdGUgdmRyRGlhbG9nVGl0bGU+XHJcbiAgICB7eyAnY29tbW9uLmNvbmZpcm0tYnVsay1hc3NpZ24tdG8tY2hhbm5lbCcgfCB0cmFuc2xhdGUgfX1cclxuPC9uZy10ZW1wbGF0ZT5cclxuPGRpdiBjbGFzcz1cImZvcm0tZ3JpZFwiPlxyXG4gICAgPHZkci1mb3JtLWl0ZW0+XHJcbiAgICAgICAgPGRpdiAqbmdJZj1cIjAgPCBuTW9yZVwiPlxyXG4gICAgICAgICAgICB7e1xyXG4gICAgICAgICAgICAgICAgJ2NvbW1vbi5saXN0LWl0ZW1zLWFuZC1uLW1vcmUnXHJcbiAgICAgICAgICAgICAgICAgICAgfCB0cmFuc2xhdGVcclxuICAgICAgICAgICAgICAgICAgICAgICAgOiB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGl0ZW1zOiBpdGVtTmFtZXMsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIG5Nb3JlOiBuTW9yZVxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgfX1cclxuICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8ZGl2ICpuZ0lmPVwibk1vcmUgPT09IDBcIj5cclxuICAgICAgICAgICAge3sgaXRlbU5hbWVzIH19XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICA8L3Zkci1mb3JtLWl0ZW0+XHJcbiAgICA8dmRyLWZvcm0tZmllbGQgW2xhYmVsXT1cIidjb21tb24uY2hhbm5lbCcgfCB0cmFuc2xhdGVcIiBjbGFzcz1cIm1iLTRcIj5cclxuICAgICAgICA8dmRyLWNoYW5uZWwtYXNzaWdubWVudC1jb250cm9sXHJcbiAgICAgICAgICAgIGNscklucHV0XHJcbiAgICAgICAgICAgIFttdWx0aXBsZV09XCJmYWxzZVwiXHJcbiAgICAgICAgICAgIFtpbmNsdWRlRGVmYXVsdENoYW5uZWxdPVwiZmFsc2VcIlxyXG4gICAgICAgICAgICBbZm9ybUNvbnRyb2xdPVwic2VsZWN0ZWRDaGFubmVsSWRDb250cm9sXCJcclxuICAgICAgICA+PC92ZHItY2hhbm5lbC1hc3NpZ25tZW50LWNvbnRyb2w+XHJcbiAgICA8L3Zkci1mb3JtLWZpZWxkPlxyXG48L2Rpdj5cclxuXHJcbjxuZy10ZW1wbGF0ZSB2ZHJEaWFsb2dCdXR0b25zPlxyXG4gICAgPGJ1dHRvbiB0eXBlPVwiYnV0dG9uXCIgY2xhc3M9XCJidG5cIiAoY2xpY2spPVwiY2FuY2VsKClcIj57eyAnY29tbW9uLmNhbmNlbCcgfCB0cmFuc2xhdGUgfX08L2J1dHRvbj5cclxuICAgIDxidXR0b24gdHlwZT1cInN1Ym1pdFwiIChjbGljayk9XCJhc3NpZ24oKVwiIFtkaXNhYmxlZF09XCIhc2VsZWN0ZWRDaGFubmVsXCIgY2xhc3M9XCJidG4gYnRuLXByaW1hcnlcIj5cclxuICAgICAgICA8bmctdGVtcGxhdGUgW25nSWZdPVwic2VsZWN0ZWRDaGFubmVsXCIgW25nSWZFbHNlXT1cIm5vU2VsZWN0aW9uXCI+XHJcbiAgICAgICAgICAgIHt7ICdjYXRhbG9nLmFzc2lnbi10by1uYW1lZC1jaGFubmVsJyB8IHRyYW5zbGF0ZSA6IHsgY2hhbm5lbENvZGU6IHNlbGVjdGVkQ2hhbm5lbD8uY29kZSB9IH19XHJcbiAgICAgICAgPC9uZy10ZW1wbGF0ZT5cclxuICAgICAgICA8bmctdGVtcGxhdGUgI25vU2VsZWN0aW9uPlxyXG4gICAgICAgICAgICB7eyAnY2F0YWxvZy5uby1jaGFubmVsLXNlbGVjdGVkJyB8IHRyYW5zbGF0ZSB9fVxyXG4gICAgICAgIDwvbmctdGVtcGxhdGU+XHJcbiAgICA8L2J1dHRvbj5cclxuPC9uZy10ZW1wbGF0ZT5cclxuIl19
|
package/esm2022/core/shared/components/currency-code-selector/currency-code-selector.component.mjs
CHANGED
|
@@ -61,4 +61,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.3", ngImpor
|
|
|
61
61
|
},
|
|
62
62
|
], template: "<ng-select\r\n [items]=\"currencyCodes\"\r\n [addTag]=\"false\"\r\n [hideSelected]=\"true\"\r\n [searchFn]=\"searchCurrencyCodes\"\r\n multiple=\"true\"\r\n appendTo=\"body\"\r\n [(ngModel)]=\"value\"\r\n (ngModelChange)=\"onChangeFn($event)\"\r\n>\r\n <ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\">\r\n <span class=\"ng-value-icon left\" (click)=\"clear.call(null, item)\" aria-hidden=\"true\"> \u00D7 </span>\r\n <span class=\"ng-value-label\">{{ item | localeCurrencyName }}</span>\r\n </ng-template>\r\n <ng-template ng-option-tmp let-item=\"item\">{{ item | localeCurrencyName }}</ng-template>\r\n</ng-select>\r\n" }]
|
|
63
63
|
}], ctorParameters: function () { return [{ type: i1.DataService }, { type: i0.ChangeDetectorRef }]; } });
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VycmVuY3ktY29kZS1zZWxlY3Rvci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvc3JjL3NoYXJlZC9jb21wb25lbnRzL2N1cnJlbmN5LWNvZGUtc2VsZWN0b3IvY3VycmVuY3ktY29kZS1zZWxlY3Rvci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvcmUvc3JjL3NoYXJlZC9jb21wb25lbnRzL2N1cnJlbmN5LWNvZGUtc2VsZWN0b3IvY3VycmVuY3ktY29kZS1zZWxlY3Rvci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQXFCLFNBQVMsRUFBRSxVQUFVLEVBQWEsTUFBTSxlQUFlLENBQUM7QUFDN0csT0FBTyxFQUF3QixpQkFBaUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRXpFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQzs7Ozs7O0FBZ0IvRCxNQUFNLE9BQU8sNkJBQTZCO0lBZXRDLFlBQVksV0FBeUIsRUFBRSxpQkFBcUM7UUFkNUUsa0JBQWEsR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO1FBTzVDLHdCQUFtQixHQUFHLENBQUMsSUFBWSxFQUFFLElBQWtCLEVBQUUsRUFBRTtZQUN2RCxNQUFNLGdCQUFnQixHQUFHLElBQUksSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsRUFBRTtnQkFDMUQsSUFBSSxFQUFFLFVBQVU7YUFDbkIsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUNaLE9BQU8sZ0JBQWdCLEVBQUUsV0FBVyxFQUFFLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDO1FBQ3hFLENBQUMsQ0FBQztRQUdFLElBQUksV0FBVyxJQUFJLGlCQUFpQixFQUFFO1lBQ2xDLElBQUksQ0FBQyxZQUFZLEdBQUcsV0FBVyxDQUFDLE1BQU07aUJBQ2pDLE9BQU8sRUFBRTtpQkFDVCxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDO2lCQUMvQixTQUFTLENBQUMsQ0FBQyxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsRUFBRSxFQUFFO2dCQUNoQyxJQUFJLENBQUMsTUFBTSxHQUFHLFFBQVEsQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLEdBQUcsQ0FBQyxDQUFDO2dCQUMxQyxJQUFJLE1BQU0sRUFBRTtvQkFDUixJQUFJLENBQUMsTUFBTSxJQUFJLElBQUksTUFBTSxFQUFFLENBQUM7aUJBQy9CO2dCQUNELGlCQUFpQixDQUFDLFlBQVksRUFBRSxDQUFDO1lBQ3JDLENBQUMsQ0FBQyxDQUFDO1NBQ1Y7SUFDTCxDQUFDO0lBRUQsVUFBVSxDQUFDLEdBQVE7UUFDZixJQUFJLENBQUMsS0FBSyxHQUFHLEdBQUcsQ0FBQztJQUNyQixDQUFDO0lBQ0QsZ0JBQWdCLENBQUMsRUFBTztRQUNwQixJQUFJLENBQUMsVUFBVSxHQUFHLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBQ0QsaUJBQWlCLENBQUMsRUFBTztRQUNyQixJQUFJLENBQUMsU0FBUyxHQUFHLEVBQUUsQ0FBQztJQUN4QixDQUFDO0lBRUQsV0FBVztRQUNQLElBQUksSUFBSSxDQUFDLFlBQVksRUFBRTtZQUNuQixJQUFJLENBQUMsWUFBWSxDQUFDLFdBQVcsRUFBRSxDQUFDO1NBQ25DO0lBQ0wsQ0FBQzs4R0E1Q1EsNkJBQTZCO2tHQUE3Qiw2QkFBNkIscURBUjNCO1lBQ1A7Z0JBQ0ksT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyw2QkFBNkIsQ0FBQztnQkFDNUQsS0FBSyxFQUFFLElBQUk7YUFDZDtTQUNKLDBCQ2pCTCw2cUJBZ0JBOzsyRkRHYSw2QkFBNkI7a0JBYnpDLFNBQVM7K0JBQ0ksNEJBQTRCLG1CQUdyQix1QkFBdUIsQ0FBQyxNQUFNLGFBQ3BDO3dCQUNQOzRCQUNJLE9BQU8sRUFBRSxpQkFBaUI7NEJBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLDhCQUE4QixDQUFDOzRCQUM1RCxLQUFLLEVBQUUsSUFBSTt5QkFDZDtxQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDaGFuZ2VEZXRlY3RvclJlZiwgQ29tcG9uZW50LCBmb3J3YXJkUmVmLCBPbkRlc3Ryb3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29udHJvbFZhbHVlQWNjZXNzb3IsIE5HX1ZBTFVFX0FDQ0VTU09SIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBTdWJzY3JpcHRpb24gfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgQ3VycmVuY3lDb2RlIH0gZnJvbSAnLi4vLi4vLi4vY29tbW9uL2dlbmVyYXRlZC10eXBlcyc7XHJcbmltcG9ydCB7IERhdGFTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vZGF0YS9wcm92aWRlcnMvZGF0YS5zZXJ2aWNlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICd2ZHItY3VycmVuY3ktY29kZS1zZWxlY3RvcicsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vY3VycmVuY3ktY29kZS1zZWxlY3Rvci5jb21wb25lbnQuaHRtbCcsXHJcbiAgICBzdHlsZVVybHM6IFsnLi9jdXJyZW5jeS1jb2RlLXNlbGVjdG9yLmNvbXBvbmVudC5jc3MnXSxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gICAgcHJvdmlkZXJzOiBbXHJcbiAgICAgICAge1xyXG4gICAgICAgICAgICBwcm92aWRlOiBOR19WQUxVRV9BQ0NFU1NPUixcclxuICAgICAgICAgICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gQ3VycmVuY3lDb2RlU2VsZWN0b3JDb21wb25lbnQpLFxyXG4gICAgICAgICAgICBtdWx0aTogdHJ1ZSxcclxuICAgICAgICB9LFxyXG4gICAgXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIEN1cnJlbmN5Q29kZVNlbGVjdG9yQ29tcG9uZW50IGltcGxlbWVudHMgQ29udHJvbFZhbHVlQWNjZXNzb3IsIE9uRGVzdHJveSB7XHJcbiAgICBjdXJyZW5jeUNvZGVzID0gT2JqZWN0LnZhbHVlcyhDdXJyZW5jeUNvZGUpO1xyXG4gICAgcHJpdmF0ZSBzdWJzY3JpcHRpb246IFN1YnNjcmlwdGlvbjtcclxuICAgIHByaXZhdGUgbG9jYWxlOiBzdHJpbmc7XHJcbiAgICBwcm90ZWN0ZWQgdmFsdWU6IHN0cmluZyB8IHVuZGVmaW5lZDtcclxuICAgIG9uQ2hhbmdlRm46ICh2YWx1ZTogYW55KSA9PiB2b2lkO1xyXG4gICAgb25Ub3VjaEZuOiAodmFsdWU6IGFueSkgPT4gdm9pZDtcclxuXHJcbiAgICBzZWFyY2hDdXJyZW5jeUNvZGVzID0gKHRlcm06IHN0cmluZywgaXRlbTogQ3VycmVuY3lDb2RlKSA9PiB7XHJcbiAgICAgICAgY29uc3QgY3VycmVuY3lDb2RlTmFtZSA9IG5ldyBJbnRsLkRpc3BsYXlOYW1lcyhbdGhpcy5sb2NhbGVdLCB7XHJcbiAgICAgICAgICAgIHR5cGU6ICdjdXJyZW5jeScsXHJcbiAgICAgICAgfSkub2YoaXRlbSk7XHJcbiAgICAgICAgcmV0dXJuIGN1cnJlbmN5Q29kZU5hbWU/LnRvTG93ZXJDYXNlKCkuaW5jbHVkZXModGVybS50b0xvd2VyQ2FzZSgpKTtcclxuICAgIH07XHJcblxyXG4gICAgY29uc3RydWN0b3IoZGF0YVNlcnZpY2U/OiBEYXRhU2VydmljZSwgY2hhbmdlRGV0ZWN0b3JSZWY/OiBDaGFuZ2VEZXRlY3RvclJlZikge1xyXG4gICAgICAgIGlmIChkYXRhU2VydmljZSAmJiBjaGFuZ2VEZXRlY3RvclJlZikge1xyXG4gICAgICAgICAgICB0aGlzLnN1YnNjcmlwdGlvbiA9IGRhdGFTZXJ2aWNlLmNsaWVudFxyXG4gICAgICAgICAgICAgICAgLnVpU3RhdGUoKVxyXG4gICAgICAgICAgICAgICAgLm1hcFN0cmVhbShkYXRhID0+IGRhdGEudWlTdGF0ZSlcclxuICAgICAgICAgICAgICAgIC5zdWJzY3JpYmUoKHsgbGFuZ3VhZ2UsIGxvY2FsZSB9KSA9PiB7XHJcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5sb2NhbGUgPSBsYW5ndWFnZS5yZXBsYWNlKC9fL2csICctJyk7XHJcbiAgICAgICAgICAgICAgICAgICAgaWYgKGxvY2FsZSkge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICB0aGlzLmxvY2FsZSArPSBgLSR7bG9jYWxlfWA7XHJcbiAgICAgICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgICAgIGNoYW5nZURldGVjdG9yUmVmLm1hcmtGb3JDaGVjaygpO1xyXG4gICAgICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG5cclxuICAgIHdyaXRlVmFsdWUob2JqOiBhbnkpOiB2b2lkIHtcclxuICAgICAgICB0aGlzLnZhbHVlID0gb2JqO1xyXG4gICAgfVxyXG4gICAgcmVnaXN0ZXJPbkNoYW5nZShmbjogYW55KTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5vbkNoYW5nZUZuID0gZm47XHJcbiAgICB9XHJcbiAgICByZWdpc3Rlck9uVG91Y2hlZChmbjogYW55KTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5vblRvdWNoRm4gPSBmbjtcclxuICAgIH1cclxuXHJcbiAgICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcclxuICAgICAgICBpZiAodGhpcy5zdWJzY3JpcHRpb24pIHtcclxuICAgICAgICAgICAgdGhpcy5zdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcbn1cclxuIiwiPG5nLXNlbGVjdFxyXG4gICAgW2l0ZW1zXT1cImN1cnJlbmN5Q29kZXNcIlxyXG4gICAgW2FkZFRhZ109XCJmYWxzZVwiXHJcbiAgICBbaGlkZVNlbGVjdGVkXT1cInRydWVcIlxyXG4gICAgW3NlYXJjaEZuXT1cInNlYXJjaEN1cnJlbmN5Q29kZXNcIlxyXG4gICAgbXVsdGlwbGU9XCJ0cnVlXCJcclxuICAgIGFwcGVuZFRvPVwiYm9keVwiXHJcbiAgICBbKG5nTW9kZWwpXT1cInZhbHVlXCJcclxuICAgIChuZ01vZGVsQ2hhbmdlKT1cIm9uQ2hhbmdlRm4oJGV2ZW50KVwiXHJcbj5cclxuICAgIDxuZy10ZW1wbGF0ZSBuZy1sYWJlbC10bXAgbGV0LWl0ZW09XCJpdGVtXCIgbGV0LWNsZWFyPVwiY2xlYXJcIj5cclxuICAgICAgICA8c3BhbiBjbGFzcz1cIm5nLXZhbHVlLWljb24gbGVmdFwiIChjbGljayk9XCJjbGVhci5jYWxsKG51bGwsIGl0ZW0pXCIgYXJpYS1oaWRkZW49XCJ0cnVlXCI+IMOXIDwvc3Bhbj5cclxuICAgICAgICA8c3BhbiBjbGFzcz1cIm5nLXZhbHVlLWxhYmVsXCI+e3sgaXRlbSB8IGxvY2FsZUN1cnJlbmN5TmFtZSB9fTwvc3Bhbj5cclxuICAgIDwvbmctdGVtcGxhdGU+XHJcbiAgICA8bmctdGVtcGxhdGUgbmctb3B0aW9uLXRtcCBsZXQtaXRlbT1cIml0ZW1cIj57eyBpdGVtIHwgbG9jYWxlQ3VycmVuY3lOYW1lIH19PC9uZy10ZW1wbGF0ZT5cclxuPC9uZy1zZWxlY3Q+XHJcbiJdfQ==
|