@ng-formworks/material 17.5.7 → 17.6.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/material-design-framework.component.mjs +2 -2
- package/esm2022/lib/widgets/flex-layout-root.component.mjs +25 -6
- package/esm2022/lib/widgets/material-button-group.component.mjs +5 -2
- package/esm2022/lib/widgets/material-button.component.mjs +3 -2
- package/esm2022/lib/widgets/material-checkbox.component.mjs +5 -2
- package/esm2022/lib/widgets/material-checkboxes.component.mjs +9 -2
- package/esm2022/lib/widgets/material-chip-list.component.mjs +5 -2
- package/esm2022/lib/widgets/material-datepicker.component.mjs +5 -2
- package/esm2022/lib/widgets/material-file.component.mjs +5 -2
- package/esm2022/lib/widgets/material-input.component.mjs +4 -1
- package/esm2022/lib/widgets/material-number.component.mjs +4 -1
- package/esm2022/lib/widgets/material-one-of.component.mjs +73 -5
- package/esm2022/lib/widgets/material-radios.component.mjs +5 -2
- package/esm2022/lib/widgets/material-select.component.mjs +99 -5
- package/esm2022/lib/widgets/material-stepper.component.mjs +5 -2
- package/esm2022/lib/widgets/material-tabs.component.mjs +104 -26
- package/esm2022/lib/widgets/material-textarea.component.mjs +5 -2
- package/fesm2022/ng-formworks-material.mjs +394 -100
- package/fesm2022/ng-formworks-material.mjs.map +1 -1
- package/lib/widgets/flex-layout-root.component.d.ts +9 -1
- package/lib/widgets/material-button-group.component.d.ts +3 -2
- package/lib/widgets/material-checkbox.component.d.ts +3 -2
- package/lib/widgets/material-checkboxes.component.d.ts +3 -2
- package/lib/widgets/material-chip-list.component.d.ts +3 -2
- package/lib/widgets/material-datepicker.component.d.ts +3 -2
- package/lib/widgets/material-file.component.d.ts +3 -2
- package/lib/widgets/material-input.component.d.ts +3 -2
- package/lib/widgets/material-number.component.d.ts +3 -2
- package/lib/widgets/material-one-of.component.d.ts +6 -2
- package/lib/widgets/material-radios.component.d.ts +3 -2
- package/lib/widgets/material-select.component.d.ts +5 -2
- package/lib/widgets/material-stepper.component.d.ts +3 -2
- package/lib/widgets/material-textarea.component.d.ts +3 -2
- package/lib/widgets/public_api.d.ts +1 -1
- package/package.json +3 -3
|
@@ -46,6 +46,9 @@ export class MaterialNumberComponent {
|
|
|
46
46
|
updateValue(event) {
|
|
47
47
|
this.jsf.updateValue(this, event.target.value);
|
|
48
48
|
}
|
|
49
|
+
ngOnDestroy() {
|
|
50
|
+
this.jsf.updateValue(this, null);
|
|
51
|
+
}
|
|
49
52
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MaterialNumberComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
50
53
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.12", type: MaterialNumberComponent, selector: "material-number-widget", inputs: { layoutNode: { classPropertyName: "layoutNode", publicName: "layoutNode", isSignal: true, isRequired: false, transformFunction: null }, layoutIndex: { classPropertyName: "layoutIndex", publicName: "layoutIndex", isSignal: true, isRequired: false, transformFunction: null }, dataIndex: { classPropertyName: "dataIndex", publicName: "dataIndex", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
|
|
51
54
|
<mat-form-field [appearance]="options?.appearance || matFormFieldDefaultOptions?.appearance || 'fill'"
|
|
@@ -163,4 +166,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
163
166
|
<mat-error *ngIf="options?.showErrors && options?.errorMessage"
|
|
164
167
|
[innerHTML]="options?.errorMessage"></mat-error>`, styles: ["mat-error{font-size:75%;margin-top:-1rem;margin-bottom:.5rem}::ng-deep json-schema-form mat-form-field .mat-mdc-form-field-wrapper .mat-form-field-flex .mat-form-field-infix{width:initial}\n"] }]
|
|
165
168
|
}] });
|
|
166
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
169
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"material-number.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-material/src/lib/widgets/material-number.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAqB,MAAM,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAE5E,OAAO,EAAE,8BAA8B,EAAE,MAAM,8BAA8B,CAAC;AAC9E,OAAO,EAAE,qBAAqB,EAAE,MAAM,oBAAoB,CAAC;;;;;;;AAmE3D,MAAM,OAAO,uBAAuB;IAjEpC;QAkEE,+BAA0B,GAAG,MAAM,CAAC,8BAA8B,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QAChF,QAAG,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;QAK5C,oBAAe,GAAG,KAAK,CAAC;QACxB,iBAAY,GAAG,KAAK,CAAC;QAErB,kBAAa,GAAG,IAAI,CAAC;QACrB,iBAAY,GAAG,IAAI,CAAC;QACpB,mBAAc,GAAG,KAAK,CAAC;QACvB,oBAAe,GAAG,EAAE,CAAC;QACZ,eAAU,GAAG,KAAK,CAAM,SAAS,CAAC,CAAC;QACnC,gBAAW,GAAG,KAAK,CAAW,SAAS,CAAC,CAAC;QACzC,cAAS,GAAG,KAAK,CAAW,SAAS,CAAC,CAAC;KAkCjD;IAhCC,+FAA+F;IAC/F,IAAI,eAAe;QAChB,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC,mBAAmB,CAAC,CAAC;IAC9C,CAAC;IAEC,mDAAmD;IACnD,yDAAyD;IACzD,WAAW,CAAC,CAAC;QACX,CAAC,CAAC,eAAe,EAAE,CAAC;IACtB,CAAC;IAED,YAAY,CAAC,CAAC;QACZ,CAAC,CAAC,eAAe,EAAE,CAAC;IACtB,CAAC;IAEH,QAAQ;QACN,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,OAAO,IAAI,EAAE,CAAC;QAC/C,IAAI,CAAC,GAAG,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QACjC,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC,QAAQ,KAAK,SAAS,EAAE;YAAE,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;SAAE;QAC5E,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE;YAClF,IAAI,CAAC,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC;SACrD;IACH,CAAC;IAED,WAAW,CAAC,KAAK;QACf,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,EAAE,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACjD,CAAC;IAED,WAAW;QACT,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACnC,CAAC;+GAhDU,uBAAuB;mGAAvB,uBAAuB,+dA9DxB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uDAuD2C;;4FAO1C,uBAAuB;kBAjEnC,SAAS;+BAEE,wBAAwB,YACxB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uDAuD2C","sourcesContent":["import { Component, OnDestroy, OnInit, inject, input } from '@angular/core';\r\nimport { AbstractControl } from '@angular/forms';\r\nimport { MAT_FORM_FIELD_DEFAULT_OPTIONS } from '@angular/material/form-field';\r\nimport { JsonSchemaFormService } from '@ng-formworks/core';\r\n\r\n@Component({\r\n  // tslint:disable-next-line:component-selector\r\n  selector: 'material-number-widget',\r\n  template: `\r\n    <mat-form-field [appearance]=\"options?.appearance || matFormFieldDefaultOptions?.appearance || 'fill'\"\r\n    [class]=\"options?.htmlClass || ''\" class=\"sortable-filter\"\r\n    [floatLabel]=\"options?.floatLabel || matFormFieldDefaultOptions?.floatLabel || (options?.notitle ? 'never' : 'auto')\"\r\n    [hideRequiredMarker]=\"options?.hideRequired ? 'true' : 'false'\"\r\n    [style.width]=\"'100%'\">\r\n    <mat-label *ngIf=\"!options?.notitle\">{{options?.title}}</mat-label>\r\n      <span matPrefix *ngIf=\"options?.prefix || options?.fieldAddonLeft\"\r\n        [innerHTML]=\"options?.prefix || options?.fieldAddonLeft\"></span>\r\n      <input matInput *ngIf=\"boundControl\"\r\n        [formControl]=\"formControl\"\r\n        [attr.aria-describedby]=\"'control' + layoutNode()?._id + 'Status'\"\r\n        [attr.max]=\"options?.maximum\"\r\n        [attr.min]=\"options?.minimum\"\r\n        [attr.step]=\"options?.multipleOf || options?.step || 'any'\"\r\n        [id]=\"'control' + layoutNode()?._id\"\r\n        [name]=\"controlName\"\r\n        [placeholder]=\"options?.notitle ? options?.placeholder : options?.title\"\r\n        [readonly]=\"options?.readonly ? 'readonly' : null\"\r\n        [required]=\"options?.required\"\r\n        [style.width]=\"'100%'\"\r\n        [type]=\"'number'\"\r\n        (blur)=\"options.showErrors = true\"\r\n        [attributes]=\"inputAttributes\"\r\n        (mousedown)=\"onMouseDown($event)\"\r\n        (touchstart)=\"onTouchStart($event)\"  \r\n        >\r\n      <input matInput *ngIf=\"!boundControl\"\r\n        [attr.aria-describedby]=\"'control' + layoutNode()?._id + 'Status'\"\r\n        [attr.max]=\"options?.maximum\"\r\n        [attr.min]=\"options?.minimum\"\r\n        [attr.step]=\"options?.multipleOf || options?.step || 'any'\"\r\n        [disabled]=\"controlDisabled\"\r\n        [id]=\"'control' + layoutNode()?._id\"\r\n        [name]=\"controlName\"\r\n        [placeholder]=\"options?.notitle ? options?.placeholder : options?.title\"\r\n        [readonly]=\"options?.readonly ? 'readonly' : null\"\r\n        [required]=\"options?.required\"\r\n        [style.width]=\"'100%'\"\r\n        [type]=\"'number'\"\r\n        [value]=\"controlValue\"\r\n        (input)=\"updateValue($event)\"\r\n        (blur)=\"options.showErrors = true\"\r\n        [attributes]=\"inputAttributes\"\r\n        (mousedown)=\"onMouseDown($event)\"\r\n        (touchstart)=\"onTouchStart($event)\"  \r\n        >\r\n      <span matSuffix *ngIf=\"options?.suffix || options?.fieldAddonRight\"\r\n        [innerHTML]=\"options?.suffix || options?.fieldAddonRight\"></span>\r\n      <mat-hint *ngIf=\"layoutNode()?.type === 'range'\" align=\"start\"\r\n        [innerHTML]=\"controlValue\"></mat-hint>\r\n      <mat-hint *ngIf=\"options?.description && (!options?.showErrors || !options?.errorMessage)\"\r\n        align=\"end\" [innerHTML]=\"options?.description\"></mat-hint>\r\n    </mat-form-field>\r\n    <mat-error *ngIf=\"options?.showErrors && options?.errorMessage\"\r\n      [innerHTML]=\"options?.errorMessage\"></mat-error>`,\r\n  styles: [`\r\n    mat-error { font-size: 75%; margin-top: -1rem; margin-bottom: 0.5rem; }\r\n    ::ng-deep json-schema-form mat-form-field .mat-mdc-form-field-wrapper .mat-form-field-flex\r\n      .mat-form-field-infix { width: initial; }\r\n  `],\r\n})\r\nexport class MaterialNumberComponent implements OnInit,OnDestroy {\r\n  matFormFieldDefaultOptions = inject(MAT_FORM_FIELD_DEFAULT_OPTIONS, { optional: true });\r\n  private jsf = inject(JsonSchemaFormService);\r\n\r\n  formControl: AbstractControl;\r\n  controlName: string;\r\n  controlValue: any;\r\n  controlDisabled = false;\r\n  boundControl = false;\r\n  options: any;\r\n  allowNegative = true;\r\n  allowDecimal = true;\r\n  allowExponents = false;\r\n  lastValidNumber = '';\r\n  readonly layoutNode = input<any>(undefined);\r\n  readonly layoutIndex = input<number[]>(undefined);\r\n  readonly dataIndex = input<number[]>(undefined);\r\n\r\n  //needed as templates don't accept something like [attributes]=\"options?.['x-inputAttributes']\"\r\n  get inputAttributes() {\r\n     return this.options?.['x-inputAttributes'];\r\n  }\r\n \r\n    //TODO review:stopPropagation used as a workaround \r\n    //to prevent dragging onMouseDown and onTouchStart events\r\n    onMouseDown(e){\r\n      e.stopPropagation();\r\n    }\r\n\r\n    onTouchStart(e){\r\n      e.stopPropagation();\r\n    }  \r\n  \r\n  ngOnInit() {\r\n    this.options = this.layoutNode().options || {};\r\n    this.jsf.initializeControl(this);\r\n    if (this.layoutNode().dataType === 'integer') { this.allowDecimal = false; }\r\n    if (!this.options.notitle && !this.options.description && this.options.placeholder) {\r\n      this.options.description = this.options.placeholder;\r\n    }\r\n  }\r\n\r\n  updateValue(event) {\r\n    this.jsf.updateValue(this, event.target.value);\r\n  }\r\n\r\n  ngOnDestroy () {\r\n    this.jsf.updateValue(this, null);\r\n  }\r\n\r\n}\r\n"]}
|
|
@@ -1,9 +1,13 @@
|
|
|
1
|
-
import { Component, input,
|
|
2
|
-
import { JsonSchemaFormService } from '@ng-formworks/core';
|
|
1
|
+
import { Component, inject, input, viewChild } from '@angular/core';
|
|
2
|
+
import { hasNonNullValue, hasOwn, JsonPointer, JsonSchemaFormService, path2ControlKey } from '@ng-formworks/core';
|
|
3
|
+
import { isEqual, isObject } from 'lodash';
|
|
4
|
+
import { MaterialTabsComponent } from './material-tabs.component';
|
|
3
5
|
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "./material-tabs.component";
|
|
4
7
|
// TODO: Add this control
|
|
5
8
|
export class MaterialOneOfComponent {
|
|
6
9
|
constructor() {
|
|
10
|
+
this.tabs = viewChild('tabs', { read: MaterialTabsComponent });
|
|
7
11
|
this.jsf = inject(JsonSchemaFormService);
|
|
8
12
|
this.controlDisabled = false;
|
|
9
13
|
this.boundControl = false;
|
|
@@ -13,20 +17,84 @@ export class MaterialOneOfComponent {
|
|
|
13
17
|
}
|
|
14
18
|
ngOnInit() {
|
|
15
19
|
this.options = this.layoutNode().options || {};
|
|
20
|
+
this.options.tabMode = "oneOfMode";
|
|
21
|
+
this.options.selectedTab = this.findSelectedTab();
|
|
22
|
+
//this.options.description=this.options.description||"choose one of";
|
|
16
23
|
this.jsf.initializeControl(this);
|
|
17
24
|
}
|
|
25
|
+
findSelectedTab() {
|
|
26
|
+
//TODO test- this.jsf.formValues seems to be the initial data supplied to the form
|
|
27
|
+
//while the jsf.formGroup value is derived from the actual controls
|
|
28
|
+
//let formValue=this.jsf.getFormControlValue(this);
|
|
29
|
+
let foundInd = -1;
|
|
30
|
+
//seach for non null value
|
|
31
|
+
if (this.layoutNode().items) {
|
|
32
|
+
this.layoutNode().items.forEach((layoutItem, ind) => {
|
|
33
|
+
let formValue = JsonPointer.get(this.jsf.formValues, layoutItem.dataPointer);
|
|
34
|
+
if (layoutItem.oneOfPointer) {
|
|
35
|
+
let controlKey = path2ControlKey(layoutItem.oneOfPointer);
|
|
36
|
+
let fname = layoutItem.name;
|
|
37
|
+
if (hasOwn(this.jsf.formGroup.controls, controlKey) &&
|
|
38
|
+
(formValue || hasNonNullValue(this.jsf.formGroup.controls[controlKey].value))
|
|
39
|
+
//hasOwn(formValue,fname) && hasOwn(this.jsf.formGroup.controls,controlKey)
|
|
40
|
+
// && (formValue[fname] || this.jsf.formGroup.controls[controlKey].value)
|
|
41
|
+
//&&isEqual(formValue[fname],this.jsf.formGroup.controls[controlKey].value)
|
|
42
|
+
) {
|
|
43
|
+
foundInd = ind;
|
|
44
|
+
}
|
|
45
|
+
//foundInd=formValue[controlKey]!=null?ind:foundInd;
|
|
46
|
+
//if no exact match found, then search in descendant values
|
|
47
|
+
//to see which one of item matches
|
|
48
|
+
if (foundInd == -1) {
|
|
49
|
+
//find all descendant oneof paths
|
|
50
|
+
let descendantOneOfControlNames = Object.keys(this.jsf.formGroup.controls).filter(controlName => {
|
|
51
|
+
return controlName.startsWith(controlKey);
|
|
52
|
+
});
|
|
53
|
+
descendantOneOfControlNames.forEach(controlName => {
|
|
54
|
+
let parts = controlName.split('$');
|
|
55
|
+
let fieldName = parts[parts.length - 1];
|
|
56
|
+
let controlValue = this.jsf.formGroup.controls[controlName].value;
|
|
57
|
+
if (isObject(formValue) && hasOwn(formValue, fieldName) &&
|
|
58
|
+
formValue[fieldName] == controlValue
|
|
59
|
+
//formValue[fieldName]||controlValue
|
|
60
|
+
) {
|
|
61
|
+
foundInd = ind;
|
|
62
|
+
}
|
|
63
|
+
else //if(formValue || controlValue){
|
|
64
|
+
if (isEqual(formValue, controlValue)) {
|
|
65
|
+
foundInd = ind;
|
|
66
|
+
}
|
|
67
|
+
});
|
|
68
|
+
//now need to compare values
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
return Math.max(foundInd, 0);
|
|
74
|
+
}
|
|
18
75
|
updateValue(event) {
|
|
19
76
|
this.jsf.updateValue(this, event.target.value);
|
|
20
77
|
}
|
|
78
|
+
ngOnDestroy() {
|
|
79
|
+
}
|
|
21
80
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MaterialOneOfComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
22
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.
|
|
81
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "17.3.12", type: MaterialOneOfComponent, selector: "material-one-of-widget", inputs: { layoutNode: { classPropertyName: "layoutNode", publicName: "layoutNode", isSignal: true, isRequired: false, transformFunction: null }, layoutIndex: { classPropertyName: "layoutIndex", publicName: "layoutIndex", isSignal: true, isRequired: false, transformFunction: null }, dataIndex: { classPropertyName: "dataIndex", publicName: "dataIndex", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "tabs", first: true, predicate: ["tabs"], descendants: true, read: MaterialTabsComponent, isSignal: true }], ngImport: i0, template: `<h4>{{this.options?.description}}</h4>
|
|
82
|
+
<material-tabs-widget #tabs [layoutNode]="layoutNode()"
|
|
83
|
+
[layoutIndex]="layoutIndex()"
|
|
84
|
+
[dataIndex]="dataIndex()" >
|
|
85
|
+
</material-tabs-widget>`, isInline: true, dependencies: [{ kind: "component", type: i1.MaterialTabsComponent, selector: "material-tabs-widget", inputs: ["layoutNode", "layoutIndex", "dataIndex"] }] }); }
|
|
23
86
|
}
|
|
24
87
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MaterialOneOfComponent, decorators: [{
|
|
25
88
|
type: Component,
|
|
26
89
|
args: [{
|
|
27
90
|
// tslint:disable-next-line:component-selector
|
|
28
91
|
selector: 'material-one-of-widget',
|
|
29
|
-
template:
|
|
92
|
+
template: `<h4>{{this.options?.description}}</h4>
|
|
93
|
+
<material-tabs-widget #tabs [layoutNode]="layoutNode()"
|
|
94
|
+
[layoutIndex]="layoutIndex()"
|
|
95
|
+
[dataIndex]="dataIndex()" >
|
|
96
|
+
</material-tabs-widget>`,
|
|
97
|
+
standalone: false
|
|
30
98
|
}]
|
|
31
99
|
}] });
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"material-one-of.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-material/src/lib/widgets/material-one-of.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAqB,SAAS,EAAE,MAAM,eAAe,CAAC;AAEvF,OAAO,EAAE,eAAe,EAAE,MAAM,EAAE,WAAW,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAClH,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,QAAQ,CAAC;AAC3C,OAAO,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;;;AAGlE,yBAAyB;AAYzB,MAAM,OAAO,sBAAsB;IAVnC;QAYW,SAAI,GAAG,SAAS,CAAC,MAAM,EAAE,EAAE,IAAI,EAAE,qBAAqB,EAAE,CAAC,CAAC;QAE3D,QAAG,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;QAK5C,oBAAe,GAAG,KAAK,CAAC;QACxB,iBAAY,GAAG,KAAK,CAAC;QAEZ,eAAU,GAAG,KAAK,CAAM,SAAS,CAAC,CAAC;QACnC,gBAAW,GAAG,KAAK,CAAW,SAAS,CAAC,CAAC;QACzC,cAAS,GAAG,KAAK,CAAW,SAAS,CAAC,CAAC;KAsEjD;IApEC,QAAQ;QACN,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,OAAO,IAAI,EAAE,CAAC;QAC/C,IAAI,CAAC,OAAO,CAAC,OAAO,GAAC,WAAW,CAAC;QACjC,IAAI,CAAC,OAAO,CAAC,WAAW,GAAC,IAAI,CAAC,eAAe,EAAE,CAAC;QAChD,qEAAqE;QACrE,IAAI,CAAC,GAAG,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;IAEnC,CAAC;IAGD,eAAe;QACb,kFAAkF;QAClF,mEAAmE;QACnE,mDAAmD;QACnD,IAAI,QAAQ,GAAC,CAAC,CAAC,CAAC;QAChB,0BAA0B;QAC1B,IAAG,IAAI,CAAC,UAAU,EAAE,CAAC,KAAK,EAAC;YACzB,IAAI,CAAC,UAAU,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,UAAU,EAAC,GAAG,EAAC,EAAE;gBAChD,IAAI,SAAS,GAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,EAAC,UAAU,CAAC,WAAW,CAAC,CAAC;gBACxE,IAAG,UAAU,CAAC,YAAY,EAAC;oBACzB,IAAI,UAAU,GAAC,eAAe,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;oBACxD,IAAI,KAAK,GAAC,UAAU,CAAC,IAAI,CAAC;oBAC1B,IAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,QAAQ,EAAC,UAAU,CAAC;wBAC/C,CAAC,SAAS,IAAI,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,KAAK,CAAC,CAAC;oBAC7E,4EAA4E;oBAC9E,yEAAyE;oBACvE,2EAA2E;sBAC5E;wBACG,QAAQ,GAAC,GAAG,CAAC;qBAChB;oBACD,oDAAoD;oBACpD,2DAA2D;oBAC3D,kCAAkC;oBAClC,IAAG,QAAQ,IAAE,CAAC,CAAC,EAAC;wBACd,iCAAiC;wBACjC,IAAI,2BAA2B,GAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,WAAW,CAAA,EAAE;4BAC3F,OAAO,WAAW,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;wBAC5C,CAAC,CAAC,CAAA;wBACF,2BAA2B,CAAC,OAAO,CAAC,WAAW,CAAA,EAAE;4BAC/C,IAAI,KAAK,GAAC,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;4BACjC,IAAI,SAAS,GAAC,KAAK,CAAC,KAAK,CAAC,MAAM,GAAC,CAAC,CAAC,CAAC;4BACpC,IAAI,YAAY,GAAC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,KAAK,CAAC;4BAChE,IAAG,QAAQ,CAAC,SAAS,CAAC,IAAI,MAAM,CAAC,SAAS,EAAC,SAAS,CAAC;gCACrD,SAAS,CAAC,SAAS,CAAC,IAAE,YAAY;4BACnC,oCAAoC;8BACpC;gCACG,QAAQ,GAAC,GAAG,CAAC;6BACd;iCAAK,gCAAgC;6BACtC,IAAG,OAAO,CAAC,SAAS,EAAC,YAAY,CAAC,EAAC;gCACjC,QAAQ,GAAC,GAAG,CAAC;6BACd;wBACH,CAAC,CAAC,CAAA;wBACF,4BAA4B;qBAC7B;iBACF;YACL,CAAC,CAAC,CAAA;SACH;QACD,OAAO,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAC,CAAC,CAAC,CAAC;IAC9B,CAAC;IAED,WAAW,CAAC,KAAK;QACf,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,EAAE,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACjD,CAAC;IAED,WAAW;IAEX,CAAC;+GAlFU,sBAAsB;mGAAtB,sBAAsB,wiBAES,qBAAqB,6CATnD;;;;4BAIc;;4FAGf,sBAAsB;kBAVlC,SAAS;mBAAC;oBACP,8CAA8C;oBAC9C,QAAQ,EAAE,wBAAwB;oBAClC,QAAQ,EAAE;;;;4BAIc;oBACxB,UAAU,EAAE,KAAK;iBACpB","sourcesContent":["import { Component, inject, input, OnDestroy, OnInit, viewChild } from '@angular/core';\r\nimport { AbstractControl } from '@angular/forms';\r\nimport { hasNonNullValue, hasOwn, JsonPointer, JsonSchemaFormService, path2ControlKey } from '@ng-formworks/core';\r\nimport { isEqual, isObject } from 'lodash';\r\nimport { MaterialTabsComponent } from './material-tabs.component';\r\n\r\n\r\n// TODO: Add this control\r\n\r\n@Component({\r\n    // tslint:disable-next-line:component-selector\r\n    selector: 'material-one-of-widget',\r\n    template: `<h4>{{this.options?.description}}</h4>\r\n    <material-tabs-widget #tabs [layoutNode]=\"layoutNode()\" \r\n    [layoutIndex]=\"layoutIndex()\" \r\n    [dataIndex]=\"dataIndex()\" >\r\n    </material-tabs-widget>`,\r\n    standalone: false\r\n})\r\nexport class MaterialOneOfComponent implements OnInit,OnDestroy {\r\n\r\n  readonly tabs = viewChild('tabs', { read: MaterialTabsComponent });\r\n\r\n  private jsf = inject(JsonSchemaFormService);\r\n\r\n  formControl: AbstractControl;\r\n  controlName: string;\r\n  controlValue: any;\r\n  controlDisabled = false;\r\n  boundControl = false;\r\n  options: any;\r\n  readonly layoutNode = input<any>(undefined);\r\n  readonly layoutIndex = input<number[]>(undefined);\r\n  readonly dataIndex = input<number[]>(undefined);\r\n\r\n  ngOnInit() {\r\n    this.options = this.layoutNode().options || {};\r\n    this.options.tabMode=\"oneOfMode\";\r\n    this.options.selectedTab=this.findSelectedTab();\r\n    //this.options.description=this.options.description||\"choose one of\";\r\n    this.jsf.initializeControl(this);\r\n    \r\n  }\r\n\r\n\r\n  findSelectedTab(){\r\n    //TODO test- this.jsf.formValues seems to be the initial data supplied to the form\r\n    //while the jsf.formGroup value is derived from the actual controls\r\n    //let formValue=this.jsf.getFormControlValue(this);\r\n    let foundInd=-1;\r\n    //seach for non null value\r\n    if(this.layoutNode().items){\r\n      this.layoutNode().items.forEach((layoutItem,ind)=>{\r\n        let formValue=JsonPointer.get(this.jsf.formValues,layoutItem.dataPointer);\r\n          if(layoutItem.oneOfPointer){\r\n            let controlKey=path2ControlKey(layoutItem.oneOfPointer);\r\n            let fname=layoutItem.name;\r\n            if(hasOwn(this.jsf.formGroup.controls,controlKey)&&\r\n              (formValue || hasNonNullValue(this.jsf.formGroup.controls[controlKey].value))\r\n              //hasOwn(formValue,fname) && hasOwn(this.jsf.formGroup.controls,controlKey) \r\n            // && (formValue[fname] || this.jsf.formGroup.controls[controlKey].value)\r\n              //&&isEqual(formValue[fname],this.jsf.formGroup.controls[controlKey].value)\r\n            ){\r\n                foundInd=ind;\r\n            }\r\n            //foundInd=formValue[controlKey]!=null?ind:foundInd;\r\n            //if no exact match found, then search in descendant values\r\n            //to see which one of item matches\r\n            if(foundInd==-1){\r\n              //find all descendant oneof paths\r\n              let descendantOneOfControlNames=Object.keys(this.jsf.formGroup.controls).filter(controlName=>{\r\n                return controlName.startsWith(controlKey);\r\n              })\r\n              descendantOneOfControlNames.forEach(controlName=>{\r\n                let parts=controlName.split('$');\r\n                let fieldName=parts[parts.length-1];\r\n                let controlValue=this.jsf.formGroup.controls[controlName].value;\r\n                if(isObject(formValue) && hasOwn(formValue,fieldName) && \r\n                formValue[fieldName]==controlValue\r\n               //formValue[fieldName]||controlValue\r\n              ){\r\n                  foundInd=ind;\r\n                }else //if(formValue || controlValue){\r\n                if(isEqual(formValue,controlValue)){\r\n                  foundInd=ind;\r\n                }\r\n              })\r\n              //now need to compare values\r\n            }\r\n          }\r\n      })\r\n    }\r\n    return Math.max(foundInd,0);\r\n  }\r\n\r\n  updateValue(event) {\r\n    this.jsf.updateValue(this, event.target.value);\r\n  }\r\n\r\n  ngOnDestroy () {\r\n    \r\n  }\r\n\r\n}\r\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component,
|
|
1
|
+
import { Component, inject, input } from '@angular/core';
|
|
2
2
|
import { JsonSchemaFormService, buildTitleMap } from '@ng-formworks/core';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@angular/common";
|
|
@@ -28,6 +28,9 @@ export class MaterialRadiosComponent {
|
|
|
28
28
|
this.options.showErrors = true;
|
|
29
29
|
this.jsf.updateValue(this, value);
|
|
30
30
|
}
|
|
31
|
+
ngOnDestroy() {
|
|
32
|
+
this.jsf.updateValue(this, null);
|
|
33
|
+
}
|
|
31
34
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MaterialRadiosComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
32
35
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.12", type: MaterialRadiosComponent, selector: "material-radios-widget", inputs: { layoutNode: { classPropertyName: "layoutNode", publicName: "layoutNode", isSignal: true, isRequired: false, transformFunction: null }, layoutIndex: { classPropertyName: "layoutIndex", publicName: "layoutIndex", isSignal: true, isRequired: false, transformFunction: null }, dataIndex: { classPropertyName: "dataIndex", publicName: "dataIndex", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
|
|
33
36
|
<div>
|
|
@@ -115,4 +118,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
115
118
|
[innerHTML]="options?.errorMessage"></mat-error>
|
|
116
119
|
</div>`, styles: ["mat-radio-group{display:inline-flex}mat-radio-button{margin:2px}mat-error{font-size:75%}\n"] }]
|
|
117
120
|
}] });
|
|
118
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
121
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF0ZXJpYWwtcmFkaW9zLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLWZvcm13b3Jrcy1tYXRlcmlhbC9zcmMvbGliL3dpZGdldHMvbWF0ZXJpYWwtcmFkaW9zLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFxQixNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTVFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxhQUFhLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQzs7Ozs7O0FBdUQxRSxNQUFNLE9BQU8sdUJBQXVCO0lBcERwQztRQXFEVSxRQUFHLEdBQUcsTUFBTSxDQUFDLHFCQUFxQixDQUFDLENBQUM7UUFLNUMsb0JBQWUsR0FBRyxLQUFLLENBQUM7UUFDeEIsaUJBQVksR0FBRyxLQUFLLENBQUM7UUFFckIsa0JBQWEsR0FBRyxRQUFRLENBQUM7UUFDekIsZUFBVSxHQUFVLEVBQUUsQ0FBQztRQUNkLGVBQVUsR0FBRyxLQUFLLENBQU0sU0FBUyxDQUFDLENBQUM7UUFDbkMsZ0JBQVcsR0FBRyxLQUFLLENBQVcsU0FBUyxDQUFDLENBQUM7UUFDekMsY0FBUyxHQUFHLEtBQUssQ0FBVyxTQUFTLENBQUMsQ0FBQztLQXVCakQ7SUFyQkMsUUFBUTtRQUNOLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDLE9BQU8sSUFBSSxFQUFFLENBQUM7UUFDL0MsSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUMsSUFBSSxLQUFLLGVBQWUsRUFBRTtZQUM5QyxJQUFJLENBQUMsYUFBYSxHQUFHLEtBQUssQ0FBQztTQUM1QjtRQUNELElBQUksQ0FBQyxVQUFVLEdBQUcsYUFBYSxDQUM3QixJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsRUFDL0MsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUN4QixDQUFDO1FBQ0YsSUFBSSxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQzNELENBQUM7SUFFRCxXQUFXLENBQUMsS0FBSztRQUNmLElBQUksQ0FBQyxPQUFPLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQztRQUMvQixJQUFJLENBQUMsR0FBRyxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDcEMsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsR0FBRyxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDbkMsQ0FBQzsrR0FsQ1UsdUJBQXVCO21HQUF2Qix1QkFBdUIsK2RBakR4Qjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztXQXdDRDs7NEZBU0UsdUJBQXVCO2tCQXBEbkMsU0FBUzsrQkFFRSx3QkFBd0IsWUFDeEI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7V0F3Q0QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uRGVzdHJveSwgT25Jbml0LCBpbmplY3QsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEFic3RyYWN0Q29udHJvbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgSnNvblNjaGVtYUZvcm1TZXJ2aWNlLCBidWlsZFRpdGxlTWFwIH0gZnJvbSAnQG5nLWZvcm13b3Jrcy9jb3JlJztcclxuXHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6Y29tcG9uZW50LXNlbGVjdG9yXHJcbiAgc2VsZWN0b3I6ICdtYXRlcmlhbC1yYWRpb3Mtd2lkZ2V0JyxcclxuICB0ZW1wbGF0ZTogYFxyXG4gICAgPGRpdj5cclxuICAgICAgPGRpdiAqbmdJZj1cIm9wdGlvbnM/LnRpdGxlXCI+XHJcbiAgICAgICAgPGxhYmVsXHJcbiAgICAgICAgICBbYXR0ci5mb3JdPVwiJ2NvbnRyb2wnICsgbGF5b3V0Tm9kZSgpPy5faWRcIlxyXG4gICAgICAgICAgW2NsYXNzXT1cIm9wdGlvbnM/LmxhYmVsSHRtbENsYXNzIHx8ICcnXCJcclxuICAgICAgICAgIFtzdHlsZS5kaXNwbGF5XT1cIm9wdGlvbnM/Lm5vdGl0bGUgPyAnbm9uZScgOiAnJ1wiXHJcbiAgICAgICAgICBbaW5uZXJIVE1MXT1cIm9wdGlvbnM/LnRpdGxlXCI+PC9sYWJlbD5cclxuICAgICAgPC9kaXY+XHJcbiAgICAgIDxtYXQtcmFkaW8tZ3JvdXAgKm5nSWY9XCJib3VuZENvbnRyb2xcIlxyXG4gICAgICAgIFtmb3JtQ29udHJvbF09XCJmb3JtQ29udHJvbFwiXHJcbiAgICAgICAgW2F0dHIuYXJpYS1kZXNjcmliZWRieV09XCInY29udHJvbCcgKyBsYXlvdXROb2RlKCk/Ll9pZCArICdTdGF0dXMnXCJcclxuICAgICAgICBbYXR0ci5yZWFkb25seV09XCJvcHRpb25zPy5yZWFkb25seSA/ICdyZWFkb25seScgOiBudWxsXCJcclxuICAgICAgICBbYXR0ci5yZXF1aXJlZF09XCJvcHRpb25zPy5yZXF1aXJlZFwiXHJcbiAgICAgICAgW3N0eWxlLmZsZXgtZGlyZWN0aW9uXT1cImZsZXhEaXJlY3Rpb25cIlxyXG4gICAgICAgIFtuYW1lXT1cImNvbnRyb2xOYW1lXCJcclxuICAgICAgICAoYmx1cik9XCJvcHRpb25zLnNob3dFcnJvcnMgPSB0cnVlXCI+XHJcbiAgICAgICAgPG1hdC1yYWRpby1idXR0b24gKm5nRm9yPVwibGV0IHJhZGlvSXRlbSBvZiByYWRpb3NMaXN0XCJcclxuICAgICAgICAgIFtpZF09XCInY29udHJvbCcgKyBsYXlvdXROb2RlKCk/Ll9pZCArICcvJyArIHJhZGlvSXRlbT8ubmFtZVwiXHJcbiAgICAgICAgICBbdmFsdWVdPVwicmFkaW9JdGVtPy52YWx1ZVwiPlxyXG4gICAgICAgICAgPHNwYW4gW2lubmVySFRNTF09XCJyYWRpb0l0ZW0/Lm5hbWVcIj48L3NwYW4+XHJcbiAgICAgICAgPC9tYXQtcmFkaW8tYnV0dG9uPlxyXG4gICAgICA8L21hdC1yYWRpby1ncm91cD5cclxuICAgICAgPG1hdC1yYWRpby1ncm91cCAqbmdJZj1cIiFib3VuZENvbnRyb2xcIlxyXG4gICAgICAgIFthdHRyLmFyaWEtZGVzY3JpYmVkYnldPVwiJ2NvbnRyb2wnICsgbGF5b3V0Tm9kZSgpPy5faWQgKyAnU3RhdHVzJ1wiXHJcbiAgICAgICAgW2F0dHIucmVhZG9ubHldPVwib3B0aW9ucz8ucmVhZG9ubHkgPyAncmVhZG9ubHknIDogbnVsbFwiXHJcbiAgICAgICAgW2F0dHIucmVxdWlyZWRdPVwib3B0aW9ucz8ucmVxdWlyZWRcIlxyXG4gICAgICAgIFtzdHlsZS5mbGV4LWRpcmVjdGlvbl09XCJmbGV4RGlyZWN0aW9uXCJcclxuICAgICAgICBbZGlzYWJsZWRdPVwiY29udHJvbERpc2FibGVkIHx8IG9wdGlvbnM/LnJlYWRvbmx5XCJcclxuICAgICAgICBbbmFtZV09XCJjb250cm9sTmFtZVwiXHJcbiAgICAgICAgW3ZhbHVlXT1cImNvbnRyb2xWYWx1ZVwiPlxyXG4gICAgICAgIDxtYXQtcmFkaW8tYnV0dG9uICpuZ0Zvcj1cImxldCByYWRpb0l0ZW0gb2YgcmFkaW9zTGlzdFwiXHJcbiAgICAgICAgICBbaWRdPVwiJ2NvbnRyb2wnICsgbGF5b3V0Tm9kZSgpPy5faWQgKyAnLycgKyByYWRpb0l0ZW0/Lm5hbWVcIlxyXG4gICAgICAgICAgW3ZhbHVlXT1cInJhZGlvSXRlbT8udmFsdWVcIlxyXG4gICAgICAgICAgKGNsaWNrKT1cInVwZGF0ZVZhbHVlKHJhZGlvSXRlbT8udmFsdWUpXCI+XHJcbiAgICAgICAgICA8c3BhbiBbaW5uZXJIVE1MXT1cInJhZGlvSXRlbT8ubmFtZVwiPjwvc3Bhbj5cclxuICAgICAgICA8L21hdC1yYWRpby1idXR0b24+XHJcbiAgICAgIDwvbWF0LXJhZGlvLWdyb3VwPlxyXG4gICAgICA8bWF0LWVycm9yICpuZ0lmPVwib3B0aW9ucz8uc2hvd0Vycm9ycyAmJiBvcHRpb25zPy5lcnJvck1lc3NhZ2VcIlxyXG4gICAgICAgIFtpbm5lckhUTUxdPVwib3B0aW9ucz8uZXJyb3JNZXNzYWdlXCI+PC9tYXQtZXJyb3I+XHJcbiAgICA8L2Rpdj5gLFxyXG4gIHN0eWxlczogW2BcclxuICAgIC8qIFRPRE8obWRjLW1pZ3JhdGlvbik6IFRoZSBmb2xsb3dpbmcgcnVsZSB0YXJnZXRzIGludGVybmFsIGNsYXNzZXMgb2YgcmFkaW8gdGhhdCBtYXkgbm8gbG9uZ2VyIGFwcGx5IGZvciB0aGUgTURDIHZlcnNpb24uICovXHJcbiAgICBtYXQtcmFkaW8tZ3JvdXAgeyBkaXNwbGF5OiBpbmxpbmUtZmxleDsgfVxyXG4gICAgLyogVE9ETyhtZGMtbWlncmF0aW9uKTogVGhlIGZvbGxvd2luZyBydWxlIHRhcmdldHMgaW50ZXJuYWwgY2xhc3NlcyBvZiByYWRpbyB0aGF0IG1heSBubyBsb25nZXIgYXBwbHkgZm9yIHRoZSBNREMgdmVyc2lvbi4gKi9cclxuICAgIG1hdC1yYWRpby1idXR0b24geyBtYXJnaW46IDJweDsgfVxyXG4gICAgbWF0LWVycm9yIHsgZm9udC1zaXplOiA3NSU7IH1cclxuICBgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTWF0ZXJpYWxSYWRpb3NDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsT25EZXN0cm95IHtcclxuICBwcml2YXRlIGpzZiA9IGluamVjdChKc29uU2NoZW1hRm9ybVNlcnZpY2UpO1xyXG5cclxuICBmb3JtQ29udHJvbDogQWJzdHJhY3RDb250cm9sO1xyXG4gIGNvbnRyb2xOYW1lOiBzdHJpbmc7XHJcbiAgY29udHJvbFZhbHVlOiBhbnk7XHJcbiAgY29udHJvbERpc2FibGVkID0gZmFsc2U7XHJcbiAgYm91bmRDb250cm9sID0gZmFsc2U7XHJcbiAgb3B0aW9uczogYW55O1xyXG4gIGZsZXhEaXJlY3Rpb24gPSAnY29sdW1uJztcclxuICByYWRpb3NMaXN0OiBhbnlbXSA9IFtdO1xyXG4gIHJlYWRvbmx5IGxheW91dE5vZGUgPSBpbnB1dDxhbnk+KHVuZGVmaW5lZCk7XHJcbiAgcmVhZG9ubHkgbGF5b3V0SW5kZXggPSBpbnB1dDxudW1iZXJbXT4odW5kZWZpbmVkKTtcclxuICByZWFkb25seSBkYXRhSW5kZXggPSBpbnB1dDxudW1iZXJbXT4odW5kZWZpbmVkKTtcclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICB0aGlzLm9wdGlvbnMgPSB0aGlzLmxheW91dE5vZGUoKS5vcHRpb25zIHx8IHt9O1xyXG4gICAgaWYgKHRoaXMubGF5b3V0Tm9kZSgpLnR5cGUgPT09ICdyYWRpb3MtaW5saW5lJykge1xyXG4gICAgICB0aGlzLmZsZXhEaXJlY3Rpb24gPSAncm93JztcclxuICAgIH1cclxuICAgIHRoaXMucmFkaW9zTGlzdCA9IGJ1aWxkVGl0bGVNYXAoXHJcbiAgICAgIHRoaXMub3B0aW9ucy50aXRsZU1hcCB8fCB0aGlzLm9wdGlvbnMuZW51bU5hbWVzLFxyXG4gICAgICB0aGlzLm9wdGlvbnMuZW51bSwgdHJ1ZVxyXG4gICAgKTtcclxuICAgIHRoaXMuanNmLmluaXRpYWxpemVDb250cm9sKHRoaXMsICF0aGlzLm9wdGlvbnMucmVhZG9ubHkpO1xyXG4gIH1cclxuXHJcbiAgdXBkYXRlVmFsdWUodmFsdWUpIHtcclxuICAgIHRoaXMub3B0aW9ucy5zaG93RXJyb3JzID0gdHJ1ZTtcclxuICAgIHRoaXMuanNmLnVwZGF0ZVZhbHVlKHRoaXMsIHZhbHVlKTtcclxuICB9XHJcblxyXG4gIG5nT25EZXN0cm95ICgpIHtcclxuICAgIHRoaXMuanNmLnVwZGF0ZVZhbHVlKHRoaXMsIG51bGwpO1xyXG4gIH1cclxuXHJcbn1cclxuIl19
|
|
@@ -14,6 +14,7 @@ export class MaterialSelectComponent {
|
|
|
14
14
|
this.controlDisabled = false;
|
|
15
15
|
this.boundControl = false;
|
|
16
16
|
this.selectList = [];
|
|
17
|
+
this.selectListFlatGroup = [];
|
|
17
18
|
this.isArray = isArray;
|
|
18
19
|
this.layoutNode = input(undefined);
|
|
19
20
|
this.layoutIndex = input(undefined);
|
|
@@ -22,15 +23,44 @@ export class MaterialSelectComponent {
|
|
|
22
23
|
ngOnInit() {
|
|
23
24
|
this.options = this.layoutNode().options || {};
|
|
24
25
|
this.selectList = buildTitleMap(this.options.titleMap || this.options.enumNames, this.options.enum, !!this.options.required, !!this.options.flatList);
|
|
26
|
+
//the selectListFlatGroup array will be used to update the formArray values
|
|
27
|
+
//while the selectList array will be bound to the form select
|
|
28
|
+
//as either a grouped select or a flat select
|
|
29
|
+
this.selectListFlatGroup = buildTitleMap(this.options.titleMap || this.options.enumNames, this.options.enum, !!this.options.required, true);
|
|
25
30
|
this.jsf.initializeControl(this, !this.options.readonly);
|
|
26
31
|
if (!this.options.notitle && !this.options.description && this.options.placeholder) {
|
|
27
32
|
this.options.description = this.options.placeholder;
|
|
28
33
|
}
|
|
29
34
|
}
|
|
35
|
+
deselectAll() {
|
|
36
|
+
this.selectListFlatGroup.forEach(selItem => {
|
|
37
|
+
selItem.checked = false;
|
|
38
|
+
});
|
|
39
|
+
}
|
|
30
40
|
updateValue(event) {
|
|
31
41
|
this.options.showErrors = true;
|
|
42
|
+
if (this.options.multiple) {
|
|
43
|
+
if (event.value.includes(null)) {
|
|
44
|
+
this.deselectAll();
|
|
45
|
+
//this.control.setValue([]); // Reset the form control to an empty array
|
|
46
|
+
//this.selectList=JSON.parse(JSON.stringify(this.selectList));
|
|
47
|
+
this.jsf.updateArrayMultiSelectList(this, []);
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
this.selectListFlatGroup.forEach(selItem => {
|
|
51
|
+
selItem.checked = event.value.indexOf(selItem.value) >= 0 ? true : false;
|
|
52
|
+
});
|
|
53
|
+
this.jsf.updateArrayMultiSelectList(this, this.selectListFlatGroup);
|
|
54
|
+
}
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
32
57
|
this.jsf.updateValue(this, event.value);
|
|
33
58
|
}
|
|
59
|
+
ngOnDestroy() {
|
|
60
|
+
let nullVal = this.options.multiple ? [null] : null;
|
|
61
|
+
this.formControl.reset(nullVal);
|
|
62
|
+
this.controlValue = null;
|
|
63
|
+
}
|
|
34
64
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MaterialSelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
35
65
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.12", type: MaterialSelectComponent, selector: "material-select-widget", inputs: { layoutNode: { classPropertyName: "layoutNode", publicName: "layoutNode", isSignal: true, isRequired: false, transformFunction: null }, layoutIndex: { classPropertyName: "layoutIndex", publicName: "layoutIndex", isSignal: true, isRequired: false, transformFunction: null }, dataIndex: { classPropertyName: "dataIndex", publicName: "dataIndex", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
|
|
36
66
|
<mat-form-field
|
|
@@ -42,7 +72,10 @@ export class MaterialSelectComponent {
|
|
|
42
72
|
<mat-label *ngIf="!options?.notitle">{{options?.title}}</mat-label>
|
|
43
73
|
<span matPrefix *ngIf="options?.prefix || options?.fieldAddonLeft"
|
|
44
74
|
[innerHTML]="options?.prefix || options?.fieldAddonLeft"></span>
|
|
45
|
-
<
|
|
75
|
+
<ng-container *ngIf="boundControl">
|
|
76
|
+
|
|
77
|
+
</ng-container>
|
|
78
|
+
<mat-select *ngIf="boundControl && !options?.multiple"
|
|
46
79
|
[formControl]="formControl"
|
|
47
80
|
[attr.aria-describedby]="'control' + layoutNode()?._id + 'Status'"
|
|
48
81
|
[attr.name]="controlName"
|
|
@@ -51,7 +84,8 @@ export class MaterialSelectComponent {
|
|
|
51
84
|
[placeholder]="options?.notitle ? options?.placeholder : options?.title"
|
|
52
85
|
[required]="options?.required"
|
|
53
86
|
[style.width]="'100%'"
|
|
54
|
-
(blur)="options.showErrors = true"
|
|
87
|
+
(blur)="options.showErrors = true"
|
|
88
|
+
(selectionChange)="updateValue($event)">
|
|
55
89
|
<ng-template ngFor let-selectItem [ngForOf]="selectList">
|
|
56
90
|
<mat-option *ngIf="!isArray(selectItem?.items)"
|
|
57
91
|
[value]="selectItem?.value">
|
|
@@ -94,6 +128,34 @@ export class MaterialSelectComponent {
|
|
|
94
128
|
</mat-optgroup>
|
|
95
129
|
</ng-template>
|
|
96
130
|
</mat-select>
|
|
131
|
+
<mat-select *ngIf="boundControl && options?.multiple"
|
|
132
|
+
[attr.aria-describedby]="'control' + layoutNode()?._id + 'Status'"
|
|
133
|
+
[attr.name]="controlName"
|
|
134
|
+
[disabled]="controlDisabled || options?.readonly"
|
|
135
|
+
[id]="'control' + layoutNode()?._id"
|
|
136
|
+
[multiple]="options?.multiple"
|
|
137
|
+
[placeholder]="options?.notitle ? options?.placeholder : options?.title"
|
|
138
|
+
[required]="options?.required"
|
|
139
|
+
[style.width]="'100%'"
|
|
140
|
+
[value]="controlValue"
|
|
141
|
+
(blur)="options.showErrors = true"
|
|
142
|
+
(selectionChange)="updateValue($event)">
|
|
143
|
+
<ng-template ngFor let-selectItem [ngForOf]="selectList">
|
|
144
|
+
<mat-option *ngIf="!isArray(selectItem?.items)"
|
|
145
|
+
[attr.selected]="selectItem?.value === controlValue"
|
|
146
|
+
[value]="selectItem?.value">
|
|
147
|
+
<span [innerHTML]="selectItem?.name"></span>
|
|
148
|
+
</mat-option>
|
|
149
|
+
<mat-optgroup *ngIf="isArray(selectItem?.items)"
|
|
150
|
+
[label]="selectItem?.group">
|
|
151
|
+
<mat-option *ngFor="let subItem of selectItem.items"
|
|
152
|
+
[attr.selected]="subItem?.value === controlValue"
|
|
153
|
+
[value]="subItem?.value">
|
|
154
|
+
<span [innerHTML]="subItem?.name"></span>
|
|
155
|
+
</mat-option>
|
|
156
|
+
</mat-optgroup>
|
|
157
|
+
</ng-template>
|
|
158
|
+
</mat-select>
|
|
97
159
|
<span matSuffix *ngIf="options?.suffix || options?.fieldAddonRight"
|
|
98
160
|
[innerHTML]="options?.suffix || options?.fieldAddonRight"></span>
|
|
99
161
|
<mat-hint *ngIf="options?.description && (!options?.showErrors || !options?.errorMessage)"
|
|
@@ -114,7 +176,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
114
176
|
<mat-label *ngIf="!options?.notitle">{{options?.title}}</mat-label>
|
|
115
177
|
<span matPrefix *ngIf="options?.prefix || options?.fieldAddonLeft"
|
|
116
178
|
[innerHTML]="options?.prefix || options?.fieldAddonLeft"></span>
|
|
117
|
-
<
|
|
179
|
+
<ng-container *ngIf="boundControl">
|
|
180
|
+
|
|
181
|
+
</ng-container>
|
|
182
|
+
<mat-select *ngIf="boundControl && !options?.multiple"
|
|
118
183
|
[formControl]="formControl"
|
|
119
184
|
[attr.aria-describedby]="'control' + layoutNode()?._id + 'Status'"
|
|
120
185
|
[attr.name]="controlName"
|
|
@@ -123,7 +188,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
123
188
|
[placeholder]="options?.notitle ? options?.placeholder : options?.title"
|
|
124
189
|
[required]="options?.required"
|
|
125
190
|
[style.width]="'100%'"
|
|
126
|
-
(blur)="options.showErrors = true"
|
|
191
|
+
(blur)="options.showErrors = true"
|
|
192
|
+
(selectionChange)="updateValue($event)">
|
|
127
193
|
<ng-template ngFor let-selectItem [ngForOf]="selectList">
|
|
128
194
|
<mat-option *ngIf="!isArray(selectItem?.items)"
|
|
129
195
|
[value]="selectItem?.value">
|
|
@@ -166,6 +232,34 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
166
232
|
</mat-optgroup>
|
|
167
233
|
</ng-template>
|
|
168
234
|
</mat-select>
|
|
235
|
+
<mat-select *ngIf="boundControl && options?.multiple"
|
|
236
|
+
[attr.aria-describedby]="'control' + layoutNode()?._id + 'Status'"
|
|
237
|
+
[attr.name]="controlName"
|
|
238
|
+
[disabled]="controlDisabled || options?.readonly"
|
|
239
|
+
[id]="'control' + layoutNode()?._id"
|
|
240
|
+
[multiple]="options?.multiple"
|
|
241
|
+
[placeholder]="options?.notitle ? options?.placeholder : options?.title"
|
|
242
|
+
[required]="options?.required"
|
|
243
|
+
[style.width]="'100%'"
|
|
244
|
+
[value]="controlValue"
|
|
245
|
+
(blur)="options.showErrors = true"
|
|
246
|
+
(selectionChange)="updateValue($event)">
|
|
247
|
+
<ng-template ngFor let-selectItem [ngForOf]="selectList">
|
|
248
|
+
<mat-option *ngIf="!isArray(selectItem?.items)"
|
|
249
|
+
[attr.selected]="selectItem?.value === controlValue"
|
|
250
|
+
[value]="selectItem?.value">
|
|
251
|
+
<span [innerHTML]="selectItem?.name"></span>
|
|
252
|
+
</mat-option>
|
|
253
|
+
<mat-optgroup *ngIf="isArray(selectItem?.items)"
|
|
254
|
+
[label]="selectItem?.group">
|
|
255
|
+
<mat-option *ngFor="let subItem of selectItem.items"
|
|
256
|
+
[attr.selected]="subItem?.value === controlValue"
|
|
257
|
+
[value]="subItem?.value">
|
|
258
|
+
<span [innerHTML]="subItem?.name"></span>
|
|
259
|
+
</mat-option>
|
|
260
|
+
</mat-optgroup>
|
|
261
|
+
</ng-template>
|
|
262
|
+
</mat-select>
|
|
169
263
|
<span matSuffix *ngIf="options?.suffix || options?.fieldAddonRight"
|
|
170
264
|
[innerHTML]="options?.suffix || options?.fieldAddonRight"></span>
|
|
171
265
|
<mat-hint *ngIf="options?.description && (!options?.showErrors || !options?.errorMessage)"
|
|
@@ -174,4 +268,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
174
268
|
<mat-error *ngIf="options?.showErrors && options?.errorMessage"
|
|
175
269
|
[innerHTML]="options?.errorMessage"></mat-error>`, styles: ["mat-error{font-size:75%;margin-top:-1rem;margin-bottom:.5rem}::ng-deep json-schema-form mat-form-field .mat-mdc-form-field-wrapper .mat-form-field-flex .mat-form-field-infix{width:initial}\n"] }]
|
|
176
270
|
}] });
|
|
177
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"material-select.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-material/src/lib/widgets/material-select.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,MAAM,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAEjE,OAAO,EAAE,8BAA8B,EAAE,MAAM,8BAA8B,CAAC;AAC9E,OAAO,EAAE,qBAAqB,EAAE,aAAa,EAAE,OAAO,EAAE,MAAM,oBAAoB,CAAC;;;;;;;AAgFnF,MAAM,OAAO,uBAAuB;IA9EpC;QA+EE,+BAA0B,GAAG,MAAM,CAAC,8BAA8B,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QAChF,QAAG,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;QAK5C,oBAAe,GAAG,KAAK,CAAC;QACxB,iBAAY,GAAG,KAAK,CAAC;QAErB,eAAU,GAAU,EAAE,CAAC;QACvB,YAAO,GAAG,OAAO,CAAC;QACT,eAAU,GAAG,KAAK,CAAM,SAAS,CAAC,CAAC;QACnC,gBAAW,GAAG,KAAK,CAAW,SAAS,CAAC,CAAC;QACzC,cAAS,GAAG,KAAK,CAAW,SAAS,CAAC,CAAC;KAkBjD;IAhBC,QAAQ;QACN,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,OAAO,IAAI,EAAE,CAAC;QAC/C,IAAI,CAAC,UAAU,GAAG,aAAa,CAC7B,IAAI,CAAC,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,EAC/C,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CACpE,CAAC;QACF,IAAI,CAAC,GAAG,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;QACzD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE;YAClF,IAAI,CAAC,OAAO,CAAC,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC;SACrD;IACH,CAAC;IAED,WAAW,CAAC,KAAK;QACf,IAAI,CAAC,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC;QAC/B,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;IAC1C,CAAC;+GA/BU,uBAAuB;mGAAvB,uBAAuB,+dA3ExB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uDAoE2C;;4FAO1C,uBAAuB;kBA9EnC,SAAS;+BAEE,wBAAwB,YACxB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uDAoE2C","sourcesContent":["import { Component, OnInit, inject, input } from '@angular/core';\r\nimport { AbstractControl } from '@angular/forms';\r\nimport { MAT_FORM_FIELD_DEFAULT_OPTIONS } from '@angular/material/form-field';\r\nimport { JsonSchemaFormService, buildTitleMap, isArray } from '@ng-formworks/core';\r\n\r\n@Component({\r\n  // tslint:disable-next-line:component-selector\r\n  selector: 'material-select-widget',\r\n  template: `\r\n    <mat-form-field\r\n      [appearance]=\"options?.appearance || matFormFieldDefaultOptions?.appearance || 'fill'\"\r\n      [class]=\"options?.htmlClass || ''\" class=\"sortable-filter\"\r\n      [floatLabel]=\"options?.floatLabel || matFormFieldDefaultOptions?.floatLabel || (options?.notitle ? 'never' : 'auto')\"\r\n      [hideRequiredMarker]=\"options?.hideRequired ? 'true' : 'false'\"\r\n      [style.width]=\"'100%'\">\r\n      <mat-label *ngIf=\"!options?.notitle\">{{options?.title}}</mat-label>\r\n      <span matPrefix *ngIf=\"options?.prefix || options?.fieldAddonLeft\"\r\n        [innerHTML]=\"options?.prefix || options?.fieldAddonLeft\"></span>\r\n      <mat-select *ngIf=\"boundControl\"\r\n        [formControl]=\"formControl\"\r\n        [attr.aria-describedby]=\"'control' + layoutNode()?._id + 'Status'\"\r\n        [attr.name]=\"controlName\"\r\n        [id]=\"'control' + layoutNode()?._id\"\r\n        [multiple]=\"options?.multiple\"\r\n        [placeholder]=\"options?.notitle ? options?.placeholder : options?.title\"\r\n        [required]=\"options?.required\"\r\n        [style.width]=\"'100%'\"\r\n        (blur)=\"options.showErrors = true\">\r\n        <ng-template ngFor let-selectItem [ngForOf]=\"selectList\">\r\n          <mat-option *ngIf=\"!isArray(selectItem?.items)\"\r\n            [value]=\"selectItem?.value\">\r\n            <span [innerHTML]=\"selectItem?.name\"></span>\r\n          </mat-option>\r\n          <mat-optgroup *ngIf=\"isArray(selectItem?.items)\"\r\n            [label]=\"selectItem?.group\">\r\n            <mat-option *ngFor=\"let subItem of selectItem.items\"\r\n              [value]=\"subItem?.value\">\r\n              <span [innerHTML]=\"subItem?.name\"></span>\r\n            </mat-option>\r\n          </mat-optgroup>\r\n        </ng-template>\r\n      </mat-select>\r\n      <mat-select *ngIf=\"!boundControl\"\r\n        [attr.aria-describedby]=\"'control' + layoutNode()?._id + 'Status'\"\r\n        [attr.name]=\"controlName\"\r\n        [disabled]=\"controlDisabled || options?.readonly\"\r\n        [id]=\"'control' + layoutNode()?._id\"\r\n        [multiple]=\"options?.multiple\"\r\n        [placeholder]=\"options?.notitle ? options?.placeholder : options?.title\"\r\n        [required]=\"options?.required\"\r\n        [style.width]=\"'100%'\"\r\n        [value]=\"controlValue\"\r\n        (blur)=\"options.showErrors = true\"\r\n        (change)=\"updateValue($event)\">\r\n        <ng-template ngFor let-selectItem [ngForOf]=\"selectList\">\r\n          <mat-option *ngIf=\"!isArray(selectItem?.items)\"\r\n            [attr.selected]=\"selectItem?.value === controlValue\"\r\n            [value]=\"selectItem?.value\">\r\n            <span [innerHTML]=\"selectItem?.name\"></span>\r\n          </mat-option>\r\n          <mat-optgroup *ngIf=\"isArray(selectItem?.items)\"\r\n            [label]=\"selectItem?.group\">\r\n            <mat-option *ngFor=\"let subItem of selectItem.items\"\r\n              [attr.selected]=\"subItem?.value === controlValue\"\r\n              [value]=\"subItem?.value\">\r\n              <span [innerHTML]=\"subItem?.name\"></span>\r\n            </mat-option>\r\n          </mat-optgroup>\r\n        </ng-template>\r\n      </mat-select>\r\n      <span matSuffix *ngIf=\"options?.suffix || options?.fieldAddonRight\"\r\n        [innerHTML]=\"options?.suffix || options?.fieldAddonRight\"></span>\r\n      <mat-hint *ngIf=\"options?.description && (!options?.showErrors || !options?.errorMessage)\"\r\n        align=\"end\" [innerHTML]=\"options?.description\"></mat-hint>\r\n    </mat-form-field>\r\n    <mat-error *ngIf=\"options?.showErrors && options?.errorMessage\"\r\n      [innerHTML]=\"options?.errorMessage\"></mat-error>`,\r\n  styles: [`\r\n    mat-error { font-size: 75%; margin-top: -1rem; margin-bottom: 0.5rem; }\r\n    ::ng-deep json-schema-form mat-form-field .mat-mdc-form-field-wrapper .mat-form-field-flex\r\n      .mat-form-field-infix { width: initial; }\r\n  `],\r\n})\r\nexport class MaterialSelectComponent implements OnInit {\r\n  matFormFieldDefaultOptions = inject(MAT_FORM_FIELD_DEFAULT_OPTIONS, { optional: true });\r\n  private jsf = inject(JsonSchemaFormService);\r\n\r\n  formControl: AbstractControl;\r\n  controlName: string;\r\n  controlValue: any;\r\n  controlDisabled = false;\r\n  boundControl = false;\r\n  options: any;\r\n  selectList: any[] = [];\r\n  isArray = isArray;\r\n  readonly layoutNode = input<any>(undefined);\r\n  readonly layoutIndex = input<number[]>(undefined);\r\n  readonly dataIndex = input<number[]>(undefined);\r\n\r\n  ngOnInit() {\r\n    this.options = this.layoutNode().options || {};\r\n    this.selectList = buildTitleMap(\r\n      this.options.titleMap || this.options.enumNames,\r\n      this.options.enum, !!this.options.required, !!this.options.flatList\r\n    );\r\n    this.jsf.initializeControl(this, !this.options.readonly);\r\n    if (!this.options.notitle && !this.options.description && this.options.placeholder) {\r\n      this.options.description = this.options.placeholder;\r\n    }\r\n  }\r\n\r\n  updateValue(event) {\r\n    this.options.showErrors = true;\r\n    this.jsf.updateValue(this, event.value);\r\n  }\r\n}\r\n"]}
|
|
271
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"material-select.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-formworks-material/src/lib/widgets/material-select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, OnInit, inject, input } from '@angular/core';\r\nimport { AbstractControl } from '@angular/forms';\r\nimport { MAT_FORM_FIELD_DEFAULT_OPTIONS } from '@angular/material/form-field';\r\nimport { JsonSchemaFormService, buildTitleMap, isArray } from '@ng-formworks/core';\r\n\r\n@Component({\r\n  // tslint:disable-next-line:component-selector\r\n  selector: 'material-select-widget',\r\n  template: `\r\n    <mat-form-field\r\n      [appearance]=\"options?.appearance || matFormFieldDefaultOptions?.appearance || 'fill'\"\r\n      [class]=\"options?.htmlClass || ''\" class=\"sortable-filter\"\r\n      [floatLabel]=\"options?.floatLabel || matFormFieldDefaultOptions?.floatLabel || (options?.notitle ? 'never' : 'auto')\"\r\n      [hideRequiredMarker]=\"options?.hideRequired ? 'true' : 'false'\"\r\n      [style.width]=\"'100%'\">\r\n      <mat-label *ngIf=\"!options?.notitle\">{{options?.title}}</mat-label>\r\n      <span matPrefix *ngIf=\"options?.prefix || options?.fieldAddonLeft\"\r\n        [innerHTML]=\"options?.prefix || options?.fieldAddonLeft\"></span>\r\n      <ng-container *ngIf=\"boundControl\">\r\n      \r\n      </ng-container>  \r\n      <mat-select *ngIf=\"boundControl && !options?.multiple\"\r\n        [formControl]=\"formControl\"\r\n        [attr.aria-describedby]=\"'control' + layoutNode()?._id + 'Status'\"\r\n        [attr.name]=\"controlName\"\r\n        [id]=\"'control' + layoutNode()?._id\"\r\n        [multiple]=\"options?.multiple\"\r\n        [placeholder]=\"options?.notitle ? options?.placeholder : options?.title\"\r\n        [required]=\"options?.required\"\r\n        [style.width]=\"'100%'\"\r\n        (blur)=\"options.showErrors = true\"\r\n         (selectionChange)=\"updateValue($event)\">\r\n        <ng-template ngFor let-selectItem [ngForOf]=\"selectList\">\r\n          <mat-option *ngIf=\"!isArray(selectItem?.items)\"\r\n            [value]=\"selectItem?.value\">\r\n            <span [innerHTML]=\"selectItem?.name\"></span>\r\n          </mat-option>\r\n          <mat-optgroup *ngIf=\"isArray(selectItem?.items)\"\r\n            [label]=\"selectItem?.group\">\r\n            <mat-option *ngFor=\"let subItem of selectItem.items\"\r\n              [value]=\"subItem?.value\">\r\n              <span [innerHTML]=\"subItem?.name\"></span>\r\n            </mat-option>\r\n          </mat-optgroup>\r\n        </ng-template>\r\n      </mat-select>\r\n      <mat-select *ngIf=\"!boundControl\"\r\n        [attr.aria-describedby]=\"'control' + layoutNode()?._id + 'Status'\"\r\n        [attr.name]=\"controlName\"\r\n        [disabled]=\"controlDisabled || options?.readonly\"\r\n        [id]=\"'control' + layoutNode()?._id\"\r\n        [multiple]=\"options?.multiple\"\r\n        [placeholder]=\"options?.notitle ? options?.placeholder : options?.title\"\r\n        [required]=\"options?.required\"\r\n        [style.width]=\"'100%'\"\r\n        [value]=\"controlValue\"\r\n        (blur)=\"options.showErrors = true\"\r\n        (change)=\"updateValue($event)\">\r\n        <ng-template ngFor let-selectItem [ngForOf]=\"selectList\">\r\n          <mat-option *ngIf=\"!isArray(selectItem?.items)\"\r\n            [attr.selected]=\"selectItem?.value === controlValue\"\r\n            [value]=\"selectItem?.value\">\r\n            <span [innerHTML]=\"selectItem?.name\"></span>\r\n          </mat-option>\r\n          <mat-optgroup *ngIf=\"isArray(selectItem?.items)\"\r\n            [label]=\"selectItem?.group\">\r\n            <mat-option *ngFor=\"let subItem of selectItem.items\"\r\n              [attr.selected]=\"subItem?.value === controlValue\"\r\n              [value]=\"subItem?.value\">\r\n              <span [innerHTML]=\"subItem?.name\"></span>\r\n            </mat-option>\r\n          </mat-optgroup>\r\n        </ng-template>\r\n      </mat-select>\r\n      <mat-select *ngIf=\"boundControl && options?.multiple\"\r\n        [attr.aria-describedby]=\"'control' + layoutNode()?._id + 'Status'\"\r\n        [attr.name]=\"controlName\"\r\n        [disabled]=\"controlDisabled || options?.readonly\"\r\n        [id]=\"'control' + layoutNode()?._id\"\r\n        [multiple]=\"options?.multiple\"\r\n        [placeholder]=\"options?.notitle ? options?.placeholder : options?.title\"\r\n        [required]=\"options?.required\"\r\n        [style.width]=\"'100%'\"\r\n        [value]=\"controlValue\"\r\n        (blur)=\"options.showErrors = true\"\r\n        (selectionChange)=\"updateValue($event)\">\r\n        <ng-template ngFor let-selectItem [ngForOf]=\"selectList\">\r\n          <mat-option *ngIf=\"!isArray(selectItem?.items)\"\r\n            [attr.selected]=\"selectItem?.value === controlValue\"\r\n            [value]=\"selectItem?.value\">\r\n            <span [innerHTML]=\"selectItem?.name\"></span>\r\n          </mat-option>\r\n          <mat-optgroup *ngIf=\"isArray(selectItem?.items)\"\r\n            [label]=\"selectItem?.group\">\r\n            <mat-option *ngFor=\"let subItem of selectItem.items\"\r\n              [attr.selected]=\"subItem?.value === controlValue\"\r\n              [value]=\"subItem?.value\">\r\n              <span [innerHTML]=\"subItem?.name\"></span>\r\n            </mat-option>\r\n          </mat-optgroup>\r\n        </ng-template>\r\n      </mat-select>\r\n      <span matSuffix *ngIf=\"options?.suffix || options?.fieldAddonRight\"\r\n        [innerHTML]=\"options?.suffix || options?.fieldAddonRight\"></span>\r\n      <mat-hint *ngIf=\"options?.description && (!options?.showErrors || !options?.errorMessage)\"\r\n        align=\"end\" [innerHTML]=\"options?.description\"></mat-hint>\r\n    </mat-form-field>\r\n    <mat-error *ngIf=\"options?.showErrors && options?.errorMessage\"\r\n      [innerHTML]=\"options?.errorMessage\"></mat-error>`,\r\n  styles: [`\r\n    mat-error { font-size: 75%; margin-top: -1rem; margin-bottom: 0.5rem; }\r\n    ::ng-deep json-schema-form mat-form-field .mat-mdc-form-field-wrapper .mat-form-field-flex\r\n      .mat-form-field-infix { width: initial; }\r\n  `],\r\n})\r\nexport class MaterialSelectComponent implements OnInit, OnDestroy {\r\n  matFormFieldDefaultOptions = inject(MAT_FORM_FIELD_DEFAULT_OPTIONS, { optional: true });\r\n  private jsf = inject(JsonSchemaFormService);\r\n\r\n  formControl: AbstractControl;\r\n  controlName: string;\r\n  controlValue: any;\r\n  controlDisabled = false;\r\n  boundControl = false;\r\n  options: any;\r\n  selectList: any[] = [];\r\n  selectListFlatGroup: any[] = [];\r\n  isArray = isArray;\r\n  readonly layoutNode = input<any>(undefined);\r\n  readonly layoutIndex = input<number[]>(undefined);\r\n  readonly dataIndex = input<number[]>(undefined);\r\n\r\n  ngOnInit() {\r\n    this.options = this.layoutNode().options || {};\r\n    this.selectList = buildTitleMap(\r\n      this.options.titleMap || this.options.enumNames,\r\n      this.options.enum, !!this.options.required, !!this.options.flatList\r\n    );\r\n    //the selectListFlatGroup array will be used to update the formArray values\r\n    //while the selectList array will be bound to the form select\r\n    //as either a grouped select or a flat select\r\n    this.selectListFlatGroup = buildTitleMap(\r\n      this.options.titleMap || this.options.enumNames,\r\n      this.options.enum, !!this.options.required, true\r\n    )\r\n    this.jsf.initializeControl(this, !this.options.readonly);\r\n    if (!this.options.notitle && !this.options.description && this.options.placeholder) {\r\n      this.options.description = this.options.placeholder;\r\n    }\r\n  }\r\n\r\n  deselectAll() {\r\n    this.selectListFlatGroup.forEach(selItem => {\r\n      selItem.checked = false;\r\n    })\r\n  }\r\n\r\n\r\n\r\n  updateValue(event) {\r\n\r\n    this.options.showErrors = true;\r\n    if (this.options.multiple) {\r\n      if (event.value.includes(null)) {\r\n        this.deselectAll();\r\n        //this.control.setValue([]);  // Reset the form control to an empty array\r\n        //this.selectList=JSON.parse(JSON.stringify(this.selectList));\r\n        this.jsf.updateArrayMultiSelectList(this, []);\r\n      } else {\r\n        this.selectListFlatGroup.forEach(selItem => {\r\n          selItem.checked = event.value.indexOf(selItem.value) >= 0 ? true : false;\r\n        })\r\n        this.jsf.updateArrayMultiSelectList(this, this.selectListFlatGroup);\r\n      }\r\n      return;\r\n    }\r\n    this.jsf.updateValue(this, event.value);\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    let nullVal=this.options.multiple?[null]:null;\r\n    this.formControl.reset(nullVal)\r\n    this.controlValue=null;\r\n  }\r\n}\r\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component,
|
|
1
|
+
import { Component, inject, input } from '@angular/core';
|
|
2
2
|
import { JsonSchemaFormService } from '@ng-formworks/core';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
// TODO: Add this control
|
|
@@ -18,6 +18,9 @@ export class MaterialStepperComponent {
|
|
|
18
18
|
updateValue(event) {
|
|
19
19
|
this.jsf.updateValue(this, event.target.value);
|
|
20
20
|
}
|
|
21
|
+
ngOnDestroy() {
|
|
22
|
+
this.jsf.updateValue(this, null);
|
|
23
|
+
}
|
|
21
24
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MaterialStepperComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
22
25
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.12", type: MaterialStepperComponent, selector: "material-stepper-widget", inputs: { layoutNode: { classPropertyName: "layoutNode", publicName: "layoutNode", isSignal: true, isRequired: false, transformFunction: null }, layoutIndex: { classPropertyName: "layoutIndex", publicName: "layoutIndex", isSignal: true, isRequired: false, transformFunction: null }, dataIndex: { classPropertyName: "dataIndex", publicName: "dataIndex", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: ``, isInline: true }); }
|
|
23
26
|
}
|
|
@@ -29,4 +32,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
29
32
|
template: ``,
|
|
30
33
|
}]
|
|
31
34
|
}] });
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF0ZXJpYWwtc3RlcHBlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1mb3Jtd29ya3MtbWF0ZXJpYWwvc3JjL2xpYi93aWRnZXRzL21hdGVyaWFsLXN0ZXBwZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFFNUUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7O0FBRTNELHlCQUF5QjtBQU96QixNQUFNLE9BQU8sd0JBQXdCO0lBTHJDO1FBTVUsUUFBRyxHQUFHLE1BQU0sQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1FBSzVDLG9CQUFlLEdBQUcsS0FBSyxDQUFDO1FBQ3hCLGlCQUFZLEdBQUcsS0FBSyxDQUFDO1FBRVosZUFBVSxHQUFHLEtBQUssQ0FBTSxTQUFTLENBQUMsQ0FBQztRQUNuQyxnQkFBVyxHQUFHLEtBQUssQ0FBVyxTQUFTLENBQUMsQ0FBQztRQUN6QyxjQUFTLEdBQUcsS0FBSyxDQUFXLFNBQVMsQ0FBQyxDQUFDO0tBZWpEO0lBYkMsUUFBUTtRQUNOLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDLE9BQU8sSUFBSSxFQUFFLENBQUM7UUFDL0MsSUFBSSxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBRUQsV0FBVyxDQUFDLEtBQUs7UUFDZixJQUFJLENBQUMsR0FBRyxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNqRCxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxHQUFHLENBQUMsV0FBVyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztJQUNuQyxDQUFDOytHQXhCVSx3QkFBd0I7bUdBQXhCLHdCQUF3QixnZUFGekIsRUFBRTs7NEZBRUQsd0JBQXdCO2tCQUxwQyxTQUFTO21CQUFDO29CQUNULDhDQUE4QztvQkFDOUMsUUFBUSxFQUFFLHlCQUF5QjtvQkFDbkMsUUFBUSxFQUFFLEVBQUU7aUJBQ2IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIGluamVjdCwgaW5wdXQsIE9uRGVzdHJveSwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEFic3RyYWN0Q29udHJvbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgSnNvblNjaGVtYUZvcm1TZXJ2aWNlIH0gZnJvbSAnQG5nLWZvcm13b3Jrcy9jb3JlJztcclxuXHJcbi8vIFRPRE86IEFkZCB0aGlzIGNvbnRyb2xcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIC8vIHRzbGludDpkaXNhYmxlLW5leHQtbGluZTpjb21wb25lbnQtc2VsZWN0b3JcclxuICBzZWxlY3RvcjogJ21hdGVyaWFsLXN0ZXBwZXItd2lkZ2V0JyxcclxuICB0ZW1wbGF0ZTogYGAsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBNYXRlcmlhbFN0ZXBwZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsT25EZXN0cm95IHtcclxuICBwcml2YXRlIGpzZiA9IGluamVjdChKc29uU2NoZW1hRm9ybVNlcnZpY2UpO1xyXG5cclxuICBmb3JtQ29udHJvbDogQWJzdHJhY3RDb250cm9sO1xyXG4gIGNvbnRyb2xOYW1lOiBzdHJpbmc7XHJcbiAgY29udHJvbFZhbHVlOiBhbnk7XHJcbiAgY29udHJvbERpc2FibGVkID0gZmFsc2U7XHJcbiAgYm91bmRDb250cm9sID0gZmFsc2U7XHJcbiAgb3B0aW9uczogYW55O1xyXG4gIHJlYWRvbmx5IGxheW91dE5vZGUgPSBpbnB1dDxhbnk+KHVuZGVmaW5lZCk7XHJcbiAgcmVhZG9ubHkgbGF5b3V0SW5kZXggPSBpbnB1dDxudW1iZXJbXT4odW5kZWZpbmVkKTtcclxuICByZWFkb25seSBkYXRhSW5kZXggPSBpbnB1dDxudW1iZXJbXT4odW5kZWZpbmVkKTtcclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICB0aGlzLm9wdGlvbnMgPSB0aGlzLmxheW91dE5vZGUoKS5vcHRpb25zIHx8IHt9O1xyXG4gICAgdGhpcy5qc2YuaW5pdGlhbGl6ZUNvbnRyb2wodGhpcyk7XHJcbiAgfVxyXG5cclxuICB1cGRhdGVWYWx1ZShldmVudCkge1xyXG4gICAgdGhpcy5qc2YudXBkYXRlVmFsdWUodGhpcywgZXZlbnQudGFyZ2V0LnZhbHVlKTtcclxuICB9XHJcblxyXG4gIG5nT25EZXN0cm95ICgpIHtcclxuICAgIHRoaXMuanNmLnVwZGF0ZVZhbHVlKHRoaXMsIG51bGwpO1xyXG4gIH1cclxuXHJcbn1cclxuIl19
|