cps-ui-kit 17.20.0 → 17.22.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/esm2022/lib/components/cps-timepicker/cps-timepicker.component.mjs +7 -13
- package/esm2022/lib/services/cps-dialog/cps-dialog.service.mjs +32 -7
- package/fesm2022/cps-ui-kit.mjs +37 -18
- package/fesm2022/cps-ui-kit.mjs.map +1 -1
- package/lib/components/cps-timepicker/cps-timepicker.component.d.ts +1 -2
- package/lib/services/cps-dialog/cps-dialog.service.d.ts +9 -4
- package/package.json +1 -1
|
@@ -155,7 +155,8 @@ export class CpsTimepickerComponent {
|
|
|
155
155
|
this._checkErrors();
|
|
156
156
|
}
|
|
157
157
|
updateHours(hours) {
|
|
158
|
-
|
|
158
|
+
hours = hours || '';
|
|
159
|
+
const userInput = this.hoursField?.inputText || hours;
|
|
159
160
|
if (userInput) {
|
|
160
161
|
this._initValue();
|
|
161
162
|
const h = parseInt(userInput, 10);
|
|
@@ -169,7 +170,7 @@ export class CpsTimepickerComponent {
|
|
|
169
170
|
if (this.value)
|
|
170
171
|
this.value.hours = hours;
|
|
171
172
|
}
|
|
172
|
-
this.
|
|
173
|
+
this._updateValue(this.value);
|
|
173
174
|
}
|
|
174
175
|
updateMinutes(minutes) {
|
|
175
176
|
minutes = minutes || '';
|
|
@@ -179,7 +180,7 @@ export class CpsTimepickerComponent {
|
|
|
179
180
|
if (this.value)
|
|
180
181
|
this.value.minutes = minutes;
|
|
181
182
|
}
|
|
182
|
-
this.
|
|
183
|
+
this._updateValue(this.value);
|
|
183
184
|
}
|
|
184
185
|
updateSeconds(seconds) {
|
|
185
186
|
seconds = seconds || '';
|
|
@@ -189,7 +190,7 @@ export class CpsTimepickerComponent {
|
|
|
189
190
|
if (this.value)
|
|
190
191
|
this.value.seconds = seconds;
|
|
191
192
|
}
|
|
192
|
-
this.
|
|
193
|
+
this._updateValue(this.value);
|
|
193
194
|
}
|
|
194
195
|
updateDayPeriod(dayPeriod) {
|
|
195
196
|
if (dayPeriod)
|
|
@@ -198,7 +199,7 @@ export class CpsTimepickerComponent {
|
|
|
198
199
|
if (this.value)
|
|
199
200
|
this.value.dayPeriod = dayPeriod;
|
|
200
201
|
}
|
|
201
|
-
this.
|
|
202
|
+
this._updateValue(this.value);
|
|
202
203
|
}
|
|
203
204
|
numberOnly(event) {
|
|
204
205
|
const charCode = event.which ? event.which : event.keyCode;
|
|
@@ -289,13 +290,6 @@ export class CpsTimepickerComponent {
|
|
|
289
290
|
this.onChange(value);
|
|
290
291
|
this.valueChanged.emit(value);
|
|
291
292
|
}
|
|
292
|
-
_tryUpdateValue() {
|
|
293
|
-
if (this.value?.hours &&
|
|
294
|
-
this.value?.minutes &&
|
|
295
|
-
(!this.withSeconds || (this.withSeconds && this.value?.seconds)) &&
|
|
296
|
-
(this.use24HourTime || (!this.use24HourTime && this.value?.dayPeriod)))
|
|
297
|
-
this._updateValue(this.value);
|
|
298
|
-
}
|
|
299
293
|
_getRange(startFrom, until) {
|
|
300
294
|
return Array.from({ length: until + 1 - startFrom }, (_, k) => k + startFrom);
|
|
301
295
|
}
|
|
@@ -353,4 +347,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
353
347
|
type: ViewChild,
|
|
354
348
|
args: ['secondsField']
|
|
355
349
|
}] } });
|
|
356
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-timepicker.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-timepicker/cps-timepicker.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-timepicker/cps-timepicker.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,QAAQ,EACR,MAAM,EACN,IAAI,EACJ,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAa,MAAM,gBAAgB,CAAC;AAExD,OAAO,EACL,wBAAwB,EAEzB,MAAM,kDAAkD,CAAC;AAC1D,OAAO,EAAE,wBAAwB,EAAE,MAAM,gDAAgD,CAAC;AAE1F,OAAO,EAAE,sBAAsB,EAAE,MAAM,8CAA8C,CAAC;;;;AAatF;;;GAGG;AAcH,MAAM,OAAO,sBAAsB;IA2EjC;;;OAGG;IACH,IAAa,KAAK,CAAC,KAA0B;QAC3C,IAAI,CAAC,KAAK;YAAE,KAAK,GAAG,SAAS,CAAC;QAC9B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAyCD,YAAwC,QAAmB;QAAnB,aAAQ,GAAR,QAAQ,CAAW;QA7H3D;;;WAGG;QACM,UAAK,GAAG,EAAE,CAAC;QAEpB;;;WAGG;QACM,aAAQ,GAAG,KAAK,CAAC;QAE1B;;;WAGG;QACM,kBAAa,GAAG,KAAK,CAAC;QAE/B;;;WAGG;QACM,gBAAW,GAAG,KAAK,CAAC;QAE7B;;;WAGG;QACM,SAAI,GAAG,EAAE,CAAC;QAEnB;;;WAGG;QACM,gBAAW,GAAG,KAAK,CAAC;QAE7B;;;WAGG;QACM,gBAAW,GAAG,EAAE,CAAC;QAE1B;;;WAGG;QACM,qBAAgB,GAAG,qBAAqB,CAAC;QAElD;;;WAGG;QACM,wBAAmB,GAAoB,MAAM,CAAC;QAEvD;;;WAGG;QACM,0BAAqB,GAAG,KAAK,CAAC;QAEvC;;;WAGG;QACM,wBAAmB,GAAuB,KAAK,CAAC;QAEzD;;;WAGG;QACM,mBAAc,GAAG,KAAK,CAAC;QAgBhC;;;;WAIG;QACO,iBAAY,GAAG,IAAI,YAAY,EAAW,CAAC;QAWrD,qBAAgB,GAA4B;YAC1C,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE;YAC5B,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE;SAC7B,CAAC;QAEF,iBAAY,GAAuC,EAAE,CAAC;QAEtD,mBAAc,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YACjD,KAAK,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC;YACpC,KAAK,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC;SACrC,CAAC,CAAC,CAAC;QAEJ,mBAAc,GAAuC,EAAE,CAAC;QAIxD,UAAK,GAAG,EAAE,CAAC;QACX,eAAU,GAAG,EAAE,CAAC;QAChB,iBAAY,GAAG,EAAE,CAAC;QAClB,iBAAY,GAAG,EAAE,CAAC;QAEV,WAAM,GAAwB,SAAS,CAAC;QAmChD,gEAAgE;QAChE,aAAQ,GAAG,CAAC,KAAU,EAAE,EAAE,GAAE,CAAC,CAAC;QAC9B,gEAAgE;QAChE,cAAS,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;QAnCnB,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,IAAI,CAAC,QAAQ,CAAC,aAAa,GAAG,IAAI,CAAC;QACrC,CAAC;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAEzB,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBACtD,KAAK,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC;gBACpC,KAAK,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC;aACrC,CAAC,CAAC,CAAC;QACN,CAAC;QAED,IAAI,CAAC,0BAA0B,GAAG,IAAI,CAAC,QAAQ,EAAE,aAAa,EAAE,SAAS,CACvE,GAAG,EAAE;YACH,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC,CACF,CAAC;IACJ,CAAC;IAED,eAAe;QACb,IAAI,IAAI,CAAC,UAAU;YAAE,IAAI,CAAC,UAAU,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9D,IAAI,IAAI,CAAC,YAAY;YAAE,IAAI,CAAC,YAAY,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAClE,IAAI,IAAI,CAAC,YAAY;YAAE,IAAI,CAAC,YAAY,CAAC,iBAAiB,GAAG,IAAI,CAAC;IACpE,CAAC;IAED,WAAW;QACT,IAAI,CAAC,0BAA0B,EAAE,WAAW,EAAE,CAAC;IACjD,CAAC;IAOD,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,gEAAgE;IAChE,gBAAgB,CAAC,QAAiB,IAAG,CAAC;IAEtC,UAAU,CAAC,KAAc;QACvB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAED,WAAW;QACT,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,aAAa,EAAE,CAAC;QACxC,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,WAAW,CAAC,KAAa;QACvB,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,EAAE,SAAS,IAAI,KAAK,IAAI,EAAE,CAAC;QAC5D,IAAI,SAAS,EAAE,CAAC;YACd,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,MAAM,CAAC,GAAG,QAAQ,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;YAClC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;gBAC5B,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;oBAC9C,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,IAAI,CAAC;gBAC9B,CAAC;YACH,CAAC;QACH,CAAC;QAED,IAAI,IAAI,CAAC,KAAK,EAAE,KAAK,KAAK,KAAK,EAAE,CAAC;YAChC,IAAI,IAAI,CAAC,KAAK;gBAAE,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;QAC3C,CAAC;QACD,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAED,aAAa,CAAC,OAAe;QAC3B,OAAO,GAAG,OAAO,IAAI,EAAE,CAAC;QACxB,IAAI,OAAO;YAAE,IAAI,CAAC,UAAU,EAAE,CAAC;QAC/B,IAAI,IAAI,CAAC,KAAK,EAAE,OAAO,KAAK,OAAO,EAAE,CAAC;YACpC,IAAI,IAAI,CAAC,KAAK;gBAAE,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;QAC/C,CAAC;QACD,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAED,aAAa,CAAC,OAAe;QAC3B,OAAO,GAAG,OAAO,IAAI,EAAE,CAAC;QACxB,IAAI,OAAO;YAAE,IAAI,CAAC,UAAU,EAAE,CAAC;QAC/B,IAAI,IAAI,CAAC,KAAK,EAAE,OAAO,KAAK,OAAO,EAAE,CAAC;YACpC,IAAI,IAAI,CAAC,KAAK;gBAAE,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;QAC/C,CAAC;QACD,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAED,eAAe,CAAC,SAAsB;QACpC,IAAI,SAAS;YAAE,IAAI,CAAC,UAAU,EAAE,CAAC;QACjC,IAAI,IAAI,CAAC,KAAK,EAAE,SAAS,KAAK,SAAS,EAAE,CAAC;YACxC,IAAI,IAAI,CAAC,KAAK;gBAAE,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,SAAS,CAAC;QACnD,CAAC;QACD,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAED,UAAU,CAAC,KAAU;QACnB,MAAM,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC;QAC3D,IAAI,QAAQ,GAAG,EAAE,IAAI,CAAC,QAAQ,GAAG,EAAE,IAAI,QAAQ,GAAG,EAAE,CAAC,EAAE,CAAC;YACtD,OAAO,KAAK,CAAC;QACf,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,UAAU;QAChB,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YAChB,IAAI,CAAC,KAAK,GAAG;gBACX,KAAK,EAAE,EAAE;gBACT,OAAO,EAAE,EAAE;aACZ,CAAC;QACJ,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,CAAC,WAAW,IAAI,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;YACxD,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,IAAI,CAAC;QAC9B,CAAC;QACD,IAAI,IAAI,CAAC,WAAW,IAAI,CAAC,CAAC,SAAS,IAAI,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;YACnD,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,EAAE,CAAC;QAC1B,CAAC;IACH,CAAC;IAEO,aAAa;QACnB,IAAI,CAAC,IAAI,CAAC,KAAK;YAAE,OAAO,KAAK,CAAC;QAC9B,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO;YAAE,OAAO,KAAK,CAAC;QAC3D,IAAI,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO;YAAE,OAAO,KAAK,CAAC;QAC1D,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS;YAAE,OAAO,KAAK,CAAC;QAC/D,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,aAAa;QACnB,IAAI,CAAC,KAAK,GAAG,iBAAiB,CAAC;QAC/B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC;QACtD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC;QAC1D,IAAI,IAAI,CAAC,WAAW;YAClB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC;IAC9D,CAAC;IAEO,UAAU,CAAC,KAAa;QAC9B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;IACpD,CAAC;IAEO,YAAY;QAClB,IAAI,CAAC,IAAI,CAAC,QAAQ;YAAE,OAAO;QAE3B,IAAI,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,EAAE,CAAC;YACxC,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,OAAO;QACT,CAAC;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,EAAE,MAAM,CAAC;QAErC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC;YAChD,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;YACpB,OAAO;QACT,CAAC;QAED,IAAI,UAAU,IAAI,MAAM,EAAE,CAAC;YACzB,IAAI,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC;YACrC,OAAO;QACT,CAAC;QAED,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QACrC,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACtB,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;YACpB,OAAO;QACT,CAAC;QACD,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAC;QAE9D,IAAI,CAAC,UAAU,CAAC,OAAO,IAAI,eAAe,CAAC,CAAC;IAC9C,CAAC;IAEO,iBAAiB;QACvB,MAAM,YAAY,GAAG,CAAC,CAAS,EAAE,EAAE;YACjC,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;YAC1B,OAAO,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QACvC,CAAC,CAAC;QAEF,IAAI,CAAC,YAAY,GAAG,CAClB,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,CACnE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;YACV,MAAM,GAAG,GAAqD;gBAC5D,KAAK,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC;gBACpC,KAAK,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC;aACrC,CAAC;YACF,IAAI,CAAC,IAAI,CAAC,aAAa;gBAAE,GAAG,CAAC,KAAK,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;YACrD,OAAO,GAAG,CAAC;QACb,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,YAAY,CAAC,KAAc;QACjC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACvB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACrB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAEO,eAAe;QACrB,IACE,IAAI,CAAC,KAAK,EAAE,KAAK;YACjB,IAAI,CAAC,KAAK,EAAE,OAAO;YACnB,CAAC,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;YAChE,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,CAAC,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;YAEtE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClC,CAAC;IAEO,SAAS,CAAC,SAAiB,EAAE,KAAa;QAChD,OAAO,KAAK,CAAC,IAAI,CACf,EAAE,MAAM,EAAE,KAAK,GAAG,CAAC,GAAG,SAAS,EAAE,EACjC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,SAAS,CACxB,CAAC;IACJ,CAAC;8GAzVU,sBAAsB;kGAAtB,sBAAsB,izBCnDnC,o/FAuFA,+hCD7CI,YAAY,gOACZ,WAAW,+BACX,wBAAwB,uTACxB,wBAAwB,6tBACxB,sBAAsB;;2FAKb,sBAAsB;kBAblC,SAAS;+BACE,gBAAgB,cACd,IAAI,WACP;wBACP,YAAY;wBACZ,WAAW;wBACX,wBAAwB;wBACxB,wBAAwB;wBACxB,sBAAsB;qBACvB;;0BAoIY,IAAI;;0BAAI,QAAQ;yCAzHpB,KAAK;sBAAb,KAAK;gBAMG,QAAQ;sBAAhB,KAAK;gBAMG,aAAa;sBAArB,KAAK;gBAMG,WAAW;sBAAnB,KAAK;gBAMG,IAAI;sBAAZ,KAAK;gBAMG,WAAW;sBAAnB,KAAK;gBAMG,WAAW;sBAAnB,KAAK;gBAMG,gBAAgB;sBAAxB,KAAK;gBAMG,mBAAmB;sBAA3B,KAAK;gBAMG,qBAAqB;sBAA7B,KAAK;gBAMG,mBAAmB;sBAA3B,KAAK;gBAMG,cAAc;sBAAtB,KAAK;gBAMO,KAAK;sBAAjB,KAAK;gBAeI,YAAY;sBAArB,MAAM;gBAGP,UAAU;sBADT,SAAS;uBAAC,YAAY;gBAIvB,YAAY;sBADX,SAAS;uBAAC,cAAc;gBAIzB,YAAY;sBADX,SAAS;uBAAC,cAAc","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  ViewChild\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule, NgControl } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport {\n  CpsButtonToggleComponent,\n  CpsButtonToggleOption\n} from '../cps-button-toggle/cps-button-toggle.component';\nimport { CpsAutocompleteComponent } from '../cps-autocomplete/cps-autocomplete.component';\nimport { CpsTooltipPosition } from '../../directives/cps-tooltip/cps-tooltip.directive';\nimport { CpsInfoCircleComponent } from '../cps-info-circle/cps-info-circle.component';\n\n/**\n * CpsTime is used to define the time format.\n * @group Interface\n */\nexport interface CpsTime {\n  hours: string;\n  minutes: string;\n  seconds?: string;\n  dayPeriod?: 'AM' | 'PM';\n}\n\n/**\n * CpsTimepickerComponent allows to pick a specific time from a set of available options or input it manually.\n * @group Components\n */\n@Component({\n  selector: 'cps-timepicker',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    CpsButtonToggleComponent,\n    CpsAutocompleteComponent,\n    CpsInfoCircleComponent\n  ],\n  templateUrl: './cps-timepicker.component.html',\n  styleUrls: ['./cps-timepicker.component.scss']\n})\nexport class CpsTimepickerComponent\n  implements OnInit, AfterViewInit, OnDestroy\n{\n  /**\n   * Label of the timepicker.\n   * @group Props\n   */\n  @Input() label = '';\n\n  /**\n   * Determines whether the timepicker is disabled.\n   * @group Props\n   */\n  @Input() disabled = false;\n\n  /**\n   * Determines whether the timepicker uses 24-hour format.\n   * @group Props\n   */\n  @Input() use24HourTime = false;\n\n  /**\n   * Determines whether the timepicker has seconds.\n   * @group Props\n   */\n  @Input() withSeconds = false;\n\n  /**\n   * Bottom hint text for the timepicker.\n   * @group Props\n   */\n  @Input() hint = '';\n\n  /**\n   * Hides hint and validation errors.\n   * @group Props\n   */\n  @Input() hideDetails = 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   * Max width 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   * Determines whether the timepicker input fields can be cleared.\n   * @group Props\n   */\n  @Input() mandatoryValue = false;\n\n  /**\n   * Value of the timepicker.\n   * @group Props\n   */\n  @Input() set value(value: CpsTime | undefined) {\n    if (!value) value = undefined;\n    this._value = value;\n    this.onChange(value);\n  }\n\n  get value(): CpsTime | undefined {\n    return this._value;\n  }\n\n  /**\n   * Callback to invoke on value change.\n   * @param {string} string - value changed.\n   * @group Emits\n   */\n  @Output() valueChanged = new EventEmitter<CpsTime>();\n\n  @ViewChild('hoursField')\n  hoursField!: CpsAutocompleteComponent;\n\n  @ViewChild('minutesField')\n  minutesField!: CpsAutocompleteComponent;\n\n  @ViewChild('secondsField')\n  secondsField?: CpsAutocompleteComponent;\n\n  dayPeriodOptions: CpsButtonToggleOption[] = [\n    { label: 'AM', value: 'AM' },\n    { label: 'PM', value: 'PM' }\n  ];\n\n  hoursOptions: { label: string; value: string }[] = [];\n\n  minutesOptions = this._getRange(0, 59).map((m) => ({\n    value: m.toString().padStart(2, '0'),\n    label: m.toString().padStart(2, '0')\n  }));\n\n  secondsOptions: { label: string; value: string }[] = [];\n\n  private _statusChangesSubscription?: Subscription;\n\n  error = '';\n  hoursError = '';\n  minutesError = '';\n  secondsError = '';\n\n  private _value: CpsTime | undefined = undefined;\n\n  constructor(@Self() @Optional() private _control: NgControl) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  ngOnInit(): void {\n    this._initHoursOptions();\n\n    if (this.withSeconds) {\n      this.secondsOptions = this._getRange(0, 59).map((m) => ({\n        value: m.toString().padStart(2, '0'),\n        label: m.toString().padStart(2, '0')\n      }));\n    }\n\n    this._statusChangesSubscription = this._control?.statusChanges?.subscribe(\n      () => {\n        this._checkErrors();\n      }\n    );\n  }\n\n  ngAfterViewInit(): void {\n    if (this.hoursField) this.hoursField.isTimePickerField = true;\n    if (this.minutesField) this.minutesField.isTimePickerField = true;\n    if (this.secondsField) this.secondsField.isTimePickerField = true;\n  }\n\n  ngOnDestroy() {\n    this._statusChangesSubscription?.unsubscribe();\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\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  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  setDisabledState(disabled: boolean) {}\n\n  writeValue(value: CpsTime) {\n    this.value = value;\n  }\n\n  onFieldBlur() {\n    this._control?.control?.markAsTouched();\n    this._checkErrors();\n  }\n\n  updateHours(hours: string) {\n    const userInput = this.hoursField?.inputText || hours || '';\n    if (userInput) {\n      this._initValue();\n      const h = parseInt(userInput, 10);\n      if (!isNaN(h) && this.value) {\n        if (h >= 13 && h <= 23 && !this.use24HourTime) {\n          this.value.dayPeriod = 'PM';\n        }\n      }\n    }\n\n    if (this.value?.hours !== hours) {\n      if (this.value) this.value.hours = hours;\n    }\n    this._tryUpdateValue();\n  }\n\n  updateMinutes(minutes: string) {\n    minutes = minutes || '';\n    if (minutes) this._initValue();\n    if (this.value?.minutes !== minutes) {\n      if (this.value) this.value.minutes = minutes;\n    }\n    this._tryUpdateValue();\n  }\n\n  updateSeconds(seconds: string) {\n    seconds = seconds || '';\n    if (seconds) this._initValue();\n    if (this.value?.seconds !== seconds) {\n      if (this.value) this.value.seconds = seconds;\n    }\n    this._tryUpdateValue();\n  }\n\n  updateDayPeriod(dayPeriod: 'AM' | 'PM') {\n    if (dayPeriod) this._initValue();\n    if (this.value?.dayPeriod !== dayPeriod) {\n      if (this.value) this.value.dayPeriod = dayPeriod;\n    }\n    this._tryUpdateValue();\n  }\n\n  numberOnly(event: any): boolean {\n    const charCode = event.which ? event.which : event.keyCode;\n    if (charCode > 31 && (charCode < 48 || charCode > 57)) {\n      return false;\n    }\n    return true;\n  }\n\n  private _initValue() {\n    if (!this.value) {\n      this.value = {\n        hours: '',\n        minutes: ''\n      };\n    }\n    if (!this.use24HourTime && !('dayPeriod' in this.value)) {\n      this.value.dayPeriod = 'AM';\n    }\n    if (this.withSeconds && !('seconds' in this.value)) {\n      this.value.seconds = '';\n    }\n  }\n\n  private _isValueValid() {\n    if (!this.value) return false;\n    if (!this.value.hours || !this.value.minutes) return false;\n    if (this.withSeconds && !this.value.seconds) return false;\n    if (!this.use24HourTime && !this.value.dayPeriod) return false;\n    return true;\n  }\n\n  private _updateErrors() {\n    this.error = 'Time is invalid';\n    this.hoursError = this.value?.hours ? '' : this.error;\n    this.minutesError = this.value?.minutes ? '' : this.error;\n    if (this.withSeconds)\n      this.secondsError = this.value?.seconds ? '' : this.error;\n  }\n\n  private _setErrors(error: string) {\n    this.error = error;\n    this.hoursError = error;\n    this.minutesError = error;\n    this.secondsError = this.withSeconds ? error : '';\n  }\n\n  private _checkErrors() {\n    if (!this._control) return;\n\n    if (this.value && !this._isValueValid()) {\n      this._updateErrors();\n      return;\n    }\n\n    const errors = this._control?.errors;\n\n    if (!this._control?.control?.touched || !errors) {\n      this._setErrors('');\n      return;\n    }\n\n    if ('required' in errors) {\n      this._setErrors('Field is required');\n      return;\n    }\n\n    const errArr = Object.values(errors);\n    if (errArr.length < 1) {\n      this._setErrors('');\n      return;\n    }\n    const message = errArr.find((msg) => typeof msg === 'string');\n\n    this._setErrors(message || 'Unknown error');\n  }\n\n  private _initHoursOptions() {\n    const getHourAlias = (h: number) => {\n      h = h === 12 ? 0 : h + 12;\n      return h.toString().padStart(2, '0');\n    };\n\n    this.hoursOptions = (\n      this.use24HourTime ? this._getRange(0, 23) : this._getRange(1, 12)\n    ).map((h) => {\n      const res: { value: string; label: string; alias?: string } = {\n        value: h.toString().padStart(2, '0'),\n        label: h.toString().padStart(2, '0')\n      };\n      if (!this.use24HourTime) res.alias = getHourAlias(h);\n      return res;\n    });\n  }\n\n  private _updateValue(value: CpsTime) {\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  private _tryUpdateValue() {\n    if (\n      this.value?.hours &&\n      this.value?.minutes &&\n      (!this.withSeconds || (this.withSeconds && this.value?.seconds)) &&\n      (this.use24HourTime || (!this.use24HourTime && this.value?.dayPeriod))\n    )\n      this._updateValue(this.value);\n  }\n\n  private _getRange(startFrom: number, until: number) {\n    return Array.from(\n      { length: until + 1 - startFrom },\n      (_, k) => k + startFrom\n    );\n  }\n}\n","<div class=\"cps-timepicker\">\n  <div\n    class=\"cps-timepicker-label\"\n    [ngClass]=\"{ 'cps-timepicker-label-disabled': disabled }\"\n    *ngIf=\"label\">\n    <label>{{ label }}</label>\n    <cps-info-circle\n      *ngIf=\"infoTooltip\"\n      class=\"cps-timepicker-label-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  <div class=\"cps-timepicker-body\">\n    <cps-autocomplete\n      #hoursField\n      (keypress)=\"numberOnly($event)\"\n      width=\"60\"\n      [emptyOptionIndex]=\"mandatoryValue ? 0 : -1\"\n      [options]=\"hoursOptions\"\n      [withOptionsAliases]=\"!use24HourTime\"\n      [useOptionsAliasesWhenNoMatch]=\"true\"\n      [hideDetails]=\"true\"\n      [disabled]=\"disabled\"\n      [showChevron]=\"false\"\n      [showEmptyMessage]=\"false\"\n      (blurred)=\"onFieldBlur()\"\n      [returnObject]=\"false\"\n      [value]=\"value?.hours\"\n      (valueChanged)=\"updateHours($event)\"\n      [externalError]=\"hoursError\"\n      placeholder=\"HH\"></cps-autocomplete>\n    <span class=\"cps-timepicker-delimiter\">:</span>\n    <cps-autocomplete\n      #minutesField\n      (keypress)=\"numberOnly($event)\"\n      width=\"60\"\n      [emptyOptionIndex]=\"mandatoryValue ? 0 : -1\"\n      [options]=\"minutesOptions\"\n      [hideDetails]=\"true\"\n      [disabled]=\"disabled\"\n      [showChevron]=\"false\"\n      [showEmptyMessage]=\"false\"\n      (blurred)=\"onFieldBlur()\"\n      [returnObject]=\"false\"\n      [value]=\"value?.minutes\"\n      (valueChanged)=\"updateMinutes($event)\"\n      [externalError]=\"minutesError\"\n      placeholder=\"MM\"></cps-autocomplete>\n    <span *ngIf=\"withSeconds\" class=\"cps-timepicker-delimiter\">:</span>\n    <cps-autocomplete\n      *ngIf=\"withSeconds\"\n      #secondsField\n      (keypress)=\"numberOnly($event)\"\n      width=\"60\"\n      [emptyOptionIndex]=\"mandatoryValue ? 0 : -1\"\n      [options]=\"secondsOptions\"\n      [hideDetails]=\"true\"\n      [disabled]=\"disabled\"\n      [showChevron]=\"false\"\n      [showEmptyMessage]=\"false\"\n      (blurred)=\"onFieldBlur()\"\n      [returnObject]=\"false\"\n      [value]=\"value?.seconds\"\n      (valueChanged)=\"updateSeconds($event)\"\n      [externalError]=\"secondsError\"\n      placeholder=\"SS\"></cps-autocomplete>\n    <cps-button-toggle\n      *ngIf=\"!use24HourTime\"\n      class=\"cps-timepicker-am-pm-selector\"\n      [options]=\"dayPeriodOptions\"\n      [disabled]=\"disabled\"\n      [value]=\"value?.dayPeriod || 'AM'\"\n      (valueChanged)=\"updateDayPeriod($event)\">\n    </cps-button-toggle>\n  </div>\n  <div *ngIf=\"!error && !hideDetails\" class=\"cps-timepicker-hint\">\n    {{ hint }}\n  </div>\n  <div *ngIf=\"error && !hideDetails\" class=\"cps-timepicker-error\">\n    {{ error }}\n  </div>\n</div>\n"]}
|
|
350
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-timepicker.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-timepicker/cps-timepicker.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-timepicker/cps-timepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  ViewChild\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule, NgControl } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport {\n  CpsButtonToggleComponent,\n  CpsButtonToggleOption\n} from '../cps-button-toggle/cps-button-toggle.component';\nimport { CpsAutocompleteComponent } from '../cps-autocomplete/cps-autocomplete.component';\nimport { CpsTooltipPosition } from '../../directives/cps-tooltip/cps-tooltip.directive';\nimport { CpsInfoCircleComponent } from '../cps-info-circle/cps-info-circle.component';\n\n/**\n * CpsTime is used to define the time format.\n * @group Interface\n */\nexport interface CpsTime {\n  hours: string;\n  minutes: string;\n  seconds?: string;\n  dayPeriod?: 'AM' | 'PM';\n}\n\n/**\n * CpsTimepickerComponent allows to pick a specific time from a set of available options or input it manually.\n * @group Components\n */\n@Component({\n  selector: 'cps-timepicker',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    CpsButtonToggleComponent,\n    CpsAutocompleteComponent,\n    CpsInfoCircleComponent\n  ],\n  templateUrl: './cps-timepicker.component.html',\n  styleUrls: ['./cps-timepicker.component.scss']\n})\nexport class CpsTimepickerComponent\n  implements OnInit, AfterViewInit, OnDestroy\n{\n  /**\n   * Label of the timepicker.\n   * @group Props\n   */\n  @Input() label = '';\n\n  /**\n   * Determines whether the timepicker is disabled.\n   * @group Props\n   */\n  @Input() disabled = false;\n\n  /**\n   * Determines whether the timepicker uses 24-hour format.\n   * @group Props\n   */\n  @Input() use24HourTime = false;\n\n  /**\n   * Determines whether the timepicker has seconds.\n   * @group Props\n   */\n  @Input() withSeconds = false;\n\n  /**\n   * Bottom hint text for the timepicker.\n   * @group Props\n   */\n  @Input() hint = '';\n\n  /**\n   * Hides hint and validation errors.\n   * @group Props\n   */\n  @Input() hideDetails = 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   * Max width 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   * Determines whether the timepicker input fields can be cleared.\n   * @group Props\n   */\n  @Input() mandatoryValue = false;\n\n  /**\n   * Value of the timepicker.\n   * @group Props\n   */\n  @Input() set value(value: CpsTime | undefined) {\n    if (!value) value = undefined;\n    this._value = value;\n    this.onChange(value);\n  }\n\n  get value(): CpsTime | undefined {\n    return this._value;\n  }\n\n  /**\n   * Callback to invoke on value change.\n   * @param {string} string - value changed.\n   * @group Emits\n   */\n  @Output() valueChanged = new EventEmitter<CpsTime>();\n\n  @ViewChild('hoursField')\n  hoursField!: CpsAutocompleteComponent;\n\n  @ViewChild('minutesField')\n  minutesField!: CpsAutocompleteComponent;\n\n  @ViewChild('secondsField')\n  secondsField?: CpsAutocompleteComponent;\n\n  dayPeriodOptions: CpsButtonToggleOption[] = [\n    { label: 'AM', value: 'AM' },\n    { label: 'PM', value: 'PM' }\n  ];\n\n  hoursOptions: { label: string; value: string }[] = [];\n\n  minutesOptions = this._getRange(0, 59).map((m) => ({\n    value: m.toString().padStart(2, '0'),\n    label: m.toString().padStart(2, '0')\n  }));\n\n  secondsOptions: { label: string; value: string }[] = [];\n\n  private _statusChangesSubscription?: Subscription;\n\n  error = '';\n  hoursError = '';\n  minutesError = '';\n  secondsError = '';\n\n  private _value: CpsTime | undefined = undefined;\n\n  constructor(@Self() @Optional() private _control: NgControl) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  ngOnInit(): void {\n    this._initHoursOptions();\n\n    if (this.withSeconds) {\n      this.secondsOptions = this._getRange(0, 59).map((m) => ({\n        value: m.toString().padStart(2, '0'),\n        label: m.toString().padStart(2, '0')\n      }));\n    }\n\n    this._statusChangesSubscription = this._control?.statusChanges?.subscribe(\n      () => {\n        this._checkErrors();\n      }\n    );\n  }\n\n  ngAfterViewInit(): void {\n    if (this.hoursField) this.hoursField.isTimePickerField = true;\n    if (this.minutesField) this.minutesField.isTimePickerField = true;\n    if (this.secondsField) this.secondsField.isTimePickerField = true;\n  }\n\n  ngOnDestroy() {\n    this._statusChangesSubscription?.unsubscribe();\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\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  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  setDisabledState(disabled: boolean) {}\n\n  writeValue(value: CpsTime | undefined) {\n    this.value = value;\n  }\n\n  onFieldBlur() {\n    this._control?.control?.markAsTouched();\n    this._checkErrors();\n  }\n\n  updateHours(hours: string) {\n    hours = hours || '';\n    const userInput = this.hoursField?.inputText || hours;\n    if (userInput) {\n      this._initValue();\n      const h = parseInt(userInput, 10);\n      if (!isNaN(h) && this.value) {\n        if (h >= 13 && h <= 23 && !this.use24HourTime) {\n          this.value.dayPeriod = 'PM';\n        }\n      }\n    }\n\n    if (this.value?.hours !== hours) {\n      if (this.value) this.value.hours = hours;\n    }\n    this._updateValue(this.value);\n  }\n\n  updateMinutes(minutes: string) {\n    minutes = minutes || '';\n    if (minutes) this._initValue();\n    if (this.value?.minutes !== minutes) {\n      if (this.value) this.value.minutes = minutes;\n    }\n    this._updateValue(this.value);\n  }\n\n  updateSeconds(seconds: string) {\n    seconds = seconds || '';\n    if (seconds) this._initValue();\n    if (this.value?.seconds !== seconds) {\n      if (this.value) this.value.seconds = seconds;\n    }\n    this._updateValue(this.value);\n  }\n\n  updateDayPeriod(dayPeriod: 'AM' | 'PM') {\n    if (dayPeriod) this._initValue();\n    if (this.value?.dayPeriod !== dayPeriod) {\n      if (this.value) this.value.dayPeriod = dayPeriod;\n    }\n    this._updateValue(this.value);\n  }\n\n  numberOnly(event: any): boolean {\n    const charCode = event.which ? event.which : event.keyCode;\n    if (charCode > 31 && (charCode < 48 || charCode > 57)) {\n      return false;\n    }\n    return true;\n  }\n\n  private _initValue() {\n    if (!this.value) {\n      this.value = {\n        hours: '',\n        minutes: ''\n      };\n    }\n    if (!this.use24HourTime && !('dayPeriod' in this.value)) {\n      this.value.dayPeriod = 'AM';\n    }\n    if (this.withSeconds && !('seconds' in this.value)) {\n      this.value.seconds = '';\n    }\n  }\n\n  private _isValueValid() {\n    if (!this.value) return false;\n    if (!this.value.hours || !this.value.minutes) return false;\n    if (this.withSeconds && !this.value.seconds) return false;\n    if (!this.use24HourTime && !this.value.dayPeriod) return false;\n    return true;\n  }\n\n  private _updateErrors() {\n    this.error = 'Time is invalid';\n    this.hoursError = this.value?.hours ? '' : this.error;\n    this.minutesError = this.value?.minutes ? '' : this.error;\n    if (this.withSeconds)\n      this.secondsError = this.value?.seconds ? '' : this.error;\n  }\n\n  private _setErrors(error: string) {\n    this.error = error;\n    this.hoursError = error;\n    this.minutesError = error;\n    this.secondsError = this.withSeconds ? error : '';\n  }\n\n  private _checkErrors() {\n    if (!this._control) return;\n\n    if (this.value && !this._isValueValid()) {\n      this._updateErrors();\n      return;\n    }\n\n    const errors = this._control?.errors;\n\n    if (!this._control?.control?.touched || !errors) {\n      this._setErrors('');\n      return;\n    }\n\n    if ('required' in errors) {\n      this._setErrors('Field is required');\n      return;\n    }\n\n    const errArr = Object.values(errors);\n    if (errArr.length < 1) {\n      this._setErrors('');\n      return;\n    }\n    const message = errArr.find((msg) => typeof msg === 'string');\n\n    this._setErrors(message || 'Unknown error');\n  }\n\n  private _initHoursOptions() {\n    const getHourAlias = (h: number) => {\n      h = h === 12 ? 0 : h + 12;\n      return h.toString().padStart(2, '0');\n    };\n\n    this.hoursOptions = (\n      this.use24HourTime ? this._getRange(0, 23) : this._getRange(1, 12)\n    ).map((h) => {\n      const res: { value: string; label: string; alias?: string } = {\n        value: h.toString().padStart(2, '0'),\n        label: h.toString().padStart(2, '0')\n      };\n      if (!this.use24HourTime) res.alias = getHourAlias(h);\n      return res;\n    });\n  }\n\n  private _updateValue(value: CpsTime | undefined) {\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  private _getRange(startFrom: number, until: number) {\n    return Array.from(\n      { length: until + 1 - startFrom },\n      (_, k) => k + startFrom\n    );\n  }\n}\n","<div class=\"cps-timepicker\">\n  <div\n    class=\"cps-timepicker-label\"\n    [ngClass]=\"{ 'cps-timepicker-label-disabled': disabled }\"\n    *ngIf=\"label\">\n    <label>{{ label }}</label>\n    <cps-info-circle\n      *ngIf=\"infoTooltip\"\n      class=\"cps-timepicker-label-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  <div class=\"cps-timepicker-body\">\n    <cps-autocomplete\n      #hoursField\n      (keypress)=\"numberOnly($event)\"\n      width=\"60\"\n      [emptyOptionIndex]=\"mandatoryValue ? 0 : -1\"\n      [options]=\"hoursOptions\"\n      [withOptionsAliases]=\"!use24HourTime\"\n      [useOptionsAliasesWhenNoMatch]=\"true\"\n      [hideDetails]=\"true\"\n      [disabled]=\"disabled\"\n      [showChevron]=\"false\"\n      [showEmptyMessage]=\"false\"\n      (blurred)=\"onFieldBlur()\"\n      [returnObject]=\"false\"\n      [value]=\"value?.hours\"\n      (valueChanged)=\"updateHours($event)\"\n      [externalError]=\"hoursError\"\n      placeholder=\"HH\"></cps-autocomplete>\n    <span class=\"cps-timepicker-delimiter\">:</span>\n    <cps-autocomplete\n      #minutesField\n      (keypress)=\"numberOnly($event)\"\n      width=\"60\"\n      [emptyOptionIndex]=\"mandatoryValue ? 0 : -1\"\n      [options]=\"minutesOptions\"\n      [hideDetails]=\"true\"\n      [disabled]=\"disabled\"\n      [showChevron]=\"false\"\n      [showEmptyMessage]=\"false\"\n      (blurred)=\"onFieldBlur()\"\n      [returnObject]=\"false\"\n      [value]=\"value?.minutes\"\n      (valueChanged)=\"updateMinutes($event)\"\n      [externalError]=\"minutesError\"\n      placeholder=\"MM\"></cps-autocomplete>\n    <span *ngIf=\"withSeconds\" class=\"cps-timepicker-delimiter\">:</span>\n    <cps-autocomplete\n      *ngIf=\"withSeconds\"\n      #secondsField\n      (keypress)=\"numberOnly($event)\"\n      width=\"60\"\n      [emptyOptionIndex]=\"mandatoryValue ? 0 : -1\"\n      [options]=\"secondsOptions\"\n      [hideDetails]=\"true\"\n      [disabled]=\"disabled\"\n      [showChevron]=\"false\"\n      [showEmptyMessage]=\"false\"\n      (blurred)=\"onFieldBlur()\"\n      [returnObject]=\"false\"\n      [value]=\"value?.seconds\"\n      (valueChanged)=\"updateSeconds($event)\"\n      [externalError]=\"secondsError\"\n      placeholder=\"SS\"></cps-autocomplete>\n    <cps-button-toggle\n      *ngIf=\"!use24HourTime\"\n      class=\"cps-timepicker-am-pm-selector\"\n      [options]=\"dayPeriodOptions\"\n      [disabled]=\"disabled\"\n      [value]=\"value?.dayPeriod || 'AM'\"\n      (valueChanged)=\"updateDayPeriod($event)\">\n    </cps-button-toggle>\n  </div>\n  <div *ngIf=\"!error && !hideDetails\" class=\"cps-timepicker-hint\">\n    {{ hint }}\n  </div>\n  <div *ngIf=\"error && !hideDetails\" class=\"cps-timepicker-error\">\n    {{ error }}\n  </div>\n</div>\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Injectable, Inject, createComponent, createEnvironmentInjector } from '@angular/core';
|
|
1
|
+
import { Injectable, Inject, createComponent, createEnvironmentInjector, Optional, SkipSelf } from '@angular/core';
|
|
2
2
|
import { DOCUMENT } from '@angular/common';
|
|
3
3
|
import { CpsDialogRef } from './utils/cps-dialog-ref';
|
|
4
4
|
import { CpsDialogConfig } from './utils/cps-dialog-config';
|
|
@@ -10,13 +10,20 @@ import * as i0 from "@angular/core";
|
|
|
10
10
|
* @group Services
|
|
11
11
|
*/
|
|
12
12
|
export class CpsDialogService {
|
|
13
|
+
get openDialogs() {
|
|
14
|
+
return this._parentDialogService
|
|
15
|
+
? this._parentDialogService.openDialogs
|
|
16
|
+
: this._openDialogsAtThisLevel;
|
|
17
|
+
}
|
|
13
18
|
// eslint-disable-next-line no-useless-constructor
|
|
14
|
-
constructor(_appRef, _environmentInjector, _injector, document) {
|
|
19
|
+
constructor(_appRef, _environmentInjector, _injector, document, _parentDialogService) {
|
|
15
20
|
this._appRef = _appRef;
|
|
16
21
|
this._environmentInjector = _environmentInjector;
|
|
17
22
|
this._injector = _injector;
|
|
18
23
|
this.document = document;
|
|
24
|
+
this._parentDialogService = _parentDialogService;
|
|
19
25
|
this.dialogComponentRefMap = new Map();
|
|
26
|
+
this._openDialogsAtThisLevel = [];
|
|
20
27
|
}
|
|
21
28
|
/**
|
|
22
29
|
* Opens a dialog with a dynamically loaded component.
|
|
@@ -61,12 +68,12 @@ export class CpsDialogService {
|
|
|
61
68
|
* @group Method
|
|
62
69
|
*/
|
|
63
70
|
closeAll(force = false) {
|
|
64
|
-
this.
|
|
71
|
+
this._reverseForEach(this.openDialogs, (dialogRef) => {
|
|
65
72
|
if (force) {
|
|
66
|
-
|
|
73
|
+
dialogRef.destroy();
|
|
67
74
|
}
|
|
68
75
|
else {
|
|
69
|
-
|
|
76
|
+
dialogRef.close();
|
|
70
77
|
}
|
|
71
78
|
});
|
|
72
79
|
}
|
|
@@ -94,6 +101,7 @@ export class CpsDialogService {
|
|
|
94
101
|
.rootNodes[0];
|
|
95
102
|
this.document.body.appendChild(domElem);
|
|
96
103
|
this.dialogComponentRefMap.set(dialogRef, componentRef);
|
|
104
|
+
this.openDialogs.push(dialogRef);
|
|
97
105
|
dialogRef._setContainerInstance(componentRef.instance);
|
|
98
106
|
return dialogRef;
|
|
99
107
|
}
|
|
@@ -107,8 +115,21 @@ export class CpsDialogService {
|
|
|
107
115
|
dialogComponentRef.destroy();
|
|
108
116
|
this.dialogComponentRefMap.delete(dialogRef);
|
|
109
117
|
}
|
|
118
|
+
const index = this.openDialogs.indexOf(dialogRef);
|
|
119
|
+
if (index > -1) {
|
|
120
|
+
this.openDialogs.splice(index, 1);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
ngOnDestroy() {
|
|
124
|
+
this._reverseForEach(this._openDialogsAtThisLevel, (dialogRef) => dialogRef.destroy());
|
|
125
|
+
}
|
|
126
|
+
_reverseForEach(items, callback) {
|
|
127
|
+
let i = items.length;
|
|
128
|
+
while (i--) {
|
|
129
|
+
callback(items[i]);
|
|
130
|
+
}
|
|
110
131
|
}
|
|
111
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: CpsDialogService, deps: [{ token: i0.ApplicationRef }, { token: i0.EnvironmentInjector }, { token: i0.Injector }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
132
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: CpsDialogService, deps: [{ token: i0.ApplicationRef }, { token: i0.EnvironmentInjector }, { token: i0.Injector }, { token: DOCUMENT }, { token: CpsDialogService, optional: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
112
133
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: CpsDialogService, providedIn: 'root' }); }
|
|
113
134
|
}
|
|
114
135
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: CpsDialogService, decorators: [{
|
|
@@ -117,5 +138,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
117
138
|
}], ctorParameters: () => [{ type: i0.ApplicationRef }, { type: i0.EnvironmentInjector }, { type: i0.Injector }, { type: Document, decorators: [{
|
|
118
139
|
type: Inject,
|
|
119
140
|
args: [DOCUMENT]
|
|
141
|
+
}] }, { type: CpsDialogService, decorators: [{
|
|
142
|
+
type: Optional
|
|
143
|
+
}, {
|
|
144
|
+
type: SkipSelf
|
|
120
145
|
}] }] });
|
|
121
|
-
//# 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  Type,\n  EmbeddedViewRef,\n  ComponentRef,\n  Inject,\n  ApplicationRef,\n  createComponent,\n  EnvironmentInjector,\n  createEnvironmentInjector,\n  Injector\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    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  /**\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      elementInjector:\n        this._injector !== this._environmentInjector\n          ? this._injector\n          : undefined\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"]}
|
|
146
|
+
//# 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  Type,\n  EmbeddedViewRef,\n  ComponentRef,\n  Inject,\n  ApplicationRef,\n  createComponent,\n  EnvironmentInjector,\n  createEnvironmentInjector,\n  Injector,\n  Optional,\n  SkipSelf,\n  OnDestroy\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 implements OnDestroy {\n  get openDialogs(): CpsDialogRef<any>[] {\n    return this._parentDialogService\n      ? this._parentDialogService.openDialogs\n      : this._openDialogsAtThisLevel;\n  }\n\n  dialogComponentRefMap: Map<CpsDialogRef, ComponentRef<CpsDialogComponent>> =\n    new Map();\n\n  private _openDialogsAtThisLevel: CpsDialogRef<any>[] = [];\n\n  // eslint-disable-next-line no-useless-constructor\n  constructor(\n    private _appRef: ApplicationRef,\n    private _environmentInjector: EnvironmentInjector,\n    private _injector: Injector,\n    @Inject(DOCUMENT) private document: Document,\n    @Optional() @SkipSelf() private _parentDialogService: CpsDialogService\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._reverseForEach(this.openDialogs, (dialogRef) => {\n      if (force) {\n        dialogRef.destroy();\n      } else {\n        dialogRef.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      elementInjector:\n        this._injector !== this._environmentInjector\n          ? this._injector\n          : undefined\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    this.openDialogs.push(dialogRef);\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    const index = this.openDialogs.indexOf(dialogRef);\n\n    if (index > -1) {\n      this.openDialogs.splice(index, 1);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._reverseForEach(this._openDialogsAtThisLevel, (dialogRef) =>\n      dialogRef.destroy()\n    );\n  }\n\n  private _reverseForEach<T>(\n    items: T[] | readonly T[],\n    callback: (current: T) => void\n  ) {\n    let i = items.length;\n\n    while (i--) {\n      callback(items[i]);\n    }\n  }\n}\n"]}
|
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, createComponent, createEnvironmentInjector, Injectable } 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, createComponent, createEnvironmentInjector, Injectable, SkipSelf } 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';
|
|
@@ -10752,7 +10752,8 @@ class CpsTimepickerComponent {
|
|
|
10752
10752
|
this._checkErrors();
|
|
10753
10753
|
}
|
|
10754
10754
|
updateHours(hours) {
|
|
10755
|
-
|
|
10755
|
+
hours = hours || '';
|
|
10756
|
+
const userInput = this.hoursField?.inputText || hours;
|
|
10756
10757
|
if (userInput) {
|
|
10757
10758
|
this._initValue();
|
|
10758
10759
|
const h = parseInt(userInput, 10);
|
|
@@ -10766,7 +10767,7 @@ class CpsTimepickerComponent {
|
|
|
10766
10767
|
if (this.value)
|
|
10767
10768
|
this.value.hours = hours;
|
|
10768
10769
|
}
|
|
10769
|
-
this.
|
|
10770
|
+
this._updateValue(this.value);
|
|
10770
10771
|
}
|
|
10771
10772
|
updateMinutes(minutes) {
|
|
10772
10773
|
minutes = minutes || '';
|
|
@@ -10776,7 +10777,7 @@ class CpsTimepickerComponent {
|
|
|
10776
10777
|
if (this.value)
|
|
10777
10778
|
this.value.minutes = minutes;
|
|
10778
10779
|
}
|
|
10779
|
-
this.
|
|
10780
|
+
this._updateValue(this.value);
|
|
10780
10781
|
}
|
|
10781
10782
|
updateSeconds(seconds) {
|
|
10782
10783
|
seconds = seconds || '';
|
|
@@ -10786,7 +10787,7 @@ class CpsTimepickerComponent {
|
|
|
10786
10787
|
if (this.value)
|
|
10787
10788
|
this.value.seconds = seconds;
|
|
10788
10789
|
}
|
|
10789
|
-
this.
|
|
10790
|
+
this._updateValue(this.value);
|
|
10790
10791
|
}
|
|
10791
10792
|
updateDayPeriod(dayPeriod) {
|
|
10792
10793
|
if (dayPeriod)
|
|
@@ -10795,7 +10796,7 @@ class CpsTimepickerComponent {
|
|
|
10795
10796
|
if (this.value)
|
|
10796
10797
|
this.value.dayPeriod = dayPeriod;
|
|
10797
10798
|
}
|
|
10798
|
-
this.
|
|
10799
|
+
this._updateValue(this.value);
|
|
10799
10800
|
}
|
|
10800
10801
|
numberOnly(event) {
|
|
10801
10802
|
const charCode = event.which ? event.which : event.keyCode;
|
|
@@ -10886,13 +10887,6 @@ class CpsTimepickerComponent {
|
|
|
10886
10887
|
this.onChange(value);
|
|
10887
10888
|
this.valueChanged.emit(value);
|
|
10888
10889
|
}
|
|
10889
|
-
_tryUpdateValue() {
|
|
10890
|
-
if (this.value?.hours &&
|
|
10891
|
-
this.value?.minutes &&
|
|
10892
|
-
(!this.withSeconds || (this.withSeconds && this.value?.seconds)) &&
|
|
10893
|
-
(this.use24HourTime || (!this.use24HourTime && this.value?.dayPeriod)))
|
|
10894
|
-
this._updateValue(this.value);
|
|
10895
|
-
}
|
|
10896
10890
|
_getRange(startFrom, until) {
|
|
10897
10891
|
return Array.from({ length: until + 1 - startFrom }, (_, k) => k + startFrom);
|
|
10898
10892
|
}
|
|
@@ -13092,13 +13086,20 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
13092
13086
|
* @group Services
|
|
13093
13087
|
*/
|
|
13094
13088
|
class CpsDialogService {
|
|
13089
|
+
get openDialogs() {
|
|
13090
|
+
return this._parentDialogService
|
|
13091
|
+
? this._parentDialogService.openDialogs
|
|
13092
|
+
: this._openDialogsAtThisLevel;
|
|
13093
|
+
}
|
|
13095
13094
|
// eslint-disable-next-line no-useless-constructor
|
|
13096
|
-
constructor(_appRef, _environmentInjector, _injector, document) {
|
|
13095
|
+
constructor(_appRef, _environmentInjector, _injector, document, _parentDialogService) {
|
|
13097
13096
|
this._appRef = _appRef;
|
|
13098
13097
|
this._environmentInjector = _environmentInjector;
|
|
13099
13098
|
this._injector = _injector;
|
|
13100
13099
|
this.document = document;
|
|
13100
|
+
this._parentDialogService = _parentDialogService;
|
|
13101
13101
|
this.dialogComponentRefMap = new Map();
|
|
13102
|
+
this._openDialogsAtThisLevel = [];
|
|
13102
13103
|
}
|
|
13103
13104
|
/**
|
|
13104
13105
|
* Opens a dialog with a dynamically loaded component.
|
|
@@ -13143,12 +13144,12 @@ class CpsDialogService {
|
|
|
13143
13144
|
* @group Method
|
|
13144
13145
|
*/
|
|
13145
13146
|
closeAll(force = false) {
|
|
13146
|
-
this.
|
|
13147
|
+
this._reverseForEach(this.openDialogs, (dialogRef) => {
|
|
13147
13148
|
if (force) {
|
|
13148
|
-
|
|
13149
|
+
dialogRef.destroy();
|
|
13149
13150
|
}
|
|
13150
13151
|
else {
|
|
13151
|
-
|
|
13152
|
+
dialogRef.close();
|
|
13152
13153
|
}
|
|
13153
13154
|
});
|
|
13154
13155
|
}
|
|
@@ -13176,6 +13177,7 @@ class CpsDialogService {
|
|
|
13176
13177
|
.rootNodes[0];
|
|
13177
13178
|
this.document.body.appendChild(domElem);
|
|
13178
13179
|
this.dialogComponentRefMap.set(dialogRef, componentRef);
|
|
13180
|
+
this.openDialogs.push(dialogRef);
|
|
13179
13181
|
dialogRef._setContainerInstance(componentRef.instance);
|
|
13180
13182
|
return dialogRef;
|
|
13181
13183
|
}
|
|
@@ -13189,8 +13191,21 @@ class CpsDialogService {
|
|
|
13189
13191
|
dialogComponentRef.destroy();
|
|
13190
13192
|
this.dialogComponentRefMap.delete(dialogRef);
|
|
13191
13193
|
}
|
|
13194
|
+
const index = this.openDialogs.indexOf(dialogRef);
|
|
13195
|
+
if (index > -1) {
|
|
13196
|
+
this.openDialogs.splice(index, 1);
|
|
13197
|
+
}
|
|
13198
|
+
}
|
|
13199
|
+
ngOnDestroy() {
|
|
13200
|
+
this._reverseForEach(this._openDialogsAtThisLevel, (dialogRef) => dialogRef.destroy());
|
|
13192
13201
|
}
|
|
13193
|
-
|
|
13202
|
+
_reverseForEach(items, callback) {
|
|
13203
|
+
let i = items.length;
|
|
13204
|
+
while (i--) {
|
|
13205
|
+
callback(items[i]);
|
|
13206
|
+
}
|
|
13207
|
+
}
|
|
13208
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: CpsDialogService, deps: [{ token: i0.ApplicationRef }, { token: i0.EnvironmentInjector }, { token: i0.Injector }, { token: DOCUMENT }, { token: CpsDialogService, optional: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
13194
13209
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: CpsDialogService, providedIn: 'root' }); }
|
|
13195
13210
|
}
|
|
13196
13211
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImport: i0, type: CpsDialogService, decorators: [{
|
|
@@ -13199,6 +13214,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.0", ngImpor
|
|
|
13199
13214
|
}], ctorParameters: () => [{ type: i0.ApplicationRef }, { type: i0.EnvironmentInjector }, { type: i0.Injector }, { type: Document, decorators: [{
|
|
13200
13215
|
type: Inject,
|
|
13201
13216
|
args: [DOCUMENT]
|
|
13217
|
+
}] }, { type: CpsDialogService, decorators: [{
|
|
13218
|
+
type: Optional
|
|
13219
|
+
}, {
|
|
13220
|
+
type: SkipSelf
|
|
13202
13221
|
}] }] });
|
|
13203
13222
|
|
|
13204
13223
|
/* eslint-disable no-unused-vars */
|