@vendure/admin-ui 2.1.4 → 2.2.0-next.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (36) hide show
  1. package/catalog/components/product-list/product-list.component.d.ts +1 -1
  2. package/catalog/components/product-variant-list/product-variant-list.component.d.ts +1 -1
  3. package/core/common/utilities/custom-field-default-value.d.ts +1 -1
  4. package/core/common/version.d.ts +1 -1
  5. package/core/components/app-shell/app-shell.component.d.ts +1 -0
  6. package/core/components/ui-language-switcher-dialog/ui-language-switcher-dialog.component.d.ts +9 -3
  7. package/core/core.module.d.ts +1 -1
  8. package/core/providers/i18n/i18n.service.d.ts +6 -0
  9. package/core/shared/components/order-state-label/order-state-label.component.d.ts +1 -1
  10. package/core/shared/dynamic-form-inputs/default-form-inputs.d.ts +1 -1
  11. package/esm2022/core/common/utilities/configurable-operation-utils.mjs +1 -1
  12. package/esm2022/core/common/version.mjs +2 -2
  13. package/esm2022/core/components/app-shell/app-shell.component.mjs +15 -10
  14. package/esm2022/core/components/ui-language-switcher-dialog/ui-language-switcher-dialog.component.mjs +42 -273
  15. package/esm2022/core/core.module.mjs +13 -5
  16. package/esm2022/core/providers/i18n/i18n.service.mjs +11 -1
  17. package/esm2022/core/providers/localization/localization.service.mjs +4 -4
  18. package/esm2022/core/shared/components/asset-preview/asset-preview.component.mjs +3 -3
  19. package/esm2022/core/shared/components/configurable-input/configurable-input.component.mjs +1 -1
  20. package/esm2022/core/shared/components/datetime-picker/datetime-picker.service.mjs +1 -1
  21. package/esm2022/marketing/components/promotion-detail/promotion-detail.component.mjs +8 -8
  22. package/esm2022/react/react-hooks/use-query.mjs +61 -1
  23. package/esm2022/settings/components/payment-method-detail/payment-method-detail.component.mjs +8 -8
  24. package/fesm2022/vendure-admin-ui-core.mjs +66 -276
  25. package/fesm2022/vendure-admin-ui-core.mjs.map +1 -1
  26. package/fesm2022/vendure-admin-ui-marketing.mjs +7 -7
  27. package/fesm2022/vendure-admin-ui-marketing.mjs.map +1 -1
  28. package/fesm2022/vendure-admin-ui-react.mjs +61 -1
  29. package/fesm2022/vendure-admin-ui-react.mjs.map +1 -1
  30. package/fesm2022/vendure-admin-ui-settings.mjs +7 -7
  31. package/fesm2022/vendure-admin-ui-settings.mjs.map +1 -1
  32. package/package.json +14 -14
  33. package/react/react-hooks/use-query.d.ts +59 -0
  34. package/settings/components/stock-location-list/stock-location-list.component.d.ts +1 -1
  35. package/static/i18n-messages/fa.json +1 -1
  36. package/static/vendure-ui-config.json +260 -5
@@ -9,7 +9,7 @@ export declare class ProductListComponent extends TypedBaseListComponent<typeof
9
9
  pendingSearchIndexUpdates: number;
10
10
  readonly customFields: import("@vendure/admin-ui/core").CustomFieldConfig[];
11
11
  readonly filters: import("@vendure/admin-ui/core").DataTableFilterCollection<import("@vendure/admin-ui/core").ProductFilterParameter>;
12
- readonly sorts: import("@vendure/admin-ui/core").DataTableSortCollection<import("@vendure/admin-ui/core").ProductSortParameter, ["name" | "id" | "createdAt" | "updatedAt" | "slug"]>;
12
+ readonly sorts: import("@vendure/admin-ui/core").DataTableSortCollection<import("@vendure/admin-ui/core").ProductSortParameter, ["name" | "slug" | "id" | "createdAt" | "updatedAt"]>;
13
13
  constructor(dataService: DataService, modalService: ModalService, notificationService: NotificationService, jobQueueService: JobQueueService);
14
14
  rebuildSearchIndex(): void;
15
15
  deleteProduct(productId: string): void;
@@ -7,7 +7,7 @@ export declare class ProductVariantListComponent extends TypedBaseListComponent<
7
7
  dataTableId: DataTableLocationId | undefined;
8
8
  readonly customFields: import("@vendure/admin-ui/core").CustomFieldConfig[];
9
9
  readonly filters: import("@vendure/admin-ui/core").DataTableFilterCollection<import("@vendure/admin-ui/core").ProductVariantFilterParameter>;
10
- readonly sorts: import("@vendure/admin-ui/core").DataTableSortCollection<import("@vendure/admin-ui/core").ProductVariantSortParameter, ["name" | "price" | "sku" | "id" | "createdAt" | "updatedAt" | "priceWithTax"]>;
10
+ readonly sorts: import("@vendure/admin-ui/core").DataTableSortCollection<import("@vendure/admin-ui/core").ProductVariantSortParameter, ["name" | "id" | "createdAt" | "updatedAt" | "price" | "sku" | "priceWithTax"]>;
11
11
  constructor();
12
12
  static ɵfac: i0.ɵɵFactoryDeclaration<ProductVariantListComponent, never>;
13
13
  static ɵcmp: i0.ɵɵComponentDeclaration<ProductVariantListComponent, "vdr-product-variant-list", never, { "productId": { "alias": "productId"; "required": false; }; "hideLanguageSelect": { "alias": "hideLanguageSelect"; "required": false; }; "dataTableId": { "alias": "dataTableId"; "required": false; }; }, {}, never, never, false, never>;
@@ -3,4 +3,4 @@ import { CustomFieldConfig } from '../generated-types';
3
3
  export declare function getCustomFieldsDefaults(customFieldConfig: CustomFieldConfig[]): {
4
4
  [key: string]: ReturnType<typeof getDefaultValue>;
5
5
  };
6
- export declare function getDefaultValue(type: CustomFieldType, isNullable?: boolean): false | 0 | "" | Date | null;
6
+ export declare function getDefaultValue(type: CustomFieldType, isNullable?: boolean): false | "" | 0 | Date | null;
@@ -1 +1 @@
1
- export declare const ADMIN_UI_VERSION = "2.1.4";
1
+ export declare const ADMIN_UI_VERSION = "2.2.0-next.0";
@@ -24,6 +24,7 @@ export declare class AppShellComponent implements OnInit {
24
24
  uiLanguageAndLocale$: LocalizationLanguageCodeType;
25
25
  direction$: LocalizationDirectionType;
26
26
  availableLanguages: LanguageCode[];
27
+ availableLocales: string[];
27
28
  hideVendureBranding: boolean | undefined;
28
29
  pageTitle$: Observable<string>;
29
30
  mainNavExpanded$: Observable<boolean>;
@@ -1,8 +1,13 @@
1
- import { OnInit } from '@angular/core';
1
+ import { ChangeDetectorRef, OnDestroy, OnInit } from '@angular/core';
2
2
  import { CurrencyCode, LanguageCode } from '../../common/generated-types';
3
3
  import { Dialog } from '../../providers/modal/modal.types';
4
+ import { DataService } from '../../data/providers/data.service';
4
5
  import * as i0 from "@angular/core";
5
- export declare class UiLanguageSwitcherDialogComponent implements Dialog<[LanguageCode, string | undefined]>, OnInit {
6
+ export declare class UiLanguageSwitcherDialogComponent implements Dialog<[LanguageCode, string | undefined]>, OnInit, OnDestroy {
7
+ private dataService;
8
+ private changeDetector;
9
+ isLoading: boolean;
10
+ private destroy$;
6
11
  resolveWith: (result?: [LanguageCode, string | undefined]) => void;
7
12
  currentLanguage: LanguageCode;
8
13
  availableLanguages: LanguageCode[];
@@ -13,8 +18,9 @@ export declare class UiLanguageSwitcherDialogComponent implements Dialog<[Langua
13
18
  previewLocale: string;
14
19
  readonly browserDefaultLocale: string | undefined;
15
20
  readonly now: string;
16
- constructor();
21
+ constructor(dataService: DataService, changeDetector: ChangeDetectorRef);
17
22
  ngOnInit(): void;
23
+ ngOnDestroy(): void;
18
24
  updatePreviewLocale(): void;
19
25
  setLanguage(): void;
20
26
  cancel(): void;
@@ -33,7 +33,7 @@ export declare class CoreModule {
33
33
  private dataService;
34
34
  private notificationService;
35
35
  constructor(i18nService: I18nService, localStorageService: LocalStorageService, titleService: Title, alertsService: AlertsService, dataService: DataService, notificationService: NotificationService);
36
- private initUiLanguages;
36
+ private initUiLanguagesAndLocales;
37
37
  private initUiTitle;
38
38
  private initAlerts;
39
39
  static ɵfac: i0.ɵɵFactoryDeclaration<CoreModule, never>;
@@ -5,8 +5,10 @@ import * as i0 from "@angular/core";
5
5
  export declare class I18nService {
6
6
  private ngxTranslate;
7
7
  private document;
8
+ _availableLocales: string[];
8
9
  _availableLanguages: LanguageCode[];
9
10
  get availableLanguages(): LanguageCode[];
11
+ get availableLocales(): string[];
10
12
  constructor(ngxTranslate: TranslateService, document: Document);
11
13
  /**
12
14
  * Set the default language
@@ -20,6 +22,10 @@ export declare class I18nService {
20
22
  * Set the available UI languages
21
23
  */
22
24
  setAvailableLanguages(languages: LanguageCode[]): void;
25
+ /**
26
+ * Set the available UI locales
27
+ */
28
+ setAvailableLocales(locales: string[]): void;
23
29
  /**
24
30
  * Translate the given key.
25
31
  */
@@ -11,7 +11,7 @@ import * as i0 from "@angular/core";
11
11
  */
12
12
  export declare class OrderStateLabelComponent {
13
13
  state: string;
14
- get chipColorType(): "success" | "warning" | "error" | "";
14
+ get chipColorType(): "" | "success" | "error" | "warning";
15
15
  static ɵfac: i0.ɵɵFactoryDeclaration<OrderStateLabelComponent, never>;
16
16
  static ɵcmp: i0.ɵɵComponentDeclaration<OrderStateLabelComponent, "vdr-order-state-label", never, { "state": { "alias": "state"; "required": false; }; }, {}, never, ["*"], false, never>;
17
17
  }
@@ -8,7 +8,7 @@ import { PasswordFormInputComponent } from './password-form-input/password-form-
8
8
  import { ProductMultiSelectorFormInputComponent } from './product-multi-selector-form-input/product-multi-selector-form-input.component';
9
9
  import { ProductSelectorFormInputComponent } from './product-selector-form-input/product-selector-form-input.component';
10
10
  import { SelectFormInputComponent } from './select-form-input/select-form-input.component';
11
- export declare const defaultFormInputs: (typeof ProductSelectorFormInputComponent | typeof CustomerGroupFormInputComponent | typeof PasswordFormInputComponent | typeof CurrencyFormInputComponent | typeof SelectFormInputComponent | typeof JsonEditorFormInputComponent | typeof HtmlEditorFormInputComponent | typeof ProductMultiSelectorFormInputComponent | typeof CombinationModeFormInputComponent)[];
11
+ export declare const defaultFormInputs: (typeof SelectFormInputComponent | typeof ProductSelectorFormInputComponent | typeof ProductMultiSelectorFormInputComponent | typeof PasswordFormInputComponent | typeof CustomerGroupFormInputComponent | typeof CurrencyFormInputComponent | typeof CombinationModeFormInputComponent | typeof JsonEditorFormInputComponent | typeof HtmlEditorFormInputComponent)[];
12
12
  /**
13
13
  * Registers the default form input components.
14
14
  */
@@ -113,4 +113,4 @@ export function getDefaultConfigArgValue(arg) {
113
113
  assertNever(type);
114
114
  }
115
115
  }
116
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"configurable-operation-utils.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/common/utilities/configurable-operation-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { ConfigArgType } from '@vendure/common/lib/shared-types';\nimport { assertNever } from '@vendure/common/lib/shared-utils';\n\nimport {\n    ConfigArgDefinition,\n    ConfigurableOperation,\n    ConfigurableOperationDefinition,\n    ConfigurableOperationInput,\n} from '../generated-types';\n\n/**\n * ConfigArg values are always stored as strings. If they are not primitives, then\n * they are JSON-encoded. This function unwraps them back into their original\n * data type.\n */\nexport function getConfigArgValue(value: any) {\n    try {\n        const result = value != null ? JSON.parse(value) : undefined;\n        if (result && typeof result === 'object' && !Array.isArray(result)) {\n            // There is an edge-case where the value is a valid JSON-encoded string and\n            // will get parsed as an object, but we actually want it to be a string.\n            return JSON.stringify(result);\n        } else {\n            return result;\n        }\n    } catch (e: any) {\n        return value;\n    }\n}\n\nexport function encodeConfigArgValue(value: any): string {\n    return Array.isArray(value) ? JSON.stringify(value) : (value ?? '').toString();\n}\n\n/**\n * Creates an empty ConfigurableOperation object based on the definition.\n */\nexport function configurableDefinitionToInstance(\n    def: ConfigurableOperationDefinition,\n): ConfigurableOperation {\n    return {\n        ...def,\n        args: def.args.map(arg => ({\n            ...arg,\n            value: getDefaultConfigArgValue(arg),\n        })),\n    } as ConfigurableOperation;\n}\n\n/**\n * Converts an object of the type:\n * ```\n * {\n *     code: 'my-operation',\n *     args: {\n *         someProperty: 'foo'\n *     }\n * }\n * ```\n * to the format defined by the ConfigurableOperationInput GraphQL input type:\n * ```\n * {\n *     code: 'my-operation',\n *     arguments: [\n *         { name: 'someProperty', value: 'foo' }\n *     ]\n * }\n * ```\n */\nexport function toConfigurableOperationInput(\n    operation: ConfigurableOperation,\n    formValueOperations: { args: Record<string, string> | Array<{ name: string; value: string }> },\n): ConfigurableOperationInput {\n    const argsArray = Array.isArray(formValueOperations.args) ? formValueOperations.args : undefined;\n    const argsMap = !Array.isArray(formValueOperations.args) ? formValueOperations.args : undefined;\n    return {\n        code: operation.code,\n        arguments: operation.args.map(({ name, value }, j) => {\n            const formValue = argsArray?.find(arg => arg.name === name)?.value ?? argsMap?.[name];\n            if (formValue == null) {\n                throw new Error(`Cannot find an argument value for the key \"${name}\"`);\n            }\n            return {\n                name,\n                value: formValue?.hasOwnProperty('value')\n                    ? encodeConfigArgValue((formValue as any).value)\n                    : encodeConfigArgValue(formValue),\n            };\n        }),\n    };\n}\n\nexport function configurableOperationValueIsValid(\n    def?: ConfigurableOperationDefinition,\n    value?: { code: string; args: { [key: string]: string } },\n) {\n    if (!def || !value) {\n        return false;\n    }\n    if (def.code !== value.code) {\n        return false;\n    }\n    for (const argDef of def.args) {\n        const argVal = value.args[argDef.name];\n        if (argDef.required && (argVal == null || argVal === '' || argVal === '0')) {\n            return false;\n        }\n    }\n    return true;\n}\n\n/**\n * Returns a default value based on the type of the config arg.\n */\nexport function getDefaultConfigArgValue(arg: ConfigArgDefinition): any {\n    if (arg.list) {\n        return [];\n    }\n    if (arg.defaultValue != null) {\n        return arg.defaultValue;\n    }\n    const type = arg.type as ConfigArgType;\n    switch (type) {\n        case 'string':\n        case 'datetime':\n        case 'float':\n        case 'ID':\n        case 'int':\n            return null;\n        case 'boolean':\n            return false;\n        default:\n            assertNever(type);\n    }\n}\n"]}
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"configurable-operation-utils.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/common/utilities/configurable-operation-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { ConfigArgType } from '@vendure/common/lib/shared-types';\r\nimport { assertNever } from '@vendure/common/lib/shared-utils';\r\n\r\nimport {\r\n    ConfigArgDefinition,\r\n    ConfigurableOperation,\r\n    ConfigurableOperationDefinition,\r\n    ConfigurableOperationInput,\r\n} from '../generated-types';\r\n\r\n/**\r\n * ConfigArg values are always stored as strings. If they are not primitives, then\r\n * they are JSON-encoded. This function unwraps them back into their original\r\n * data type.\r\n */\r\nexport function getConfigArgValue(value: any) {\r\n    try {\r\n        const result = value != null ? JSON.parse(value) : undefined;\r\n        if (result && typeof result === 'object' && !Array.isArray(result)) {\r\n            // There is an edge-case where the value is a valid JSON-encoded string and\r\n            // will get parsed as an object, but we actually want it to be a string.\r\n            return JSON.stringify(result);\r\n        } else {\r\n            return result;\r\n        }\r\n    } catch (e: any) {\r\n        return value;\r\n    }\r\n}\r\n\r\nexport function encodeConfigArgValue(value: any): string {\r\n    return Array.isArray(value) ? JSON.stringify(value) : (value ?? '').toString();\r\n}\r\n\r\n/**\r\n * Creates an empty ConfigurableOperation object based on the definition.\r\n */\r\nexport function configurableDefinitionToInstance(\r\n    def: ConfigurableOperationDefinition,\r\n): ConfigurableOperation {\r\n    return {\r\n        ...def,\r\n        args: def.args.map(arg => ({\r\n            ...arg,\r\n            value: getDefaultConfigArgValue(arg),\r\n        })),\r\n    } as ConfigurableOperation;\r\n}\r\n\r\n/**\r\n * Converts an object of the type:\r\n * ```\r\n * {\r\n *     code: 'my-operation',\r\n *     args: {\r\n *         someProperty: 'foo'\r\n *     }\r\n * }\r\n * ```\r\n * to the format defined by the ConfigurableOperationInput GraphQL input type:\r\n * ```\r\n * {\r\n *     code: 'my-operation',\r\n *     arguments: [\r\n *         { name: 'someProperty', value: 'foo' }\r\n *     ]\r\n * }\r\n * ```\r\n */\r\nexport function toConfigurableOperationInput(\r\n    operation: ConfigurableOperation,\r\n    formValueOperations: { args: Record<string, string> | Array<{ name: string; value: string }> },\r\n): ConfigurableOperationInput {\r\n    const argsArray = Array.isArray(formValueOperations.args) ? formValueOperations.args : undefined;\r\n    const argsMap = !Array.isArray(formValueOperations.args) ? formValueOperations.args : undefined;\r\n    return {\r\n        code: operation.code,\r\n        arguments: operation.args.map(({ name, value }, j) => {\r\n            const formValue = argsArray?.find(arg => arg.name === name)?.value ?? argsMap?.[name];\r\n            if (formValue == null) {\r\n                throw new Error(`Cannot find an argument value for the key \"${name}\"`);\r\n            }\r\n            return {\r\n                name,\r\n                value: formValue?.hasOwnProperty('value')\r\n                    ? encodeConfigArgValue((formValue as any).value)\r\n                    : encodeConfigArgValue(formValue),\r\n            };\r\n        }),\r\n    };\r\n}\r\n\r\nexport function configurableOperationValueIsValid(\r\n    def?: ConfigurableOperationDefinition,\r\n    value?: { code: string; args: { [key: string]: string } },\r\n) {\r\n    if (!def || !value) {\r\n        return false;\r\n    }\r\n    if (def.code !== value.code) {\r\n        return false;\r\n    }\r\n    for (const argDef of def.args) {\r\n        const argVal = value.args[argDef.name];\r\n        if (argDef.required && (argVal == null || argVal === '' || argVal === '0')) {\r\n            return false;\r\n        }\r\n    }\r\n    return true;\r\n}\r\n\r\n/**\r\n * Returns a default value based on the type of the config arg.\r\n */\r\nexport function getDefaultConfigArgValue(arg: ConfigArgDefinition): any {\r\n    if (arg.list) {\r\n        return [];\r\n    }\r\n    if (arg.defaultValue != null) {\r\n        return arg.defaultValue;\r\n    }\r\n    const type = arg.type as ConfigArgType;\r\n    switch (type) {\r\n        case 'string':\r\n        case 'datetime':\r\n        case 'float':\r\n        case 'ID':\r\n        case 'int':\r\n            return null;\r\n        case 'boolean':\r\n            return false;\r\n        default:\r\n            assertNever(type);\r\n    }\r\n}\r\n"]}
@@ -1,3 +1,3 @@
1
1
  // Auto-generated by the set-version.js script.
2
- export const ADMIN_UI_VERSION = '2.1.4';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvY29yZS9zcmMvY29tbW9uL3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsK0NBQStDO0FBQy9DLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLE9BQU8sQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIEF1dG8tZ2VuZXJhdGVkIGJ5IHRoZSBzZXQtdmVyc2lvbi5qcyBzY3JpcHQuXG5leHBvcnQgY29uc3QgQURNSU5fVUlfVkVSU0lPTiA9ICcyLjEuNCc7XG4iXX0=
2
+ export const ADMIN_UI_VERSION = '2.2.0-next.0';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvY29yZS9zcmMvY29tbW9uL3ZlcnNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsK0NBQStDO0FBQy9DLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIEF1dG8tZ2VuZXJhdGVkIGJ5IHRoZSBzZXQtdmVyc2lvbi5qcyBzY3JpcHQuXG5leHBvcnQgY29uc3QgQURNSU5fVUlfVkVSU0lPTiA9ICcyLjIuMC1uZXh0LjAnO1xuIl19
@@ -37,6 +37,7 @@ export class AppShellComponent {
37
37
  this.localizationService = localizationService;
38
38
  this.version = ADMIN_UI_VERSION;
39
39
  this.availableLanguages = [];
40
+ this.availableLocales = [];
40
41
  this.hideVendureBranding = getAppConfig().hideVendureBranding;
41
42
  this.devMode = isDevMode();
42
43
  }
@@ -47,6 +48,7 @@ export class AppShellComponent {
47
48
  .userStatus()
48
49
  .single$.pipe(map(data => data.userStatus.username));
49
50
  this.availableLanguages = this.i18nService.availableLanguages;
51
+ this.availableLocales = this.i18nService.availableLocales;
50
52
  this.pageTitle$ = this.breadcrumbService.breadcrumbs$.pipe(map(breadcrumbs => breadcrumbs[breadcrumbs.length - 1].label));
51
53
  this.mainNavExpanded$ = this.dataService.client
52
54
  .uiState()
@@ -54,15 +56,18 @@ export class AppShellComponent {
54
56
  }
55
57
  selectUiLanguage() {
56
58
  this.uiLanguageAndLocale$
57
- .pipe(take(1), switchMap(([currentLanguage, currentLocale]) => this.modalService.fromComponent(UiLanguageSwitcherDialogComponent, {
58
- closable: true,
59
- size: 'lg',
60
- locals: {
61
- availableLanguages: this.availableLanguages,
62
- currentLanguage,
63
- currentLocale,
64
- },
65
- })), switchMap(result => result ? this.dataService.client.setUiLanguage(result[0], result[1]) : EMPTY))
59
+ .pipe(take(1), switchMap(([currentLanguage, currentLocale]) => {
60
+ return this.modalService.fromComponent(UiLanguageSwitcherDialogComponent, {
61
+ closable: true,
62
+ size: 'lg',
63
+ locals: {
64
+ availableLocales: this.availableLocales,
65
+ availableLanguages: this.availableLanguages,
66
+ currentLanguage: currentLanguage,
67
+ currentLocale: currentLocale,
68
+ },
69
+ });
70
+ }), switchMap(result => result ? this.dataService.client.setUiLanguage(result[0], result[1]) : EMPTY))
66
71
  .subscribe(result => {
67
72
  if (result.setUiLanguage) {
68
73
  this.i18nService.setLanguage(result.setUiLanguage);
@@ -95,4 +100,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.2", ngImpor
95
100
  type: Component,
96
101
  args: [{ selector: 'vdr-app-shell', template: "<div class=\"app-container\" [dir]=\"direction$ | async\">\r\n <div class=\"left-nav\" [class.expanded]=\"mainNavExpanded$ | async\">\r\n <div class=\"branding\">\r\n <a [routerLink]=\"['/']\" *ngIf=\"!hideVendureBranding\"\r\n ><img src=\"assets/logo-top.webp\" class=\"logo\" style=\"max-width: 100px\"\r\n /></a>\r\n <div class=\"collapse-menu\">\r\n <button class=\"\" (click)=\"collapseNav()\">\r\n <clr-icon shape=\"window-close\" size=\"24\"></clr-icon>\r\n </button>\r\n </div>\r\n </div>\r\n <div class=\"mx-4\">\r\n <vdr-channel-switcher *vdrIfMultichannel></vdr-channel-switcher>\r\n </div>\r\n <div class=\"main-nav-container\">\r\n <vdr-main-nav (itemClick)=\"collapseNav()\"></vdr-main-nav>\r\n </div>\r\n <div class=\"settings-nav-container\">\r\n <hr />\r\n <vdr-main-nav displayMode=\"settings\" (itemClick)=\"collapseNav()\"></vdr-main-nav>\r\n </div>\r\n <div class=\"mx-2\">\r\n <div *ngIf=\"devMode\" class=\"flex center mb-2\">\r\n <vdr-dropdown>\r\n <button class=\"icon-button dev-mode-button\" vdrDropdownTrigger title=\"DEV MODE\">\r\n <clr-icon shape=\"code\" size=\"24\"></clr-icon> DEV MODE\r\n </button>\r\n <vdr-dropdown-menu>\r\n <div class=\"px-2 py-1\">\r\n <div>Version: {{ version }}</div>\r\n <div>View UI extension points: <kbd>CTRL + U</kbd></div>\r\n </div>\r\n </vdr-dropdown-menu>\r\n </vdr-dropdown>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"surface\">\r\n <div class=\"content-container\">\r\n <div class=\"top-bar\">\r\n <div class=\"expand-menu mr-1\">\r\n <button class=\"\" (click)=\"expandNav()\">\r\n <svg\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n fill=\"none\"\r\n viewBox=\"0 0 24 24\"\r\n stroke-width=\"1.5\"\r\n stroke=\"currentColor\"\r\n class=\"bars\"\r\n >\r\n <path\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\"\r\n d=\"M3.75 6.75h16.5M3.75 12h16.5m-16.5 5.25h16.5\"\r\n />\r\n </svg>\r\n </button>\r\n </div>\r\n <div>\r\n <vdr-breadcrumb></vdr-breadcrumb>\r\n </div>\r\n <div class=\"universal-search flex-spacer\"></div>\r\n <div class=\"mx-1\">\r\n <vdr-alerts></vdr-alerts>\r\n </div>\r\n <div>\r\n <vdr-user-menu\r\n [userName]=\"userName$ | async\"\r\n [uiLanguageAndLocale]=\"uiLanguageAndLocale$ | async\"\r\n [availableLanguages]=\"availableLanguages\"\r\n (selectUiLanguage)=\"selectUiLanguage()\"\r\n (logOut)=\"logOut()\"\r\n ></vdr-user-menu>\r\n </div>\r\n </div>\r\n <div class=\"content-area\"><router-outlet></router-outlet></div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".app-container{display:flex;height:100vh;overflow:hidden}.left-nav{background-color:var(--color-left-nav-bg);color:var(--color-left-nav-text);display:flex;flex-direction:column;overflow:hidden;height:100%;border-inline-end:1px solid var(--color-weight-150);z-index:2;width:var(--left-nav-width);max-width:var(--left-nav-width)}@media screen and (max-width: 992px){.left-nav.expanded{position:fixed;inset:0;width:100%;max-width:100%;animation:fade-in .2s ease-in-out forwards}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@media screen and (min-width: 992px){.expand-menu,.collapse-menu{display:none}}.expand-menu button,.collapse-menu button{border:none;padding:calc(var(--space-unit) * 1) calc(var(--space-unit) * 2);background-color:var(--color-page-header-item-bg);border-radius:var(--border-radius-lg);color:var(--color-text-100);display:flex;align-items:center;justify-content:center}.expand-menu .bars,.collapse-menu .bars{width:24px;height:24px}.collapse-menu button{height:40px;background-color:var(--color-weight-200)}.main-nav-container{overflow:auto;flex:1}.settings-nav-container{margin:calc(var(--space-unit) * 3) 0}.settings-nav-container hr{margin:0 calc(var(--space-unit) * 4);margin-bottom:calc(var(--space-unit) * 4);border:1px solid var(--color-weight-150);box-shadow:0 1px 0 var(--color-weight-100)}.logo{max-width:100%}.wordmark{font-weight:700;margin-inline-start:12px;font-size:24px;color:var(--color-primary-500)}@media screen and (max-width: 992px){.wordmark{display:none}}.surface{display:flex;flex-direction:column;flex:1;background-color:var(--color-surface-bg)}.content-container{overflow:auto;min-height:100vh;display:flex;flex-direction:column}.branding{display:flex;align-items:center;justify-content:space-between;min-width:0;padding:calc(var(--space-unit) * 2) calc(var(--space-unit) * 4);padding-inline-end:calc(var(--space-unit) * 1.5)}@media screen and (min-width: 992px){.branding{padding:calc(var(--space-unit) * 4)}}.top-bar{width:100%;display:flex;align-items:center;justify-content:space-between;padding:calc(var(--space-unit) * 2) calc(var(--space-unit) * 1);background-color:var(--color-page-header)}@media screen and (min-width: 992px){.top-bar{padding:calc(var(--space-unit) * 4);padding-inline-start:var(--surface-margin-left)}}.header-actions{align-items:center}.content-area{position:relative;margin-inline-end:auto;flex:1;display:block;width:100%}.dev-mode-button{opacity:.7;font-size:12px}\n"] }]
97
102
  }], ctorParameters: function () { return [{ type: i1.AuthService }, { type: i2.DataService }, { type: i3.Router }, { type: i4.I18nService }, { type: i5.ModalService }, { type: i6.LocalStorageService }, { type: i7.BreadcrumbService }, { type: i8.LocalizationService }]; } });
98
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app-shell.component.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/components/app-shell/app-shell.component.ts","../../../../../src/lib/core/src/components/app-shell/app-shell.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, isDevMode, OnInit } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { EMPTY, Observable } from 'rxjs';\r\nimport { map, switchMap, take } from 'rxjs/operators';\r\n\r\nimport { getAppConfig } from '../../app.config';\r\nimport { LanguageCode } from '../../common/generated-types';\r\nimport { ADMIN_UI_VERSION } from '../../common/version';\r\nimport { DataService } from '../../data/providers/data.service';\r\nimport { AuthService } from '../../providers/auth/auth.service';\r\nimport { BreadcrumbService } from '../../providers/breadcrumb/breadcrumb.service';\r\nimport { I18nService } from '../../providers/i18n/i18n.service';\r\nimport { LocalStorageService } from '../../providers/local-storage/local-storage.service';\r\nimport { ModalService } from '../../providers/modal/modal.service';\r\nimport { UiLanguageSwitcherDialogComponent } from '../ui-language-switcher-dialog/ui-language-switcher-dialog.component';\r\nimport {\r\n    LocalizationDirectionType,\r\n    LocalizationLanguageCodeType,\r\n    LocalizationService,\r\n} from '../../providers/localization/localization.service';\r\n\r\n@Component({\r\n    selector: 'vdr-app-shell',\r\n    templateUrl: './app-shell.component.html',\r\n    styleUrls: ['./app-shell.component.scss'],\r\n})\r\nexport class AppShellComponent implements OnInit {\r\n    version = ADMIN_UI_VERSION;\r\n    userName$: Observable<string>;\r\n    uiLanguageAndLocale$: LocalizationLanguageCodeType;\r\n    direction$: LocalizationDirectionType;\r\n    availableLanguages: LanguageCode[] = [];\r\n    hideVendureBranding = getAppConfig().hideVendureBranding;\r\n    pageTitle$: Observable<string>;\r\n    mainNavExpanded$: Observable<boolean>;\r\n    devMode = isDevMode();\r\n\r\n    constructor(\r\n        private authService: AuthService,\r\n        private dataService: DataService,\r\n        private router: Router,\r\n        private i18nService: I18nService,\r\n        private modalService: ModalService,\r\n        private localStorageService: LocalStorageService,\r\n        private breadcrumbService: BreadcrumbService,\r\n        private localizationService: LocalizationService,\r\n    ) {}\r\n\r\n    ngOnInit() {\r\n        this.direction$ = this.localizationService.direction$;\r\n\r\n        this.uiLanguageAndLocale$ = this.localizationService.uiLanguageAndLocale$;\r\n\r\n        this.userName$ = this.dataService.client\r\n            .userStatus()\r\n            .single$.pipe(map(data => data.userStatus.username));\r\n\r\n        this.availableLanguages = this.i18nService.availableLanguages;\r\n\r\n        this.pageTitle$ = this.breadcrumbService.breadcrumbs$.pipe(\r\n            map(breadcrumbs => breadcrumbs[breadcrumbs.length - 1].label),\r\n        );\r\n\r\n        this.mainNavExpanded$ = this.dataService.client\r\n            .uiState()\r\n            .stream$.pipe(map(({ uiState }) => uiState.mainNavExpanded));\r\n    }\r\n\r\n    selectUiLanguage() {\r\n        this.uiLanguageAndLocale$\r\n            .pipe(\r\n                take(1),\r\n                switchMap(([currentLanguage, currentLocale]) =>\r\n                    this.modalService.fromComponent(UiLanguageSwitcherDialogComponent, {\r\n                        closable: true,\r\n                        size: 'lg',\r\n                        locals: {\r\n                            availableLanguages: this.availableLanguages,\r\n                            currentLanguage,\r\n                            currentLocale,\r\n                        },\r\n                    }),\r\n                ),\r\n                switchMap(result =>\r\n                    result ? this.dataService.client.setUiLanguage(result[0], result[1]) : EMPTY,\r\n                ),\r\n            )\r\n            .subscribe(result => {\r\n                if (result.setUiLanguage) {\r\n                    this.i18nService.setLanguage(result.setUiLanguage);\r\n                    this.localStorageService.set('uiLanguageCode', result.setUiLanguage);\r\n                    this.localStorageService.set('uiLocale', result.setUiLocale ?? undefined);\r\n                }\r\n            });\r\n    }\r\n\r\n    expandNav() {\r\n        this.dataService.client.setMainNavExpanded(true).subscribe();\r\n    }\r\n\r\n    collapseNav() {\r\n        this.dataService.client.setMainNavExpanded(false).subscribe();\r\n    }\r\n\r\n    logOut() {\r\n        this.authService.logOut().subscribe(() => {\r\n            const { loginUrl } = getAppConfig();\r\n            if (loginUrl) {\r\n                window.location.href = loginUrl;\r\n            } else {\r\n                this.router.navigate(['/login']);\r\n            }\r\n        });\r\n    }\r\n}\r\n","<div class=\"app-container\" [dir]=\"direction$ | async\">\r\n    <div class=\"left-nav\" [class.expanded]=\"mainNavExpanded$ | async\">\r\n        <div class=\"branding\">\r\n            <a [routerLink]=\"['/']\" *ngIf=\"!hideVendureBranding\"\r\n                ><img src=\"assets/logo-top.webp\" class=\"logo\" style=\"max-width: 100px\"\r\n            /></a>\r\n            <div class=\"collapse-menu\">\r\n                <button class=\"\" (click)=\"collapseNav()\">\r\n                    <clr-icon shape=\"window-close\" size=\"24\"></clr-icon>\r\n                </button>\r\n            </div>\r\n        </div>\r\n        <div class=\"mx-4\">\r\n            <vdr-channel-switcher *vdrIfMultichannel></vdr-channel-switcher>\r\n        </div>\r\n        <div class=\"main-nav-container\">\r\n            <vdr-main-nav (itemClick)=\"collapseNav()\"></vdr-main-nav>\r\n        </div>\r\n        <div class=\"settings-nav-container\">\r\n            <hr />\r\n            <vdr-main-nav displayMode=\"settings\" (itemClick)=\"collapseNav()\"></vdr-main-nav>\r\n        </div>\r\n        <div class=\"mx-2\">\r\n            <div *ngIf=\"devMode\" class=\"flex center mb-2\">\r\n                <vdr-dropdown>\r\n                    <button class=\"icon-button dev-mode-button\" vdrDropdownTrigger title=\"DEV MODE\">\r\n                        <clr-icon shape=\"code\" size=\"24\"></clr-icon> DEV MODE\r\n                    </button>\r\n                    <vdr-dropdown-menu>\r\n                        <div class=\"px-2 py-1\">\r\n                            <div>Version: {{ version }}</div>\r\n                            <div>View UI extension points: <kbd>CTRL + U</kbd></div>\r\n                        </div>\r\n                    </vdr-dropdown-menu>\r\n                </vdr-dropdown>\r\n            </div>\r\n        </div>\r\n    </div>\r\n\r\n    <div class=\"surface\">\r\n        <div class=\"content-container\">\r\n            <div class=\"top-bar\">\r\n                <div class=\"expand-menu mr-1\">\r\n                    <button class=\"\" (click)=\"expandNav()\">\r\n                        <svg\r\n                            xmlns=\"http://www.w3.org/2000/svg\"\r\n                            fill=\"none\"\r\n                            viewBox=\"0 0 24 24\"\r\n                            stroke-width=\"1.5\"\r\n                            stroke=\"currentColor\"\r\n                            class=\"bars\"\r\n                        >\r\n                            <path\r\n                                stroke-linecap=\"round\"\r\n                                stroke-linejoin=\"round\"\r\n                                d=\"M3.75 6.75h16.5M3.75 12h16.5m-16.5 5.25h16.5\"\r\n                            />\r\n                        </svg>\r\n                    </button>\r\n                </div>\r\n                <div>\r\n                    <vdr-breadcrumb></vdr-breadcrumb>\r\n                </div>\r\n                <div class=\"universal-search flex-spacer\"></div>\r\n                <div class=\"mx-1\">\r\n                    <vdr-alerts></vdr-alerts>\r\n                </div>\r\n                <div>\r\n                    <vdr-user-menu\r\n                        [userName]=\"userName$ | async\"\r\n                        [uiLanguageAndLocale]=\"uiLanguageAndLocale$ | async\"\r\n                        [availableLanguages]=\"availableLanguages\"\r\n                        (selectUiLanguage)=\"selectUiLanguage()\"\r\n                        (logOut)=\"logOut()\"\r\n                    ></vdr-user-menu>\r\n                </div>\r\n            </div>\r\n            <div class=\"content-area\"><router-outlet></router-outlet></div>\r\n        </div>\r\n    </div>\r\n</div>\r\n"]}
103
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"app-shell.component.js","sourceRoot":"","sources":["../../../../../src/lib/core/src/components/app-shell/app-shell.component.ts","../../../../../src/lib/core/src/components/app-shell/app-shell.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, isDevMode, OnInit } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { EMPTY, Observable } from 'rxjs';\r\nimport { map, switchMap, take } from 'rxjs/operators';\r\n\r\nimport { getAppConfig } from '../../app.config';\r\nimport { LanguageCode } from '../../common/generated-types';\r\nimport { ADMIN_UI_VERSION } from '../../common/version';\r\nimport { DataService } from '../../data/providers/data.service';\r\nimport { AuthService } from '../../providers/auth/auth.service';\r\nimport { BreadcrumbService } from '../../providers/breadcrumb/breadcrumb.service';\r\nimport { I18nService } from '../../providers/i18n/i18n.service';\r\nimport { LocalStorageService } from '../../providers/local-storage/local-storage.service';\r\nimport { ModalService } from '../../providers/modal/modal.service';\r\nimport { UiLanguageSwitcherDialogComponent } from '../ui-language-switcher-dialog/ui-language-switcher-dialog.component';\r\nimport {\r\n    LocalizationDirectionType,\r\n    LocalizationLanguageCodeType,\r\n    LocalizationService,\r\n} from '../../providers/localization/localization.service';\r\n\r\n@Component({\r\n    selector: 'vdr-app-shell',\r\n    templateUrl: './app-shell.component.html',\r\n    styleUrls: ['./app-shell.component.scss'],\r\n})\r\nexport class AppShellComponent implements OnInit {\r\n    version = ADMIN_UI_VERSION;\r\n    userName$: Observable<string>;\r\n    uiLanguageAndLocale$: LocalizationLanguageCodeType;\r\n    direction$: LocalizationDirectionType;\r\n    availableLanguages: LanguageCode[] = [];\r\n    availableLocales: string[] = [];\r\n    hideVendureBranding = getAppConfig().hideVendureBranding;\r\n    pageTitle$: Observable<string>;\r\n    mainNavExpanded$: Observable<boolean>;\r\n    devMode = isDevMode();\r\n\r\n    constructor(\r\n        private authService: AuthService,\r\n        private dataService: DataService,\r\n        private router: Router,\r\n        private i18nService: I18nService,\r\n        private modalService: ModalService,\r\n        private localStorageService: LocalStorageService,\r\n        private breadcrumbService: BreadcrumbService,\r\n        private localizationService: LocalizationService,\r\n    ) {}\r\n\r\n    ngOnInit() {\r\n        this.direction$ = this.localizationService.direction$;\r\n\r\n        this.uiLanguageAndLocale$ = this.localizationService.uiLanguageAndLocale$;\r\n\r\n        this.userName$ = this.dataService.client\r\n            .userStatus()\r\n            .single$.pipe(map(data => data.userStatus.username));\r\n\r\n        this.availableLanguages = this.i18nService.availableLanguages;\r\n\r\n        this.availableLocales = this.i18nService.availableLocales;\r\n\r\n        this.pageTitle$ = this.breadcrumbService.breadcrumbs$.pipe(\r\n            map(breadcrumbs => breadcrumbs[breadcrumbs.length - 1].label),\r\n        );\r\n\r\n        this.mainNavExpanded$ = this.dataService.client\r\n            .uiState()\r\n            .stream$.pipe(map(({ uiState }) => uiState.mainNavExpanded));\r\n    }\r\n\r\n    selectUiLanguage() {\r\n        this.uiLanguageAndLocale$\r\n            .pipe(\r\n                take(1),\r\n                switchMap(([currentLanguage, currentLocale]) => {\r\n                    return this.modalService.fromComponent(UiLanguageSwitcherDialogComponent, {\r\n                        closable: true,\r\n                        size: 'lg',\r\n                        locals: {\r\n                            availableLocales: this.availableLocales,\r\n                            availableLanguages: this.availableLanguages,\r\n                            currentLanguage: currentLanguage,\r\n                            currentLocale: currentLocale,\r\n                        },\r\n                    });\r\n                }),\r\n                switchMap(result =>\r\n                    result ? this.dataService.client.setUiLanguage(result[0], result[1]) : EMPTY,\r\n                ),\r\n            )\r\n            .subscribe(result => {\r\n                if (result.setUiLanguage) {\r\n                    this.i18nService.setLanguage(result.setUiLanguage);\r\n                    this.localStorageService.set('uiLanguageCode', result.setUiLanguage);\r\n                    this.localStorageService.set('uiLocale', result.setUiLocale ?? undefined);\r\n                }\r\n            });\r\n    }\r\n\r\n    expandNav() {\r\n        this.dataService.client.setMainNavExpanded(true).subscribe();\r\n    }\r\n\r\n    collapseNav() {\r\n        this.dataService.client.setMainNavExpanded(false).subscribe();\r\n    }\r\n\r\n    logOut() {\r\n        this.authService.logOut().subscribe(() => {\r\n            const { loginUrl } = getAppConfig();\r\n            if (loginUrl) {\r\n                window.location.href = loginUrl;\r\n            } else {\r\n                this.router.navigate(['/login']);\r\n            }\r\n        });\r\n    }\r\n}\r\n","<div class=\"app-container\" [dir]=\"direction$ | async\">\r\n    <div class=\"left-nav\" [class.expanded]=\"mainNavExpanded$ | async\">\r\n        <div class=\"branding\">\r\n            <a [routerLink]=\"['/']\" *ngIf=\"!hideVendureBranding\"\r\n                ><img src=\"assets/logo-top.webp\" class=\"logo\" style=\"max-width: 100px\"\r\n            /></a>\r\n            <div class=\"collapse-menu\">\r\n                <button class=\"\" (click)=\"collapseNav()\">\r\n                    <clr-icon shape=\"window-close\" size=\"24\"></clr-icon>\r\n                </button>\r\n            </div>\r\n        </div>\r\n        <div class=\"mx-4\">\r\n            <vdr-channel-switcher *vdrIfMultichannel></vdr-channel-switcher>\r\n        </div>\r\n        <div class=\"main-nav-container\">\r\n            <vdr-main-nav (itemClick)=\"collapseNav()\"></vdr-main-nav>\r\n        </div>\r\n        <div class=\"settings-nav-container\">\r\n            <hr />\r\n            <vdr-main-nav displayMode=\"settings\" (itemClick)=\"collapseNav()\"></vdr-main-nav>\r\n        </div>\r\n        <div class=\"mx-2\">\r\n            <div *ngIf=\"devMode\" class=\"flex center mb-2\">\r\n                <vdr-dropdown>\r\n                    <button class=\"icon-button dev-mode-button\" vdrDropdownTrigger title=\"DEV MODE\">\r\n                        <clr-icon shape=\"code\" size=\"24\"></clr-icon> DEV MODE\r\n                    </button>\r\n                    <vdr-dropdown-menu>\r\n                        <div class=\"px-2 py-1\">\r\n                            <div>Version: {{ version }}</div>\r\n                            <div>View UI extension points: <kbd>CTRL + U</kbd></div>\r\n                        </div>\r\n                    </vdr-dropdown-menu>\r\n                </vdr-dropdown>\r\n            </div>\r\n        </div>\r\n    </div>\r\n\r\n    <div class=\"surface\">\r\n        <div class=\"content-container\">\r\n            <div class=\"top-bar\">\r\n                <div class=\"expand-menu mr-1\">\r\n                    <button class=\"\" (click)=\"expandNav()\">\r\n                        <svg\r\n                            xmlns=\"http://www.w3.org/2000/svg\"\r\n                            fill=\"none\"\r\n                            viewBox=\"0 0 24 24\"\r\n                            stroke-width=\"1.5\"\r\n                            stroke=\"currentColor\"\r\n                            class=\"bars\"\r\n                        >\r\n                            <path\r\n                                stroke-linecap=\"round\"\r\n                                stroke-linejoin=\"round\"\r\n                                d=\"M3.75 6.75h16.5M3.75 12h16.5m-16.5 5.25h16.5\"\r\n                            />\r\n                        </svg>\r\n                    </button>\r\n                </div>\r\n                <div>\r\n                    <vdr-breadcrumb></vdr-breadcrumb>\r\n                </div>\r\n                <div class=\"universal-search flex-spacer\"></div>\r\n                <div class=\"mx-1\">\r\n                    <vdr-alerts></vdr-alerts>\r\n                </div>\r\n                <div>\r\n                    <vdr-user-menu\r\n                        [userName]=\"userName$ | async\"\r\n                        [uiLanguageAndLocale]=\"uiLanguageAndLocale$ | async\"\r\n                        [availableLanguages]=\"availableLanguages\"\r\n                        (selectUiLanguage)=\"selectUiLanguage()\"\r\n                        (logOut)=\"logOut()\"\r\n                    ></vdr-user-menu>\r\n                </div>\r\n            </div>\r\n            <div class=\"content-area\"><router-outlet></router-outlet></div>\r\n        </div>\r\n    </div>\r\n</div>\r\n"]}