@testgorilla/tgo-ui 3.13.0 → 3.13.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/multi-input/multi-input.component.d.ts +23 -43
- package/components/multi-input/multi-input.model.d.ts +4 -1
- package/components/multi-input/required-multi-input.validator.d.ts +3 -0
- package/components/side-panel/side-panel.component.d.ts +1 -1
- package/components/side-panel/side-panel.model.d.ts +25 -0
- package/components/side-panel/side-panel.service.d.ts +5 -4
- package/esm2022/components/autocomplete/autocomplete.component.mjs +3 -3
- package/esm2022/components/multi-input/multi-input.component.mjs +80 -148
- package/esm2022/components/multi-input/multi-input.model.mjs +1 -1
- package/esm2022/components/multi-input/required-multi-input.validator.mjs +14 -0
- package/esm2022/components/side-panel/side-panel.component.mjs +3 -3
- package/esm2022/components/side-panel/side-panel.model.mjs +31 -1
- package/esm2022/components/side-panel/side-panel.service.mjs +19 -7
- package/fesm2022/testgorilla-tgo-ui.mjs +141 -156
- package/fesm2022/testgorilla-tgo-ui.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -39,10 +39,10 @@ export class SidePanelComponent {
|
|
|
39
39
|
this.isOpen.set(true);
|
|
40
40
|
});
|
|
41
41
|
}
|
|
42
|
-
close() {
|
|
42
|
+
close(result) {
|
|
43
43
|
this.isOpen.set(false);
|
|
44
44
|
setTimeout(() => {
|
|
45
|
-
this.sidePanelService.destroyComponent();
|
|
45
|
+
this.sidePanelService.destroyComponent(result);
|
|
46
46
|
}, sidePanelAnimationDuration);
|
|
47
47
|
}
|
|
48
48
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SidePanelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
@@ -52,4 +52,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
52
52
|
type: Component,
|
|
53
53
|
args: [{ selector: 'ui-side-panel', animations: [sidePanelAnimation, backdropAnimation], changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [TooltipComponentModule, ButtonComponentModule, UiTranslatePipe, AsyncPipe, NgClass], template: "<div class=\"side-panel-backdrop\" #sidePanelBackdrop (click)=\"close()\" [@fadeInOut]=\"isOpen() ? 'open' : 'closed'\"></div>\n<div\n class=\"side-panel\"\n [class]=\"sidePanelConfig.panelClass\"\n [class.side-panel-small]=\"isSmall()\"\n [class.side-panel-large]=\"isLarge()\"\n #sidePanel\n [@slideInOut]=\"animation()\"\n>\n @if (sidePanelConfig.showHeader) {\n <div class=\"side-panel-header\">\n <div class=\"side-panel-title-container\">\n @if (sidePanelConfig.showBackButton) {\n <ui-button\n class=\"side-panel-action\"\n [variant]=\"'icon-button'\"\n [iconName]=\"'Arrow-chevron-left-filled'\"\n (click)=\"close()\"\n [tooltip]=\"('COMMON.BACK' | uiTranslate | async)!\"\n size=\"medium\"\n ></ui-button>\n }\n <span class=\"side-panel-title\">{{ sidePanelConfig.title }}</span>\n </div>\n @if (sidePanelConfig.showCloseButton) {\n <ui-button\n class=\"side-panel-action\"\n [variant]=\"'icon-button'\"\n [iconName]=\"'Close'\"\n [tooltip]=\"('COMMON.CLOSE' | uiTranslate | async)!\"\n (click)=\"close()\"\n size=\"medium\"\n ></ui-button>\n }\n </div>\n }\n\n <div class=\"side-panel-content\">\n <ng-container #sidePanelContainer></ng-container>\n </div>\n</div>\n", styles: [".bg-teal-60b{background:#1c443c}.bg-teal-30b{background:#31766a}.bg-teal-default{background:#46a997}.bg-teal-30w{background:#7ec3b6}.bg-teal-60w{background:#b5ddd5}.bg-teal-secondary{background:#cbd6cb}.bg-teal-90w{background:#ecf6f5}.bg-petrol-60b{background:#102930}.bg-petrol-30b{background:#1b4754}.bg-petrol-default{background:#276678}.bg-petrol-30w{background:#6894a0}.bg-petrol-60w{background:#a9c2c9}.bg-petrol-secondary{background:#c8d7de}.bg-petrol-90w{background:#e9f0f1}.bg-error-60b{background:#513131}.bg-error-30b{background:#8e5655}.bg-error-60w{background:#e3c3c6}.bg-error-secondary{background:#f0dad9}.bg-error-default{background:#cb7b7a}.bg-warning-secondary{background:#f0d6bb}.bg-warning-default{background:#cca45f}.bg-black{background:#000}.bg-dark{background:#888}.bg-medium{background:#e0e0e0}.bg-grey{background:#ededed}.bg-light{background:#f6f6f6}.bg-white{background:#fff}.bg-box-shadow{background:#00000014}.bg-navigation-subtitle{background:#528593}.bgc-teal-60b{background-color:#1c443c}.bgc-teal-30b{background-color:#31766a}.bgc-teal-default{background-color:#46a997}.bgc-teal-30w{background-color:#7ec3b6}.bgc-teal-60w{background-color:#b5ddd5}.bgc-teal-secondary{background-color:#cbd6cb}.bgc-teal-90w{background-color:#ecf6f5}.bgc-petrol-60b{background-color:#102930}.bgc-petrol-30b{background-color:#1b4754}.bgc-petrol-default{background-color:#276678}.bgc-petrol-30w{background-color:#6894a0}.bgc-petrol-60w{background-color:#a9c2c9}.bgc-petrol-secondary{background-color:#c8d7de}.bgc-petrol-90w{background-color:#e9f0f1}.bgc-error-60b{background-color:#513131}.bgc-error-30b{background-color:#8e5655}.bgc-error-60w{background-color:#e3c3c6}.bgc-error-secondary{background-color:#f0dad9}.bgc-error-default{background-color:#cb7b7a}.bgc-warning-secondary{background-color:#f0d6bb}.bgc-warning-default{background-color:#cca45f}.bgc-black{background-color:#000}.bgc-dark{background-color:#888}.bgc-medium{background-color:#e0e0e0}.bgc-grey{background-color:#ededed}.bgc-light{background-color:#f6f6f6}.bgc-white{background-color:#fff}.bgc-box-shadow{background-color:#00000014}.bgc-navigation-subtitle{background-color:#528593}.side-panel{position:fixed;top:0;bottom:0;background-color:#fff;padding:32px;box-shadow:2px 24px 48px 8px #00000014;z-index:999999;display:flex;flex-direction:column;will-change:transform;transform:translate(100%)}.side-panel.side-panel-small{width:600px}@media (max-width: 600px){.side-panel.side-panel-small{width:100%}}.side-panel.side-panel-large{width:956px}@media (max-width: 600px){.side-panel.side-panel-large{width:100%}}@media (max-width: 960px){.side-panel.side-panel-large{width:100%}}.side-panel-action{margin-top:1px}.side-panel-title-container{display:flex;gap:8px}.side-panel.left{left:0}.side-panel.right{right:0}.side-panel-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:#000;z-index:899;opacity:0}.side-panel-title{font-weight:900;font-size:24px;display:block;display:-webkit-box;max-height:3em;line-height:1.5em;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;white-space:normal}.side-panel-content{overflow:auto;flex:1}.side-panel-header{position:sticky;min-height:30px;display:flex;justify-content:space-between;margin-bottom:40px}\n"] }]
|
|
54
54
|
}], ctorParameters: () => [] });
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-panel.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/side-panel/side-panel.component.ts","../../../../../projects/tgo-canopy-ui/components/side-panel/side-panel.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe, NgClass } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  computed,\n  ElementRef,\n  inject,\n  signal,\n  viewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport { UiTranslatePipe } from '../../pipes/ui-translate.pipe';\nimport { LanguageService } from '../../utils/localization/language.service';\nimport { ButtonComponentModule } from '../button/button.component.module';\nimport { TooltipComponentModule } from '../tooltip/tooltip.component.module';\nimport { backdropAnimation, sidePanelAnimation, sidePanelAnimationDuration } from './side-panel.animations';\nimport { SidePanelAnimationState, SidePanelConfig, SidePanelPosition, SidePanelSize } from './side-panel.model';\nimport { SidePanelService } from './side-panel.service';\n\n@Component({\n  selector: 'ui-side-panel',\n  templateUrl: './side-panel.component.html',\n  styleUrls: ['./side-panel.component.scss'],\n  animations: [sidePanelAnimation, backdropAnimation],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [TooltipComponentModule, ButtonComponentModule, UiTranslatePipe, AsyncPipe, NgClass],\n})\nexport class SidePanelComponent {\n  sidePanelPosition = signal<SidePanelPosition>('right');\n\n  sidePanelContainer = viewChild.required('sidePanelContainer', { read: ViewContainerRef });\n  sidePanel = viewChild.required<ElementRef<HTMLDivElement>>('sidePanel');\n  backdrop = viewChild.required<ElementRef<HTMLDivElement>>('sidePanelBackdrop');\n  language = LanguageService.defaultLanguage;\n  isOpen = signal<boolean>(false);\n  size = signal<SidePanelSize | undefined>(undefined);\n  isSmall = computed(() => this.size() === 'small');\n  isLarge = computed(() => this.size() === 'large');\n\n  animation = computed(() => {\n    if (this.isOpen()) {\n      return SidePanelAnimationState.Open;\n    }\n\n    return this.sidePanelPosition() === 'left'\n      ? SidePanelAnimationState.ClosedLeft\n      : SidePanelAnimationState.ClosedRight;\n  });\n\n  private sidePanelService = inject(SidePanelService);\n  public sidePanelConfig = inject(SidePanelConfig);\n\n  constructor() {\n    const { position, size } = this.sidePanelConfig;\n    this.sidePanelPosition.set(position);\n    this.size.set(size);\n  }\n\n  open(): void {\n    setTimeout(() => {\n      this.isOpen.set(true);\n    });\n  }\n\n  close(result?: any): void {\n    this.isOpen.set(false);\n    setTimeout(() => {\n      this.sidePanelService.destroyComponent(result);\n    }, sidePanelAnimationDuration);\n  }\n}\n","<div class=\"side-panel-backdrop\" #sidePanelBackdrop (click)=\"close()\" [@fadeInOut]=\"isOpen() ? 'open' : 'closed'\"></div>\n<div\n  class=\"side-panel\"\n  [class]=\"sidePanelConfig.panelClass\"\n  [class.side-panel-small]=\"isSmall()\"\n  [class.side-panel-large]=\"isLarge()\"\n  #sidePanel\n  [@slideInOut]=\"animation()\"\n>\n  @if (sidePanelConfig.showHeader) {\n    <div class=\"side-panel-header\">\n      <div class=\"side-panel-title-container\">\n        @if (sidePanelConfig.showBackButton) {\n          <ui-button\n            class=\"side-panel-action\"\n            [variant]=\"'icon-button'\"\n            [iconName]=\"'Arrow-chevron-left-filled'\"\n            (click)=\"close()\"\n            [tooltip]=\"('COMMON.BACK' | uiTranslate | async)!\"\n            size=\"medium\"\n          ></ui-button>\n        }\n        <span class=\"side-panel-title\">{{ sidePanelConfig.title }}</span>\n      </div>\n      @if (sidePanelConfig.showCloseButton) {\n        <ui-button\n          class=\"side-panel-action\"\n          [variant]=\"'icon-button'\"\n          [iconName]=\"'Close'\"\n          [tooltip]=\"('COMMON.CLOSE' | uiTranslate | async)!\"\n          (click)=\"close()\"\n          size=\"medium\"\n        ></ui-button>\n      }\n    </div>\n  }\n\n  <div class=\"side-panel-content\">\n    <ng-container #sidePanelContainer></ng-container>\n  </div>\n</div>\n"]}
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
+
/* eslint-disable no-underscore-dangle */
|
|
1
2
|
import { InjectionToken } from '@angular/core';
|
|
3
|
+
import { Subject } from 'rxjs';
|
|
2
4
|
export var SidePanelAnimationState;
|
|
3
5
|
(function (SidePanelAnimationState) {
|
|
4
6
|
SidePanelAnimationState["Open"] = "open";
|
|
@@ -21,4 +23,32 @@ export const SIDE_PANEL_CONFIG = new InjectionToken('SIDE_PANEL_CONFIG', {
|
|
|
21
23
|
providedIn: 'root',
|
|
22
24
|
factory: () => defaultSidePanelConfig,
|
|
23
25
|
});
|
|
24
|
-
|
|
26
|
+
/**
|
|
27
|
+
* Reference to a side panel opened via the SidePanelService.
|
|
28
|
+
* Similar to MatDialogRef from Angular Material.
|
|
29
|
+
*/
|
|
30
|
+
export class SidePanelRef {
|
|
31
|
+
constructor() {
|
|
32
|
+
this._afterClosed = new Subject();
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Observable that emits when the side panel is closed.
|
|
36
|
+
* Emits the result passed to the close method, or undefined if no result was provided.
|
|
37
|
+
*/
|
|
38
|
+
afterClosed() {
|
|
39
|
+
return this._afterClosed.asObservable();
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Closes the side panel with an optional result.
|
|
43
|
+
* @param result Optional data to be emitted via afterClosed()
|
|
44
|
+
*/
|
|
45
|
+
close(result) {
|
|
46
|
+
// This will be overridden by the service
|
|
47
|
+
}
|
|
48
|
+
/** @internal */
|
|
49
|
+
_emitClose(result) {
|
|
50
|
+
this._afterClosed.next(result);
|
|
51
|
+
this._afterClosed.complete();
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZS1wYW5lbC5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Rnby1jYW5vcHktdWkvY29tcG9uZW50cy9zaWRlLXBhbmVsL3NpZGUtcGFuZWwubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEseUNBQXlDO0FBQ3pDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDL0MsT0FBTyxFQUFjLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUkzQyxNQUFNLENBQU4sSUFBWSx1QkFLWDtBQUxELFdBQVksdUJBQXVCO0lBQ2pDLHdDQUFhLENBQUE7SUFDYiw0Q0FBaUIsQ0FBQTtJQUNqQixzREFBMkIsQ0FBQTtJQUMzQixvREFBeUIsQ0FBQTtBQUMzQixDQUFDLEVBTFcsdUJBQXVCLEtBQXZCLHVCQUF1QixRQUtsQztBQUlELE1BQU0sT0FBTyxlQUFlO0NBUzNCO0FBRUQsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQW9CO0lBQ3JELFFBQVEsRUFBRSxPQUFPO0lBQ2pCLGNBQWMsRUFBRSxLQUFLO0lBQ3JCLEtBQUssRUFBRSxFQUFFO0lBQ1QsSUFBSSxFQUFFLFNBQVM7SUFDZixVQUFVLEVBQUUsSUFBSTtJQUNoQixlQUFlLEVBQUUsSUFBSTtJQUNyQixJQUFJLEVBQUUsT0FBTztDQUNkLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBRyxJQUFJLGNBQWMsQ0FBa0IsbUJBQW1CLEVBQUU7SUFDeEYsVUFBVSxFQUFFLE1BQU07SUFDbEIsT0FBTyxFQUFFLEdBQUcsRUFBRSxDQUFDLHNCQUFzQjtDQUN0QyxDQUFDLENBQUM7QUFFSDs7O0dBR0c7QUFDSCxNQUFNLE9BQU8sWUFBWTtJQUF6QjtRQUNtQixpQkFBWSxHQUFHLElBQUksT0FBTyxFQUFpQixDQUFDO0lBNkIvRCxDQUFDO0lBckJDOzs7T0FHRztJQUNILFdBQVc7UUFDVCxPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDMUMsQ0FBQztJQUVEOzs7T0FHRztJQUNILEtBQUssQ0FBQyxNQUFVO1FBQ2QseUNBQXlDO0lBQzNDLENBQUM7SUFFRCxnQkFBZ0I7SUFDaEIsVUFBVSxDQUFDLE1BQVU7UUFDbkIsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDL0IsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUMvQixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBuby11bmRlcnNjb3JlLWRhbmdsZSAqL1xuaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE9ic2VydmFibGUsIFN1YmplY3QgfSBmcm9tICdyeGpzJztcblxuZXhwb3J0IHR5cGUgU2lkZVBhbmVsUG9zaXRpb24gPSAnbGVmdCcgfCAncmlnaHQnO1xuXG5leHBvcnQgZW51bSBTaWRlUGFuZWxBbmltYXRpb25TdGF0ZSB7XG4gIE9wZW4gPSAnb3BlbicsXG4gIENsb3NlZCA9ICdjbG9zZWQnLFxuICBDbG9zZWRSaWdodCA9ICdjbG9zZWRSaWdodCcsXG4gIENsb3NlZExlZnQgPSAnY2xvc2VkTGVmdCcsXG59XG5cbmV4cG9ydCB0eXBlIFNpZGVQYW5lbFNpemUgPSAnc21hbGwnIHwgJ2xhcmdlJztcblxuZXhwb3J0IGNsYXNzIFNpZGVQYW5lbENvbmZpZyB7XG4gIHRpdGxlOiBzdHJpbmc7XG4gIHBvc2l0aW9uOiBTaWRlUGFuZWxQb3NpdGlvbjtcbiAgc2hvd0JhY2tCdXR0b246IGJvb2xlYW47XG4gIGRhdGE/OiB1bmtub3duO1xuICBzaG93Q2xvc2VCdXR0b24/OiBib29sZWFuO1xuICBzaG93SGVhZGVyPzogYm9vbGVhbjtcbiAgcGFuZWxDbGFzcz86IHN0cmluZztcbiAgc2l6ZT86IFNpZGVQYW5lbFNpemU7XG59XG5cbmV4cG9ydCBjb25zdCBkZWZhdWx0U2lkZVBhbmVsQ29uZmlnOiBTaWRlUGFuZWxDb25maWcgPSB7XG4gIHBvc2l0aW9uOiAncmlnaHQnLFxuICBzaG93QmFja0J1dHRvbjogZmFsc2UsXG4gIHRpdGxlOiAnJyxcbiAgZGF0YTogdW5kZWZpbmVkLFxuICBzaG93SGVhZGVyOiB0cnVlLFxuICBzaG93Q2xvc2VCdXR0b246IHRydWUsXG4gIHNpemU6ICdzbWFsbCcsXG59O1xuXG5leHBvcnQgY29uc3QgU0lERV9QQU5FTF9DT05GSUcgPSBuZXcgSW5qZWN0aW9uVG9rZW48U2lkZVBhbmVsQ29uZmlnPignU0lERV9QQU5FTF9DT05GSUcnLCB7XG4gIHByb3ZpZGVkSW46ICdyb290JyxcbiAgZmFjdG9yeTogKCkgPT4gZGVmYXVsdFNpZGVQYW5lbENvbmZpZyxcbn0pO1xuXG4vKipcbiAqIFJlZmVyZW5jZSB0byBhIHNpZGUgcGFuZWwgb3BlbmVkIHZpYSB0aGUgU2lkZVBhbmVsU2VydmljZS5cbiAqIFNpbWlsYXIgdG8gTWF0RGlhbG9nUmVmIGZyb20gQW5ndWxhciBNYXRlcmlhbC5cbiAqL1xuZXhwb3J0IGNsYXNzIFNpZGVQYW5lbFJlZjxUID0gYW55LCBSID0gYW55PiB7XG4gIHByaXZhdGUgcmVhZG9ubHkgX2FmdGVyQ2xvc2VkID0gbmV3IFN1YmplY3Q8VCB8IHVuZGVmaW5lZD4oKTtcblxuICAvKipcbiAgICogSW5zdGFuY2Ugb2YgdGhlIGNvbXBvbmVudCBsb2FkZWQgaW50byB0aGUgc2lkZSBwYW5lbC5cbiAgICogV2lsbCBiZSB1bmRlZmluZWQgaWYgYSBUZW1wbGF0ZVJlZiB3YXMgdXNlZCBpbnN0ZWFkIG9mIGEgY29tcG9uZW50LlxuICAgKi9cbiAgY29tcG9uZW50SW5zdGFuY2U/OiBSO1xuXG4gIC8qKlxuICAgKiBPYnNlcnZhYmxlIHRoYXQgZW1pdHMgd2hlbiB0aGUgc2lkZSBwYW5lbCBpcyBjbG9zZWQuXG4gICAqIEVtaXRzIHRoZSByZXN1bHQgcGFzc2VkIHRvIHRoZSBjbG9zZSBtZXRob2QsIG9yIHVuZGVmaW5lZCBpZiBubyByZXN1bHQgd2FzIHByb3ZpZGVkLlxuICAgKi9cbiAgYWZ0ZXJDbG9zZWQoKTogT2JzZXJ2YWJsZTxUIHwgdW5kZWZpbmVkPiB7XG4gICAgcmV0dXJuIHRoaXMuX2FmdGVyQ2xvc2VkLmFzT2JzZXJ2YWJsZSgpO1xuICB9XG5cbiAgLyoqXG4gICAqIENsb3NlcyB0aGUgc2lkZSBwYW5lbCB3aXRoIGFuIG9wdGlvbmFsIHJlc3VsdC5cbiAgICogQHBhcmFtIHJlc3VsdCBPcHRpb25hbCBkYXRhIHRvIGJlIGVtaXR0ZWQgdmlhIGFmdGVyQ2xvc2VkKClcbiAgICovXG4gIGNsb3NlKHJlc3VsdD86IFQpOiB2b2lkIHtcbiAgICAvLyBUaGlzIHdpbGwgYmUgb3ZlcnJpZGRlbiBieSB0aGUgc2VydmljZVxuICB9XG5cbiAgLyoqIEBpbnRlcm5hbCAqL1xuICBfZW1pdENsb3NlKHJlc3VsdD86IFQpOiB2b2lkIHtcbiAgICB0aGlzLl9hZnRlckNsb3NlZC5uZXh0KHJlc3VsdCk7XG4gICAgdGhpcy5fYWZ0ZXJDbG9zZWQuY29tcGxldGUoKTtcbiAgfVxufVxuIl19
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { ApplicationRef, createComponent, EnvironmentInjector, inject, Injectable, Injector, TemplateRef, } from '@angular/core';
|
|
2
2
|
import { SIDE_PANEL_DATA } from './side-panel-data-injection-token';
|
|
3
3
|
import { SidePanelComponent } from './side-panel.component';
|
|
4
|
-
import { SIDE_PANEL_CONFIG, SidePanelConfig } from './side-panel.model';
|
|
4
|
+
import { SIDE_PANEL_CONFIG, SidePanelConfig, SidePanelRef } from './side-panel.model';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export class SidePanelService {
|
|
7
7
|
constructor() {
|
|
@@ -11,6 +11,11 @@ export class SidePanelService {
|
|
|
11
11
|
}
|
|
12
12
|
open(content, config, parentInjector) {
|
|
13
13
|
const panelConfig = { ...this.defaultSidePanelConfig, ...config };
|
|
14
|
+
const sidePanelRef = new SidePanelRef();
|
|
15
|
+
this.currentSidePanelRef = sidePanelRef;
|
|
16
|
+
sidePanelRef.close = (result) => {
|
|
17
|
+
this.close(result);
|
|
18
|
+
};
|
|
14
19
|
if (!this.SidePanelComponentRef) {
|
|
15
20
|
const injector = this.createSidePanelInjector(panelConfig, parentInjector);
|
|
16
21
|
const SidePanelComponentRef = this.createSidePanelComponent(panelConfig.position, injector);
|
|
@@ -20,16 +25,21 @@ export class SidePanelService {
|
|
|
20
25
|
this.loadTemplate(content);
|
|
21
26
|
}
|
|
22
27
|
else {
|
|
23
|
-
this.loadComponent(content);
|
|
28
|
+
this.loadComponent(content, sidePanelRef);
|
|
24
29
|
}
|
|
25
30
|
this.SidePanelComponentRef.instance.open();
|
|
31
|
+
return sidePanelRef;
|
|
26
32
|
}
|
|
27
|
-
close() {
|
|
33
|
+
close(result) {
|
|
28
34
|
if (this.SidePanelComponentRef) {
|
|
29
|
-
this.SidePanelComponentRef.instance.close();
|
|
35
|
+
this.SidePanelComponentRef.instance.close(result);
|
|
30
36
|
}
|
|
31
37
|
}
|
|
32
|
-
destroyComponent() {
|
|
38
|
+
destroyComponent(result) {
|
|
39
|
+
if (this.currentSidePanelRef) {
|
|
40
|
+
this.currentSidePanelRef._emitClose(result);
|
|
41
|
+
this.currentSidePanelRef = undefined;
|
|
42
|
+
}
|
|
33
43
|
if (this.SidePanelComponentRef) {
|
|
34
44
|
this.appRef.detachView(this.SidePanelComponentRef.hostView);
|
|
35
45
|
this.SidePanelComponentRef.destroy();
|
|
@@ -60,11 +70,13 @@ export class SidePanelService {
|
|
|
60
70
|
document.body.appendChild(sidePanelEl);
|
|
61
71
|
return sidePanelComponentRef;
|
|
62
72
|
}
|
|
63
|
-
loadComponent(component) {
|
|
73
|
+
loadComponent(component, sidePanelRef) {
|
|
64
74
|
const viewContainerRef = this.SidePanelComponentRef?.instance.sidePanelContainer;
|
|
65
75
|
if (viewContainerRef) {
|
|
66
76
|
viewContainerRef().clear();
|
|
67
77
|
this.contentComponentRef = viewContainerRef().createComponent(component);
|
|
78
|
+
// Set the component instance on the SidePanelRef
|
|
79
|
+
sidePanelRef.componentInstance = this.contentComponentRef.instance;
|
|
68
80
|
}
|
|
69
81
|
}
|
|
70
82
|
loadTemplate(template) {
|
|
@@ -83,4 +95,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
83
95
|
providedIn: 'root',
|
|
84
96
|
}]
|
|
85
97
|
}], ctorParameters: () => [] });
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-panel.service.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/side-panel/side-panel.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ApplicationRef,\n  ComponentRef,\n  createComponent,\n  EmbeddedViewRef,\n  EnvironmentInjector,\n  inject,\n  Injectable,\n  Injector,\n  TemplateRef,\n  Type,\n} from '@angular/core';\nimport { SIDE_PANEL_DATA } from './side-panel-data-injection-token';\nimport { SidePanelComponent } from './side-panel.component';\nimport { SIDE_PANEL_CONFIG, SidePanelConfig, SidePanelPosition } from './side-panel.model';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class SidePanelService {\n  private SidePanelComponentRef?: ComponentRef<SidePanelComponent>;\n  private contentComponentRef?: ComponentRef<any>;\n  private embeddedViewRef?: EmbeddedViewRef<any>;\n  private defaultSidePanelConfig: SidePanelConfig = inject(SIDE_PANEL_CONFIG);\n  private injector = inject(EnvironmentInjector);\n  private appRef = inject(ApplicationRef);\n\n  constructor() {}\n\n  open(content: Type<any> | TemplateRef<any>, config: Partial<SidePanelConfig>, parentInjector?: Injector): void {\n    const panelConfig: SidePanelConfig = { ...this.defaultSidePanelConfig, ...config };\n\n    if (!this.SidePanelComponentRef) {\n      const injector = this.createSidePanelInjector(panelConfig, parentInjector);\n      const SidePanelComponentRef = this.createSidePanelComponent(panelConfig.position, injector);\n      this.SidePanelComponentRef = SidePanelComponentRef;\n    }\n\n    if (content instanceof TemplateRef) {\n      this.loadTemplate(content);\n    } else {\n      this.loadComponent(content);\n    }\n\n    this.SidePanelComponentRef.instance.open();\n  }\n\n  close() {\n    if (this.SidePanelComponentRef) {\n      this.SidePanelComponentRef.instance.close();\n    }\n  }\n\n  destroyComponent(): void {\n    if (this.SidePanelComponentRef) {\n      this.appRef.detachView(this.SidePanelComponentRef.hostView);\n      this.SidePanelComponentRef.destroy();\n      this.SidePanelComponentRef = undefined;\n    }\n\n    if (this.contentComponentRef) {\n      this.contentComponentRef.destroy();\n      this.contentComponentRef = undefined;\n    }\n  }\n\n  private createSidePanelInjector(config: SidePanelConfig, parentInjector?: Injector): Injector {\n    return Injector.create({\n      parent: parentInjector,\n      providers: [\n        { provide: SidePanelConfig, useValue: config },\n        { provide: SIDE_PANEL_DATA, useValue: config.data },\n      ],\n    });\n  }\n\n  private createSidePanelComponent(position: SidePanelPosition, injector: Injector): ComponentRef<SidePanelComponent> {\n    const sidePanelComponentRef = createComponent(SidePanelComponent, {\n      environmentInjector: this.injector,\n      elementInjector: injector,\n    });\n\n    this.appRef.attachView(sidePanelComponentRef.hostView);\n\n    const sidePanelEl = (sidePanelComponentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n    sidePanelEl.querySelector('.side-panel')?.classList.add(position);\n\n    document.body.appendChild(sidePanelEl);\n\n    return sidePanelComponentRef;\n  }\n\n  private loadComponent(component: Type<any>): void {\n    const viewContainerRef = this.SidePanelComponentRef?.instance.sidePanelContainer;\n    if (viewContainerRef) {\n      viewContainerRef().clear();\n      this.contentComponentRef = viewContainerRef().createComponent(component);\n    }\n  }\n\n  private loadTemplate(template: TemplateRef<any>): void {\n    const viewContainerRef = this.SidePanelComponentRef?.instance.sidePanelContainer;\n    if (viewContainerRef) {\n      viewContainerRef().clear();\n      this.embeddedViewRef = viewContainerRef().createEmbeddedView(template);\n    }\n  }\n}\n"]}
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-panel.service.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/side-panel/side-panel.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ApplicationRef,\n  ComponentRef,\n  createComponent,\n  EmbeddedViewRef,\n  EnvironmentInjector,\n  inject,\n  Injectable,\n  Injector,\n  TemplateRef,\n  Type,\n} from '@angular/core';\nimport { SIDE_PANEL_DATA } from './side-panel-data-injection-token';\nimport { SidePanelComponent } from './side-panel.component';\nimport { SIDE_PANEL_CONFIG, SidePanelConfig, SidePanelPosition, SidePanelRef } from './side-panel.model';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class SidePanelService {\n  private SidePanelComponentRef?: ComponentRef<SidePanelComponent>;\n  private contentComponentRef?: ComponentRef<any>;\n  private embeddedViewRef?: EmbeddedViewRef<any>;\n  private currentSidePanelRef?: SidePanelRef<any>;\n  private defaultSidePanelConfig: SidePanelConfig = inject(SIDE_PANEL_CONFIG);\n  private injector = inject(EnvironmentInjector);\n  private appRef = inject(ApplicationRef);\n\n  constructor() {}\n\n  open<T = any, R = any>(\n    content: Type<R> | TemplateRef<any>,\n    config: Partial<SidePanelConfig>,\n    parentInjector?: Injector\n  ): SidePanelRef<T, R> {\n    const panelConfig: SidePanelConfig = { ...this.defaultSidePanelConfig, ...config };\n\n    const sidePanelRef = new SidePanelRef<T, R>();\n    this.currentSidePanelRef = sidePanelRef;\n\n    sidePanelRef.close = (result?: T) => {\n      this.close(result);\n    };\n\n    if (!this.SidePanelComponentRef) {\n      const injector = this.createSidePanelInjector(panelConfig, parentInjector);\n      const SidePanelComponentRef = this.createSidePanelComponent(panelConfig.position, injector);\n      this.SidePanelComponentRef = SidePanelComponentRef;\n    }\n\n    if (content instanceof TemplateRef) {\n      this.loadTemplate(content);\n    } else {\n      this.loadComponent(content, sidePanelRef);\n    }\n\n    this.SidePanelComponentRef.instance.open();\n\n    return sidePanelRef;\n  }\n\n  close<T = any>(result?: T): void {\n    if (this.SidePanelComponentRef) {\n      this.SidePanelComponentRef.instance.close(result);\n    }\n  }\n\n  destroyComponent<T = any>(result?: T): void {\n    if (this.currentSidePanelRef) {\n      this.currentSidePanelRef._emitClose(result);\n      this.currentSidePanelRef = undefined;\n    }\n\n    if (this.SidePanelComponentRef) {\n      this.appRef.detachView(this.SidePanelComponentRef.hostView);\n      this.SidePanelComponentRef.destroy();\n      this.SidePanelComponentRef = undefined;\n    }\n\n    if (this.contentComponentRef) {\n      this.contentComponentRef.destroy();\n      this.contentComponentRef = undefined;\n    }\n  }\n\n  private createSidePanelInjector(config: SidePanelConfig, parentInjector?: Injector): Injector {\n    return Injector.create({\n      parent: parentInjector,\n      providers: [\n        { provide: SidePanelConfig, useValue: config },\n        { provide: SIDE_PANEL_DATA, useValue: config.data },\n      ],\n    });\n  }\n\n  private createSidePanelComponent(position: SidePanelPosition, injector: Injector): ComponentRef<SidePanelComponent> {\n    const sidePanelComponentRef = createComponent(SidePanelComponent, {\n      environmentInjector: this.injector,\n      elementInjector: injector,\n    });\n\n    this.appRef.attachView(sidePanelComponentRef.hostView);\n\n    const sidePanelEl = (sidePanelComponentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n    sidePanelEl.querySelector('.side-panel')?.classList.add(position);\n\n    document.body.appendChild(sidePanelEl);\n\n    return sidePanelComponentRef;\n  }\n\n  private loadComponent<R = any>(component: Type<R>, sidePanelRef: SidePanelRef<any, R>): void {\n    const viewContainerRef = this.SidePanelComponentRef?.instance.sidePanelContainer;\n    if (viewContainerRef) {\n      viewContainerRef().clear();\n      this.contentComponentRef = viewContainerRef().createComponent(component);\n      // Set the component instance on the SidePanelRef\n      sidePanelRef.componentInstance = this.contentComponentRef.instance as R;\n    }\n  }\n\n  private loadTemplate(template: TemplateRef<any>): void {\n    const viewContainerRef = this.SidePanelComponentRef?.instance.sidePanelContainer;\n    if (viewContainerRef) {\n      viewContainerRef().clear();\n      this.embeddedViewRef = viewContainerRef().createEmbeddedView(template);\n    }\n  }\n}\n"]}
|