@c8y/ngx-components 1021.22.150 → 1021.22.153
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/core/forms/reactive-validators.d.ts +1 -0
- package/core/forms/reactive-validators.d.ts.map +1 -1
- package/core/modal/modal-confirm.component.d.ts +10 -3
- package/core/modal/modal-confirm.component.d.ts.map +1 -1
- package/core/modal/modal.module.d.ts +3 -2
- package/core/modal/modal.module.d.ts.map +1 -1
- package/core/modal/modal.service.d.ts +2 -1
- package/core/modal/modal.service.d.ts.map +1 -1
- package/esm2022/core/bootstrap/cookie-banner/cookie-banner-preferences-modal/cookie-banner-preferences-modal.component.mjs +1 -1
- package/esm2022/core/forms/reactive-validators.mjs +9 -1
- package/esm2022/core/modal/modal-confirm.component.mjs +32 -5
- package/esm2022/core/modal/modal.module.mjs +5 -4
- package/esm2022/core/modal/modal.service.mjs +11 -3
- package/esm2022/sub-assets/delete-assets-modal/delete-assets-modal.component.mjs +1 -1
- package/esm2022/sub-assets/unassign-assets-modal/unassign-modal.component.mjs +1 -1
- package/esm2022/tenants/tenant-list/tenant-list.component.mjs +72 -33
- package/esm2022/widgets/implementations/kpi/kpi-widget-config/kpi-widget-config.component.mjs +4 -3
- package/fesm2022/c8y-ngx-components-sub-assets.mjs +2 -2
- package/fesm2022/c8y-ngx-components-sub-assets.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-tenants.mjs +71 -32
- package/fesm2022/c8y-ngx-components-tenants.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-widgets-implementations-kpi.mjs +3 -2
- package/fesm2022/c8y-ngx-components-widgets-implementations-kpi.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components.mjs +104 -62
- package/fesm2022/c8y-ngx-components.mjs.map +1 -1
- package/locales/de.po +12 -0
- package/locales/es.po +12 -0
- package/locales/fr.po +12 -0
- package/locales/ja_JP.po +12 -0
- package/locales/ko.po +12 -0
- package/locales/locales.pot +12 -0
- package/locales/nl.po +12 -0
- package/locales/pl.po +12 -0
- package/locales/pt_BR.po +12 -0
- package/locales/zh_CN.po +12 -0
- package/locales/zh_TW.po +12 -0
- package/package.json +1 -1
- package/tenants/tenant-list/tenant-list.component.d.ts +1 -0
- package/tenants/tenant-list/tenant-list.component.d.ts.map +1 -1
- package/widgets/implementations/kpi/kpi-widget-config/kpi-widget-config.component.d.ts.map +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"reactive-validators.d.ts","sourceRoot":"","sources":["../../../core/forms/reactive-validators.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgD,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAK3F,qBAAa,aAAa;IACxB,MAAM,CAAC,eAAe,IAAI,WAAW;IA8BrC,MAAM,CAAC,oBAAoB,IAAI,WAAW;IAkC1C,MAAM,CAAC,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,WAAW;IA2C9C,MAAM,CAAC,cAAc,CAAC,SAAS,EAAE,MAAM,EAAE,eAAe,SAAqB,GAAG,WAAW;IA6B3F,MAAM,CAAC,cAAc,CAAC,SAAS,EAAE,MAAM,EAAE,eAAe,SAAqB,GAAG,WAAW;IA6B3F,MAAM,CAAC,cAAc,CAAC,OAAO,EAAE;QAC7B,mBAAmB,CAAC,EAAE,MAAM,CAAC;QAC7B,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,kBAAkB,CAAC,EAAE,MAAM,EAAE,CAAC;KAC/B,GAAG,WAAW;IAyCf,OAAO,CAAC,MAAM,CAAC,YAAY;CAkB5B"}
|
|
1
|
+
{"version":3,"file":"reactive-validators.d.ts","sourceRoot":"","sources":["../../../core/forms/reactive-validators.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgD,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAK3F,qBAAa,aAAa;IACxB,MAAM,CAAC,gBAAgB,IAAI,WAAW;IAStC,MAAM,CAAC,eAAe,IAAI,WAAW;IA8BrC,MAAM,CAAC,oBAAoB,IAAI,WAAW;IAkC1C,MAAM,CAAC,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,WAAW;IA2C9C,MAAM,CAAC,cAAc,CAAC,SAAS,EAAE,MAAM,EAAE,eAAe,SAAqB,GAAG,WAAW;IA6B3F,MAAM,CAAC,cAAc,CAAC,SAAS,EAAE,MAAM,EAAE,eAAe,SAAqB,GAAG,WAAW;IA6B3F,MAAM,CAAC,cAAc,CAAC,OAAO,EAAE;QAC7B,mBAAmB,CAAC,EAAE,MAAM,CAAC;QAC7B,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,kBAAkB,CAAC,EAAE,MAAM,EAAE,CAAC;KAC/B,GAAG,WAAW;IAyCf,OAAO,CAAC,MAAM,CAAC,YAAY;CAkB5B"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { OnDestroy } from '@angular/core';
|
|
1
|
+
import { OnDestroy, OnInit } from '@angular/core';
|
|
2
2
|
import { BsModalRef } from 'ngx-bootstrap/modal';
|
|
3
3
|
import { Observable } from 'rxjs';
|
|
4
4
|
import { StatusType } from '../common/status.model';
|
|
@@ -20,7 +20,7 @@ export interface ConfirmOption {
|
|
|
20
20
|
*/
|
|
21
21
|
disabledByKey?: string;
|
|
22
22
|
}
|
|
23
|
-
export declare class ConfirmModalComponent implements OnDestroy {
|
|
23
|
+
export declare class ConfirmModalComponent implements OnInit, OnDestroy {
|
|
24
24
|
private modal;
|
|
25
25
|
result: Promise<boolean | {
|
|
26
26
|
confirmed: boolean;
|
|
@@ -34,15 +34,22 @@ export declare class ConfirmModalComponent implements OnDestroy {
|
|
|
34
34
|
body: string | SafeHtml;
|
|
35
35
|
confirmOptions: ConfirmOptions;
|
|
36
36
|
status: StatusType;
|
|
37
|
+
requireCodeVerification?: boolean;
|
|
37
38
|
set labels(labels: ModalLabels);
|
|
38
39
|
get labels(): ModalLabels;
|
|
40
|
+
code: string;
|
|
41
|
+
confirmString: string;
|
|
39
42
|
private _labels;
|
|
40
43
|
constructor(modal: BsModalRef);
|
|
44
|
+
ngOnInit(): void;
|
|
41
45
|
get classIcon(): string;
|
|
42
46
|
get classAlert(): string;
|
|
43
47
|
ngOnDestroy(): void;
|
|
44
48
|
isHtml(str: string | SafeHtml): boolean;
|
|
49
|
+
canConfirmWithCode(): boolean;
|
|
50
|
+
get isOkButtonDisabled(): boolean;
|
|
51
|
+
private generateRandomCode;
|
|
45
52
|
static ɵfac: i0.ɵɵFactoryDeclaration<ConfirmModalComponent, never>;
|
|
46
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<ConfirmModalComponent, "c8y-confirm-modal", never, { "title": { "alias": "title"; "required": false; }; "body": { "alias": "body"; "required": false; }; "confirmOptions": { "alias": "confirmOptions"; "required": false; }; "status": { "alias": "status"; "required": false; }; "labels": { "alias": "labels"; "required": false; }; }, {}, never, ["*"], false, never>;
|
|
53
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<ConfirmModalComponent, "c8y-confirm-modal", never, { "title": { "alias": "title"; "required": false; }; "body": { "alias": "body"; "required": false; }; "confirmOptions": { "alias": "confirmOptions"; "required": false; }; "status": { "alias": "status"; "required": false; }; "requireCodeVerification": { "alias": "requireCodeVerification"; "required": false; }; "labels": { "alias": "labels"; "required": false; }; }, {}, never, ["*"], false, never>;
|
|
47
54
|
}
|
|
48
55
|
//# sourceMappingURL=modal-confirm.component.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"modal-confirm.component.d.ts","sourceRoot":"","sources":["../../../core/modal/modal-confirm.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,SAAS,EAAE,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"modal-confirm.component.d.ts","sourceRoot":"","sources":["../../../core/modal/modal-confirm.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,SAAS,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEpE,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AACjD,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAClC,OAAO,EAAoC,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACtF,OAAO,EAAE,WAAW,EAAE,MAAM,oCAAoC,CAAC;AACjE,OAAO,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAC;;AAErD;;GAEG;AACH,MAAM,WAAW,cAAc;IAC7B,CAAC,GAAG,EAAE,MAAM,GAAG,aAAa,CAAC;CAC9B;AAED,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,MAAM,CAAC,EAAE,OAAO,GAAG,CAAC,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,GAAG,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC;IAC5E;;OAEG;IACH,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAED,qBAIa,qBAAsB,YAAW,MAAM,EAAE,SAAS;IAsBjD,OAAO,CAAC,KAAK;IArBzB,MAAM,EAAE,OAAO,CAAC,OAAO,GAAG;QAAE,SAAS,EAAE,OAAO,CAAC;QAAC,cAAc,EAAE;YAAE,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAA;SAAE,CAAA;KAAE,CAAC,CAAC;IAC9F,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,KAAK,EAAE,MAAM,IAAI,CAAC;IACT,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,GAAG,QAAQ,CAAC;IACxB,cAAc,EAAE,cAAc,CAAC;IAC/B,MAAM,EAAE,UAAU,CAAe;IACjC,uBAAuB,CAAC,EAAE,OAAO,CAAS;IACnD,IAAa,MAAM,CAAC,MAAM,EAAE,WAAW,EAGtC;IAED,IAAI,MAAM,IAAI,WAAW,CAExB;IAED,IAAI,EAAE,MAAM,CAAC;IACb,aAAa,SAAM;IAEnB,OAAO,CAAC,OAAO,CAAc;gBACT,KAAK,EAAE,UAAU;IA2BrC,QAAQ;IAMR,IAAI,SAAS,WAEZ;IAED,IAAI,UAAU,WAEb;IAED,WAAW;IAIX,MAAM,CAAC,GAAG,EAAE,MAAM,GAAG,QAAQ,GAAG,OAAO;IAKvC,kBAAkB,IAAI,OAAO;IAI7B,IAAI,kBAAkB,IAAI,OAAO,CAKhC;IAED,OAAO,CAAC,kBAAkB;yCAnFf,qBAAqB;2CAArB,qBAAqB;CA0FjC"}
|
|
@@ -4,7 +4,8 @@ import * as i2 from "./modal.component";
|
|
|
4
4
|
import * as i3 from "./popover-confirm.component";
|
|
5
5
|
import * as i4 from "ngx-bootstrap/modal";
|
|
6
6
|
import * as i5 from "../common/common.module";
|
|
7
|
-
import * as i6 from "
|
|
7
|
+
import * as i6 from "@angular/forms";
|
|
8
|
+
import * as i7 from "ngx-bootstrap/popover";
|
|
8
9
|
/**
|
|
9
10
|
* The angular module definition for modal.
|
|
10
11
|
* @exports ConfirmModalComponent
|
|
@@ -13,7 +14,7 @@ import * as i6 from "ngx-bootstrap/popover";
|
|
|
13
14
|
*/
|
|
14
15
|
export declare class ModalModule {
|
|
15
16
|
static ɵfac: i0.ɵɵFactoryDeclaration<ModalModule, never>;
|
|
16
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<ModalModule, [typeof i1.ConfirmModalComponent, typeof i2.ModalComponent, typeof i3.PopoverConfirmComponent], [typeof i4.ModalModule, typeof i5.CommonModule, typeof i6.PopoverModule], [typeof i1.ConfirmModalComponent, typeof i2.ModalComponent, typeof i3.PopoverConfirmComponent]>;
|
|
17
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<ModalModule, [typeof i1.ConfirmModalComponent, typeof i2.ModalComponent, typeof i3.PopoverConfirmComponent], [typeof i4.ModalModule, typeof i5.CommonModule, typeof i6.FormsModule, typeof i7.PopoverModule], [typeof i1.ConfirmModalComponent, typeof i2.ModalComponent, typeof i3.PopoverConfirmComponent]>;
|
|
17
18
|
static ɵinj: i0.ɵɵInjectorDeclaration<ModalModule>;
|
|
18
19
|
}
|
|
19
20
|
//# sourceMappingURL=modal.module.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"modal.module.d.ts","sourceRoot":"","sources":["../../../core/modal/modal.module.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"modal.module.d.ts","sourceRoot":"","sources":["../../../core/modal/modal.module.ts"],"names":[],"mappings":";;;;;;;;AAUA;;;;;GAKG;AACH,qBAMa,WAAW;yCAAX,WAAW;0CAAX,WAAW;0CAAX,WAAW;CAAG"}
|
|
@@ -19,8 +19,9 @@ export declare class ModalService {
|
|
|
19
19
|
* @param labels The labels to use. Default: { ok: 'Confirm', cancel: 'Cancel'}
|
|
20
20
|
* @param confirmOptions Selection options to display as checkbox list.
|
|
21
21
|
* @param productExperienceEvent Additional data to attach to custom product experience events.
|
|
22
|
+
* @param requireCodeVerification Whether to require user to retype a random code for confirmation.
|
|
22
23
|
*/
|
|
23
|
-
confirm(title: string, body: string, status?: StatusType, labels?: ConfirmModalComponent['labels'], confirmOptions?: ConfirmOptions, productExperienceEvent?: ProductExperienceEvent): Promise<boolean | {
|
|
24
|
+
confirm(title: string, body: string, status?: StatusType, labels?: ConfirmModalComponent['labels'], confirmOptions?: ConfirmOptions, productExperienceEvent?: ProductExperienceEvent, requireCodeVerification?: boolean): Promise<boolean | {
|
|
24
25
|
confirmed: boolean;
|
|
25
26
|
confirmOptions: {
|
|
26
27
|
[key: string]: boolean;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"modal.service.d.ts","sourceRoot":"","sources":["../../../core/modal/modal.service.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAU,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAE5D,OAAO,EAAE,gBAAgB,EAAE,MAAM,yCAAyC,CAAC;AAC3E,OAAO,EAAE,sBAAsB,EAAE,MAAM,gDAAgD,CAAC;AACxF,OAAO,EAAE,qBAAqB,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;;AAElF;;GAEG;AACH,qBAGa,YAAY;IAErB,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,gBAAgB;gBADhB,YAAY,EAAE,cAAc,EAC5B,gBAAgB,EAAE,gBAAgB;IAG5C
|
|
1
|
+
{"version":3,"file":"modal.service.d.ts","sourceRoot":"","sources":["../../../core/modal/modal.service.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAU,UAAU,EAAE,MAAM,wBAAwB,CAAC;AAE5D,OAAO,EAAE,gBAAgB,EAAE,MAAM,yCAAyC,CAAC;AAC3E,OAAO,EAAE,sBAAsB,EAAE,MAAM,gDAAgD,CAAC;AACxF,OAAO,EAAE,qBAAqB,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;;AAElF;;GAEG;AACH,qBAGa,YAAY;IAErB,OAAO,CAAC,YAAY;IACpB,OAAO,CAAC,gBAAgB;gBADhB,YAAY,EAAE,cAAc,EAC5B,gBAAgB,EAAE,gBAAgB;IAG5C;;;;;;;;;OASG;IACG,OAAO,CACX,KAAK,EAAE,MAAM,EACb,IAAI,EAAE,MAAM,EACZ,MAAM,GAAE,UAAwB,EAChC,MAAM,GAAE,qBAAqB,CAAC,QAAQ,CAAM,EAC5C,cAAc,GAAE,cAAmB,EACnC,sBAAsB,GAAE,sBAAsD,EAC9E,uBAAuB,UAAQ;;;;;;IA0BjC;;;;;;;OAOG;IACG,WAAW,CACf,KAAK,EAAE,MAAM,EACb,IAAI,EAAE,MAAM,EACZ,MAAM,GAAE,UAAwB,EAChC,gBAAgB,GAAE,MAA2B,EAC7C,sBAAsB,GAAE,sBAAsD;;;;;;IAgBhF;;;;;OAKG;IACG,aAAa,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,MAAM,GAAE,UAA2B,EAAE,MAAM,GAAE,GAAQ;;;;;;IAUxF,OAAO,CAAC,YAAY;yCA9FT,YAAY;6CAAZ,YAAY;CAkHxB"}
|
|
@@ -44,7 +44,7 @@ export class CookieBannerPreferencesModalComponent {
|
|
|
44
44
|
return this.cookieBannerService.getCookieDescription(cookieType);
|
|
45
45
|
}
|
|
46
46
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: CookieBannerPreferencesModalComponent, deps: [{ token: i1.CookieBannerService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
47
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: CookieBannerPreferencesModalComponent, selector: "c8y-cookie-banner-preferences-modal", viewQueries: [{ propertyName: "modalRef", first: true, predicate: ["modalRef"], descendants: true }], ngImport: i0, template: "<c8y-confirm-modal [title]=\"title\" [status]=\"status\" [labels]=\"labels\" #modalRef>\n\n <div *ngFor=\"let item of configCookiePreferencesList\" class=\"row p-t-8 p-b-8 separator-top\">\n <div class=\"col-xs-2\">\n <div class=\"text-center\">\n <label class=\"c8y-switch\">\n <input\n name=\"{{ item.name }}\"\n type=\"checkbox\"\n [(ngModel)]=\"item.value\"\n [disabled]=\"item.isReadonly\"\n />\n <span></span>\n </label>\n </div>\n </div>\n <div class=\"col-xs-10\">\n <h4 class=\"text-medium\">\n {{ item.name | translate | humanize }}\n </h4>\n <p>\n {{ getCookieDescription(item.name) | translate }}\n </p>\n </div>\n </div>\n</c8y-confirm-modal>\n", dependencies: [{ kind: "directive", type: i2.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i4.ConfirmModalComponent, selector: "c8y-confirm-modal", inputs: ["title", "body", "confirmOptions", "status", "labels"] }, { kind: "pipe", type: i5.C8yTranslatePipe, name: "translate" }, { kind: "pipe", type: i6.HumanizePipe, name: "humanize" }] }); }
|
|
47
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: CookieBannerPreferencesModalComponent, selector: "c8y-cookie-banner-preferences-modal", viewQueries: [{ propertyName: "modalRef", first: true, predicate: ["modalRef"], descendants: true }], ngImport: i0, template: "<c8y-confirm-modal [title]=\"title\" [status]=\"status\" [labels]=\"labels\" #modalRef>\n\n <div *ngFor=\"let item of configCookiePreferencesList\" class=\"row p-t-8 p-b-8 separator-top\">\n <div class=\"col-xs-2\">\n <div class=\"text-center\">\n <label class=\"c8y-switch\">\n <input\n name=\"{{ item.name }}\"\n type=\"checkbox\"\n [(ngModel)]=\"item.value\"\n [disabled]=\"item.isReadonly\"\n />\n <span></span>\n </label>\n </div>\n </div>\n <div class=\"col-xs-10\">\n <h4 class=\"text-medium\">\n {{ item.name | translate | humanize }}\n </h4>\n <p>\n {{ getCookieDescription(item.name) | translate }}\n </p>\n </div>\n </div>\n</c8y-confirm-modal>\n", dependencies: [{ kind: "directive", type: i2.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i4.ConfirmModalComponent, selector: "c8y-confirm-modal", inputs: ["title", "body", "confirmOptions", "status", "requireCodeVerification", "labels"] }, { kind: "pipe", type: i5.C8yTranslatePipe, name: "translate" }, { kind: "pipe", type: i6.HumanizePipe, name: "humanize" }] }); }
|
|
48
48
|
}
|
|
49
49
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: CookieBannerPreferencesModalComponent, decorators: [{
|
|
50
50
|
type: Component,
|
|
@@ -3,6 +3,14 @@ import { DatapointLibraryValidationErrors } from './validation-pattern';
|
|
|
3
3
|
import { get } from 'lodash-es';
|
|
4
4
|
// @dynamic
|
|
5
5
|
export class C8yValidators {
|
|
6
|
+
static integerValidator() {
|
|
7
|
+
return (control) => {
|
|
8
|
+
if (control.value == null || control.value === '') {
|
|
9
|
+
return null;
|
|
10
|
+
}
|
|
11
|
+
return Number.isInteger(control.value) ? null : { integer: true };
|
|
12
|
+
};
|
|
13
|
+
}
|
|
6
14
|
static minMaxValidator() {
|
|
7
15
|
return (control) => {
|
|
8
16
|
const min = control.get(`min`);
|
|
@@ -195,4 +203,4 @@ export class C8yValidators {
|
|
|
195
203
|
return removedError;
|
|
196
204
|
}
|
|
197
205
|
}
|
|
198
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reactive-validators.js","sourceRoot":"","sources":["../../../../core/forms/reactive-validators.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, FormArray, ValidationErrors, ValidatorFn } from '@angular/forms';\nimport { DatapointLibraryValidationErrors } from './validation-pattern';\nimport { get } from 'lodash-es';\n\n// @dynamic\nexport class C8yValidators {\n  static minMaxValidator(): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n      const min = control.get(`min`);\n      const max = control.get(`max`);\n\n      const minDefined = min && min.value !== undefined && min.value !== null;\n      const maxDefined = max && max.value !== undefined && max.value !== null;\n\n      // remove previous errors\n      this.removeErrors(min, [DatapointLibraryValidationErrors.GREATER_THAN_RANGE_MAX]);\n      this.removeErrors(max, [DatapointLibraryValidationErrors.LESS_THAN_RANGE_MIN]);\n\n      if (!minDefined || !maxDefined) {\n        return null;\n      }\n\n      // sets errors\n      if (min.value >= max.value) {\n        const minError = { [DatapointLibraryValidationErrors.GREATER_THAN_RANGE_MAX]: true };\n        const maxError = { [DatapointLibraryValidationErrors.LESS_THAN_RANGE_MIN]: true };\n        const errors = Object.assign({}, minError, maxError);\n        min.setErrors(Object.assign(minError, min.errors || {}));\n        max.setErrors(Object.assign(maxError, max.errors || {}));\n        return errors;\n      }\n\n      return null;\n    };\n  }\n\n  static requireBothMinAndMax(): ValidatorFn {\n    const errorAttribute = DatapointLibraryValidationErrors.SHOULD_BE_DEFINED;\n    return (control: AbstractControl): ValidationErrors | null => {\n      const min = control.get(`min`);\n      const max = control.get(`max`);\n\n      const minDefined = min && min.value !== undefined && min.value !== null;\n      const maxDefined = max && max.value !== undefined && max.value !== null;\n\n      const errors = {};\n      if (minDefined && !maxDefined && max) {\n        // sets error\n        const error = { [errorAttribute]: true };\n        max.setErrors(Object.assign({}, max.errors || {}, error));\n        Object.assign(errors, error);\n      } else {\n        // remove previous error\n        this.removeErrors(max, [errorAttribute]);\n      }\n\n      if (maxDefined && !minDefined && min) {\n        // sets error\n        const error = { [errorAttribute]: true };\n        min.setErrors(Object.assign({}, min.errors || {}, error));\n        Object.assign(errors, error);\n      } else {\n        // remove previous error\n        this.removeErrors(min, [errorAttribute]);\n      }\n\n      return Object.keys(errors).length ? errors : null;\n    };\n  }\n\n  static withinScale(field: string): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n      if (!field) {\n        return null;\n      }\n      const min = control.get(`range.min`);\n      const max = control.get(`range.max`);\n      const fieldControl = control.get(field);\n\n      const minDefined = min && min.value !== undefined && min.value !== null;\n      const maxDefined = max && max.value !== undefined && max.value !== null;\n      const fieldDefined =\n        fieldControl && fieldControl.value !== undefined && fieldControl.value !== null;\n\n      // remove previous errors\n      this.removeErrors(fieldControl, [\n        DatapointLibraryValidationErrors.GREATER_THAN_SCALE_MAX,\n        DatapointLibraryValidationErrors.LESS_THAN_SCALE_MIN\n      ]);\n\n      if (!minDefined || !maxDefined || !fieldDefined) {\n        return null;\n      }\n\n      const errors = {};\n\n      // sets errors\n      if (fieldControl.value < min.value) {\n        const error = { [DatapointLibraryValidationErrors.LESS_THAN_SCALE_MIN]: true };\n        fieldControl.setErrors(Object.assign({}, fieldControl.errors || {}, error));\n        Object.assign(errors, error);\n      }\n\n      if (fieldControl.value > max.value) {\n        const error = { [DatapointLibraryValidationErrors.GREATER_THAN_SCALE_MAX]: true };\n        fieldControl.setErrors(Object.assign({}, fieldControl.errors || {}, error));\n        Object.assign(errors, error);\n      }\n\n      return Object.keys(errors).length ? errors : null;\n    };\n  }\n\n  static maxActiveCount(maxActive: number, activeAttribute = 'details.__active'): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n      if (!Number.isInteger(maxActive) || Number.isNaN(maxActive)) {\n        return null;\n      }\n\n      if (!(control instanceof FormArray)) {\n        return null;\n      }\n      const formArray = control as FormArray;\n      const value: any[] = formArray.value;\n      if (!Array.isArray(value)) {\n        return null;\n      }\n\n      const filteredActiveEntries = value.filter(tmp => tmp && !!get(tmp, activeAttribute));\n      if (filteredActiveEntries.length <= maxActive) {\n        return null;\n      }\n\n      return {\n        [DatapointLibraryValidationErrors.MAX_ACTIVE_COUNT]: {\n          maxActive,\n          actualLength: filteredActiveEntries.length\n        }\n      };\n    };\n  }\n\n  static minActiveCount(minActive: number, activeAttribute = 'details.__active'): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n      if (!Number.isInteger(minActive) || Number.isNaN(minActive)) {\n        return null;\n      }\n\n      if (!(control instanceof FormArray)) {\n        return null;\n      }\n      const formArray = control as FormArray;\n      const value: any[] = formArray.value;\n      if (!Array.isArray(value)) {\n        return null;\n      }\n\n      const filteredActiveEntries = value.filter(tmp => tmp && !!get(tmp, activeAttribute));\n      if (filteredActiveEntries.length >= minActive) {\n        return null;\n      }\n\n      return {\n        [DatapointLibraryValidationErrors.MIN_ACTIVE_COUNT]: {\n          minActive,\n          actualLength: filteredActiveEntries.length\n        }\n      };\n    };\n  }\n\n  static filesValidator(options: {\n    maximumFileSizeInKb?: number;\n    typePrefix?: string;\n    allowedFileEndings?: string[];\n  }): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n      const files: { file: File }[] | null = control.value;\n      if (!files) {\n        return null;\n      }\n      for (const fileObj of files) {\n        const file = fileObj.file;\n        if (options.typePrefix && !file.type.startsWith(options.typePrefix)) {\n          return {\n            wrongFileType: {\n              wrongFileType: file.type\n            }\n          };\n        }\n\n        if (\n          options.allowedFileEndings?.length &&\n          !options.allowedFileEndings.some(ending => file.name.endsWith(ending))\n        ) {\n          return {\n            wrongFileEnding: {\n              allowedFileEndings: options.allowedFileEndings\n            }\n          };\n        }\n\n        if (file.size > options.maximumFileSizeInKb * 1024) {\n          const actualFileSize = file.size / 1024;\n          return {\n            maxFileSizeReached: {\n              maxFileSize: options.maximumFileSizeInKb,\n              actualFileSize: `~${actualFileSize.toFixed(0)}`\n            }\n          };\n        }\n      }\n      return null;\n    };\n  }\n\n  private static removeErrors(control: AbstractControl, errors: string[]): boolean {\n    if (!control || !control.errors) {\n      return false;\n    }\n    let removedError = false;\n    for (const error of errors) {\n      if (control.errors[error]) {\n        removedError = true;\n        delete control.errors[error];\n      }\n    }\n    if (removedError) {\n      control.setErrors(\n        Object.keys(control.errors).length ? Object.assign({}, control.errors) : null\n      );\n    }\n    return removedError;\n  }\n}\n"]}
|
|
206
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"reactive-validators.js","sourceRoot":"","sources":["../../../../core/forms/reactive-validators.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, FormArray, ValidationErrors, ValidatorFn } from '@angular/forms';\nimport { DatapointLibraryValidationErrors } from './validation-pattern';\nimport { get } from 'lodash-es';\n\n// @dynamic\nexport class C8yValidators {\n  static integerValidator(): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n      if (control.value == null || control.value === '') {\n        return null;\n      }\n      return Number.isInteger(control.value) ? null : { integer: true };\n    };\n  }\n\n  static minMaxValidator(): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n      const min = control.get(`min`);\n      const max = control.get(`max`);\n\n      const minDefined = min && min.value !== undefined && min.value !== null;\n      const maxDefined = max && max.value !== undefined && max.value !== null;\n\n      // remove previous errors\n      this.removeErrors(min, [DatapointLibraryValidationErrors.GREATER_THAN_RANGE_MAX]);\n      this.removeErrors(max, [DatapointLibraryValidationErrors.LESS_THAN_RANGE_MIN]);\n\n      if (!minDefined || !maxDefined) {\n        return null;\n      }\n\n      // sets errors\n      if (min.value >= max.value) {\n        const minError = { [DatapointLibraryValidationErrors.GREATER_THAN_RANGE_MAX]: true };\n        const maxError = { [DatapointLibraryValidationErrors.LESS_THAN_RANGE_MIN]: true };\n        const errors = Object.assign({}, minError, maxError);\n        min.setErrors(Object.assign(minError, min.errors || {}));\n        max.setErrors(Object.assign(maxError, max.errors || {}));\n        return errors;\n      }\n\n      return null;\n    };\n  }\n\n  static requireBothMinAndMax(): ValidatorFn {\n    const errorAttribute = DatapointLibraryValidationErrors.SHOULD_BE_DEFINED;\n    return (control: AbstractControl): ValidationErrors | null => {\n      const min = control.get(`min`);\n      const max = control.get(`max`);\n\n      const minDefined = min && min.value !== undefined && min.value !== null;\n      const maxDefined = max && max.value !== undefined && max.value !== null;\n\n      const errors = {};\n      if (minDefined && !maxDefined && max) {\n        // sets error\n        const error = { [errorAttribute]: true };\n        max.setErrors(Object.assign({}, max.errors || {}, error));\n        Object.assign(errors, error);\n      } else {\n        // remove previous error\n        this.removeErrors(max, [errorAttribute]);\n      }\n\n      if (maxDefined && !minDefined && min) {\n        // sets error\n        const error = { [errorAttribute]: true };\n        min.setErrors(Object.assign({}, min.errors || {}, error));\n        Object.assign(errors, error);\n      } else {\n        // remove previous error\n        this.removeErrors(min, [errorAttribute]);\n      }\n\n      return Object.keys(errors).length ? errors : null;\n    };\n  }\n\n  static withinScale(field: string): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n      if (!field) {\n        return null;\n      }\n      const min = control.get(`range.min`);\n      const max = control.get(`range.max`);\n      const fieldControl = control.get(field);\n\n      const minDefined = min && min.value !== undefined && min.value !== null;\n      const maxDefined = max && max.value !== undefined && max.value !== null;\n      const fieldDefined =\n        fieldControl && fieldControl.value !== undefined && fieldControl.value !== null;\n\n      // remove previous errors\n      this.removeErrors(fieldControl, [\n        DatapointLibraryValidationErrors.GREATER_THAN_SCALE_MAX,\n        DatapointLibraryValidationErrors.LESS_THAN_SCALE_MIN\n      ]);\n\n      if (!minDefined || !maxDefined || !fieldDefined) {\n        return null;\n      }\n\n      const errors = {};\n\n      // sets errors\n      if (fieldControl.value < min.value) {\n        const error = { [DatapointLibraryValidationErrors.LESS_THAN_SCALE_MIN]: true };\n        fieldControl.setErrors(Object.assign({}, fieldControl.errors || {}, error));\n        Object.assign(errors, error);\n      }\n\n      if (fieldControl.value > max.value) {\n        const error = { [DatapointLibraryValidationErrors.GREATER_THAN_SCALE_MAX]: true };\n        fieldControl.setErrors(Object.assign({}, fieldControl.errors || {}, error));\n        Object.assign(errors, error);\n      }\n\n      return Object.keys(errors).length ? errors : null;\n    };\n  }\n\n  static maxActiveCount(maxActive: number, activeAttribute = 'details.__active'): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n      if (!Number.isInteger(maxActive) || Number.isNaN(maxActive)) {\n        return null;\n      }\n\n      if (!(control instanceof FormArray)) {\n        return null;\n      }\n      const formArray = control as FormArray;\n      const value: any[] = formArray.value;\n      if (!Array.isArray(value)) {\n        return null;\n      }\n\n      const filteredActiveEntries = value.filter(tmp => tmp && !!get(tmp, activeAttribute));\n      if (filteredActiveEntries.length <= maxActive) {\n        return null;\n      }\n\n      return {\n        [DatapointLibraryValidationErrors.MAX_ACTIVE_COUNT]: {\n          maxActive,\n          actualLength: filteredActiveEntries.length\n        }\n      };\n    };\n  }\n\n  static minActiveCount(minActive: number, activeAttribute = 'details.__active'): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n      if (!Number.isInteger(minActive) || Number.isNaN(minActive)) {\n        return null;\n      }\n\n      if (!(control instanceof FormArray)) {\n        return null;\n      }\n      const formArray = control as FormArray;\n      const value: any[] = formArray.value;\n      if (!Array.isArray(value)) {\n        return null;\n      }\n\n      const filteredActiveEntries = value.filter(tmp => tmp && !!get(tmp, activeAttribute));\n      if (filteredActiveEntries.length >= minActive) {\n        return null;\n      }\n\n      return {\n        [DatapointLibraryValidationErrors.MIN_ACTIVE_COUNT]: {\n          minActive,\n          actualLength: filteredActiveEntries.length\n        }\n      };\n    };\n  }\n\n  static filesValidator(options: {\n    maximumFileSizeInKb?: number;\n    typePrefix?: string;\n    allowedFileEndings?: string[];\n  }): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n      const files: { file: File }[] | null = control.value;\n      if (!files) {\n        return null;\n      }\n      for (const fileObj of files) {\n        const file = fileObj.file;\n        if (options.typePrefix && !file.type.startsWith(options.typePrefix)) {\n          return {\n            wrongFileType: {\n              wrongFileType: file.type\n            }\n          };\n        }\n\n        if (\n          options.allowedFileEndings?.length &&\n          !options.allowedFileEndings.some(ending => file.name.endsWith(ending))\n        ) {\n          return {\n            wrongFileEnding: {\n              allowedFileEndings: options.allowedFileEndings\n            }\n          };\n        }\n\n        if (file.size > options.maximumFileSizeInKb * 1024) {\n          const actualFileSize = file.size / 1024;\n          return {\n            maxFileSizeReached: {\n              maxFileSize: options.maximumFileSizeInKb,\n              actualFileSize: `~${actualFileSize.toFixed(0)}`\n            }\n          };\n        }\n      }\n      return null;\n    };\n  }\n\n  private static removeErrors(control: AbstractControl, errors: string[]): boolean {\n    if (!control || !control.errors) {\n      return false;\n    }\n    let removedError = false;\n    for (const error of errors) {\n      if (control.errors[error]) {\n        removedError = true;\n        delete control.errors[error];\n      }\n    }\n    if (removedError) {\n      control.setErrors(\n        Object.keys(control.errors).length ? Object.assign({}, control.errors) : null\n      );\n    }\n    return removedError;\n  }\n}\n"]}
|
|
@@ -5,8 +5,9 @@ import { Status, statusAlert, statusIcons } from '../common/status.model';
|
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "ngx-bootstrap/modal";
|
|
7
7
|
import * as i2 from "@angular/common";
|
|
8
|
-
import * as i3 from "
|
|
9
|
-
import * as i4 from "../
|
|
8
|
+
import * as i3 from "@angular/forms";
|
|
9
|
+
import * as i4 from "../i18n/c8y-translate.pipe";
|
|
10
|
+
import * as i5 from "../common/show-if-filter.pipe";
|
|
10
11
|
export class ConfirmModalComponent {
|
|
11
12
|
set labels(labels) {
|
|
12
13
|
const { ok = 'OK', cancel = 'Cancel' } = labels || {};
|
|
@@ -18,6 +19,8 @@ export class ConfirmModalComponent {
|
|
|
18
19
|
constructor(modal) {
|
|
19
20
|
this.modal = modal;
|
|
20
21
|
this.status = Status.INFO;
|
|
22
|
+
this.requireCodeVerification = false;
|
|
23
|
+
this.confirmString = '';
|
|
21
24
|
this._labels = {
|
|
22
25
|
ok: 'OK',
|
|
23
26
|
cancel: 'Cancel'
|
|
@@ -28,6 +31,9 @@ export class ConfirmModalComponent {
|
|
|
28
31
|
this.modal.hide();
|
|
29
32
|
};
|
|
30
33
|
this.close = () => {
|
|
34
|
+
if (this.requireCodeVerification && !this.canConfirmWithCode()) {
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
31
37
|
resolve(isEmpty(this.confirmOptions)
|
|
32
38
|
? true
|
|
33
39
|
: {
|
|
@@ -38,6 +44,11 @@ export class ConfirmModalComponent {
|
|
|
38
44
|
};
|
|
39
45
|
});
|
|
40
46
|
}
|
|
47
|
+
ngOnInit() {
|
|
48
|
+
if (this.requireCodeVerification) {
|
|
49
|
+
this.code = this.generateRandomCode();
|
|
50
|
+
}
|
|
51
|
+
}
|
|
41
52
|
get classIcon() {
|
|
42
53
|
return `dlt-c8y-icon-${statusIcons[this.status]}`;
|
|
43
54
|
}
|
|
@@ -51,12 +62,26 @@ export class ConfirmModalComponent {
|
|
|
51
62
|
const doc = new DOMParser().parseFromString(str, 'text/html');
|
|
52
63
|
return Array.from(doc.body.childNodes).some(node => node.nodeType === Node.ELEMENT_NODE);
|
|
53
64
|
}
|
|
65
|
+
canConfirmWithCode() {
|
|
66
|
+
return this.confirmString === this.code;
|
|
67
|
+
}
|
|
68
|
+
get isOkButtonDisabled() {
|
|
69
|
+
if (this.requireCodeVerification) {
|
|
70
|
+
return !this.canConfirmWithCode();
|
|
71
|
+
}
|
|
72
|
+
return false;
|
|
73
|
+
}
|
|
74
|
+
generateRandomCode() {
|
|
75
|
+
// no l, I, 0, O chars to prevent confusion:
|
|
76
|
+
const chars = 'ABCDEFGHJKLMNPQRSTUVWXYZabcdefhijkmnoprstuvwxyz123456789';
|
|
77
|
+
return Array.from({ length: 5 }, () => chars.charAt(Math.floor(Math.random() * chars.length))).join('');
|
|
78
|
+
}
|
|
54
79
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: ConfirmModalComponent, deps: [{ token: i1.BsModalRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
55
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
80
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.9", type: ConfirmModalComponent, selector: "c8y-confirm-modal", inputs: { title: "title", body: "body", confirmOptions: "confirmOptions", status: "status", requireCodeVerification: "requireCodeVerification", labels: "labels" }, ngImport: i0, template: "<div\n class=\"c8y-prompt alert\"\n [ngClass]=\"[classAlert]\"\n data-cy=\"prompt-alert\"\n>\n <h3\n class=\"m-b-16 d-flex a-i-center\"\n *ngIf=\"title\"\n >\n <i\n class=\"dlt-c8y-icon\"\n [ngClass]=\"[classIcon]\"\n ></i>\n <span id=\"modal-title\">{{ title | translate }}</span>\n </h3>\n <div id=\"modal-body\">\n <p\n class=\"text-break-word m-b-16\"\n *ngIf=\"!isHtml(body)\"\n >\n {{ body | translate }}\n </p>\n <div\n class=\"text-break-word m-b-16\"\n *ngIf=\"isHtml(body)\"\n [innerHTML]=\"body | translate\"\n ></div>\n <div\n class=\"c8y-checkbox plain m-b-8\"\n *ngFor=\"let co of confirmOptions | showIfFilter | async | keyvalue\"\n >\n <label\n class=\"c8y-checkbox\"\n [title]=\"co.value.text | translate\"\n >\n <input\n type=\"checkbox\"\n [checked]=\"co.value.checked\"\n (change)=\"co.value.checked = !co.value.checked\"\n [disabled]=\"confirmOptions[co.value.disabledByKey]?.checked\"\n />\n <span></span>\n <span class=\"text-muted\">{{ co.value.text | translate }}</span>\n </label>\n </div>\n @if (requireCodeVerification) {\n <p class=\"text-break-word m-b-16\">\n <code>{{ code }}</code>\n </p>\n <form (submit)=\"$event.preventDefault()\">\n <div class=\"form-group\">\n <label for=\"confirmString\">\n {{ 'Confirm:' | translate }}\n </label>\n <input\n class=\"form-control\"\n id=\"confirmString\"\n placeholder=\"{{ 'Type here' | translate }}\"\n name=\"confirmString\"\n type=\"text\"\n autocomplete=\"off\"\n [(ngModel)]=\"confirmString\"\n />\n </div>\n </form>\n }\n <ng-content></ng-content>\n </div>\n <div class=\"alert-footer\">\n <button\n class=\"btn btn-default\"\n title=\"{{ labels.cancel | translate }}\"\n type=\"button\"\n *ngIf=\"labels.cancel !== null\"\n (click)=\"dismiss()\"\n data-cy=\"c8y-confirm-modal--cancel\"\n >\n {{ labels.cancel | translate }}\n </button>\n <button\n class=\"btn btn-primary m-t-xs-8\"\n title=\"{{ labels.ok | translate }}\"\n type=\"button\"\n (click)=\"close()\"\n data-cy=\"c8y-confirm-modal--ok\"\n [disabled]=\"isOkButtonDisabled\"\n >\n {{ labels.ok | translate }}\n </button>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "pipe", type: i4.C8yTranslatePipe, name: "translate" }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.KeyValuePipe, name: "keyvalue" }, { kind: "pipe", type: i5.ShowIfFilterPipe, name: "showIfFilter" }] }); }
|
|
56
81
|
}
|
|
57
82
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: ConfirmModalComponent, decorators: [{
|
|
58
83
|
type: Component,
|
|
59
|
-
args: [{ selector: 'c8y-confirm-modal', template: "<div\n class=\"c8y-prompt alert\"\n [ngClass]=\"[classAlert]\"\n data-cy=\"prompt-alert\"\n>\n <h3\n class=\"m-b-16 d-flex a-i-center\"\n *ngIf=\"title\"\n >\n <i\n class=\"dlt-c8y-icon\"\n [ngClass]=\"[classIcon]\"\n ></i>\n <span id=\"modal-title\">{{ title | translate }}</span>\n </h3>\n <div id=\"modal-body\">\n <p\n class=\"text-break-word m-b-16\"\n *ngIf=\"!isHtml(body)\"\n >\n {{ body | translate }}\n </p>\n <div\n class=\"text-break-word m-b-16\"\n *ngIf=\"isHtml(body)\"\n [innerHTML]=\"body | translate\"\n ></div>\n <div\n class=\"c8y-checkbox plain m-b-8\"\n *ngFor=\"let co of confirmOptions | showIfFilter | async | keyvalue\"\n >\n <label\n class=\"c8y-checkbox\"\n [title]=\"co.value.text | translate\"\n >\n <input\n type=\"checkbox\"\n [checked]=\"co.value.checked\"\n (change)=\"co.value.checked = !co.value.checked\"\n [disabled]=\"confirmOptions[co.value.disabledByKey]?.checked\"\n />\n <span></span>\n <span class=\"text-muted\">{{ co.value.text | translate }}</span>\n </label>\n </div>\n <ng-content></ng-content>\n </div>\n <div class=\"alert-footer\">\n <button\n class=\"btn btn-default\"\n title=\"{{ labels.cancel | translate }}\"\n type=\"button\"\n *ngIf=\"labels.cancel !== null\"\n (click)=\"dismiss()\"\n data-cy=\"c8y-confirm-modal--cancel\"\n >\n {{ labels.cancel | translate }}\n </button>\n <button\n class=\"btn btn-primary m-t-xs-8\"\n title=\"{{ labels.ok | translate }}\"\n type=\"button\"\n (click)=\"close()\"\n data-cy=\"c8y-confirm-modal--ok\"\n >\n {{ labels.ok | translate }}\n </button>\n </div>\n</div>\n" }]
|
|
84
|
+
args: [{ selector: 'c8y-confirm-modal', template: "<div\n class=\"c8y-prompt alert\"\n [ngClass]=\"[classAlert]\"\n data-cy=\"prompt-alert\"\n>\n <h3\n class=\"m-b-16 d-flex a-i-center\"\n *ngIf=\"title\"\n >\n <i\n class=\"dlt-c8y-icon\"\n [ngClass]=\"[classIcon]\"\n ></i>\n <span id=\"modal-title\">{{ title | translate }}</span>\n </h3>\n <div id=\"modal-body\">\n <p\n class=\"text-break-word m-b-16\"\n *ngIf=\"!isHtml(body)\"\n >\n {{ body | translate }}\n </p>\n <div\n class=\"text-break-word m-b-16\"\n *ngIf=\"isHtml(body)\"\n [innerHTML]=\"body | translate\"\n ></div>\n <div\n class=\"c8y-checkbox plain m-b-8\"\n *ngFor=\"let co of confirmOptions | showIfFilter | async | keyvalue\"\n >\n <label\n class=\"c8y-checkbox\"\n [title]=\"co.value.text | translate\"\n >\n <input\n type=\"checkbox\"\n [checked]=\"co.value.checked\"\n (change)=\"co.value.checked = !co.value.checked\"\n [disabled]=\"confirmOptions[co.value.disabledByKey]?.checked\"\n />\n <span></span>\n <span class=\"text-muted\">{{ co.value.text | translate }}</span>\n </label>\n </div>\n @if (requireCodeVerification) {\n <p class=\"text-break-word m-b-16\">\n <code>{{ code }}</code>\n </p>\n <form (submit)=\"$event.preventDefault()\">\n <div class=\"form-group\">\n <label for=\"confirmString\">\n {{ 'Confirm:' | translate }}\n </label>\n <input\n class=\"form-control\"\n id=\"confirmString\"\n placeholder=\"{{ 'Type here' | translate }}\"\n name=\"confirmString\"\n type=\"text\"\n autocomplete=\"off\"\n [(ngModel)]=\"confirmString\"\n />\n </div>\n </form>\n }\n <ng-content></ng-content>\n </div>\n <div class=\"alert-footer\">\n <button\n class=\"btn btn-default\"\n title=\"{{ labels.cancel | translate }}\"\n type=\"button\"\n *ngIf=\"labels.cancel !== null\"\n (click)=\"dismiss()\"\n data-cy=\"c8y-confirm-modal--cancel\"\n >\n {{ labels.cancel | translate }}\n </button>\n <button\n class=\"btn btn-primary m-t-xs-8\"\n title=\"{{ labels.ok | translate }}\"\n type=\"button\"\n (click)=\"close()\"\n data-cy=\"c8y-confirm-modal--ok\"\n [disabled]=\"isOkButtonDisabled\"\n >\n {{ labels.ok | translate }}\n </button>\n </div>\n</div>\n" }]
|
|
60
85
|
}], ctorParameters: () => [{ type: i1.BsModalRef }], propDecorators: { title: [{
|
|
61
86
|
type: Input
|
|
62
87
|
}], body: [{
|
|
@@ -65,7 +90,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
65
90
|
type: Input
|
|
66
91
|
}], status: [{
|
|
67
92
|
type: Input
|
|
93
|
+
}], requireCodeVerification: [{
|
|
94
|
+
type: Input
|
|
68
95
|
}], labels: [{
|
|
69
96
|
type: Input
|
|
70
97
|
}] } });
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-confirm.component.js","sourceRoot":"","sources":["../../../../core/modal/modal-confirm.component.ts","../../../../core/modal/modal-confirm.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAa,MAAM,eAAe,CAAC;AAC5D,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAC/C,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEjD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,EAAc,MAAM,wBAAwB,CAAC;;;;;;AAyBtF,MAAM,OAAO,qBAAqB;IAQhC,IAAa,MAAM,CAAC,MAAmB;QACrC,MAAM,EAAE,EAAE,GAAG,IAAI,EAAE,MAAM,GAAG,QAAQ,EAAE,GAAG,MAAM,IAAI,EAAE,CAAC;QACtD,IAAI,CAAC,OAAO,GAAG,EAAE,EAAE,EAAE,MAAM,EAAE,CAAC;IAChC,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAGD,YAAoB,KAAiB;QAAjB,UAAK,GAAL,KAAK,CAAY;QAX5B,WAAM,GAAe,MAAM,CAAC,IAAI,CAAC;QAYxC,IAAI,CAAC,OAAO,GAAG;YACb,EAAE,EAAE,IAAI;YACR,MAAM,EAAE,QAAQ;SACjB,CAAC;QACF,IAAI,CAAC,MAAM,GAAG,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC5C,IAAI,CAAC,OAAO,GAAG,GAAG,EAAE;gBAClB,MAAM,EAAE,CAAC;gBACT,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;YACpB,CAAC,CAAC;YACF,IAAI,CAAC,KAAK,GAAG,GAAG,EAAE;gBAChB,OAAO,CACL,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC;oBAC1B,CAAC,CAAC,IAAI;oBACN,CAAC,CAAC;wBACE,SAAS,EAAE,IAAI;wBACf,cAAc,EAAE,SAAS,CAAC,IAAI,CAAC,cAAc,EAAE,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC;qBACzE,CACN,CAAC;gBACF,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;YACpB,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED,IAAI,SAAS;QACX,OAAO,gBAAgB,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;IACpD,CAAC;IAED,IAAI,UAAU;QACZ,OAAO,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAClC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,OAAO,EAAE,CAAC;IACjB,CAAC;IAED,MAAM,CAAC,GAAsB;QAC3B,MAAM,GAAG,GAAG,IAAI,SAAS,EAAE,CAAC,eAAe,CAAC,GAAa,EAAE,WAAW,CAAC,CAAC;QACxE,OAAO,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,YAAY,CAAC,CAAC;IAC3F,CAAC;8GAzDU,qBAAqB;kGAArB,qBAAqB,yKC7BlC,gzDAqEA;;2FDxCa,qBAAqB;kBAJjC,SAAS;+BACE,mBAAmB;+EAOpB,KAAK;sBAAb,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACO,MAAM;sBAAlB,KAAK","sourcesContent":["import { Component, Input, OnDestroy } from '@angular/core';\nimport { isEmpty, mapValues } from 'lodash-es';\nimport { BsModalRef } from 'ngx-bootstrap/modal';\nimport { Observable } from 'rxjs';\nimport { Status, statusAlert, statusIcons, StatusType } from '../common/status.model';\nimport { ModalLabels } from '../select-modal/select-modal.model';\nimport { SafeHtml } from '@angular/platform-browser';\n\n/**\n * Defines options to be displayed in the confirm dialog.\n */\nexport interface ConfirmOptions {\n  [key: string]: ConfirmOption;\n}\n\nexport interface ConfirmOption {\n  text: string;\n  checked?: boolean;\n  showIf?: boolean | (() => boolean | Promise<boolean> | Observable<boolean>);\n  /**\n   * Will disable the current option when an option with the given key is selected.\n   */\n  disabledByKey?: string;\n}\n\n@Component({\n  selector: 'c8y-confirm-modal',\n  templateUrl: './modal-confirm.component.html'\n})\nexport class ConfirmModalComponent implements OnDestroy {\n  result: Promise<boolean | { confirmed: boolean; confirmOptions: { [key: string]: boolean } }>;\n  dismiss: () => void;\n  close: () => void;\n  @Input() title: string;\n  @Input() body: string | SafeHtml;\n  @Input() confirmOptions: ConfirmOptions;\n  @Input() status: StatusType = Status.INFO;\n  @Input() set labels(labels: ModalLabels) {\n    const { ok = 'OK', cancel = 'Cancel' } = labels || {};\n    this._labels = { ok, cancel };\n  }\n\n  get labels(): ModalLabels {\n    return this._labels;\n  }\n\n  private _labels: ModalLabels;\n  constructor(private modal: BsModalRef) {\n    this._labels = {\n      ok: 'OK',\n      cancel: 'Cancel'\n    };\n    this.result = new Promise((resolve, reject) => {\n      this.dismiss = () => {\n        reject();\n        this.modal.hide();\n      };\n      this.close = () => {\n        resolve(\n          isEmpty(this.confirmOptions)\n            ? true\n            : {\n                confirmed: true,\n                confirmOptions: mapValues(this.confirmOptions, option => option.checked)\n              }\n        );\n        this.modal.hide();\n      };\n    });\n  }\n\n  get classIcon() {\n    return `dlt-c8y-icon-${statusIcons[this.status]}`;\n  }\n\n  get classAlert() {\n    return statusAlert[this.status];\n  }\n\n  ngOnDestroy() {\n    this.dismiss();\n  }\n\n  isHtml(str: string | SafeHtml): boolean {\n    const doc = new DOMParser().parseFromString(str as string, 'text/html');\n    return Array.from(doc.body.childNodes).some(node => node.nodeType === Node.ELEMENT_NODE);\n  }\n}\n","<div\n  class=\"c8y-prompt alert\"\n  [ngClass]=\"[classAlert]\"\n  data-cy=\"prompt-alert\"\n>\n  <h3\n    class=\"m-b-16 d-flex a-i-center\"\n    *ngIf=\"title\"\n  >\n    <i\n      class=\"dlt-c8y-icon\"\n      [ngClass]=\"[classIcon]\"\n    ></i>\n    <span id=\"modal-title\">{{ title | translate }}</span>\n  </h3>\n  <div id=\"modal-body\">\n    <p\n      class=\"text-break-word m-b-16\"\n      *ngIf=\"!isHtml(body)\"\n    >\n      {{ body | translate }}\n    </p>\n    <div\n      class=\"text-break-word m-b-16\"\n      *ngIf=\"isHtml(body)\"\n      [innerHTML]=\"body | translate\"\n    ></div>\n    <div\n      class=\"c8y-checkbox plain m-b-8\"\n      *ngFor=\"let co of confirmOptions | showIfFilter | async | keyvalue\"\n    >\n      <label\n        class=\"c8y-checkbox\"\n        [title]=\"co.value.text | translate\"\n      >\n        <input\n          type=\"checkbox\"\n          [checked]=\"co.value.checked\"\n          (change)=\"co.value.checked = !co.value.checked\"\n          [disabled]=\"confirmOptions[co.value.disabledByKey]?.checked\"\n        />\n        <span></span>\n        <span class=\"text-muted\">{{ co.value.text | translate }}</span>\n      </label>\n    </div>\n    <ng-content></ng-content>\n  </div>\n  <div class=\"alert-footer\">\n    <button\n      class=\"btn btn-default\"\n      title=\"{{ labels.cancel | translate }}\"\n      type=\"button\"\n      *ngIf=\"labels.cancel !== null\"\n      (click)=\"dismiss()\"\n      data-cy=\"c8y-confirm-modal--cancel\"\n    >\n      {{ labels.cancel | translate }}\n    </button>\n    <button\n      class=\"btn btn-primary m-t-xs-8\"\n      title=\"{{ labels.ok | translate }}\"\n      type=\"button\"\n      (click)=\"close()\"\n      data-cy=\"c8y-confirm-modal--ok\"\n    >\n      {{ labels.ok | translate }}\n    </button>\n  </div>\n</div>\n"]}
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal-confirm.component.js","sourceRoot":"","sources":["../../../../core/modal/modal-confirm.component.ts","../../../../core/modal/modal-confirm.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy, OnInit } from '@angular/core';\nimport { isEmpty, mapValues } from 'lodash-es';\nimport { BsModalRef } from 'ngx-bootstrap/modal';\nimport { Observable } from 'rxjs';\nimport { Status, statusAlert, statusIcons, StatusType } from '../common/status.model';\nimport { ModalLabels } from '../select-modal/select-modal.model';\nimport { SafeHtml } from '@angular/platform-browser';\n\n/**\n * Defines options to be displayed in the confirm dialog.\n */\nexport interface ConfirmOptions {\n  [key: string]: ConfirmOption;\n}\n\nexport interface ConfirmOption {\n  text: string;\n  checked?: boolean;\n  showIf?: boolean | (() => boolean | Promise<boolean> | Observable<boolean>);\n  /**\n   * Will disable the current option when an option with the given key is selected.\n   */\n  disabledByKey?: string;\n}\n\n@Component({\n  selector: 'c8y-confirm-modal',\n  templateUrl: './modal-confirm.component.html'\n})\nexport class ConfirmModalComponent implements OnInit, OnDestroy {\n  result: Promise<boolean | { confirmed: boolean; confirmOptions: { [key: string]: boolean } }>;\n  dismiss: () => void;\n  close: () => void;\n  @Input() title: string;\n  @Input() body: string | SafeHtml;\n  @Input() confirmOptions: ConfirmOptions;\n  @Input() status: StatusType = Status.INFO;\n  @Input() requireCodeVerification?: boolean = false;\n  @Input() set labels(labels: ModalLabels) {\n    const { ok = 'OK', cancel = 'Cancel' } = labels || {};\n    this._labels = { ok, cancel };\n  }\n\n  get labels(): ModalLabels {\n    return this._labels;\n  }\n\n  code: string;\n  confirmString = '';\n\n  private _labels: ModalLabels;\n  constructor(private modal: BsModalRef) {\n    this._labels = {\n      ok: 'OK',\n      cancel: 'Cancel'\n    };\n    this.result = new Promise((resolve, reject) => {\n      this.dismiss = () => {\n        reject();\n        this.modal.hide();\n      };\n      this.close = () => {\n        if (this.requireCodeVerification && !this.canConfirmWithCode()) {\n          return;\n        }\n        resolve(\n          isEmpty(this.confirmOptions)\n            ? true\n            : {\n                confirmed: true,\n                confirmOptions: mapValues(this.confirmOptions, option => option.checked)\n              }\n        );\n        this.modal.hide();\n      };\n    });\n  }\n\n  ngOnInit() {\n    if (this.requireCodeVerification) {\n      this.code = this.generateRandomCode();\n    }\n  }\n\n  get classIcon() {\n    return `dlt-c8y-icon-${statusIcons[this.status]}`;\n  }\n\n  get classAlert() {\n    return statusAlert[this.status];\n  }\n\n  ngOnDestroy() {\n    this.dismiss();\n  }\n\n  isHtml(str: string | SafeHtml): boolean {\n    const doc = new DOMParser().parseFromString(str as string, 'text/html');\n    return Array.from(doc.body.childNodes).some(node => node.nodeType === Node.ELEMENT_NODE);\n  }\n\n  canConfirmWithCode(): boolean {\n    return this.confirmString === this.code;\n  }\n\n  get isOkButtonDisabled(): boolean {\n    if (this.requireCodeVerification) {\n      return !this.canConfirmWithCode();\n    }\n    return false;\n  }\n\n  private generateRandomCode(): string {\n    // no l, I, 0, O chars to prevent confusion:\n    const chars = 'ABCDEFGHJKLMNPQRSTUVWXYZabcdefhijkmnoprstuvwxyz123456789';\n    return Array.from({ length: 5 }, () =>\n      chars.charAt(Math.floor(Math.random() * chars.length))\n    ).join('');\n  }\n}\n","<div\n  class=\"c8y-prompt alert\"\n  [ngClass]=\"[classAlert]\"\n  data-cy=\"prompt-alert\"\n>\n  <h3\n    class=\"m-b-16 d-flex a-i-center\"\n    *ngIf=\"title\"\n  >\n    <i\n      class=\"dlt-c8y-icon\"\n      [ngClass]=\"[classIcon]\"\n    ></i>\n    <span id=\"modal-title\">{{ title | translate }}</span>\n  </h3>\n  <div id=\"modal-body\">\n    <p\n      class=\"text-break-word m-b-16\"\n      *ngIf=\"!isHtml(body)\"\n    >\n      {{ body | translate }}\n    </p>\n    <div\n      class=\"text-break-word m-b-16\"\n      *ngIf=\"isHtml(body)\"\n      [innerHTML]=\"body | translate\"\n    ></div>\n    <div\n      class=\"c8y-checkbox plain m-b-8\"\n      *ngFor=\"let co of confirmOptions | showIfFilter | async | keyvalue\"\n    >\n      <label\n        class=\"c8y-checkbox\"\n        [title]=\"co.value.text | translate\"\n      >\n        <input\n          type=\"checkbox\"\n          [checked]=\"co.value.checked\"\n          (change)=\"co.value.checked = !co.value.checked\"\n          [disabled]=\"confirmOptions[co.value.disabledByKey]?.checked\"\n        />\n        <span></span>\n        <span class=\"text-muted\">{{ co.value.text | translate }}</span>\n      </label>\n    </div>\n    @if (requireCodeVerification) {\n      <p class=\"text-break-word m-b-16\">\n        <code>{{ code }}</code>\n      </p>\n      <form (submit)=\"$event.preventDefault()\">\n        <div class=\"form-group\">\n          <label for=\"confirmString\">\n            {{ 'Confirm:' | translate }}\n          </label>\n          <input\n            class=\"form-control\"\n            id=\"confirmString\"\n            placeholder=\"{{ 'Type here' | translate }}\"\n            name=\"confirmString\"\n            type=\"text\"\n            autocomplete=\"off\"\n            [(ngModel)]=\"confirmString\"\n          />\n        </div>\n      </form>\n    }\n    <ng-content></ng-content>\n  </div>\n  <div class=\"alert-footer\">\n    <button\n      class=\"btn btn-default\"\n      title=\"{{ labels.cancel | translate }}\"\n      type=\"button\"\n      *ngIf=\"labels.cancel !== null\"\n      (click)=\"dismiss()\"\n      data-cy=\"c8y-confirm-modal--cancel\"\n    >\n      {{ labels.cancel | translate }}\n    </button>\n    <button\n      class=\"btn btn-primary m-t-xs-8\"\n      title=\"{{ labels.ok | translate }}\"\n      type=\"button\"\n      (click)=\"close()\"\n      data-cy=\"c8y-confirm-modal--ok\"\n      [disabled]=\"isOkButtonDisabled\"\n    >\n      {{ labels.ok | translate }}\n    </button>\n  </div>\n</div>\n"]}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { NgModule } from '@angular/core';
|
|
2
|
+
import { FormsModule } from '@angular/forms';
|
|
2
3
|
import { ModalModule as BsModalModule } from 'ngx-bootstrap/modal';
|
|
3
4
|
import { ConfirmModalComponent } from './modal-confirm.component';
|
|
4
5
|
import { ModalComponent } from './modal.component';
|
|
@@ -17,16 +18,16 @@ import * as i2 from "ngx-bootstrap/popover";
|
|
|
17
18
|
*/
|
|
18
19
|
export class ModalModule {
|
|
19
20
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: ModalModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
20
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.9", ngImport: i0, type: ModalModule, declarations: [ConfirmModalComponent, ModalComponent, PopoverConfirmComponent], imports: [i1.ModalModule, CommonModule, i2.PopoverModule], exports: [ConfirmModalComponent, ModalComponent, PopoverConfirmComponent] }); }
|
|
21
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: ModalModule, providers: [ModalService], imports: [BsModalModule.forRoot(), CommonModule, PopoverModule.forRoot()] }); }
|
|
21
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.9", ngImport: i0, type: ModalModule, declarations: [ConfirmModalComponent, ModalComponent, PopoverConfirmComponent], imports: [i1.ModalModule, CommonModule, FormsModule, i2.PopoverModule], exports: [ConfirmModalComponent, ModalComponent, PopoverConfirmComponent] }); }
|
|
22
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: ModalModule, providers: [ModalService], imports: [BsModalModule.forRoot(), CommonModule, FormsModule, PopoverModule.forRoot()] }); }
|
|
22
23
|
}
|
|
23
24
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: ModalModule, decorators: [{
|
|
24
25
|
type: NgModule,
|
|
25
26
|
args: [{
|
|
26
|
-
imports: [BsModalModule.forRoot(), CommonModule, PopoverModule.forRoot()],
|
|
27
|
+
imports: [BsModalModule.forRoot(), CommonModule, FormsModule, PopoverModule.forRoot()],
|
|
27
28
|
exports: [ConfirmModalComponent, ModalComponent, PopoverConfirmComponent],
|
|
28
29
|
declarations: [ConfirmModalComponent, ModalComponent, PopoverConfirmComponent],
|
|
29
30
|
providers: [ModalService]
|
|
30
31
|
}]
|
|
31
32
|
}] });
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vY29yZS9tb2RhbC9tb2RhbC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLFdBQVcsSUFBSSxhQUFhLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNuRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDbkQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN2RCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUN0RSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7Ozs7QUFFdEQ7Ozs7O0dBS0c7QUFPSCxNQUFNLE9BQU8sV0FBVzs4R0FBWCxXQUFXOytHQUFYLFdBQVcsaUJBSFAscUJBQXFCLEVBQUUsY0FBYyxFQUFFLHVCQUF1Qiw2QkFGMUMsWUFBWSxFQUFFLFdBQVcsK0JBQ2xELHFCQUFxQixFQUFFLGNBQWMsRUFBRSx1QkFBdUI7K0dBSTdELFdBQVcsYUFGWCxDQUFDLFlBQVksQ0FBQyxZQUhmLGFBQWEsQ0FBQyxPQUFPLEVBQUUsRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFLGFBQWEsQ0FBQyxPQUFPLEVBQUU7OzJGQUsxRSxXQUFXO2tCQU52QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLGFBQWEsQ0FBQyxPQUFPLEVBQUUsRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFLGFBQWEsQ0FBQyxPQUFPLEVBQUUsQ0FBQztvQkFDdEYsT0FBTyxFQUFFLENBQUMscUJBQXFCLEVBQUUsY0FBYyxFQUFFLHVCQUF1QixDQUFDO29CQUN6RSxZQUFZLEVBQUUsQ0FBQyxxQkFBcUIsRUFBRSxjQUFjLEVBQUUsdUJBQXVCLENBQUM7b0JBQzlFLFNBQVMsRUFBRSxDQUFDLFlBQVksQ0FBQztpQkFDMUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBNb2RhbE1vZHVsZSBhcyBCc01vZGFsTW9kdWxlIH0gZnJvbSAnbmd4LWJvb3RzdHJhcC9tb2RhbCc7XG5pbXBvcnQgeyBDb25maXJtTW9kYWxDb21wb25lbnQgfSBmcm9tICcuL21vZGFsLWNvbmZpcm0uY29tcG9uZW50JztcbmltcG9ydCB7IE1vZGFsQ29tcG9uZW50IH0gZnJvbSAnLi9tb2RhbC5jb21wb25lbnQnO1xuaW1wb3J0IHsgTW9kYWxTZXJ2aWNlIH0gZnJvbSAnLi9tb2RhbC5zZXJ2aWNlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJy4uL2NvbW1vbi9jb21tb24ubW9kdWxlJztcbmltcG9ydCB7IFBvcG92ZXJDb25maXJtQ29tcG9uZW50IH0gZnJvbSAnLi9wb3BvdmVyLWNvbmZpcm0uY29tcG9uZW50JztcbmltcG9ydCB7IFBvcG92ZXJNb2R1bGUgfSBmcm9tICduZ3gtYm9vdHN0cmFwL3BvcG92ZXInO1xuXG4vKipcbiAqIFRoZSBhbmd1bGFyIG1vZHVsZSBkZWZpbml0aW9uIGZvciBtb2RhbC5cbiAqIEBleHBvcnRzIENvbmZpcm1Nb2RhbENvbXBvbmVudFxuICogQGV4cG9ydHMgTW9kYWxDb21wb25lbnRcbiAqIEBleHBvcnRzIFBvcG92ZXJDb25maXJtQ29tcG9uZW50XG4gKi9cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtCc01vZGFsTW9kdWxlLmZvclJvb3QoKSwgQ29tbW9uTW9kdWxlLCBGb3Jtc01vZHVsZSwgUG9wb3Zlck1vZHVsZS5mb3JSb290KCldLFxuICBleHBvcnRzOiBbQ29uZmlybU1vZGFsQ29tcG9uZW50LCBNb2RhbENvbXBvbmVudCwgUG9wb3ZlckNvbmZpcm1Db21wb25lbnRdLFxuICBkZWNsYXJhdGlvbnM6IFtDb25maXJtTW9kYWxDb21wb25lbnQsIE1vZGFsQ29tcG9uZW50LCBQb3BvdmVyQ29uZmlybUNvbXBvbmVudF0sXG4gIHByb3ZpZGVyczogW01vZGFsU2VydmljZV1cbn0pXG5leHBvcnQgY2xhc3MgTW9kYWxNb2R1bGUge31cbiJdfQ==
|
|
@@ -23,14 +23,22 @@ export class ModalService {
|
|
|
23
23
|
* @param labels The labels to use. Default: { ok: 'Confirm', cancel: 'Cancel'}
|
|
24
24
|
* @param confirmOptions Selection options to display as checkbox list.
|
|
25
25
|
* @param productExperienceEvent Additional data to attach to custom product experience events.
|
|
26
|
+
* @param requireCodeVerification Whether to require user to retype a random code for confirmation.
|
|
26
27
|
*/
|
|
27
|
-
async confirm(title, body, status = Status.INFO, labels = {}, confirmOptions = {}, productExperienceEvent = { eventName: 'confirmModal' }) {
|
|
28
|
+
async confirm(title, body, status = Status.INFO, labels = {}, confirmOptions = {}, productExperienceEvent = { eventName: 'confirmModal' }, requireCodeVerification = false) {
|
|
28
29
|
const modalLabels = {
|
|
29
30
|
ok: labels.ok || gettext('Confirm'),
|
|
30
31
|
cancel: labels.cancel || gettext('Cancel')
|
|
31
32
|
};
|
|
32
33
|
const modalRef = this.modalService.show(ConfirmModalComponent, {
|
|
33
|
-
initialState: {
|
|
34
|
+
initialState: {
|
|
35
|
+
title,
|
|
36
|
+
body,
|
|
37
|
+
labels: modalLabels,
|
|
38
|
+
status,
|
|
39
|
+
confirmOptions,
|
|
40
|
+
requireCodeVerification
|
|
41
|
+
},
|
|
34
42
|
ariaDescribedby: 'modal-body',
|
|
35
43
|
ariaLabelledBy: 'modal-title',
|
|
36
44
|
ignoreBackdropClick: true
|
|
@@ -102,4 +110,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
102
110
|
providedIn: 'root'
|
|
103
111
|
}]
|
|
104
112
|
}], ctorParameters: () => [{ type: i1.BsModalService }, { type: i2.GainsightService }] });
|
|
105
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.service.js","sourceRoot":"","sources":["../../../../core/modal/modal.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { BsModalService } from 'ngx-bootstrap/modal';\nimport { Status, StatusType } from '../common/status.model';\nimport { gettext } from '../i18n/gettext';\nimport { GainsightService } from '../product-experience/gainsight.service';\nimport { ProductExperienceEvent } from '../product-experience/product-experience.model';\nimport { ConfirmModalComponent, ConfirmOptions } from './modal-confirm.component';\n\n/**\n * Service to show a modal.\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class ModalService {\n  constructor(\n    private modalService: BsModalService,\n    private gainsightService: GainsightService\n  ) {}\n\n  /**\n   * Shows a quick confirm message modal.\n   * @param title The title of that modal.\n   * @param body The text body to display.\n   * @param status The status.\n   * @param labels The labels to use. Default: { ok: 'Confirm', cancel: 'Cancel'}\n   * @param confirmOptions Selection options to display as checkbox list.\n   * @param productExperienceEvent Additional data to attach to custom product experience events.\n   */\n  async confirm(\n    title: string,\n    body: string,\n    status: StatusType = Status.INFO,\n    labels: ConfirmModalComponent['labels'] = {},\n    confirmOptions: ConfirmOptions = {},\n    productExperienceEvent: ProductExperienceEvent = { eventName: 'confirmModal' }\n  ) {\n    const modalLabels = {\n      ok: labels.ok || gettext('Confirm'),\n      cancel: labels.cancel || gettext('Cancel')\n    };\n    const modalRef = this.modalService.show(ConfirmModalComponent, {\n      initialState: { title, body, labels: modalLabels, status, confirmOptions },\n      ariaDescribedby: 'modal-body',\n      ariaLabelledBy: 'modal-title',\n      ignoreBackdropClick: true\n    });\n    if (productExperienceEvent) {\n      productExperienceEvent.data = { ...productExperienceEvent.data, title };\n    }\n    this.triggerEvent(modalRef.content.result, modalLabels, productExperienceEvent);\n    return await modalRef.content.result;\n  }\n\n  /**\n   * Shows a quick acknowledge message modal.\n   * @param title The title of that modal.\n   * @param body The text body to display.\n   * @param status The status.\n   * @param acknowledgeLabel The label to use.\n   * @param productExperienceEvent Additional data to attach to custom product experience events.\n   */\n  async acknowledge(\n    title: string,\n    body: string,\n    status: StatusType = Status.INFO,\n    acknowledgeLabel: string = gettext('Confirm'),\n    productExperienceEvent: ProductExperienceEvent = { eventName: 'confirmModal' }\n  ) {\n    const labels = { ok: acknowledgeLabel, cancel: null };\n    const modalRef = this.modalService.show(ConfirmModalComponent, {\n      initialState: { title, body, labels, status },\n      ariaDescribedby: 'modal-body',\n      ariaLabelledBy: 'modal-title',\n      ignoreBackdropClick: true\n    });\n    if (productExperienceEvent) {\n      productExperienceEvent.data = { ...productExperienceEvent.data, title };\n    }\n    this.triggerEvent(modalRef.content.result, labels, productExperienceEvent);\n    return await modalRef.content.result;\n  }\n\n  /**\n   * Shows a quick logout confirmation modal.\n   * @param body The text body to display. Default: 'You will be logged out to apply your changes. Do you want to proceed?'\n   * @param status The status.\n   * @param labels The labels to use. Default: { ok: 'Confirm and log out', cancel: 'Cancel' }\n   */\n  async confirmLogout(body?: string, status: StatusType = Status.WARNING, labels: any = {}) {\n    const modalLabels = {\n      ok: labels.ok || gettext('Confirm and log out'),\n      cancel: labels.cancel || gettext('Cancel')\n    };\n    const modalBody =\n      body || gettext('You must log out to apply your changes. Do you want to proceed?');\n    return await this.confirm(gettext('Logout required'), modalBody, status, modalLabels);\n  }\n\n  private triggerEvent(\n    result: Promise<boolean | { confirmed: boolean; confirmOptions: { [key: string]: boolean } }>,\n    labels: any,\n    productExperienceEvent: ProductExperienceEvent\n  ): void {\n    const data = { ...productExperienceEvent.data, url: window.location.href };\n    result\n      .then(() => {\n        this.gainsightService.triggerEvent(productExperienceEvent.eventName, {\n          ...data,\n          result: labels.ok\n        });\n      })\n      .catch(() => {\n        this.gainsightService.triggerEvent(productExperienceEvent.eventName, {\n          ...data,\n          result: labels.cancel\n        });\n      });\n  }\n}\n"]}
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.service.js","sourceRoot":"","sources":["../../../../core/modal/modal.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { BsModalService } from 'ngx-bootstrap/modal';\nimport { Status, StatusType } from '../common/status.model';\nimport { gettext } from '../i18n/gettext';\nimport { GainsightService } from '../product-experience/gainsight.service';\nimport { ProductExperienceEvent } from '../product-experience/product-experience.model';\nimport { ConfirmModalComponent, ConfirmOptions } from './modal-confirm.component';\n\n/**\n * Service to show a modal.\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class ModalService {\n  constructor(\n    private modalService: BsModalService,\n    private gainsightService: GainsightService\n  ) {}\n\n  /**\n   * Shows a quick confirm message modal.\n   * @param title The title of that modal.\n   * @param body The text body to display.\n   * @param status The status.\n   * @param labels The labels to use. Default: { ok: 'Confirm', cancel: 'Cancel'}\n   * @param confirmOptions Selection options to display as checkbox list.\n   * @param productExperienceEvent Additional data to attach to custom product experience events.\n   * @param requireCodeVerification Whether to require user to retype a random code for confirmation.\n   */\n  async confirm(\n    title: string,\n    body: string,\n    status: StatusType = Status.INFO,\n    labels: ConfirmModalComponent['labels'] = {},\n    confirmOptions: ConfirmOptions = {},\n    productExperienceEvent: ProductExperienceEvent = { eventName: 'confirmModal' },\n    requireCodeVerification = false\n  ) {\n    const modalLabels = {\n      ok: labels.ok || gettext('Confirm'),\n      cancel: labels.cancel || gettext('Cancel')\n    };\n    const modalRef = this.modalService.show(ConfirmModalComponent, {\n      initialState: {\n        title,\n        body,\n        labels: modalLabels,\n        status,\n        confirmOptions,\n        requireCodeVerification\n      },\n      ariaDescribedby: 'modal-body',\n      ariaLabelledBy: 'modal-title',\n      ignoreBackdropClick: true\n    });\n    if (productExperienceEvent) {\n      productExperienceEvent.data = { ...productExperienceEvent.data, title };\n    }\n    this.triggerEvent(modalRef.content.result, modalLabels, productExperienceEvent);\n    return await modalRef.content.result;\n  }\n\n  /**\n   * Shows a quick acknowledge message modal.\n   * @param title The title of that modal.\n   * @param body The text body to display.\n   * @param status The status.\n   * @param acknowledgeLabel The label to use.\n   * @param productExperienceEvent Additional data to attach to custom product experience events.\n   */\n  async acknowledge(\n    title: string,\n    body: string,\n    status: StatusType = Status.INFO,\n    acknowledgeLabel: string = gettext('Confirm'),\n    productExperienceEvent: ProductExperienceEvent = { eventName: 'confirmModal' }\n  ) {\n    const labels = { ok: acknowledgeLabel, cancel: null };\n    const modalRef = this.modalService.show(ConfirmModalComponent, {\n      initialState: { title, body, labels, status },\n      ariaDescribedby: 'modal-body',\n      ariaLabelledBy: 'modal-title',\n      ignoreBackdropClick: true\n    });\n    if (productExperienceEvent) {\n      productExperienceEvent.data = { ...productExperienceEvent.data, title };\n    }\n    this.triggerEvent(modalRef.content.result, labels, productExperienceEvent);\n    return await modalRef.content.result;\n  }\n\n  /**\n   * Shows a quick logout confirmation modal.\n   * @param body The text body to display. Default: 'You will be logged out to apply your changes. Do you want to proceed?'\n   * @param status The status.\n   * @param labels The labels to use. Default: { ok: 'Confirm and log out', cancel: 'Cancel' }\n   */\n  async confirmLogout(body?: string, status: StatusType = Status.WARNING, labels: any = {}) {\n    const modalLabels = {\n      ok: labels.ok || gettext('Confirm and log out'),\n      cancel: labels.cancel || gettext('Cancel')\n    };\n    const modalBody =\n      body || gettext('You must log out to apply your changes. Do you want to proceed?');\n    return await this.confirm(gettext('Logout required'), modalBody, status, modalLabels);\n  }\n\n  private triggerEvent(\n    result: Promise<boolean | { confirmed: boolean; confirmOptions: { [key: string]: boolean } }>,\n    labels: any,\n    productExperienceEvent: ProductExperienceEvent\n  ): void {\n    const data = { ...productExperienceEvent.data, url: window.location.href };\n    result\n      .then(() => {\n        this.gainsightService.triggerEvent(productExperienceEvent.eventName, {\n          ...data,\n          result: labels.ok\n        });\n      })\n      .catch(() => {\n        this.gainsightService.triggerEvent(productExperienceEvent.eventName, {\n          ...data,\n          result: labels.cancel\n        });\n      });\n  }\n}\n"]}
|
|
@@ -59,7 +59,7 @@ export class DeleteAssetsModalComponent {
|
|
|
59
59
|
this.deleteGroupSubAssetsMsg = this.translateService.instant(gettext('Also delete all devices inside "{{name}}" and its subassets.'), { name: this.asset.name });
|
|
60
60
|
}
|
|
61
61
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DeleteAssetsModalComponent, deps: [{ token: i1.TranslateService }, { token: i2.GainsightService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
62
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: DeleteAssetsModalComponent, selector: "c8y-delete-assets-modal", inputs: { showWithCascadeCheckbox: "showWithCascadeCheckbox", showWithDeviceUserCheckbox: "showWithDeviceUserCheckbox", asset: "asset" }, viewQueries: [{ propertyName: "modalRef", first: true, predicate: ["modalRef"], descendants: true }], ngImport: i0, template: "<c8y-confirm-modal [title]=\"title\" [status]=\"status\" [labels]=\"labels\" #modalRef>\n <form #assetsForm=\"ngForm\">\n <p class=\"text-wrap m-b-16\">\n {{ message | translate }}\n </p>\n <c8y-form-group *ngIf=\"showWithCascadeCheckbox\" class=\"m-b-0\">\n <label title=\"{{ 'Delete devices' | translate }}\" class=\"c8y-checkbox\">\n <input\n type=\"checkbox\"\n name=\"cascade\"\n [(ngModel)]=\"config.cascade\"\n c8yProductExperience\n [actionName]=\"PRODUCT_EXPERIENCE.EVENT\"\n [actionData]=\"{\n component: PRODUCT_EXPERIENCE.DELETE_ASSET.COMPONENTS.DELETE_ASSETS_MODAL,\n action: PRODUCT_EXPERIENCE.DELETE_ASSET.ACTIONS.CASCADE_DELETE\n }\"\n [disabled]=\"config?.withDeviceUser\"\n />\n <span></span>\n <span class=\"text-break-word\">\n {{ deleteGroupSubAssetsMsg | translate }}\n </span>\n </label>\n </c8y-form-group>\n <c8y-form-group *ngIf=\"showWithDeviceUserCheckbox\" class=\"m-b-0\">\n <label title=\"{{ 'Delete associated device owner' | translate }}\" class=\"c8y-checkbox\">\n <input\n type=\"checkbox\"\n name=\"withDeviceUser\"\n [(ngModel)]=\"config.withDeviceUser\"\n c8yProductExperience\n [actionName]=\"PRODUCT_EXPERIENCE.EVENT\"\n [actionData]=\"{\n component: PRODUCT_EXPERIENCE.DELETE_ASSET.COMPONENTS.DELETE_ASSETS_MODAL,\n action: PRODUCT_EXPERIENCE.DELETE_ASSET.ACTIONS.DELETE_DEVICE_OWNER\n }\"\n [disabled]=\"config?.cascade\"\n />\n <span></span>\n <span>\n {{ 'Also delete associated device owner.' | translate }}\n </span>\n </label>\n </c8y-form-group>\n </form>\n</c8y-confirm-modal>\n", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.ConfirmModalComponent, selector: "c8y-confirm-modal", inputs: ["title", "body", "confirmOptions", "status", "labels"] }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i4.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i2.FormGroupComponent, selector: "c8y-form-group", inputs: ["hasError", "hasWarning", "hasSuccess", "novalidation", "status"] }, { kind: "directive", type: i2.ProductExperienceDirective, selector: "[c8yProductExperience]", inputs: ["actionName", "actionData", "inherit", "suppressDataOverriding"] }, { kind: "pipe", type: i2.C8yTranslatePipe, name: "translate" }] }); }
|
|
62
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: DeleteAssetsModalComponent, selector: "c8y-delete-assets-modal", inputs: { showWithCascadeCheckbox: "showWithCascadeCheckbox", showWithDeviceUserCheckbox: "showWithDeviceUserCheckbox", asset: "asset" }, viewQueries: [{ propertyName: "modalRef", first: true, predicate: ["modalRef"], descendants: true }], ngImport: i0, template: "<c8y-confirm-modal [title]=\"title\" [status]=\"status\" [labels]=\"labels\" #modalRef>\n <form #assetsForm=\"ngForm\">\n <p class=\"text-wrap m-b-16\">\n {{ message | translate }}\n </p>\n <c8y-form-group *ngIf=\"showWithCascadeCheckbox\" class=\"m-b-0\">\n <label title=\"{{ 'Delete devices' | translate }}\" class=\"c8y-checkbox\">\n <input\n type=\"checkbox\"\n name=\"cascade\"\n [(ngModel)]=\"config.cascade\"\n c8yProductExperience\n [actionName]=\"PRODUCT_EXPERIENCE.EVENT\"\n [actionData]=\"{\n component: PRODUCT_EXPERIENCE.DELETE_ASSET.COMPONENTS.DELETE_ASSETS_MODAL,\n action: PRODUCT_EXPERIENCE.DELETE_ASSET.ACTIONS.CASCADE_DELETE\n }\"\n [disabled]=\"config?.withDeviceUser\"\n />\n <span></span>\n <span class=\"text-break-word\">\n {{ deleteGroupSubAssetsMsg | translate }}\n </span>\n </label>\n </c8y-form-group>\n <c8y-form-group *ngIf=\"showWithDeviceUserCheckbox\" class=\"m-b-0\">\n <label title=\"{{ 'Delete associated device owner' | translate }}\" class=\"c8y-checkbox\">\n <input\n type=\"checkbox\"\n name=\"withDeviceUser\"\n [(ngModel)]=\"config.withDeviceUser\"\n c8yProductExperience\n [actionName]=\"PRODUCT_EXPERIENCE.EVENT\"\n [actionData]=\"{\n component: PRODUCT_EXPERIENCE.DELETE_ASSET.COMPONENTS.DELETE_ASSETS_MODAL,\n action: PRODUCT_EXPERIENCE.DELETE_ASSET.ACTIONS.DELETE_DEVICE_OWNER\n }\"\n [disabled]=\"config?.cascade\"\n />\n <span></span>\n <span>\n {{ 'Also delete associated device owner.' | translate }}\n </span>\n </label>\n </c8y-form-group>\n </form>\n</c8y-confirm-modal>\n", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.ConfirmModalComponent, selector: "c8y-confirm-modal", inputs: ["title", "body", "confirmOptions", "status", "requireCodeVerification", "labels"] }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i4.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i2.FormGroupComponent, selector: "c8y-form-group", inputs: ["hasError", "hasWarning", "hasSuccess", "novalidation", "status"] }, { kind: "directive", type: i2.ProductExperienceDirective, selector: "[c8yProductExperience]", inputs: ["actionName", "actionData", "inherit", "suppressDataOverriding"] }, { kind: "pipe", type: i2.C8yTranslatePipe, name: "translate" }] }); }
|
|
63
63
|
}
|
|
64
64
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DeleteAssetsModalComponent, decorators: [{
|
|
65
65
|
type: Component,
|
|
@@ -46,7 +46,7 @@ export class UnassignModalComponent {
|
|
|
46
46
|
this.closeSubject.complete();
|
|
47
47
|
}
|
|
48
48
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: UnassignModalComponent, deps: [{ token: i1.TranslateService }, { token: i2.GainsightService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
49
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: UnassignModalComponent, selector: "c8y-unassign-modal", inputs: { asset: "asset" }, viewQueries: [{ propertyName: "modalRef", first: true, predicate: ["modalRef"], descendants: true }], ngImport: i0, template: "<c8y-confirm-modal [title]=\"title\" [status]=\"status\" [labels]=\"labels\" #modalRef>\n <span>{{ message | translate }}</span>\n</c8y-confirm-modal>\n", dependencies: [{ kind: "component", type: i2.ConfirmModalComponent, selector: "c8y-confirm-modal", inputs: ["title", "body", "confirmOptions", "status", "labels"] }, { kind: "pipe", type: i2.C8yTranslatePipe, name: "translate" }] }); }
|
|
49
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: UnassignModalComponent, selector: "c8y-unassign-modal", inputs: { asset: "asset" }, viewQueries: [{ propertyName: "modalRef", first: true, predicate: ["modalRef"], descendants: true }], ngImport: i0, template: "<c8y-confirm-modal [title]=\"title\" [status]=\"status\" [labels]=\"labels\" #modalRef>\n <span>{{ message | translate }}</span>\n</c8y-confirm-modal>\n", dependencies: [{ kind: "component", type: i2.ConfirmModalComponent, selector: "c8y-confirm-modal", inputs: ["title", "body", "confirmOptions", "status", "requireCodeVerification", "labels"] }, { kind: "pipe", type: i2.C8yTranslatePipe, name: "translate" }] }); }
|
|
50
50
|
}
|
|
51
51
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: UnassignModalComponent, decorators: [{
|
|
52
52
|
type: Component,
|