c3-components 0.0.30 → 0.0.33

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.
@@ -9,24 +9,30 @@ import { ConfirmDialogComponent } from './components/c3-dialog-confirm.component
9
9
  import { C3DialogEmbedChildComponent } from './components/c3-dialog-embed-child.component';
10
10
  import { C3PromptDialogComponent } from './components/c3-dialog-prompt.component';
11
11
  import { C3DialogService } from './services/c3-dialog.service';
12
+ import { MatToolbarModule } from '@angular/material/toolbar';
13
+ import { MatIconModule } from '@angular/material/icon';
12
14
  import * as i0 from "@angular/core";
13
15
  export class C3DialogModule {
14
16
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3DialogModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
15
17
  static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.1", ngImport: i0, type: C3DialogModule, declarations: [ConfirmDialogComponent,
16
18
  C3PromptDialogComponent,
17
19
  C3DialogEmbedChildComponent], imports: [CommonModule,
18
- MatDialogModule,
20
+ FormsModule,
19
21
  MatButtonModule,
22
+ MatDialogModule,
20
23
  MatFormFieldModule,
24
+ MatIconModule,
21
25
  MatInputModule,
22
- FormsModule,
26
+ MatToolbarModule,
23
27
  ReactiveFormsModule] }); }
24
28
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3DialogModule, providers: [C3DialogService], imports: [CommonModule,
25
- MatDialogModule,
29
+ FormsModule,
26
30
  MatButtonModule,
31
+ MatDialogModule,
27
32
  MatFormFieldModule,
33
+ MatIconModule,
28
34
  MatInputModule,
29
- FormsModule,
35
+ MatToolbarModule,
30
36
  ReactiveFormsModule] }); }
31
37
  }
32
38
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3DialogModule, decorators: [{
@@ -39,14 +45,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImpor
39
45
  ],
40
46
  imports: [
41
47
  CommonModule,
42
- MatDialogModule,
48
+ FormsModule,
43
49
  MatButtonModule,
50
+ MatDialogModule,
44
51
  MatFormFieldModule,
52
+ MatIconModule,
45
53
  MatInputModule,
46
- FormsModule,
54
+ MatToolbarModule,
47
55
  ReactiveFormsModule,
48
56
  ],
49
57
  providers: [C3DialogService],
50
58
  }]
51
59
  }] });
52
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZGlhbG9nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1kaWFsb2cvYzMtZGlhbG9nLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDbEYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sOENBQThDLENBQUM7QUFDM0YsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDbEYsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDhCQUE4QixDQUFDOztBQW1CL0QsTUFBTSxPQUFPLGNBQWM7OEdBQWQsY0FBYzsrR0FBZCxjQUFjLGlCQWZ2QixzQkFBc0I7WUFDdEIsdUJBQXVCO1lBQ3ZCLDJCQUEyQixhQUczQixZQUFZO1lBQ1osZUFBZTtZQUNmLGVBQWU7WUFDZixrQkFBa0I7WUFDbEIsY0FBYztZQUNkLFdBQVc7WUFDWCxtQkFBbUI7K0dBSVYsY0FBYyxhQUZkLENBQUMsZUFBZSxDQUFDLFlBUjFCLFlBQVk7WUFDWixlQUFlO1lBQ2YsZUFBZTtZQUNmLGtCQUFrQjtZQUNsQixjQUFjO1lBQ2QsV0FBVztZQUNYLG1CQUFtQjs7MkZBSVYsY0FBYztrQkFqQjFCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLHNCQUFzQjt3QkFDdEIsdUJBQXVCO3dCQUN2QiwyQkFBMkI7cUJBQzVCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGVBQWU7d0JBQ2YsZUFBZTt3QkFDZixrQkFBa0I7d0JBQ2xCLGNBQWM7d0JBQ2QsV0FBVzt3QkFDWCxtQkFBbUI7cUJBQ3BCO29CQUNELFNBQVMsRUFBRSxDQUFDLGVBQWUsQ0FBQztpQkFDN0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQgeyBNYXREaWFsb2dNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuaW1wb3J0IHsgTWF0Rm9ybUZpZWxkTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZm9ybS1maWVsZCc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IE1hdElucHV0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaW5wdXQnO1xuaW1wb3J0IHsgQ29uZmlybURpYWxvZ0NvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9jMy1kaWFsb2ctY29uZmlybS5jb21wb25lbnQnO1xuaW1wb3J0IHsgQzNEaWFsb2dFbWJlZENoaWxkQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2MzLWRpYWxvZy1lbWJlZC1jaGlsZC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQzNQcm9tcHREaWFsb2dDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvYzMtZGlhbG9nLXByb21wdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQzNEaWFsb2dTZXJ2aWNlIH0gZnJvbSAnLi9zZXJ2aWNlcy9jMy1kaWFsb2cuc2VydmljZSc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1xuICAgIENvbmZpcm1EaWFsb2dDb21wb25lbnQsXG4gICAgQzNQcm9tcHREaWFsb2dDb21wb25lbnQsXG4gICAgQzNEaWFsb2dFbWJlZENoaWxkQ29tcG9uZW50LFxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIE1hdERpYWxvZ01vZHVsZSxcbiAgICBNYXRCdXR0b25Nb2R1bGUsXG4gICAgTWF0Rm9ybUZpZWxkTW9kdWxlLFxuICAgIE1hdElucHV0TW9kdWxlLFxuICAgIEZvcm1zTW9kdWxlLFxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gIF0sXG4gIHByb3ZpZGVyczogW0MzRGlhbG9nU2VydmljZV0sXG59KVxuZXhwb3J0IGNsYXNzIEMzRGlhbG9nTW9kdWxlIHt9XG4iXX0=
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZGlhbG9nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1kaWFsb2cvYzMtZGlhbG9nLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDbEYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sOENBQThDLENBQUM7QUFDM0YsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDbEYsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQy9ELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7QUFxQnZELE1BQU0sT0FBTyxjQUFjOzhHQUFkLGNBQWM7K0dBQWQsY0FBYyxpQkFqQnZCLHNCQUFzQjtZQUN0Qix1QkFBdUI7WUFDdkIsMkJBQTJCLGFBRzNCLFlBQVk7WUFDWixXQUFXO1lBQ1gsZUFBZTtZQUNmLGVBQWU7WUFDZixrQkFBa0I7WUFDbEIsYUFBYTtZQUNiLGNBQWM7WUFDZCxnQkFBZ0I7WUFDaEIsbUJBQW1COytHQUlWLGNBQWMsYUFGZCxDQUFDLGVBQWUsQ0FBQyxZQVYxQixZQUFZO1lBQ1osV0FBVztZQUNYLGVBQWU7WUFDZixlQUFlO1lBQ2Ysa0JBQWtCO1lBQ2xCLGFBQWE7WUFDYixjQUFjO1lBQ2QsZ0JBQWdCO1lBQ2hCLG1CQUFtQjs7MkZBSVYsY0FBYztrQkFuQjFCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLHNCQUFzQjt3QkFDdEIsdUJBQXVCO3dCQUN2QiwyQkFBMkI7cUJBQzVCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLFdBQVc7d0JBQ1gsZUFBZTt3QkFDZixlQUFlO3dCQUNmLGtCQUFrQjt3QkFDbEIsYUFBYTt3QkFDYixjQUFjO3dCQUNkLGdCQUFnQjt3QkFDaEIsbUJBQW1CO3FCQUNwQjtvQkFDRCxTQUFTLEVBQUUsQ0FBQyxlQUFlLENBQUM7aUJBQzdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuaW1wb3J0IHsgTWF0RGlhbG9nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcbmltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBNYXRJbnB1dE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcbmltcG9ydCB7IENvbmZpcm1EaWFsb2dDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvYzMtZGlhbG9nLWNvbmZpcm0uY29tcG9uZW50JztcbmltcG9ydCB7IEMzRGlhbG9nRW1iZWRDaGlsZENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9jMy1kaWFsb2ctZW1iZWQtY2hpbGQuY29tcG9uZW50JztcbmltcG9ydCB7IEMzUHJvbXB0RGlhbG9nQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2MzLWRpYWxvZy1wcm9tcHQuY29tcG9uZW50JztcbmltcG9ydCB7IEMzRGlhbG9nU2VydmljZSB9IGZyb20gJy4vc2VydmljZXMvYzMtZGlhbG9nLnNlcnZpY2UnO1xuaW1wb3J0IHsgTWF0VG9vbGJhck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Rvb2xiYXInO1xuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBDb25maXJtRGlhbG9nQ29tcG9uZW50LFxuICAgIEMzUHJvbXB0RGlhbG9nQ29tcG9uZW50LFxuICAgIEMzRGlhbG9nRW1iZWRDaGlsZENvbXBvbmVudCxcbiAgXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBNYXRCdXR0b25Nb2R1bGUsXG4gICAgTWF0RGlhbG9nTW9kdWxlLFxuICAgIE1hdEZvcm1GaWVsZE1vZHVsZSxcbiAgICBNYXRJY29uTW9kdWxlLFxuICAgIE1hdElucHV0TW9kdWxlLFxuICAgIE1hdFRvb2xiYXJNb2R1bGUsXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgXSxcbiAgcHJvdmlkZXJzOiBbQzNEaWFsb2dTZXJ2aWNlXSxcbn0pXG5leHBvcnQgY2xhc3MgQzNEaWFsb2dNb2R1bGUge31cbiJdfQ==
@@ -24,7 +24,7 @@ export class ConfirmDialogComponent {
24
24
  {{ data.accept?.text }}
25
25
  </button>
26
26
  </mat-dialog-actions>
27
- `, isInline: true, dependencies: [{ kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: i2.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }] }); }
27
+ `, isInline: true, dependencies: [{ kind: "component", type: i2.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }] }); }
28
28
  }
29
29
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: ConfirmDialogComponent, decorators: [{
30
30
  type: Component,
@@ -2,6 +2,10 @@ import { Component, Inject, ViewChild, ViewContainerRef, } from '@angular/core';
2
2
  import { MAT_DIALOG_DATA } from '@angular/material/dialog';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "@angular/material/dialog";
5
+ import * as i2 from "@angular/common";
6
+ import * as i3 from "@angular/material/button";
7
+ import * as i4 from "@angular/material/icon";
8
+ import * as i5 from "@angular/material/toolbar";
5
9
  export class C3DialogEmbedChildComponent {
6
10
  constructor(dialogRef, data, _cdr) {
7
11
  this.dialogRef = dialogRef;
@@ -10,17 +14,66 @@ export class C3DialogEmbedChildComponent {
10
14
  }
11
15
  ngAfterViewInit() {
12
16
  this.createdComponent = this.target.createComponent(this.data.component);
17
+ // detect the inputs of the component
18
+ if (!this.createdComponent)
19
+ this.dialogRef.close(false);
20
+ if (this.data.inputs)
21
+ this._setInputs(this.data.component, this.data.inputs, this.createdComponent);
13
22
  this._cdr.detectChanges();
14
23
  }
24
+ _getInputProperties(component) {
25
+ const inputs = [];
26
+ const declaredInputs = component.prototype?.constructor['ɵcmp']?.declaredInputs;
27
+ for (const input of Object.keys(declaredInputs))
28
+ inputs.push(input);
29
+ return inputs;
30
+ }
31
+ _setInputs(component, inputs, componentRef) {
32
+ const inputProperties = this._getInputProperties(component);
33
+ for (const key of inputProperties) {
34
+ if (inputs[key]) {
35
+ componentRef.setInput(key, inputs[key]);
36
+ }
37
+ }
38
+ return component;
39
+ }
15
40
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3DialogEmbedChildComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
16
41
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.1", type: C3DialogEmbedChildComponent, selector: "C3DialogEmbedChildComponent", viewQueries: [{ propertyName: "target", first: true, predicate: ["target"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: `<mat-dialog-content>
17
- <ng-template #target></ng-template>
18
- </mat-dialog-content>`, isInline: true, dependencies: [{ kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }] }); }
42
+ <mat-toolbar *ngIf="data.toolbar" [color]="data.toolbar.color || 'default'">
43
+ <span>{{ data.toolbar.title }}</span>
44
+ <span class="spacer"></span>
45
+ <button
46
+ *ngIf="data.toolbar.closeBtn"
47
+ mat-icon-button
48
+ mat-dialog-close
49
+ color="{{ data.toolbar.closeColor }}"
50
+ >
51
+ <mat-icon>close</mat-icon>
52
+ </button>
53
+ </mat-toolbar>
54
+ <mat-dialog-content>
55
+ <ng-template #target></ng-template>
56
+ </mat-dialog-content>
57
+ </mat-dialog-content>`, isInline: true, dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i5.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }] }); }
19
58
  }
20
59
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3DialogEmbedChildComponent, decorators: [{
21
60
  type: Component,
22
61
  args: [{ selector: 'C3DialogEmbedChildComponent', template: `<mat-dialog-content>
23
- <ng-template #target></ng-template>
62
+ <mat-toolbar *ngIf="data.toolbar" [color]="data.toolbar.color || 'default'">
63
+ <span>{{ data.toolbar.title }}</span>
64
+ <span class="spacer"></span>
65
+ <button
66
+ *ngIf="data.toolbar.closeBtn"
67
+ mat-icon-button
68
+ mat-dialog-close
69
+ color="{{ data.toolbar.closeColor }}"
70
+ >
71
+ <mat-icon>close</mat-icon>
72
+ </button>
73
+ </mat-toolbar>
74
+ <mat-dialog-content>
75
+ <ng-template #target></ng-template>
76
+ </mat-dialog-content>
24
77
  </mat-dialog-content>` }]
25
78
  }], ctorParameters: () => [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
26
79
  type: Inject,
@@ -29,4 +82,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImpor
29
82
  type: ViewChild,
30
83
  args: ['target', { read: ViewContainerRef }]
31
84
  }] } });
32
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZGlhbG9nLWVtYmVkLWNoaWxkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1kaWFsb2cvY29tcG9uZW50cy9jMy1kaWFsb2ctZW1iZWQtY2hpbGQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFHTCxTQUFTLEVBRVQsTUFBTSxFQUVOLFNBQVMsRUFDVCxnQkFBZ0IsR0FDakIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFnQixlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7O0FBU3pFLE1BQU0sT0FBTywyQkFBMkI7SUFPdEMsWUFDUyxTQUFtRSxFQUVuRSxJQUVOLEVBQ08sSUFBdUI7UUFMeEIsY0FBUyxHQUFULFNBQVMsQ0FBMEQ7UUFFbkUsU0FBSSxHQUFKLElBQUksQ0FFVjtRQUNPLFNBQUksR0FBSixJQUFJLENBQW1CO0lBQzlCLENBQUM7SUFFSixlQUFlO1FBQ2IsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDekUsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUM1QixDQUFDOzhHQW5CVSwyQkFBMkIsOENBUzVCLGVBQWU7a0dBVGQsMkJBQTJCLGdKQUdULGdCQUFnQiw2QkFSbkM7O3dCQUVZOzsyRkFHWCwyQkFBMkI7a0JBUHZDLFNBQVM7K0JBQ0UsNkJBQTZCLFlBQzdCOzt3QkFFWTs7MEJBWW5CLE1BQU07MkJBQUMsZUFBZTt5RUFOd0IsTUFBTTtzQkFBdEQsU0FBUzt1QkFBQyxRQUFRLEVBQUUsRUFBRSxJQUFJLEVBQUUsZ0JBQWdCLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBBZnRlclZpZXdJbml0LFxuICBDaGFuZ2VEZXRlY3RvclJlZixcbiAgQ29tcG9uZW50LFxuICBDb21wb25lbnRSZWYsXG4gIEluamVjdCxcbiAgVHlwZSxcbiAgVmlld0NoaWxkLFxuICBWaWV3Q29udGFpbmVyUmVmLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hdERpYWxvZ1JlZiwgTUFUX0RJQUxPR19EQVRBIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnQzNEaWFsb2dFbWJlZENoaWxkQ29tcG9uZW50JyxcbiAgdGVtcGxhdGU6IGA8bWF0LWRpYWxvZy1jb250ZW50PlxuICAgIDxuZy10ZW1wbGF0ZSAjdGFyZ2V0PjwvbmctdGVtcGxhdGU+XG4gIDwvbWF0LWRpYWxvZy1jb250ZW50PmAsXG4gIHN0eWxlczogW10sXG59KVxuZXhwb3J0IGNsYXNzIEMzRGlhbG9nRW1iZWRDaGlsZENvbXBvbmVudDxDb21wb25lbnlUeXBlPlxuICBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXRcbntcbiAgQFZpZXdDaGlsZCgndGFyZ2V0JywgeyByZWFkOiBWaWV3Q29udGFpbmVyUmVmIH0pIHRhcmdldCE6IFZpZXdDb250YWluZXJSZWY7XG5cbiAgY3JlYXRlZENvbXBvbmVudD86IENvbXBvbmVudFJlZjxDb21wb25lbnlUeXBlPjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgZGlhbG9nUmVmOiBNYXREaWFsb2dSZWY8QzNEaWFsb2dFbWJlZENoaWxkQ29tcG9uZW50PENvbXBvbmVueVR5cGU+PixcbiAgICBASW5qZWN0KE1BVF9ESUFMT0dfREFUQSlcbiAgICBwdWJsaWMgZGF0YToge1xuICAgICAgY29tcG9uZW50OiBUeXBlPENvbXBvbmVueVR5cGU+O1xuICAgIH0sXG4gICAgcHJpdmF0ZSBfY2RyOiBDaGFuZ2VEZXRlY3RvclJlZlxuICApIHt9XG5cbiAgbmdBZnRlclZpZXdJbml0KCkge1xuICAgIHRoaXMuY3JlYXRlZENvbXBvbmVudCA9IHRoaXMudGFyZ2V0LmNyZWF0ZUNvbXBvbmVudCh0aGlzLmRhdGEuY29tcG9uZW50KTtcbiAgICB0aGlzLl9jZHIuZGV0ZWN0Q2hhbmdlcygpO1xuICB9XG59XG4iXX0=
85
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZGlhbG9nLWVtYmVkLWNoaWxkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1kaWFsb2cvY29tcG9uZW50cy9jMy1kaWFsb2ctZW1iZWQtY2hpbGQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFHTCxTQUFTLEVBRVQsTUFBTSxFQUVOLFNBQVMsRUFDVCxnQkFBZ0IsR0FDakIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFnQixlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7Ozs7OztBQXVCekUsTUFBTSxPQUFPLDJCQUEyQjtJQU90QyxZQUNTLFNBQXVELEVBRXZELElBU04sRUFDTyxJQUF1QjtRQVp4QixjQUFTLEdBQVQsU0FBUyxDQUE4QztRQUV2RCxTQUFJLEdBQUosSUFBSSxDQVNWO1FBQ08sU0FBSSxHQUFKLElBQUksQ0FBbUI7SUFDOUIsQ0FBQztJQUVKLGVBQWU7UUFDYixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUV6RSxxQ0FBcUM7UUFDckMsSUFBSSxDQUFDLElBQUksQ0FBQyxnQkFBZ0I7WUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUV4RCxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTTtZQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFFcEcsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUM1QixDQUFDO0lBRU8sbUJBQW1CLENBQUksU0FBa0I7UUFDL0MsTUFBTSxNQUFNLEdBQWEsRUFBRSxDQUFDO1FBQzVCLE1BQU0sY0FBYyxHQUNsQixTQUFTLENBQUMsU0FBUyxFQUFFLFdBQVcsQ0FBQyxNQUFNLENBQUMsRUFBRSxjQUFjLENBQUM7UUFDM0QsS0FBSyxNQUFNLEtBQUssSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQztZQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFcEUsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQztJQUVPLFVBQVUsQ0FDaEIsU0FBa0IsRUFDbEIsTUFBeUMsRUFDekMsWUFBNkI7UUFFN0IsTUFBTSxlQUFlLEdBQUcsSUFBSSxDQUFDLG1CQUFtQixDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQzVELEtBQUssTUFBTSxHQUFHLElBQUksZUFBZSxFQUFFLENBQUM7WUFDbEMsSUFBSSxNQUFNLENBQUMsR0FBYyxDQUFDLEVBQUUsQ0FBQztnQkFDM0IsWUFBWSxDQUFDLFFBQVEsQ0FBQyxHQUFHLEVBQUUsTUFBTSxDQUFDLEdBQWMsQ0FBQyxDQUFDLENBQUM7WUFDckQsQ0FBQztRQUNILENBQUM7UUFDRCxPQUFPLFNBQVMsQ0FBQztJQUNuQixDQUFDOzhHQXZEVSwyQkFBMkIsOENBUzVCLGVBQWU7a0dBVGQsMkJBQTJCLGdKQUdULGdCQUFnQiw2QkF0Qm5DOzs7Ozs7Ozs7Ozs7Ozs7O3dCQWdCWTs7MkZBR1gsMkJBQTJCO2tCQXJCdkMsU0FBUzsrQkFDRSw2QkFBNkIsWUFDN0I7Ozs7Ozs7Ozs7Ozs7Ozs7d0JBZ0JZOzswQkFZbkIsTUFBTTsyQkFBQyxlQUFlO3lFQU53QixNQUFNO3NCQUF0RCxTQUFTO3VCQUFDLFFBQVEsRUFBRSxFQUFFLElBQUksRUFBRSxnQkFBZ0IsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudFR5cGUgfSBmcm9tICdAYW5ndWxhci9jZGsvcG9ydGFsJztcbmltcG9ydCB7XG4gIEFmdGVyVmlld0luaXQsXG4gIENoYW5nZURldGVjdG9yUmVmLFxuICBDb21wb25lbnQsXG4gIENvbXBvbmVudFJlZixcbiAgSW5qZWN0LFxuICBUeXBlLFxuICBWaWV3Q2hpbGQsXG4gIFZpZXdDb250YWluZXJSZWYsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF0RGlhbG9nUmVmLCBNQVRfRElBTE9HX0RBVEEgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdDM0RpYWxvZ0VtYmVkQ2hpbGRDb21wb25lbnQnLFxuICB0ZW1wbGF0ZTogYDxtYXQtZGlhbG9nLWNvbnRlbnQ+XG4gICAgPG1hdC10b29sYmFyICpuZ0lmPVwiZGF0YS50b29sYmFyXCIgW2NvbG9yXT1cImRhdGEudG9vbGJhci5jb2xvciB8fCAnZGVmYXVsdCdcIj5cbiAgICAgIDxzcGFuPnt7IGRhdGEudG9vbGJhci50aXRsZSB9fTwvc3Bhbj5cbiAgICAgIDxzcGFuIGNsYXNzPVwic3BhY2VyXCI+PC9zcGFuPlxuICAgICAgPGJ1dHRvblxuICAgICAgICAqbmdJZj1cImRhdGEudG9vbGJhci5jbG9zZUJ0blwiXG4gICAgICAgIG1hdC1pY29uLWJ1dHRvblxuICAgICAgICBtYXQtZGlhbG9nLWNsb3NlXG4gICAgICAgIGNvbG9yPVwie3sgZGF0YS50b29sYmFyLmNsb3NlQ29sb3IgfX1cIlxuICAgICAgPlxuICAgICAgICA8bWF0LWljb24+Y2xvc2U8L21hdC1pY29uPlxuICAgICAgPC9idXR0b24+XG4gICAgPC9tYXQtdG9vbGJhcj5cbiAgICA8bWF0LWRpYWxvZy1jb250ZW50PlxuICAgICAgPG5nLXRlbXBsYXRlICN0YXJnZXQ+PC9uZy10ZW1wbGF0ZT5cbiAgICA8L21hdC1kaWFsb2ctY29udGVudD5cbiAgPC9tYXQtZGlhbG9nLWNvbnRlbnQ+YCxcbiAgc3R5bGVzOiBbXSxcbn0pXG5leHBvcnQgY2xhc3MgQzNEaWFsb2dFbWJlZENoaWxkQ29tcG9uZW50PEM+XG4gIGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdFxue1xuICBAVmlld0NoaWxkKCd0YXJnZXQnLCB7IHJlYWQ6IFZpZXdDb250YWluZXJSZWYgfSkgdGFyZ2V0ITogVmlld0NvbnRhaW5lclJlZjtcblxuICBjcmVhdGVkQ29tcG9uZW50PzogQ29tcG9uZW50UmVmPEM+O1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyBkaWFsb2dSZWY6IE1hdERpYWxvZ1JlZjxDM0RpYWxvZ0VtYmVkQ2hpbGRDb21wb25lbnQ8Qz4+LFxuICAgIEBJbmplY3QoTUFUX0RJQUxPR19EQVRBKVxuICAgIHB1YmxpYyBkYXRhOiB7XG4gICAgICBjb21wb25lbnQ6IENvbXBvbmVudFR5cGU8Qz47XG4gICAgICBpbnB1dHM/OiBQYXJ0aWFsPFJlY29yZDxrZXlvZiBDLCB1bmtub3duPj47XG4gICAgICB0b29sYmFyPzoge1xuICAgICAgICB0aXRsZTogc3RyaW5nO1xuICAgICAgICBjbG9zZUJ0bj86IGJvb2xlYW47XG4gICAgICAgIGNsb3NlQ29sb3I/OiBzdHJpbmc7XG4gICAgICAgIGNvbG9yPzogc3RyaW5nO1xuICAgICAgfVxuICAgIH0sXG4gICAgcHJpdmF0ZSBfY2RyOiBDaGFuZ2VEZXRlY3RvclJlZlxuICApIHt9XG5cbiAgbmdBZnRlclZpZXdJbml0KCkge1xuICAgIHRoaXMuY3JlYXRlZENvbXBvbmVudCA9IHRoaXMudGFyZ2V0LmNyZWF0ZUNvbXBvbmVudCh0aGlzLmRhdGEuY29tcG9uZW50KTtcblxuICAgIC8vIGRldGVjdCB0aGUgaW5wdXRzIG9mIHRoZSBjb21wb25lbnRcbiAgICBpZiAoIXRoaXMuY3JlYXRlZENvbXBvbmVudCkgdGhpcy5kaWFsb2dSZWYuY2xvc2UoZmFsc2UpO1xuXG4gICAgaWYgKHRoaXMuZGF0YS5pbnB1dHMpIHRoaXMuX3NldElucHV0cyh0aGlzLmRhdGEuY29tcG9uZW50LCB0aGlzLmRhdGEuaW5wdXRzLCB0aGlzLmNyZWF0ZWRDb21wb25lbnQpO1xuXG4gICAgdGhpcy5fY2RyLmRldGVjdENoYW5nZXMoKTtcbiAgfVxuXG4gIHByaXZhdGUgX2dldElucHV0UHJvcGVydGllczxDPihjb21wb25lbnQ6IFR5cGU8Qz4pIHtcbiAgICBjb25zdCBpbnB1dHM6IHN0cmluZ1tdID0gW107XG4gICAgY29uc3QgZGVjbGFyZWRJbnB1dHM6IFBhcnRpYWw8UmVjb3JkPGtleW9mIEMsIHN0cmluZz4+ID1cbiAgICAgIGNvbXBvbmVudC5wcm90b3R5cGU/LmNvbnN0cnVjdG9yWyfJtWNtcCddPy5kZWNsYXJlZElucHV0cztcbiAgICBmb3IgKGNvbnN0IGlucHV0IG9mIE9iamVjdC5rZXlzKGRlY2xhcmVkSW5wdXRzKSkgaW5wdXRzLnB1c2goaW5wdXQpO1xuXG4gICAgcmV0dXJuIGlucHV0cztcbiAgfVxuXG4gIHByaXZhdGUgX3NldElucHV0czxDPihcbiAgICBjb21wb25lbnQ6IFR5cGU8Qz4sXG4gICAgaW5wdXRzOiBQYXJ0aWFsPFJlY29yZDxrZXlvZiBDLCB1bmtub3duPj4sXG4gICAgY29tcG9uZW50UmVmOiBDb21wb25lbnRSZWY8Qz5cbiAgKSB7XG4gICAgY29uc3QgaW5wdXRQcm9wZXJ0aWVzID0gdGhpcy5fZ2V0SW5wdXRQcm9wZXJ0aWVzKGNvbXBvbmVudCk7XG4gICAgZm9yIChjb25zdCBrZXkgb2YgaW5wdXRQcm9wZXJ0aWVzKSB7XG4gICAgICBpZiAoaW5wdXRzW2tleSBhcyBrZXlvZiBDXSkge1xuICAgICAgICBjb21wb25lbnRSZWYuc2V0SW5wdXQoa2V5LCBpbnB1dHNba2V5IGFzIGtleW9mIENdKTtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIGNvbXBvbmVudDtcbiAgfVxufVxuIl19
@@ -51,7 +51,7 @@ export class C3PromptDialogComponent {
51
51
  {{ data.accept?.text }}
52
52
  </button>
53
53
  </mat-dialog-actions>
54
- `, isInline: true, styles: ["mat-form-field{width:100%}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: i4.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i5.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }, { kind: "directive", type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i7.CdkTextareaAutosize, selector: "textarea[cdkTextareaAutosize]", inputs: ["cdkAutosizeMinRows", "cdkAutosizeMaxRows", "cdkTextareaAutosize", "placeholder"], exportAs: ["cdkTextareaAutosize"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }] }); }
54
+ `, isInline: true, styles: ["mat-form-field{width:100%}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "component", type: i4.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: i5.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }, { kind: "directive", type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i7.CdkTextareaAutosize, selector: "textarea[cdkTextareaAutosize]", inputs: ["cdkAutosizeMinRows", "cdkAutosizeMaxRows", "cdkTextareaAutosize", "placeholder"], exportAs: ["cdkTextareaAutosize"] }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }] }); }
55
55
  }
56
56
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3PromptDialogComponent, decorators: [{
57
57
  type: Component,
@@ -2,8 +2,8 @@ import { Injectable, inject } from '@angular/core';
2
2
  import { MatDialog } from '@angular/material/dialog';
3
3
  import { ConfirmDialogComponent, } from '../components/c3-dialog-confirm.component';
4
4
  import { C3PromptDialogComponent, } from '../components/c3-dialog-prompt.component';
5
- import { C3ExtandedPromise } from '../../c3-extanded-promise';
6
5
  import 'reflect-metadata';
6
+ import { C3DialogEmbedChildComponent } from '../components/c3-dialog-embed-child.component';
7
7
  import * as i0 from "@angular/core";
8
8
  export class C3DialogService {
9
9
  #dialog = inject(MatDialog);
@@ -28,7 +28,7 @@ export class C3DialogService {
28
28
  },
29
29
  },
30
30
  });
31
- return new C3ExtandedPromise((resolve, reject) => {
31
+ return new Promise((resolve, reject) => {
32
32
  dialogRef.afterClosed().subscribe({
33
33
  next: (value) => {
34
34
  resolve(value);
@@ -64,7 +64,7 @@ export class C3DialogService {
64
64
  },
65
65
  },
66
66
  });
67
- return new C3ExtandedPromise((resolve, reject) => {
67
+ return new Promise((resolve, reject) => {
68
68
  dialogRef.afterClosed().subscribe({
69
69
  next: (value) => {
70
70
  if (value === undefined) {
@@ -78,38 +78,18 @@ export class C3DialogService {
78
78
  });
79
79
  });
80
80
  }
81
- createDialogFromComponent({ data, ...config }) {
82
- if (!data?.component) {
81
+ /**
82
+ * Opens a dialog with the provided component and inputs.
83
+ * @param {MatDialogConfig<{ component: ComponentType<C>; inputs?: Partial<Record<keyof C, unknown>>; }>} config Configuration options for the dialog. See MatDialogConfig below.
84
+ * @returns {MatDialogRef<C>} The dialog reference.
85
+ */
86
+ createDialogFromComponent(config) {
87
+ if (!config.data?.component) {
83
88
  throw new Error('No component provided');
84
89
  }
85
- const { component, ..._data } = data;
86
- const dialog = this.#dialog.open(component, {
87
- ...config,
88
- });
89
- // detect the inputs of the component
90
- const { componentRef } = dialog;
91
- if (!componentRef)
92
- return dialog;
93
- if (_data.inputs)
94
- this._setInputs(component, _data.inputs, componentRef);
90
+ const dialog = this.#dialog.open((C3DialogEmbedChildComponent), config);
95
91
  return dialog;
96
92
  }
97
- _getInputProperties(component) {
98
- const inputs = [];
99
- const declaredInputs = component.prototype?.constructor['ɵcmp']?.declaredInputs;
100
- for (const input of Object.keys(declaredInputs))
101
- inputs.push(input);
102
- return inputs;
103
- }
104
- _setInputs(component, inputs, componentRef) {
105
- const inputProperties = this._getInputProperties(component);
106
- for (const key of inputProperties) {
107
- if (inputs[key]) {
108
- componentRef.setInput(key, inputs[key]);
109
- }
110
- }
111
- return component;
112
- }
113
93
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3DialogService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
114
94
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3DialogService, providedIn: 'root' }); }
115
95
  }
@@ -119,4 +99,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImpor
119
99
  providedIn: 'root',
120
100
  }]
121
101
  }] });
122
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"c3-dialog.service.js","sourceRoot":"","sources":["../../../../../../projects/c3-components/src/lib/c3-dialog/services/c3-dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentRef, Injectable, Type, inject } from '@angular/core';\nimport { MatDialog, MatDialogConfig } from '@angular/material/dialog';\nimport {\n  ConfirmConfig,\n  ConfirmDialogComponent,\n} from '../components/c3-dialog-confirm.component';\nimport {\n  PromptConfig,\n  C3PromptDialogComponent,\n} from '../components/c3-dialog-prompt.component';\nimport { C3ExtandedPromise } from '../../c3-extanded-promise';\nimport { lastValueFrom, map } from 'rxjs';\nimport { ComponentType } from '@angular/cdk/portal';\nimport 'reflect-metadata';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class C3DialogService {\n  readonly #dialog = inject(MatDialog);\n\n  /**\n   * Opens a confirm dialog and returns a promise that resolves to a boolean indicating whether the user accepted or rejected the confirmation.\n   *\n   * @param {ConfirmConfig} data Configuration options for the confirm dialog. See ConfirmConfig below.\n   * @returns {C3ExtendedPromise<boolean>} A promise that resolves to `true` if the user accepted the confirmation, and `false` otherwise.\n   */\n  public confirm(data: ConfirmConfig) {\n    const dialogRef = this.#dialog.open(ConfirmDialogComponent, {\n      width: data.width || '250px',\n      data: {\n        text: data.text,\n        reject: {\n          color:\n            data.reject && data.reject.color ? data.reject.color : undefined,\n          text: (data.reject && data.reject.text) || 'Annuler',\n        },\n        accept: {\n          color: (data.accept && data.accept.color) || 'primary',\n          text: (data.accept && data.accept.text) || 'Accepter',\n        },\n      },\n    });\n\n    return new C3ExtandedPromise<boolean>((resolve, reject) => {\n      dialogRef.afterClosed().subscribe({\n        next: (value) => {\n          resolve(value);\n        },\n        error: reject,\n      });\n    });\n  }\n\n  /**\n   * Opens a prompt dialog and returns a promise that resolves to the value entered by the user, or `false` if the user cancelled the prompt.\n   *\n   * @param {PromptConfig} data Configuration options for the prompt dialog. See PromptConfig below.\n   * @returns {C3ExtendedPromise<false | T>} A promise that resolves to the value entered by the user, or `false` if the user cancelled the prompt.\n   */\n  public prompt(data: PromptConfig): C3ExtandedPromise<false | string> {\n    const dialogRef = this.#dialog.open<C3PromptDialogComponent, any, string>(\n      C3PromptDialogComponent,\n      {\n        width: data.width || '250px',\n        maxWidth: data.maxWidth || '100vw',\n        data: {\n          text: data.text,\n          defaultValue: data.defaultValue,\n          placeholder: data.placeholder,\n          multiline: data.multiline,\n          validators: data.validators,\n          required: data.required,\n          reject: {\n            color:\n              data.reject && data.reject.color ? data.reject.color : undefined,\n            text: (data.reject && data.reject.text) || 'Annuler',\n          },\n          accept: {\n            color: (data.accept && data.accept.color) || 'primary',\n            text: (data.accept && data.accept.text) || 'Accepter',\n          },\n        },\n      }\n    );\n\n    return new C3ExtandedPromise<string | false>((resolve, reject) => {\n      dialogRef.afterClosed().subscribe({\n        next: (value) => {\n          if (value === undefined) {\n            resolve(false);\n          } else {\n            resolve(value);\n          }\n        },\n        error: reject,\n      });\n    }\n    );\n  }\n\n  createDialogFromComponent<C>({\n    data,\n    ...config\n  }: MatDialogConfig<{\n    component: ComponentType<C>;\n    inputs?: Partial<Record<keyof C, unknown>>;\n  }>) {\n    if (!data?.component) {\n      throw new Error('No component provided');\n    }\n\n    const { component, ..._data } = data;\n    const dialog = this.#dialog.open<C>(component, {\n      ...config,\n    });\n\n    // detect the inputs of the component\n    const { componentRef } = dialog;\n    if (!componentRef) return dialog;\n\n    if (_data.inputs) this._setInputs(component, _data.inputs, componentRef);\n\n    return dialog;\n  }\n\n  private _getInputProperties<C>(component: Type<C>) {\n    const inputs: string[] = [];\n    const declaredInputs: Partial<Record<keyof C, string>> =\n      component.prototype?.constructor['ɵcmp']?.declaredInputs;\n    for (const input of Object.keys(declaredInputs)) inputs.push(input);\n\n    return inputs;\n  }\n\n  private _setInputs<C>(\n    component: Type<C>,\n    inputs: Partial<Record<keyof C, unknown>>,\n    componentRef: ComponentRef<C>\n  ) {\n    const inputProperties = this._getInputProperties(component);\n    for (const key of inputProperties) {\n      if (inputs[key as keyof C]) {\n        componentRef.setInput(key, inputs[key as keyof C]);\n      }\n    }\n    return component;\n  }\n}\n"]}
102
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"c3-dialog.service.js","sourceRoot":"","sources":["../../../../../../projects/c3-components/src/lib/c3-dialog/services/c3-dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentRef, Injectable, Type, inject } from '@angular/core';\nimport { MatDialog, MatDialogConfig } from '@angular/material/dialog';\nimport {\n  ConfirmConfig,\n  ConfirmDialogComponent,\n} from '../components/c3-dialog-confirm.component';\nimport {\n  PromptConfig,\n  C3PromptDialogComponent,\n} from '../components/c3-dialog-prompt.component';\nimport { ComponentType } from '@angular/cdk/portal';\nimport 'reflect-metadata';\nimport { C3DialogEmbedChildComponent } from '../components/c3-dialog-embed-child.component';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class C3DialogService {\n  readonly #dialog = inject(MatDialog);\n\n  /**\n   * Opens a confirm dialog and returns a promise that resolves to a boolean indicating whether the user accepted or rejected the confirmation.\n   *\n   * @param {ConfirmConfig} data Configuration options for the confirm dialog. See ConfirmConfig below.\n   * @returns {C3ExtendedPromise<boolean>} A promise that resolves to `true` if the user accepted the confirmation, and `false` otherwise.\n   */\n  public confirm(data: ConfirmConfig) {\n    const dialogRef = this.#dialog.open(ConfirmDialogComponent, {\n      width: data.width || '250px',\n      data: {\n        text: data.text,\n        reject: {\n          color:\n            data.reject && data.reject.color ? data.reject.color : undefined,\n          text: (data.reject && data.reject.text) || 'Annuler',\n        },\n        accept: {\n          color: (data.accept && data.accept.color) || 'primary',\n          text: (data.accept && data.accept.text) || 'Accepter',\n        },\n      },\n    });\n\n    return new Promise<boolean>((resolve, reject) => {\n      dialogRef.afterClosed().subscribe({\n        next: (value) => {\n          resolve(value);\n        },\n        error: reject,\n      });\n    });\n  }\n\n  /**\n   * Opens a prompt dialog and returns a promise that resolves to the value entered by the user, or `false` if the user cancelled the prompt.\n   *\n   * @param {PromptConfig} data Configuration options for the prompt dialog. See PromptConfig below.\n   * @returns {C3ExtendedPromise<false | T>} A promise that resolves to the value entered by the user, or `false` if the user cancelled the prompt.\n   */\n  public prompt(data: PromptConfig): Promise<false | string> {\n    const dialogRef = this.#dialog.open<C3PromptDialogComponent, any, string>(\n      C3PromptDialogComponent,\n      {\n        width: data.width || '250px',\n        maxWidth: data.maxWidth || '100vw',\n        data: {\n          text: data.text,\n          defaultValue: data.defaultValue,\n          placeholder: data.placeholder,\n          multiline: data.multiline,\n          validators: data.validators,\n          required: data.required,\n          reject: {\n            color:\n              data.reject && data.reject.color ? data.reject.color : undefined,\n            text: (data.reject && data.reject.text) || 'Annuler',\n          },\n          accept: {\n            color: (data.accept && data.accept.color) || 'primary',\n            text: (data.accept && data.accept.text) || 'Accepter',\n          },\n        },\n      }\n    );\n\n    return new Promise<string | false>((resolve, reject) => {\n      dialogRef.afterClosed().subscribe({\n        next: (value) => {\n          if (value === undefined) {\n            resolve(false);\n          } else {\n            resolve(value);\n          }\n        },\n        error: reject,\n      });\n    }\n    );\n  }\n\n  /**\n   * Opens a dialog with the provided component and inputs.\n   * @param {MatDialogConfig<{ component: ComponentType<C>; inputs?: Partial<Record<keyof C, unknown>>; }>} config Configuration options for the dialog. See MatDialogConfig below.\n   * @returns {MatDialogRef<C>} The dialog reference.\n   */\n  createDialogFromComponent<C>(config: MatDialogConfig<{\n    component: ComponentType<C>;\n    inputs?: Partial<Record<keyof C, unknown>>;\n    toolbar?: {\n      title: string;\n      closeBtn?: boolean;\n      closeColor?: string;\n      color?: string;\n    }\n  }>) {\n    if (!config.data?.component) {\n      throw new Error('No component provided');\n    }\n\n    const dialog = this.#dialog.open(C3DialogEmbedChildComponent<C>, config);\n\n    return dialog;\n  }\n}\n"]}
@@ -8,7 +8,7 @@ import * as i1$1 from '@angular/cdk/overlay';
8
8
  import { OverlayConfig, OverlayModule } from '@angular/cdk/overlay';
9
9
  import { coerceBooleanProperty } from '@angular/cdk/coercion';
10
10
  import { TemplatePortal } from '@angular/cdk/portal';
11
- import { Subscription, Subject, merge, takeUntil, from, BehaviorSubject, filter, skip, debounceTime, mergeMap, tap, map } from 'rxjs';
11
+ import { Subscription, Subject, merge, takeUntil, BehaviorSubject, filter, skip, debounceTime, mergeMap, tap, map } from 'rxjs';
12
12
  import * as i1$2 from '@angular/material/dialog';
13
13
  import { MAT_DIALOG_DATA, MatDialog, MatDialogModule } from '@angular/material/dialog';
14
14
  import * as i2 from '@angular/material/button';
@@ -18,16 +18,17 @@ import { MatFormFieldModule } from '@angular/material/form-field';
18
18
  import * as i6 from '@angular/material/input';
19
19
  import { MatInputModule } from '@angular/material/input';
20
20
  import * as i7 from '@angular/cdk/text-field';
21
+ import * as i4 from '@angular/material/icon';
22
+ import { MatIconModule } from '@angular/material/icon';
23
+ import * as i5$1 from '@angular/material/toolbar';
24
+ import { MatToolbarModule } from '@angular/material/toolbar';
21
25
  import 'reflect-metadata';
22
26
  import * as i1$4 from '@angular/common/http';
23
27
  import { HttpClient, provideHttpClient, withInterceptorsFromDi } from '@angular/common/http';
24
28
  import * as i1$3 from '@angular/platform-browser';
25
- import * as i3 from '@angular/material/icon';
26
- import { MatIconModule } from '@angular/material/icon';
27
- import * as i4 from '@angular/material/tooltip';
29
+ import * as i4$1 from '@angular/material/tooltip';
28
30
  import { MatTooltipModule } from '@angular/material/tooltip';
29
31
  import autoAnimate from '@formkit/auto-animate';
30
- import { MatToolbarModule } from '@angular/material/toolbar';
31
32
 
32
33
  class C3DropdownComponent {
33
34
  constructor(_changeDetectorRef) {
@@ -226,7 +227,7 @@ class ConfirmDialogComponent {
226
227
  {{ data.accept?.text }}
227
228
  </button>
228
229
  </mat-dialog-actions>
229
- `, isInline: true, dependencies: [{ kind: "directive", type: i1$2.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1$2.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1$2.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: i2.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }] }); }
230
+ `, isInline: true, dependencies: [{ kind: "component", type: i2.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "directive", type: i1$2.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1$2.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1$2.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }] }); }
230
231
  }
231
232
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: ConfirmDialogComponent, decorators: [{
232
233
  type: Component,
@@ -294,7 +295,7 @@ class C3PromptDialogComponent {
294
295
  {{ data.accept?.text }}
295
296
  </button>
296
297
  </mat-dialog-actions>
297
- `, isInline: true, styles: ["mat-form-field{width:100%}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$2.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1$2.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1$2.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1$2.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: i2.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i5.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }, { kind: "directive", type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i7.CdkTextareaAutosize, selector: "textarea[cdkTextareaAutosize]", inputs: ["cdkAutosizeMinRows", "cdkAutosizeMaxRows", "cdkTextareaAutosize", "placeholder"], exportAs: ["cdkTextareaAutosize"] }, { kind: "directive", type: i2$1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2$1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }] }); }
298
+ `, isInline: true, styles: ["mat-form-field{width:100%}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2$1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "component", type: i2.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "directive", type: i1$2.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1$2.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1$2.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1$2.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: i5.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }, { kind: "directive", type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i7.CdkTextareaAutosize, selector: "textarea[cdkTextareaAutosize]", inputs: ["cdkAutosizeMinRows", "cdkAutosizeMaxRows", "cdkTextareaAutosize", "placeholder"], exportAs: ["cdkTextareaAutosize"] }, { kind: "directive", type: i2$1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }] }); }
298
299
  }
299
300
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3PromptDialogComponent, decorators: [{
300
301
  type: Component,
@@ -344,17 +345,66 @@ class C3DialogEmbedChildComponent {
344
345
  }
345
346
  ngAfterViewInit() {
346
347
  this.createdComponent = this.target.createComponent(this.data.component);
348
+ // detect the inputs of the component
349
+ if (!this.createdComponent)
350
+ this.dialogRef.close(false);
351
+ if (this.data.inputs)
352
+ this._setInputs(this.data.component, this.data.inputs, this.createdComponent);
347
353
  this._cdr.detectChanges();
348
354
  }
355
+ _getInputProperties(component) {
356
+ const inputs = [];
357
+ const declaredInputs = component.prototype?.constructor['ɵcmp']?.declaredInputs;
358
+ for (const input of Object.keys(declaredInputs))
359
+ inputs.push(input);
360
+ return inputs;
361
+ }
362
+ _setInputs(component, inputs, componentRef) {
363
+ const inputProperties = this._getInputProperties(component);
364
+ for (const key of inputProperties) {
365
+ if (inputs[key]) {
366
+ componentRef.setInput(key, inputs[key]);
367
+ }
368
+ }
369
+ return component;
370
+ }
349
371
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3DialogEmbedChildComponent, deps: [{ token: i1$2.MatDialogRef }, { token: MAT_DIALOG_DATA }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
350
372
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.1", type: C3DialogEmbedChildComponent, selector: "C3DialogEmbedChildComponent", viewQueries: [{ propertyName: "target", first: true, predicate: ["target"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: `<mat-dialog-content>
351
- <ng-template #target></ng-template>
352
- </mat-dialog-content>`, isInline: true, dependencies: [{ kind: "directive", type: i1$2.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }] }); }
373
+ <mat-toolbar *ngIf="data.toolbar" [color]="data.toolbar.color || 'default'">
374
+ <span>{{ data.toolbar.title }}</span>
375
+ <span class="spacer"></span>
376
+ <button
377
+ *ngIf="data.toolbar.closeBtn"
378
+ mat-icon-button
379
+ mat-dialog-close
380
+ color="{{ data.toolbar.closeColor }}"
381
+ >
382
+ <mat-icon>close</mat-icon>
383
+ </button>
384
+ </mat-toolbar>
385
+ <mat-dialog-content>
386
+ <ng-template #target></ng-template>
387
+ </mat-dialog-content>
388
+ </mat-dialog-content>`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "directive", type: i1$2.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1$2.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i5$1.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }] }); }
353
389
  }
354
390
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3DialogEmbedChildComponent, decorators: [{
355
391
  type: Component,
356
392
  args: [{ selector: 'C3DialogEmbedChildComponent', template: `<mat-dialog-content>
357
- <ng-template #target></ng-template>
393
+ <mat-toolbar *ngIf="data.toolbar" [color]="data.toolbar.color || 'default'">
394
+ <span>{{ data.toolbar.title }}</span>
395
+ <span class="spacer"></span>
396
+ <button
397
+ *ngIf="data.toolbar.closeBtn"
398
+ mat-icon-button
399
+ mat-dialog-close
400
+ color="{{ data.toolbar.closeColor }}"
401
+ >
402
+ <mat-icon>close</mat-icon>
403
+ </button>
404
+ </mat-toolbar>
405
+ <mat-dialog-content>
406
+ <ng-template #target></ng-template>
407
+ </mat-dialog-content>
358
408
  </mat-dialog-content>` }]
359
409
  }], ctorParameters: () => [{ type: i1$2.MatDialogRef }, { type: undefined, decorators: [{
360
410
  type: Inject,
@@ -364,15 +414,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImpor
364
414
  args: ['target', { read: ViewContainerRef }]
365
415
  }] } });
366
416
 
367
- class C3ExtandedPromise extends Promise {
368
- constructor(executor) {
369
- super(executor);
370
- }
371
- toObservable() {
372
- return from(this);
373
- }
374
- }
375
-
376
417
  class C3DialogService {
377
418
  #dialog = inject(MatDialog);
378
419
  /**
@@ -396,7 +437,7 @@ class C3DialogService {
396
437
  },
397
438
  },
398
439
  });
399
- return new C3ExtandedPromise((resolve, reject) => {
440
+ return new Promise((resolve, reject) => {
400
441
  dialogRef.afterClosed().subscribe({
401
442
  next: (value) => {
402
443
  resolve(value);
@@ -432,7 +473,7 @@ class C3DialogService {
432
473
  },
433
474
  },
434
475
  });
435
- return new C3ExtandedPromise((resolve, reject) => {
476
+ return new Promise((resolve, reject) => {
436
477
  dialogRef.afterClosed().subscribe({
437
478
  next: (value) => {
438
479
  if (value === undefined) {
@@ -446,38 +487,18 @@ class C3DialogService {
446
487
  });
447
488
  });
448
489
  }
449
- createDialogFromComponent({ data, ...config }) {
450
- if (!data?.component) {
490
+ /**
491
+ * Opens a dialog with the provided component and inputs.
492
+ * @param {MatDialogConfig<{ component: ComponentType<C>; inputs?: Partial<Record<keyof C, unknown>>; }>} config Configuration options for the dialog. See MatDialogConfig below.
493
+ * @returns {MatDialogRef<C>} The dialog reference.
494
+ */
495
+ createDialogFromComponent(config) {
496
+ if (!config.data?.component) {
451
497
  throw new Error('No component provided');
452
498
  }
453
- const { component, ..._data } = data;
454
- const dialog = this.#dialog.open(component, {
455
- ...config,
456
- });
457
- // detect the inputs of the component
458
- const { componentRef } = dialog;
459
- if (!componentRef)
460
- return dialog;
461
- if (_data.inputs)
462
- this._setInputs(component, _data.inputs, componentRef);
499
+ const dialog = this.#dialog.open((C3DialogEmbedChildComponent), config);
463
500
  return dialog;
464
501
  }
465
- _getInputProperties(component) {
466
- const inputs = [];
467
- const declaredInputs = component.prototype?.constructor['ɵcmp']?.declaredInputs;
468
- for (const input of Object.keys(declaredInputs))
469
- inputs.push(input);
470
- return inputs;
471
- }
472
- _setInputs(component, inputs, componentRef) {
473
- const inputProperties = this._getInputProperties(component);
474
- for (const key of inputProperties) {
475
- if (inputs[key]) {
476
- componentRef.setInput(key, inputs[key]);
477
- }
478
- }
479
- return component;
480
- }
481
502
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3DialogService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
482
503
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3DialogService, providedIn: 'root' }); }
483
504
  }
@@ -493,18 +514,22 @@ class C3DialogModule {
493
514
  static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.1", ngImport: i0, type: C3DialogModule, declarations: [ConfirmDialogComponent,
494
515
  C3PromptDialogComponent,
495
516
  C3DialogEmbedChildComponent], imports: [CommonModule,
496
- MatDialogModule,
517
+ FormsModule,
497
518
  MatButtonModule,
519
+ MatDialogModule,
498
520
  MatFormFieldModule,
521
+ MatIconModule,
499
522
  MatInputModule,
500
- FormsModule,
523
+ MatToolbarModule,
501
524
  ReactiveFormsModule] }); }
502
525
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3DialogModule, providers: [C3DialogService], imports: [CommonModule,
503
- MatDialogModule,
526
+ FormsModule,
504
527
  MatButtonModule,
528
+ MatDialogModule,
505
529
  MatFormFieldModule,
530
+ MatIconModule,
506
531
  MatInputModule,
507
- FormsModule,
532
+ MatToolbarModule,
508
533
  ReactiveFormsModule] }); }
509
534
  }
510
535
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3DialogModule, decorators: [{
@@ -517,11 +542,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImpor
517
542
  ],
518
543
  imports: [
519
544
  CommonModule,
520
- MatDialogModule,
545
+ FormsModule,
521
546
  MatButtonModule,
547
+ MatDialogModule,
522
548
  MatFormFieldModule,
549
+ MatIconModule,
523
550
  MatInputModule,
524
- FormsModule,
551
+ MatToolbarModule,
525
552
  ReactiveFormsModule,
526
553
  ],
527
554
  providers: [C3DialogService],
@@ -1111,7 +1138,7 @@ class C3ExpansionHeaderComponent {
1111
1138
  return 'c3-expansion-header';
1112
1139
  }
1113
1140
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3ExpansionHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
1114
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.0.1", type: C3ExpansionHeaderComponent, selector: "c3-expansion-header", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null }, c3Expansion: { classPropertyName: "c3Expansion", publicName: "c3Expansion", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class": "this.hostClass" } }, ngImport: i0, template: "<ng-content>\n <h4 class=\"text-lg\" *ngIf=\"title()\">\n {{ title() }}\n </h4>\n <button\n *ngIf=\"c3Expansion()\"\n mat-icon-button\n (click)=\"c3Expansion()?.toggleExpand()\"\n [matTooltip]=\"c3Expansion()?.isExpanded() ? 'R\u00E9duire' : 'D\u00E9velopper'\"\n >\n <mat-icon>{{\n c3Expansion()?.isExpanded() ? \"expand_less\" : \"expand_more\"\n }}</mat-icon>\n </button>\n</ng-content>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }], encapsulation: i0.ViewEncapsulation.None }); }
1141
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.0.1", type: C3ExpansionHeaderComponent, selector: "c3-expansion-header", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null }, c3Expansion: { classPropertyName: "c3Expansion", publicName: "c3Expansion", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class": "this.hostClass" } }, ngImport: i0, template: "<ng-content>\n <h4 class=\"text-lg\" *ngIf=\"title()\">\n {{ title() }}\n </h4>\n <button\n *ngIf=\"c3Expansion()\"\n mat-icon-button\n (click)=\"c3Expansion()?.toggleExpand()\"\n [matTooltip]=\"c3Expansion()?.isExpanded() ? 'R\u00E9duire' : 'D\u00E9velopper'\"\n >\n <mat-icon>{{\n c3Expansion()?.isExpanded() ? \"expand_less\" : \"expand_more\"\n }}</mat-icon>\n </button>\n</ng-content>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i4$1.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }], encapsulation: i0.ViewEncapsulation.None }); }
1115
1142
  }
1116
1143
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: C3ExpansionHeaderComponent, decorators: [{
1117
1144
  type: Component,