@fundamental-ngx/ui5-webcomponents-fiori 0.58.0-rc.71 → 0.58.0-rc.73
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/barcode-scanner-dialog/index.d.ts +66 -0
- package/dynamic-page/index.d.ts +65 -0
- package/dynamic-page-header/index.d.ts +37 -0
- package/dynamic-page-title/index.d.ts +63 -0
- package/dynamic-side-content/index.d.ts +81 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-barcode-scanner-dialog.mjs +131 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-barcode-scanner-dialog.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-dynamic-page-header.mjs +61 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-dynamic-page-header.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-dynamic-page-title.mjs +115 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-dynamic-page-title.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-dynamic-page.mjs +139 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-dynamic-page.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-dynamic-side-content.mjs +148 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-dynamic-side-content.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-filter-item-option.mjs +65 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-filter-item-option.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-filter-item.mjs +91 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-filter-item.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-flexible-column-layout.mjs +297 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-flexible-column-layout.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-group-item.mjs +65 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-group-item.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-illustrated-message.mjs +159 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-illustrated-message.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-media-gallery-item.mjs +100 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-media-gallery-item.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-media-gallery.mjs +148 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-media-gallery.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-navigation-layout.mjs +95 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-navigation-layout.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-notification-list-group-item.mjs +139 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-notification-list-group-item.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-notification-list-item.mjs +174 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-notification-list-item.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-notification-list.mjs +114 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-notification-list.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-page.mjs +115 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-page.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-product-switch-item.mjs +145 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-product-switch-item.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-product-switch.mjs +61 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-product-switch.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-search-item-group.mjs +36 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-search-item-group.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-search-item-show-more.mjs +87 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-search-item-show-more.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-search-item.mjs +143 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-search-item.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-search-message-area.mjs +65 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-search-message-area.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-search-scope.mjs +65 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-search-scope.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-search.mjs +191 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-search.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-shell-bar-branding.mjs +135 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-shell-bar-branding.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-shell-bar-item.mjs +109 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-shell-bar-item.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-shell-bar-search.mjs +196 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-shell-bar-search.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-shell-bar-spacer.mjs +36 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-shell-bar-spacer.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-shell-bar.mjs +334 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-shell-bar.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-side-navigation-group.mjs +105 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-side-navigation-group.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-side-navigation-item.mjs +195 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-side-navigation-item.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-side-navigation-sub-item.mjs +165 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-side-navigation-sub-item.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-side-navigation.mjs +130 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-side-navigation.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-sort-item.mjs +65 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-sort-item.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-theming.mjs +23 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-theming.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-timeline-group-item.mjs +109 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-timeline-group-item.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-timeline-item.mjs +136 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-timeline-item.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-timeline.mjs +135 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-timeline.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-upload-collection-item.mjs +184 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-upload-collection-item.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-upload-collection.mjs +152 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-upload-collection.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-user-menu-account.mjs +95 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-user-menu-account.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-user-menu-item-group.mjs +36 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-user-menu-item-group.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-user-menu-item.mjs +63 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-user-menu-item.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-user-menu.mjs +174 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-user-menu.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-user-settings-account-view.mjs +130 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-user-settings-account-view.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-user-settings-dialog.mjs +138 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-user-settings-dialog.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-user-settings-item.mjs +158 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-user-settings-item.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-user-settings-view.mjs +96 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-user-settings-view.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-view-settings-dialog.mjs +150 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-view-settings-dialog.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-wizard-step.mjs +130 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-wizard-step.mjs.map +1 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-wizard.mjs +107 -0
- package/fesm2022/fundamental-ngx-ui5-webcomponents-fiori-wizard.mjs.map +1 -0
- package/filter-item/index.d.ts +46 -0
- package/filter-item-option/index.d.ts +22 -0
- package/flexible-column-layout/index.d.ts +135 -0
- package/group-item/index.d.ts +22 -0
- package/illustrated-message/index.d.ts +105 -0
- package/media-gallery/index.d.ts +84 -0
- package/media-gallery-item/index.d.ts +50 -0
- package/navigation-layout/index.d.ts +43 -0
- package/notification-list/index.d.ts +54 -0
- package/notification-list-group-item/index.d.ts +75 -0
- package/notification-list-item/index.d.ts +97 -0
- package/package.json +210 -2
- package/page/index.d.ts +60 -0
- package/product-switch/index.d.ts +37 -0
- package/product-switch-item/index.d.ts +83 -0
- package/search/index.d.ts +106 -0
- package/search-item/index.d.ts +75 -0
- package/search-item-group/index.d.ts +14 -0
- package/search-item-show-more/index.d.ts +30 -0
- package/search-message-area/index.d.ts +22 -0
- package/search-scope/index.d.ts +22 -0
- package/shell-bar/index.d.ts +218 -0
- package/shell-bar-branding/index.d.ts +71 -0
- package/shell-bar-item/index.d.ts +51 -0
- package/shell-bar-search/index.d.ts +110 -0
- package/shell-bar-spacer/index.d.ts +14 -0
- package/side-navigation/index.d.ts +67 -0
- package/side-navigation-group/index.d.ts +58 -0
- package/side-navigation-item/index.d.ts +128 -0
- package/side-navigation-sub-item/index.d.ts +101 -0
- package/sort-item/index.d.ts +22 -0
- package/theming/index.d.ts +11 -0
- package/timeline/index.d.ts +73 -0
- package/timeline-group-item/index.d.ts +50 -0
- package/timeline-item/index.d.ts +73 -0
- package/upload-collection/index.d.ts +84 -0
- package/upload-collection-item/index.d.ts +111 -0
- package/user-menu/index.d.ts +100 -0
- package/user-menu-account/index.d.ts +46 -0
- package/user-menu-item/index.d.ts +39 -0
- package/user-menu-item-group/index.d.ts +14 -0
- package/user-settings-account-view/index.d.ts +64 -0
- package/user-settings-dialog/index.d.ts +71 -0
- package/user-settings-item/index.d.ts +88 -0
- package/user-settings-view/index.d.ts +50 -0
- package/view-settings-dialog/index.d.ts +78 -0
- package/wizard/index.d.ts +49 -0
- package/wizard-step/index.d.ts +81 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fundamental-ngx-ui5-webcomponents-fiori-media-gallery.mjs","sources":["../tmp-esm2022/media-gallery/index.js","../tmp-esm2022/media-gallery/fundamental-ngx-ui5-webcomponents-fiori-media-gallery.js"],"sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, input, output, effect, runInInjectionContext, inject, Injector, booleanAttribute } from '@angular/core';\nimport '@ui5/webcomponents-fiori/dist/MediaGallery.js';\nimport * as i0 from \"@angular/core\";\nexport class MediaGallery {\n constructor() {\n /**\n * If set to `true`, all thumbnails are rendered in a scrollable container.\n If `false`, only up to five thumbnails are rendered, followed by\n an overflow button that shows the count of the remaining thumbnails.\n */\n this.showAllThumbnails = input(false, ...(ngDevMode ? [{ debugName: \"showAllThumbnails\", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));\n /**\n * If enabled, a `display-area-click` event is fired\n when the user clicks or taps on the display area.\n \n The display area is the central area that contains\n the enlarged content of the currently selected item.\n */\n this.interactiveDisplayArea = input(false, ...(ngDevMode ? [{ debugName: \"interactiveDisplayArea\", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));\n /**\n * Determines the layout of the component.\n */\n this.layout = input(\"Auto\", ...(ngDevMode ? [{ debugName: \"layout\" }] : []));\n /**\n * Determines the horizontal alignment of the thumbnails menu\n vs. the central display area.\n */\n this.menuHorizontalAlign = input(\"Left\", ...(ngDevMode ? [{ debugName: \"menuHorizontalAlign\" }] : []));\n /**\n * Determines the vertical alignment of the thumbnails menu\n vs. the central display area.\n */\n this.menuVerticalAlign = input(\"Bottom\", ...(ngDevMode ? [{ debugName: \"menuVerticalAlign\" }] : [])); // className is now passed\n /**\n * Fired when selection is changed by user interaction.\n */\n this.ui5SelectionChange = output();\n /**\n * Fired when the thumbnails overflow button is clicked.\n */\n this.ui5OverflowClick = output();\n /**\n * Fired when the display area is clicked.\n The display area is the central area that contains\n the enlarged content of the currently selected item.\n */\n this.ui5DisplayAreaClick = output();\n /**\n * Available slots for content projection in this component.\n *\n * Slots allow you to insert custom content into predefined areas of the web component.\n * Use the `slot` attribute on child elements to target specific slots.\n *\n * - **(default)**: Defines the component items.\n \n **Note:** Only one selected item is allowed.\n \n **Note:** Use the `ui5-media-gallery-item` component to define the desired items.\n *\n * @example\n * ```html\n * <ui5-media-gallery>\n * <div slot=\"header\">Custom header content</div>\n * <p>Default slot content</p>\n * </ui5-media-gallery>\n * ```\n *\n * @readonly\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_templates_and_slots | MDN Web Components Slots}\n */\n this.slots = [\n {\n \"name\": \"default\",\n \"description\": \"Defines the component items.\\n\\n**Note:** Only one selected item is allowed.\\n\\n**Note:** Use the `ui5-media-gallery-item` component to define the desired items.\"\n }\n ];\n this.elementRef = inject(ElementRef);\n this.injector = inject(Injector);\n }\n get element() {\n return this.elementRef.nativeElement;\n }\n ngAfterViewInit() {\n const wcElement = this.element;\n const inputsToSync = [\n 'showAllThumbnails',\n 'interactiveDisplayArea',\n 'layout',\n 'menuHorizontalAlign',\n 'menuVerticalAlign',\n ];\n // Synchronize inputs (properties)\n for (const inputName of inputsToSync) {\n // Find the corresponding camelCase signal property on the Angular component\n const signalName = inputName.replace(/-./g, (x) => x[1].toUpperCase());\n // Use the Injector to run the effect in the correct context\n if (this[signalName] && typeof this[signalName] === 'function') {\n runInInjectionContext(this.injector, () => {\n effect(() => {\n // Read the signal value\n const value = this[signalName]();\n if (wcElement) {\n // Write the value to the Web Component's property\n wcElement[inputName] = value;\n }\n });\n });\n }\n }\n const outputsToSync = [\n 'ui5SelectionChange',\n 'ui5OverflowClick',\n 'ui5DisplayAreaClick',\n ];\n // Synchronize outputs (events)\n for (const outputName of outputsToSync) {\n // Map Angular output name to UI5 web component event name\n const eventName = outputName.replace('ui5', '').replace(/([A-Z])/g, '-$1').toLowerCase().substring(1);\n // Ensure the output property exists and has an emit function before adding listener\n if (this[outputName] && typeof this[outputName].emit === 'function' && wcElement.addEventListener) {\n // Cast the listener to the correct type to satisfy TypeScript\n wcElement.addEventListener(eventName, (e) => {\n this[outputName].emit(e);\n });\n }\n }\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.1.4\", ngImport: i0, type: MediaGallery, deps: [], target: i0.ɵɵFactoryTarget.Component }); }\n static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: \"17.1.0\", version: \"20.1.4\", type: MediaGallery, isStandalone: true, selector: \"ui5-media-gallery, [ui5-media-gallery]\", inputs: { showAllThumbnails: { classPropertyName: \"showAllThumbnails\", publicName: \"showAllThumbnails\", isSignal: true, isRequired: false, transformFunction: null }, interactiveDisplayArea: { classPropertyName: \"interactiveDisplayArea\", publicName: \"interactiveDisplayArea\", isSignal: true, isRequired: false, transformFunction: null }, layout: { classPropertyName: \"layout\", publicName: \"layout\", isSignal: true, isRequired: false, transformFunction: null }, menuHorizontalAlign: { classPropertyName: \"menuHorizontalAlign\", publicName: \"menuHorizontalAlign\", isSignal: true, isRequired: false, transformFunction: null }, menuVerticalAlign: { classPropertyName: \"menuVerticalAlign\", publicName: \"menuVerticalAlign\", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { ui5SelectionChange: \"ui5SelectionChange\", ui5OverflowClick: \"ui5OverflowClick\", ui5DisplayAreaClick: \"ui5DisplayAreaClick\" }, exportAs: [\"ui5MediaGallery\"], ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.1.4\", ngImport: i0, type: MediaGallery, decorators: [{\n type: Component,\n args: [{\n standalone: true,\n selector: 'ui5-media-gallery, [ui5-media-gallery]',\n template: '<ng-content></ng-content>',\n exportAs: 'ui5MediaGallery',\n changeDetection: ChangeDetectionStrategy.OnPush,\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../libs/ui5-webcomponents-fiori/media-gallery/index.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  input,\n  output,\n  AfterViewInit,\n  effect,\n  runInInjectionContext,\n  inject,\n  Injector,\n  booleanAttribute,\n  computed,\n  signal\n} from '@angular/core';\nimport '@ui5/webcomponents-fiori/dist/MediaGallery.js';\nimport { default as _MediaGallery } from '@ui5/webcomponents-fiori/dist/MediaGallery.js';\nimport { UI5CustomEvent } from '@ui5/webcomponents-base';\n\nimport { default as MediaGalleryLayout } from '@ui5/webcomponents-fiori/dist/types/MediaGalleryLayout.js';\nimport { default as MediaGalleryMenuHorizontalAlign } from '@ui5/webcomponents-fiori/dist/types/MediaGalleryMenuHorizontalAlign.js';\nimport { default as MediaGalleryMenuVerticalAlign } from '@ui5/webcomponents-fiori/dist/types/MediaGalleryMenuVerticalAlign.js';\n\n@Component({\n  standalone: true,\n  selector: 'ui5-media-gallery, [ui5-media-gallery]',\n  template: '<ng-content></ng-content>',\n  exportAs: 'ui5MediaGallery',\n\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class MediaGallery implements AfterViewInit {\n\n  /**\n   * If set to `true`, all thumbnails are rendered in a scrollable container.\nIf `false`, only up to five thumbnails are rendered, followed by\nan overflow button that shows the count of the remaining thumbnails.\n   */\n  showAllThumbnails = input(false, { transform: booleanAttribute });\n\n  /**\n   * If enabled, a `display-area-click` event is fired\nwhen the user clicks or taps on the display area.\n\nThe display area is the central area that contains\nthe enlarged content of the currently selected item.\n   */\n  interactiveDisplayArea = input(false, { transform: booleanAttribute });\n\n  /**\n   * Determines the layout of the component.\n   */\n  layout = input<typeof _MediaGallery.prototype.layout | undefined>(\"Auto\");\n\n  /**\n   * Determines the horizontal alignment of the thumbnails menu\nvs. the central display area.\n   */\n  menuHorizontalAlign = input<typeof _MediaGallery.prototype.menuHorizontalAlign | undefined>(\"Left\");\n\n  /**\n   * Determines the vertical alignment of the thumbnails menu\nvs. the central display area.\n   */\n  menuVerticalAlign = input<typeof _MediaGallery.prototype.menuVerticalAlign | undefined>(\"Bottom\"); // className is now passed\n\n\n\n  /**\n   * Fired when selection is changed by user interaction.\n   */\n  ui5SelectionChange = output<UI5CustomEvent<_MediaGallery, 'selection-change'>>();\n\n  /**\n   * Fired when the thumbnails overflow button is clicked.\n   */\n  ui5OverflowClick = output<UI5CustomEvent<_MediaGallery, 'overflow-click'>>();\n\n  /**\n   * Fired when the display area is clicked.\nThe display area is the central area that contains\nthe enlarged content of the currently selected item.\n   */\n  ui5DisplayAreaClick = output<UI5CustomEvent<_MediaGallery, 'display-area-click'>>();\n\n  /**\n   * Available slots for content projection in this component.\n   * \n   * Slots allow you to insert custom content into predefined areas of the web component.\n   * Use the `slot` attribute on child elements to target specific slots.\n   * \n   * - **(default)**: Defines the component items.\n\n**Note:** Only one selected item is allowed.\n\n**Note:** Use the `ui5-media-gallery-item` component to define the desired items.\n   * \n   * @example\n   * ```html\n   * <ui5-media-gallery>\n   *   <div slot=\"header\">Custom header content</div>\n   *   <p>Default slot content</p>\n   * </ui5-media-gallery>\n   * ```\n   * \n   * @readonly\n   * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_templates_and_slots | MDN Web Components Slots}\n   */\n  readonly slots = [\n      {\n          \"name\": \"default\",\n          \"description\": \"Defines the component items.\\n\\n**Note:** Only one selected item is allowed.\\n\\n**Note:** Use the `ui5-media-gallery-item` component to define the desired items.\"\n      }\n  ];\n\n\n  public elementRef: ElementRef<_MediaGallery> = inject(ElementRef);\n  public injector = inject(Injector);\n\n  get element(): _MediaGallery {\n    return this.elementRef.nativeElement;\n  }\n\n  ngAfterViewInit(): void {\n    const wcElement = this.element;\n    \n    const inputsToSync = [\n      'showAllThumbnails',\n      'interactiveDisplayArea',\n      'layout',\n      'menuHorizontalAlign',\n      'menuVerticalAlign',\n    ];\n    \n    // Synchronize inputs (properties)\n    for (const inputName of inputsToSync) {\n      // Find the corresponding camelCase signal property on the Angular component\n      const signalName = inputName.replace(/-./g, (x: string) => x[1].toUpperCase());\n\n      // Use the Injector to run the effect in the correct context\n      if (this[signalName] && typeof this[signalName] === 'function') {\n        runInInjectionContext(this.injector, () => {\n          effect(() => {\n            // Read the signal value\n            const value = this[signalName]();\n            if (wcElement) {\n              // Write the value to the Web Component's property\n              wcElement[inputName] = value;\n            }\n          });\n        });\n      }\n    }\n  \n    \n    const outputsToSync = [\n      'ui5SelectionChange',\n      'ui5OverflowClick',\n      'ui5DisplayAreaClick',\n    ];\n    \n    // Synchronize outputs (events)\n    for (const outputName of outputsToSync) {\n      // Map Angular output name to UI5 web component event name\n      const eventName = outputName.replace('ui5', '').replace(/([A-Z])/g, '-$1').toLowerCase().substring(1);\n      // Ensure the output property exists and has an emit function before adding listener\n      if (this[outputName] && typeof this[outputName].emit === 'function' && wcElement.addEventListener) {\n        // Cast the listener to the correct type to satisfy TypeScript\n        wcElement.addEventListener(eventName, (e) => {\n\n          this[outputName].emit(e as CustomEvent<any>);\n        });\n      }\n    }\n  \n\n  }\n}\n\n"]}","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnVuZGFtZW50YWwtbmd4LXVpNS13ZWJjb21wb25lbnRzLWZpb3JpLW1lZGlhLWdhbGxlcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL3VpNS13ZWJjb21wb25lbnRzLWZpb3JpL21lZGlhLWdhbGxlcnkvZnVuZGFtZW50YWwtbmd4LXVpNS13ZWJjb21wb25lbnRzLWZpb3JpLW1lZGlhLWdhbGxlcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0="],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
import { input, inject, ElementRef, Injector, runInInjectionContext, effect, ChangeDetectionStrategy, Component } from '@angular/core';
|
|
3
|
+
import '@ui5/webcomponents-fiori/dist/NavigationLayout.js';
|
|
4
|
+
|
|
5
|
+
class NavigationLayout {
|
|
6
|
+
constructor() {
|
|
7
|
+
/**
|
|
8
|
+
* Specifies the navigation layout mode.
|
|
9
|
+
*/
|
|
10
|
+
this.mode = input("Auto", ...(ngDevMode ? [{ debugName: "mode" }] : [])); // className is now passed
|
|
11
|
+
/**
|
|
12
|
+
* Available slots for content projection in this component.
|
|
13
|
+
*
|
|
14
|
+
* Slots allow you to insert custom content into predefined areas of the web component.
|
|
15
|
+
* Use the `slot` attribute on child elements to target specific slots.
|
|
16
|
+
*
|
|
17
|
+
* - **header**: Defines the header.
|
|
18
|
+
* - **sideContent**: Defines the side content.
|
|
19
|
+
* - **(default)**: Defines the content.
|
|
20
|
+
*
|
|
21
|
+
* @example
|
|
22
|
+
* ```html
|
|
23
|
+
* <ui5-navigation-layout>
|
|
24
|
+
* <div slot="header">Custom header content</div>
|
|
25
|
+
* <p>Default slot content</p>
|
|
26
|
+
* </ui5-navigation-layout>
|
|
27
|
+
* ```
|
|
28
|
+
*
|
|
29
|
+
* @readonly
|
|
30
|
+
* @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_templates_and_slots | MDN Web Components Slots}
|
|
31
|
+
*/
|
|
32
|
+
this.slots = [
|
|
33
|
+
{
|
|
34
|
+
"name": "header",
|
|
35
|
+
"description": "Defines the header."
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
"name": "sideContent",
|
|
39
|
+
"description": "Defines the side content."
|
|
40
|
+
},
|
|
41
|
+
{
|
|
42
|
+
"name": "default",
|
|
43
|
+
"description": "Defines the content."
|
|
44
|
+
}
|
|
45
|
+
];
|
|
46
|
+
this.elementRef = inject(ElementRef);
|
|
47
|
+
this.injector = inject(Injector);
|
|
48
|
+
}
|
|
49
|
+
get element() {
|
|
50
|
+
return this.elementRef.nativeElement;
|
|
51
|
+
}
|
|
52
|
+
ngAfterViewInit() {
|
|
53
|
+
const wcElement = this.element;
|
|
54
|
+
const inputsToSync = [
|
|
55
|
+
'mode',
|
|
56
|
+
];
|
|
57
|
+
// Synchronize inputs (properties)
|
|
58
|
+
for (const inputName of inputsToSync) {
|
|
59
|
+
// Find the corresponding camelCase signal property on the Angular component
|
|
60
|
+
const signalName = inputName.replace(/-./g, (x) => x[1].toUpperCase());
|
|
61
|
+
// Use the Injector to run the effect in the correct context
|
|
62
|
+
if (this[signalName] && typeof this[signalName] === 'function') {
|
|
63
|
+
runInInjectionContext(this.injector, () => {
|
|
64
|
+
effect(() => {
|
|
65
|
+
// Read the signal value
|
|
66
|
+
const value = this[signalName]();
|
|
67
|
+
if (wcElement) {
|
|
68
|
+
// Write the value to the Web Component's property
|
|
69
|
+
wcElement[inputName] = value;
|
|
70
|
+
}
|
|
71
|
+
});
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.1.4", ngImport: i0, type: NavigationLayout, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
77
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "20.1.4", type: NavigationLayout, isStandalone: true, selector: "ui5-navigation-layout, [ui5-navigation-layout]", inputs: { mode: { classPropertyName: "mode", publicName: "mode", isSignal: true, isRequired: false, transformFunction: null } }, exportAs: ["ui5NavigationLayout"], ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
78
|
+
}
|
|
79
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.4", ngImport: i0, type: NavigationLayout, decorators: [{
|
|
80
|
+
type: Component,
|
|
81
|
+
args: [{
|
|
82
|
+
standalone: true,
|
|
83
|
+
selector: 'ui5-navigation-layout, [ui5-navigation-layout]',
|
|
84
|
+
template: '<ng-content></ng-content>',
|
|
85
|
+
exportAs: 'ui5NavigationLayout',
|
|
86
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
87
|
+
}]
|
|
88
|
+
}] });
|
|
89
|
+
|
|
90
|
+
/**
|
|
91
|
+
* Generated bundle index. Do not edit.
|
|
92
|
+
*/
|
|
93
|
+
|
|
94
|
+
export { NavigationLayout };
|
|
95
|
+
//# sourceMappingURL=fundamental-ngx-ui5-webcomponents-fiori-navigation-layout.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fundamental-ngx-ui5-webcomponents-fiori-navigation-layout.mjs","sources":["../tmp-esm2022/navigation-layout/index.js","../tmp-esm2022/navigation-layout/fundamental-ngx-ui5-webcomponents-fiori-navigation-layout.js"],"sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, input, effect, runInInjectionContext, inject, Injector } from '@angular/core';\nimport '@ui5/webcomponents-fiori/dist/NavigationLayout.js';\nimport * as i0 from \"@angular/core\";\nexport class NavigationLayout {\n constructor() {\n /**\n * Specifies the navigation layout mode.\n */\n this.mode = input(\"Auto\", ...(ngDevMode ? [{ debugName: \"mode\" }] : [])); // className is now passed\n /**\n * Available slots for content projection in this component.\n *\n * Slots allow you to insert custom content into predefined areas of the web component.\n * Use the `slot` attribute on child elements to target specific slots.\n *\n * - **header**: Defines the header.\n * - **sideContent**: Defines the side content.\n * - **(default)**: Defines the content.\n *\n * @example\n * ```html\n * <ui5-navigation-layout>\n * <div slot=\"header\">Custom header content</div>\n * <p>Default slot content</p>\n * </ui5-navigation-layout>\n * ```\n *\n * @readonly\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_templates_and_slots | MDN Web Components Slots}\n */\n this.slots = [\n {\n \"name\": \"header\",\n \"description\": \"Defines the header.\"\n },\n {\n \"name\": \"sideContent\",\n \"description\": \"Defines the side content.\"\n },\n {\n \"name\": \"default\",\n \"description\": \"Defines the content.\"\n }\n ];\n this.elementRef = inject(ElementRef);\n this.injector = inject(Injector);\n }\n get element() {\n return this.elementRef.nativeElement;\n }\n ngAfterViewInit() {\n const wcElement = this.element;\n const inputsToSync = [\n 'mode',\n ];\n // Synchronize inputs (properties)\n for (const inputName of inputsToSync) {\n // Find the corresponding camelCase signal property on the Angular component\n const signalName = inputName.replace(/-./g, (x) => x[1].toUpperCase());\n // Use the Injector to run the effect in the correct context\n if (this[signalName] && typeof this[signalName] === 'function') {\n runInInjectionContext(this.injector, () => {\n effect(() => {\n // Read the signal value\n const value = this[signalName]();\n if (wcElement) {\n // Write the value to the Web Component's property\n wcElement[inputName] = value;\n }\n });\n });\n }\n }\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.1.4\", ngImport: i0, type: NavigationLayout, deps: [], target: i0.ɵɵFactoryTarget.Component }); }\n static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: \"17.1.0\", version: \"20.1.4\", type: NavigationLayout, isStandalone: true, selector: \"ui5-navigation-layout, [ui5-navigation-layout]\", inputs: { mode: { classPropertyName: \"mode\", publicName: \"mode\", isSignal: true, isRequired: false, transformFunction: null } }, exportAs: [\"ui5NavigationLayout\"], ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.1.4\", ngImport: i0, type: NavigationLayout, decorators: [{\n type: Component,\n args: [{\n standalone: true,\n selector: 'ui5-navigation-layout, [ui5-navigation-layout]',\n template: '<ng-content></ng-content>',\n exportAs: 'ui5NavigationLayout',\n changeDetection: ChangeDetectionStrategy.OnPush,\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL3VpNS13ZWJjb21wb25lbnRzLWZpb3JpL25hdmlnYXRpb24tbGF5b3V0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFVBQVUsRUFDVixLQUFLLEVBR0wsTUFBTSxFQUNOLHFCQUFxQixFQUNyQixNQUFNLEVBQ04sUUFBUSxFQUlULE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sbURBQW1ELENBQUM7O0FBYzNELE1BQU0sT0FBTyxnQkFBZ0I7SUFSN0I7UUFVRTs7V0FFRztRQUNILFNBQUksR0FBRyxLQUFLLENBQXNELE1BQU0sZ0RBQUMsQ0FBQyxDQUFDLDBCQUEwQjtRQUtyRzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7V0FvQkc7UUFDTSxVQUFLLEdBQUc7WUFDYjtnQkFDSSxNQUFNLEVBQUUsUUFBUTtnQkFDaEIsYUFBYSxFQUFFLHFCQUFxQjthQUN2QztZQUNEO2dCQUNJLE1BQU0sRUFBRSxhQUFhO2dCQUNyQixhQUFhLEVBQUUsMkJBQTJCO2FBQzdDO1lBQ0Q7Z0JBQ0ksTUFBTSxFQUFFLFNBQVM7Z0JBQ2pCLGFBQWEsRUFBRSxzQkFBc0I7YUFDeEM7U0FDSixDQUFDO1FBR0ssZUFBVSxHQUFrQyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDL0QsYUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztLQXFDcEM7SUFuQ0MsSUFBSSxPQUFPO1FBQ1QsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQztJQUN2QyxDQUFDO0lBRUQsZUFBZTtRQUNiLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUM7UUFFL0IsTUFBTSxZQUFZLEdBQUc7WUFDbkIsTUFBTTtTQUNQLENBQUM7UUFFRixrQ0FBa0M7UUFDbEMsS0FBSyxNQUFNLFNBQVMsSUFBSSxZQUFZLEVBQUUsQ0FBQztZQUNyQyw0RUFBNEU7WUFDNUUsTUFBTSxVQUFVLEdBQUcsU0FBUyxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFTLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDO1lBRS9FLDREQUE0RDtZQUM1RCxJQUFJLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxVQUFVLEVBQUUsQ0FBQztnQkFDL0QscUJBQXFCLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxHQUFHLEVBQUU7b0JBQ3hDLE1BQU0sQ0FBQyxHQUFHLEVBQUU7d0JBQ1Ysd0JBQXdCO3dCQUN4QixNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLEVBQUUsQ0FBQzt3QkFDakMsSUFBSSxTQUFTLEVBQUUsQ0FBQzs0QkFDZCxrREFBa0Q7NEJBQ2xELFNBQVMsQ0FBQyxTQUFTLENBQUMsR0FBRyxLQUFLLENBQUM7d0JBQy9CLENBQUM7b0JBQ0gsQ0FBQyxDQUFDLENBQUM7Z0JBQ0wsQ0FBQyxDQUFDLENBQUM7WUFDTCxDQUFDO1FBQ0gsQ0FBQztJQUtILENBQUM7OEdBcEZVLGdCQUFnQjtrR0FBaEIsZ0JBQWdCLDhRQUxqQiwyQkFBMkI7OzJGQUsxQixnQkFBZ0I7a0JBUjVCLFNBQVM7bUJBQUM7b0JBQ1QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxnREFBZ0Q7b0JBQzFELFFBQVEsRUFBRSwyQkFBMkI7b0JBQ3JDLFFBQVEsRUFBRSxxQkFBcUI7b0JBRS9CLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2lCQUNoRCIsInNvdXJjZXNDb250ZW50IjpbIlxuaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgRWxlbWVudFJlZixcbiAgaW5wdXQsXG4gIG91dHB1dCxcbiAgQWZ0ZXJWaWV3SW5pdCxcbiAgZWZmZWN0LFxuICBydW5JbkluamVjdGlvbkNvbnRleHQsXG4gIGluamVjdCxcbiAgSW5qZWN0b3IsXG4gIGJvb2xlYW5BdHRyaWJ1dGUsXG4gIGNvbXB1dGVkLFxuICBzaWduYWxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgJ0B1aTUvd2ViY29tcG9uZW50cy1maW9yaS9kaXN0L05hdmlnYXRpb25MYXlvdXQuanMnO1xuaW1wb3J0IHsgZGVmYXVsdCBhcyBfTmF2aWdhdGlvbkxheW91dCB9IGZyb20gJ0B1aTUvd2ViY29tcG9uZW50cy1maW9yaS9kaXN0L05hdmlnYXRpb25MYXlvdXQuanMnO1xuaW1wb3J0IHsgVUk1Q3VzdG9tRXZlbnQgfSBmcm9tICdAdWk1L3dlYmNvbXBvbmVudHMtYmFzZSc7XG5cbmltcG9ydCB7IGRlZmF1bHQgYXMgTmF2aWdhdGlvbkxheW91dE1vZGUgfSBmcm9tICdAdWk1L3dlYmNvbXBvbmVudHMtZmlvcmkvZGlzdC90eXBlcy9OYXZpZ2F0aW9uTGF5b3V0TW9kZS5qcyc7XG5cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ3VpNS1uYXZpZ2F0aW9uLWxheW91dCwgW3VpNS1uYXZpZ2F0aW9uLWxheW91dF0nLFxuICB0ZW1wbGF0ZTogJzxuZy1jb250ZW50PjwvbmctY29udGVudD4nLFxuICBleHBvcnRBczogJ3VpNU5hdmlnYXRpb25MYXlvdXQnLFxuXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBOYXZpZ2F0aW9uTGF5b3V0IGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdCB7XG5cbiAgLyoqXG4gICAqIFNwZWNpZmllcyB0aGUgbmF2aWdhdGlvbiBsYXlvdXQgbW9kZS5cbiAgICovXG4gIG1vZGUgPSBpbnB1dDx0eXBlb2YgX05hdmlnYXRpb25MYXlvdXQucHJvdG90eXBlLm1vZGUgfCB1bmRlZmluZWQ+KFwiQXV0b1wiKTsgLy8gY2xhc3NOYW1lIGlzIG5vdyBwYXNzZWRcblxuXG5cblxuICAvKipcbiAgICogQXZhaWxhYmxlIHNsb3RzIGZvciBjb250ZW50IHByb2plY3Rpb24gaW4gdGhpcyBjb21wb25lbnQuXG4gICAqIFxuICAgKiBTbG90cyBhbGxvdyB5b3UgdG8gaW5zZXJ0IGN1c3RvbSBjb250ZW50IGludG8gcHJlZGVmaW5lZCBhcmVhcyBvZiB0aGUgd2ViIGNvbXBvbmVudC5cbiAgICogVXNlIHRoZSBgc2xvdGAgYXR0cmlidXRlIG9uIGNoaWxkIGVsZW1lbnRzIHRvIHRhcmdldCBzcGVjaWZpYyBzbG90cy5cbiAgICogXG4gICAqIC0gKipoZWFkZXIqKjogRGVmaW5lcyB0aGUgaGVhZGVyLlxuICAgKiAtICoqc2lkZUNvbnRlbnQqKjogRGVmaW5lcyB0aGUgc2lkZSBjb250ZW50LlxuICAgKiAtICoqKGRlZmF1bHQpKio6IERlZmluZXMgdGhlIGNvbnRlbnQuXG4gICAqIFxuICAgKiBAZXhhbXBsZVxuICAgKiBgYGBodG1sXG4gICAqIDx1aTUtbmF2aWdhdGlvbi1sYXlvdXQ+XG4gICAqICAgPGRpdiBzbG90PVwiaGVhZGVyXCI+Q3VzdG9tIGhlYWRlciBjb250ZW50PC9kaXY+XG4gICAqICAgPHA+RGVmYXVsdCBzbG90IGNvbnRlbnQ8L3A+XG4gICAqIDwvdWk1LW5hdmlnYXRpb24tbGF5b3V0PlxuICAgKiBgYGBcbiAgICogXG4gICAqIEByZWFkb25seVxuICAgKiBAc2VlIHtAbGluayBodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9BUEkvV2ViX2NvbXBvbmVudHMvVXNpbmdfdGVtcGxhdGVzX2FuZF9zbG90cyB8IE1ETiBXZWIgQ29tcG9uZW50cyBTbG90c31cbiAgICovXG4gIHJlYWRvbmx5IHNsb3RzID0gW1xuICAgICAge1xuICAgICAgICAgIFwibmFtZVwiOiBcImhlYWRlclwiLFxuICAgICAgICAgIFwiZGVzY3JpcHRpb25cIjogXCJEZWZpbmVzIHRoZSBoZWFkZXIuXCJcbiAgICAgIH0sXG4gICAgICB7XG4gICAgICAgICAgXCJuYW1lXCI6IFwic2lkZUNvbnRlbnRcIixcbiAgICAgICAgICBcImRlc2NyaXB0aW9uXCI6IFwiRGVmaW5lcyB0aGUgc2lkZSBjb250ZW50LlwiXG4gICAgICB9LFxuICAgICAge1xuICAgICAgICAgIFwibmFtZVwiOiBcImRlZmF1bHRcIixcbiAgICAgICAgICBcImRlc2NyaXB0aW9uXCI6IFwiRGVmaW5lcyB0aGUgY29udGVudC5cIlxuICAgICAgfVxuICBdO1xuXG5cbiAgcHVibGljIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWY8X05hdmlnYXRpb25MYXlvdXQ+ID0gaW5qZWN0KEVsZW1lbnRSZWYpO1xuICBwdWJsaWMgaW5qZWN0b3IgPSBpbmplY3QoSW5qZWN0b3IpO1xuXG4gIGdldCBlbGVtZW50KCk6IF9OYXZpZ2F0aW9uTGF5b3V0IHtcbiAgICByZXR1cm4gdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQ7XG4gIH1cblxuICBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XG4gICAgY29uc3Qgd2NFbGVtZW50ID0gdGhpcy5lbGVtZW50O1xuICAgIFxuICAgIGNvbnN0IGlucHV0c1RvU3luYyA9IFtcbiAgICAgICdtb2RlJyxcbiAgICBdO1xuICAgIFxuICAgIC8vIFN5bmNocm9uaXplIGlucHV0cyAocHJvcGVydGllcylcbiAgICBmb3IgKGNvbnN0IGlucHV0TmFtZSBvZiBpbnB1dHNUb1N5bmMpIHtcbiAgICAgIC8vIEZpbmQgdGhlIGNvcnJlc3BvbmRpbmcgY2FtZWxDYXNlIHNpZ25hbCBwcm9wZXJ0eSBvbiB0aGUgQW5ndWxhciBjb21wb25lbnRcbiAgICAgIGNvbnN0IHNpZ25hbE5hbWUgPSBpbnB1dE5hbWUucmVwbGFjZSgvLS4vZywgKHg6IHN0cmluZykgPT4geFsxXS50b1VwcGVyQ2FzZSgpKTtcblxuICAgICAgLy8gVXNlIHRoZSBJbmplY3RvciB0byBydW4gdGhlIGVmZmVjdCBpbiB0aGUgY29ycmVjdCBjb250ZXh0XG4gICAgICBpZiAodGhpc1tzaWduYWxOYW1lXSAmJiB0eXBlb2YgdGhpc1tzaWduYWxOYW1lXSA9PT0gJ2Z1bmN0aW9uJykge1xuICAgICAgICBydW5JbkluamVjdGlvbkNvbnRleHQodGhpcy5pbmplY3RvciwgKCkgPT4ge1xuICAgICAgICAgIGVmZmVjdCgoKSA9PiB7XG4gICAgICAgICAgICAvLyBSZWFkIHRoZSBzaWduYWwgdmFsdWVcbiAgICAgICAgICAgIGNvbnN0IHZhbHVlID0gdGhpc1tzaWduYWxOYW1lXSgpO1xuICAgICAgICAgICAgaWYgKHdjRWxlbWVudCkge1xuICAgICAgICAgICAgICAvLyBXcml0ZSB0aGUgdmFsdWUgdG8gdGhlIFdlYiBDb21wb25lbnQncyBwcm9wZXJ0eVxuICAgICAgICAgICAgICB3Y0VsZW1lbnRbaW5wdXROYW1lXSA9IHZhbHVlO1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH0pO1xuICAgICAgICB9KTtcbiAgICAgIH1cbiAgICB9XG4gIFxuICAgIFxuICAgIFxuXG4gIH1cbn1cblxuIl19","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnVuZGFtZW50YWwtbmd4LXVpNS13ZWJjb21wb25lbnRzLWZpb3JpLW5hdmlnYXRpb24tbGF5b3V0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy91aTUtd2ViY29tcG9uZW50cy1maW9yaS9uYXZpZ2F0aW9uLWxheW91dC9mdW5kYW1lbnRhbC1uZ3gtdWk1LXdlYmNvbXBvbmVudHMtZmlvcmktbmF2aWdhdGlvbi1sYXlvdXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0="],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
import { input, booleanAttribute, output, inject, ElementRef, Injector, runInInjectionContext, effect, ChangeDetectionStrategy, Component } from '@angular/core';
|
|
3
|
+
import '@ui5/webcomponents-fiori/dist/NotificationListGroupItem.js';
|
|
4
|
+
|
|
5
|
+
class NotificationListGroupItem {
|
|
6
|
+
constructor() {
|
|
7
|
+
/**
|
|
8
|
+
* Defines if the group is collapsed or expanded.
|
|
9
|
+
*/
|
|
10
|
+
this.collapsed = input(false, ...(ngDevMode ? [{ debugName: "collapsed", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));
|
|
11
|
+
/**
|
|
12
|
+
* Defines whether the component will have growing capability by pressing a `More` button.
|
|
13
|
+
When button is pressed `load-more` event will be fired.
|
|
14
|
+
*/
|
|
15
|
+
this.growing = input("None", ...(ngDevMode ? [{ debugName: "growing" }] : []));
|
|
16
|
+
/**
|
|
17
|
+
* Defines the `titleText` of the item.
|
|
18
|
+
*/
|
|
19
|
+
this.titleText = input(...(ngDevMode ? [undefined, { debugName: "titleText" }] : []));
|
|
20
|
+
/**
|
|
21
|
+
* Defines if the `notification` is new or has been already read.
|
|
22
|
+
|
|
23
|
+
**Note:** if set to `false` the `titleText` has bold font,
|
|
24
|
+
if set to true - it has a normal font.
|
|
25
|
+
*/
|
|
26
|
+
this.read = input(false, ...(ngDevMode ? [{ debugName: "read", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));
|
|
27
|
+
/**
|
|
28
|
+
* Defines if a busy indicator would be displayed over the item.
|
|
29
|
+
*/
|
|
30
|
+
this.loading = input(false, ...(ngDevMode ? [{ debugName: "loading", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));
|
|
31
|
+
/**
|
|
32
|
+
* Defines the delay in milliseconds, after which the busy indicator will show up for this component.
|
|
33
|
+
*/
|
|
34
|
+
this.loadingDelay = input(1000, ...(ngDevMode ? [{ debugName: "loadingDelay" }] : [])); // className is now passed
|
|
35
|
+
/**
|
|
36
|
+
* Fired when the `ui5-li-notification-group` is expanded/collapsed by user interaction.
|
|
37
|
+
*/
|
|
38
|
+
this.ui5Toggle = output();
|
|
39
|
+
/**
|
|
40
|
+
* Fired when additional items are requested.
|
|
41
|
+
*/
|
|
42
|
+
this.ui5LoadMore = output();
|
|
43
|
+
/**
|
|
44
|
+
* Available slots for content projection in this component.
|
|
45
|
+
*
|
|
46
|
+
* Slots allow you to insert custom content into predefined areas of the web component.
|
|
47
|
+
* Use the `slot` attribute on child elements to target specific slots.
|
|
48
|
+
*
|
|
49
|
+
* - **(default)**: Defines the items of the `ui5-li-notification-group`,
|
|
50
|
+
usually `ui5-li-notification` items.
|
|
51
|
+
*
|
|
52
|
+
* @example
|
|
53
|
+
* ```html
|
|
54
|
+
* <ui5-li-notification-group>
|
|
55
|
+
* <div slot="header">Custom header content</div>
|
|
56
|
+
* <p>Default slot content</p>
|
|
57
|
+
* </ui5-li-notification-group>
|
|
58
|
+
* ```
|
|
59
|
+
*
|
|
60
|
+
* @readonly
|
|
61
|
+
* @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_templates_and_slots | MDN Web Components Slots}
|
|
62
|
+
*/
|
|
63
|
+
this.slots = [
|
|
64
|
+
{
|
|
65
|
+
"name": "default",
|
|
66
|
+
"description": "Defines the items of the `ui5-li-notification-group`,\nusually `ui5-li-notification` items."
|
|
67
|
+
}
|
|
68
|
+
];
|
|
69
|
+
this.elementRef = inject(ElementRef);
|
|
70
|
+
this.injector = inject(Injector);
|
|
71
|
+
}
|
|
72
|
+
get element() {
|
|
73
|
+
return this.elementRef.nativeElement;
|
|
74
|
+
}
|
|
75
|
+
ngAfterViewInit() {
|
|
76
|
+
const wcElement = this.element;
|
|
77
|
+
const inputsToSync = [
|
|
78
|
+
'collapsed',
|
|
79
|
+
'growing',
|
|
80
|
+
'titleText',
|
|
81
|
+
'read',
|
|
82
|
+
'loading',
|
|
83
|
+
'loadingDelay',
|
|
84
|
+
];
|
|
85
|
+
// Synchronize inputs (properties)
|
|
86
|
+
for (const inputName of inputsToSync) {
|
|
87
|
+
// Find the corresponding camelCase signal property on the Angular component
|
|
88
|
+
const signalName = inputName.replace(/-./g, (x) => x[1].toUpperCase());
|
|
89
|
+
// Use the Injector to run the effect in the correct context
|
|
90
|
+
if (this[signalName] && typeof this[signalName] === 'function') {
|
|
91
|
+
runInInjectionContext(this.injector, () => {
|
|
92
|
+
effect(() => {
|
|
93
|
+
// Read the signal value
|
|
94
|
+
const value = this[signalName]();
|
|
95
|
+
if (wcElement) {
|
|
96
|
+
// Write the value to the Web Component's property
|
|
97
|
+
wcElement[inputName] = value;
|
|
98
|
+
}
|
|
99
|
+
});
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
const outputsToSync = [
|
|
104
|
+
'ui5Toggle',
|
|
105
|
+
'ui5LoadMore',
|
|
106
|
+
];
|
|
107
|
+
// Synchronize outputs (events)
|
|
108
|
+
for (const outputName of outputsToSync) {
|
|
109
|
+
// Map Angular output name to UI5 web component event name
|
|
110
|
+
const eventName = outputName.replace('ui5', '').replace(/([A-Z])/g, '-$1').toLowerCase().substring(1);
|
|
111
|
+
// Ensure the output property exists and has an emit function before adding listener
|
|
112
|
+
if (this[outputName] && typeof this[outputName].emit === 'function' && wcElement.addEventListener) {
|
|
113
|
+
// Cast the listener to the correct type to satisfy TypeScript
|
|
114
|
+
wcElement.addEventListener(eventName, (e) => {
|
|
115
|
+
this[outputName].emit(e);
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.1.4", ngImport: i0, type: NotificationListGroupItem, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
121
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "20.1.4", type: NotificationListGroupItem, isStandalone: true, selector: "ui5-li-notification-group, [ui5-li-notification-group]", inputs: { collapsed: { classPropertyName: "collapsed", publicName: "collapsed", isSignal: true, isRequired: false, transformFunction: null }, growing: { classPropertyName: "growing", publicName: "growing", isSignal: true, isRequired: false, transformFunction: null }, titleText: { classPropertyName: "titleText", publicName: "titleText", isSignal: true, isRequired: false, transformFunction: null }, read: { classPropertyName: "read", publicName: "read", isSignal: true, isRequired: false, transformFunction: null }, loading: { classPropertyName: "loading", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, loadingDelay: { classPropertyName: "loadingDelay", publicName: "loadingDelay", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { ui5Toggle: "ui5Toggle", ui5LoadMore: "ui5LoadMore" }, exportAs: ["ui5NotificationListGroupItem"], ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
122
|
+
}
|
|
123
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.4", ngImport: i0, type: NotificationListGroupItem, decorators: [{
|
|
124
|
+
type: Component,
|
|
125
|
+
args: [{
|
|
126
|
+
standalone: true,
|
|
127
|
+
selector: 'ui5-li-notification-group, [ui5-li-notification-group]',
|
|
128
|
+
template: '<ng-content></ng-content>',
|
|
129
|
+
exportAs: 'ui5NotificationListGroupItem',
|
|
130
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
131
|
+
}]
|
|
132
|
+
}] });
|
|
133
|
+
|
|
134
|
+
/**
|
|
135
|
+
* Generated bundle index. Do not edit.
|
|
136
|
+
*/
|
|
137
|
+
|
|
138
|
+
export { NotificationListGroupItem };
|
|
139
|
+
//# sourceMappingURL=fundamental-ngx-ui5-webcomponents-fiori-notification-list-group-item.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fundamental-ngx-ui5-webcomponents-fiori-notification-list-group-item.mjs","sources":["../tmp-esm2022/notification-list-group-item/index.js","../tmp-esm2022/notification-list-group-item/fundamental-ngx-ui5-webcomponents-fiori-notification-list-group-item.js"],"sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, input, output, effect, runInInjectionContext, inject, Injector, booleanAttribute } from '@angular/core';\nimport '@ui5/webcomponents-fiori/dist/NotificationListGroupItem.js';\nimport * as i0 from \"@angular/core\";\nexport class NotificationListGroupItem {\n constructor() {\n /**\n * Defines if the group is collapsed or expanded.\n */\n this.collapsed = input(false, ...(ngDevMode ? [{ debugName: \"collapsed\", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));\n /**\n * Defines whether the component will have growing capability by pressing a `More` button.\n When button is pressed `load-more` event will be fired.\n */\n this.growing = input(\"None\", ...(ngDevMode ? [{ debugName: \"growing\" }] : []));\n /**\n * Defines the `titleText` of the item.\n */\n this.titleText = input(...(ngDevMode ? [undefined, { debugName: \"titleText\" }] : []));\n /**\n * Defines if the `notification` is new or has been already read.\n \n **Note:** if set to `false` the `titleText` has bold font,\n if set to true - it has a normal font.\n */\n this.read = input(false, ...(ngDevMode ? [{ debugName: \"read\", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));\n /**\n * Defines if a busy indicator would be displayed over the item.\n */\n this.loading = input(false, ...(ngDevMode ? [{ debugName: \"loading\", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));\n /**\n * Defines the delay in milliseconds, after which the busy indicator will show up for this component.\n */\n this.loadingDelay = input(1000, ...(ngDevMode ? [{ debugName: \"loadingDelay\" }] : [])); // className is now passed\n /**\n * Fired when the `ui5-li-notification-group` is expanded/collapsed by user interaction.\n */\n this.ui5Toggle = output();\n /**\n * Fired when additional items are requested.\n */\n this.ui5LoadMore = output();\n /**\n * Available slots for content projection in this component.\n *\n * Slots allow you to insert custom content into predefined areas of the web component.\n * Use the `slot` attribute on child elements to target specific slots.\n *\n * - **(default)**: Defines the items of the `ui5-li-notification-group`,\n usually `ui5-li-notification` items.\n *\n * @example\n * ```html\n * <ui5-li-notification-group>\n * <div slot=\"header\">Custom header content</div>\n * <p>Default slot content</p>\n * </ui5-li-notification-group>\n * ```\n *\n * @readonly\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_templates_and_slots | MDN Web Components Slots}\n */\n this.slots = [\n {\n \"name\": \"default\",\n \"description\": \"Defines the items of the `ui5-li-notification-group`,\\nusually `ui5-li-notification` items.\"\n }\n ];\n this.elementRef = inject(ElementRef);\n this.injector = inject(Injector);\n }\n get element() {\n return this.elementRef.nativeElement;\n }\n ngAfterViewInit() {\n const wcElement = this.element;\n const inputsToSync = [\n 'collapsed',\n 'growing',\n 'titleText',\n 'read',\n 'loading',\n 'loadingDelay',\n ];\n // Synchronize inputs (properties)\n for (const inputName of inputsToSync) {\n // Find the corresponding camelCase signal property on the Angular component\n const signalName = inputName.replace(/-./g, (x) => x[1].toUpperCase());\n // Use the Injector to run the effect in the correct context\n if (this[signalName] && typeof this[signalName] === 'function') {\n runInInjectionContext(this.injector, () => {\n effect(() => {\n // Read the signal value\n const value = this[signalName]();\n if (wcElement) {\n // Write the value to the Web Component's property\n wcElement[inputName] = value;\n }\n });\n });\n }\n }\n const outputsToSync = [\n 'ui5Toggle',\n 'ui5LoadMore',\n ];\n // Synchronize outputs (events)\n for (const outputName of outputsToSync) {\n // Map Angular output name to UI5 web component event name\n const eventName = outputName.replace('ui5', '').replace(/([A-Z])/g, '-$1').toLowerCase().substring(1);\n // Ensure the output property exists and has an emit function before adding listener\n if (this[outputName] && typeof this[outputName].emit === 'function' && wcElement.addEventListener) {\n // Cast the listener to the correct type to satisfy TypeScript\n wcElement.addEventListener(eventName, (e) => {\n this[outputName].emit(e);\n });\n }\n }\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.1.4\", ngImport: i0, type: NotificationListGroupItem, deps: [], target: i0.ɵɵFactoryTarget.Component }); }\n static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: \"17.1.0\", version: \"20.1.4\", type: NotificationListGroupItem, isStandalone: true, selector: \"ui5-li-notification-group, [ui5-li-notification-group]\", inputs: { collapsed: { classPropertyName: \"collapsed\", publicName: \"collapsed\", isSignal: true, isRequired: false, transformFunction: null }, growing: { classPropertyName: \"growing\", publicName: \"growing\", isSignal: true, isRequired: false, transformFunction: null }, titleText: { classPropertyName: \"titleText\", publicName: \"titleText\", isSignal: true, isRequired: false, transformFunction: null }, read: { classPropertyName: \"read\", publicName: \"read\", isSignal: true, isRequired: false, transformFunction: null }, loading: { classPropertyName: \"loading\", publicName: \"loading\", isSignal: true, isRequired: false, transformFunction: null }, loadingDelay: { classPropertyName: \"loadingDelay\", publicName: \"loadingDelay\", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { ui5Toggle: \"ui5Toggle\", ui5LoadMore: \"ui5LoadMore\" }, exportAs: [\"ui5NotificationListGroupItem\"], ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.1.4\", ngImport: i0, type: NotificationListGroupItem, decorators: [{\n type: Component,\n args: [{\n standalone: true,\n selector: 'ui5-li-notification-group, [ui5-li-notification-group]',\n template: '<ng-content></ng-content>',\n exportAs: 'ui5NotificationListGroupItem',\n changeDetection: ChangeDetectionStrategy.OnPush,\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../libs/ui5-webcomponents-fiori/notification-list-group-item/index.ts"],"names":[],"mappings":"AACA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,UAAU,EACV,KAAK,EACL,MAAM,EAEN,MAAM,EACN,qBAAqB,EACrB,MAAM,EACN,QAAQ,EACR,gBAAgB,EAGjB,MAAM,eAAe,CAAC;AACvB,OAAO,4DAA4D,CAAC;;AAcpE,MAAM,OAAO,yBAAyB;IARtC;QAUE;;WAEG;QACH,cAAS,GAAG,KAAK,CAAC,KAAK,6CAAI,SAAS,EAAE,gBAAgB,OAA7B,EAAE,SAAS,EAAE,gBAAgB,EAAE,GAAC,CAAC;QAE1D;;;WAGG;QACH,YAAO,GAAG,KAAK,CAAkE,MAAM,mDAAC,CAAC;QAEzF;;WAEG;QACH,cAAS,GAAG,KAAK,+DAAqE,CAAC;QAEvF;;;;;WAKG;QACH,SAAI,GAAG,KAAK,CAAC,KAAK,wCAAI,SAAS,EAAE,gBAAgB,OAA7B,EAAE,SAAS,EAAE,gBAAgB,EAAE,GAAC,CAAC;QAErD;;WAEG;QACH,YAAO,GAAG,KAAK,CAAC,KAAK,2CAAI,SAAS,EAAE,gBAAgB,OAA7B,EAAE,SAAS,EAAE,gBAAgB,EAAE,GAAC,CAAC;QAExD;;WAEG;QACH,iBAAY,GAAG,KAAK,CAAuE,IAAI,wDAAC,CAAC,CAAC,0BAA0B;QAI5H;;WAEG;QACH,cAAS,GAAG,MAAM,EAAwD,CAAC;QAE3E;;WAEG;QACH,gBAAW,GAAG,MAAM,EAA2D,CAAC;QAEhF;;;;;;;;;;;;;;;;;;;WAmBG;QACM,UAAK,GAAG;YACb;gBACI,MAAM,EAAE,SAAS;gBACjB,aAAa,EAAE,6FAA6F;aAC/G;SACJ,CAAC;QAGK,eAAU,GAA2C,MAAM,CAAC,UAAU,CAAC,CAAC;QACxE,aAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;KA4DpC;IA1DC,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;IACvC,CAAC;IAED,eAAe;QACb,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC;QAE/B,MAAM,YAAY,GAAG;YACnB,WAAW;YACX,SAAS;YACT,WAAW;YACX,MAAM;YACN,SAAS;YACT,cAAc;SACf,CAAC;QAEF,kCAAkC;QAClC,KAAK,MAAM,SAAS,IAAI,YAAY,EAAE,CAAC;YACrC,4EAA4E;YAC5E,MAAM,UAAU,GAAG,SAAS,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;YAE/E,4DAA4D;YAC5D,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,UAAU,EAAE,CAAC;gBAC/D,qBAAqB,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,EAAE;oBACxC,MAAM,CAAC,GAAG,EAAE;wBACV,wBAAwB;wBACxB,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;wBACjC,IAAI,SAAS,EAAE,CAAC;4BACd,kDAAkD;4BAClD,SAAS,CAAC,SAAS,CAAC,GAAG,KAAK,CAAC;wBAC/B,CAAC;oBACH,CAAC,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;YACL,CAAC;QACH,CAAC;QAGD,MAAM,aAAa,GAAG;YACpB,WAAW;YACX,aAAa;SACd,CAAC;QAEF,+BAA+B;QAC/B,KAAK,MAAM,UAAU,IAAI,aAAa,EAAE,CAAC;YACvC,0DAA0D;YAC1D,MAAM,SAAS,GAAG,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;YACtG,oFAAoF;YACpF,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,OAAO,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,KAAK,UAAU,IAAI,SAAS,CAAC,gBAAgB,EAAE,CAAC;gBAClG,8DAA8D;gBAC9D,SAAS,CAAC,gBAAgB,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE;oBAE1C,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAqB,CAAC,CAAC;gBAC/C,CAAC,CAAC,CAAC;YACL,CAAC;QACH,CAAC;IAGH,CAAC;8GAxIU,yBAAyB;kGAAzB,yBAAyB,i/BAL1B,2BAA2B;;2FAK1B,yBAAyB;kBARrC,SAAS;mBAAC;oBACT,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,wDAAwD;oBAClE,QAAQ,EAAE,2BAA2B;oBACrC,QAAQ,EAAE,8BAA8B;oBAExC,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD","sourcesContent":["\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  input,\n  output,\n  AfterViewInit,\n  effect,\n  runInInjectionContext,\n  inject,\n  Injector,\n  booleanAttribute,\n  computed,\n  signal\n} from '@angular/core';\nimport '@ui5/webcomponents-fiori/dist/NotificationListGroupItem.js';\nimport { default as _NotificationListGroupItem } from '@ui5/webcomponents-fiori/dist/NotificationListGroupItem.js';\nimport { UI5CustomEvent } from '@ui5/webcomponents-base';\n\nimport { default as NotificationListGrowingMode } from '@ui5/webcomponents/dist/types/NotificationListGrowingMode.js';\n\n@Component({\n  standalone: true,\n  selector: 'ui5-li-notification-group, [ui5-li-notification-group]',\n  template: '<ng-content></ng-content>',\n  exportAs: 'ui5NotificationListGroupItem',\n\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NotificationListGroupItem implements AfterViewInit {\n\n  /**\n   * Defines if the group is collapsed or expanded.\n   */\n  collapsed = input(false, { transform: booleanAttribute });\n\n  /**\n   * Defines whether the component will have growing capability by pressing a `More` button.\nWhen button is pressed `load-more` event will be fired.\n   */\n  growing = input<typeof _NotificationListGroupItem.prototype.growing | undefined>(\"None\");\n\n  /**\n   * Defines the `titleText` of the item.\n   */\n  titleText = input<typeof _NotificationListGroupItem.prototype.titleText | undefined>();\n\n  /**\n   * Defines if the `notification` is new or has been already read.\n\n**Note:** if set to `false` the `titleText` has bold font,\nif set to true - it has a normal font.\n   */\n  read = input(false, { transform: booleanAttribute });\n\n  /**\n   * Defines if a busy indicator would be displayed over the item.\n   */\n  loading = input(false, { transform: booleanAttribute });\n\n  /**\n   * Defines the delay in milliseconds, after which the busy indicator will show up for this component.\n   */\n  loadingDelay = input<typeof _NotificationListGroupItem.prototype.loadingDelay | undefined>(1000); // className is now passed\n\n\n\n  /**\n   * Fired when the `ui5-li-notification-group` is expanded/collapsed by user interaction.\n   */\n  ui5Toggle = output<UI5CustomEvent<_NotificationListGroupItem, 'toggle'>>();\n\n  /**\n   * Fired when additional items are requested.\n   */\n  ui5LoadMore = output<UI5CustomEvent<_NotificationListGroupItem, 'load-more'>>();\n\n  /**\n   * Available slots for content projection in this component.\n   * \n   * Slots allow you to insert custom content into predefined areas of the web component.\n   * Use the `slot` attribute on child elements to target specific slots.\n   * \n   * - **(default)**: Defines the items of the `ui5-li-notification-group`,\nusually `ui5-li-notification` items.\n   * \n   * @example\n   * ```html\n   * <ui5-li-notification-group>\n   *   <div slot=\"header\">Custom header content</div>\n   *   <p>Default slot content</p>\n   * </ui5-li-notification-group>\n   * ```\n   * \n   * @readonly\n   * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_templates_and_slots | MDN Web Components Slots}\n   */\n  readonly slots = [\n      {\n          \"name\": \"default\",\n          \"description\": \"Defines the items of the `ui5-li-notification-group`,\\nusually `ui5-li-notification` items.\"\n      }\n  ];\n\n\n  public elementRef: ElementRef<_NotificationListGroupItem> = inject(ElementRef);\n  public injector = inject(Injector);\n\n  get element(): _NotificationListGroupItem {\n    return this.elementRef.nativeElement;\n  }\n\n  ngAfterViewInit(): void {\n    const wcElement = this.element;\n    \n    const inputsToSync = [\n      'collapsed',\n      'growing',\n      'titleText',\n      'read',\n      'loading',\n      'loadingDelay',\n    ];\n    \n    // Synchronize inputs (properties)\n    for (const inputName of inputsToSync) {\n      // Find the corresponding camelCase signal property on the Angular component\n      const signalName = inputName.replace(/-./g, (x: string) => x[1].toUpperCase());\n\n      // Use the Injector to run the effect in the correct context\n      if (this[signalName] && typeof this[signalName] === 'function') {\n        runInInjectionContext(this.injector, () => {\n          effect(() => {\n            // Read the signal value\n            const value = this[signalName]();\n            if (wcElement) {\n              // Write the value to the Web Component's property\n              wcElement[inputName] = value;\n            }\n          });\n        });\n      }\n    }\n  \n    \n    const outputsToSync = [\n      'ui5Toggle',\n      'ui5LoadMore',\n    ];\n    \n    // Synchronize outputs (events)\n    for (const outputName of outputsToSync) {\n      // Map Angular output name to UI5 web component event name\n      const eventName = outputName.replace('ui5', '').replace(/([A-Z])/g, '-$1').toLowerCase().substring(1);\n      // Ensure the output property exists and has an emit function before adding listener\n      if (this[outputName] && typeof this[outputName].emit === 'function' && wcElement.addEventListener) {\n        // Cast the listener to the correct type to satisfy TypeScript\n        wcElement.addEventListener(eventName, (e) => {\n\n          this[outputName].emit(e as CustomEvent<any>);\n        });\n      }\n    }\n  \n\n  }\n}\n\n"]}","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnVuZGFtZW50YWwtbmd4LXVpNS13ZWJjb21wb25lbnRzLWZpb3JpLW5vdGlmaWNhdGlvbi1saXN0LWdyb3VwLWl0ZW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL3VpNS13ZWJjb21wb25lbnRzLWZpb3JpL25vdGlmaWNhdGlvbi1saXN0LWdyb3VwLWl0ZW0vZnVuZGFtZW50YWwtbmd4LXVpNS13ZWJjb21wb25lbnRzLWZpb3JpLW5vdGlmaWNhdGlvbi1saXN0LWdyb3VwLWl0ZW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0="],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,174 @@
|
|
|
1
|
+
import * as i0 from '@angular/core';
|
|
2
|
+
import { input, booleanAttribute, output, inject, ElementRef, Injector, runInInjectionContext, effect, ChangeDetectionStrategy, Component } from '@angular/core';
|
|
3
|
+
import '@ui5/webcomponents-fiori/dist/NotificationListItem.js';
|
|
4
|
+
|
|
5
|
+
class NotificationListItem {
|
|
6
|
+
constructor() {
|
|
7
|
+
/**
|
|
8
|
+
* Defines if the `titleText` and `description` should wrap,
|
|
9
|
+
they truncate by default.
|
|
10
|
+
|
|
11
|
+
**Note:** by default the `titleText` and `description`,
|
|
12
|
+
and a `ShowMore/Less` button would be displayed.
|
|
13
|
+
*/
|
|
14
|
+
this.wrappingType = input("None", ...(ngDevMode ? [{ debugName: "wrappingType" }] : []));
|
|
15
|
+
/**
|
|
16
|
+
* Defines the status indicator of the item.
|
|
17
|
+
*/
|
|
18
|
+
this.state = input("None", ...(ngDevMode ? [{ debugName: "state" }] : []));
|
|
19
|
+
/**
|
|
20
|
+
* Defines if the `Close` button would be displayed.
|
|
21
|
+
*/
|
|
22
|
+
this.showClose = input(false, ...(ngDevMode ? [{ debugName: "showClose", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));
|
|
23
|
+
/**
|
|
24
|
+
* Defines the `Important` label of the item.
|
|
25
|
+
*/
|
|
26
|
+
this.importance = input("Standard", ...(ngDevMode ? [{ debugName: "importance" }] : []));
|
|
27
|
+
/**
|
|
28
|
+
* Defines the `titleText` of the item.
|
|
29
|
+
*/
|
|
30
|
+
this.titleText = input(...(ngDevMode ? [undefined, { debugName: "titleText" }] : []));
|
|
31
|
+
/**
|
|
32
|
+
* Defines if the `notification` is new or has been already read.
|
|
33
|
+
|
|
34
|
+
**Note:** if set to `false` the `titleText` has bold font,
|
|
35
|
+
if set to true - it has a normal font.
|
|
36
|
+
*/
|
|
37
|
+
this.read = input(false, ...(ngDevMode ? [{ debugName: "read", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));
|
|
38
|
+
/**
|
|
39
|
+
* Defines if a busy indicator would be displayed over the item.
|
|
40
|
+
*/
|
|
41
|
+
this.loading = input(false, ...(ngDevMode ? [{ debugName: "loading", transform: booleanAttribute }] : [{ transform: booleanAttribute }]));
|
|
42
|
+
/**
|
|
43
|
+
* Defines the delay in milliseconds, after which the busy indicator will show up for this component.
|
|
44
|
+
*/
|
|
45
|
+
this.loadingDelay = input(1000, ...(ngDevMode ? [{ debugName: "loadingDelay" }] : [])); // className is now passed
|
|
46
|
+
/**
|
|
47
|
+
* Fired when the `Close` button is pressed.
|
|
48
|
+
*/
|
|
49
|
+
this.ui5Close = output();
|
|
50
|
+
/**
|
|
51
|
+
* Available slots for content projection in this component.
|
|
52
|
+
*
|
|
53
|
+
* Slots allow you to insert custom content into predefined areas of the web component.
|
|
54
|
+
* Use the `slot` attribute on child elements to target specific slots.
|
|
55
|
+
*
|
|
56
|
+
* - **avatar**: Defines the avatar, displayed in the `ui5-li-notification`.
|
|
57
|
+
|
|
58
|
+
**Note:** Consider using the `ui5-avatar` to display icons, initials or images.
|
|
59
|
+
|
|
60
|
+
**Note:** In order to be complaint with the UX guidlines and for best experience,
|
|
61
|
+
we recommend using avatars with 2rem X 2rem in size (32px X 32px). In case you are using the `ui5-avatar`
|
|
62
|
+
you can set its `size` property to `XS` to get the required size - `<ui5-avatar size="XS"></ui5-avatar>`.
|
|
63
|
+
* - **menu**: Defines the menu, displayed in the `ui5-li-notification`.
|
|
64
|
+
|
|
65
|
+
**Note:** Use this for implementing actions.
|
|
66
|
+
|
|
67
|
+
**Note:** Should be used instead `u5-notification-action`, which is deprecated as of version 2.0.
|
|
68
|
+
* - **footnotes**: Defines the elements, displayed in the footer of the of the component.
|
|
69
|
+
* - **(default)**: Defines the content of the `ui5-li-notification`,
|
|
70
|
+
usually a description of the notification.
|
|
71
|
+
|
|
72
|
+
**Note:** Although this slot accepts HTML Elements, it is strongly recommended that you only use text in order to preserve the intended design.
|
|
73
|
+
*
|
|
74
|
+
* @example
|
|
75
|
+
* ```html
|
|
76
|
+
* <ui5-li-notification>
|
|
77
|
+
* <div slot="header">Custom header content</div>
|
|
78
|
+
* <p>Default slot content</p>
|
|
79
|
+
* </ui5-li-notification>
|
|
80
|
+
* ```
|
|
81
|
+
*
|
|
82
|
+
* @readonly
|
|
83
|
+
* @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Web_components/Using_templates_and_slots | MDN Web Components Slots}
|
|
84
|
+
*/
|
|
85
|
+
this.slots = [
|
|
86
|
+
{
|
|
87
|
+
"name": "avatar",
|
|
88
|
+
"description": "Defines the avatar, displayed in the `ui5-li-notification`.\n\n**Note:** Consider using the `ui5-avatar` to display icons, initials or images.\n\n**Note:** In order to be complaint with the UX guidlines and for best experience,\nwe recommend using avatars with 2rem X 2rem in size (32px X 32px). In case you are using the `ui5-avatar`\nyou can set its `size` property to `XS` to get the required size - `<ui5-avatar size=\"XS\"></ui5-avatar>`."
|
|
89
|
+
},
|
|
90
|
+
{
|
|
91
|
+
"name": "menu",
|
|
92
|
+
"description": "Defines the menu, displayed in the `ui5-li-notification`.\n\n**Note:** Use this for implementing actions.\n\n**Note:** Should be used instead `u5-notification-action`, which is deprecated as of version 2.0."
|
|
93
|
+
},
|
|
94
|
+
{
|
|
95
|
+
"name": "footnotes",
|
|
96
|
+
"description": "Defines the elements, displayed in the footer of the of the component."
|
|
97
|
+
},
|
|
98
|
+
{
|
|
99
|
+
"name": "default",
|
|
100
|
+
"description": "Defines the content of the `ui5-li-notification`,\nusually a description of the notification.\n\n**Note:** Although this slot accepts HTML Elements, it is strongly recommended that you only use text in order to preserve the intended design."
|
|
101
|
+
}
|
|
102
|
+
];
|
|
103
|
+
this.elementRef = inject(ElementRef);
|
|
104
|
+
this.injector = inject(Injector);
|
|
105
|
+
}
|
|
106
|
+
get element() {
|
|
107
|
+
return this.elementRef.nativeElement;
|
|
108
|
+
}
|
|
109
|
+
ngAfterViewInit() {
|
|
110
|
+
const wcElement = this.element;
|
|
111
|
+
const inputsToSync = [
|
|
112
|
+
'wrappingType',
|
|
113
|
+
'state',
|
|
114
|
+
'showClose',
|
|
115
|
+
'importance',
|
|
116
|
+
'titleText',
|
|
117
|
+
'read',
|
|
118
|
+
'loading',
|
|
119
|
+
'loadingDelay',
|
|
120
|
+
];
|
|
121
|
+
// Synchronize inputs (properties)
|
|
122
|
+
for (const inputName of inputsToSync) {
|
|
123
|
+
// Find the corresponding camelCase signal property on the Angular component
|
|
124
|
+
const signalName = inputName.replace(/-./g, (x) => x[1].toUpperCase());
|
|
125
|
+
// Use the Injector to run the effect in the correct context
|
|
126
|
+
if (this[signalName] && typeof this[signalName] === 'function') {
|
|
127
|
+
runInInjectionContext(this.injector, () => {
|
|
128
|
+
effect(() => {
|
|
129
|
+
// Read the signal value
|
|
130
|
+
const value = this[signalName]();
|
|
131
|
+
if (wcElement) {
|
|
132
|
+
// Write the value to the Web Component's property
|
|
133
|
+
wcElement[inputName] = value;
|
|
134
|
+
}
|
|
135
|
+
});
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
const outputsToSync = [
|
|
140
|
+
'ui5Close',
|
|
141
|
+
];
|
|
142
|
+
// Synchronize outputs (events)
|
|
143
|
+
for (const outputName of outputsToSync) {
|
|
144
|
+
// Map Angular output name to UI5 web component event name
|
|
145
|
+
const eventName = outputName.replace('ui5', '').replace(/([A-Z])/g, '-$1').toLowerCase().substring(1);
|
|
146
|
+
// Ensure the output property exists and has an emit function before adding listener
|
|
147
|
+
if (this[outputName] && typeof this[outputName].emit === 'function' && wcElement.addEventListener) {
|
|
148
|
+
// Cast the listener to the correct type to satisfy TypeScript
|
|
149
|
+
wcElement.addEventListener(eventName, (e) => {
|
|
150
|
+
this[outputName].emit(e);
|
|
151
|
+
});
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.1.4", ngImport: i0, type: NotificationListItem, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
156
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "20.1.4", type: NotificationListItem, isStandalone: true, selector: "ui5-li-notification, [ui5-li-notification]", inputs: { wrappingType: { classPropertyName: "wrappingType", publicName: "wrappingType", isSignal: true, isRequired: false, transformFunction: null }, state: { classPropertyName: "state", publicName: "state", isSignal: true, isRequired: false, transformFunction: null }, showClose: { classPropertyName: "showClose", publicName: "showClose", isSignal: true, isRequired: false, transformFunction: null }, importance: { classPropertyName: "importance", publicName: "importance", isSignal: true, isRequired: false, transformFunction: null }, titleText: { classPropertyName: "titleText", publicName: "titleText", isSignal: true, isRequired: false, transformFunction: null }, read: { classPropertyName: "read", publicName: "read", isSignal: true, isRequired: false, transformFunction: null }, loading: { classPropertyName: "loading", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, loadingDelay: { classPropertyName: "loadingDelay", publicName: "loadingDelay", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { ui5Close: "ui5Close" }, exportAs: ["ui5NotificationListItem"], ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
157
|
+
}
|
|
158
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.4", ngImport: i0, type: NotificationListItem, decorators: [{
|
|
159
|
+
type: Component,
|
|
160
|
+
args: [{
|
|
161
|
+
standalone: true,
|
|
162
|
+
selector: 'ui5-li-notification, [ui5-li-notification]',
|
|
163
|
+
template: '<ng-content></ng-content>',
|
|
164
|
+
exportAs: 'ui5NotificationListItem',
|
|
165
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
166
|
+
}]
|
|
167
|
+
}] });
|
|
168
|
+
|
|
169
|
+
/**
|
|
170
|
+
* Generated bundle index. Do not edit.
|
|
171
|
+
*/
|
|
172
|
+
|
|
173
|
+
export { NotificationListItem };
|
|
174
|
+
//# sourceMappingURL=fundamental-ngx-ui5-webcomponents-fiori-notification-list-item.mjs.map
|