@covalent/core 8.12.3 → 8.14.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dialogs/README.md +32 -24
- package/dialogs/_dialog-theme.scss +7 -1
- package/dialogs/dialog.component.d.ts +6 -1
- package/dialogs/dialogs.module.d.ts +10 -9
- package/dialogs/public_api.d.ts +1 -0
- package/dialogs/services/dialog.service.d.ts +22 -0
- package/dialogs/status-dialog/status-dialog.component.d.ts +23 -0
- package/esm2022/dialogs/dialog.component.mjs +18 -3
- package/esm2022/dialogs/dialogs.module.mjs +11 -4
- package/esm2022/dialogs/public_api.mjs +2 -1
- package/esm2022/dialogs/services/dialog.service.mjs +37 -1
- package/esm2022/dialogs/status-dialog/status-dialog.component.mjs +55 -0
- package/fesm2022/covalent-core-dialogs.mjs +110 -7
- package/fesm2022/covalent-core-dialogs.mjs.map +1 -1
- package/package.json +2 -2
- package/theming/_teradata-theme.scss +12 -0
package/dialogs/README.md
CHANGED
@@ -16,6 +16,8 @@ Note: if no [ViewContainerRef] is provided, [TdDialogService] will throw an erro
|
|
16
16
|
- Opens a confirm dialog with the provided config.
|
17
17
|
- openPrompt: function(IPromptConfig): MatDialogRef<TdPromptDialogComponent>
|
18
18
|
- Opens a prompt dialog with the provided config.
|
19
|
+
- openStatus: function(IStatusConfig): MatDialogRef<TdStatusDialogComponent>
|
20
|
+
- Opens a status dialog with the provided config.
|
19
21
|
- open: function<T>(component: ComponentType<T>, config: MatDialogConfig): MatDialogRef<T>
|
20
22
|
- Wrapper function over the open() method in MatDialog. Opens a modal dialog containing the given component.
|
21
23
|
- openDraggable: function<T>(IDraggableConfig<T>): MatDialogRef<T>
|
@@ -87,6 +89,28 @@ export class Demo {
|
|
87
89
|
});
|
88
90
|
}
|
89
91
|
|
92
|
+
openStatus(): void {
|
93
|
+
this._dialogService.openStatus({
|
94
|
+
closeButton: 'Close', //OPTIONAL, defaults to 'CLOSE'
|
95
|
+
details: 'Additional information about the error.', //OPTIONAL, additional details to be displayed in the message
|
96
|
+
detailsLabels: {
|
97
|
+
showDetailsLabel: 'Show more details',
|
98
|
+
hideDetailsLabel: 'Hide more details'
|
99
|
+
}, //OPTIONAL, defaults to 'Show details' and 'Hide details'
|
100
|
+
disableClose: true, // defaults to false
|
101
|
+
message:
|
102
|
+
'This is how simple it is to create a status dialog with this wrapper service.',
|
103
|
+
state: 'error', // represents the state ('error' | 'positive' | 'warning') of the dialog, defaults to 'error'
|
104
|
+
title: 'Status dialog', //OPTIONAL, hides if not provided
|
105
|
+
}).afterClosed().subscribe((newValue: string) => {
|
106
|
+
if (newValue) {
|
107
|
+
// DO SOMETHING
|
108
|
+
} else {
|
109
|
+
// DO SOMETHING ELSE
|
110
|
+
}
|
111
|
+
});;
|
112
|
+
}
|
113
|
+
|
90
114
|
openDraggable(): void {
|
91
115
|
this._dialogService.openDraggable({
|
92
116
|
component: DraggableDemoComponent,
|
@@ -150,25 +174,15 @@ A utility to make a draggable dialog resizable.
|
|
150
174
|
```
|
151
175
|
|
152
176
|
```ts
|
153
|
-
const {
|
154
|
-
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
component: DraggableResizableDialogComponent,
|
159
|
-
// CSS selectors of element(s) inside the component meant to be drag handle(s)
|
160
|
-
dragHandleSelectors: ['.drag-handle'],
|
161
|
-
}
|
162
|
-
);
|
177
|
+
const { matDialogRef, dragRefSubject }: IDraggableRefs<DraggableResizableDialogComponent> = this._dialogService.openDraggable({
|
178
|
+
component: DraggableResizableDialogComponent,
|
179
|
+
// CSS selectors of element(s) inside the component meant to be drag handle(s)
|
180
|
+
dragHandleSelectors: ['.drag-handle'],
|
181
|
+
});
|
163
182
|
|
164
183
|
let resizableDraggableDialog: ResizableDraggableDialog;
|
165
184
|
dragRefSubject.subscribe((dragRf: DragRef) => {
|
166
|
-
resizableDraggableDialog = new ResizableDraggableDialog(
|
167
|
-
this._document,
|
168
|
-
this._renderer2,
|
169
|
-
matDialogRef,
|
170
|
-
dragRf
|
171
|
-
);
|
185
|
+
resizableDraggableDialog = new ResizableDraggableDialog(this._document, this._renderer2, matDialogRef, dragRf);
|
172
186
|
});
|
173
187
|
|
174
188
|
// Detach resize-ability event listeners after dialog closes
|
@@ -200,12 +214,7 @@ A component that can be utilized to create a dialog with a toolbar
|
|
200
214
|
```ts
|
201
215
|
@Component({
|
202
216
|
template: `
|
203
|
-
<td-window-dialog
|
204
|
-
[title]="'Title'"
|
205
|
-
[toolbarColor]="'accent'"
|
206
|
-
[closeLabel]="'Close'"
|
207
|
-
(closed)="closed.emit()"
|
208
|
-
>
|
217
|
+
<td-window-dialog [title]="'Title'" [toolbarColor]="'accent'" [closeLabel]="'Close'" (closed)="closed.emit()">
|
209
218
|
<p>Comes with a handy toolbar</p>
|
210
219
|
</td-window-dialog>
|
211
220
|
`,
|
@@ -216,8 +225,7 @@ export class DraggableResizableWindowDialogComponent {
|
|
216
225
|
```
|
217
226
|
|
218
227
|
```ts
|
219
|
-
const matDialogRef: MatDialogRef<DraggableResizableWindowDialogComponent> =
|
220
|
-
this._dialogService.open(DraggableResizableWindowDialogComponent);
|
228
|
+
const matDialogRef: MatDialogRef<DraggableResizableWindowDialogComponent> = this._dialogService.open(DraggableResizableWindowDialogComponent);
|
221
229
|
// listen to close event
|
222
230
|
matDialogRef.componentInstance.closed.subscribe(() => matDialogRef.close());
|
223
231
|
```
|
@@ -2,7 +2,8 @@
|
|
2
2
|
@import '../common/styles/typography-functions';
|
3
3
|
|
4
4
|
@mixin td-dialog-typography($config) {
|
5
|
-
.td-dialog-title
|
5
|
+
.td-dialog-title,
|
6
|
+
.td-status-dialog-title {
|
6
7
|
font: {
|
7
8
|
family: td-font-family($config);
|
8
9
|
size: td-font-size($config, title);
|
@@ -10,6 +11,11 @@
|
|
10
11
|
}
|
11
12
|
}
|
12
13
|
|
14
|
+
.td-status-dialog-title,
|
15
|
+
.td-status-dialog-title .td-dialog-message {
|
16
|
+
line-height: td-line-height($config, subheading-1);
|
17
|
+
}
|
18
|
+
|
13
19
|
.td-dialog-message {
|
14
20
|
font: {
|
15
21
|
family: td-font-family($config);
|
@@ -12,11 +12,16 @@ export declare class TdDialogActionsDirective {
|
|
12
12
|
static ɵfac: i0.ɵɵFactoryDeclaration<TdDialogActionsDirective, never>;
|
13
13
|
static ɵdir: i0.ɵɵDirectiveDeclaration<TdDialogActionsDirective, "[tdDialogActions]", never, {}, {}, never, never, false, never>;
|
14
14
|
}
|
15
|
+
export declare class TdDialogStatusDirective {
|
16
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TdDialogStatusDirective, never>;
|
17
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<TdDialogStatusDirective, "[tdDialogStatus]", never, {}, {}, never, never, false, never>;
|
18
|
+
}
|
15
19
|
export declare class TdDialogComponent implements AfterContentInit {
|
16
20
|
dialogTitle: QueryList<TdDialogTitleDirective>;
|
17
21
|
dialogContent: QueryList<TdDialogContentDirective>;
|
18
22
|
dialogActions: QueryList<TdDialogActionsDirective>;
|
23
|
+
dialogStatus: QueryList<TdDialogStatusDirective>;
|
19
24
|
ngAfterContentInit(): void;
|
20
25
|
static ɵfac: i0.ɵɵFactoryDeclaration<TdDialogComponent, never>;
|
21
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TdDialogComponent, "td-dialog", never, {}, {}, ["dialogTitle", "dialogContent", "dialogActions"], ["[tdDialogTitle]", "[tdDialogContent]", "[tdDialogActions]"], false, never>;
|
26
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TdDialogComponent, "td-dialog", never, {}, {}, ["dialogTitle", "dialogContent", "dialogActions", "dialogStatus"], ["[tdDialogStatus]", "[tdDialogTitle]", "[tdDialogContent]", "[tdDialogActions]"], false, never>;
|
22
27
|
}
|
@@ -4,16 +4,17 @@ import * as i2 from "./confirm-dialog/confirm-dialog.component";
|
|
4
4
|
import * as i3 from "./prompt-dialog/prompt-dialog.component";
|
5
5
|
import * as i4 from "./dialog.component";
|
6
6
|
import * as i5 from "./window-dialog/window-dialog.component";
|
7
|
-
import * as i6 from "
|
8
|
-
import * as i7 from "@angular/
|
9
|
-
import * as i8 from "@angular/
|
10
|
-
import * as i9 from "@angular/material/
|
11
|
-
import * as i10 from "@angular/material/
|
12
|
-
import * as i11 from "@angular/material/
|
13
|
-
import * as i12 from "@angular/material/
|
14
|
-
import * as i13 from "@angular/material/
|
7
|
+
import * as i6 from "./status-dialog/status-dialog.component";
|
8
|
+
import * as i7 from "@angular/forms";
|
9
|
+
import * as i8 from "@angular/common";
|
10
|
+
import * as i9 from "@angular/material/dialog";
|
11
|
+
import * as i10 from "@angular/material/input";
|
12
|
+
import * as i11 from "@angular/material/button";
|
13
|
+
import * as i12 from "@angular/material/toolbar";
|
14
|
+
import * as i13 from "@angular/material/tooltip";
|
15
|
+
import * as i14 from "@angular/material/icon";
|
15
16
|
export declare class CovalentDialogsModule {
|
16
17
|
static ɵfac: i0.ɵɵFactoryDeclaration<CovalentDialogsModule, never>;
|
17
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<CovalentDialogsModule, [typeof i1.TdAlertDialogComponent, typeof i2.TdConfirmDialogComponent, typeof i3.TdPromptDialogComponent, typeof i4.TdDialogComponent, typeof i4.TdDialogTitleDirective, typeof i4.TdDialogActionsDirective, typeof i4.TdDialogContentDirective, typeof i5.TdWindowDialogComponent, typeof i1.TdAlertDialogComponent, typeof i2.TdConfirmDialogComponent, typeof i3.TdPromptDialogComponent], [typeof
|
18
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<CovalentDialogsModule, [typeof i1.TdAlertDialogComponent, typeof i2.TdConfirmDialogComponent, typeof i3.TdPromptDialogComponent, typeof i4.TdDialogComponent, typeof i4.TdDialogStatusDirective, typeof i4.TdDialogTitleDirective, typeof i4.TdDialogActionsDirective, typeof i4.TdDialogContentDirective, typeof i5.TdWindowDialogComponent, typeof i1.TdAlertDialogComponent, typeof i2.TdConfirmDialogComponent, typeof i3.TdPromptDialogComponent, typeof i6.TdStatusDialogComponent], [typeof i7.FormsModule, typeof i8.CommonModule, typeof i9.MatDialogModule, typeof i10.MatInputModule, typeof i11.MatButtonModule, typeof i12.MatToolbarModule, typeof i13.MatTooltipModule, typeof i14.MatIconModule], [typeof i1.TdAlertDialogComponent, typeof i2.TdConfirmDialogComponent, typeof i3.TdPromptDialogComponent, typeof i4.TdDialogComponent, typeof i4.TdDialogStatusDirective, typeof i4.TdDialogTitleDirective, typeof i4.TdDialogActionsDirective, typeof i4.TdDialogContentDirective, typeof i5.TdWindowDialogComponent, typeof i1.TdAlertDialogComponent, typeof i2.TdConfirmDialogComponent, typeof i3.TdPromptDialogComponent, typeof i6.TdStatusDialogComponent]>;
|
18
19
|
static ɵinj: i0.ɵɵInjectorDeclaration<CovalentDialogsModule>;
|
19
20
|
}
|
package/dialogs/public_api.d.ts
CHANGED
@@ -3,6 +3,7 @@ export * from './dialog.component';
|
|
3
3
|
export * from './alert-dialog/alert-dialog.component';
|
4
4
|
export * from './confirm-dialog/confirm-dialog.component';
|
5
5
|
export * from './prompt-dialog/prompt-dialog.component';
|
6
|
+
export * from './status-dialog/status-dialog.component';
|
6
7
|
export * from './services/dialog.service';
|
7
8
|
export * from './resizable-draggable-dialog/resizable-draggable-dialog';
|
8
9
|
export * from './window-dialog/window-dialog.component';
|
@@ -6,6 +6,7 @@ import { TdConfirmDialogComponent } from '../confirm-dialog/confirm-dialog.compo
|
|
6
6
|
import { TdPromptDialogComponent } from '../prompt-dialog/prompt-dialog.component';
|
7
7
|
import { DragDrop, DragRef } from '@angular/cdk/drag-drop';
|
8
8
|
import { Subject } from 'rxjs';
|
9
|
+
import { TdStatusDialogStates, TdStatusDialogComponent, TdStatusDialogDetailsLabels } from '../status-dialog/status-dialog.component';
|
9
10
|
import * as i0 from "@angular/core";
|
10
11
|
export interface IDialogConfig extends MatDialogConfig {
|
11
12
|
title?: string;
|
@@ -22,6 +23,11 @@ export interface IConfirmConfig extends IDialogConfig {
|
|
22
23
|
export interface IPromptConfig extends IConfirmConfig {
|
23
24
|
value?: string;
|
24
25
|
}
|
26
|
+
export interface IStatusConfig extends IAlertConfig {
|
27
|
+
state?: TdStatusDialogStates;
|
28
|
+
details?: string;
|
29
|
+
detailsLabels?: TdStatusDialogDetailsLabels;
|
30
|
+
}
|
25
31
|
export interface IDraggableConfig<T> {
|
26
32
|
component: ComponentType<T>;
|
27
33
|
config?: MatDialogConfig;
|
@@ -100,6 +106,22 @@ export declare class TdDialogService {
|
|
100
106
|
*/
|
101
107
|
openDraggable<T>({ component, config, dragHandleSelectors, draggableClass, }: IDraggableConfig<T>): IDraggableRefs<T>;
|
102
108
|
private _createConfig;
|
109
|
+
/**
|
110
|
+
* params:
|
111
|
+
* - config: IStatusConfig {
|
112
|
+
* closeButton?: string;
|
113
|
+
* details?: string;
|
114
|
+
* detailsLabels?: TdStatusDialogDetailsLabels;
|
115
|
+
* message: string;
|
116
|
+
* state?: 'error' | 'positive' | 'warning'
|
117
|
+
* title?: string;
|
118
|
+
* viewContainerRef?: ViewContainerRef;
|
119
|
+
* }
|
120
|
+
*
|
121
|
+
* Opens a status dialog with the provided config.
|
122
|
+
* Returns an MatDialogRef<TdStatusDialogComponent> object.
|
123
|
+
*/
|
124
|
+
openStatus(config: IStatusConfig): MatDialogRef<TdStatusDialogComponent>;
|
103
125
|
static ɵfac: i0.ɵɵFactoryDeclaration<TdDialogService, never>;
|
104
126
|
static ɵprov: i0.ɵɵInjectableDeclaration<TdDialogService>;
|
105
127
|
}
|
@@ -0,0 +1,23 @@
|
|
1
|
+
import { MatDialogRef } from '@angular/material/dialog';
|
2
|
+
import * as i0 from "@angular/core";
|
3
|
+
export type TdStatusDialogStates = 'error' | 'positive' | 'warning';
|
4
|
+
export type TdStatusDialogDetailsLabels = {
|
5
|
+
showDetailsLabel: string;
|
6
|
+
hideDetailsLabel: string;
|
7
|
+
};
|
8
|
+
export declare class TdStatusDialogComponent {
|
9
|
+
private _dialogRef;
|
10
|
+
closeButton?: string;
|
11
|
+
message?: string;
|
12
|
+
state?: TdStatusDialogStates;
|
13
|
+
title?: string;
|
14
|
+
details?: string;
|
15
|
+
showDetails?: boolean | undefined;
|
16
|
+
detailsLabels?: TdStatusDialogDetailsLabels;
|
17
|
+
constructor(_dialogRef: MatDialogRef<TdStatusDialogComponent>);
|
18
|
+
close(): void;
|
19
|
+
getStatusIcon(): string;
|
20
|
+
toggleDetails(): void;
|
21
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TdStatusDialogComponent, never>;
|
22
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TdStatusDialogComponent, "td-status-dialog", never, {}, {}, never, never, false, never>;
|
23
|
+
}
|
@@ -26,10 +26,19 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
26
26
|
type: Directive,
|
27
27
|
args: [{ selector: '[tdDialogActions]' }]
|
28
28
|
}] });
|
29
|
+
export class TdDialogStatusDirective {
|
30
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: TdDialogStatusDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
31
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.1.2", type: TdDialogStatusDirective, selector: "[tdDialogStatus]", ngImport: i0 });
|
32
|
+
}
|
33
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: TdDialogStatusDirective, decorators: [{
|
34
|
+
type: Directive,
|
35
|
+
args: [{ selector: '[tdDialogStatus]' }]
|
36
|
+
}] });
|
29
37
|
export class TdDialogComponent {
|
30
38
|
dialogTitle;
|
31
39
|
dialogContent;
|
32
40
|
dialogActions;
|
41
|
+
dialogStatus;
|
33
42
|
ngAfterContentInit() {
|
34
43
|
if (this.dialogTitle.length > 1) {
|
35
44
|
throw new Error('Duplicate td-dialog-title component at in td-dialog.');
|
@@ -40,13 +49,16 @@ export class TdDialogComponent {
|
|
40
49
|
if (this.dialogActions.length > 1) {
|
41
50
|
throw new Error('Duplicate td-dialog-actions component at in td-dialog.');
|
42
51
|
}
|
52
|
+
if (this.dialogStatus.length > 1) {
|
53
|
+
throw new Error('Duplicate td-dialog-status component at in td-dialog.');
|
54
|
+
}
|
43
55
|
}
|
44
56
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: TdDialogComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
45
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: TdDialogComponent, selector: "td-dialog", queries: [{ propertyName: "dialogTitle", predicate: TdDialogTitleDirective, descendants: true }, { propertyName: "dialogContent", predicate: TdDialogContentDirective, descendants: true }, { propertyName: "dialogActions", predicate: TdDialogActionsDirective, descendants: true }], ngImport: i0, template: "<div mat-dialog-title *ngIf=\"dialogTitle.length > 0\">\n
|
57
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: TdDialogComponent, selector: "td-dialog", queries: [{ propertyName: "dialogTitle", predicate: TdDialogTitleDirective, descendants: true }, { propertyName: "dialogContent", predicate: TdDialogContentDirective, descendants: true }, { propertyName: "dialogActions", predicate: TdDialogActionsDirective, descendants: true }, { propertyName: "dialogStatus", predicate: TdDialogStatusDirective, descendants: true }], ngImport: i0, template: "<div class=\"td-dialog-wrapper\">\n <ng-content\n *ngIf=\"dialogStatus.length > 0\"\n select=\"[tdDialogStatus]\"\n ></ng-content>\n <section class=\"td-dialog\">\n <div mat-dialog-title *ngIf=\"dialogTitle.length > 0\">\n <ng-content select=\"[tdDialogTitle]\"></ng-content>\n </div>\n <mat-dialog-content\n class=\"td-dialog-content\"\n *ngIf=\"dialogContent.length > 0\"\n >\n <ng-content select=\"[tdDialogContent]\"></ng-content>\n </mat-dialog-content>\n <mat-dialog-actions\n class=\"td-dialog-actions\"\n *ngIf=\"dialogActions.length > 0\"\n >\n <span class=\"td-dialog-spacer\"></span>\n <ng-content select=\"[tdDialogActions]\"></ng-content>\n </mat-dialog-actions>\n </section>\n</div>\n", styles: [".td-dialog{width:100%}.td-dialog-wrapper{display:flex}.td-dialog-actions{flex-direction:row;box-sizing:border-box;display:flex}.td-dialog-actions .td-dialog-spacer{flex:1}.td-dialog-actions ::ng-deep button{text-transform:uppercase;margin-left:8px;padding-left:8px;padding-right:8px;min-width:64px}[dir=rtl] .td-dialog-actions ::ng-deep button{margin-right:8px;margin-left:inherit}.td-dialog-actions ::ng-deep .td-status-dialog___button{padding:9px 16px}@media screen and (max-width: 480px){.td-dialog-wrapper{flex-direction:column}}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i2.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i2.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }] });
|
46
58
|
}
|
47
59
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: TdDialogComponent, decorators: [{
|
48
60
|
type: Component,
|
49
|
-
args: [{ selector: 'td-dialog', template: "<div mat-dialog-title *ngIf=\"dialogTitle.length > 0\">\n
|
61
|
+
args: [{ selector: 'td-dialog', template: "<div class=\"td-dialog-wrapper\">\n <ng-content\n *ngIf=\"dialogStatus.length > 0\"\n select=\"[tdDialogStatus]\"\n ></ng-content>\n <section class=\"td-dialog\">\n <div mat-dialog-title *ngIf=\"dialogTitle.length > 0\">\n <ng-content select=\"[tdDialogTitle]\"></ng-content>\n </div>\n <mat-dialog-content\n class=\"td-dialog-content\"\n *ngIf=\"dialogContent.length > 0\"\n >\n <ng-content select=\"[tdDialogContent]\"></ng-content>\n </mat-dialog-content>\n <mat-dialog-actions\n class=\"td-dialog-actions\"\n *ngIf=\"dialogActions.length > 0\"\n >\n <span class=\"td-dialog-spacer\"></span>\n <ng-content select=\"[tdDialogActions]\"></ng-content>\n </mat-dialog-actions>\n </section>\n</div>\n", styles: [".td-dialog{width:100%}.td-dialog-wrapper{display:flex}.td-dialog-actions{flex-direction:row;box-sizing:border-box;display:flex}.td-dialog-actions .td-dialog-spacer{flex:1}.td-dialog-actions ::ng-deep button{text-transform:uppercase;margin-left:8px;padding-left:8px;padding-right:8px;min-width:64px}[dir=rtl] .td-dialog-actions ::ng-deep button{margin-right:8px;margin-left:inherit}.td-dialog-actions ::ng-deep .td-status-dialog___button{padding:9px 16px}@media screen and (max-width: 480px){.td-dialog-wrapper{flex-direction:column}}\n"] }]
|
50
62
|
}], propDecorators: { dialogTitle: [{
|
51
63
|
type: ContentChildren,
|
52
64
|
args: [TdDialogTitleDirective, { descendants: true }]
|
@@ -56,5 +68,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
56
68
|
}], dialogActions: [{
|
57
69
|
type: ContentChildren,
|
58
70
|
args: [TdDialogActionsDirective, { descendants: true }]
|
71
|
+
}], dialogStatus: [{
|
72
|
+
type: ContentChildren,
|
73
|
+
args: [TdDialogStatusDirective, { descendants: true }]
|
59
74
|
}] } });
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9kaWFsb2dzL3NyYy9kaWFsb2cuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL2RpYWxvZ3Mvc3JjL2RpYWxvZy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULFNBQVMsRUFDVCxlQUFlLEVBQ2YsU0FBUyxHQUVWLE1BQU0sZUFBZSxDQUFDOzs7O0FBR3ZCLE1BQU0sT0FBTyxzQkFBc0I7dUdBQXRCLHNCQUFzQjsyRkFBdEIsc0JBQXNCOzsyRkFBdEIsc0JBQXNCO2tCQURsQyxTQUFTO21CQUFDLEVBQUUsUUFBUSxFQUFFLGlCQUFpQixFQUFFOztBQUkxQyxNQUFNLE9BQU8sd0JBQXdCO3VHQUF4Qix3QkFBd0I7MkZBQXhCLHdCQUF3Qjs7MkZBQXhCLHdCQUF3QjtrQkFEcEMsU0FBUzttQkFBQyxFQUFFLFFBQVEsRUFBRSxtQkFBbUIsRUFBRTs7QUFJNUMsTUFBTSxPQUFPLHdCQUF3Qjt1R0FBeEIsd0JBQXdCOzJGQUF4Qix3QkFBd0I7OzJGQUF4Qix3QkFBd0I7a0JBRHBDLFNBQVM7bUJBQUMsRUFBRSxRQUFRLEVBQUUsbUJBQW1CLEVBQUU7O0FBSTVDLE1BQU0sT0FBTyx1QkFBdUI7dUdBQXZCLHVCQUF1QjsyRkFBdkIsdUJBQXVCOzsyRkFBdkIsdUJBQXVCO2tCQURuQyxTQUFTO21CQUFDLEVBQUUsUUFBUSxFQUFFLGtCQUFrQixFQUFFOztBQVEzQyxNQUFNLE9BQU8saUJBQWlCO0lBRTVCLFdBQVcsQ0FBcUM7SUFFaEQsYUFBYSxDQUF1QztJQUVwRCxhQUFhLENBQXVDO0lBRXBELFlBQVksQ0FBc0M7SUFFbEQsa0JBQWtCO1FBQ2hCLElBQUksSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDaEMsTUFBTSxJQUFJLEtBQUssQ0FBQyxzREFBc0QsQ0FBQyxDQUFDO1FBQzFFLENBQUM7UUFDRCxJQUFJLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQ2xDLE1BQU0sSUFBSSxLQUFLLENBQUMsd0RBQXdELENBQUMsQ0FBQztRQUM1RSxDQUFDO1FBQ0QsSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQztZQUNsQyxNQUFNLElBQUksS0FBSyxDQUFDLHdEQUF3RCxDQUFDLENBQUM7UUFDNUUsQ0FBQztRQUNELElBQUksSUFBSSxDQUFDLFlBQVksQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDakMsTUFBTSxJQUFJLEtBQUssQ0FBQyx1REFBdUQsQ0FBQyxDQUFDO1FBQzNFLENBQUM7SUFDSCxDQUFDO3VHQXZCVSxpQkFBaUI7MkZBQWpCLGlCQUFpQiw2RUFDWCxzQkFBc0IsbUVBRXRCLHdCQUF3QixtRUFFeEIsd0JBQXdCLGtFQUV4Qix1QkFBdUIsZ0RDaEMxQyxzd0JBd0JBOzsyRkRDYSxpQkFBaUI7a0JBTDdCLFNBQVM7K0JBQ0UsV0FBVzs4QkFNckIsV0FBVztzQkFEVixlQUFlO3VCQUFDLHNCQUFzQixFQUFFLEVBQUUsV0FBVyxFQUFFLElBQUksRUFBRTtnQkFHOUQsYUFBYTtzQkFEWixlQUFlO3VCQUFDLHdCQUF3QixFQUFFLEVBQUUsV0FBVyxFQUFFLElBQUksRUFBRTtnQkFHaEUsYUFBYTtzQkFEWixlQUFlO3VCQUFDLHdCQUF3QixFQUFFLEVBQUUsV0FBVyxFQUFFLElBQUksRUFBRTtnQkFHaEUsWUFBWTtzQkFEWCxlQUFlO3VCQUFDLHVCQUF1QixFQUFFLEVBQUUsV0FBVyxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENvbXBvbmVudCxcbiAgRGlyZWN0aXZlLFxuICBDb250ZW50Q2hpbGRyZW4sXG4gIFF1ZXJ5TGlzdCxcbiAgQWZ0ZXJDb250ZW50SW5pdCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBEaXJlY3RpdmUoeyBzZWxlY3RvcjogJ1t0ZERpYWxvZ1RpdGxlXScgfSlcbmV4cG9ydCBjbGFzcyBUZERpYWxvZ1RpdGxlRGlyZWN0aXZlIHt9XG5cbkBEaXJlY3RpdmUoeyBzZWxlY3RvcjogJ1t0ZERpYWxvZ0NvbnRlbnRdJyB9KVxuZXhwb3J0IGNsYXNzIFRkRGlhbG9nQ29udGVudERpcmVjdGl2ZSB7fVxuXG5ARGlyZWN0aXZlKHsgc2VsZWN0b3I6ICdbdGREaWFsb2dBY3Rpb25zXScgfSlcbmV4cG9ydCBjbGFzcyBUZERpYWxvZ0FjdGlvbnNEaXJlY3RpdmUge31cblxuQERpcmVjdGl2ZSh7IHNlbGVjdG9yOiAnW3RkRGlhbG9nU3RhdHVzXScgfSlcbmV4cG9ydCBjbGFzcyBUZERpYWxvZ1N0YXR1c0RpcmVjdGl2ZSB7fVxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd0ZC1kaWFsb2cnLFxuICB0ZW1wbGF0ZVVybDogJy4vZGlhbG9nLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZGlhbG9nLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIFRkRGlhbG9nQ29tcG9uZW50IGltcGxlbWVudHMgQWZ0ZXJDb250ZW50SW5pdCB7XG4gIEBDb250ZW50Q2hpbGRyZW4oVGREaWFsb2dUaXRsZURpcmVjdGl2ZSwgeyBkZXNjZW5kYW50czogdHJ1ZSB9KVxuICBkaWFsb2dUaXRsZSE6IFF1ZXJ5TGlzdDxUZERpYWxvZ1RpdGxlRGlyZWN0aXZlPjtcbiAgQENvbnRlbnRDaGlsZHJlbihUZERpYWxvZ0NvbnRlbnREaXJlY3RpdmUsIHsgZGVzY2VuZGFudHM6IHRydWUgfSlcbiAgZGlhbG9nQ29udGVudCE6IFF1ZXJ5TGlzdDxUZERpYWxvZ0NvbnRlbnREaXJlY3RpdmU+O1xuICBAQ29udGVudENoaWxkcmVuKFRkRGlhbG9nQWN0aW9uc0RpcmVjdGl2ZSwgeyBkZXNjZW5kYW50czogdHJ1ZSB9KVxuICBkaWFsb2dBY3Rpb25zITogUXVlcnlMaXN0PFRkRGlhbG9nQWN0aW9uc0RpcmVjdGl2ZT47XG4gIEBDb250ZW50Q2hpbGRyZW4oVGREaWFsb2dTdGF0dXNEaXJlY3RpdmUsIHsgZGVzY2VuZGFudHM6IHRydWUgfSlcbiAgZGlhbG9nU3RhdHVzITogUXVlcnlMaXN0PFRkRGlhbG9nU3RhdHVzRGlyZWN0aXZlPjtcblxuICBuZ0FmdGVyQ29udGVudEluaXQoKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuZGlhbG9nVGl0bGUubGVuZ3RoID4gMSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdEdXBsaWNhdGUgdGQtZGlhbG9nLXRpdGxlIGNvbXBvbmVudCBhdCBpbiB0ZC1kaWFsb2cuJyk7XG4gICAgfVxuICAgIGlmICh0aGlzLmRpYWxvZ0NvbnRlbnQubGVuZ3RoID4gMSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdEdXBsaWNhdGUgdGQtZGlhbG9nLWNvbnRlbnQgY29tcG9uZW50IGF0IGluIHRkLWRpYWxvZy4nKTtcbiAgICB9XG4gICAgaWYgKHRoaXMuZGlhbG9nQWN0aW9ucy5sZW5ndGggPiAxKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ0R1cGxpY2F0ZSB0ZC1kaWFsb2ctYWN0aW9ucyBjb21wb25lbnQgYXQgaW4gdGQtZGlhbG9nLicpO1xuICAgIH1cbiAgICBpZiAodGhpcy5kaWFsb2dTdGF0dXMubGVuZ3RoID4gMSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdEdXBsaWNhdGUgdGQtZGlhbG9nLXN0YXR1cyBjb21wb25lbnQgYXQgaW4gdGQtZGlhbG9nLicpO1xuICAgIH1cbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cInRkLWRpYWxvZy13cmFwcGVyXCI+XG4gIDxuZy1jb250ZW50XG4gICAgKm5nSWY9XCJkaWFsb2dTdGF0dXMubGVuZ3RoID4gMFwiXG4gICAgc2VsZWN0PVwiW3RkRGlhbG9nU3RhdHVzXVwiXG4gID48L25nLWNvbnRlbnQ+XG4gIDxzZWN0aW9uIGNsYXNzPVwidGQtZGlhbG9nXCI+XG4gICAgPGRpdiBtYXQtZGlhbG9nLXRpdGxlICpuZ0lmPVwiZGlhbG9nVGl0bGUubGVuZ3RoID4gMFwiPlxuICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiW3RkRGlhbG9nVGl0bGVdXCI+PC9uZy1jb250ZW50PlxuICAgIDwvZGl2PlxuICAgIDxtYXQtZGlhbG9nLWNvbnRlbnRcbiAgICAgIGNsYXNzPVwidGQtZGlhbG9nLWNvbnRlbnRcIlxuICAgICAgKm5nSWY9XCJkaWFsb2dDb250ZW50Lmxlbmd0aCA+IDBcIlxuICAgID5cbiAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIlt0ZERpYWxvZ0NvbnRlbnRdXCI+PC9uZy1jb250ZW50PlxuICAgIDwvbWF0LWRpYWxvZy1jb250ZW50PlxuICAgIDxtYXQtZGlhbG9nLWFjdGlvbnNcbiAgICAgIGNsYXNzPVwidGQtZGlhbG9nLWFjdGlvbnNcIlxuICAgICAgKm5nSWY9XCJkaWFsb2dBY3Rpb25zLmxlbmd0aCA+IDBcIlxuICAgID5cbiAgICAgIDxzcGFuIGNsYXNzPVwidGQtZGlhbG9nLXNwYWNlclwiPjwvc3Bhbj5cbiAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIlt0ZERpYWxvZ0FjdGlvbnNdXCI+PC9uZy1jb250ZW50PlxuICAgIDwvbWF0LWRpYWxvZy1hY3Rpb25zPlxuICA8L3NlY3Rpb24+XG48L2Rpdj5cbiJdfQ==
|
@@ -4,10 +4,11 @@ import { FormsModule } from '@angular/forms';
|
|
4
4
|
import { MatDialogModule } from '@angular/material/dialog';
|
5
5
|
import { MatInputModule } from '@angular/material/input';
|
6
6
|
import { MatButtonModule } from '@angular/material/button';
|
7
|
-
import { TdDialogComponent, TdDialogTitleDirective, TdDialogActionsDirective, TdDialogContentDirective, } from './dialog.component';
|
7
|
+
import { TdDialogComponent, TdDialogTitleDirective, TdDialogActionsDirective, TdDialogContentDirective, TdDialogStatusDirective, } from './dialog.component';
|
8
8
|
import { TdAlertDialogComponent } from './alert-dialog/alert-dialog.component';
|
9
9
|
import { TdConfirmDialogComponent } from './confirm-dialog/confirm-dialog.component';
|
10
10
|
import { TdPromptDialogComponent } from './prompt-dialog/prompt-dialog.component';
|
11
|
+
import { TdStatusDialogComponent } from './status-dialog/status-dialog.component';
|
11
12
|
import { TdDialogService } from './services/dialog.service';
|
12
13
|
import { TdWindowDialogComponent } from './window-dialog/window-dialog.component';
|
13
14
|
import { MatToolbarModule } from '@angular/material/toolbar';
|
@@ -19,6 +20,7 @@ const TD_DIALOGS = [
|
|
19
20
|
TdConfirmDialogComponent,
|
20
21
|
TdPromptDialogComponent,
|
21
22
|
TdDialogComponent,
|
23
|
+
TdDialogStatusDirective,
|
22
24
|
TdDialogTitleDirective,
|
23
25
|
TdDialogActionsDirective,
|
24
26
|
TdDialogContentDirective,
|
@@ -26,6 +28,7 @@ const TD_DIALOGS = [
|
|
26
28
|
TdAlertDialogComponent,
|
27
29
|
TdConfirmDialogComponent,
|
28
30
|
TdPromptDialogComponent,
|
31
|
+
TdStatusDialogComponent,
|
29
32
|
];
|
30
33
|
export class CovalentDialogsModule {
|
31
34
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CovalentDialogsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
@@ -33,13 +36,15 @@ export class CovalentDialogsModule {
|
|
33
36
|
TdConfirmDialogComponent,
|
34
37
|
TdPromptDialogComponent,
|
35
38
|
TdDialogComponent,
|
39
|
+
TdDialogStatusDirective,
|
36
40
|
TdDialogTitleDirective,
|
37
41
|
TdDialogActionsDirective,
|
38
42
|
TdDialogContentDirective,
|
39
43
|
TdWindowDialogComponent,
|
40
44
|
TdAlertDialogComponent,
|
41
45
|
TdConfirmDialogComponent,
|
42
|
-
TdPromptDialogComponent
|
46
|
+
TdPromptDialogComponent,
|
47
|
+
TdStatusDialogComponent], imports: [FormsModule,
|
43
48
|
CommonModule,
|
44
49
|
MatDialogModule,
|
45
50
|
MatInputModule,
|
@@ -50,13 +55,15 @@ export class CovalentDialogsModule {
|
|
50
55
|
TdConfirmDialogComponent,
|
51
56
|
TdPromptDialogComponent,
|
52
57
|
TdDialogComponent,
|
58
|
+
TdDialogStatusDirective,
|
53
59
|
TdDialogTitleDirective,
|
54
60
|
TdDialogActionsDirective,
|
55
61
|
TdDialogContentDirective,
|
56
62
|
TdWindowDialogComponent,
|
57
63
|
TdAlertDialogComponent,
|
58
64
|
TdConfirmDialogComponent,
|
59
|
-
TdPromptDialogComponent
|
65
|
+
TdPromptDialogComponent,
|
66
|
+
TdStatusDialogComponent] });
|
60
67
|
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CovalentDialogsModule, providers: [TdDialogService], imports: [FormsModule,
|
61
68
|
CommonModule,
|
62
69
|
MatDialogModule,
|
@@ -84,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
84
91
|
providers: [TdDialogService],
|
85
92
|
}]
|
86
93
|
}] });
|
87
|
-
//# sourceMappingURL=data:application/json;base64,
|
94
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9ncy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvZGlhbG9ncy9zcmMvZGlhbG9ncy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBRTNELE9BQU8sRUFDTCxpQkFBaUIsRUFDakIsc0JBQXNCLEVBQ3RCLHdCQUF3QixFQUN4Qix3QkFBd0IsRUFDeEIsdUJBQXVCLEdBQ3hCLE1BQU0sb0JBQW9CLENBQUM7QUFDNUIsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDL0UsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDckYsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDbEYsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDbEYsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzVELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQ2xGLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzdELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7QUFFdkQsTUFBTSxVQUFVLEdBQWdCO0lBQzlCLHNCQUFzQjtJQUN0Qix3QkFBd0I7SUFDeEIsdUJBQXVCO0lBQ3ZCLGlCQUFpQjtJQUNqQix1QkFBdUI7SUFDdkIsc0JBQXNCO0lBQ3RCLHdCQUF3QjtJQUN4Qix3QkFBd0I7SUFDeEIsdUJBQXVCO0lBQ3ZCLHNCQUFzQjtJQUN0Qix3QkFBd0I7SUFDeEIsdUJBQXVCO0lBQ3ZCLHVCQUF1QjtDQUN4QixDQUFDO0FBaUJGLE1BQU0sT0FBTyxxQkFBcUI7dUdBQXJCLHFCQUFxQjt3R0FBckIscUJBQXFCLGlCQTlCaEMsc0JBQXNCO1lBQ3RCLHdCQUF3QjtZQUN4Qix1QkFBdUI7WUFDdkIsaUJBQWlCO1lBQ2pCLHVCQUF1QjtZQUN2QixzQkFBc0I7WUFDdEIsd0JBQXdCO1lBQ3hCLHdCQUF3QjtZQUN4Qix1QkFBdUI7WUFDdkIsc0JBQXNCO1lBQ3RCLHdCQUF3QjtZQUN4Qix1QkFBdUI7WUFDdkIsdUJBQXVCLGFBS3JCLFdBQVc7WUFDWCxZQUFZO1lBQ1osZUFBZTtZQUNmLGNBQWM7WUFDZCxlQUFlO1lBQ2YsZ0JBQWdCO1lBQ2hCLGdCQUFnQjtZQUNoQixhQUFhLGFBeEJmLHNCQUFzQjtZQUN0Qix3QkFBd0I7WUFDeEIsdUJBQXVCO1lBQ3ZCLGlCQUFpQjtZQUNqQix1QkFBdUI7WUFDdkIsc0JBQXNCO1lBQ3RCLHdCQUF3QjtZQUN4Qix3QkFBd0I7WUFDeEIsdUJBQXVCO1lBQ3ZCLHNCQUFzQjtZQUN0Qix3QkFBd0I7WUFDeEIsdUJBQXVCO1lBQ3ZCLHVCQUF1Qjt3R0FrQloscUJBQXFCLGFBRnJCLENBQUMsZUFBZSxDQUFDLFlBWDFCLFdBQVc7WUFDWCxZQUFZO1lBQ1osZUFBZTtZQUNmLGNBQWM7WUFDZCxlQUFlO1lBQ2YsZ0JBQWdCO1lBQ2hCLGdCQUFnQjtZQUNoQixhQUFhOzsyRkFNSixxQkFBcUI7a0JBZmpDLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLFdBQVc7d0JBQ1gsWUFBWTt3QkFDWixlQUFlO3dCQUNmLGNBQWM7d0JBQ2QsZUFBZTt3QkFDZixnQkFBZ0I7d0JBQ2hCLGdCQUFnQjt3QkFDaEIsYUFBYTtxQkFDZDtvQkFDRCxZQUFZLEVBQUUsQ0FBQyxHQUFHLFVBQVUsQ0FBQztvQkFDN0IsT0FBTyxFQUFFLENBQUMsR0FBRyxVQUFVLENBQUM7b0JBQ3hCLFNBQVMsRUFBRSxDQUFDLGVBQWUsQ0FBQztpQkFDN0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUeXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBNYXREaWFsb2dNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuaW1wb3J0IHsgTWF0SW5wdXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuXG5pbXBvcnQge1xuICBUZERpYWxvZ0NvbXBvbmVudCxcbiAgVGREaWFsb2dUaXRsZURpcmVjdGl2ZSxcbiAgVGREaWFsb2dBY3Rpb25zRGlyZWN0aXZlLFxuICBUZERpYWxvZ0NvbnRlbnREaXJlY3RpdmUsXG4gIFRkRGlhbG9nU3RhdHVzRGlyZWN0aXZlLFxufSBmcm9tICcuL2RpYWxvZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgVGRBbGVydERpYWxvZ0NvbXBvbmVudCB9IGZyb20gJy4vYWxlcnQtZGlhbG9nL2FsZXJ0LWRpYWxvZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgVGRDb25maXJtRGlhbG9nQ29tcG9uZW50IH0gZnJvbSAnLi9jb25maXJtLWRpYWxvZy9jb25maXJtLWRpYWxvZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgVGRQcm9tcHREaWFsb2dDb21wb25lbnQgfSBmcm9tICcuL3Byb21wdC1kaWFsb2cvcHJvbXB0LWRpYWxvZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgVGRTdGF0dXNEaWFsb2dDb21wb25lbnQgfSBmcm9tICcuL3N0YXR1cy1kaWFsb2cvc3RhdHVzLWRpYWxvZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgVGREaWFsb2dTZXJ2aWNlIH0gZnJvbSAnLi9zZXJ2aWNlcy9kaWFsb2cuc2VydmljZSc7XG5pbXBvcnQgeyBUZFdpbmRvd0RpYWxvZ0NvbXBvbmVudCB9IGZyb20gJy4vd2luZG93LWRpYWxvZy93aW5kb3ctZGlhbG9nLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNYXRUb29sYmFyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdG9vbGJhcic7XG5pbXBvcnQgeyBNYXRUb29sdGlwTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdG9vbHRpcCc7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5cbmNvbnN0IFREX0RJQUxPR1M6IFR5cGU8YW55PltdID0gW1xuICBUZEFsZXJ0RGlhbG9nQ29tcG9uZW50LFxuICBUZENvbmZpcm1EaWFsb2dDb21wb25lbnQsXG4gIFRkUHJvbXB0RGlhbG9nQ29tcG9uZW50LFxuICBUZERpYWxvZ0NvbXBvbmVudCxcbiAgVGREaWFsb2dTdGF0dXNEaXJlY3RpdmUsXG4gIFRkRGlhbG9nVGl0bGVEaXJlY3RpdmUsXG4gIFRkRGlhbG9nQWN0aW9uc0RpcmVjdGl2ZSxcbiAgVGREaWFsb2dDb250ZW50RGlyZWN0aXZlLFxuICBUZFdpbmRvd0RpYWxvZ0NvbXBvbmVudCxcbiAgVGRBbGVydERpYWxvZ0NvbXBvbmVudCxcbiAgVGRDb25maXJtRGlhbG9nQ29tcG9uZW50LFxuICBUZFByb21wdERpYWxvZ0NvbXBvbmVudCxcbiAgVGRTdGF0dXNEaWFsb2dDb21wb25lbnQsXG5dO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgRm9ybXNNb2R1bGUsXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIE1hdERpYWxvZ01vZHVsZSxcbiAgICBNYXRJbnB1dE1vZHVsZSxcbiAgICBNYXRCdXR0b25Nb2R1bGUsXG4gICAgTWF0VG9vbGJhck1vZHVsZSxcbiAgICBNYXRUb29sdGlwTW9kdWxlLFxuICAgIE1hdEljb25Nb2R1bGUsXG4gIF0sXG4gIGRlY2xhcmF0aW9uczogWy4uLlREX0RJQUxPR1NdLFxuICBleHBvcnRzOiBbLi4uVERfRElBTE9HU10sXG4gIHByb3ZpZGVyczogW1RkRGlhbG9nU2VydmljZV0sXG59KVxuZXhwb3J0IGNsYXNzIENvdmFsZW50RGlhbG9nc01vZHVsZSB7fVxuIl19
|
@@ -3,7 +3,8 @@ export * from './dialog.component';
|
|
3
3
|
export * from './alert-dialog/alert-dialog.component';
|
4
4
|
export * from './confirm-dialog/confirm-dialog.component';
|
5
5
|
export * from './prompt-dialog/prompt-dialog.component';
|
6
|
+
export * from './status-dialog/status-dialog.component';
|
6
7
|
export * from './services/dialog.service';
|
7
8
|
export * from './resizable-draggable-dialog/resizable-draggable-dialog';
|
8
9
|
export * from './window-dialog/window-dialog.component';
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9kaWFsb2dzL3NyYy9wdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx5REFBeUQsQ0FBQztBQUN4RSxjQUFjLHlDQUF5QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9kaWFsb2dzLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2RpYWxvZy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9hbGVydC1kaWFsb2cvYWxlcnQtZGlhbG9nLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NvbmZpcm0tZGlhbG9nL2NvbmZpcm0tZGlhbG9nLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3Byb21wdC1kaWFsb2cvcHJvbXB0LWRpYWxvZy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9zdGF0dXMtZGlhbG9nL3N0YXR1cy1kaWFsb2cuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vc2VydmljZXMvZGlhbG9nLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9yZXNpemFibGUtZHJhZ2dhYmxlLWRpYWxvZy9yZXNpemFibGUtZHJhZ2dhYmxlLWRpYWxvZyc7XG5leHBvcnQgKiBmcm9tICcuL3dpbmRvdy1kaWFsb2cvd2luZG93LWRpYWxvZy5jb21wb25lbnQnO1xuIl19
|
@@ -6,6 +6,7 @@ import { TdPromptDialogComponent } from '../prompt-dialog/prompt-dialog.componen
|
|
6
6
|
import { DragDrop } from '@angular/cdk/drag-drop';
|
7
7
|
import { DOCUMENT } from '@angular/common';
|
8
8
|
import { Subject } from 'rxjs';
|
9
|
+
import { TdStatusDialogComponent, } from '../status-dialog/status-dialog.component';
|
9
10
|
import * as i0 from "@angular/core";
|
10
11
|
import * as i1 from "@angular/material/dialog";
|
11
12
|
import * as i2 from "@angular/cdk/drag-drop";
|
@@ -167,6 +168,41 @@ export class TdDialogService {
|
|
167
168
|
Object.assign(dialogConfig, config);
|
168
169
|
return dialogConfig;
|
169
170
|
}
|
171
|
+
/**
|
172
|
+
* params:
|
173
|
+
* - config: IStatusConfig {
|
174
|
+
* closeButton?: string;
|
175
|
+
* details?: string;
|
176
|
+
* detailsLabels?: TdStatusDialogDetailsLabels;
|
177
|
+
* message: string;
|
178
|
+
* state?: 'error' | 'positive' | 'warning'
|
179
|
+
* title?: string;
|
180
|
+
* viewContainerRef?: ViewContainerRef;
|
181
|
+
* }
|
182
|
+
*
|
183
|
+
* Opens a status dialog with the provided config.
|
184
|
+
* Returns an MatDialogRef<TdStatusDialogComponent> object.
|
185
|
+
*/
|
186
|
+
openStatus(config) {
|
187
|
+
config.panelClass = 'td-status-dialog';
|
188
|
+
config.autoFocus = false;
|
189
|
+
config.width = '575px';
|
190
|
+
config.maxWidth = '96vw';
|
191
|
+
const dialogConfig = this._createConfig(config);
|
192
|
+
const dialogRef = this._dialogService.open(TdStatusDialogComponent, dialogConfig);
|
193
|
+
const statusDialogComponent = dialogRef.componentInstance;
|
194
|
+
statusDialogComponent.title = config.title;
|
195
|
+
statusDialogComponent.message = config.message;
|
196
|
+
statusDialogComponent.state = config.state;
|
197
|
+
statusDialogComponent.details = config.details;
|
198
|
+
if (config.detailsLabels) {
|
199
|
+
statusDialogComponent.detailsLabels = config.detailsLabels;
|
200
|
+
}
|
201
|
+
if (config.closeButton) {
|
202
|
+
statusDialogComponent.closeButton = config.closeButton;
|
203
|
+
}
|
204
|
+
return dialogRef;
|
205
|
+
}
|
170
206
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: TdDialogService, deps: [{ token: DOCUMENT }, { token: i1.MatDialog }, { token: i2.DragDrop }, { token: i0.RendererFactory2 }], target: i0.ɵɵFactoryTarget.Injectable });
|
171
207
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: TdDialogService });
|
172
208
|
}
|
@@ -176,4 +212,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
176
212
|
type: Inject,
|
177
213
|
args: [DOCUMENT]
|
178
214
|
}] }, { type: i1.MatDialog }, { type: i2.DragDrop }, { type: i0.RendererFactory2 }] });
|
179
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.service.js","sourceRoot":"","sources":["../../../../../../libs/angular/dialogs/src/services/dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject, Renderer2, RendererFactory2 } from '@angular/core';\nimport {\n  MatDialog,\n  MatDialogRef,\n  MatDialogConfig,\n} from '@angular/material/dialog';\nimport { ComponentType } from '@angular/cdk/portal';\n\nimport { TdAlertDialogComponent } from '../alert-dialog/alert-dialog.component';\nimport { TdConfirmDialogComponent } from '../confirm-dialog/confirm-dialog.component';\nimport { TdPromptDialogComponent } from '../prompt-dialog/prompt-dialog.component';\nimport { DragDrop, DragRef } from '@angular/cdk/drag-drop';\nimport { DOCUMENT } from '@angular/common';\nimport { Subject } from 'rxjs';\n\nexport interface IDialogConfig extends MatDialogConfig {\n  title?: string;\n  message: string;\n}\n\nexport interface IAlertConfig extends IDialogConfig {\n  closeButton?: string;\n}\n\nexport interface IConfirmConfig extends IDialogConfig {\n  acceptButton?: string;\n  cancelButton?: string;\n  isDestructive?: boolean;\n}\n\nexport interface IPromptConfig extends IConfirmConfig {\n  value?: string;\n}\n\nexport interface IDraggableConfig<T> {\n  component: ComponentType<T>;\n  config?: MatDialogConfig;\n  // CSS selectors of element(s) inside the component meant to be drag handle(s)\n  dragHandleSelectors?: string[];\n  // Class that will be added to the component signifying drag-ability\n  draggableClass?: string;\n}\n\nexport interface IDraggableRefs<T> {\n  matDialogRef: MatDialogRef<T>;\n  dragRefSubject: Subject<DragRef>;\n}\n\n@Injectable()\nexport class TdDialogService {\n  private _renderer2: Renderer2;\n\n  constructor(\n    @Inject(DOCUMENT) private _document: any,\n    private _dialogService: MatDialog,\n    private _dragDrop: DragDrop,\n    private rendererFactory: RendererFactory2\n  ) {\n    this._renderer2 = rendererFactory.createRenderer(undefined, null);\n  }\n\n  /**\n   * params:\n   * - component: ComponentType<T>\n   * - config: MatDialogConfig\n   * Wrapper function over the open() method in MatDialog.\n   * Opens a modal dialog containing the given component.\n   */\n  public open<T>(\n    component: ComponentType<T>,\n    config?: MatDialogConfig\n  ): MatDialogRef<T> {\n    return this._dialogService.open(component, config);\n  }\n\n  /**\n   * Wrapper function over the closeAll() method in MatDialog.\n   * Closes all of the currently-open dialogs.\n   */\n  public closeAll(): void {\n    this._dialogService.closeAll();\n  }\n\n  /**\n   * params:\n   * - config: IAlertConfig {\n   *     message: string;\n   *     title?: string;\n   *     viewContainerRef?: ViewContainerRef;\n   *     closeButton?: string;\n   * }\n   *\n   * Opens an alert dialog with the provided config.\n   * Returns an MatDialogRef<TdAlertDialogComponent> object.\n   */\n  public openAlert(config: IAlertConfig): MatDialogRef<TdAlertDialogComponent> {\n    const dialogConfig: MatDialogConfig = this._createConfig(config);\n    const dialogRef: MatDialogRef<TdAlertDialogComponent> =\n      this._dialogService.open(TdAlertDialogComponent, dialogConfig);\n    const alertDialogComponent: TdAlertDialogComponent =\n      dialogRef.componentInstance;\n    alertDialogComponent.title = config.title;\n    alertDialogComponent.message = config.message;\n    if (config.closeButton) {\n      alertDialogComponent.closeButton = config.closeButton;\n    }\n    return dialogRef;\n  }\n\n  /**\n   * params:\n   * - config: IConfirmConfig {\n   *     message: string;\n   *     title?: string;\n   *     viewContainerRef?: ViewContainerRef;\n   *     acceptButton?: string;\n   *     cancelButton?: string;\n   *     isDestructive?: boolean;\n   * }\n   *\n   * Opens a confirm dialog with the provided config.\n   * Returns an MatDialogRef<TdConfirmDialogComponent> object.\n   */\n  public openConfirm(\n    config: IConfirmConfig\n  ): MatDialogRef<TdConfirmDialogComponent> {\n    const dialogConfig: MatDialogConfig = this._createConfig(config);\n    const dialogRef: MatDialogRef<TdConfirmDialogComponent> =\n      this._dialogService.open(TdConfirmDialogComponent, dialogConfig);\n    const confirmDialogComponent: TdConfirmDialogComponent =\n      dialogRef.componentInstance;\n    confirmDialogComponent.title = config.title;\n    confirmDialogComponent.message = config.message;\n    if (config.acceptButton) {\n      confirmDialogComponent.acceptButton = config.acceptButton;\n    }\n    if (config.isDestructive) {\n      confirmDialogComponent.isDestructive = config.isDestructive;\n    }\n    if (config.cancelButton) {\n      confirmDialogComponent.cancelButton = config.cancelButton;\n    }\n    return dialogRef;\n  }\n\n  /**\n   * params:\n   * - config: IPromptConfig {\n   *     message: string;\n   *     title?: string;\n   *     value?: string;\n   *     viewContainerRef?: ViewContainerRef;\n   *     acceptButton?: string;\n   *     cancelButton?: string;\n   * }\n   *\n   * Opens a prompt dialog with the provided config.\n   * Returns an MatDialogRef<TdPromptDialogComponent> object.\n   */\n  public openPrompt(\n    config: IPromptConfig\n  ): MatDialogRef<TdPromptDialogComponent> {\n    const dialogConfig: MatDialogConfig = this._createConfig(config);\n    const dialogRef: MatDialogRef<TdPromptDialogComponent> =\n      this._dialogService.open(TdPromptDialogComponent, dialogConfig);\n    const promptDialogComponent: TdPromptDialogComponent =\n      dialogRef.componentInstance;\n    promptDialogComponent.title = config.title;\n    promptDialogComponent.message = config.message;\n    promptDialogComponent.value = config.value;\n    if (config.acceptButton) {\n      promptDialogComponent.acceptButton = config.acceptButton;\n    }\n    if (config.cancelButton) {\n      promptDialogComponent.cancelButton = config.cancelButton;\n    }\n    return dialogRef;\n  }\n\n  /**\n   * Opens a draggable dialog containing the given component.\n   */\n  public openDraggable<T>({\n    component,\n    config,\n    dragHandleSelectors,\n    draggableClass,\n  }: IDraggableConfig<T>): IDraggableRefs<T> {\n    const matDialogRef: MatDialogRef<T, any> = this._dialogService.open(\n      component,\n      config\n    );\n    const dragRefSubject: Subject<DragRef> = new Subject<DragRef>();\n\n    const CDK_OVERLAY_PANE_SELECTOR = '.cdk-overlay-pane';\n    const CDK_OVERLAY_CONTAINER_SELECTOR = '.cdk-overlay-container';\n\n    matDialogRef.afterOpened().subscribe(() => {\n      const dialogElement: HTMLElement = <HTMLElement>(\n        this._document.getElementById(matDialogRef.id)\n      );\n\n      if (!dialogElement) {\n        return;\n      }\n\n      const draggableElement: DragRef =\n        this._dragDrop.createDrag(dialogElement);\n\n      if (draggableClass) {\n        const childComponent = dialogElement.firstElementChild;\n        this._renderer2.addClass(childComponent, draggableClass);\n      }\n      if (dragHandleSelectors && dragHandleSelectors.length) {\n        const dragHandles: Element[] = dragHandleSelectors.reduce(\n          (acc: Element[], curr: string) => [\n            ...acc,\n            ...Array.from(dialogElement.querySelectorAll(curr)),\n          ],\n          []\n        );\n        if (dragHandles.length > 0) {\n          draggableElement.withHandles(<HTMLElement[]>dragHandles);\n        }\n      }\n      const rootElement = dialogElement.closest(CDK_OVERLAY_PANE_SELECTOR);\n      if (rootElement) {\n        draggableElement.withRootElement(<HTMLElement>rootElement);\n      }\n\n      const boundaryElement = dialogElement.closest(\n        CDK_OVERLAY_CONTAINER_SELECTOR\n      );\n      if (boundaryElement) {\n        draggableElement.withBoundaryElement(<HTMLElement>boundaryElement);\n      }\n      dragRefSubject.next(draggableElement);\n    });\n\n    return { matDialogRef, dragRefSubject };\n  }\n\n  private _createConfig(config: IDialogConfig): MatDialogConfig {\n    const dialogConfig: MatDialogConfig = new MatDialogConfig();\n    dialogConfig.width = '400px';\n    Object.assign(dialogConfig, config);\n    return dialogConfig;\n  }\n}\n"]}
|
215
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.service.js","sourceRoot":"","sources":["../../../../../../libs/angular/dialogs/src/services/dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject, Renderer2, RendererFactory2 } from '@angular/core';\nimport {\n  MatDialog,\n  MatDialogRef,\n  MatDialogConfig,\n} from '@angular/material/dialog';\nimport { ComponentType } from '@angular/cdk/portal';\n\nimport { TdAlertDialogComponent } from '../alert-dialog/alert-dialog.component';\nimport { TdConfirmDialogComponent } from '../confirm-dialog/confirm-dialog.component';\nimport { TdPromptDialogComponent } from '../prompt-dialog/prompt-dialog.component';\nimport { DragDrop, DragRef } from '@angular/cdk/drag-drop';\nimport { DOCUMENT } from '@angular/common';\nimport { Subject } from 'rxjs';\nimport {\n  TdStatusDialogStates,\n  TdStatusDialogComponent,\n  TdStatusDialogDetailsLabels,\n} from '../status-dialog/status-dialog.component';\n\nexport interface IDialogConfig extends MatDialogConfig {\n  title?: string;\n  message: string;\n}\n\nexport interface IAlertConfig extends IDialogConfig {\n  closeButton?: string;\n}\n\nexport interface IConfirmConfig extends IDialogConfig {\n  acceptButton?: string;\n  cancelButton?: string;\n  isDestructive?: boolean;\n}\n\nexport interface IPromptConfig extends IConfirmConfig {\n  value?: string;\n}\n\nexport interface IStatusConfig extends IAlertConfig {\n  state?: TdStatusDialogStates;\n  details?: string;\n  detailsLabels?: TdStatusDialogDetailsLabels;\n}\n\nexport interface IDraggableConfig<T> {\n  component: ComponentType<T>;\n  config?: MatDialogConfig;\n  // CSS selectors of element(s) inside the component meant to be drag handle(s)\n  dragHandleSelectors?: string[];\n  // Class that will be added to the component signifying drag-ability\n  draggableClass?: string;\n}\n\nexport interface IDraggableRefs<T> {\n  matDialogRef: MatDialogRef<T>;\n  dragRefSubject: Subject<DragRef>;\n}\n\n@Injectable()\nexport class TdDialogService {\n  private _renderer2: Renderer2;\n\n  constructor(\n    @Inject(DOCUMENT) private _document: any,\n    private _dialogService: MatDialog,\n    private _dragDrop: DragDrop,\n    private rendererFactory: RendererFactory2\n  ) {\n    this._renderer2 = rendererFactory.createRenderer(undefined, null);\n  }\n\n  /**\n   * params:\n   * - component: ComponentType<T>\n   * - config: MatDialogConfig\n   * Wrapper function over the open() method in MatDialog.\n   * Opens a modal dialog containing the given component.\n   */\n  public open<T>(\n    component: ComponentType<T>,\n    config?: MatDialogConfig\n  ): MatDialogRef<T> {\n    return this._dialogService.open(component, config);\n  }\n\n  /**\n   * Wrapper function over the closeAll() method in MatDialog.\n   * Closes all of the currently-open dialogs.\n   */\n  public closeAll(): void {\n    this._dialogService.closeAll();\n  }\n\n  /**\n   * params:\n   * - config: IAlertConfig {\n   *     message: string;\n   *     title?: string;\n   *     viewContainerRef?: ViewContainerRef;\n   *     closeButton?: string;\n   * }\n   *\n   * Opens an alert dialog with the provided config.\n   * Returns an MatDialogRef<TdAlertDialogComponent> object.\n   */\n  public openAlert(config: IAlertConfig): MatDialogRef<TdAlertDialogComponent> {\n    const dialogConfig: MatDialogConfig = this._createConfig(config);\n    const dialogRef: MatDialogRef<TdAlertDialogComponent> =\n      this._dialogService.open(TdAlertDialogComponent, dialogConfig);\n    const alertDialogComponent: TdAlertDialogComponent =\n      dialogRef.componentInstance;\n    alertDialogComponent.title = config.title;\n    alertDialogComponent.message = config.message;\n    if (config.closeButton) {\n      alertDialogComponent.closeButton = config.closeButton;\n    }\n    return dialogRef;\n  }\n\n  /**\n   * params:\n   * - config: IConfirmConfig {\n   *     message: string;\n   *     title?: string;\n   *     viewContainerRef?: ViewContainerRef;\n   *     acceptButton?: string;\n   *     cancelButton?: string;\n   *     isDestructive?: boolean;\n   * }\n   *\n   * Opens a confirm dialog with the provided config.\n   * Returns an MatDialogRef<TdConfirmDialogComponent> object.\n   */\n  public openConfirm(\n    config: IConfirmConfig\n  ): MatDialogRef<TdConfirmDialogComponent> {\n    const dialogConfig: MatDialogConfig = this._createConfig(config);\n    const dialogRef: MatDialogRef<TdConfirmDialogComponent> =\n      this._dialogService.open(TdConfirmDialogComponent, dialogConfig);\n    const confirmDialogComponent: TdConfirmDialogComponent =\n      dialogRef.componentInstance;\n    confirmDialogComponent.title = config.title;\n    confirmDialogComponent.message = config.message;\n    if (config.acceptButton) {\n      confirmDialogComponent.acceptButton = config.acceptButton;\n    }\n    if (config.isDestructive) {\n      confirmDialogComponent.isDestructive = config.isDestructive;\n    }\n    if (config.cancelButton) {\n      confirmDialogComponent.cancelButton = config.cancelButton;\n    }\n    return dialogRef;\n  }\n\n  /**\n   * params:\n   * - config: IPromptConfig {\n   *     message: string;\n   *     title?: string;\n   *     value?: string;\n   *     viewContainerRef?: ViewContainerRef;\n   *     acceptButton?: string;\n   *     cancelButton?: string;\n   * }\n   *\n   * Opens a prompt dialog with the provided config.\n   * Returns an MatDialogRef<TdPromptDialogComponent> object.\n   */\n  public openPrompt(\n    config: IPromptConfig\n  ): MatDialogRef<TdPromptDialogComponent> {\n    const dialogConfig: MatDialogConfig = this._createConfig(config);\n    const dialogRef: MatDialogRef<TdPromptDialogComponent> =\n      this._dialogService.open(TdPromptDialogComponent, dialogConfig);\n    const promptDialogComponent: TdPromptDialogComponent =\n      dialogRef.componentInstance;\n    promptDialogComponent.title = config.title;\n    promptDialogComponent.message = config.message;\n    promptDialogComponent.value = config.value;\n    if (config.acceptButton) {\n      promptDialogComponent.acceptButton = config.acceptButton;\n    }\n    if (config.cancelButton) {\n      promptDialogComponent.cancelButton = config.cancelButton;\n    }\n    return dialogRef;\n  }\n\n  /**\n   * Opens a draggable dialog containing the given component.\n   */\n  public openDraggable<T>({\n    component,\n    config,\n    dragHandleSelectors,\n    draggableClass,\n  }: IDraggableConfig<T>): IDraggableRefs<T> {\n    const matDialogRef: MatDialogRef<T, any> = this._dialogService.open(\n      component,\n      config\n    );\n    const dragRefSubject: Subject<DragRef> = new Subject<DragRef>();\n\n    const CDK_OVERLAY_PANE_SELECTOR = '.cdk-overlay-pane';\n    const CDK_OVERLAY_CONTAINER_SELECTOR = '.cdk-overlay-container';\n\n    matDialogRef.afterOpened().subscribe(() => {\n      const dialogElement: HTMLElement = <HTMLElement>(\n        this._document.getElementById(matDialogRef.id)\n      );\n\n      if (!dialogElement) {\n        return;\n      }\n\n      const draggableElement: DragRef =\n        this._dragDrop.createDrag(dialogElement);\n\n      if (draggableClass) {\n        const childComponent = dialogElement.firstElementChild;\n        this._renderer2.addClass(childComponent, draggableClass);\n      }\n      if (dragHandleSelectors && dragHandleSelectors.length) {\n        const dragHandles: Element[] = dragHandleSelectors.reduce(\n          (acc: Element[], curr: string) => [\n            ...acc,\n            ...Array.from(dialogElement.querySelectorAll(curr)),\n          ],\n          []\n        );\n        if (dragHandles.length > 0) {\n          draggableElement.withHandles(<HTMLElement[]>dragHandles);\n        }\n      }\n      const rootElement = dialogElement.closest(CDK_OVERLAY_PANE_SELECTOR);\n      if (rootElement) {\n        draggableElement.withRootElement(<HTMLElement>rootElement);\n      }\n\n      const boundaryElement = dialogElement.closest(\n        CDK_OVERLAY_CONTAINER_SELECTOR\n      );\n      if (boundaryElement) {\n        draggableElement.withBoundaryElement(<HTMLElement>boundaryElement);\n      }\n      dragRefSubject.next(draggableElement);\n    });\n\n    return { matDialogRef, dragRefSubject };\n  }\n\n  private _createConfig(config: IDialogConfig): MatDialogConfig {\n    const dialogConfig: MatDialogConfig = new MatDialogConfig();\n    dialogConfig.width = '400px';\n    Object.assign(dialogConfig, config);\n    return dialogConfig;\n  }\n\n  /**\n   * params:\n   * - config: IStatusConfig {\n   *     closeButton?: string;\n   *     details?: string;\n   *     detailsLabels?: TdStatusDialogDetailsLabels;\n   *     message: string;\n   *     state?: 'error' | 'positive' | 'warning'\n   *     title?: string;\n   *     viewContainerRef?: ViewContainerRef;\n   * }\n   *\n   * Opens a status dialog with the provided config.\n   * Returns an MatDialogRef<TdStatusDialogComponent> object.\n   */\n  public openStatus(\n    config: IStatusConfig\n  ): MatDialogRef<TdStatusDialogComponent> {\n    config.panelClass = 'td-status-dialog';\n    config.autoFocus = false;\n    config.width = '575px';\n    config.maxWidth = '96vw';\n    const dialogConfig: MatDialogConfig = this._createConfig(config);\n    const dialogRef: MatDialogRef<TdStatusDialogComponent> =\n      this._dialogService.open(TdStatusDialogComponent, dialogConfig);\n    const statusDialogComponent: TdStatusDialogComponent =\n      dialogRef.componentInstance;\n    statusDialogComponent.title = config.title;\n    statusDialogComponent.message = config.message;\n    statusDialogComponent.state = config.state;\n    statusDialogComponent.details = config.details;\n    if (config.detailsLabels) {\n      statusDialogComponent.detailsLabels = config.detailsLabels;\n    }\n    if (config.closeButton) {\n      statusDialogComponent.closeButton = config.closeButton;\n    }\n    return dialogRef;\n  }\n}\n"]}
|