@testgorilla/tgo-ui 3.8.4 → 3.8.6

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.
@@ -1,8 +1,8 @@
1
1
  import { EventEmitter, OnChanges, OnInit } from '@angular/core';
2
2
  import { DomSanitizer, SafeHtml } from '@angular/platform-browser';
3
3
  import { ApplicationTheme } from '../../models/application-theme.model';
4
- import { CardSize, CardVariant } from './card.model';
5
4
  import { IconSize } from '../icon/icon.model';
5
+ import { CardSize, CardVariant } from './card.model';
6
6
  import * as i0 from "@angular/core";
7
7
  export declare class CardComponent implements OnChanges, OnInit {
8
8
  private readonly defaultAppTheme;
@@ -21,13 +21,13 @@ export declare class DonutChartComponent {
21
21
  id: string;
22
22
  afterDatasetDraw: (chart: any) => void;
23
23
  };
24
- donutChartPlugins: ({
24
+ donutChartPlugins: (import("chart.js").Plugin<keyof import("chart.js").ChartTypeRegistry, import("chart.js/dist/types/basic").AnyObject> | {
25
25
  id: string;
26
26
  beforeDraw: (chart: any) => void;
27
27
  } | {
28
28
  id: string;
29
29
  afterDatasetDraw: (chart: any) => void;
30
- } | import("chart.js").Plugin<keyof import("chart.js").ChartTypeRegistry, import("chart.js/dist/types/basic").AnyObject>)[];
30
+ })[];
31
31
  donutChartOptions: ChartOptions<'doughnut'>;
32
32
  static ɵfac: i0.ɵɵFactoryDeclaration<DonutChartComponent, never>;
33
33
  static ɵcmp: i0.ɵɵComponentDeclaration<DonutChartComponent, "ui-donut-chart", never, { "donutChartData": { "alias": "donutChartData"; "required": false; "isSignal": true; }; "applicationTheme": { "alias": "applicationTheme"; "required": false; "isSignal": true; }; }, {}, never, never, false, never>;
@@ -10,6 +10,7 @@ export declare class SidePanelService {
10
10
  private appRef;
11
11
  constructor();
12
12
  open(content: Type<any> | TemplateRef<any>, config: Partial<SidePanelConfig>, parentInjector?: Injector): void;
13
+ close(): void;
13
14
  destroyComponent(): void;
14
15
  private createSidePanelInjector;
15
16
  private createSidePanelComponent;
@@ -90,7 +90,7 @@ export class CardComponent {
90
90
  this.variant !== 'neutral');
91
91
  }
92
92
  selectCard() {
93
- if (!this.allowSelect &&
93
+ if (this.allowSelect &&
94
94
  this.variant !== 'educative' &&
95
95
  this.variant !== 'premium' &&
96
96
  this.variant !== 'ai' &&
@@ -129,4 +129,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
129
129
  }], cardSelected: [{
130
130
  type: Output
131
131
  }] } });
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"card.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/card/card.component.ts","../../../../../projects/tgo-canopy-ui/components/card/card.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Inject,\n  Input,\n  OnChanges,\n  OnInit,\n  Optional,\n  Output,\n} from '@angular/core';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { CardSize, CardVariant } from './card.model';\nimport { IconSize } from '../icon/icon.model';\n\n@Component({\n  selector: 'ui-card',\n  templateUrl: './card.component.html',\n  styleUrls: ['./card.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class CardComponent implements OnChanges, OnInit {\n  /**\n   * Card size. Defaults \"medium\".\n   *\n   * @type {CardSize}\n   * @memberof CardComponent\n   */\n  @Input() size: CardSize = 'medium';\n\n  /**\n   * Card variants. Defaults \"default\".\n   *\n   * @type {CardVariant}\n   * @memberof CardComponent\n   */\n  @Input() variant: CardVariant = 'default';\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof CardComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * Show errors below card.\n   *\n   * @type {string[]}\n   * @memberof CardComponent\n   */\n  @Input() set errors(errors: string[]) {\n    this.safeErrors = errors?.filter(Boolean).map(error => this.domSanitizer.bypassSecurityTrustHtml(error));\n  }\n\n  /**\n   * Errors size\n   *\n   * @type {string}\n   * @memberof CardComponent\n   */\n  @Input() errorsSize? = 'default';\n\n  /**\n   * Marks card as selected\n   *\n   * @type {boolean}\n   * @memberof CardComponent\n   */\n  @Input() selected = false;\n\n  /**\n   * Marks card as readonly. Defaults \"false\".\n   *\n   * @type {CardVariant}\n   * @memberof CardComponent\n   */\n  @Input() allowSelect = false;\n\n  /**\n   * Emits when card is being selected\n   */\n  @Output() cardSelected = new EventEmitter<boolean>();\n\n  safeErrors: SafeHtml[];\n\n  classes = '';\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private domSanitizer: DomSanitizer\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  ngOnChanges(): void {\n    this.classes = `card-size-${this.size ?? 'medium'} ${this.cardVariant ?? 'default'}`;\n  }\n\n  ngOnInit(): void {\n    this.classes = `card-size-${this.size ?? 'medium'} ${this.cardVariant ?? 'default'}`;\n  }\n\n  get cardVariant(): CardVariant {\n    return this.safeErrors?.length ? 'error' : this.variant;\n  }\n\n  get errorIconSize(): IconSize {\n    return this.errorsSize === 'small' ? '16' : '24';\n  }\n\n  get isSelected(): boolean {\n    // educative, premium, ai, actionDriver and neutral variants shouldn't have any selected/interactive states\n    return (\n      this.selected &&\n      this.variant !== 'educative' &&\n      this.variant !== 'premium' &&\n      this.variant !== 'ai' &&\n      this.variant !== 'actionDriver' &&\n      this.variant !== 'neutral'\n    );\n  }\n\n  selectCard() {\n    if (\n      !this.allowSelect &&\n      this.variant !== 'educative' &&\n      this.variant !== 'premium' &&\n      this.variant !== 'ai' &&\n      this.variant !== 'actionDriver' &&\n      this.variant !== 'neutral' &&\n      this.variant !== 'default'\n    ) {\n      this.selected = true;\n      this.cardSelected.emit(this.selected);\n    }\n  }\n}\n","<div\n  class=\"card-container\"\n  (keydown.enter)=\"selectCard()\"\n  (keydown.space)=\"selectCard()\"\n  (click)=\"selectCard()\"\n  [ngClass]=\"[classes, isSelected ? 'selected' : '']\"\n  [attr.theme]=\"applicationTheme\"\n  tabindex=\"0\"\n>\n  <ng-content></ng-content>\n</div>\n@if (safeErrors?.length) {\n  <div class=\"errors\"\n       [class.errors-small]=\"errorsSize === 'small'\">\n    @for (error of safeErrors; track error) {\n      <div class=\"error\">\n        <ui-icon [size]=\"errorIconSize\" [applicationTheme]=\"applicationTheme\" [name]=\"'Error'\"></ui-icon>\n        <span [innerHTML]=\"error\"></span>\n      </div>\n    }\n  </div>\n}\n"]}
132
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"card.component.js","sourceRoot":"","sources":["../../../../../projects/tgo-canopy-ui/components/card/card.component.ts","../../../../../projects/tgo-canopy-ui/components/card/card.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Inject,\n  Input,\n  OnChanges,\n  OnInit,\n  Optional,\n  Output,\n} from '@angular/core';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { ApplicationTheme } from '../../models/application-theme.model';\nimport { IconSize } from '../icon/icon.model';\nimport { CardSize, CardVariant } from './card.model';\n\n@Component({\n  selector: 'ui-card',\n  templateUrl: './card.component.html',\n  styleUrls: ['./card.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class CardComponent implements OnChanges, OnInit {\n  /**\n   * Card size. Defaults \"medium\".\n   *\n   * @type {CardSize}\n   * @memberof CardComponent\n   */\n  @Input() size: CardSize = 'medium';\n\n  /**\n   * Card variants. Defaults \"default\".\n   *\n   * @type {CardVariant}\n   * @memberof CardComponent\n   */\n  @Input() variant: CardVariant = 'default';\n\n  /**\n   *\n   * Defines the application theme\n   *\n   * @type {ApplicationTheme}\n   * @memberof CardComponent\n   */\n  @Input() applicationTheme: ApplicationTheme = 'light';\n\n  /**\n   * Show errors below card.\n   *\n   * @type {string[]}\n   * @memberof CardComponent\n   */\n  @Input() set errors(errors: string[]) {\n    this.safeErrors = errors?.filter(Boolean).map(error => this.domSanitizer.bypassSecurityTrustHtml(error));\n  }\n\n  /**\n   * Errors size\n   *\n   * @type {string}\n   * @memberof CardComponent\n   */\n  @Input() errorsSize? = 'default';\n\n  /**\n   * Marks card as selected\n   *\n   * @type {boolean}\n   * @memberof CardComponent\n   */\n  @Input() selected = false;\n\n  /**\n   * Marks card as readonly. Defaults \"false\".\n   *\n   * @type {CardVariant}\n   * @memberof CardComponent\n   */\n  @Input() allowSelect = false;\n\n  /**\n   * Emits when card is being selected\n   */\n  @Output() cardSelected = new EventEmitter<boolean>();\n\n  safeErrors: SafeHtml[];\n\n  classes = '';\n\n  constructor(\n    @Optional() @Inject('CANOPYUI_DEFAULT_APPLICATION_THEME') private readonly defaultAppTheme: ApplicationTheme,\n    private domSanitizer: DomSanitizer\n  ) {\n    if (defaultAppTheme) {\n      this.applicationTheme = defaultAppTheme;\n    }\n  }\n\n  ngOnChanges(): void {\n    this.classes = `card-size-${this.size ?? 'medium'} ${this.cardVariant ?? 'default'}`;\n  }\n\n  ngOnInit(): void {\n    this.classes = `card-size-${this.size ?? 'medium'} ${this.cardVariant ?? 'default'}`;\n  }\n\n  get cardVariant(): CardVariant {\n    return this.safeErrors?.length ? 'error' : this.variant;\n  }\n\n  get errorIconSize(): IconSize {\n    return this.errorsSize === 'small' ? '16' : '24';\n  }\n\n  get isSelected(): boolean {\n    // educative, premium, ai, actionDriver and neutral variants shouldn't have any selected/interactive states\n    return (\n      this.selected &&\n      this.variant !== 'educative' &&\n      this.variant !== 'premium' &&\n      this.variant !== 'ai' &&\n      this.variant !== 'actionDriver' &&\n      this.variant !== 'neutral'\n    );\n  }\n\n  selectCard() {\n    if (\n      this.allowSelect &&\n      this.variant !== 'educative' &&\n      this.variant !== 'premium' &&\n      this.variant !== 'ai' &&\n      this.variant !== 'actionDriver' &&\n      this.variant !== 'neutral' &&\n      this.variant !== 'default'\n    ) {\n      this.selected = true;\n      this.cardSelected.emit(this.selected);\n    }\n  }\n}\n","<div\n  class=\"card-container\"\n  (keydown.enter)=\"selectCard()\"\n  (keydown.space)=\"selectCard()\"\n  (click)=\"selectCard()\"\n  [ngClass]=\"[classes, isSelected ? 'selected' : '']\"\n  [attr.theme]=\"applicationTheme\"\n  tabindex=\"0\"\n>\n  <ng-content></ng-content>\n</div>\n@if (safeErrors?.length) {\n  <div class=\"errors\"\n       [class.errors-small]=\"errorsSize === 'small'\">\n    @for (error of safeErrors; track error) {\n      <div class=\"error\">\n        <ui-icon [size]=\"errorIconSize\" [applicationTheme]=\"applicationTheme\" [name]=\"'Error'\"></ui-icon>\n        <span [innerHTML]=\"error\"></span>\n      </div>\n    }\n  </div>\n}\n"]}
@@ -24,6 +24,11 @@ export class SidePanelService {
24
24
  }
25
25
  this.SidePanelComponentRef.instance.open();
26
26
  }
27
+ close() {
28
+ if (this.SidePanelComponentRef) {
29
+ this.SidePanelComponentRef.instance.close();
30
+ }
31
+ }
27
32
  destroyComponent() {
28
33
  if (this.SidePanelComponentRef) {
29
34
  this.appRef.detachView(this.SidePanelComponentRef.hostView);
@@ -78,4 +83,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
78
83
  providedIn: 'root',
79
84
  }]
80
85
  }], ctorParameters: () => [] });
81
- //# 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  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"]}
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"]}
@@ -1,5 +1,5 @@
1
1
  import * as i0 from '@angular/core';
2
- import { Injectable, Input, HostBinding, Optional, Inject, ViewEncapsulation, Component, EventEmitter, booleanAttribute, Output, Pipe, ChangeDetectionStrategy, NgModule, HostListener, Directive, ViewChild, Self, ContentChild, input, computed, signal, ElementRef, forwardRef, ViewContainerRef, Host, TemplateRef, inject, ViewChildren, model, output, InjectionToken, PLATFORM_ID, ChangeDetectorRef, effect, DestroyRef, EnvironmentInjector, ApplicationRef, Injector, createComponent, viewChild } from '@angular/core';
2
+ import { Injectable, Component, ViewEncapsulation, Optional, Inject, HostBinding, Input, EventEmitter, booleanAttribute, Output, Pipe, ChangeDetectionStrategy, NgModule, Directive, HostListener, ViewChild, Self, ContentChild, input, computed, signal, ElementRef, forwardRef, ViewContainerRef, Host, TemplateRef, inject, ViewChildren, model, output, InjectionToken, PLATFORM_ID, ChangeDetectorRef, effect, DestroyRef, EnvironmentInjector, ApplicationRef, Injector, createComponent, viewChild } from '@angular/core';
3
3
  import * as i1$1 from '@angular/common';
4
4
  import { CommonModule, KeyValuePipe, NgIf, NgForOf, NgClass, NgTemplateOutlet, AsyncPipe, formatDate, isPlatformBrowser, NgOptimizedImage, DecimalPipe } from '@angular/common';
5
5
  import * as i1 from '@angular/material/icon';
@@ -74,7 +74,7 @@ import * as i7$2 from '@angular/material/sort';
74
74
  import { MatSortModule } from '@angular/material/sort';
75
75
  import * as i2$7 from '@angular/material/slider';
76
76
  import { MatSliderModule } from '@angular/material/slider';
77
- import { NgxMaskDirective, provideNgxMask } from 'ngx-mask';
77
+ import { provideNgxMask, NgxMaskDirective } from 'ngx-mask';
78
78
  import * as i2$8 from '@angular/material/divider';
79
79
  import { MatDividerModule } from '@angular/material/divider';
80
80
  import { hasModifierKey, SPACE, ENTER } from '@angular/cdk/keycodes';
@@ -6084,7 +6084,7 @@ class CardComponent {
6084
6084
  this.variant !== 'neutral');
6085
6085
  }
6086
6086
  selectCard() {
6087
- if (!this.allowSelect &&
6087
+ if (this.allowSelect &&
6088
6088
  this.variant !== 'educative' &&
6089
6089
  this.variant !== 'premium' &&
6090
6090
  this.variant !== 'ai' &&
@@ -16621,6 +16621,11 @@ class SidePanelService {
16621
16621
  }
16622
16622
  this.SidePanelComponentRef.instance.open();
16623
16623
  }
16624
+ close() {
16625
+ if (this.SidePanelComponentRef) {
16626
+ this.SidePanelComponentRef.instance.close();
16627
+ }
16628
+ }
16624
16629
  destroyComponent() {
16625
16630
  if (this.SidePanelComponentRef) {
16626
16631
  this.appRef.detachView(this.SidePanelComponentRef.hostView);