cps-ui-kit 17.11.0 → 17.13.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/README.md +1 -0
- package/esm2022/lib/components/cps-switch/cps-switch.component.mjs +130 -0
- package/esm2022/lib/services/cps-dialog/cps-dialog.service.mjs +33 -15
- package/esm2022/lib/services/cps-dialog/internal/components/cps-confirmation/cps-confirmation.component.mjs +2 -2
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/cps-ui-kit.mjs +158 -16
- package/fesm2022/cps-ui-kit.mjs.map +1 -1
- package/lib/components/cps-switch/cps-switch.component.d.ts +72 -0
- package/lib/services/cps-dialog/cps-dialog.service.d.ts +10 -4
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
package/README.md
CHANGED
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { Component, EventEmitter, Input, Optional, Output, Self } from '@angular/core';
|
|
3
|
+
import { CpsInfoCircleComponent } from '../cps-info-circle/cps-info-circle.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/forms";
|
|
6
|
+
import * as i2 from "@angular/common";
|
|
7
|
+
/**
|
|
8
|
+
* CpsSwitchComponent is a component used to toggle a boolean value.
|
|
9
|
+
* @group Components
|
|
10
|
+
*/
|
|
11
|
+
export class CpsSwitchComponent {
|
|
12
|
+
/**
|
|
13
|
+
* Value of the switch component.
|
|
14
|
+
* @group Props
|
|
15
|
+
*/
|
|
16
|
+
set value(value) {
|
|
17
|
+
this._value = value;
|
|
18
|
+
this.onChange(value);
|
|
19
|
+
}
|
|
20
|
+
get value() {
|
|
21
|
+
return this._value;
|
|
22
|
+
}
|
|
23
|
+
constructor(_control, _elementRef) {
|
|
24
|
+
this._control = _control;
|
|
25
|
+
this._elementRef = _elementRef;
|
|
26
|
+
/**
|
|
27
|
+
* Label of the component.
|
|
28
|
+
* @group Props
|
|
29
|
+
*/
|
|
30
|
+
this.label = '';
|
|
31
|
+
/**
|
|
32
|
+
* Determines whether the component is disabled.
|
|
33
|
+
* @group Props
|
|
34
|
+
*/
|
|
35
|
+
this.disabled = false;
|
|
36
|
+
/**
|
|
37
|
+
* When it is not an empty string, an info icon is displayed to show text for more info.
|
|
38
|
+
* @group Props
|
|
39
|
+
*/
|
|
40
|
+
this.infoTooltip = '';
|
|
41
|
+
/**
|
|
42
|
+
* InfoTooltip class for styling.
|
|
43
|
+
* @group Props
|
|
44
|
+
*/
|
|
45
|
+
this.infoTooltipClass = 'cps-tooltip-content';
|
|
46
|
+
/**
|
|
47
|
+
* Size of infoTooltip, of type number denoting pixels or string.
|
|
48
|
+
* @group Props
|
|
49
|
+
*/
|
|
50
|
+
this.infoTooltipMaxWidth = '100%';
|
|
51
|
+
/**
|
|
52
|
+
* Determines whether the infoTooltip is persistent.
|
|
53
|
+
* @group Props
|
|
54
|
+
*/
|
|
55
|
+
this.infoTooltipPersistent = false;
|
|
56
|
+
/**
|
|
57
|
+
* Position of infoTooltip, it can be 'top', 'bottom', 'left' or 'right'.
|
|
58
|
+
* @group Props
|
|
59
|
+
*/
|
|
60
|
+
this.infoTooltipPosition = 'top';
|
|
61
|
+
/**
|
|
62
|
+
* Callback to invoke on value change.
|
|
63
|
+
* @param {boolean} boolean - value changed.
|
|
64
|
+
* @group Emits
|
|
65
|
+
*/
|
|
66
|
+
this.valueChanged = new EventEmitter();
|
|
67
|
+
this._value = false;
|
|
68
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
69
|
+
this.onChange = (event) => { };
|
|
70
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
71
|
+
this.onTouched = () => { };
|
|
72
|
+
if (this._control) {
|
|
73
|
+
this._control.valueAccessor = this;
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
registerOnChange(fn) {
|
|
77
|
+
this.onChange = fn;
|
|
78
|
+
}
|
|
79
|
+
registerOnTouched(fn) {
|
|
80
|
+
this.onTouched = fn;
|
|
81
|
+
}
|
|
82
|
+
writeValue(value) {
|
|
83
|
+
this.value = value;
|
|
84
|
+
}
|
|
85
|
+
updateValueEvent(event) {
|
|
86
|
+
event.preventDefault();
|
|
87
|
+
if (this.disabled)
|
|
88
|
+
return;
|
|
89
|
+
this._updateValue(!this.value);
|
|
90
|
+
}
|
|
91
|
+
_updateValue(value) {
|
|
92
|
+
this.writeValue(value);
|
|
93
|
+
this.onChange(value);
|
|
94
|
+
this.valueChanged.emit(value);
|
|
95
|
+
}
|
|
96
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
97
|
+
setDisabledState(disabled) { }
|
|
98
|
+
focus() {
|
|
99
|
+
this._elementRef?.nativeElement?.querySelector('input')?.focus();
|
|
100
|
+
}
|
|
101
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsSwitchComponent, deps: [{ token: i1.NgControl, optional: true, self: true }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
102
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: CpsSwitchComponent, isStandalone: true, selector: "cps-switch", inputs: { label: "label", disabled: "disabled", infoTooltip: "infoTooltip", infoTooltipClass: "infoTooltipClass", infoTooltipMaxWidth: "infoTooltipMaxWidth", infoTooltipPersistent: "infoTooltipPersistent", infoTooltipPosition: "infoTooltipPosition", value: "value" }, outputs: { valueChanged: "valueChanged" }, ngImport: i0, template: "<div class=\"cps-switch-container\">\n <label class=\"cps-switch\">\n <input\n type=\"checkbox\"\n [disabled]=\"disabled\"\n [checked]=\"value\"\n (change)=\"updateValueEvent($event)\" />\n <span class=\"cps-switch-slider\"></span>\n </label>\n <span\n *ngIf=\"label\"\n class=\"cps-switch-label\"\n [ngClass]=\"{ 'cps-switch-label-disabled': disabled }\"\n >{{ label }}</span\n >\n <cps-info-circle\n *ngIf=\"infoTooltip\"\n class=\"cps-switch-info-circle\"\n size=\"xsmall\"\n [tooltipPosition]=\"infoTooltipPosition\"\n [tooltipContentClass]=\"infoTooltipClass\"\n [tooltipMaxWidth]=\"infoTooltipMaxWidth\"\n [tooltipPersistent]=\"infoTooltipPersistent\"\n [tooltipText]=\"infoTooltip\">\n </cps-info-circle>\n</div>\n", styles: [":host{min-width:max-content;display:inline-block}:host .cps-switch-container{line-height:normal;display:flex;align-items:center}:host .cps-switch-container .cps-switch{position:relative;display:inline-block;width:48px;height:24px}:host .cps-switch-container .cps-switch input{opacity:0;width:0;height:0}:host .cps-switch-container .cps-switch-slider{position:absolute;cursor:pointer;inset:0;background-color:#fff;transition:.2s;border:1px solid var(--cps-color-calm);border-radius:30px}:host .cps-switch-container .cps-switch-label{font-size:16px;font-family:Source Sans Pro,sans-serif;font-style:normal;color:var(--cps-color-text-dark);margin-left:10px;cursor:default}:host .cps-switch-container .cps-switch-label-disabled{color:var(--cps-color-text-light)}:host .cps-switch-container .cps-switch-slider:before{position:absolute;content:\"\";height:14px;width:14px;border-radius:20px;left:4px;bottom:4px;background-color:var(--cps-color-calm);transition:.2s}:host .cps-switch-container input:checked+.cps-switch-slider{background-color:var(--cps-color-calm)}:host .cps-switch-container input:focus+.cps-switch-slider{box-shadow:0 0 1px var(--cps-color-calm)}:host .cps-switch-container input:checked+.cps-switch-slider:before{transform:translate(24px);background-color:#fff}:host .cps-switch-container input:disabled~.cps-switch-slider{cursor:default;border-color:var(--cps-color-text-lightest)}:host .cps-switch-container input:disabled:checked~.cps-switch-slider{background-color:var(--cps-color-text-lightest)}:host .cps-switch-container input:disabled:not(:checked)~.cps-switch-slider:before{background-color:var(--cps-color-text-lightest)}:host .cps-switch-container .cps-switch-info-circle{margin-left:8px}:host .cps-switch-container .cps-switch-info-circle ::ng-deep cps-icon i{width:14px;height:14px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: CpsInfoCircleComponent, selector: "cps-info-circle", inputs: ["size", "tooltipText", "tooltipPosition", "tooltipContentClass", "tooltipMaxWidth", "tooltipPersistent"] }] }); }
|
|
103
|
+
}
|
|
104
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsSwitchComponent, decorators: [{
|
|
105
|
+
type: Component,
|
|
106
|
+
args: [{ standalone: true, imports: [CommonModule, CpsInfoCircleComponent], selector: 'cps-switch', template: "<div class=\"cps-switch-container\">\n <label class=\"cps-switch\">\n <input\n type=\"checkbox\"\n [disabled]=\"disabled\"\n [checked]=\"value\"\n (change)=\"updateValueEvent($event)\" />\n <span class=\"cps-switch-slider\"></span>\n </label>\n <span\n *ngIf=\"label\"\n class=\"cps-switch-label\"\n [ngClass]=\"{ 'cps-switch-label-disabled': disabled }\"\n >{{ label }}</span\n >\n <cps-info-circle\n *ngIf=\"infoTooltip\"\n class=\"cps-switch-info-circle\"\n size=\"xsmall\"\n [tooltipPosition]=\"infoTooltipPosition\"\n [tooltipContentClass]=\"infoTooltipClass\"\n [tooltipMaxWidth]=\"infoTooltipMaxWidth\"\n [tooltipPersistent]=\"infoTooltipPersistent\"\n [tooltipText]=\"infoTooltip\">\n </cps-info-circle>\n</div>\n", styles: [":host{min-width:max-content;display:inline-block}:host .cps-switch-container{line-height:normal;display:flex;align-items:center}:host .cps-switch-container .cps-switch{position:relative;display:inline-block;width:48px;height:24px}:host .cps-switch-container .cps-switch input{opacity:0;width:0;height:0}:host .cps-switch-container .cps-switch-slider{position:absolute;cursor:pointer;inset:0;background-color:#fff;transition:.2s;border:1px solid var(--cps-color-calm);border-radius:30px}:host .cps-switch-container .cps-switch-label{font-size:16px;font-family:Source Sans Pro,sans-serif;font-style:normal;color:var(--cps-color-text-dark);margin-left:10px;cursor:default}:host .cps-switch-container .cps-switch-label-disabled{color:var(--cps-color-text-light)}:host .cps-switch-container .cps-switch-slider:before{position:absolute;content:\"\";height:14px;width:14px;border-radius:20px;left:4px;bottom:4px;background-color:var(--cps-color-calm);transition:.2s}:host .cps-switch-container input:checked+.cps-switch-slider{background-color:var(--cps-color-calm)}:host .cps-switch-container input:focus+.cps-switch-slider{box-shadow:0 0 1px var(--cps-color-calm)}:host .cps-switch-container input:checked+.cps-switch-slider:before{transform:translate(24px);background-color:#fff}:host .cps-switch-container input:disabled~.cps-switch-slider{cursor:default;border-color:var(--cps-color-text-lightest)}:host .cps-switch-container input:disabled:checked~.cps-switch-slider{background-color:var(--cps-color-text-lightest)}:host .cps-switch-container input:disabled:not(:checked)~.cps-switch-slider:before{background-color:var(--cps-color-text-lightest)}:host .cps-switch-container .cps-switch-info-circle{margin-left:8px}:host .cps-switch-container .cps-switch-info-circle ::ng-deep cps-icon i{width:14px;height:14px}\n"] }]
|
|
107
|
+
}], ctorParameters: () => [{ type: i1.NgControl, decorators: [{
|
|
108
|
+
type: Self
|
|
109
|
+
}, {
|
|
110
|
+
type: Optional
|
|
111
|
+
}] }, { type: i0.ElementRef }], propDecorators: { label: [{
|
|
112
|
+
type: Input
|
|
113
|
+
}], disabled: [{
|
|
114
|
+
type: Input
|
|
115
|
+
}], infoTooltip: [{
|
|
116
|
+
type: Input
|
|
117
|
+
}], infoTooltipClass: [{
|
|
118
|
+
type: Input
|
|
119
|
+
}], infoTooltipMaxWidth: [{
|
|
120
|
+
type: Input
|
|
121
|
+
}], infoTooltipPersistent: [{
|
|
122
|
+
type: Input
|
|
123
|
+
}], infoTooltipPosition: [{
|
|
124
|
+
type: Input
|
|
125
|
+
}], value: [{
|
|
126
|
+
type: Input
|
|
127
|
+
}], valueChanged: [{
|
|
128
|
+
type: Output
|
|
129
|
+
}] } });
|
|
130
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-switch.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-switch/cps-switch.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-switch/cps-switch.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Optional,\n  Output,\n  Self\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { CpsInfoCircleComponent } from '../cps-info-circle/cps-info-circle.component';\nimport { CpsTooltipPosition } from '../../directives/cps-tooltip/cps-tooltip.directive';\n\n/**\n * CpsSwitchComponent is a component used to toggle a boolean value.\n * @group Components\n */\n@Component({\n  standalone: true,\n  imports: [CommonModule, CpsInfoCircleComponent],\n  selector: 'cps-switch',\n  templateUrl: './cps-switch.component.html',\n  styleUrls: ['./cps-switch.component.scss']\n})\nexport class CpsSwitchComponent implements ControlValueAccessor {\n  /**\n   * Label of the component.\n   * @group Props\n   */\n  @Input() label = '';\n\n  /**\n   * Determines whether the component is disabled.\n   * @group Props\n   */\n  @Input() disabled = false;\n\n  /**\n   * When it is not an empty string, an info icon is displayed to show text for more info.\n   * @group Props\n   */\n  @Input() infoTooltip = '';\n\n  /**\n   * InfoTooltip class for styling.\n   * @group Props\n   */\n  @Input() infoTooltipClass = 'cps-tooltip-content';\n\n  /**\n   * Size of infoTooltip, of type number denoting pixels or string.\n   * @group Props\n   */\n  @Input() infoTooltipMaxWidth: number | string = '100%';\n\n  /**\n   * Determines whether the infoTooltip is persistent.\n   * @group Props\n   */\n  @Input() infoTooltipPersistent = false;\n\n  /**\n   * Position of infoTooltip, it can be 'top', 'bottom', 'left' or 'right'.\n   * @group Props\n   */\n  @Input() infoTooltipPosition: CpsTooltipPosition = 'top';\n\n  /**\n   * Value of the switch component.\n   * @group Props\n   */\n  @Input() set value(value: boolean) {\n    this._value = value;\n    this.onChange(value);\n  }\n\n  get value(): boolean {\n    return this._value;\n  }\n\n  /**\n   * Callback to invoke on value change.\n   * @param {boolean} boolean - value changed.\n   * @group Emits\n   */\n  @Output() valueChanged = new EventEmitter<boolean>();\n\n  private _value = false;\n\n  constructor(\n    @Self() @Optional() private _control: NgControl,\n    private _elementRef: ElementRef<HTMLElement>\n  ) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  writeValue(value: boolean) {\n    this.value = value;\n  }\n\n  updateValueEvent(event: any) {\n    event.preventDefault();\n    if (this.disabled) return;\n    this._updateValue(!this.value);\n  }\n\n  private _updateValue(value: boolean) {\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  setDisabledState(disabled: boolean) {}\n\n  focus() {\n    this._elementRef?.nativeElement?.querySelector('input')?.focus();\n  }\n}\n","<div class=\"cps-switch-container\">\n  <label class=\"cps-switch\">\n    <input\n      type=\"checkbox\"\n      [disabled]=\"disabled\"\n      [checked]=\"value\"\n      (change)=\"updateValueEvent($event)\" />\n    <span class=\"cps-switch-slider\"></span>\n  </label>\n  <span\n    *ngIf=\"label\"\n    class=\"cps-switch-label\"\n    [ngClass]=\"{ 'cps-switch-label-disabled': disabled }\"\n    >{{ label }}</span\n  >\n  <cps-info-circle\n    *ngIf=\"infoTooltip\"\n    class=\"cps-switch-info-circle\"\n    size=\"xsmall\"\n    [tooltipPosition]=\"infoTooltipPosition\"\n    [tooltipContentClass]=\"infoTooltipClass\"\n    [tooltipMaxWidth]=\"infoTooltipMaxWidth\"\n    [tooltipPersistent]=\"infoTooltipPersistent\"\n    [tooltipText]=\"infoTooltip\">\n  </cps-info-circle>\n</div>\n"]}
|
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
import { Injectable, Inject } from '@angular/core';
|
|
2
|
-
import { DynamicDialogInjector } from 'primeng/dynamicdialog';
|
|
1
|
+
import { Injectable, Inject, createComponent, createEnvironmentInjector } from '@angular/core';
|
|
3
2
|
import { DOCUMENT } from '@angular/common';
|
|
4
3
|
import { CpsDialogRef } from './utils/cps-dialog-ref';
|
|
5
4
|
import { CpsDialogConfig } from './utils/cps-dialog-config';
|
|
@@ -12,9 +11,9 @@ import * as i0 from "@angular/core";
|
|
|
12
11
|
*/
|
|
13
12
|
export class CpsDialogService {
|
|
14
13
|
// eslint-disable-next-line no-useless-constructor
|
|
15
|
-
constructor(
|
|
16
|
-
this.
|
|
17
|
-
this.
|
|
14
|
+
constructor(_appRef, _environmentInjector, document) {
|
|
15
|
+
this._appRef = _appRef;
|
|
16
|
+
this._environmentInjector = _environmentInjector;
|
|
18
17
|
this.document = document;
|
|
19
18
|
this.dialogComponentRefMap = new Map();
|
|
20
19
|
}
|
|
@@ -55,11 +54,23 @@ export class CpsDialogService {
|
|
|
55
54
|
instance.childComponentType = CpsConfirmationComponent;
|
|
56
55
|
return dialogRef;
|
|
57
56
|
}
|
|
57
|
+
/**
|
|
58
|
+
* Closes all dialogs.
|
|
59
|
+
* @param {boolean} [force=false] - If true closes all dialogs even if they have disableClose set to true.
|
|
60
|
+
* @group Method
|
|
61
|
+
*/
|
|
62
|
+
closeAll(force = false) {
|
|
63
|
+
this.dialogComponentRefMap.forEach((_, key) => {
|
|
64
|
+
if (force) {
|
|
65
|
+
key.destroy();
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
key.close();
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
}
|
|
58
72
|
appendDialogComponentToBody(config) {
|
|
59
|
-
const map = new WeakMap();
|
|
60
|
-
map.set(CpsDialogConfig, config);
|
|
61
73
|
const dialogRef = new CpsDialogRef();
|
|
62
|
-
map.set(CpsDialogRef, dialogRef);
|
|
63
74
|
const sub = dialogRef.onClose.subscribe(() => {
|
|
64
75
|
this.dialogComponentRefMap.get(dialogRef)?.instance.close();
|
|
65
76
|
});
|
|
@@ -68,7 +79,13 @@ export class CpsDialogService {
|
|
|
68
79
|
destroySub.unsubscribe();
|
|
69
80
|
sub.unsubscribe();
|
|
70
81
|
});
|
|
71
|
-
const componentRef =
|
|
82
|
+
const componentRef = createComponent(CpsDialogComponent, {
|
|
83
|
+
environmentInjector: createEnvironmentInjector([
|
|
84
|
+
{ provide: CpsDialogConfig, useValue: config },
|
|
85
|
+
{ provide: CpsDialogRef, useValue: dialogRef }
|
|
86
|
+
], this._environmentInjector)
|
|
87
|
+
});
|
|
88
|
+
this._appRef.attachView(componentRef.hostView);
|
|
72
89
|
const domElem = componentRef.hostView
|
|
73
90
|
.rootNodes[0];
|
|
74
91
|
this.document.body.appendChild(domElem);
|
|
@@ -82,18 +99,19 @@ export class CpsDialogService {
|
|
|
82
99
|
}
|
|
83
100
|
const dialogComponentRef = this.dialogComponentRefMap.get(dialogRef);
|
|
84
101
|
if (dialogComponentRef) {
|
|
85
|
-
this.
|
|
102
|
+
this._appRef.detachView(dialogComponentRef.hostView);
|
|
86
103
|
dialogComponentRef.destroy();
|
|
87
104
|
this.dialogComponentRefMap.delete(dialogRef);
|
|
88
105
|
}
|
|
89
106
|
}
|
|
90
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogService, deps: [{ token: i0.
|
|
91
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogService }); }
|
|
107
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogService, deps: [{ token: i0.ApplicationRef }, { token: i0.EnvironmentInjector }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
108
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogService, providedIn: 'root' }); }
|
|
92
109
|
}
|
|
93
110
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogService, decorators: [{
|
|
94
|
-
type: Injectable
|
|
95
|
-
|
|
111
|
+
type: Injectable,
|
|
112
|
+
args: [{ providedIn: 'root' }]
|
|
113
|
+
}], ctorParameters: () => [{ type: i0.ApplicationRef }, { type: i0.EnvironmentInjector }, { type: Document, decorators: [{
|
|
96
114
|
type: Inject,
|
|
97
115
|
args: [DOCUMENT]
|
|
98
116
|
}] }] });
|
|
99
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-dialog.service.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/services/cps-dialog/cps-dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Injectable,\n  Injector,\n  Type,\n  EmbeddedViewRef,\n  ComponentRef,\n  Inject,\n  ViewContainerRef\n} from '@angular/core';\nimport { DynamicDialogInjector } from 'primeng/dynamicdialog';\nimport { DOCUMENT } from '@angular/common';\nimport { CpsDialogRef } from './utils/cps-dialog-ref';\nimport { CpsDialogConfig } from './utils/cps-dialog-config';\nimport { CpsDialogComponent } from './internal/components/cps-dialog/cps-dialog.component';\nimport { CpsConfirmationComponent } from './internal/components/cps-confirmation/cps-confirmation.component';\n\n/**\n * Service for showing CpsDialog.\n * @group Services\n */\n@Injectable()\nexport class CpsDialogService {\n  dialogComponentRefMap: Map<CpsDialogRef, ComponentRef<CpsDialogComponent>> =\n    new Map();\n\n  // eslint-disable-next-line no-useless-constructor\n  constructor(\n    private viewContainerRef: ViewContainerRef,\n    private injector: Injector,\n    @Inject(DOCUMENT) private document: Document\n  ) {}\n\n  /**\n   * Opens a dialog with a dynamically loaded component.\n   * @param {*} componentType - Dynamic component for content template.\n   * @param {CpsDialogConfig} config - CpsDialogConfig object.\n   * @returns {CpsDialogRef} CpsDialogRef instance.\n   * @group Method\n   */\n  public open(componentType: Type<any>, config: CpsDialogConfig): CpsDialogRef {\n    const dialogRef = this.appendDialogComponentToBody(config);\n\n    const instance = this.dialogComponentRefMap.get(dialogRef)?.instance;\n    if (instance) instance.childComponentType = componentType;\n\n    return dialogRef;\n  }\n\n  /**\n   * Opens a confirmation dialog.\n   * @param {CpsDialogConfig} config - CpsDialogConfig object.\n   * @returns {CpsDialogRef} CpsDialogRef instance.\n   * @group Method\n   */\n  public openConfirmationDialog(config: CpsDialogConfig): CpsDialogRef {\n    if (!config.headerTitle) config.headerTitle = 'Confirm the action';\n    if (!config.headerIcon) config.headerIcon = 'warning';\n    if (!config.headerIconColor) config.headerIconColor = 'calm';\n    if (!config.minWidth) config.minWidth = '400px';\n    if (!config.maxWidth) config.maxWidth = '600px';\n    const dialogRef = this.appendDialogComponentToBody(config);\n\n    const instance = this.dialogComponentRefMap.get(dialogRef)?.instance;\n    if (instance) instance.childComponentType = CpsConfirmationComponent;\n\n    return dialogRef;\n  }\n\n  private appendDialogComponentToBody(config: CpsDialogConfig) {\n    const map = new WeakMap();\n    map.set(CpsDialogConfig, config);\n\n    const dialogRef = new CpsDialogRef();\n    map.set(CpsDialogRef, dialogRef);\n\n    const sub = dialogRef.onClose.subscribe(() => {\n      this.dialogComponentRefMap.get(dialogRef)?.instance.close();\n    });\n\n    const destroySub = dialogRef.onDestroy.subscribe(() => {\n      this.removeDialogComponentFromBody(dialogRef);\n      destroySub.unsubscribe();\n      sub.unsubscribe();\n    });\n\n    const componentRef = this.viewContainerRef.createComponent(\n      CpsDialogComponent,\n      { injector: new DynamicDialogInjector(this.injector, map) }\n    );\n\n    const domElem = (componentRef.hostView as EmbeddedViewRef<any>)\n      .rootNodes[0] as HTMLElement;\n    this.document.body.appendChild(domElem);\n\n    this.dialogComponentRefMap.set(dialogRef, componentRef);\n    dialogRef._setContainerInstance(componentRef.instance);\n\n    return dialogRef;\n  }\n\n  private removeDialogComponentFromBody(dialogRef: CpsDialogRef) {\n    if (!dialogRef || !this.dialogComponentRefMap.has(dialogRef)) {\n      return;\n    }\n\n    const dialogComponentRef = this.dialogComponentRefMap.get(dialogRef);\n    if (dialogComponentRef) {\n      this.viewContainerRef.detach(\n        this.viewContainerRef.indexOf(dialogComponentRef.hostView)\n      );\n      dialogComponentRef.destroy();\n      this.dialogComponentRefMap.delete(dialogRef);\n    }\n  }\n}\n"]}
|
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-dialog.service.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/services/cps-dialog/cps-dialog.service.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,UAAU,EAIV,MAAM,EAEN,eAAe,EAEf,yBAAyB,EAC1B,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC5D,OAAO,EAAE,kBAAkB,EAAE,MAAM,uDAAuD,CAAC;AAC3F,OAAO,EAAE,wBAAwB,EAAE,MAAM,mEAAmE,CAAC;;AAE7G;;;GAGG;AAEH,MAAM,OAAO,gBAAgB;IAI3B,kDAAkD;IAClD,YACU,OAAuB,EACvB,oBAAyC,EACvB,QAAkB;QAFpC,YAAO,GAAP,OAAO,CAAgB;QACvB,yBAAoB,GAApB,oBAAoB,CAAqB;QACvB,aAAQ,GAAR,QAAQ,CAAU;QAP9C,0BAAqB,GACnB,IAAI,GAAG,EAAE,CAAC;IAOT,CAAC;IAEJ;;;;;;OAMG;IACI,IAAI,CAAC,aAAwB,EAAE,MAAuB;QAC3D,MAAM,SAAS,GAAG,IAAI,CAAC,2BAA2B,CAAC,MAAM,CAAC,CAAC;QAE3D,MAAM,QAAQ,GAAG,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,QAAQ,CAAC;QACrE,IAAI,QAAQ;YAAE,QAAQ,CAAC,kBAAkB,GAAG,aAAa,CAAC;QAE1D,OAAO,SAAS,CAAC;IACnB,CAAC;IAED;;;;;OAKG;IACI,sBAAsB,CAAC,MAAuB;QACnD,IAAI,CAAC,MAAM,CAAC,WAAW;YAAE,MAAM,CAAC,WAAW,GAAG,oBAAoB,CAAC;QACnE,IAAI,CAAC,MAAM,CAAC,UAAU;YAAE,MAAM,CAAC,UAAU,GAAG,SAAS,CAAC;QACtD,IAAI,CAAC,MAAM,CAAC,eAAe;YAAE,MAAM,CAAC,eAAe,GAAG,MAAM,CAAC;QAC7D,IAAI,CAAC,MAAM,CAAC,QAAQ;YAAE,MAAM,CAAC,QAAQ,GAAG,OAAO,CAAC;QAChD,IAAI,CAAC,MAAM,CAAC,QAAQ;YAAE,MAAM,CAAC,QAAQ,GAAG,OAAO,CAAC;QAChD,MAAM,SAAS,GAAG,IAAI,CAAC,2BAA2B,CAAC,MAAM,CAAC,CAAC;QAE3D,MAAM,QAAQ,GAAG,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,QAAQ,CAAC;QACrE,IAAI,QAAQ;YAAE,QAAQ,CAAC,kBAAkB,GAAG,wBAAwB,CAAC;QAErE,OAAO,SAAS,CAAC;IACnB,CAAC;IAED;;;;OAIG;IACI,QAAQ,CAAC,KAAK,GAAG,KAAK;QAC3B,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;YAC5C,IAAI,KAAK,EAAE,CAAC;gBACV,GAAG,CAAC,OAAO,EAAE,CAAC;YAChB,CAAC;iBAAM,CAAC;gBACN,GAAG,CAAC,KAAK,EAAE,CAAC;YACd,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,2BAA2B,CAAC,MAAuB;QACzD,MAAM,SAAS,GAAG,IAAI,YAAY,EAAE,CAAC;QAErC,MAAM,GAAG,GAAG,SAAS,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE;YAC3C,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,QAAQ,CAAC,KAAK,EAAE,CAAC;QAC9D,CAAC,CAAC,CAAC;QAEH,MAAM,UAAU,GAAG,SAAS,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,EAAE;YACpD,IAAI,CAAC,6BAA6B,CAAC,SAAS,CAAC,CAAC;YAC9C,UAAU,CAAC,WAAW,EAAE,CAAC;YACzB,GAAG,CAAC,WAAW,EAAE,CAAC;QACpB,CAAC,CAAC,CAAC;QAEH,MAAM,YAAY,GAAG,eAAe,CAAC,kBAAkB,EAAE;YACvD,mBAAmB,EAAE,yBAAyB,CAC5C;gBACE,EAAE,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,EAAE;gBAC9C,EAAE,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,SAAS,EAAE;aAC/C,EACD,IAAI,CAAC,oBAAoB,CAC1B;SACF,CAAC,CAAC;QAEH,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAE/C,MAAM,OAAO,GAAI,YAAY,CAAC,QAAiC;aAC5D,SAAS,CAAC,CAAC,CAAgB,CAAC;QAC/B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QAExC,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC;QACxD,SAAS,CAAC,qBAAqB,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAEvD,OAAO,SAAS,CAAC;IACnB,CAAC;IAEO,6BAA6B,CAAC,SAAuB;QAC3D,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC;YAC7D,OAAO;QACT,CAAC;QAED,MAAM,kBAAkB,GAAG,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACrE,IAAI,kBAAkB,EAAE,CAAC;YACvB,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;YACrD,kBAAkB,CAAC,OAAO,EAAE,CAAC;YAC7B,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QAC/C,CAAC;IACH,CAAC;8GA5GU,gBAAgB,mFAQjB,QAAQ;kHARP,gBAAgB,cADH,MAAM;;2FACnB,gBAAgB;kBAD5B,UAAU;mBAAC,EAAE,UAAU,EAAE,MAAM,EAAE;;0BAS7B,MAAM;2BAAC,QAAQ","sourcesContent":["import {\n  Injectable,\n  Type,\n  EmbeddedViewRef,\n  ComponentRef,\n  Inject,\n  ApplicationRef,\n  createComponent,\n  EnvironmentInjector,\n  createEnvironmentInjector\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { CpsDialogRef } from './utils/cps-dialog-ref';\nimport { CpsDialogConfig } from './utils/cps-dialog-config';\nimport { CpsDialogComponent } from './internal/components/cps-dialog/cps-dialog.component';\nimport { CpsConfirmationComponent } from './internal/components/cps-confirmation/cps-confirmation.component';\n\n/**\n * Service for showing CpsDialog.\n * @group Services\n */\n@Injectable({ providedIn: 'root' })\nexport class CpsDialogService {\n  dialogComponentRefMap: Map<CpsDialogRef, ComponentRef<CpsDialogComponent>> =\n    new Map();\n\n  // eslint-disable-next-line no-useless-constructor\n  constructor(\n    private _appRef: ApplicationRef,\n    private _environmentInjector: EnvironmentInjector,\n    @Inject(DOCUMENT) private document: Document\n  ) {}\n\n  /**\n   * Opens a dialog with a dynamically loaded component.\n   * @param {*} componentType - Dynamic component for content template.\n   * @param {CpsDialogConfig} config - CpsDialogConfig object.\n   * @returns {CpsDialogRef} CpsDialogRef instance.\n   * @group Method\n   */\n  public open(componentType: Type<any>, config: CpsDialogConfig): CpsDialogRef {\n    const dialogRef = this.appendDialogComponentToBody(config);\n\n    const instance = this.dialogComponentRefMap.get(dialogRef)?.instance;\n    if (instance) instance.childComponentType = componentType;\n\n    return dialogRef;\n  }\n\n  /**\n   * Opens a confirmation dialog.\n   * @param {CpsDialogConfig} config - CpsDialogConfig object.\n   * @returns {CpsDialogRef} CpsDialogRef instance.\n   * @group Method\n   */\n  public openConfirmationDialog(config: CpsDialogConfig): CpsDialogRef {\n    if (!config.headerTitle) config.headerTitle = 'Confirm the action';\n    if (!config.headerIcon) config.headerIcon = 'warning';\n    if (!config.headerIconColor) config.headerIconColor = 'calm';\n    if (!config.minWidth) config.minWidth = '400px';\n    if (!config.maxWidth) config.maxWidth = '600px';\n    const dialogRef = this.appendDialogComponentToBody(config);\n\n    const instance = this.dialogComponentRefMap.get(dialogRef)?.instance;\n    if (instance) instance.childComponentType = CpsConfirmationComponent;\n\n    return dialogRef;\n  }\n\n  /**\n   * Closes all dialogs.\n   * @param {boolean} [force=false] - If true closes all dialogs even if they have disableClose set to true.\n   * @group Method\n   */\n  public closeAll(force = false): void {\n    this.dialogComponentRefMap.forEach((_, key) => {\n      if (force) {\n        key.destroy();\n      } else {\n        key.close();\n      }\n    });\n  }\n\n  private appendDialogComponentToBody(config: CpsDialogConfig) {\n    const dialogRef = new CpsDialogRef();\n\n    const sub = dialogRef.onClose.subscribe(() => {\n      this.dialogComponentRefMap.get(dialogRef)?.instance.close();\n    });\n\n    const destroySub = dialogRef.onDestroy.subscribe(() => {\n      this.removeDialogComponentFromBody(dialogRef);\n      destroySub.unsubscribe();\n      sub.unsubscribe();\n    });\n\n    const componentRef = createComponent(CpsDialogComponent, {\n      environmentInjector: createEnvironmentInjector(\n        [\n          { provide: CpsDialogConfig, useValue: config },\n          { provide: CpsDialogRef, useValue: dialogRef }\n        ],\n        this._environmentInjector\n      )\n    });\n\n    this._appRef.attachView(componentRef.hostView);\n\n    const domElem = (componentRef.hostView as EmbeddedViewRef<any>)\n      .rootNodes[0] as HTMLElement;\n    this.document.body.appendChild(domElem);\n\n    this.dialogComponentRefMap.set(dialogRef, componentRef);\n    dialogRef._setContainerInstance(componentRef.instance);\n\n    return dialogRef;\n  }\n\n  private removeDialogComponentFromBody(dialogRef: CpsDialogRef) {\n    if (!dialogRef || !this.dialogComponentRefMap.has(dialogRef)) {\n      return;\n    }\n\n    const dialogComponentRef = this.dialogComponentRefMap.get(dialogRef);\n    if (dialogComponentRef) {\n      this._appRef.detachView(dialogComponentRef.hostView);\n      dialogComponentRef.destroy();\n      this.dialogComponentRefMap.delete(dialogRef);\n    }\n  }\n}\n"]}
|
|
@@ -10,7 +10,7 @@ export class CpsConfirmationComponent {
|
|
|
10
10
|
this._dialogRef = _dialogRef;
|
|
11
11
|
this._config = _config;
|
|
12
12
|
this.subtitle = '';
|
|
13
|
-
this.subtitle = this._config.data
|
|
13
|
+
this.subtitle = this._config.data?.subtitle;
|
|
14
14
|
}
|
|
15
15
|
close(confirm) {
|
|
16
16
|
this._dialogRef?.close(confirm);
|
|
@@ -22,4 +22,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
22
22
|
type: Component,
|
|
23
23
|
args: [{ standalone: true, imports: [CpsButtonComponent, CpsIconComponent], selector: 'cps-confirmation', template: "<div class=\"cps-confirmation\">\n <span class=\"cps-confirmation-subtitle\">{{ subtitle }}</span>\n <div class=\"cps-confirmation-buttons\">\n <cps-button\n type=\"outlined\"\n label=\"No\"\n (clicked)=\"close(false)\"\n color=\"prepared\">\n </cps-button>\n <cps-button\n data-cy=\"btn-yes\"\n label=\"Yes\"\n (clicked)=\"close(true)\"\n color=\"prepared\">\n </cps-button>\n </div>\n</div>\n", styles: [":host .cps-confirmation{display:flex;flex-direction:column;align-items:center;padding:8px}:host .cps-confirmation-subtitle{font-size:16px;font-weight:400;font-family:Source Sans Pro,sans-serif;color:var(--cps-color-text-dark)}:host .cps-confirmation-buttons{width:100%;display:flex;justify-content:space-around;padding-top:28px}\n"] }]
|
|
24
24
|
}], ctorParameters: () => [{ type: i1.CpsDialogRef }, { type: i2.CpsDialogConfig }] });
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BzLWNvbmZpcm1hdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jcHMtdWkta2l0L3NyYy9saWIvc2VydmljZXMvY3BzLWRpYWxvZy9pbnRlcm5hbC9jb21wb25lbnRzL2Nwcy1jb25maXJtYXRpb24vY3BzLWNvbmZpcm1hdGlvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jcHMtdWkta2l0L3NyYy9saWIvc2VydmljZXMvY3BzLWRpYWxvZy9pbnRlcm5hbC9jb21wb25lbnRzL2Nwcy1jb25maXJtYXRpb24vY3BzLWNvbmZpcm1hdGlvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDJEQUEyRCxDQUFDO0FBQy9GLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHVEQUF1RCxDQUFDOzs7O0FBV3pGLE1BQU0sT0FBTyx3QkFBd0I7SUFHbkMsa0RBQWtEO0lBQ2xELFlBQ1UsVUFBd0IsRUFDeEIsT0FBd0I7UUFEeEIsZUFBVSxHQUFWLFVBQVUsQ0FBYztRQUN4QixZQUFPLEdBQVAsT0FBTyxDQUFpQjtRQUxsQyxhQUFRLEdBQUcsRUFBRSxDQUFDO1FBT1osSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxRQUFRLENBQUM7SUFDOUMsQ0FBQztJQUVELEtBQUssQ0FBQyxPQUFnQjtRQUNwQixJQUFJLENBQUMsVUFBVSxFQUFFLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNsQyxDQUFDOzhHQWJVLHdCQUF3QjtrR0FBeEIsd0JBQXdCLDRFQ2JyQyxtY0FpQkEsb1lEVFksa0JBQWtCOzsyRkFLakIsd0JBQXdCO2tCQVBwQyxTQUFTO2lDQUNJLElBQUksV0FDUCxDQUFDLGtCQUFrQixFQUFFLGdCQUFnQixDQUFDLFlBQ3JDLGtCQUFrQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ3BzQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vY29tcG9uZW50cy9jcHMtYnV0dG9uL2Nwcy1idXR0b24uY29tcG9uZW50JztcbmltcG9ydCB7IENwc0ljb25Db21wb25lbnQgfSBmcm9tICcuLi8uLi8uLi8uLi8uLi9jb21wb25lbnRzL2Nwcy1pY29uL2Nwcy1pY29uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDcHNEaWFsb2dSZWYgfSBmcm9tICcuLi8uLi8uLi91dGlscy9jcHMtZGlhbG9nLXJlZic7XG5pbXBvcnQgeyBDcHNEaWFsb2dDb25maWcgfSBmcm9tICcuLi8uLi8uLi91dGlscy9jcHMtZGlhbG9nLWNvbmZpZyc7XG5cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ3BzQnV0dG9uQ29tcG9uZW50LCBDcHNJY29uQ29tcG9uZW50XSxcbiAgc2VsZWN0b3I6ICdjcHMtY29uZmlybWF0aW9uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2Nwcy1jb25maXJtYXRpb24uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jcHMtY29uZmlybWF0aW9uLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgQ3BzQ29uZmlybWF0aW9uQ29tcG9uZW50IHtcbiAgc3VidGl0bGUgPSAnJztcblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tdXNlbGVzcy1jb25zdHJ1Y3RvclxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIF9kaWFsb2dSZWY6IENwc0RpYWxvZ1JlZixcbiAgICBwcml2YXRlIF9jb25maWc6IENwc0RpYWxvZ0NvbmZpZ1xuICApIHtcbiAgICB0aGlzLnN1YnRpdGxlID0gdGhpcy5fY29uZmlnLmRhdGE/LnN1YnRpdGxlO1xuICB9XG5cbiAgY2xvc2UoY29uZmlybTogYm9vbGVhbikge1xuICAgIHRoaXMuX2RpYWxvZ1JlZj8uY2xvc2UoY29uZmlybSk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJjcHMtY29uZmlybWF0aW9uXCI+XG4gIDxzcGFuIGNsYXNzPVwiY3BzLWNvbmZpcm1hdGlvbi1zdWJ0aXRsZVwiPnt7IHN1YnRpdGxlIH19PC9zcGFuPlxuICA8ZGl2IGNsYXNzPVwiY3BzLWNvbmZpcm1hdGlvbi1idXR0b25zXCI+XG4gICAgPGNwcy1idXR0b25cbiAgICAgIHR5cGU9XCJvdXRsaW5lZFwiXG4gICAgICBsYWJlbD1cIk5vXCJcbiAgICAgIChjbGlja2VkKT1cImNsb3NlKGZhbHNlKVwiXG4gICAgICBjb2xvcj1cInByZXBhcmVkXCI+XG4gICAgPC9jcHMtYnV0dG9uPlxuICAgIDxjcHMtYnV0dG9uXG4gICAgICBkYXRhLWN5PVwiYnRuLXllc1wiXG4gICAgICBsYWJlbD1cIlllc1wiXG4gICAgICAoY2xpY2tlZCk9XCJjbG9zZSh0cnVlKVwiXG4gICAgICBjb2xvcj1cInByZXBhcmVkXCI+XG4gICAgPC9jcHMtYnV0dG9uPlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
|
package/esm2022/public-api.mjs
CHANGED
|
@@ -42,6 +42,7 @@ export * from './lib/components/cps-tab-group/cps-tab/cps-tab.component';
|
|
|
42
42
|
export * from './lib/components/cps-timepicker/cps-timepicker.component';
|
|
43
43
|
export * from './lib/components/cps-file-upload/cps-file-upload.component';
|
|
44
44
|
export * from './lib/components/cps-scheduler/cps-scheduler.component';
|
|
45
|
+
export * from './lib/components/cps-switch/cps-switch.component';
|
|
45
46
|
export * from './lib/directives/cps-tooltip/cps-tooltip.directive';
|
|
46
47
|
export * from './lib/services/cps-dialog/cps-dialog.service';
|
|
47
48
|
export * from './lib/services/cps-dialog/utils/cps-dialog-config';
|
|
@@ -49,4 +50,4 @@ export * from './lib/services/cps-dialog/utils/cps-dialog-ref';
|
|
|
49
50
|
export * from './lib/services/cps-notification/cps-notification.service';
|
|
50
51
|
export * from './lib/services/cps-notification/utils/cps-notification-config';
|
|
51
52
|
export * from './lib/utils/colors-utils';
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2Nwcy11aS1raXQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLDREQUE0RCxDQUFDO0FBQzNFLGNBQWMsOERBQThELENBQUM7QUFDN0UsY0FBYyx3RUFBd0UsQ0FBQztBQUN2RixjQUFjLDREQUE0RCxDQUFDO0FBQzNFLGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyxzREFBc0QsQ0FBQztBQUNyRSxjQUFjLGdFQUFnRSxDQUFDO0FBQy9FLGNBQWMsNERBQTRELENBQUM7QUFDM0UsY0FBYyxnREFBZ0QsQ0FBQztBQUMvRCxjQUFjLDJFQUEyRSxDQUFDO0FBQzFGLGNBQWMseUVBQXlFLENBQUM7QUFDeEYsY0FBYyw2RUFBNkUsQ0FBQztBQUM1RixjQUFjLDBFQUEwRSxDQUFDO0FBQ3pGLGNBQWMsb0RBQW9ELENBQUM7QUFDbkUsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLHFGQUFxRixDQUFDO0FBQ3BHLGNBQWMsbUZBQW1GLENBQUM7QUFDbEcsY0FBYyxpRkFBaUYsQ0FBQztBQUNoRyxjQUFjLHVGQUF1RixDQUFDO0FBQ3RHLGNBQWMsb0ZBQW9GLENBQUM7QUFDbkcsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYyx3REFBd0QsQ0FBQztBQUN2RSxjQUFjLHdEQUF3RCxDQUFDO0FBQ3ZFLGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyxvRUFBb0UsQ0FBQztBQUNuRixjQUFjLHdFQUF3RSxDQUFDO0FBQ3ZGLGNBQWMsb0VBQW9FLENBQUM7QUFDbkYsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLDhEQUE4RCxDQUFDO0FBQzdFLGNBQWMsc0RBQXNELENBQUM7QUFDckUsY0FBYyxnRUFBZ0UsQ0FBQztBQUMvRSxjQUFjLHdEQUF3RCxDQUFDO0FBQ3ZFLGNBQWMsMERBQTBELENBQUM7QUFDekUsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLDREQUE0RCxDQUFDO0FBQzNFLGNBQWMsd0RBQXdELENBQUM7QUFDdkUsY0FBYyxrREFBa0QsQ0FBQztBQUVqRSxjQUFjLG9EQUFvRCxDQUFDO0FBRW5FLGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLGdEQUFnRCxDQUFDO0FBRS9ELGNBQWMsMERBQTBELENBQUM7QUFDekUsY0FBYywrREFBK0QsQ0FBQztBQUU5RSxjQUFjLDBCQUEwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBjcHMtdWkta2l0XG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtaWNvbi9jcHMtaWNvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtaW5wdXQvY3BzLWlucHV0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1zZWxlY3QvY3BzLXNlbGVjdC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdHJlZS1zZWxlY3QvY3BzLXRyZWUtc2VsZWN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1hdXRvY29tcGxldGUvY3BzLWF1dG9jb21wbGV0ZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdHJlZS1hdXRvY29tcGxldGUvY3BzLXRyZWUtYXV0b2NvbXBsZXRlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1pbmZvLWNpcmNsZS9jcHMtaW5mby1jaXJjbGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWJ1dHRvbi9jcHMtYnV0dG9uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1jaGVja2JveC9jcHMtY2hlY2tib3guY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXJhZGlvLWdyb3VwL2Nwcy1yYWRpby9jcHMtcmFkaW8uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXJhZGlvLWdyb3VwL2Nwcy1yYWRpby1ncm91cC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGFibGUvY3BzLXRhYmxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10YWJsZS9kaXJlY3RpdmVzL2Nwcy10YWJsZS1jb2x1bW4tc29ydGFibGUuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRhYmxlL2RpcmVjdGl2ZXMvY3BzLXRhYmxlLWNvbHVtbi1maWx0ZXIuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRhYmxlL2RpcmVjdGl2ZXMvY3BzLXRhYmxlLWhlYWRlci1zZWxlY3RhYmxlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10YWJsZS9kaXJlY3RpdmVzL2Nwcy10YWJsZS1yb3ctc2VsZWN0YWJsZS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGFibGUvY3BzLWNvbHVtbi1maWx0ZXItdHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdHJlZS10YWJsZS9jcHMtdHJlZS10YWJsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdHJlZS10YWJsZS9kaXJlY3RpdmVzL2Nwcy10cmVlLXRhYmxlLWNvbHVtbi1zb3J0YWJsZS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdHJlZS10YWJsZS9kaXJlY3RpdmVzL2Nwcy10cmVlLXRhYmxlLWNvbHVtbi1maWx0ZXIuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRyZWUtdGFibGUvZGlyZWN0aXZlcy9jcHMtdHJlZS10YWJsZS1yb3ctdG9nZ2xlci5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdHJlZS10YWJsZS9kaXJlY3RpdmVzL2Nwcy10cmVlLXRhYmxlLWhlYWRlci1zZWxlY3RhYmxlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10cmVlLXRhYmxlL2RpcmVjdGl2ZXMvY3BzLXRyZWUtdGFibGUtcm93LXNlbGVjdGFibGUuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRhZy9jcHMtdGFnLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1jaGlwL2Nwcy1jaGlwLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1tZW51L2Nwcy1tZW51LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1wYWdpbmF0b3IvY3BzLXBhZ2luYXRvci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtcGFnaW5hdG9yL3BpcGVzL2Nwcy1wYWdpbmF0ZS5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWxvYWRlci9jcHMtbG9hZGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1leHBhbnNpb24tcGFuZWwvY3BzLWV4cGFuc2lvbi1wYW5lbC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtcHJvZ3Jlc3MtY2lyY3VsYXIvY3BzLXByb2dyZXNzLWNpcmN1bGFyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1wcm9ncmVzcy1saW5lYXIvY3BzLXByb2dyZXNzLWxpbmVhci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtZGF0ZXBpY2tlci9jcHMtZGF0ZXBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtc2lkZWJhci1tZW51L2Nwcy1zaWRlYmFyLW1lbnUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRleHRhcmVhL2Nwcy10ZXh0YXJlYS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtYnV0dG9uLXRvZ2dsZS9jcHMtYnV0dG9uLXRvZ2dsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGFiLWdyb3VwL2Nwcy10YWItZ3JvdXAuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRhYi1ncm91cC9jcHMtdGFiL2Nwcy10YWIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRpbWVwaWNrZXIvY3BzLXRpbWVwaWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWZpbGUtdXBsb2FkL2Nwcy1maWxlLXVwbG9hZC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtc2NoZWR1bGVyL2Nwcy1zY2hlZHVsZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXN3aXRjaC9jcHMtc3dpdGNoLmNvbXBvbmVudCc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvY3BzLXRvb2x0aXAvY3BzLXRvb2x0aXAuZGlyZWN0aXZlJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvY3BzLWRpYWxvZy9jcHMtZGlhbG9nLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvY3BzLWRpYWxvZy91dGlscy9jcHMtZGlhbG9nLWNvbmZpZyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlcy9jcHMtZGlhbG9nL3V0aWxzL2Nwcy1kaWFsb2ctcmVmJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvY3BzLW5vdGlmaWNhdGlvbi9jcHMtbm90aWZpY2F0aW9uLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvY3BzLW5vdGlmaWNhdGlvbi91dGlscy9jcHMtbm90aWZpY2F0aW9uLWNvbmZpZyc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL2NvbG9ycy11dGlscyc7XG4iXX0=
|
package/fesm2022/cps-ui-kit.mjs
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import * as i2 from '@angular/common';
|
|
2
2
|
import { CommonModule, isPlatformBrowser, DOCUMENT } from '@angular/common';
|
|
3
3
|
import * as i0 from '@angular/core';
|
|
4
|
-
import { Component, Input, Directive, HostListener, EventEmitter, Self, Optional, Output, ViewChild, Pipe, PLATFORM_ID, ChangeDetectionStrategy, ViewEncapsulation, Inject, HostBinding, InjectionToken, Host, ContentChild, ViewChildren, RendererStyleFlags2, TemplateRef, ContentChildren,
|
|
4
|
+
import { Component, Input, Directive, HostListener, EventEmitter, Self, Optional, Output, ViewChild, Pipe, PLATFORM_ID, ChangeDetectionStrategy, ViewEncapsulation, Inject, HostBinding, InjectionToken, Host, ContentChild, ViewChildren, RendererStyleFlags2, TemplateRef, ContentChildren, createComponent, createEnvironmentInjector, Injectable } from '@angular/core';
|
|
5
5
|
import * as i1 from '@angular/forms';
|
|
6
6
|
import { FormsModule, Validators, ReactiveFormsModule } from '@angular/forms';
|
|
7
7
|
import { isEqual, cloneDeep } from 'lodash-es';
|
|
@@ -30,7 +30,6 @@ import { AngleDoubleRightIcon } from 'primeng/icons/angledoubleright';
|
|
|
30
30
|
import { fromEvent, Subscription, debounceTime, distinctUntilChanged, take, catchError, of, Subject } from 'rxjs';
|
|
31
31
|
import * as i1$4 from 'primeng/paginator';
|
|
32
32
|
import { PaginatorModule } from 'primeng/paginator';
|
|
33
|
-
import { DynamicDialogInjector } from 'primeng/dynamicdialog';
|
|
34
33
|
|
|
35
34
|
const convertSize = (size) => {
|
|
36
35
|
const res = String(size).trim();
|
|
@@ -12305,6 +12304,130 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
12305
12304
|
type: Output
|
|
12306
12305
|
}] } });
|
|
12307
12306
|
|
|
12307
|
+
/**
|
|
12308
|
+
* CpsSwitchComponent is a component used to toggle a boolean value.
|
|
12309
|
+
* @group Components
|
|
12310
|
+
*/
|
|
12311
|
+
class CpsSwitchComponent {
|
|
12312
|
+
/**
|
|
12313
|
+
* Value of the switch component.
|
|
12314
|
+
* @group Props
|
|
12315
|
+
*/
|
|
12316
|
+
set value(value) {
|
|
12317
|
+
this._value = value;
|
|
12318
|
+
this.onChange(value);
|
|
12319
|
+
}
|
|
12320
|
+
get value() {
|
|
12321
|
+
return this._value;
|
|
12322
|
+
}
|
|
12323
|
+
constructor(_control, _elementRef) {
|
|
12324
|
+
this._control = _control;
|
|
12325
|
+
this._elementRef = _elementRef;
|
|
12326
|
+
/**
|
|
12327
|
+
* Label of the component.
|
|
12328
|
+
* @group Props
|
|
12329
|
+
*/
|
|
12330
|
+
this.label = '';
|
|
12331
|
+
/**
|
|
12332
|
+
* Determines whether the component is disabled.
|
|
12333
|
+
* @group Props
|
|
12334
|
+
*/
|
|
12335
|
+
this.disabled = false;
|
|
12336
|
+
/**
|
|
12337
|
+
* When it is not an empty string, an info icon is displayed to show text for more info.
|
|
12338
|
+
* @group Props
|
|
12339
|
+
*/
|
|
12340
|
+
this.infoTooltip = '';
|
|
12341
|
+
/**
|
|
12342
|
+
* InfoTooltip class for styling.
|
|
12343
|
+
* @group Props
|
|
12344
|
+
*/
|
|
12345
|
+
this.infoTooltipClass = 'cps-tooltip-content';
|
|
12346
|
+
/**
|
|
12347
|
+
* Size of infoTooltip, of type number denoting pixels or string.
|
|
12348
|
+
* @group Props
|
|
12349
|
+
*/
|
|
12350
|
+
this.infoTooltipMaxWidth = '100%';
|
|
12351
|
+
/**
|
|
12352
|
+
* Determines whether the infoTooltip is persistent.
|
|
12353
|
+
* @group Props
|
|
12354
|
+
*/
|
|
12355
|
+
this.infoTooltipPersistent = false;
|
|
12356
|
+
/**
|
|
12357
|
+
* Position of infoTooltip, it can be 'top', 'bottom', 'left' or 'right'.
|
|
12358
|
+
* @group Props
|
|
12359
|
+
*/
|
|
12360
|
+
this.infoTooltipPosition = 'top';
|
|
12361
|
+
/**
|
|
12362
|
+
* Callback to invoke on value change.
|
|
12363
|
+
* @param {boolean} boolean - value changed.
|
|
12364
|
+
* @group Emits
|
|
12365
|
+
*/
|
|
12366
|
+
this.valueChanged = new EventEmitter();
|
|
12367
|
+
this._value = false;
|
|
12368
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
12369
|
+
this.onChange = (event) => { };
|
|
12370
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
12371
|
+
this.onTouched = () => { };
|
|
12372
|
+
if (this._control) {
|
|
12373
|
+
this._control.valueAccessor = this;
|
|
12374
|
+
}
|
|
12375
|
+
}
|
|
12376
|
+
registerOnChange(fn) {
|
|
12377
|
+
this.onChange = fn;
|
|
12378
|
+
}
|
|
12379
|
+
registerOnTouched(fn) {
|
|
12380
|
+
this.onTouched = fn;
|
|
12381
|
+
}
|
|
12382
|
+
writeValue(value) {
|
|
12383
|
+
this.value = value;
|
|
12384
|
+
}
|
|
12385
|
+
updateValueEvent(event) {
|
|
12386
|
+
event.preventDefault();
|
|
12387
|
+
if (this.disabled)
|
|
12388
|
+
return;
|
|
12389
|
+
this._updateValue(!this.value);
|
|
12390
|
+
}
|
|
12391
|
+
_updateValue(value) {
|
|
12392
|
+
this.writeValue(value);
|
|
12393
|
+
this.onChange(value);
|
|
12394
|
+
this.valueChanged.emit(value);
|
|
12395
|
+
}
|
|
12396
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
12397
|
+
setDisabledState(disabled) { }
|
|
12398
|
+
focus() {
|
|
12399
|
+
this._elementRef?.nativeElement?.querySelector('input')?.focus();
|
|
12400
|
+
}
|
|
12401
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsSwitchComponent, deps: [{ token: i1.NgControl, optional: true, self: true }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
12402
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: CpsSwitchComponent, isStandalone: true, selector: "cps-switch", inputs: { label: "label", disabled: "disabled", infoTooltip: "infoTooltip", infoTooltipClass: "infoTooltipClass", infoTooltipMaxWidth: "infoTooltipMaxWidth", infoTooltipPersistent: "infoTooltipPersistent", infoTooltipPosition: "infoTooltipPosition", value: "value" }, outputs: { valueChanged: "valueChanged" }, ngImport: i0, template: "<div class=\"cps-switch-container\">\n <label class=\"cps-switch\">\n <input\n type=\"checkbox\"\n [disabled]=\"disabled\"\n [checked]=\"value\"\n (change)=\"updateValueEvent($event)\" />\n <span class=\"cps-switch-slider\"></span>\n </label>\n <span\n *ngIf=\"label\"\n class=\"cps-switch-label\"\n [ngClass]=\"{ 'cps-switch-label-disabled': disabled }\"\n >{{ label }}</span\n >\n <cps-info-circle\n *ngIf=\"infoTooltip\"\n class=\"cps-switch-info-circle\"\n size=\"xsmall\"\n [tooltipPosition]=\"infoTooltipPosition\"\n [tooltipContentClass]=\"infoTooltipClass\"\n [tooltipMaxWidth]=\"infoTooltipMaxWidth\"\n [tooltipPersistent]=\"infoTooltipPersistent\"\n [tooltipText]=\"infoTooltip\">\n </cps-info-circle>\n</div>\n", styles: [":host{min-width:max-content;display:inline-block}:host .cps-switch-container{line-height:normal;display:flex;align-items:center}:host .cps-switch-container .cps-switch{position:relative;display:inline-block;width:48px;height:24px}:host .cps-switch-container .cps-switch input{opacity:0;width:0;height:0}:host .cps-switch-container .cps-switch-slider{position:absolute;cursor:pointer;inset:0;background-color:#fff;transition:.2s;border:1px solid var(--cps-color-calm);border-radius:30px}:host .cps-switch-container .cps-switch-label{font-size:16px;font-family:Source Sans Pro,sans-serif;font-style:normal;color:var(--cps-color-text-dark);margin-left:10px;cursor:default}:host .cps-switch-container .cps-switch-label-disabled{color:var(--cps-color-text-light)}:host .cps-switch-container .cps-switch-slider:before{position:absolute;content:\"\";height:14px;width:14px;border-radius:20px;left:4px;bottom:4px;background-color:var(--cps-color-calm);transition:.2s}:host .cps-switch-container input:checked+.cps-switch-slider{background-color:var(--cps-color-calm)}:host .cps-switch-container input:focus+.cps-switch-slider{box-shadow:0 0 1px var(--cps-color-calm)}:host .cps-switch-container input:checked+.cps-switch-slider:before{transform:translate(24px);background-color:#fff}:host .cps-switch-container input:disabled~.cps-switch-slider{cursor:default;border-color:var(--cps-color-text-lightest)}:host .cps-switch-container input:disabled:checked~.cps-switch-slider{background-color:var(--cps-color-text-lightest)}:host .cps-switch-container input:disabled:not(:checked)~.cps-switch-slider:before{background-color:var(--cps-color-text-lightest)}:host .cps-switch-container .cps-switch-info-circle{margin-left:8px}:host .cps-switch-container .cps-switch-info-circle ::ng-deep cps-icon i{width:14px;height:14px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: CpsInfoCircleComponent, selector: "cps-info-circle", inputs: ["size", "tooltipText", "tooltipPosition", "tooltipContentClass", "tooltipMaxWidth", "tooltipPersistent"] }] }); }
|
|
12403
|
+
}
|
|
12404
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsSwitchComponent, decorators: [{
|
|
12405
|
+
type: Component,
|
|
12406
|
+
args: [{ standalone: true, imports: [CommonModule, CpsInfoCircleComponent], selector: 'cps-switch', template: "<div class=\"cps-switch-container\">\n <label class=\"cps-switch\">\n <input\n type=\"checkbox\"\n [disabled]=\"disabled\"\n [checked]=\"value\"\n (change)=\"updateValueEvent($event)\" />\n <span class=\"cps-switch-slider\"></span>\n </label>\n <span\n *ngIf=\"label\"\n class=\"cps-switch-label\"\n [ngClass]=\"{ 'cps-switch-label-disabled': disabled }\"\n >{{ label }}</span\n >\n <cps-info-circle\n *ngIf=\"infoTooltip\"\n class=\"cps-switch-info-circle\"\n size=\"xsmall\"\n [tooltipPosition]=\"infoTooltipPosition\"\n [tooltipContentClass]=\"infoTooltipClass\"\n [tooltipMaxWidth]=\"infoTooltipMaxWidth\"\n [tooltipPersistent]=\"infoTooltipPersistent\"\n [tooltipText]=\"infoTooltip\">\n </cps-info-circle>\n</div>\n", styles: [":host{min-width:max-content;display:inline-block}:host .cps-switch-container{line-height:normal;display:flex;align-items:center}:host .cps-switch-container .cps-switch{position:relative;display:inline-block;width:48px;height:24px}:host .cps-switch-container .cps-switch input{opacity:0;width:0;height:0}:host .cps-switch-container .cps-switch-slider{position:absolute;cursor:pointer;inset:0;background-color:#fff;transition:.2s;border:1px solid var(--cps-color-calm);border-radius:30px}:host .cps-switch-container .cps-switch-label{font-size:16px;font-family:Source Sans Pro,sans-serif;font-style:normal;color:var(--cps-color-text-dark);margin-left:10px;cursor:default}:host .cps-switch-container .cps-switch-label-disabled{color:var(--cps-color-text-light)}:host .cps-switch-container .cps-switch-slider:before{position:absolute;content:\"\";height:14px;width:14px;border-radius:20px;left:4px;bottom:4px;background-color:var(--cps-color-calm);transition:.2s}:host .cps-switch-container input:checked+.cps-switch-slider{background-color:var(--cps-color-calm)}:host .cps-switch-container input:focus+.cps-switch-slider{box-shadow:0 0 1px var(--cps-color-calm)}:host .cps-switch-container input:checked+.cps-switch-slider:before{transform:translate(24px);background-color:#fff}:host .cps-switch-container input:disabled~.cps-switch-slider{cursor:default;border-color:var(--cps-color-text-lightest)}:host .cps-switch-container input:disabled:checked~.cps-switch-slider{background-color:var(--cps-color-text-lightest)}:host .cps-switch-container input:disabled:not(:checked)~.cps-switch-slider:before{background-color:var(--cps-color-text-lightest)}:host .cps-switch-container .cps-switch-info-circle{margin-left:8px}:host .cps-switch-container .cps-switch-info-circle ::ng-deep cps-icon i{width:14px;height:14px}\n"] }]
|
|
12407
|
+
}], ctorParameters: () => [{ type: i1.NgControl, decorators: [{
|
|
12408
|
+
type: Self
|
|
12409
|
+
}, {
|
|
12410
|
+
type: Optional
|
|
12411
|
+
}] }, { type: i0.ElementRef }], propDecorators: { label: [{
|
|
12412
|
+
type: Input
|
|
12413
|
+
}], disabled: [{
|
|
12414
|
+
type: Input
|
|
12415
|
+
}], infoTooltip: [{
|
|
12416
|
+
type: Input
|
|
12417
|
+
}], infoTooltipClass: [{
|
|
12418
|
+
type: Input
|
|
12419
|
+
}], infoTooltipMaxWidth: [{
|
|
12420
|
+
type: Input
|
|
12421
|
+
}], infoTooltipPersistent: [{
|
|
12422
|
+
type: Input
|
|
12423
|
+
}], infoTooltipPosition: [{
|
|
12424
|
+
type: Input
|
|
12425
|
+
}], value: [{
|
|
12426
|
+
type: Input
|
|
12427
|
+
}], valueChanged: [{
|
|
12428
|
+
type: Output
|
|
12429
|
+
}] } });
|
|
12430
|
+
|
|
12308
12431
|
class CpsDialogRef {
|
|
12309
12432
|
constructor() {
|
|
12310
12433
|
this._onOpen = new Subject();
|
|
@@ -12912,7 +13035,7 @@ class CpsConfirmationComponent {
|
|
|
12912
13035
|
this._dialogRef = _dialogRef;
|
|
12913
13036
|
this._config = _config;
|
|
12914
13037
|
this.subtitle = '';
|
|
12915
|
-
this.subtitle = this._config.data
|
|
13038
|
+
this.subtitle = this._config.data?.subtitle;
|
|
12916
13039
|
}
|
|
12917
13040
|
close(confirm) {
|
|
12918
13041
|
this._dialogRef?.close(confirm);
|
|
@@ -12931,9 +13054,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
12931
13054
|
*/
|
|
12932
13055
|
class CpsDialogService {
|
|
12933
13056
|
// eslint-disable-next-line no-useless-constructor
|
|
12934
|
-
constructor(
|
|
12935
|
-
this.
|
|
12936
|
-
this.
|
|
13057
|
+
constructor(_appRef, _environmentInjector, document) {
|
|
13058
|
+
this._appRef = _appRef;
|
|
13059
|
+
this._environmentInjector = _environmentInjector;
|
|
12937
13060
|
this.document = document;
|
|
12938
13061
|
this.dialogComponentRefMap = new Map();
|
|
12939
13062
|
}
|
|
@@ -12974,11 +13097,23 @@ class CpsDialogService {
|
|
|
12974
13097
|
instance.childComponentType = CpsConfirmationComponent;
|
|
12975
13098
|
return dialogRef;
|
|
12976
13099
|
}
|
|
13100
|
+
/**
|
|
13101
|
+
* Closes all dialogs.
|
|
13102
|
+
* @param {boolean} [force=false] - If true closes all dialogs even if they have disableClose set to true.
|
|
13103
|
+
* @group Method
|
|
13104
|
+
*/
|
|
13105
|
+
closeAll(force = false) {
|
|
13106
|
+
this.dialogComponentRefMap.forEach((_, key) => {
|
|
13107
|
+
if (force) {
|
|
13108
|
+
key.destroy();
|
|
13109
|
+
}
|
|
13110
|
+
else {
|
|
13111
|
+
key.close();
|
|
13112
|
+
}
|
|
13113
|
+
});
|
|
13114
|
+
}
|
|
12977
13115
|
appendDialogComponentToBody(config) {
|
|
12978
|
-
const map = new WeakMap();
|
|
12979
|
-
map.set(CpsDialogConfig, config);
|
|
12980
13116
|
const dialogRef = new CpsDialogRef();
|
|
12981
|
-
map.set(CpsDialogRef, dialogRef);
|
|
12982
13117
|
const sub = dialogRef.onClose.subscribe(() => {
|
|
12983
13118
|
this.dialogComponentRefMap.get(dialogRef)?.instance.close();
|
|
12984
13119
|
});
|
|
@@ -12987,7 +13122,13 @@ class CpsDialogService {
|
|
|
12987
13122
|
destroySub.unsubscribe();
|
|
12988
13123
|
sub.unsubscribe();
|
|
12989
13124
|
});
|
|
12990
|
-
const componentRef =
|
|
13125
|
+
const componentRef = createComponent(CpsDialogComponent, {
|
|
13126
|
+
environmentInjector: createEnvironmentInjector([
|
|
13127
|
+
{ provide: CpsDialogConfig, useValue: config },
|
|
13128
|
+
{ provide: CpsDialogRef, useValue: dialogRef }
|
|
13129
|
+
], this._environmentInjector)
|
|
13130
|
+
});
|
|
13131
|
+
this._appRef.attachView(componentRef.hostView);
|
|
12991
13132
|
const domElem = componentRef.hostView
|
|
12992
13133
|
.rootNodes[0];
|
|
12993
13134
|
this.document.body.appendChild(domElem);
|
|
@@ -13001,17 +13142,18 @@ class CpsDialogService {
|
|
|
13001
13142
|
}
|
|
13002
13143
|
const dialogComponentRef = this.dialogComponentRefMap.get(dialogRef);
|
|
13003
13144
|
if (dialogComponentRef) {
|
|
13004
|
-
this.
|
|
13145
|
+
this._appRef.detachView(dialogComponentRef.hostView);
|
|
13005
13146
|
dialogComponentRef.destroy();
|
|
13006
13147
|
this.dialogComponentRefMap.delete(dialogRef);
|
|
13007
13148
|
}
|
|
13008
13149
|
}
|
|
13009
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogService, deps: [{ token: i0.
|
|
13010
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogService }); }
|
|
13150
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogService, deps: [{ token: i0.ApplicationRef }, { token: i0.EnvironmentInjector }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
13151
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogService, providedIn: 'root' }); }
|
|
13011
13152
|
}
|
|
13012
13153
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogService, decorators: [{
|
|
13013
|
-
type: Injectable
|
|
13014
|
-
|
|
13154
|
+
type: Injectable,
|
|
13155
|
+
args: [{ providedIn: 'root' }]
|
|
13156
|
+
}], ctorParameters: () => [{ type: i0.ApplicationRef }, { type: i0.EnvironmentInjector }, { type: Document, decorators: [{
|
|
13015
13157
|
type: Inject,
|
|
13016
13158
|
args: [DOCUMENT]
|
|
13017
13159
|
}] }] });
|
|
@@ -13355,5 +13497,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
13355
13497
|
* Generated bundle index. Do not edit.
|
|
13356
13498
|
*/
|
|
13357
13499
|
|
|
13358
|
-
export { CPS_RADIO_GROUP, CpsAutocompleteComponent, CpsButtonComponent, CpsButtonToggleComponent, CpsCheckboxComponent, CpsChipComponent, CpsColumnFilterMatchMode, CpsDatepickerComponent, CpsDialogConfig, CpsDialogRef, CpsDialogService, CpsExpansionPanelComponent, CpsFileUploadComponent, CpsIconComponent, CpsInfoCircleComponent, CpsInputComponent, CpsLoaderComponent, CpsMenuComponent, CpsNotificationAppearance, CpsNotificationPosition, CpsNotificationService, CpsPaginatePipe, CpsPaginatorComponent, CpsProgressCircularComponent, CpsProgressLinearComponent, CpsRadioComponent, CpsRadioGroupComponent, CpsSchedulerComponent, CpsSelectComponent, CpsSidebarMenuComponent, CpsTabComponent, CpsTabGroupComponent, CpsTableColumnFilterDirective, CpsTableColumnSortableDirective, CpsTableComponent, CpsTableHeaderSelectableDirective, CpsTableRowSelectableDirective, CpsTagComponent, CpsTextareaComponent, CpsTimepickerComponent, CpsTooltipDirective, CpsTreeAutocompleteComponent, CpsTreeSelectComponent, CpsTreeTableColumnFilterDirective, CpsTreeTableColumnSortableDirective, CpsTreeTableComponent, CpsTreeTableHeaderSelectableDirective, CpsTreeTableRowSelectableDirective, CpsTreetableRowTogglerDirective, getCSSColor, getCpsColors, getTextColor, iconNames, tableFactory, treeTableFactory };
|
|
13500
|
+
export { CPS_RADIO_GROUP, CpsAutocompleteComponent, CpsButtonComponent, CpsButtonToggleComponent, CpsCheckboxComponent, CpsChipComponent, CpsColumnFilterMatchMode, CpsDatepickerComponent, CpsDialogConfig, CpsDialogRef, CpsDialogService, CpsExpansionPanelComponent, CpsFileUploadComponent, CpsIconComponent, CpsInfoCircleComponent, CpsInputComponent, CpsLoaderComponent, CpsMenuComponent, CpsNotificationAppearance, CpsNotificationPosition, CpsNotificationService, CpsPaginatePipe, CpsPaginatorComponent, CpsProgressCircularComponent, CpsProgressLinearComponent, CpsRadioComponent, CpsRadioGroupComponent, CpsSchedulerComponent, CpsSelectComponent, CpsSidebarMenuComponent, CpsSwitchComponent, CpsTabComponent, CpsTabGroupComponent, CpsTableColumnFilterDirective, CpsTableColumnSortableDirective, CpsTableComponent, CpsTableHeaderSelectableDirective, CpsTableRowSelectableDirective, CpsTagComponent, CpsTextareaComponent, CpsTimepickerComponent, CpsTooltipDirective, CpsTreeAutocompleteComponent, CpsTreeSelectComponent, CpsTreeTableColumnFilterDirective, CpsTreeTableColumnSortableDirective, CpsTreeTableComponent, CpsTreeTableHeaderSelectableDirective, CpsTreeTableRowSelectableDirective, CpsTreetableRowTogglerDirective, getCSSColor, getCpsColors, getTextColor, iconNames, tableFactory, treeTableFactory };
|
|
13359
13501
|
//# sourceMappingURL=cps-ui-kit.mjs.map
|