@rangertechnologies/ngnxt 2.1.76 → 2.1.77
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 +29 -29
- package/esm2022/lib/ar.i18n.mjs +29 -29
- package/esm2022/lib/components/custom-button/custom-button.component.mjs +39 -39
- package/esm2022/lib/components/custom-calendar/custom-calendar.component.mjs +366 -366
- package/esm2022/lib/components/custom-date/custom-date.component.mjs +47 -47
- package/esm2022/lib/components/custom-date-picker/custom-date-picker.component.mjs +48 -48
- package/esm2022/lib/components/custom-dropdown/custom-dropdown.component.mjs +219 -212
- package/esm2022/lib/components/custom-image/custom-image.component.mjs +34 -34
- package/esm2022/lib/components/custom-input/custom-input.component.mjs +93 -93
- package/esm2022/lib/components/custom-label/custom-label.component.mjs +21 -21
- package/esm2022/lib/components/custom-model/custom-model.component.mjs +48 -48
- package/esm2022/lib/components/custom-radio/custom-radio.component.mjs +115 -115
- package/esm2022/lib/components/custom-rich-text/custom-rich-text.component.mjs +177 -0
- package/esm2022/lib/components/custom-table/custom-table.component.mjs +169 -169
- package/esm2022/lib/components/custom-text-area/custom-text-area.component.mjs +65 -65
- package/esm2022/lib/components/custom-time/custom-time.component.mjs +61 -61
- package/esm2022/lib/components/dependent-table/dependent-table.component.mjs +42 -42
- package/esm2022/lib/components/dropdown-with-flag/dropdown-with-flag.component.mjs +39 -39
- package/esm2022/lib/components/file-upload/file-upload.component.mjs +233 -233
- package/esm2022/lib/components/file-view/file-view.component.mjs +46 -46
- package/esm2022/lib/components/loader/loader.component.mjs +23 -23
- package/esm2022/lib/components/pick-location/pick-location.component.mjs +188 -188
- package/esm2022/lib/components/search-box/search-box.component.mjs +130 -130
- package/esm2022/lib/components/table-appendix/table-appendix.component.mjs +123 -123
- package/esm2022/lib/directives/componenthost/componenthost.directive.mjs +19 -19
- package/esm2022/lib/en.i18n.mjs +29 -29
- package/esm2022/lib/i18n-config.service.mjs +4 -4
- package/esm2022/lib/i18n.component.mjs +47 -47
- package/esm2022/lib/i18n.module.mjs +38 -38
- package/esm2022/lib/i18n.pipe.mjs +25 -25
- package/esm2022/lib/i18n.service.mjs +56 -56
- package/esm2022/lib/interfaces/actionMeta.mjs +2 -2
- package/esm2022/lib/interfaces/apimeta.mjs +2 -2
- package/esm2022/lib/interfaces/dependencyMeta.mjs +2 -2
- package/esm2022/lib/model/bookletWrapper.mjs +9 -9
- package/esm2022/lib/model/changeWrapper.mjs +11 -11
- package/esm2022/lib/model/errorWrapper.mjs +6 -6
- package/esm2022/lib/model/tableWrapper.mjs +20 -20
- package/esm2022/lib/nxt-app.component.mjs +22 -22
- package/esm2022/lib/nxt-app.module.mjs +368 -352
- package/esm2022/lib/nxt-app.service.mjs +14 -14
- package/esm2022/lib/pages/booklet/booklet.component.mjs +541 -541
- package/esm2022/lib/pages/questionbook/questionbook.component.mjs +414 -407
- package/esm2022/lib/pages/questionnaire/questionnaire.component.mjs +2392 -2373
- package/esm2022/lib/pages/summary-page/summary-page.component.mjs +76 -76
- package/esm2022/lib/pipe/get-value.pipe.mjs +50 -50
- package/esm2022/lib/sample.mjs +3715 -3431
- package/esm2022/lib/services/change.service.mjs +53 -53
- package/esm2022/lib/services/data.service.mjs +80 -80
- package/esm2022/lib/services/salesforce.service.mjs +46 -46
- package/esm2022/lib/services/shared.service.mjs +100 -100
- package/esm2022/lib/services/storage.service.mjs +44 -44
- package/esm2022/lib/tam.i18n.mjs +29 -29
- package/esm2022/lib/wrapper.mjs +175 -175
- package/esm2022/public-api.mjs +15 -15
- package/esm2022/rangertechnologies-ngnxt.mjs +4 -4
- package/fesm2022/rangertechnologies-ngnxt.mjs +10305 -9805
- package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
- package/index.d.ts +5 -5
- package/lib/ar.i18n.d.ts +24 -24
- package/lib/components/custom-button/custom-button.component.d.ts +16 -16
- package/lib/components/custom-calendar/custom-calendar.component.d.ts +65 -65
- package/lib/components/custom-date/custom-date.component.d.ts +18 -18
- package/lib/components/custom-date-picker/custom-date-picker.component.d.ts +19 -19
- package/lib/components/custom-dropdown/custom-dropdown.component.d.ts +39 -39
- package/lib/components/custom-image/custom-image.component.d.ts +13 -13
- package/lib/components/custom-input/custom-input.component.d.ts +31 -31
- package/lib/components/custom-label/custom-label.component.d.ts +10 -10
- package/lib/components/custom-model/custom-model.component.d.ts +19 -19
- package/lib/components/custom-radio/custom-radio.component.d.ts +33 -33
- package/lib/components/custom-rich-text/custom-rich-text.component.d.ts +29 -0
- package/lib/components/custom-table/custom-table.component.d.ts +43 -43
- package/lib/components/custom-text-area/custom-text-area.component.d.ts +22 -22
- package/lib/components/custom-time/custom-time.component.d.ts +18 -18
- package/lib/components/dependent-table/dependent-table.component.d.ts +15 -15
- package/lib/components/dropdown-with-flag/dropdown-with-flag.component.d.ts +16 -16
- package/lib/components/file-upload/file-upload.component.d.ts +42 -42
- package/lib/components/file-view/file-view.component.d.ts +16 -16
- package/lib/components/loader/loader.component.d.ts +11 -11
- package/lib/components/pick-location/pick-location.component.d.ts +42 -42
- package/lib/components/search-box/search-box.component.d.ts +40 -40
- package/lib/components/table-appendix/table-appendix.component.d.ts +30 -30
- package/lib/directives/componenthost/componenthost.directive.d.ts +8 -8
- package/lib/en.i18n.d.ts +24 -24
- package/lib/i18n-config.service.d.ts +2 -2
- package/lib/i18n.component.d.ts +11 -11
- package/lib/i18n.module.d.ts +9 -9
- package/lib/i18n.pipe.d.ts +10 -10
- package/lib/i18n.service.d.ts +14 -14
- package/lib/interfaces/actionMeta.d.ts +5 -5
- package/lib/interfaces/apimeta.d.ts +14 -13
- package/lib/interfaces/dependencyMeta.d.ts +8 -8
- package/lib/model/bookletWrapper.d.ts +5 -5
- package/lib/model/changeWrapper.d.ts +10 -10
- package/lib/model/errorWrapper.d.ts +5 -5
- package/lib/model/tableWrapper.d.ts +18 -18
- package/lib/nxt-app.component.d.ts +8 -8
- package/lib/nxt-app.module.d.ts +49 -46
- package/lib/nxt-app.service.d.ts +6 -6
- package/lib/pages/booklet/booklet.component.d.ts +68 -68
- package/lib/pages/questionbook/questionbook.component.d.ts +66 -66
- package/lib/pages/questionnaire/questionnaire.component.d.ts +220 -218
- package/lib/pages/summary-page/summary-page.component.d.ts +20 -20
- package/lib/pipe/get-value.pipe.d.ts +7 -7
- package/lib/sample.d.ts +11 -10
- package/lib/services/change.service.d.ts +22 -22
- package/lib/services/data.service.d.ts +13 -13
- package/lib/services/salesforce.service.d.ts +11 -11
- package/lib/services/shared.service.d.ts +15 -15
- package/lib/services/storage.service.d.ts +13 -13
- package/lib/tam.i18n.d.ts +24 -24
- package/lib/wrapper.d.ts +203 -203
- package/package.json +1 -1
- package/public-api.d.ts +10 -10
- package/rangertechnologies-ngnxt-2.1.77.tgz +0 -0
- package/rangertechnologies-ngnxt-2.1.76.tgz +0 -0
|
@@ -1,115 +1,115 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
-
import { ChangeWrapper } from '../../model/changeWrapper';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "../../services/change.service";
|
|
5
|
-
import * as i2 from "../../services/data.service";
|
|
6
|
-
import * as i3 from "../../i18n.service";
|
|
7
|
-
import * as i4 from "@angular/common";
|
|
8
|
-
export class CustomRadioComponent {
|
|
9
|
-
changeService;
|
|
10
|
-
dataService;
|
|
11
|
-
i18nService;
|
|
12
|
-
options = [];
|
|
13
|
-
apiMeta;
|
|
14
|
-
selectedValue;
|
|
15
|
-
progressBar;
|
|
16
|
-
id;
|
|
17
|
-
readOnly = false;
|
|
18
|
-
errorMessage;
|
|
19
|
-
error;
|
|
20
|
-
fromShengel = false;
|
|
21
|
-
referenceField;
|
|
22
|
-
token;
|
|
23
|
-
valueChange = new EventEmitter();
|
|
24
|
-
invalidFieldIds = [];
|
|
25
|
-
labelField;
|
|
26
|
-
valueField;
|
|
27
|
-
subscription;
|
|
28
|
-
constructor(changeService, dataService, i18nService) {
|
|
29
|
-
this.changeService = changeService;
|
|
30
|
-
this.dataService = dataService;
|
|
31
|
-
this.i18nService = i18nService;
|
|
32
|
-
this.changeService.submitValidate$.subscribe((data) => {
|
|
33
|
-
this.invalidFieldIds.push(data);
|
|
34
|
-
});
|
|
35
|
-
}
|
|
36
|
-
ngOnInit() {
|
|
37
|
-
// VD 31NOV24 null check
|
|
38
|
-
if (this.apiMeta) {
|
|
39
|
-
let apiObj = JSON.parse(this.apiMeta);
|
|
40
|
-
this.labelField = apiObj.field;
|
|
41
|
-
this.dataService.apiResponse(apiObj.endpoint)?.subscribe((apiResponse) => {
|
|
42
|
-
let responses;
|
|
43
|
-
if (apiObj.variable) {
|
|
44
|
-
responses = this.dataService.getValue(apiResponse, apiObj.variable);
|
|
45
|
-
let results = [];
|
|
46
|
-
for (let i = 0; i < responses?.length; i++) {
|
|
47
|
-
var resp = responses[i];
|
|
48
|
-
results.push(resp);
|
|
49
|
-
}
|
|
50
|
-
this.options = results;
|
|
51
|
-
}
|
|
52
|
-
else {
|
|
53
|
-
responses = apiResponse;
|
|
54
|
-
this.options = responses;
|
|
55
|
-
}
|
|
56
|
-
});
|
|
57
|
-
let sourceId = apiObj.sourceQuestionId;
|
|
58
|
-
if (sourceId) {
|
|
59
|
-
this.subscription = this.changeService.changeAnnounced$.subscribe((changeValue) => {
|
|
60
|
-
if (changeValue != undefined) {
|
|
61
|
-
if (changeValue.valueObj != undefined && changeValue.fromQuestionId == apiObj.sourceQuestionId) {
|
|
62
|
-
this.selectedValue = changeValue.valueObj[apiObj.valueField];
|
|
63
|
-
let value = {};
|
|
64
|
-
value['name'] = this.selectedValue;
|
|
65
|
-
this.radioChange(value);
|
|
66
|
-
}
|
|
67
|
-
this.changeService.confirmChange(apiObj.sourceQuestionId);
|
|
68
|
-
}
|
|
69
|
-
});
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
radioChange(event) {
|
|
74
|
-
let change = new ChangeWrapper();
|
|
75
|
-
change.fromQuestionId = this.id;
|
|
76
|
-
change.valueObj = event.target?.id ? event.target?.id : '';
|
|
77
|
-
change.referenceField = this.referenceField;
|
|
78
|
-
change.selectedObj = event ? event[this.labelField] : '';
|
|
79
|
-
this.valueChange.emit(change);
|
|
80
|
-
if (event) {
|
|
81
|
-
this.invalidFieldIds = [];
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomRadioComponent, deps: [{ token: i1.ChangeService }, { token: i2.DataService }, { token: i3.I18nService }], target: i0.ɵɵFactoryTarget.Component });
|
|
85
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CustomRadioComponent, selector: "app-custom-radio", inputs: { options: "options", apiMeta: "apiMeta", selectedValue: "selectedValue", progressBar: "progressBar", id: "id", readOnly: "readOnly", errorMessage: "errorMessage", error: "error", fromShengel: "fromShengel", referenceField: "referenceField", token: "token" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<!-- RS 09DEC24 Changed keys--> \n<div class=\"custom-radio-container\">\n <div\n *ngFor=\"let option of options\"\n [class]=\"invalidFieldIds.includes(id) || error ? 'custom-radio-option invalid' : 'custom-radio-option'\"\n >\n <input\n type=\"radio\"\n [id]=\"apiMeta !== undefined ? option[labelField] : option.value \"\n [checked] = \"selectedValue == option.value \"\n [name]=\"id\"\n [value]=\"selectedValue\"\n (change)=\"radioChange($event)\"\n [disabled]=\"readOnly\"\n />\n <label class=\"nxt-radio-label\" [for]=\"apiMeta !== undefined ? option[labelField] : option.value\">{{ apiMeta !== undefined ? option[labelField] : option.value }}</label>\n </div>\n <span *ngIf=\"error || invalidFieldIds.includes(id)\" class=\"error-msg\">{{ errorMessage }}</span>\n </div>\n ", styles: [".custom-radio-option{display:flex;flex-direction:row;margin-bottom:5px}input[type=radio]{width:auto}.nxt-radio-label{margin-left:15px;margin-bottom:0}.custom-radio-option.invalid label{color:red}.error-msg{color:red;font-size:12px;margin-top:5px}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
86
|
-
}
|
|
87
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomRadioComponent, decorators: [{
|
|
88
|
-
type: Component,
|
|
89
|
-
args: [{ selector: 'app-custom-radio', template: "<!-- RS 09DEC24 Changed keys--> \n<div class=\"custom-radio-container\">\n <div\n *ngFor=\"let option of options\"\n [class]=\"invalidFieldIds.includes(id) || error ? 'custom-radio-option invalid' : 'custom-radio-option'\"\n >\n <input\n type=\"radio\"\n [id]=\"apiMeta !== undefined ? option[labelField] : option.value \"\n [checked] = \"selectedValue == option.value \"\n [name]=\"id\"\n [value]=\"selectedValue\"\n (change)=\"radioChange($event)\"\n [disabled]=\"readOnly\"\n />\n <label class=\"nxt-radio-label\" [for]=\"apiMeta !== undefined ? option[labelField] : option.value\">{{ apiMeta !== undefined ? option[labelField] : option.value }}</label>\n </div>\n <span *ngIf=\"error || invalidFieldIds.includes(id)\" class=\"error-msg\">{{ errorMessage }}</span>\n </div>\n ", styles: [".custom-radio-option{display:flex;flex-direction:row;margin-bottom:5px}input[type=radio]{width:auto}.nxt-radio-label{margin-left:15px;margin-bottom:0}.custom-radio-option.invalid label{color:red}.error-msg{color:red;font-size:12px;margin-top:5px}\n"] }]
|
|
90
|
-
}], ctorParameters: function () { return [{ type: i1.ChangeService }, { type: i2.DataService }, { type: i3.I18nService }]; }, propDecorators: { options: [{
|
|
91
|
-
type: Input
|
|
92
|
-
}], apiMeta: [{
|
|
93
|
-
type: Input
|
|
94
|
-
}], selectedValue: [{
|
|
95
|
-
type: Input
|
|
96
|
-
}], progressBar: [{
|
|
97
|
-
type: Input
|
|
98
|
-
}], id: [{
|
|
99
|
-
type: Input
|
|
100
|
-
}], readOnly: [{
|
|
101
|
-
type: Input
|
|
102
|
-
}], errorMessage: [{
|
|
103
|
-
type: Input
|
|
104
|
-
}], error: [{
|
|
105
|
-
type: Input
|
|
106
|
-
}], fromShengel: [{
|
|
107
|
-
type: Input
|
|
108
|
-
}], referenceField: [{
|
|
109
|
-
type: Input
|
|
110
|
-
}], token: [{
|
|
111
|
-
type: Input
|
|
112
|
-
}], valueChange: [{
|
|
113
|
-
type: Output
|
|
114
|
-
}] } });
|
|
115
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-radio.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/custom-radio/custom-radio.component.ts","../../../../../../projects/nxt-app/src/lib/components/custom-radio/custom-radio.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC/E,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;;;;;;AAY1D,MAAM,OAAO,oBAAoB;IAqBrB;IACA;IACD;IArBA,OAAO,GAAU,EAAE,CAAC;IACpB,OAAO,CAAS;IAChB,aAAa,CAAS;IACtB,WAAW,CAAU;IACrB,EAAE,CAAS;IACX,QAAQ,GAAG,KAAK,CAAC;IACjB,YAAY,CAAS;IACrB,KAAK,CAAM;IACX,WAAW,GAAY,KAAK,CAAC;IAC7B,cAAc,CAAS;IACvB,KAAK,CAAS;IACb,WAAW,GAAgC,IAAI,YAAY,EAAiB,CAAC;IACvF,eAAe,GAAa,EAAE,CAAC;IAExB,UAAU,CAAS;IACnB,UAAU,CAAS;IAC1B,YAAY,CAAe;IAE3B,YACU,aAA4B,EAC5B,WAAwB,EACzB,WAAwB;QAFvB,kBAAa,GAAb,aAAa,CAAe;QAC5B,gBAAW,GAAX,WAAW,CAAa;QACzB,gBAAW,GAAX,WAAW,CAAa;QAE/B,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YACpD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,QAAQ;QACN,wBAAwB;QACxB,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,MAAM,GAAY,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC/C,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,KAAK,CAAC;YAE/B,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,SAAS,CAAC,CAAC,WAAW,EAAE,EAAE;gBACvE,IAAI,SAAS,CAAC;gBACd,IAAI,MAAM,CAAC,QAAQ,EAAE;oBACnB,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC;oBACpE,IAAI,OAAO,GAAG,EAAE,CAAC;oBACjB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE;wBAC1C,IAAI,IAAI,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;wBACxB,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;qBACpB;oBACD,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;iBACxB;qBAAM;oBACL,SAAS,GAAG,WAAW,CAAC;oBACxB,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;iBAC1B;YACH,CAAC,CAAC,CAAC;YAEH,IAAI,QAAQ,GAAG,MAAM,CAAC,gBAAgB,CAAC;YACvC,IAAI,QAAQ,EAAE;gBACZ,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,SAAS,CAC/D,CAAC,WAAW,EAAE,EAAE;oBACd,IAAI,WAAW,IAAI,SAAS,EAAE;wBAC5B,IAAI,WAAW,CAAC,QAAQ,IAAI,SAAS,IAAI,WAAW,CAAC,cAAc,IAAI,MAAM,CAAC,gBAAgB,EAAE;4BAC9F,IAAI,CAAC,aAAa,GAAG,WAAW,CAAC,QAAQ,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;4BAC7D,IAAI,KAAK,GAAG,EAAE,CAAC;4BACf,KAAK,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC;4BACnC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;yBACzB;wBACD,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;qBAC3D;gBACH,CAAC,CACF,CAAC;aACH;SACF;IACH,CAAC;IAED,WAAW,CAAC,KAAU;QACpB,IAAI,MAAM,GAAG,IAAI,aAAa,EAAE,CAAC;QACjC,MAAM,CAAC,cAAc,GAAG,IAAI,CAAC,EAAE,CAAC;QAChC,MAAM,CAAC,QAAQ,GAAG,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC3D,MAAM,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC;QAC5C,MAAM,CAAC,WAAW,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACzD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC9B,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;SAC3B;IACH,CAAC;uGAjFU,oBAAoB;2FAApB,oBAAoB,6WCbjC,s2BAmBE;;2FDNW,oBAAoB;kBALhC,SAAS;+BACE,kBAAkB;wJAMnB,OAAO;sBAAf,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,EAAE;sBAAV,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACI,WAAW;sBAApB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { ChangeWrapper } from '../../model/changeWrapper';\nimport { ChangeService } from '../../services/change.service';\nimport { I18nService } from '../../i18n.service';\nimport { DataService } from '../../services/data.service';\nimport { Subscription } from 'rxjs';\nimport { APIMeta } from '../../interfaces/apimeta';\n\n@Component({\n  selector: 'app-custom-radio',\n  templateUrl: './custom-radio.component.html',\n  styleUrls: ['./custom-radio.component.css']\n})\nexport class CustomRadioComponent implements OnInit {\n\n  @Input() options: any[] = [];\n  @Input() apiMeta: string;\n  @Input() selectedValue: string;\n  @Input() progressBar: boolean;\n  @Input() id: string;\n  @Input() readOnly = false;\n  @Input() errorMessage: string;\n  @Input() error: any;\n  @Input() fromShengel: boolean = false;\n  @Input() referenceField: string;\n  @Input() token: string;\n  @Output() valueChange: EventEmitter<ChangeWrapper> = new EventEmitter<ChangeWrapper>();\n  invalidFieldIds: string[] = [];\n\n  public labelField: string;\n  public valueField: string;\n  subscription: Subscription;\n\n  constructor(\n    private changeService: ChangeService,\n    private dataService: DataService,\n    public i18nService: I18nService\n  ) {\n    this.changeService.submitValidate$.subscribe((data) => {\n      this.invalidFieldIds.push(data);\n    });\n  }\n\n  ngOnInit(): void {\n    // VD 31NOV24 null check\n    if (this.apiMeta) {\n      let apiObj: APIMeta = JSON.parse(this.apiMeta);\n      this.labelField = apiObj.field;\n\n      this.dataService.apiResponse(apiObj.endpoint)?.subscribe((apiResponse) => {\n        let responses;\n        if (apiObj.variable) {\n          responses = this.dataService.getValue(apiResponse, apiObj.variable);\n          let results = [];\n          for (let i = 0; i < responses?.length; i++) {\n            var resp = responses[i];\n            results.push(resp);\n          }\n          this.options = results;\n        } else {\n          responses = apiResponse;\n          this.options = responses;\n        }\n      });\n\n      let sourceId = apiObj.sourceQuestionId;\n      if (sourceId) {\n        this.subscription = this.changeService.changeAnnounced$.subscribe(\n          (changeValue) => {\n            if (changeValue != undefined) {\n              if (changeValue.valueObj != undefined && changeValue.fromQuestionId == apiObj.sourceQuestionId) {\n                this.selectedValue = changeValue.valueObj[apiObj.valueField];\n                let value = {};\n                value['name'] = this.selectedValue;\n                this.radioChange(value);\n              }\n              this.changeService.confirmChange(apiObj.sourceQuestionId);\n            }\n          }\n        );\n      }\n    }\n  }\n\n  radioChange(event: any) {\n    let change = new ChangeWrapper();\n    change.fromQuestionId = this.id;\n    change.valueObj = event.target?.id ? event.target?.id : '';\n    change.referenceField = this.referenceField;\n    change.selectedObj = event ? event[this.labelField] : '';\n    this.valueChange.emit(change);\n    if (event) {\n      this.invalidFieldIds = [];\n    }\n  }\n\n}\n","<!-- RS 09DEC24 Changed keys--> \n<div class=\"custom-radio-container\">\n    <div\n      *ngFor=\"let option of options\"\n      [class]=\"invalidFieldIds.includes(id) || error ? 'custom-radio-option invalid' : 'custom-radio-option'\"\n    >\n      <input\n        type=\"radio\"\n        [id]=\"apiMeta !== undefined ? option[labelField] : option.value \"\n        [checked] = \"selectedValue == option.value \"\n        [name]=\"id\"\n        [value]=\"selectedValue\"\n        (change)=\"radioChange($event)\"\n        [disabled]=\"readOnly\"\n      />\n      <label class=\"nxt-radio-label\" [for]=\"apiMeta !== undefined ? option[labelField] : option.value\">{{ apiMeta !== undefined ? option[labelField] : option.value  }}</label>\n    </div>\n    <span *ngIf=\"error || invalidFieldIds.includes(id)\" class=\"error-msg\">{{ errorMessage }}</span>\n  </div>\n  "]}
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { ChangeWrapper } from '../../model/changeWrapper';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../../services/change.service";
|
|
5
|
+
import * as i2 from "../../services/data.service";
|
|
6
|
+
import * as i3 from "../../i18n.service";
|
|
7
|
+
import * as i4 from "@angular/common";
|
|
8
|
+
export class CustomRadioComponent {
|
|
9
|
+
changeService;
|
|
10
|
+
dataService;
|
|
11
|
+
i18nService;
|
|
12
|
+
options = [];
|
|
13
|
+
apiMeta;
|
|
14
|
+
selectedValue;
|
|
15
|
+
progressBar;
|
|
16
|
+
id;
|
|
17
|
+
readOnly = false;
|
|
18
|
+
errorMessage;
|
|
19
|
+
error;
|
|
20
|
+
fromShengel = false;
|
|
21
|
+
referenceField;
|
|
22
|
+
token;
|
|
23
|
+
valueChange = new EventEmitter();
|
|
24
|
+
invalidFieldIds = [];
|
|
25
|
+
labelField;
|
|
26
|
+
valueField;
|
|
27
|
+
subscription;
|
|
28
|
+
constructor(changeService, dataService, i18nService) {
|
|
29
|
+
this.changeService = changeService;
|
|
30
|
+
this.dataService = dataService;
|
|
31
|
+
this.i18nService = i18nService;
|
|
32
|
+
this.changeService.submitValidate$.subscribe((data) => {
|
|
33
|
+
this.invalidFieldIds.push(data);
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
ngOnInit() {
|
|
37
|
+
// VD 31NOV24 null check
|
|
38
|
+
if (this.apiMeta) {
|
|
39
|
+
let apiObj = JSON.parse(this.apiMeta);
|
|
40
|
+
this.labelField = apiObj.field;
|
|
41
|
+
this.dataService.apiResponse(apiObj.endpoint)?.subscribe((apiResponse) => {
|
|
42
|
+
let responses;
|
|
43
|
+
if (apiObj.variable) {
|
|
44
|
+
responses = this.dataService.getValue(apiResponse, apiObj.variable);
|
|
45
|
+
let results = [];
|
|
46
|
+
for (let i = 0; i < responses?.length; i++) {
|
|
47
|
+
var resp = responses[i];
|
|
48
|
+
results.push(resp);
|
|
49
|
+
}
|
|
50
|
+
this.options = results;
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
responses = apiResponse;
|
|
54
|
+
this.options = responses;
|
|
55
|
+
}
|
|
56
|
+
});
|
|
57
|
+
let sourceId = apiObj.sourceQuestionId;
|
|
58
|
+
if (sourceId) {
|
|
59
|
+
this.subscription = this.changeService.changeAnnounced$.subscribe((changeValue) => {
|
|
60
|
+
if (changeValue != undefined) {
|
|
61
|
+
if (changeValue.valueObj != undefined && changeValue.fromQuestionId == apiObj.sourceQuestionId) {
|
|
62
|
+
this.selectedValue = changeValue.valueObj[apiObj.valueField];
|
|
63
|
+
let value = {};
|
|
64
|
+
value['name'] = this.selectedValue;
|
|
65
|
+
this.radioChange(value);
|
|
66
|
+
}
|
|
67
|
+
this.changeService.confirmChange(apiObj.sourceQuestionId);
|
|
68
|
+
}
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
radioChange(event) {
|
|
74
|
+
let change = new ChangeWrapper();
|
|
75
|
+
change.fromQuestionId = this.id;
|
|
76
|
+
change.valueObj = event.target?.id ? event.target?.id : '';
|
|
77
|
+
change.referenceField = this.referenceField;
|
|
78
|
+
change.selectedObj = event ? event[this.labelField] : '';
|
|
79
|
+
this.valueChange.emit(change);
|
|
80
|
+
if (event) {
|
|
81
|
+
this.invalidFieldIds = [];
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomRadioComponent, deps: [{ token: i1.ChangeService }, { token: i2.DataService }, { token: i3.I18nService }], target: i0.ɵɵFactoryTarget.Component });
|
|
85
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CustomRadioComponent, selector: "app-custom-radio", inputs: { options: "options", apiMeta: "apiMeta", selectedValue: "selectedValue", progressBar: "progressBar", id: "id", readOnly: "readOnly", errorMessage: "errorMessage", error: "error", fromShengel: "fromShengel", referenceField: "referenceField", token: "token" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<!-- RS 09DEC24 Changed keys--> \r\n<div class=\"custom-radio-container\">\r\n <div\r\n *ngFor=\"let option of options\"\r\n [class]=\"invalidFieldIds.includes(id) || error ? 'custom-radio-option invalid' : 'custom-radio-option'\"\r\n >\r\n <input\r\n type=\"radio\"\r\n [id]=\"apiMeta !== undefined ? option[labelField] : option.value \"\r\n [checked] = \"selectedValue == option.value \"\r\n [name]=\"id\"\r\n [value]=\"selectedValue\"\r\n (change)=\"radioChange($event)\"\r\n [disabled]=\"readOnly\"\r\n />\r\n <label class=\"nxt-radio-label\" [for]=\"apiMeta !== undefined ? option[labelField] : option.value\">{{ apiMeta !== undefined ? option[labelField] : option.value }}</label>\r\n </div>\r\n <span *ngIf=\"error || invalidFieldIds.includes(id)\" class=\"error-msg\">{{ errorMessage }}</span>\r\n </div>\r\n ", styles: [".custom-radio-option{display:flex;flex-direction:row;margin-bottom:5px}input[type=radio]{width:auto}.nxt-radio-label{margin-left:15px;margin-bottom:0}.custom-radio-option.invalid label{color:red}.error-msg{color:red;font-size:12px;margin-top:5px}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
86
|
+
}
|
|
87
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomRadioComponent, decorators: [{
|
|
88
|
+
type: Component,
|
|
89
|
+
args: [{ selector: 'app-custom-radio', template: "<!-- RS 09DEC24 Changed keys--> \r\n<div class=\"custom-radio-container\">\r\n <div\r\n *ngFor=\"let option of options\"\r\n [class]=\"invalidFieldIds.includes(id) || error ? 'custom-radio-option invalid' : 'custom-radio-option'\"\r\n >\r\n <input\r\n type=\"radio\"\r\n [id]=\"apiMeta !== undefined ? option[labelField] : option.value \"\r\n [checked] = \"selectedValue == option.value \"\r\n [name]=\"id\"\r\n [value]=\"selectedValue\"\r\n (change)=\"radioChange($event)\"\r\n [disabled]=\"readOnly\"\r\n />\r\n <label class=\"nxt-radio-label\" [for]=\"apiMeta !== undefined ? option[labelField] : option.value\">{{ apiMeta !== undefined ? option[labelField] : option.value }}</label>\r\n </div>\r\n <span *ngIf=\"error || invalidFieldIds.includes(id)\" class=\"error-msg\">{{ errorMessage }}</span>\r\n </div>\r\n ", styles: [".custom-radio-option{display:flex;flex-direction:row;margin-bottom:5px}input[type=radio]{width:auto}.nxt-radio-label{margin-left:15px;margin-bottom:0}.custom-radio-option.invalid label{color:red}.error-msg{color:red;font-size:12px;margin-top:5px}\n"] }]
|
|
90
|
+
}], ctorParameters: function () { return [{ type: i1.ChangeService }, { type: i2.DataService }, { type: i3.I18nService }]; }, propDecorators: { options: [{
|
|
91
|
+
type: Input
|
|
92
|
+
}], apiMeta: [{
|
|
93
|
+
type: Input
|
|
94
|
+
}], selectedValue: [{
|
|
95
|
+
type: Input
|
|
96
|
+
}], progressBar: [{
|
|
97
|
+
type: Input
|
|
98
|
+
}], id: [{
|
|
99
|
+
type: Input
|
|
100
|
+
}], readOnly: [{
|
|
101
|
+
type: Input
|
|
102
|
+
}], errorMessage: [{
|
|
103
|
+
type: Input
|
|
104
|
+
}], error: [{
|
|
105
|
+
type: Input
|
|
106
|
+
}], fromShengel: [{
|
|
107
|
+
type: Input
|
|
108
|
+
}], referenceField: [{
|
|
109
|
+
type: Input
|
|
110
|
+
}], token: [{
|
|
111
|
+
type: Input
|
|
112
|
+
}], valueChange: [{
|
|
113
|
+
type: Output
|
|
114
|
+
}] } });
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-radio.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/custom-radio/custom-radio.component.ts","../../../../../../projects/nxt-app/src/lib/components/custom-radio/custom-radio.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC/E,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;;;;;;AAY1D,MAAM,OAAO,oBAAoB;IAqBrB;IACA;IACD;IArBA,OAAO,GAAU,EAAE,CAAC;IACpB,OAAO,CAAS;IAChB,aAAa,CAAS;IACtB,WAAW,CAAU;IACrB,EAAE,CAAS;IACX,QAAQ,GAAG,KAAK,CAAC;IACjB,YAAY,CAAS;IACrB,KAAK,CAAM;IACX,WAAW,GAAY,KAAK,CAAC;IAC7B,cAAc,CAAS;IACvB,KAAK,CAAS;IACb,WAAW,GAAgC,IAAI,YAAY,EAAiB,CAAC;IACvF,eAAe,GAAa,EAAE,CAAC;IAExB,UAAU,CAAS;IACnB,UAAU,CAAS;IAC1B,YAAY,CAAe;IAE3B,YACU,aAA4B,EAC5B,WAAwB,EACzB,WAAwB;QAFvB,kBAAa,GAAb,aAAa,CAAe;QAC5B,gBAAW,GAAX,WAAW,CAAa;QACzB,gBAAW,GAAX,WAAW,CAAa;QAE/B,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YACpD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,QAAQ;QACN,wBAAwB;QACxB,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,MAAM,GAAY,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC/C,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,KAAK,CAAC;YAE/B,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,SAAS,CAAC,CAAC,WAAW,EAAE,EAAE;gBACvE,IAAI,SAAS,CAAC;gBACd,IAAI,MAAM,CAAC,QAAQ,EAAE;oBACnB,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC;oBACpE,IAAI,OAAO,GAAG,EAAE,CAAC;oBACjB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE;wBAC1C,IAAI,IAAI,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;wBACxB,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;qBACpB;oBACD,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;iBACxB;qBAAM;oBACL,SAAS,GAAG,WAAW,CAAC;oBACxB,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;iBAC1B;YACH,CAAC,CAAC,CAAC;YAEH,IAAI,QAAQ,GAAG,MAAM,CAAC,gBAAgB,CAAC;YACvC,IAAI,QAAQ,EAAE;gBACZ,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,SAAS,CAC/D,CAAC,WAAW,EAAE,EAAE;oBACd,IAAI,WAAW,IAAI,SAAS,EAAE;wBAC5B,IAAI,WAAW,CAAC,QAAQ,IAAI,SAAS,IAAI,WAAW,CAAC,cAAc,IAAI,MAAM,CAAC,gBAAgB,EAAE;4BAC9F,IAAI,CAAC,aAAa,GAAG,WAAW,CAAC,QAAQ,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;4BAC7D,IAAI,KAAK,GAAG,EAAE,CAAC;4BACf,KAAK,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC;4BACnC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;yBACzB;wBACD,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;qBAC3D;gBACH,CAAC,CACF,CAAC;aACH;SACF;IACH,CAAC;IAED,WAAW,CAAC,KAAU;QACpB,IAAI,MAAM,GAAG,IAAI,aAAa,EAAE,CAAC;QACjC,MAAM,CAAC,cAAc,GAAG,IAAI,CAAC,EAAE,CAAC;QAChC,MAAM,CAAC,QAAQ,GAAG,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QAC3D,MAAM,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC;QAC5C,MAAM,CAAC,WAAW,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACzD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC9B,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;SAC3B;IACH,CAAC;uGAjFU,oBAAoB;2FAApB,oBAAoB,6WCbjC,44BAmBE;;2FDNW,oBAAoB;kBALhC,SAAS;+BACE,kBAAkB;wJAMnB,OAAO;sBAAf,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,EAAE;sBAAV,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACI,WAAW;sBAApB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { ChangeWrapper } from '../../model/changeWrapper';\r\nimport { ChangeService } from '../../services/change.service';\r\nimport { I18nService } from '../../i18n.service';\r\nimport { DataService } from '../../services/data.service';\r\nimport { Subscription } from 'rxjs';\r\nimport { APIMeta } from '../../interfaces/apimeta';\r\n\r\n@Component({\r\n  selector: 'app-custom-radio',\r\n  templateUrl: './custom-radio.component.html',\r\n  styleUrls: ['./custom-radio.component.css']\r\n})\r\nexport class CustomRadioComponent implements OnInit {\r\n\r\n  @Input() options: any[] = [];\r\n  @Input() apiMeta: string;\r\n  @Input() selectedValue: string;\r\n  @Input() progressBar: boolean;\r\n  @Input() id: string;\r\n  @Input() readOnly = false;\r\n  @Input() errorMessage: string;\r\n  @Input() error: any;\r\n  @Input() fromShengel: boolean = false;\r\n  @Input() referenceField: string;\r\n  @Input() token: string;\r\n  @Output() valueChange: EventEmitter<ChangeWrapper> = new EventEmitter<ChangeWrapper>();\r\n  invalidFieldIds: string[] = [];\r\n\r\n  public labelField: string;\r\n  public valueField: string;\r\n  subscription: Subscription;\r\n\r\n  constructor(\r\n    private changeService: ChangeService,\r\n    private dataService: DataService,\r\n    public i18nService: I18nService\r\n  ) {\r\n    this.changeService.submitValidate$.subscribe((data) => {\r\n      this.invalidFieldIds.push(data);\r\n    });\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    // VD 31NOV24 null check\r\n    if (this.apiMeta) {\r\n      let apiObj: APIMeta = JSON.parse(this.apiMeta);\r\n      this.labelField = apiObj.field;\r\n\r\n      this.dataService.apiResponse(apiObj.endpoint)?.subscribe((apiResponse) => {\r\n        let responses;\r\n        if (apiObj.variable) {\r\n          responses = this.dataService.getValue(apiResponse, apiObj.variable);\r\n          let results = [];\r\n          for (let i = 0; i < responses?.length; i++) {\r\n            var resp = responses[i];\r\n            results.push(resp);\r\n          }\r\n          this.options = results;\r\n        } else {\r\n          responses = apiResponse;\r\n          this.options = responses;\r\n        }\r\n      });\r\n\r\n      let sourceId = apiObj.sourceQuestionId;\r\n      if (sourceId) {\r\n        this.subscription = this.changeService.changeAnnounced$.subscribe(\r\n          (changeValue) => {\r\n            if (changeValue != undefined) {\r\n              if (changeValue.valueObj != undefined && changeValue.fromQuestionId == apiObj.sourceQuestionId) {\r\n                this.selectedValue = changeValue.valueObj[apiObj.valueField];\r\n                let value = {};\r\n                value['name'] = this.selectedValue;\r\n                this.radioChange(value);\r\n              }\r\n              this.changeService.confirmChange(apiObj.sourceQuestionId);\r\n            }\r\n          }\r\n        );\r\n      }\r\n    }\r\n  }\r\n\r\n  radioChange(event: any) {\r\n    let change = new ChangeWrapper();\r\n    change.fromQuestionId = this.id;\r\n    change.valueObj = event.target?.id ? event.target?.id : '';\r\n    change.referenceField = this.referenceField;\r\n    change.selectedObj = event ? event[this.labelField] : '';\r\n    this.valueChange.emit(change);\r\n    if (event) {\r\n      this.invalidFieldIds = [];\r\n    }\r\n  }\r\n\r\n}\r\n","<!-- RS 09DEC24 Changed keys--> \r\n<div class=\"custom-radio-container\">\r\n    <div\r\n      *ngFor=\"let option of options\"\r\n      [class]=\"invalidFieldIds.includes(id) || error ? 'custom-radio-option invalid' : 'custom-radio-option'\"\r\n    >\r\n      <input\r\n        type=\"radio\"\r\n        [id]=\"apiMeta !== undefined ? option[labelField] : option.value \"\r\n        [checked] = \"selectedValue == option.value \"\r\n        [name]=\"id\"\r\n        [value]=\"selectedValue\"\r\n        (change)=\"radioChange($event)\"\r\n        [disabled]=\"readOnly\"\r\n      />\r\n      <label class=\"nxt-radio-label\" [for]=\"apiMeta !== undefined ? option[labelField] : option.value\">{{ apiMeta !== undefined ? option[labelField] : option.value  }}</label>\r\n    </div>\r\n    <span *ngIf=\"error || invalidFieldIds.includes(id)\" class=\"error-msg\">{{ errorMessage }}</span>\r\n  </div>\r\n  "]}
|
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
// RS 06JAN2025
|
|
2
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
3
|
+
import Quill from 'quill';
|
|
4
|
+
import { Mention } from 'quill-mention';
|
|
5
|
+
import ImageResize from 'quill-image-resize-module';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "../../i18n.service";
|
|
8
|
+
import * as i2 from "../../services/change.service";
|
|
9
|
+
import * as i3 from "ngx-quill";
|
|
10
|
+
import * as i4 from "@angular/common";
|
|
11
|
+
import * as i5 from "@angular/forms";
|
|
12
|
+
// Register Quill modules
|
|
13
|
+
Quill.register('modules/mention', Mention);
|
|
14
|
+
Quill.register('modules/imageResize', ImageResize);
|
|
15
|
+
// Define font families with their display names and actual CSS values
|
|
16
|
+
const fontFamilyArr = [
|
|
17
|
+
"Roboto Condensed",
|
|
18
|
+
"Times New Roman",
|
|
19
|
+
"Calibri",
|
|
20
|
+
"Calibri Light",
|
|
21
|
+
"Sans-Serif",
|
|
22
|
+
"Arial",
|
|
23
|
+
"Verdana",
|
|
24
|
+
"Georgia",
|
|
25
|
+
"Courier New",
|
|
26
|
+
"Comic Sans MS",
|
|
27
|
+
"Trebuchet MS",
|
|
28
|
+
"Lucida Console",
|
|
29
|
+
"Tahoma",
|
|
30
|
+
"Impact",
|
|
31
|
+
"Palatino Linotype",
|
|
32
|
+
"Segoe UI",
|
|
33
|
+
"Helvetica"
|
|
34
|
+
];
|
|
35
|
+
let fonts = Quill.import("attributors/style/font");
|
|
36
|
+
fonts.whitelist = fontFamilyArr; // Updated with additional fonts
|
|
37
|
+
Quill.register(fonts, true);
|
|
38
|
+
export const QuillConfiguration = {
|
|
39
|
+
toolbar: {
|
|
40
|
+
container: [
|
|
41
|
+
[{ 'font': fontFamilyArr }],
|
|
42
|
+
['bold', 'italic', 'underline', 'strike'],
|
|
43
|
+
['blockquote', 'code-block'],
|
|
44
|
+
[{ header: [1, 2, 3, 4, 5, 6, false] }],
|
|
45
|
+
[{ list: 'ordered' }, { list: 'bullet' }],
|
|
46
|
+
[{ color: [] }, { background: [] }],
|
|
47
|
+
[{ align: [] }],
|
|
48
|
+
['link', 'image', 'video'],
|
|
49
|
+
['formula'],
|
|
50
|
+
['clean'],
|
|
51
|
+
],
|
|
52
|
+
},
|
|
53
|
+
imageResize: {
|
|
54
|
+
displaySize: true,
|
|
55
|
+
modules: ['Resize', 'DisplaySize', 'Toolbar'],
|
|
56
|
+
toolbarStyles: {
|
|
57
|
+
backgroundColor: 'black',
|
|
58
|
+
border: 'none',
|
|
59
|
+
color: 'white'
|
|
60
|
+
},
|
|
61
|
+
handleStyles: {
|
|
62
|
+
backgroundColor: 'black',
|
|
63
|
+
border: 'none',
|
|
64
|
+
color: 'white'
|
|
65
|
+
}
|
|
66
|
+
},
|
|
67
|
+
mention: {
|
|
68
|
+
allowedChars: /^[A-Za-z\sÅÄÖåäö]*$/,
|
|
69
|
+
mentionDenotationChars: ['@', '#'],
|
|
70
|
+
source: function (searchTerm, renderList) {
|
|
71
|
+
const values = [
|
|
72
|
+
{ id: 1, value: 'User 1' },
|
|
73
|
+
{ id: 2, value: 'User 2' },
|
|
74
|
+
];
|
|
75
|
+
if (searchTerm.length === 0) {
|
|
76
|
+
renderList(values, searchTerm);
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
const matches = values.filter((item) => item.value.toLowerCase().includes(searchTerm.toLowerCase()));
|
|
80
|
+
renderList(matches, searchTerm);
|
|
81
|
+
}
|
|
82
|
+
},
|
|
83
|
+
},
|
|
84
|
+
};
|
|
85
|
+
export class CustomRichTextComponent {
|
|
86
|
+
i18nService;
|
|
87
|
+
changeService;
|
|
88
|
+
value = '';
|
|
89
|
+
placeholder;
|
|
90
|
+
error;
|
|
91
|
+
question;
|
|
92
|
+
rows; //The number of visible text lines for the control
|
|
93
|
+
readOnly = false;
|
|
94
|
+
textValueChange = new EventEmitter();
|
|
95
|
+
minLength;
|
|
96
|
+
maxLength;
|
|
97
|
+
// @Input() value: any = ''; // Set default value
|
|
98
|
+
quillConfiguration = QuillConfiguration;
|
|
99
|
+
subscription;
|
|
100
|
+
constructor(i18nService, changeService) {
|
|
101
|
+
this.i18nService = i18nService;
|
|
102
|
+
this.changeService = changeService;
|
|
103
|
+
}
|
|
104
|
+
ngOnInit() {
|
|
105
|
+
console.log('Rich Text Init:', {
|
|
106
|
+
value: this.value,
|
|
107
|
+
question: this.question
|
|
108
|
+
});
|
|
109
|
+
if (this.value === undefined || this.value === null) {
|
|
110
|
+
this.value = '';
|
|
111
|
+
this.textValueChange.emit('');
|
|
112
|
+
}
|
|
113
|
+
this.initializeDependency();
|
|
114
|
+
}
|
|
115
|
+
// Separated dependency initialization for better organization
|
|
116
|
+
initializeDependency() {
|
|
117
|
+
if (this.question?.subText) {
|
|
118
|
+
console.log('subText:', this.question.subText);
|
|
119
|
+
try {
|
|
120
|
+
const dependencyObj = JSON.parse(this.question.subText);
|
|
121
|
+
if (dependencyObj?.sourceQuestionId) {
|
|
122
|
+
this.subscription = this.changeService.changeAnnounced$.subscribe((changeValue) => {
|
|
123
|
+
console.log('Change Value:', changeValue);
|
|
124
|
+
if (changeValue && changeValue.valueObj &&
|
|
125
|
+
changeValue.fromQuestionId === dependencyObj.sourceQuestionId) {
|
|
126
|
+
this.value = changeValue.valueObj[dependencyObj.valueField];
|
|
127
|
+
this.textValueChange.emit(this.value);
|
|
128
|
+
}
|
|
129
|
+
this.changeService.confirmChange(dependencyObj.sourceQuestionId);
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
catch (error) {
|
|
134
|
+
console.error('Error parsing subText:', error);
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
onEditorChange(event) {
|
|
139
|
+
if (event && event.html !== undefined) {
|
|
140
|
+
this.textValueChange.emit(event.html);
|
|
141
|
+
}
|
|
142
|
+
else {
|
|
143
|
+
this.textValueChange.emit('');
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
// Added ngOnDestroy to prevent memory leaks
|
|
147
|
+
ngOnDestroy() {
|
|
148
|
+
if (this.subscription) {
|
|
149
|
+
this.subscription.unsubscribe();
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomRichTextComponent, deps: [{ token: i1.I18nService }, { token: i2.ChangeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
153
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CustomRichTextComponent, selector: "app-custom-rich-text", inputs: { value: "value", placeholder: "placeholder", error: "error", question: "question", rows: "rows", readOnly: "readOnly", minLength: "minLength", maxLength: "maxLength" }, outputs: { textValueChange: "textValueChange" }, ngImport: i0, template: "<!-- RS 06JAN25 -->\r\n<div class=\"rich-text-container\" >\r\n <quill-editor\r\n [(ngModel)]=\"value\"\r\n [placeholder]=\"placeholder\"\r\n [modules]=\"quillConfiguration\"\r\n [readOnly]=\"readOnly\"\r\n (onContentChanged)=\"onEditorChange($event)\"\r\n [class.error]=\"error\">\r\n </quill-editor>\r\n <div *ngIf=\"error\" class=\"error-message\">\r\n {{ error }}\r\n </div>\r\n</div>", styles: [".rich-text-container{width:100%;margin:10px 0}.error{border:1px solid red}:is() .ql-editor img{cursor:pointer}:is() .image-resizer{display:block!important;visibility:visible!important}:is() .ql-editor .image-resizer{border:1px dashed #000;position:absolute}:is() .ql-editor .image-resizer .handle{background-color:#000;border:1px solid #fff;border-radius:50%;height:12px;width:12px;position:absolute}\n"], dependencies: [{ kind: "component", type: i3.QuillEditorComponent, selector: "quill-editor" }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
|
|
154
|
+
}
|
|
155
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomRichTextComponent, decorators: [{
|
|
156
|
+
type: Component,
|
|
157
|
+
args: [{ selector: 'app-custom-rich-text', template: "<!-- RS 06JAN25 -->\r\n<div class=\"rich-text-container\" >\r\n <quill-editor\r\n [(ngModel)]=\"value\"\r\n [placeholder]=\"placeholder\"\r\n [modules]=\"quillConfiguration\"\r\n [readOnly]=\"readOnly\"\r\n (onContentChanged)=\"onEditorChange($event)\"\r\n [class.error]=\"error\">\r\n </quill-editor>\r\n <div *ngIf=\"error\" class=\"error-message\">\r\n {{ error }}\r\n </div>\r\n</div>", styles: [".rich-text-container{width:100%;margin:10px 0}.error{border:1px solid red}:is() .ql-editor img{cursor:pointer}:is() .image-resizer{display:block!important;visibility:visible!important}:is() .ql-editor .image-resizer{border:1px dashed #000;position:absolute}:is() .ql-editor .image-resizer .handle{background-color:#000;border:1px solid #fff;border-radius:50%;height:12px;width:12px;position:absolute}\n"] }]
|
|
158
|
+
}], ctorParameters: function () { return [{ type: i1.I18nService }, { type: i2.ChangeService }]; }, propDecorators: { value: [{
|
|
159
|
+
type: Input
|
|
160
|
+
}], placeholder: [{
|
|
161
|
+
type: Input
|
|
162
|
+
}], error: [{
|
|
163
|
+
type: Input
|
|
164
|
+
}], question: [{
|
|
165
|
+
type: Input
|
|
166
|
+
}], rows: [{
|
|
167
|
+
type: Input
|
|
168
|
+
}], readOnly: [{
|
|
169
|
+
type: Input
|
|
170
|
+
}], textValueChange: [{
|
|
171
|
+
type: Output
|
|
172
|
+
}], minLength: [{
|
|
173
|
+
type: Input
|
|
174
|
+
}], maxLength: [{
|
|
175
|
+
type: Input
|
|
176
|
+
}] } });
|
|
177
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-rich-text.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/custom-rich-text/custom-rich-text.component.ts","../../../../../../projects/nxt-app/src/lib/components/custom-rich-text/custom-rich-text.component.html"],"names":[],"mappings":"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","sourcesContent":["// RS 06JAN2025\r\nimport { Component, EventEmitter, Input, OnInit, Output, OnDestroy } from '@angular/core';\r\nimport { I18nService } from '../../i18n.service';\r\nimport { Subscription } from 'rxjs';\r\nimport { ChangeService } from '../../services/change.service';\r\nimport { DependencyMeta } from '../../interfaces/dependencyMeta';\r\nimport { QuillModules } from 'ngx-quill';\r\nimport Quill from 'quill';\r\nimport { Mention } from 'quill-mention';\r\nimport ImageResize from 'quill-image-resize-module';\r\n\r\n// Register Quill modules\r\nQuill.register('modules/mention', Mention);\r\nQuill.register('modules/imageResize', ImageResize);\r\n\r\n// Define font families with their display names and actual CSS values\r\nconst fontFamilyArr = [\r\n  \"Roboto Condensed\", \r\n  \"Times New Roman\", \r\n  \"Calibri\", \r\n  \"Calibri Light\", \r\n  \"Sans-Serif\", \r\n  \"Arial\", \r\n  \"Verdana\", \r\n  \"Georgia\", \r\n  \"Courier New\", \r\n  \"Comic Sans MS\", \r\n  \"Trebuchet MS\", \r\n  \"Lucida Console\", \r\n  \"Tahoma\", \r\n  \"Impact\", \r\n  \"Palatino Linotype\", \r\n  \"Segoe UI\", \r\n  \"Helvetica\"\r\n];\r\nlet fonts = Quill.import(\"attributors/style/font\");\r\nfonts.whitelist = fontFamilyArr; // Updated with additional fonts\r\nQuill.register(fonts, true);\r\n\r\nexport const QuillConfiguration: QuillModules = {\r\n  toolbar: {\r\n    container: [\r\n      [{ 'font': fontFamilyArr }],\r\n      ['bold', 'italic', 'underline', 'strike'],\r\n      ['blockquote', 'code-block'],\r\n      [{ header: [1, 2, 3, 4, 5, 6, false] }],\r\n      [{ list: 'ordered' }, { list: 'bullet' }],\r\n      [{ color: [] }, { background: [] }],\r\n      [{ align: [] }],\r\n      ['link', 'image', 'video'],\r\n      ['formula'],\r\n      ['clean'],\r\n    ],\r\n  },\r\nimageResize: {\r\n  displaySize: true,\r\n  modules: ['Resize', 'DisplaySize', 'Toolbar'],\r\n  toolbarStyles: {\r\n    backgroundColor: 'black',\r\n    border: 'none',\r\n    color: 'white'\r\n  },\r\n  handleStyles: {\r\n    backgroundColor: 'black',\r\n    border: 'none',\r\n    color: 'white'\r\n  }\r\n},\r\n  mention: {\r\n    allowedChars: /^[A-Za-z\\sÅÄÖåäö]*$/,\r\n    mentionDenotationChars: ['@', '#'],\r\n    source: function (searchTerm: string, renderList: any) {\r\n      const values = [\r\n        { id: 1, value: 'User 1' },\r\n        { id: 2, value: 'User 2' },\r\n      ];\r\n\r\n      if (searchTerm.length === 0) {\r\n        renderList(values, searchTerm);\r\n      } else {\r\n        const matches = values.filter((item) =>\r\n          item.value.toLowerCase().includes(searchTerm.toLowerCase())\r\n        );\r\n        renderList(matches, searchTerm);\r\n      }\r\n    },\r\n  },\r\n};\r\n\r\n@Component({\r\n  selector: 'app-custom-rich-text',\r\n  templateUrl: './custom-rich-text.component.html',\r\n  styleUrls: ['./custom-rich-text.component.css']\r\n})\r\n\r\nexport class CustomRichTextComponent implements OnInit, OnDestroy { \r\n  @Input() value: any | any[] = '';\r\n  @Input() placeholder: string;\r\n  @Input() error: any;\r\n  @Input() question: any;\r\n  @Input() rows:Number; //The number of visible text lines for the control\r\n  @Input() readOnly = false;\r\n  @Output() textValueChange: EventEmitter<string> = new EventEmitter<string>();\r\n  @Input() minLength?: number;\r\n  @Input() maxLength?: number;\r\n  // @Input() value: any = ''; // Set default value\r\n\r\n  quillConfiguration: QuillModules = QuillConfiguration;\r\n  subscription: Subscription;  \r\n\r\n  constructor(\r\n    public i18nService: I18nService,\r\n    private changeService: ChangeService\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    console.log('Rich Text Init:', {\r\n      value: this.value,\r\n      question: this.question\r\n    });\r\n    if (this.value === undefined || this.value === null) {\r\n      this.value = '';\r\n      this.textValueChange.emit('');\r\n\r\n    }\r\n    this.initializeDependency();\r\n  }\r\n\r\n  // Separated dependency initialization for better organization\r\n  private initializeDependency(): void {\r\n    if (this.question?.subText) {\r\n        console.log('subText:', this.question.subText);\r\n        try {\r\n            const dependencyObj: DependencyMeta = JSON.parse(this.question.subText);\r\n            if (dependencyObj?.sourceQuestionId) {\r\n                this.subscription = this.changeService.changeAnnounced$.subscribe(\r\n                    (changeValue) => {\r\n                        console.log('Change Value:', changeValue);\r\n                        if (changeValue && changeValue.valueObj &&\r\n                            changeValue.fromQuestionId === dependencyObj.sourceQuestionId) {\r\n                            this.value = changeValue.valueObj[dependencyObj.valueField];\r\n                            this.textValueChange.emit(this.value);\r\n                        }\r\n                        this.changeService.confirmChange(dependencyObj.sourceQuestionId);\r\n                    }\r\n                );\r\n            }\r\n        } catch (error) {\r\n            console.error('Error parsing subText:', error);\r\n        }\r\n    }\r\n}\r\n\r\n\r\nonEditorChange(event: any): void {\r\n  if (event && event.html !== undefined) {\r\n    this.textValueChange.emit(event.html);\r\n  } else {\r\n    this.textValueChange.emit('');\r\n  }\r\n}\r\n  // Added ngOnDestroy to prevent memory leaks\r\n  ngOnDestroy(): void {\r\n    if (this.subscription) {\r\n      this.subscription.unsubscribe();\r\n    }\r\n  }\r\n}\r\n\r\n","<!-- RS 06JAN25 -->\r\n<div class=\"rich-text-container\" >\r\n  <quill-editor\r\n    [(ngModel)]=\"value\"\r\n    [placeholder]=\"placeholder\"\r\n    [modules]=\"quillConfiguration\"\r\n    [readOnly]=\"readOnly\"\r\n    (onContentChanged)=\"onEditorChange($event)\"\r\n    [class.error]=\"error\">\r\n  </quill-editor>\r\n  <div *ngIf=\"error\" class=\"error-message\">\r\n    {{ error }}\r\n  </div>\r\n</div>"]}
|