@tots/editable-columns 16.0.4 → 16.0.6
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/column-factories/tots-select-column.mjs +21 -0
- package/esm2022/lib/columns/input-column/input-column.component.mjs +4 -5
- package/esm2022/lib/columns/select-column/select-column.component.mjs +115 -0
- package/esm2022/lib/components/tots-table-full-group/tots-table-full-group.component.mjs +27 -8
- package/esm2022/lib/editable-columns.module.mjs +8 -1
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/tots-editable-columns.mjs +163 -12
- package/fesm2022/tots-editable-columns.mjs.map +1 -1
- package/lib/column-factories/tots-select-column.d.ts +7 -0
- package/lib/columns/select-column/select-column.component.d.ts +27 -0
- package/lib/components/tots-table-full-group/tots-table-full-group.component.d.ts +1 -0
- package/lib/editable-columns.module.d.ts +9 -7
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { TotsColumn } from "@tots/table";
|
|
2
|
+
import { SelectColumnComponent } from "../columns/select-column/select-column.component";
|
|
3
|
+
export class TotsSelectColumn extends TotsColumn {
|
|
4
|
+
constructor(id, fieldKey, options, validators, title, formGroup, label, placeholder, hint, cssClass, appearance) {
|
|
5
|
+
super(id, SelectColumnComponent, fieldKey, title);
|
|
6
|
+
this.extra = {
|
|
7
|
+
group: formGroup,
|
|
8
|
+
options: options,
|
|
9
|
+
field_select_key: "value",
|
|
10
|
+
field_print_key: "caption",
|
|
11
|
+
validators: validators?.map(v => v.validator),
|
|
12
|
+
errors: validators?.map(v => { return { name: v.name, message: v.message }; }),
|
|
13
|
+
label: label,
|
|
14
|
+
class: cssClass,
|
|
15
|
+
placeholder: placeholder,
|
|
16
|
+
caption: hint,
|
|
17
|
+
appearance: appearance
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG90cy1zZWxlY3QtY29sdW1uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdG90cy9lZGl0YWJsZS1jb2x1bW5zL3NyYy9saWIvY29sdW1uLWZhY3Rvcmllcy90b3RzLXNlbGVjdC1jb2x1bW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBb0IsTUFBTSxhQUFhLENBQUM7QUFDM0QsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sa0RBQWtELENBQUM7QUFLekYsTUFBTSxPQUFPLGdCQUFpQixTQUFRLFVBQVU7SUFDL0MsWUFBWSxFQUFTLEVBQUUsUUFBd0IsRUFBRSxPQUEwQixFQUFFLFVBQTJCLEVBQUUsS0FBYSxFQUFFLFNBQW9CLEVBQUUsS0FBYSxFQUFFLFdBQW1CLEVBQUUsSUFBWSxFQUFFLFFBQWdCLEVBQUUsVUFBa0M7UUFDOU8sS0FBSyxDQUFDLEVBQUUsRUFBRSxxQkFBcUIsRUFBRSxRQUFRLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDbEQsSUFBSSxDQUFDLEtBQUssR0FBRztZQUNULEtBQUssRUFBRSxTQUFTO1lBQ2hCLE9BQU8sRUFBRSxPQUFPO1lBQ2hCLGdCQUFnQixFQUFFLE9BQU87WUFDekIsZUFBZSxFQUFFLFNBQVM7WUFDMUIsVUFBVSxFQUFFLFVBQVUsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFBLEVBQUUsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDO1lBQzVDLE1BQU0sRUFBRSxVQUFVLEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQSxFQUFFLEdBQUUsT0FBTyxFQUFDLElBQUksRUFBQyxDQUFDLENBQUMsSUFBSSxFQUFFLE9BQU8sRUFBQyxDQUFDLENBQUMsT0FBTyxFQUFDLENBQUEsQ0FBQSxDQUFDLENBQUM7WUFDdEUsS0FBSyxFQUFFLEtBQUs7WUFDWixLQUFLLEVBQUUsUUFBUTtZQUNmLFdBQVcsRUFBRSxXQUFXO1lBQ3hCLE9BQU8sRUFBRSxJQUFJO1lBQ2IsVUFBVSxFQUFFLFVBQVU7U0FDekIsQ0FBQTtJQUNMLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRvdHNDb2x1bW4sIFRvdHNDb2x1bW5PcHRpb24gfSBmcm9tIFwiQHRvdHMvdGFibGVcIjtcclxuaW1wb3J0IHsgU2VsZWN0Q29sdW1uQ29tcG9uZW50IH0gZnJvbSBcIi4uL2NvbHVtbnMvc2VsZWN0LWNvbHVtbi9zZWxlY3QtY29sdW1uLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQgeyBGb3JtR3JvdXAgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcclxuaW1wb3J0IHsgTWF0Rm9ybUZpZWxkQXBwZWFyYW5jZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkXCI7XHJcbmltcG9ydCB7IFRvdHNWYWxpZGF0b3IgfSBmcm9tIFwiLi4vZW50aXRpZXMvdG90cy12YWxpZGF0b3JcIjtcclxuXHJcbmV4cG9ydCBjbGFzcyBUb3RzU2VsZWN0Q29sdW1uIGV4dGVuZHMgVG90c0NvbHVtbiB7XHJcblx0Y29uc3RydWN0b3IoaWQ6c3RyaW5nLCBmaWVsZEtleTpzdHJpbmd8c3RyaW5nW10sIG9wdGlvbnM6VG90c0NvbHVtbk9wdGlvbltdLCB2YWxpZGF0b3JzPzpUb3RzVmFsaWRhdG9yW10sIHRpdGxlPzpzdHJpbmcsIGZvcm1Hcm91cD86Rm9ybUdyb3VwLCBsYWJlbD86c3RyaW5nLCBwbGFjZWhvbGRlcj86c3RyaW5nLCBoaW50PzpzdHJpbmcsIGNzc0NsYXNzPzpzdHJpbmcsIGFwcGVhcmFuY2U/Ok1hdEZvcm1GaWVsZEFwcGVhcmFuY2UpIHtcclxuICAgICAgICBzdXBlcihpZCwgU2VsZWN0Q29sdW1uQ29tcG9uZW50LCBmaWVsZEtleSwgdGl0bGUpO1xyXG4gICAgICAgIHRoaXMuZXh0cmEgPSB7XHJcbiAgICAgICAgICAgIGdyb3VwOiBmb3JtR3JvdXAsXHJcbiAgICAgICAgICAgIG9wdGlvbnM6IG9wdGlvbnMsXHJcbiAgICAgICAgICAgIGZpZWxkX3NlbGVjdF9rZXk6IFwidmFsdWVcIixcclxuICAgICAgICAgICAgZmllbGRfcHJpbnRfa2V5OiBcImNhcHRpb25cIixcclxuICAgICAgICAgICAgdmFsaWRhdG9yczogdmFsaWRhdG9ycz8ubWFwKHY9PiB2LnZhbGlkYXRvciksXHJcbiAgICAgICAgICAgIGVycm9yczogdmFsaWRhdG9ycz8ubWFwKHY9PiB7cmV0dXJuIHtuYW1lOnYubmFtZSwgbWVzc2FnZTp2Lm1lc3NhZ2V9fSksXHJcbiAgICAgICAgICAgIGxhYmVsOiBsYWJlbCxcclxuICAgICAgICAgICAgY2xhc3M6IGNzc0NsYXNzLFxyXG4gICAgICAgICAgICBwbGFjZWhvbGRlcjogcGxhY2Vob2xkZXIsXHJcbiAgICAgICAgICAgIGNhcHRpb246IGhpbnQsXHJcbiAgICAgICAgICAgIGFwcGVhcmFuY2U6IGFwcGVhcmFuY2VcclxuICAgICAgICB9XHJcbiAgICB9XHJcbn0iXX0=
|
|
@@ -16,12 +16,11 @@ export class InputColumnComponent extends TotsBaseColumnComponent {
|
|
|
16
16
|
this.loadChanges();
|
|
17
17
|
}
|
|
18
18
|
ngOnDestroy() {
|
|
19
|
-
this.onAction.next({ key: 'input-destroy', item: this.index });
|
|
19
|
+
this.onAction.next({ key: 'input-destroy', item: { field_key: this.getFormKey(), index: this.index } });
|
|
20
20
|
}
|
|
21
21
|
loadChanges() {
|
|
22
|
-
this.input.valueChanges
|
|
23
|
-
.
|
|
24
|
-
this.onAction.next({ key: 'input-change', item: { field_key: this.getFormKey(), item: this.item, value: res, valid: this.input.valid, index: this.index } });
|
|
22
|
+
this.input.valueChanges.subscribe(value => {
|
|
23
|
+
this.onAction.next({ key: 'input-change', item: { field_key: this.getFormKey(), item: this.item, value: value, valid: this.input.valid, index: this.index } });
|
|
25
24
|
});
|
|
26
25
|
}
|
|
27
26
|
loadForm() {
|
|
@@ -107,4 +106,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImpo
|
|
|
107
106
|
type: Component,
|
|
108
107
|
args: [{ selector: 'tots-input-column', template: "<mat-form-field class=\"{{getClass()}}\" [appearance]=\"getAppearance()\" (click)=\"$event.stopPropagation()\">\n <mat-label *ngIf=\"getLabel()\"> {{ getLabel() }} </mat-label>\n <input matInput type=\"text\" [formControl]=\"input\" [placeholder]=\"getPlaceholder()\"/>\n <mat-hint *ngIf=\"getCaption()\" [align]=\"'end'\"> {{getCaption()}} </mat-hint>\n <mat-error *ngIf=\"hasError()\">{{getErrorMessage()}}</mat-error>\n</mat-form-field>\n", styles: ["mat-form-field{margin-bottom:0}\n"] }]
|
|
109
108
|
}], ctorParameters: function () { return []; } });
|
|
110
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-column.component.js","sourceRoot":"","sources":["../../../../../../../projects/tots/editable-columns/src/lib/columns/input-column/input-column.component.ts","../../../../../../../projects/tots/editable-columns/src/lib/columns/input-column/input-column.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy } from '@angular/core';\nimport { FormControl, FormGroup, ValidatorFn } from '@angular/forms';\nimport { MatFormFieldAppearance } from '@angular/material/form-field';\nimport { TotsBaseColumnComponent, TotsTableHelper } from '@tots/table';\n\n@Component({\n  selector: 'tots-input-column',\n  templateUrl: './input-column.component.html',\n  styleUrls: ['./input-column.component.css']\n})\nexport class InputColumnComponent extends TotsBaseColumnComponent implements OnDestroy {\n\n  input!: FormControl;\n\n  constructor() {\n    super();\n  }\n\n  ngOnInit(): void {\n    this.loadInput();\n    this.loadForm();\n    this.loadChanges();\n  }\n  ngOnDestroy(): void {\n    this.onAction.next({ key: 'input-destroy', item: this.index });\n  }\n\n  loadChanges() {\n    this.input.valueChanges\n    .subscribe(res => {\n      this.onAction.next({ key: 'input-change', item: { field_key: this.getFormKey(), item: this.item, value: res, valid: this.input.valid, index: this.index } });\n    });\n  }\n\n  loadForm() {\n    if(this.column.extra == undefined || this.column.extra.group == undefined){\n      return;\n    }\n\n    let group: FormGroup = this.column.extra.group;\n    if(group.get(this.getFormKey()) != undefined){\n        return;\n    }\n\n    group.addControl(this.getFormKey(), this.input);\n  }\n\n  loadInput() {\n    let value = TotsTableHelper.getItemValueByKey(this.item, this.column.field_key);\n    this.input = new FormControl(value, this.getValidators());\n\n    this.onAction.next({ key: 'input-create', item: { field_key: this.getFormKey(), input: this.input, index: this.index, column: this.column } });\n  }\n\n  getFormKey(): string {\n    if(Array.isArray(this.column.field_key)){\n      return this.column.field_key.join('_');\n    } else {\n      return this.column.field_key!;\n    }\n  }\n\n  getValidators() : ValidatorFn[] | ValidatorFn | null {\n    if (this.column.extra && this.column.extra.validators) {\n      return this.column.extra.validators;\n    }\n    return null;\n  }\n\n  getErrorMessage() : string {\n    if (!this.column.extra.errors) {\n      return '';\n    }\n\n    for (const error of this.column.extra.errors) {\n      if (this.input.hasError(error.name)) {\n        return error.message;\n      }\n    }\n\n    return '';\n  }\n\n  getAppearance() : MatFormFieldAppearance {\n    if (this.column.extra && this.column.extra.appearance) {\n      return this.column.extra.appearance;\n    }\n    return 'fill';\n  }\n\n  getLabel() : string | undefined {\n    if (this.column.extra && this.column.extra.label) {\n      return this.column.extra.label;\n    }\n    return undefined;\n  }\n\n  getClass() : string {\n    if (this.column.extra && this.column.extra.class) {\n      return this.column.extra.class;\n    }\n    return '';\n  }\n\n  getPlaceholder() : string {\n    if (this.column.extra && this.column.extra.placeholder) {\n      return this.column.extra.placeholder;\n    }\n    return '';\n  }\n\n  getCaption() : string {\n    if (this.column.extra && this.column.extra.caption) {\n      return this.column.extra.caption;\n    }\n    return '';\n  }\n\n  hasError() : boolean {\n    return this.input.invalid && (this.input.dirty || this.input.touched);\n  }\n\n  getInput() {\n    return this.input;\n  }\n}\n","<mat-form-field class=\"{{getClass()}}\" [appearance]=\"getAppearance()\" (click)=\"$event.stopPropagation()\">\n  <mat-label *ngIf=\"getLabel()\"> {{ getLabel() }} </mat-label>\n  <input matInput type=\"text\" [formControl]=\"input\" [placeholder]=\"getPlaceholder()\"/>\n  <mat-hint *ngIf=\"getCaption()\" [align]=\"'end'\"> {{getCaption()}} </mat-hint>\n  <mat-error *ngIf=\"hasError()\">{{getErrorMessage()}}</mat-error>\n</mat-form-field>\n"]}
|
|
109
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-column.component.js","sourceRoot":"","sources":["../../../../../../../projects/tots/editable-columns/src/lib/columns/input-column/input-column.component.ts","../../../../../../../projects/tots/editable-columns/src/lib/columns/input-column/input-column.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy } from '@angular/core';\nimport { FormControl, FormGroup, ValidatorFn } from '@angular/forms';\nimport { MatFormFieldAppearance } from '@angular/material/form-field';\nimport { TotsBaseColumnComponent, TotsTableHelper } from '@tots/table';\n\n@Component({\n  selector: 'tots-input-column',\n  templateUrl: './input-column.component.html',\n  styleUrls: ['./input-column.component.css']\n})\nexport class InputColumnComponent extends TotsBaseColumnComponent implements OnDestroy {\n\n  input!: FormControl;\n\n  constructor() {\n    super();\n  }\n\n  ngOnInit(): void {\n    this.loadInput();\n    this.loadForm();\n    this.loadChanges();\n  }\n  ngOnDestroy(): void {\n    this.onAction.next({ key: 'input-destroy', item: { field_key: this.getFormKey(), index: this.index } });\n  }\n\n  loadChanges() {\n    this.input.valueChanges.subscribe(value => {\n      this.onAction.next({ key: 'input-change', item: { field_key: this.getFormKey(), item: this.item, value: value, valid: this.input.valid, index: this.index } });\n    });\n  }\n\n  loadForm() {\n    if(this.column.extra == undefined || this.column.extra.group == undefined){\n      return;\n    }\n\n    let group: FormGroup = this.column.extra.group;\n    if(group.get(this.getFormKey()) != undefined){\n        return;\n    }\n\n    group.addControl(this.getFormKey(), this.input);\n  }\n\n  loadInput() {\n    let value = TotsTableHelper.getItemValueByKey(this.item, this.column.field_key);\n    this.input = new FormControl(value, this.getValidators());\n\n    this.onAction.next({ key: 'input-create', item: { field_key: this.getFormKey(), input: this.input, index: this.index, column: this.column } });\n  }\n\n  getFormKey(): string {\n    if(Array.isArray(this.column.field_key)){\n      return this.column.field_key.join('_');\n    } else {\n      return this.column.field_key!;\n    }\n  }\n\n  getValidators() : ValidatorFn[] | ValidatorFn | null {\n    if (this.column.extra && this.column.extra.validators) {\n      return this.column.extra.validators;\n    }\n    return null;\n  }\n\n  getErrorMessage() : string {\n    if (!this.column.extra.errors) {\n      return '';\n    }\n\n    for (const error of this.column.extra.errors) {\n      if (this.input.hasError(error.name)) {\n        return error.message;\n      }\n    }\n\n    return '';\n  }\n\n  getAppearance() : MatFormFieldAppearance {\n    if (this.column.extra && this.column.extra.appearance) {\n      return this.column.extra.appearance;\n    }\n    return 'fill';\n  }\n\n  getLabel() : string | undefined {\n    if (this.column.extra && this.column.extra.label) {\n      return this.column.extra.label;\n    }\n    return undefined;\n  }\n\n  getClass() : string {\n    if (this.column.extra && this.column.extra.class) {\n      return this.column.extra.class;\n    }\n    return '';\n  }\n\n  getPlaceholder() : string {\n    if (this.column.extra && this.column.extra.placeholder) {\n      return this.column.extra.placeholder;\n    }\n    return '';\n  }\n\n  getCaption() : string {\n    if (this.column.extra && this.column.extra.caption) {\n      return this.column.extra.caption;\n    }\n    return '';\n  }\n\n  hasError() : boolean {\n    return this.input.invalid && (this.input.dirty || this.input.touched);\n  }\n\n  getInput() {\n    return this.input;\n  }\n}\n","<mat-form-field class=\"{{getClass()}}\" [appearance]=\"getAppearance()\" (click)=\"$event.stopPropagation()\">\n  <mat-label *ngIf=\"getLabel()\"> {{ getLabel() }} </mat-label>\n  <input matInput type=\"text\" [formControl]=\"input\" [placeholder]=\"getPlaceholder()\"/>\n  <mat-hint *ngIf=\"getCaption()\" [align]=\"'end'\"> {{getCaption()}} </mat-hint>\n  <mat-error *ngIf=\"hasError()\">{{getErrorMessage()}}</mat-error>\n</mat-form-field>\n"]}
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import { FormControl } from '@angular/forms';
|
|
3
|
+
import { TotsBaseColumnComponent, TotsTableHelper } from '@tots/table';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "@angular/forms";
|
|
7
|
+
import * as i3 from "@angular/material/form-field";
|
|
8
|
+
import * as i4 from "@angular/material/select";
|
|
9
|
+
import * as i5 from "@angular/material/core";
|
|
10
|
+
export class SelectColumnComponent extends TotsBaseColumnComponent {
|
|
11
|
+
constructor() {
|
|
12
|
+
super();
|
|
13
|
+
}
|
|
14
|
+
ngOnInit() {
|
|
15
|
+
this.loadInput();
|
|
16
|
+
this.loadForm();
|
|
17
|
+
this.loadChanges();
|
|
18
|
+
this.options = this.column.extra.options || [];
|
|
19
|
+
}
|
|
20
|
+
loadChanges() {
|
|
21
|
+
this.input.valueChanges
|
|
22
|
+
.subscribe(res => {
|
|
23
|
+
this.onAction.next({ key: 'input-change', item: { field_key: this.getFormKey(), item: this.item, value: res, valid: this.input.valid, index: this.index } });
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
loadForm() {
|
|
27
|
+
if (this.column.extra == undefined || this.column.extra.group == undefined) {
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
let group = this.column.extra.group;
|
|
31
|
+
if (group.get(this.getFormKey()) != undefined) {
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
group.addControl(this.getFormKey(), this.input);
|
|
35
|
+
}
|
|
36
|
+
loadInput() {
|
|
37
|
+
let value = TotsTableHelper.getItemValueByKey(this.item, this.column.field_key);
|
|
38
|
+
this.input = new FormControl(value, this.getValidators());
|
|
39
|
+
this.onAction.next({ key: 'input-create', item: { field_key: this.getFormKey(), input: this.input, index: this.index, column: this.column } });
|
|
40
|
+
}
|
|
41
|
+
getOptionValue(option) {
|
|
42
|
+
return TotsTableHelper.getItemValueByKey(option, this.column.extra.field_select_key);
|
|
43
|
+
}
|
|
44
|
+
displayOption(option) {
|
|
45
|
+
return TotsTableHelper.getItemValueByKey(option, this.column.extra.field_print_key);
|
|
46
|
+
}
|
|
47
|
+
getFormKey() {
|
|
48
|
+
if (Array.isArray(this.column.field_key)) {
|
|
49
|
+
return this.column.field_key.join('_');
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
return this.column.field_key;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
getValidators() {
|
|
56
|
+
if (this.column.extra && this.column.extra.validators) {
|
|
57
|
+
return this.column.extra.validators;
|
|
58
|
+
}
|
|
59
|
+
return null;
|
|
60
|
+
}
|
|
61
|
+
getErrorMessage() {
|
|
62
|
+
if (!this.column.extra.errors) {
|
|
63
|
+
return '';
|
|
64
|
+
}
|
|
65
|
+
for (const error of this.column.extra.errors) {
|
|
66
|
+
if (this.input.hasError(error.name)) {
|
|
67
|
+
return error.message;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
return '';
|
|
71
|
+
}
|
|
72
|
+
getAppearance() {
|
|
73
|
+
if (this.column.extra && this.column.extra.appearance) {
|
|
74
|
+
return this.column.extra.appearance;
|
|
75
|
+
}
|
|
76
|
+
return 'fill';
|
|
77
|
+
}
|
|
78
|
+
getLabel() {
|
|
79
|
+
if (this.column.extra && this.column.extra.label) {
|
|
80
|
+
return this.column.extra.label;
|
|
81
|
+
}
|
|
82
|
+
return undefined;
|
|
83
|
+
}
|
|
84
|
+
getClasses() {
|
|
85
|
+
if (this.column.extra && this.column.extra.classes) {
|
|
86
|
+
return this.column.extra.classes;
|
|
87
|
+
}
|
|
88
|
+
return '';
|
|
89
|
+
}
|
|
90
|
+
getPlaceholder() {
|
|
91
|
+
if (this.column.extra && this.column.extra.placeholder) {
|
|
92
|
+
return this.column.extra.placeholder;
|
|
93
|
+
}
|
|
94
|
+
return '';
|
|
95
|
+
}
|
|
96
|
+
getCaption() {
|
|
97
|
+
if (this.column.extra && this.column.extra.caption) {
|
|
98
|
+
return this.column.extra.caption;
|
|
99
|
+
}
|
|
100
|
+
return '';
|
|
101
|
+
}
|
|
102
|
+
hasError() {
|
|
103
|
+
return this.input.invalid && (this.input.dirty || this.input.touched);
|
|
104
|
+
}
|
|
105
|
+
getInput() {
|
|
106
|
+
return this.input;
|
|
107
|
+
}
|
|
108
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: SelectColumnComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
109
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.11", type: SelectColumnComponent, selector: "tots-select-column", usesInheritance: true, ngImport: i0, template: "<mat-form-field class=\"{{getClasses()}}\" [appearance]=\"getAppearance()\" (click)=\"$event.stopPropagation()\">\n <mat-label *ngIf=\"getLabel()\"> {{ getLabel() }} </mat-label>\n <mat-select [formControl]=\"input\" [placeholder]=\"getPlaceholder()\">\n <mat-option *ngFor=\"let option of options; let index=index;\" [value]=\"getOptionValue(option)\">\n {{ displayOption(option) }}\n </mat-option>\n </mat-select>\n <mat-hint *ngIf=\"getCaption()\" [align]=\"'end'\"> {{getCaption()}} </mat-hint>\n <mat-error *ngIf=\"hasError()\">{{getErrorMessage()}}</mat-error>\n</mat-form-field>\n", styles: ["mat-form-field{margin-bottom:0}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "component", type: i4.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex", "panelWidth", "hideSingleSelectionIndicator"], exportAs: ["matSelect"] }, { kind: "component", type: i5.MatOption, selector: "mat-option", exportAs: ["matOption"] }] }); }
|
|
110
|
+
}
|
|
111
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: SelectColumnComponent, decorators: [{
|
|
112
|
+
type: Component,
|
|
113
|
+
args: [{ selector: 'tots-select-column', template: "<mat-form-field class=\"{{getClasses()}}\" [appearance]=\"getAppearance()\" (click)=\"$event.stopPropagation()\">\n <mat-label *ngIf=\"getLabel()\"> {{ getLabel() }} </mat-label>\n <mat-select [formControl]=\"input\" [placeholder]=\"getPlaceholder()\">\n <mat-option *ngFor=\"let option of options; let index=index;\" [value]=\"getOptionValue(option)\">\n {{ displayOption(option) }}\n </mat-option>\n </mat-select>\n <mat-hint *ngIf=\"getCaption()\" [align]=\"'end'\"> {{getCaption()}} </mat-hint>\n <mat-error *ngIf=\"hasError()\">{{getErrorMessage()}}</mat-error>\n</mat-form-field>\n", styles: ["mat-form-field{margin-bottom:0}\n"] }]
|
|
114
|
+
}], ctorParameters: function () { return []; } });
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-column.component.js","sourceRoot":"","sources":["../../../../../../../projects/tots/editable-columns/src/lib/columns/select-column/select-column.component.ts","../../../../../../../projects/tots/editable-columns/src/lib/columns/select-column/select-column.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component } from '@angular/core';\nimport { FormControl, FormGroup, ValidatorFn } from '@angular/forms';\nimport { MatFormFieldAppearance } from '@angular/material/form-field';\nimport { TotsBaseColumnComponent, TotsTableHelper } from '@tots/table';\n\n@Component({\n  selector: 'tots-select-column',\n  templateUrl: './select-column.component.html',\n  styleUrls: ['./select-column.component.css']\n})\nexport class SelectColumnComponent extends TotsBaseColumnComponent {\n\n  input!: FormControl;\n  protected options! : any[];\n\n  constructor() {\n    super();\n  }\n\n  ngOnInit(): void {\n    this.loadInput();\n    this.loadForm();\n    this.loadChanges();\n    this.options = this.column.extra.options || [];\n  }\n\n  loadChanges() {\n    this.input.valueChanges\n    .subscribe(res => {\n      this.onAction.next({ key: 'input-change', item: { field_key: this.getFormKey(), item: this.item, value: res, valid: this.input.valid, index: this.index } });\n    });\n  }\n\n  loadForm() {\n    if(this.column.extra == undefined || this.column.extra.group == undefined){\n      return;\n    }\n\n    let group: FormGroup = this.column.extra.group;\n    if(group.get(this.getFormKey()) != undefined){\n        return;\n    }\n\n    group.addControl(this.getFormKey(), this.input);\n  }\n\n  loadInput() {\n    let value = TotsTableHelper.getItemValueByKey(this.item, this.column.field_key);\n    this.input = new FormControl(value, this.getValidators());\n\n    this.onAction.next({ key: 'input-create', item: { field_key: this.getFormKey(), input: this.input, index: this.index, column: this.column } });\n  }\n\n  protected getOptionValue(option:any) {\n    return TotsTableHelper.getItemValueByKey(option, this.column.extra.field_select_key);\n  }\n  protected displayOption(option:any) {\n    return TotsTableHelper.getItemValueByKey(option, this.column.extra.field_print_key);\n  }\n\n  getFormKey(): string {\n    if(Array.isArray(this.column.field_key)){\n      return this.column.field_key.join('_');\n    } else {\n      return this.column.field_key!;\n    }\n  }\n\n  getValidators() : ValidatorFn[] | ValidatorFn | null {\n    if (this.column.extra && this.column.extra.validators) {\n      return this.column.extra.validators;\n    }\n    return null;\n  }\n\n  getErrorMessage() : string {\n    if (!this.column.extra.errors) {\n      return '';\n    }\n\n    for (const error of this.column.extra.errors) {\n      if (this.input.hasError(error.name)) {\n        return error.message;\n      }\n    }\n\n    return '';\n  }\n\n  getAppearance() : MatFormFieldAppearance {\n    if (this.column.extra && this.column.extra.appearance) {\n      return this.column.extra.appearance;\n    }\n    return 'fill';\n  }\n\n  getLabel() : string | undefined {\n    if (this.column.extra && this.column.extra.label) {\n      return this.column.extra.label;\n    }\n    return undefined;\n  }\n\n  getClasses() : string {\n    if (this.column.extra && this.column.extra.classes) {\n      return this.column.extra.classes;\n    }\n    return '';\n  }\n\n  getPlaceholder() : string {\n    if (this.column.extra && this.column.extra.placeholder) {\n      return this.column.extra.placeholder;\n    }\n    return '';\n  }\n\n  getCaption() : string {\n    if (this.column.extra && this.column.extra.caption) {\n      return this.column.extra.caption;\n    }\n    return '';\n  }\n\n  hasError() : boolean {\n    return this.input.invalid && (this.input.dirty || this.input.touched);\n  }\n\n  getInput() {\n    return this.input;\n  }\n}\n","<mat-form-field class=\"{{getClasses()}}\" [appearance]=\"getAppearance()\" (click)=\"$event.stopPropagation()\">\n  <mat-label *ngIf=\"getLabel()\"> {{ getLabel() }} </mat-label>\n  <mat-select [formControl]=\"input\" [placeholder]=\"getPlaceholder()\">\n    <mat-option *ngFor=\"let option of options; let index=index;\" [value]=\"getOptionValue(option)\">\n      {{ displayOption(option) }}\n    </mat-option>\n  </mat-select>\n  <mat-hint *ngIf=\"getCaption()\" [align]=\"'end'\"> {{getCaption()}} </mat-hint>\n  <mat-error *ngIf=\"hasError()\">{{getErrorMessage()}}</mat-error>\n</mat-form-field>\n"]}
|
|
@@ -20,21 +20,37 @@ export class TotsTableFullGroupComponent {
|
|
|
20
20
|
else if (action.key == 'input-change') {
|
|
21
21
|
this.onAction.emit(action);
|
|
22
22
|
setTimeout(() => {
|
|
23
|
-
this.
|
|
23
|
+
this.emitFormChange();
|
|
24
24
|
});
|
|
25
25
|
}
|
|
26
26
|
else if (action.key == "input-destroy") {
|
|
27
|
-
this.removeInputFromGroup(action.item);
|
|
27
|
+
this.removeInputFromGroup(action.item.index, action.item.field_key);
|
|
28
28
|
}
|
|
29
29
|
this.onAction.emit(action);
|
|
30
30
|
}
|
|
31
31
|
addInputInGroup(input, index, column) {
|
|
32
|
-
let group =
|
|
33
|
-
group
|
|
34
|
-
|
|
32
|
+
let group = this.formArrayMain.at(index);
|
|
33
|
+
if (group) {
|
|
34
|
+
group.addControl(this.getFormKey(column), input);
|
|
35
|
+
this.formArrayMain.setControl(index, group);
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
group = new FormGroup({});
|
|
39
|
+
group.addControl(this.getFormKey(column), input);
|
|
40
|
+
this.formArrayMain.push(group);
|
|
41
|
+
this.emitFormChange();
|
|
42
|
+
}
|
|
35
43
|
}
|
|
36
|
-
removeInputFromGroup(index) {
|
|
37
|
-
this.formArrayMain.
|
|
44
|
+
removeInputFromGroup(index, field_key) {
|
|
45
|
+
let formGroup = this.formArrayMain.at(index);
|
|
46
|
+
if (!formGroup)
|
|
47
|
+
return;
|
|
48
|
+
formGroup.removeControl(field_key);
|
|
49
|
+
let keys = Object.keys(formGroup.controls);
|
|
50
|
+
if (keys.length == 0) {
|
|
51
|
+
this.formArrayMain.removeAt(index);
|
|
52
|
+
this.emitFormChange();
|
|
53
|
+
}
|
|
38
54
|
}
|
|
39
55
|
getFormKey(column) {
|
|
40
56
|
if (Array.isArray(column.field_key)) {
|
|
@@ -47,6 +63,9 @@ export class TotsTableFullGroupComponent {
|
|
|
47
63
|
loadItems() {
|
|
48
64
|
this.tableComp?.loadItems();
|
|
49
65
|
}
|
|
66
|
+
emitFormChange() {
|
|
67
|
+
this.onAction.emit({ key: 'form-change', item: { valid: this.formArrayMain.valid, values: this.formArrayMain.value } });
|
|
68
|
+
}
|
|
50
69
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: TotsTableFullGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
51
70
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.11", type: TotsTableFullGroupComponent, selector: "tots-table-full-group", inputs: { config: "config", pageIndex: "pageIndex", pageSize: "pageSize", hasPagination: "hasPagination", messageNotFound: "messageNotFound" }, outputs: { onAction: "onAction" }, viewQueries: [{ propertyName: "tableComp", first: true, predicate: ["tableComp"], descendants: true }], ngImport: i0, template: "<tots-table #tableComp [config]=\"config\" [pageIndex]=\"pageIndex\" [pageSize]=\"pageSize\" [hasPagination]=\"hasPagination\" [messageNotFound]=\"messageNotFound\" (onAction)=\"onTableAction($event)\"></tots-table>\n", styles: [""], dependencies: [{ kind: "component", type: i1.TotsTableComponent, selector: "tots-table", inputs: ["config", "pageIndex", "pageSize", "hasPagination", "messageNotFound"], outputs: ["onAction"] }] }); }
|
|
52
71
|
}
|
|
@@ -69,4 +88,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImpo
|
|
|
69
88
|
}], onAction: [{
|
|
70
89
|
type: Output
|
|
71
90
|
}] } });
|
|
72
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG90cy10YWJsZS1mdWxsLWdyb3VwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RvdHMvZWRpdGFibGUtY29sdW1ucy9zcmMvbGliL2NvbXBvbmVudHMvdG90cy10YWJsZS1mdWxsLWdyb3VwL3RvdHMtdGFibGUtZnVsbC1ncm91cC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90b3RzL2VkaXRhYmxlLWNvbHVtbnMvc3JjL2xpYi9jb21wb25lbnRzL3RvdHMtdGFibGUtZnVsbC1ncm91cC90b3RzLXRhYmxlLWZ1bGwtZ3JvdXAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbEYsT0FBTyxFQUFFLFNBQVMsRUFBZSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUVuRSxPQUFPLEVBQW1ELGVBQWUsRUFBRSxNQUFNLGFBQWEsQ0FBQzs7O0FBTy9GLE1BQU0sT0FBTywyQkFBMkI7SUFMeEM7UUFTVyxXQUFNLEdBQUcsSUFBSSxlQUFlLEVBQUUsQ0FBQztRQUMvQixjQUFTLEdBQVcsQ0FBQyxDQUFDO1FBQ3RCLGFBQVEsR0FBVyxFQUFFLENBQUM7UUFDdEIsa0JBQWEsR0FBWSxJQUFJLENBQUM7UUFDOUIsb0JBQWUsR0FBVyxzREFBc0QsQ0FBQztRQUVoRixhQUFRLEdBQUcsSUFBSSxZQUFZLEVBQW1CLENBQUM7UUFFekQsa0JBQWEsR0FBMEIsSUFBSSxTQUFTLENBQVksRUFBRSxDQUFDLENBQUM7S0FnRXJFO0lBOURXLGFBQWEsQ0FBQyxNQUF1QjtRQUM3QyxJQUFJLE1BQU0sQ0FBQyxHQUFHLElBQUksY0FBYyxFQUFFO1lBQ2hDLElBQUksQ0FBQyxlQUFlLENBQUMs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QjttR0FBM0IsMkJBQTJCLHdWQ1Z4QywyTkFDQTs7NEZEU2EsMkJBQTJCO2tCQUx2QyxTQUFTOytCQUNFLHVCQUF1Qjs4QkFNQyxTQUFTO3NCQUExQyxTQUFTO3VCQUFDLFdBQVc7Z0JBRWIsTUFBTTtzQkFBZCxLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLO2dCQUNHLGVBQWU7c0JBQXZCLEtBQUs7Z0JBRUksUUFBUTtzQkFBakIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0LCBWaWV3Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1BcnJheSwgRm9ybUNvbnRyb2wsIEZvcm1Hcm91cCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IFRvdHNMaXN0UmVzcG9uc2UgfSBmcm9tICdAdG90cy9jb3JlJztcbmltcG9ydCB7IFRvdHNBY3Rpb25UYWJsZSwgVG90c0NvbHVtbiwgVG90c1RhYmxlQ29tcG9uZW50LCBUb3RzVGFibGVDb25maWcgfSBmcm9tICdAdG90cy90YWJsZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3RvdHMtdGFibGUtZnVsbC1ncm91cCcsXG4gIHRlbXBsYXRlVXJsOiAnLi90b3RzLXRhYmxlLWZ1bGwtZ3JvdXAuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi90b3RzLXRhYmxlLWZ1bGwtZ3JvdXAuY29tcG9uZW50LmNzcyddXG59KVxuZXhwb3J0IGNsYXNzIFRvdHNUYWJsZUZ1bGxHcm91cENvbXBvbmVudCB7XG5cbiAgQFZpZXdDaGlsZCgndGFibGVDb21wJykgcHJvdGVjdGVkIHRhYmxlQ29tcCE6IFRvdHNUYWJsZUNvbXBvbmVudDtcblxuICBASW5wdXQoKSBjb25maWcgPSBuZXcgVG90c1RhYmxlQ29uZmlnKCk7XG4gIEBJbnB1dCgpIHBhZ2VJbmRleDogbnVtYmVyID0gMDtcbiAgQElucHV0KCkgcGFnZVNpemU6IG51bWJlciA9IDUwO1xuICBASW5wdXQoKSBoYXNQYWdpbmF0aW9uOiBib29sZWFuID0gdHJ1ZTtcbiAgQElucHV0KCkgbWVzc2FnZU5vdEZvdW5kOiBzdHJpbmcgPSBcIk5vIHJlc3VsdHMgZm91bmQsIHBsZWFzZSB0cnkgd2l0aCBvdGhlciBzZWFyY2ggdGVybXNcIjtcblxuICBAT3V0cHV0KCkgb25BY3Rpb24gPSBuZXcgRXZlbnRFbWl0dGVyPFRvdHNBY3Rpb25UYWJsZT4oKTtcblxuICBmb3JtQXJyYXlNYWluIDogRm9ybUFycmF5PEZvcm1Hcm91cD4gPSBuZXcgRm9ybUFycmF5PEZvcm1Hcm91cD4oW10pO1xuXG4gIHByb3RlY3RlZCBvblRhYmxlQWN0aW9uKGFjdGlvbjogVG90c0FjdGlvblRhYmxlKSB7XG4gICAgaWYgKGFjdGlvbi5rZXkgPT0gJ2lucHV0LWNyZWF0ZScpIHtcbiAgICAgIHRoaXMuYWRkSW5wdXRJbkdyb3VwKGFjdGlvbi5pdGVtLmlucHV0LCBhY3Rpb24uaXRlbS5pbmRleCwgYWN0aW9uLml0ZW0uY29sdW1uKTtcblxuICAgIH0gZWxzZSBpZiAoYWN0aW9uLmtleSA9PSAnaW5wdXQtY2hhbmdlJykge1xuICAgICAgdGhpcy5vbkFjdGlvbi5lbWl0KGFjdGlvbik7XG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgdGhpcy5lbWl0Rm9ybUNoYW5nZSgpO1xuICAgICAgfSk7XG5cbiAgICB9IGVsc2UgaWYgKGFjdGlvbi5rZXkgPT0gXCJpbnB1dC1kZXN0cm95XCIgKSB7XG4gICAgICB0aGlzLnJlbW92ZUlucHV0RnJvbUdyb3VwKGFjdGlvbi5pdGVtLmluZGV4LCBhY3Rpb24uaXRlbS5maWVsZF9rZXkpO1xuICAgIH1cblxuICAgIHRoaXMub25BY3Rpb24uZW1pdChhY3Rpb24pO1xuICB9XG5cbiAgcHJpdmF0ZSBhZGRJbnB1dEluR3JvdXAoaW5wdXQ6IEZvcm1Db250cm9sLCBpbmRleDogbnVtYmVyLCBjb2x1bW46IFRvdHNDb2x1bW4pIHtcbiAgICBsZXQgZ3JvdXAgPSB0aGlzLmZvcm1BcnJheU1haW4uYXQoaW5kZXgpO1xuICAgIFxuICAgIGlmIChncm91cCkge1xuICAgICAgZ3JvdXAuYWRkQ29udHJvbCh0aGlzLmdldEZvcm1LZXkoY29sdW1uKSwgaW5wdXQpO1xuICAgICAgdGhpcy5mb3JtQXJyYXlNYWluLnNldENvbnRyb2woaW5kZXgsIGdyb3VwKTtcblxuICAgIH0gZWxzZSB7XG4gICAgICBncm91cCA9IG5ldyBGb3JtR3JvdXAoe30pO1xuICAgICAgZ3JvdXAuYWRkQ29udHJvbCh0aGlzLmdldEZvcm1LZXkoY29sdW1uKSwgaW5wdXQpO1xuICAgICAgdGhpcy5mb3JtQXJyYXlNYWluLnB1c2goZ3JvdXApO1xuICAgICAgdGhpcy5lbWl0Rm9ybUNoYW5nZSgpO1xuICAgIH1cbiAgICBcbiAgfVxuICBwcml2YXRlIHJlbW92ZUlucHV0RnJvbUdyb3VwKGluZGV4OiBudW1iZXIsIGZpZWxkX2tleTogc3RyaW5nKSB7XG4gICAgbGV0IGZvcm1Hcm91cCA9IHRoaXMuZm9ybUFycmF5TWFpbi5hdChpbmRleCk7XG4gICAgaWYgKCFmb3JtR3JvdXApXG4gICAgICByZXR1cm5cblxuICAgIGZvcm1Hcm91cC5yZW1vdmVDb250cm9sKGZpZWxkX2tleSk7XG5cbiAgICBsZXQga2V5cyA9IE9iamVjdC5rZXlzKGZvcm1Hcm91cC5jb250cm9scyk7XG5cbiAgICBpZiAoa2V5cy5sZW5ndGggPT0gMCkge1xuICAgICAgdGhpcy5mb3JtQXJyYXlNYWluLnJlbW92ZUF0KGluZGV4KTtcbiAgICAgIHRoaXMuZW1pdEZvcm1DaGFuZ2UoKTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIGdldEZvcm1LZXkoY29sdW1uOiBUb3RzQ29sdW1uKTogc3RyaW5nIHtcbiAgICBpZihBcnJheS5pc0FycmF5KGNvbHVtbi5maWVsZF9rZXkpKXtcbiAgICAgIHJldHVybiBjb2x1bW4uZmllbGRfa2V5LmpvaW4oJ18nKTtcbiAgICB9IGVsc2Uge1xuICAgICAgcmV0dXJuIGNvbHVtbi5maWVsZF9rZXkhO1xuICAgIH1cbiAgfVxuXG4gIGxvYWRJdGVtcygpIHtcbiAgICB0aGlzLnRhYmxlQ29tcD8ubG9hZEl0ZW1zKCk7XG4gIH1cblxuICBwcml2YXRlIGVtaXRGb3JtQ2hhbmdlKCkge1xuICAgIHRoaXMub25BY3Rpb24uZW1pdCh7IGtleTogJ2Zvcm0tY2hhbmdlJywgaXRlbTogeyB2YWxpZDogdGhpcy5mb3JtQXJyYXlNYWluLnZhbGlkLCB2YWx1ZXM6IHRoaXMuZm9ybUFycmF5TWFpbi52YWx1ZSB9IH0pO1xuICB9XG59XG4iLCI8dG90cy10YWJsZSAjdGFibGVDb21wIFtjb25maWddPVwiY29uZmlnXCIgW3BhZ2VJbmRleF09XCJwYWdlSW5kZXhcIiBbcGFnZVNpemVdPVwicGFnZVNpemVcIiBbaGFzUGFnaW5hdGlvbl09XCJoYXNQYWdpbmF0aW9uXCIgW21lc3NhZ2VOb3RGb3VuZF09XCJtZXNzYWdlTm90Rm91bmRcIiAob25BY3Rpb24pPVwib25UYWJsZUFjdGlvbigkZXZlbnQpXCI+PC90b3RzLXRhYmxlPlxuIl19
|
|
@@ -4,10 +4,12 @@ import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
|
4
4
|
/** Angular Material */
|
|
5
5
|
import { MatInputModule } from '@angular/material/input';
|
|
6
6
|
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
7
|
+
import { MatSelectModule } from '@angular/material/select';
|
|
7
8
|
/** Tots Libraries */
|
|
8
9
|
import { TotsTableModule } from '@tots/table';
|
|
9
10
|
/** Columns */
|
|
10
11
|
import { InputColumnComponent } from './columns/input-column/input-column.component';
|
|
12
|
+
import { SelectColumnComponent } from './columns/select-column/select-column.component';
|
|
11
13
|
/** Components */
|
|
12
14
|
import { TotsTableFullGroupComponent } from './components/tots-table-full-group/tots-table-full-group.component';
|
|
13
15
|
import * as i0 from "@angular/core";
|
|
@@ -16,6 +18,7 @@ export class TotsEditableColumnsModule {
|
|
|
16
18
|
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.11", ngImport: i0, type: TotsEditableColumnsModule, declarations: [
|
|
17
19
|
/** Columns */
|
|
18
20
|
InputColumnComponent,
|
|
21
|
+
SelectColumnComponent,
|
|
19
22
|
/** Components */
|
|
20
23
|
TotsTableFullGroupComponent], imports: [CommonModule,
|
|
21
24
|
FormsModule,
|
|
@@ -23,6 +26,7 @@ export class TotsEditableColumnsModule {
|
|
|
23
26
|
/** Angular Material */
|
|
24
27
|
MatFormFieldModule,
|
|
25
28
|
MatInputModule,
|
|
29
|
+
MatSelectModule,
|
|
26
30
|
/** Tots Libraries */
|
|
27
31
|
TotsTableModule], exports: [
|
|
28
32
|
/** Columns */
|
|
@@ -35,6 +39,7 @@ export class TotsEditableColumnsModule {
|
|
|
35
39
|
/** Angular Material */
|
|
36
40
|
MatFormFieldModule,
|
|
37
41
|
MatInputModule,
|
|
42
|
+
MatSelectModule,
|
|
38
43
|
/** Tots Libraries */
|
|
39
44
|
TotsTableModule] }); }
|
|
40
45
|
}
|
|
@@ -44,6 +49,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImpo
|
|
|
44
49
|
declarations: [
|
|
45
50
|
/** Columns */
|
|
46
51
|
InputColumnComponent,
|
|
52
|
+
SelectColumnComponent,
|
|
47
53
|
/** Components */
|
|
48
54
|
TotsTableFullGroupComponent
|
|
49
55
|
],
|
|
@@ -54,6 +60,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImpo
|
|
|
54
60
|
/** Angular Material */
|
|
55
61
|
MatFormFieldModule,
|
|
56
62
|
MatInputModule,
|
|
63
|
+
MatSelectModule,
|
|
57
64
|
/** Tots Libraries */
|
|
58
65
|
TotsTableModule
|
|
59
66
|
],
|
|
@@ -65,4 +72,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImpo
|
|
|
65
72
|
]
|
|
66
73
|
}]
|
|
67
74
|
}] });
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdGFibGUtY29sdW1ucy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90b3RzL2VkaXRhYmxlLWNvbHVtbnMvc3JjL2xpYi9lZGl0YWJsZS1jb2x1bW5zLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFbEUsdUJBQXVCO0FBQ3ZCLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFFM0QscUJBQXFCO0FBQ3JCLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFOUMsY0FBYztBQUNkLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLCtDQUErQyxDQUFDO0FBQ3JGLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGlEQUFpRCxDQUFDO0FBRXhGLGlCQUFpQjtBQUNqQixPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxvRUFBb0UsQ0FBQzs7QUFvQ2pILE1BQU0sT0FBTyx5QkFBeUI7K0dBQXpCLHlCQUF5QjtnSEFBekIseUJBQXlCO1lBNUJsQyxjQUFjO1lBQ2Qsb0JBQW9CO1lBQ3BCLHFCQUFxQjtZQUVyQixpQkFBaUI7WUFDakIsMkJBQTJCLGFBRzNCLFlBQVk7WUFDWixXQUFXO1lBQ1gsbUJBQW1CO1lBRW5CLHVCQUF1QjtZQUN2QixrQkFBa0I7WUFDbEIsY0FBYztZQUNkLGVBQWU7WUFFZixxQkFBcUI7WUFDckIsZUFBZTtZQUdmLGNBQWM7WUFDZCxvQkFBb0I7WUFFcEIsaUJBQWlCO1lBQ2pCLDJCQUEyQjtnSEFHbEIseUJBQXlCLFlBcEJsQyxZQUFZO1lBQ1osV0FBVztZQUNYLG1CQUFtQjtZQUVuQix1QkFBdUI7WUFDdkIsa0JBQWtCO1lBQ2xCLGNBQWM7WUFDZCxlQUFlO1lBRWYscUJBQXFCO1lBQ3JCLGVBQWU7OzRGQVVOLHlCQUF5QjtrQkE5QnJDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLGNBQWM7d0JBQ2Qsb0JBQW9CO3dCQUNwQixxQkFBcUI7d0JBRXJCLGlCQUFpQjt3QkFDakIsMkJBQTJCO3FCQUM1QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3dCQUNYLG1CQUFtQjt3QkFFbkIsdUJBQXVCO3dCQUN2QixrQkFBa0I7d0JBQ2xCLGNBQWM7d0JBQ2QsZUFBZTt3QkFFZixxQkFBcUI7d0JBQ3JCLGVBQWU7cUJBQ2hCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxjQUFjO3dCQUNkLG9CQUFvQjt3QkFFcEIsaUJBQWlCO3dCQUNqQiwyQkFBMkI7cUJBQzVCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuLyoqIEFuZ3VsYXIgTWF0ZXJpYWwgKi9cbmltcG9ydCB7IE1hdElucHV0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaW5wdXQnO1xuaW1wb3J0IHsgTWF0Rm9ybUZpZWxkTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZm9ybS1maWVsZCc7XG5pbXBvcnQgeyBNYXRTZWxlY3RNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9zZWxlY3QnO1xuXG4vKiogVG90cyBMaWJyYXJpZXMgKi9cbmltcG9ydCB7IFRvdHNUYWJsZU1vZHVsZSB9IGZyb20gJ0B0b3RzL3RhYmxlJztcblxuLyoqIENvbHVtbnMgKi9cbmltcG9ydCB7IElucHV0Q29sdW1uQ29tcG9uZW50IH0gZnJvbSAnLi9jb2x1bW5zL2lucHV0LWNvbHVtbi9pbnB1dC1jb2x1bW4uY29tcG9uZW50JztcbmltcG9ydCB7IFNlbGVjdENvbHVtbkNvbXBvbmVudCB9IGZyb20gJy4vY29sdW1ucy9zZWxlY3QtY29sdW1uL3NlbGVjdC1jb2x1bW4uY29tcG9uZW50JztcblxuLyoqIENvbXBvbmVudHMgKi9cbmltcG9ydCB7IFRvdHNUYWJsZUZ1bGxHcm91cENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy90b3RzLXRhYmxlLWZ1bGwtZ3JvdXAvdG90cy10YWJsZS1mdWxsLWdyb3VwLmNvbXBvbmVudCc7XG5cblxuXG5cblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgLyoqIENvbHVtbnMgKi9cbiAgICBJbnB1dENvbHVtbkNvbXBvbmVudCxcbiAgICBTZWxlY3RDb2x1bW5Db21wb25lbnQsXG5cbiAgICAvKiogQ29tcG9uZW50cyAqL1xuICAgIFRvdHNUYWJsZUZ1bGxHcm91cENvbXBvbmVudFxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEZvcm1zTW9kdWxlLFxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG5cbiAgICAvKiogQW5ndWxhciBNYXRlcmlhbCAqL1xuICAgIE1hdEZvcm1GaWVsZE1vZHVsZSxcbiAgICBNYXRJbnB1dE1vZHVsZSxcbiAgICBNYXRTZWxlY3RNb2R1bGUsXG5cbiAgICAvKiogVG90cyBMaWJyYXJpZXMgKi9cbiAgICBUb3RzVGFibGVNb2R1bGVcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIC8qKiBDb2x1bW5zICovXG4gICAgSW5wdXRDb2x1bW5Db21wb25lbnQsXG5cbiAgICAvKiogQ29tcG9uZW50cyAqL1xuICAgIFRvdHNUYWJsZUZ1bGxHcm91cENvbXBvbmVudFxuICBdXG59KVxuZXhwb3J0IGNsYXNzIFRvdHNFZGl0YWJsZUNvbHVtbnNNb2R1bGUgeyB9XG4iXX0=
|
package/esm2022/public-api.mjs
CHANGED
|
@@ -9,6 +9,7 @@ export * from './lib/entities/tots-validator';
|
|
|
9
9
|
* Columns
|
|
10
10
|
*/
|
|
11
11
|
export * from './lib/columns/input-column/input-column.component';
|
|
12
|
+
export * from './lib/columns/select-column/select-column.component';
|
|
12
13
|
/**
|
|
13
14
|
* Components
|
|
14
15
|
*/
|
|
@@ -17,8 +18,9 @@ export * from './lib/components/tots-table-full-group/tots-table-full-group.comp
|
|
|
17
18
|
* Factories
|
|
18
19
|
*/
|
|
19
20
|
export * from './lib/column-factories/tots-input-column';
|
|
21
|
+
export * from './lib/column-factories/tots-select-column';
|
|
20
22
|
/**
|
|
21
23
|
* Modules
|
|
22
24
|
*/
|
|
23
25
|
export * from './lib/editable-columns.module';
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3RvdHMvZWRpdGFibGUtY29sdW1ucy9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVIOztHQUVHO0FBQ0gsY0FBYywrQkFBK0IsQ0FBQztBQUU5Qzs7R0FFRztBQUNILGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyxxREFBcUQsQ0FBQztBQUVwRTs7R0FFRztBQUNILGNBQWMsd0VBQXdFLENBQUM7QUFFdkY7O0dBRUc7QUFDSCxjQUFjLDBDQUEwQyxDQUFDO0FBQ3pELGNBQWMsMkNBQTJDLENBQUM7QUFFMUQ7O0dBRUc7QUFDSCxjQUFjLCtCQUErQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBlZGl0YWJsZS1jb2x1bW5zXG4gKi9cblxuLyoqXG4gKiBFbnRpdGllc1xuICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbnRpdGllcy90b3RzLXZhbGlkYXRvcic7XG5cbi8qKlxuICogQ29sdW1uc1xuICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb2x1bW5zL2lucHV0LWNvbHVtbi9pbnB1dC1jb2x1bW4uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbHVtbnMvc2VsZWN0LWNvbHVtbi9zZWxlY3QtY29sdW1uLmNvbXBvbmVudCc7XG5cbi8qKlxuICogQ29tcG9uZW50c1xuICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL3RvdHMtdGFibGUtZnVsbC1ncm91cC90b3RzLXRhYmxlLWZ1bGwtZ3JvdXAuY29tcG9uZW50JztcblxuLyoqXG4gKiBGYWN0b3JpZXNcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29sdW1uLWZhY3Rvcmllcy90b3RzLWlucHV0LWNvbHVtbic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb2x1bW4tZmFjdG9yaWVzL3RvdHMtc2VsZWN0LWNvbHVtbic7XG5cbi8qKlxuICogTW9kdWxlc1xuICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi9lZGl0YWJsZS1jb2x1bW5zLm1vZHVsZSc7XG4iXX0=
|
|
@@ -10,6 +10,9 @@ import * as i3 from '@angular/material/form-field';
|
|
|
10
10
|
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
11
11
|
import * as i4 from '@angular/material/input';
|
|
12
12
|
import { MatInputModule } from '@angular/material/input';
|
|
13
|
+
import * as i4$1 from '@angular/material/select';
|
|
14
|
+
import { MatSelectModule } from '@angular/material/select';
|
|
15
|
+
import * as i5 from '@angular/material/core';
|
|
13
16
|
|
|
14
17
|
class TotsValidator {
|
|
15
18
|
constructor(validator, name, message) {
|
|
@@ -29,12 +32,11 @@ class InputColumnComponent extends TotsBaseColumnComponent {
|
|
|
29
32
|
this.loadChanges();
|
|
30
33
|
}
|
|
31
34
|
ngOnDestroy() {
|
|
32
|
-
this.onAction.next({ key: 'input-destroy', item: this.index });
|
|
35
|
+
this.onAction.next({ key: 'input-destroy', item: { field_key: this.getFormKey(), index: this.index } });
|
|
33
36
|
}
|
|
34
37
|
loadChanges() {
|
|
35
|
-
this.input.valueChanges
|
|
36
|
-
.
|
|
37
|
-
this.onAction.next({ key: 'input-change', item: { field_key: this.getFormKey(), item: this.item, value: res, valid: this.input.valid, index: this.index } });
|
|
38
|
+
this.input.valueChanges.subscribe(value => {
|
|
39
|
+
this.onAction.next({ key: 'input-change', item: { field_key: this.getFormKey(), item: this.item, value: value, valid: this.input.valid, index: this.index } });
|
|
38
40
|
});
|
|
39
41
|
}
|
|
40
42
|
loadForm() {
|
|
@@ -121,6 +123,112 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImpo
|
|
|
121
123
|
args: [{ selector: 'tots-input-column', template: "<mat-form-field class=\"{{getClass()}}\" [appearance]=\"getAppearance()\" (click)=\"$event.stopPropagation()\">\n <mat-label *ngIf=\"getLabel()\"> {{ getLabel() }} </mat-label>\n <input matInput type=\"text\" [formControl]=\"input\" [placeholder]=\"getPlaceholder()\"/>\n <mat-hint *ngIf=\"getCaption()\" [align]=\"'end'\"> {{getCaption()}} </mat-hint>\n <mat-error *ngIf=\"hasError()\">{{getErrorMessage()}}</mat-error>\n</mat-form-field>\n", styles: ["mat-form-field{margin-bottom:0}\n"] }]
|
|
122
124
|
}], ctorParameters: function () { return []; } });
|
|
123
125
|
|
|
126
|
+
class SelectColumnComponent extends TotsBaseColumnComponent {
|
|
127
|
+
constructor() {
|
|
128
|
+
super();
|
|
129
|
+
}
|
|
130
|
+
ngOnInit() {
|
|
131
|
+
this.loadInput();
|
|
132
|
+
this.loadForm();
|
|
133
|
+
this.loadChanges();
|
|
134
|
+
this.options = this.column.extra.options || [];
|
|
135
|
+
}
|
|
136
|
+
loadChanges() {
|
|
137
|
+
this.input.valueChanges
|
|
138
|
+
.subscribe(res => {
|
|
139
|
+
this.onAction.next({ key: 'input-change', item: { field_key: this.getFormKey(), item: this.item, value: res, valid: this.input.valid, index: this.index } });
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
loadForm() {
|
|
143
|
+
if (this.column.extra == undefined || this.column.extra.group == undefined) {
|
|
144
|
+
return;
|
|
145
|
+
}
|
|
146
|
+
let group = this.column.extra.group;
|
|
147
|
+
if (group.get(this.getFormKey()) != undefined) {
|
|
148
|
+
return;
|
|
149
|
+
}
|
|
150
|
+
group.addControl(this.getFormKey(), this.input);
|
|
151
|
+
}
|
|
152
|
+
loadInput() {
|
|
153
|
+
let value = TotsTableHelper.getItemValueByKey(this.item, this.column.field_key);
|
|
154
|
+
this.input = new FormControl(value, this.getValidators());
|
|
155
|
+
this.onAction.next({ key: 'input-create', item: { field_key: this.getFormKey(), input: this.input, index: this.index, column: this.column } });
|
|
156
|
+
}
|
|
157
|
+
getOptionValue(option) {
|
|
158
|
+
return TotsTableHelper.getItemValueByKey(option, this.column.extra.field_select_key);
|
|
159
|
+
}
|
|
160
|
+
displayOption(option) {
|
|
161
|
+
return TotsTableHelper.getItemValueByKey(option, this.column.extra.field_print_key);
|
|
162
|
+
}
|
|
163
|
+
getFormKey() {
|
|
164
|
+
if (Array.isArray(this.column.field_key)) {
|
|
165
|
+
return this.column.field_key.join('_');
|
|
166
|
+
}
|
|
167
|
+
else {
|
|
168
|
+
return this.column.field_key;
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
getValidators() {
|
|
172
|
+
if (this.column.extra && this.column.extra.validators) {
|
|
173
|
+
return this.column.extra.validators;
|
|
174
|
+
}
|
|
175
|
+
return null;
|
|
176
|
+
}
|
|
177
|
+
getErrorMessage() {
|
|
178
|
+
if (!this.column.extra.errors) {
|
|
179
|
+
return '';
|
|
180
|
+
}
|
|
181
|
+
for (const error of this.column.extra.errors) {
|
|
182
|
+
if (this.input.hasError(error.name)) {
|
|
183
|
+
return error.message;
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
return '';
|
|
187
|
+
}
|
|
188
|
+
getAppearance() {
|
|
189
|
+
if (this.column.extra && this.column.extra.appearance) {
|
|
190
|
+
return this.column.extra.appearance;
|
|
191
|
+
}
|
|
192
|
+
return 'fill';
|
|
193
|
+
}
|
|
194
|
+
getLabel() {
|
|
195
|
+
if (this.column.extra && this.column.extra.label) {
|
|
196
|
+
return this.column.extra.label;
|
|
197
|
+
}
|
|
198
|
+
return undefined;
|
|
199
|
+
}
|
|
200
|
+
getClasses() {
|
|
201
|
+
if (this.column.extra && this.column.extra.classes) {
|
|
202
|
+
return this.column.extra.classes;
|
|
203
|
+
}
|
|
204
|
+
return '';
|
|
205
|
+
}
|
|
206
|
+
getPlaceholder() {
|
|
207
|
+
if (this.column.extra && this.column.extra.placeholder) {
|
|
208
|
+
return this.column.extra.placeholder;
|
|
209
|
+
}
|
|
210
|
+
return '';
|
|
211
|
+
}
|
|
212
|
+
getCaption() {
|
|
213
|
+
if (this.column.extra && this.column.extra.caption) {
|
|
214
|
+
return this.column.extra.caption;
|
|
215
|
+
}
|
|
216
|
+
return '';
|
|
217
|
+
}
|
|
218
|
+
hasError() {
|
|
219
|
+
return this.input.invalid && (this.input.dirty || this.input.touched);
|
|
220
|
+
}
|
|
221
|
+
getInput() {
|
|
222
|
+
return this.input;
|
|
223
|
+
}
|
|
224
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: SelectColumnComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
225
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.11", type: SelectColumnComponent, selector: "tots-select-column", usesInheritance: true, ngImport: i0, template: "<mat-form-field class=\"{{getClasses()}}\" [appearance]=\"getAppearance()\" (click)=\"$event.stopPropagation()\">\n <mat-label *ngIf=\"getLabel()\"> {{ getLabel() }} </mat-label>\n <mat-select [formControl]=\"input\" [placeholder]=\"getPlaceholder()\">\n <mat-option *ngFor=\"let option of options; let index=index;\" [value]=\"getOptionValue(option)\">\n {{ displayOption(option) }}\n </mat-option>\n </mat-select>\n <mat-hint *ngIf=\"getCaption()\" [align]=\"'end'\"> {{getCaption()}} </mat-hint>\n <mat-error *ngIf=\"hasError()\">{{getErrorMessage()}}</mat-error>\n</mat-form-field>\n", styles: ["mat-form-field{margin-bottom:0}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "component", type: i4$1.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex", "panelWidth", "hideSingleSelectionIndicator"], exportAs: ["matSelect"] }, { kind: "component", type: i5.MatOption, selector: "mat-option", exportAs: ["matOption"] }] }); }
|
|
226
|
+
}
|
|
227
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: SelectColumnComponent, decorators: [{
|
|
228
|
+
type: Component,
|
|
229
|
+
args: [{ selector: 'tots-select-column', template: "<mat-form-field class=\"{{getClasses()}}\" [appearance]=\"getAppearance()\" (click)=\"$event.stopPropagation()\">\n <mat-label *ngIf=\"getLabel()\"> {{ getLabel() }} </mat-label>\n <mat-select [formControl]=\"input\" [placeholder]=\"getPlaceholder()\">\n <mat-option *ngFor=\"let option of options; let index=index;\" [value]=\"getOptionValue(option)\">\n {{ displayOption(option) }}\n </mat-option>\n </mat-select>\n <mat-hint *ngIf=\"getCaption()\" [align]=\"'end'\"> {{getCaption()}} </mat-hint>\n <mat-error *ngIf=\"hasError()\">{{getErrorMessage()}}</mat-error>\n</mat-form-field>\n", styles: ["mat-form-field{margin-bottom:0}\n"] }]
|
|
230
|
+
}], ctorParameters: function () { return []; } });
|
|
231
|
+
|
|
124
232
|
class TotsTableFullGroupComponent {
|
|
125
233
|
constructor() {
|
|
126
234
|
this.config = new TotsTableConfig();
|
|
@@ -138,21 +246,37 @@ class TotsTableFullGroupComponent {
|
|
|
138
246
|
else if (action.key == 'input-change') {
|
|
139
247
|
this.onAction.emit(action);
|
|
140
248
|
setTimeout(() => {
|
|
141
|
-
this.
|
|
249
|
+
this.emitFormChange();
|
|
142
250
|
});
|
|
143
251
|
}
|
|
144
252
|
else if (action.key == "input-destroy") {
|
|
145
|
-
this.removeInputFromGroup(action.item);
|
|
253
|
+
this.removeInputFromGroup(action.item.index, action.item.field_key);
|
|
146
254
|
}
|
|
147
255
|
this.onAction.emit(action);
|
|
148
256
|
}
|
|
149
257
|
addInputInGroup(input, index, column) {
|
|
150
|
-
let group =
|
|
151
|
-
group
|
|
152
|
-
|
|
258
|
+
let group = this.formArrayMain.at(index);
|
|
259
|
+
if (group) {
|
|
260
|
+
group.addControl(this.getFormKey(column), input);
|
|
261
|
+
this.formArrayMain.setControl(index, group);
|
|
262
|
+
}
|
|
263
|
+
else {
|
|
264
|
+
group = new FormGroup({});
|
|
265
|
+
group.addControl(this.getFormKey(column), input);
|
|
266
|
+
this.formArrayMain.push(group);
|
|
267
|
+
this.emitFormChange();
|
|
268
|
+
}
|
|
153
269
|
}
|
|
154
|
-
removeInputFromGroup(index) {
|
|
155
|
-
this.formArrayMain.
|
|
270
|
+
removeInputFromGroup(index, field_key) {
|
|
271
|
+
let formGroup = this.formArrayMain.at(index);
|
|
272
|
+
if (!formGroup)
|
|
273
|
+
return;
|
|
274
|
+
formGroup.removeControl(field_key);
|
|
275
|
+
let keys = Object.keys(formGroup.controls);
|
|
276
|
+
if (keys.length == 0) {
|
|
277
|
+
this.formArrayMain.removeAt(index);
|
|
278
|
+
this.emitFormChange();
|
|
279
|
+
}
|
|
156
280
|
}
|
|
157
281
|
getFormKey(column) {
|
|
158
282
|
if (Array.isArray(column.field_key)) {
|
|
@@ -165,6 +289,9 @@ class TotsTableFullGroupComponent {
|
|
|
165
289
|
loadItems() {
|
|
166
290
|
this.tableComp?.loadItems();
|
|
167
291
|
}
|
|
292
|
+
emitFormChange() {
|
|
293
|
+
this.onAction.emit({ key: 'form-change', item: { valid: this.formArrayMain.valid, values: this.formArrayMain.value } });
|
|
294
|
+
}
|
|
168
295
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: TotsTableFullGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
169
296
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.11", type: TotsTableFullGroupComponent, selector: "tots-table-full-group", inputs: { config: "config", pageIndex: "pageIndex", pageSize: "pageSize", hasPagination: "hasPagination", messageNotFound: "messageNotFound" }, outputs: { onAction: "onAction" }, viewQueries: [{ propertyName: "tableComp", first: true, predicate: ["tableComp"], descendants: true }], ngImport: i0, template: "<tots-table #tableComp [config]=\"config\" [pageIndex]=\"pageIndex\" [pageSize]=\"pageSize\" [hasPagination]=\"hasPagination\" [messageNotFound]=\"messageNotFound\" (onAction)=\"onTableAction($event)\"></tots-table>\n", styles: [""], dependencies: [{ kind: "component", type: i1$1.TotsTableComponent, selector: "tots-table", inputs: ["config", "pageIndex", "pageSize", "hasPagination", "messageNotFound"], outputs: ["onAction"] }] }); }
|
|
170
297
|
}
|
|
@@ -204,11 +331,31 @@ class TotsInputColumn extends TotsColumn {
|
|
|
204
331
|
}
|
|
205
332
|
}
|
|
206
333
|
|
|
334
|
+
class TotsSelectColumn extends TotsColumn {
|
|
335
|
+
constructor(id, fieldKey, options, validators, title, formGroup, label, placeholder, hint, cssClass, appearance) {
|
|
336
|
+
super(id, SelectColumnComponent, fieldKey, title);
|
|
337
|
+
this.extra = {
|
|
338
|
+
group: formGroup,
|
|
339
|
+
options: options,
|
|
340
|
+
field_select_key: "value",
|
|
341
|
+
field_print_key: "caption",
|
|
342
|
+
validators: validators?.map(v => v.validator),
|
|
343
|
+
errors: validators?.map(v => { return { name: v.name, message: v.message }; }),
|
|
344
|
+
label: label,
|
|
345
|
+
class: cssClass,
|
|
346
|
+
placeholder: placeholder,
|
|
347
|
+
caption: hint,
|
|
348
|
+
appearance: appearance
|
|
349
|
+
};
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
|
|
207
353
|
class TotsEditableColumnsModule {
|
|
208
354
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: TotsEditableColumnsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
209
355
|
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.11", ngImport: i0, type: TotsEditableColumnsModule, declarations: [
|
|
210
356
|
/** Columns */
|
|
211
357
|
InputColumnComponent,
|
|
358
|
+
SelectColumnComponent,
|
|
212
359
|
/** Components */
|
|
213
360
|
TotsTableFullGroupComponent], imports: [CommonModule,
|
|
214
361
|
FormsModule,
|
|
@@ -216,6 +363,7 @@ class TotsEditableColumnsModule {
|
|
|
216
363
|
/** Angular Material */
|
|
217
364
|
MatFormFieldModule,
|
|
218
365
|
MatInputModule,
|
|
366
|
+
MatSelectModule,
|
|
219
367
|
/** Tots Libraries */
|
|
220
368
|
TotsTableModule], exports: [
|
|
221
369
|
/** Columns */
|
|
@@ -228,6 +376,7 @@ class TotsEditableColumnsModule {
|
|
|
228
376
|
/** Angular Material */
|
|
229
377
|
MatFormFieldModule,
|
|
230
378
|
MatInputModule,
|
|
379
|
+
MatSelectModule,
|
|
231
380
|
/** Tots Libraries */
|
|
232
381
|
TotsTableModule] }); }
|
|
233
382
|
}
|
|
@@ -237,6 +386,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImpo
|
|
|
237
386
|
declarations: [
|
|
238
387
|
/** Columns */
|
|
239
388
|
InputColumnComponent,
|
|
389
|
+
SelectColumnComponent,
|
|
240
390
|
/** Components */
|
|
241
391
|
TotsTableFullGroupComponent
|
|
242
392
|
],
|
|
@@ -247,6 +397,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImpo
|
|
|
247
397
|
/** Angular Material */
|
|
248
398
|
MatFormFieldModule,
|
|
249
399
|
MatInputModule,
|
|
400
|
+
MatSelectModule,
|
|
250
401
|
/** Tots Libraries */
|
|
251
402
|
TotsTableModule
|
|
252
403
|
],
|
|
@@ -270,5 +421,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImpo
|
|
|
270
421
|
* Generated bundle index. Do not edit.
|
|
271
422
|
*/
|
|
272
423
|
|
|
273
|
-
export { InputColumnComponent, TotsEditableColumnsModule, TotsInputColumn, TotsTableFullGroupComponent, TotsValidator };
|
|
424
|
+
export { InputColumnComponent, SelectColumnComponent, TotsEditableColumnsModule, TotsInputColumn, TotsSelectColumn, TotsTableFullGroupComponent, TotsValidator };
|
|
274
425
|
//# sourceMappingURL=tots-editable-columns.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tots-editable-columns.mjs","sources":["../../../../projects/tots/editable-columns/src/lib/entities/tots-validator.ts","../../../../projects/tots/editable-columns/src/lib/columns/input-column/input-column.component.ts","../../../../projects/tots/editable-columns/src/lib/columns/input-column/input-column.component.html","../../../../projects/tots/editable-columns/src/lib/components/tots-table-full-group/tots-table-full-group.component.ts","../../../../projects/tots/editable-columns/src/lib/components/tots-table-full-group/tots-table-full-group.component.html","../../../../projects/tots/editable-columns/src/lib/column-factories/tots-input-column.ts","../../../../projects/tots/editable-columns/src/lib/editable-columns.module.ts","../../../../projects/tots/editable-columns/src/public-api.ts","../../../../projects/tots/editable-columns/src/tots-editable-columns.ts"],"sourcesContent":["import { ValidatorFn } from \"@angular/forms\"\n\nexport class TotsValidator {\n validator: ValidatorFn;\n name: string;\n message: string;\n \n constructor(validator:ValidatorFn, name:string, message:string) {\n this.validator = validator;\n this.name = name;\n this.message = message;\n }\n}","import { Component, OnDestroy } from '@angular/core';\nimport { FormControl, FormGroup, ValidatorFn } from '@angular/forms';\nimport { MatFormFieldAppearance } from '@angular/material/form-field';\nimport { TotsBaseColumnComponent, TotsTableHelper } from '@tots/table';\n\n@Component({\n selector: 'tots-input-column',\n templateUrl: './input-column.component.html',\n styleUrls: ['./input-column.component.css']\n})\nexport class InputColumnComponent extends TotsBaseColumnComponent implements OnDestroy {\n\n input!: FormControl;\n\n constructor() {\n super();\n }\n\n ngOnInit(): void {\n this.loadInput();\n this.loadForm();\n this.loadChanges();\n }\n ngOnDestroy(): void {\n this.onAction.next({ key: 'input-destroy', item: this.index });\n }\n\n loadChanges() {\n this.input.valueChanges\n .subscribe(res => {\n this.onAction.next({ key: 'input-change', item: { field_key: this.getFormKey(), item: this.item, value: res, valid: this.input.valid, index: this.index } });\n });\n }\n\n loadForm() {\n if(this.column.extra == undefined || this.column.extra.group == undefined){\n return;\n }\n\n let group: FormGroup = this.column.extra.group;\n if(group.get(this.getFormKey()) != undefined){\n return;\n }\n\n group.addControl(this.getFormKey(), this.input);\n }\n\n loadInput() {\n let value = TotsTableHelper.getItemValueByKey(this.item, this.column.field_key);\n this.input = new FormControl(value, this.getValidators());\n\n this.onAction.next({ key: 'input-create', item: { field_key: this.getFormKey(), input: this.input, index: this.index, column: this.column } });\n }\n\n getFormKey(): string {\n if(Array.isArray(this.column.field_key)){\n return this.column.field_key.join('_');\n } else {\n return this.column.field_key!;\n }\n }\n\n getValidators() : ValidatorFn[] | ValidatorFn | null {\n if (this.column.extra && this.column.extra.validators) {\n return this.column.extra.validators;\n }\n return null;\n }\n\n getErrorMessage() : string {\n if (!this.column.extra.errors) {\n return '';\n }\n\n for (const error of this.column.extra.errors) {\n if (this.input.hasError(error.name)) {\n return error.message;\n }\n }\n\n return '';\n }\n\n getAppearance() : MatFormFieldAppearance {\n if (this.column.extra && this.column.extra.appearance) {\n return this.column.extra.appearance;\n }\n return 'fill';\n }\n\n getLabel() : string | undefined {\n if (this.column.extra && this.column.extra.label) {\n return this.column.extra.label;\n }\n return undefined;\n }\n\n getClass() : string {\n if (this.column.extra && this.column.extra.class) {\n return this.column.extra.class;\n }\n return '';\n }\n\n getPlaceholder() : string {\n if (this.column.extra && this.column.extra.placeholder) {\n return this.column.extra.placeholder;\n }\n return '';\n }\n\n getCaption() : string {\n if (this.column.extra && this.column.extra.caption) {\n return this.column.extra.caption;\n }\n return '';\n }\n\n hasError() : boolean {\n return this.input.invalid && (this.input.dirty || this.input.touched);\n }\n\n getInput() {\n return this.input;\n }\n}\n","<mat-form-field class=\"{{getClass()}}\" [appearance]=\"getAppearance()\" (click)=\"$event.stopPropagation()\">\n <mat-label *ngIf=\"getLabel()\"> {{ getLabel() }} </mat-label>\n <input matInput type=\"text\" [formControl]=\"input\" [placeholder]=\"getPlaceholder()\"/>\n <mat-hint *ngIf=\"getCaption()\" [align]=\"'end'\"> {{getCaption()}} </mat-hint>\n <mat-error *ngIf=\"hasError()\">{{getErrorMessage()}}</mat-error>\n</mat-form-field>\n","import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';\nimport { FormArray, FormControl, FormGroup } from '@angular/forms';\nimport { TotsListResponse } from '@tots/core';\nimport { TotsActionTable, TotsColumn, TotsTableComponent, TotsTableConfig } from '@tots/table';\n\n@Component({\n selector: 'tots-table-full-group',\n templateUrl: './tots-table-full-group.component.html',\n styleUrls: ['./tots-table-full-group.component.css']\n})\nexport class TotsTableFullGroupComponent {\n\n @ViewChild('tableComp') protected tableComp!: TotsTableComponent;\n\n @Input() config = new TotsTableConfig();\n @Input() pageIndex: number = 0;\n @Input() pageSize: number = 50;\n @Input() hasPagination: boolean = true;\n @Input() messageNotFound: string = \"No results found, please try with other search terms\";\n\n @Output() onAction = new EventEmitter<TotsActionTable>();\n\n formArrayMain : FormArray<FormGroup> = new FormArray<FormGroup>([]);\n\n protected onTableAction(action: TotsActionTable) {\n if (action.key == 'input-create') {\n this.addInputInGroup(action.item.input, action.item.index, action.item.column);\n\n } else if (action.key == 'input-change') {\n this.onAction.emit(action);\n setTimeout(() => {\n this.onAction.emit({ key: 'form-change', item: { valid: this.formArrayMain.valid, values: this.formArrayMain.value } });\n });\n\n } else if (action.key == \"input-destroy\" ) {\n this.removeInputFromGroup(action.item);\n }\n\n this.onAction.emit(action);\n }\n\n private addInputInGroup(input: FormControl, index: number, column: TotsColumn) {\n let group = new FormGroup({});\n group.addControl(this.getFormKey(column), input);\n this.formArrayMain.push(group);\n }\n private removeInputFromGroup(index:number) {\n this.formArrayMain.removeAt(index);\n }\n\n private getFormKey(column: TotsColumn): string {\n if(Array.isArray(column.field_key)){\n return column.field_key.join('_');\n } else {\n return column.field_key!;\n }\n }\n\n loadItems() {\n this.tableComp?.loadItems();\n }\n}\n","<tots-table #tableComp [config]=\"config\" [pageIndex]=\"pageIndex\" [pageSize]=\"pageSize\" [hasPagination]=\"hasPagination\" [messageNotFound]=\"messageNotFound\" (onAction)=\"onTableAction($event)\"></tots-table>\n","import { TotsColumn } from \"@tots/table\";\r\nimport { InputColumnComponent } from \"../columns/input-column/input-column.component\";\r\nimport { FormGroup } from \"@angular/forms\";\r\nimport { MatFormFieldAppearance } from \"@angular/material/form-field\";\r\nimport { TotsValidator } from \"../entities/tots-validator\";\r\n\r\nexport class TotsInputColumn extends TotsColumn {\r\n\tconstructor(id:string, fieldKey:string|string[], validators?:TotsValidator[], title?:string, formGroup?:FormGroup, label?:string, placeholder?:string, hint?:string, cssClass?:string, appearance?:MatFormFieldAppearance) {\r\n super(id, InputColumnComponent, fieldKey, title);\r\n this.extra = {\r\n group: formGroup,\r\n validators: validators?.map(v=> v.validator),\r\n errors: validators?.map(v=> {return {name:v.name, message:v.message}}),\r\n label: label,\r\n class: cssClass,\r\n placeholder: placeholder,\r\n caption: hint,\r\n appearance: appearance\r\n }\r\n }\r\n}","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\n\n/** Angular Material */\nimport { MatInputModule } from '@angular/material/input';\nimport { MatFormFieldModule } from '@angular/material/form-field';\n\n/** Tots Libraries */\nimport { TotsTableModule } from '@tots/table';\n\n/** Columns */\nimport { InputColumnComponent } from './columns/input-column/input-column.component';\n\n/** Components */\nimport { TotsTableFullGroupComponent } from './components/tots-table-full-group/tots-table-full-group.component';\n\n\n\n\n\n\n\n@NgModule({\n declarations: [\n\n /** Columns */\n InputColumnComponent,\n\n /** Components */\n TotsTableFullGroupComponent\n ],\n imports: [\n CommonModule,\n FormsModule,\n ReactiveFormsModule,\n\n /** Angular Material */\n MatFormFieldModule,\n MatInputModule,\n\n /** Tots Libraries */\n TotsTableModule\n ],\n exports: [\n /** Columns */\n InputColumnComponent,\n\n /** Components */\n TotsTableFullGroupComponent\n ]\n})\nexport class TotsEditableColumnsModule { }\n","/*\n * Public API Surface of editable-columns\n */\n\n/**\n * Entities\n */\nexport * from './lib/entities/tots-validator';\n\n/**\n * Columns\n */\nexport * from './lib/columns/input-column/input-column.component';\n\n/**\n * Components\n */\nexport * from './lib/components/tots-table-full-group/tots-table-full-group.component';\n\n/**\n * Factories\n */\nexport * from './lib/column-factories/tots-input-column';\n\n/**\n * Modules\n */\nexport * from './lib/editable-columns.module';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["i1"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"tots-editable-columns.mjs","sources":["../../../../projects/tots/editable-columns/src/lib/entities/tots-validator.ts","../../../../projects/tots/editable-columns/src/lib/columns/input-column/input-column.component.ts","../../../../projects/tots/editable-columns/src/lib/columns/input-column/input-column.component.html","../../../../projects/tots/editable-columns/src/lib/columns/select-column/select-column.component.ts","../../../../projects/tots/editable-columns/src/lib/columns/select-column/select-column.component.html","../../../../projects/tots/editable-columns/src/lib/components/tots-table-full-group/tots-table-full-group.component.ts","../../../../projects/tots/editable-columns/src/lib/components/tots-table-full-group/tots-table-full-group.component.html","../../../../projects/tots/editable-columns/src/lib/column-factories/tots-input-column.ts","../../../../projects/tots/editable-columns/src/lib/column-factories/tots-select-column.ts","../../../../projects/tots/editable-columns/src/lib/editable-columns.module.ts","../../../../projects/tots/editable-columns/src/public-api.ts","../../../../projects/tots/editable-columns/src/tots-editable-columns.ts"],"sourcesContent":["import { ValidatorFn } from \"@angular/forms\"\n\nexport class TotsValidator {\n validator: ValidatorFn;\n name: string;\n message: string;\n \n constructor(validator:ValidatorFn, name:string, message:string) {\n this.validator = validator;\n this.name = name;\n this.message = message;\n }\n}","import { Component, OnDestroy } from '@angular/core';\nimport { FormControl, FormGroup, ValidatorFn } from '@angular/forms';\nimport { MatFormFieldAppearance } from '@angular/material/form-field';\nimport { TotsBaseColumnComponent, TotsTableHelper } from '@tots/table';\n\n@Component({\n selector: 'tots-input-column',\n templateUrl: './input-column.component.html',\n styleUrls: ['./input-column.component.css']\n})\nexport class InputColumnComponent extends TotsBaseColumnComponent implements OnDestroy {\n\n input!: FormControl;\n\n constructor() {\n super();\n }\n\n ngOnInit(): void {\n this.loadInput();\n this.loadForm();\n this.loadChanges();\n }\n ngOnDestroy(): void {\n this.onAction.next({ key: 'input-destroy', item: { field_key: this.getFormKey(), index: this.index } });\n }\n\n loadChanges() {\n this.input.valueChanges.subscribe(value => {\n this.onAction.next({ key: 'input-change', item: { field_key: this.getFormKey(), item: this.item, value: value, valid: this.input.valid, index: this.index } });\n });\n }\n\n loadForm() {\n if(this.column.extra == undefined || this.column.extra.group == undefined){\n return;\n }\n\n let group: FormGroup = this.column.extra.group;\n if(group.get(this.getFormKey()) != undefined){\n return;\n }\n\n group.addControl(this.getFormKey(), this.input);\n }\n\n loadInput() {\n let value = TotsTableHelper.getItemValueByKey(this.item, this.column.field_key);\n this.input = new FormControl(value, this.getValidators());\n\n this.onAction.next({ key: 'input-create', item: { field_key: this.getFormKey(), input: this.input, index: this.index, column: this.column } });\n }\n\n getFormKey(): string {\n if(Array.isArray(this.column.field_key)){\n return this.column.field_key.join('_');\n } else {\n return this.column.field_key!;\n }\n }\n\n getValidators() : ValidatorFn[] | ValidatorFn | null {\n if (this.column.extra && this.column.extra.validators) {\n return this.column.extra.validators;\n }\n return null;\n }\n\n getErrorMessage() : string {\n if (!this.column.extra.errors) {\n return '';\n }\n\n for (const error of this.column.extra.errors) {\n if (this.input.hasError(error.name)) {\n return error.message;\n }\n }\n\n return '';\n }\n\n getAppearance() : MatFormFieldAppearance {\n if (this.column.extra && this.column.extra.appearance) {\n return this.column.extra.appearance;\n }\n return 'fill';\n }\n\n getLabel() : string | undefined {\n if (this.column.extra && this.column.extra.label) {\n return this.column.extra.label;\n }\n return undefined;\n }\n\n getClass() : string {\n if (this.column.extra && this.column.extra.class) {\n return this.column.extra.class;\n }\n return '';\n }\n\n getPlaceholder() : string {\n if (this.column.extra && this.column.extra.placeholder) {\n return this.column.extra.placeholder;\n }\n return '';\n }\n\n getCaption() : string {\n if (this.column.extra && this.column.extra.caption) {\n return this.column.extra.caption;\n }\n return '';\n }\n\n hasError() : boolean {\n return this.input.invalid && (this.input.dirty || this.input.touched);\n }\n\n getInput() {\n return this.input;\n }\n}\n","<mat-form-field class=\"{{getClass()}}\" [appearance]=\"getAppearance()\" (click)=\"$event.stopPropagation()\">\n <mat-label *ngIf=\"getLabel()\"> {{ getLabel() }} </mat-label>\n <input matInput type=\"text\" [formControl]=\"input\" [placeholder]=\"getPlaceholder()\"/>\n <mat-hint *ngIf=\"getCaption()\" [align]=\"'end'\"> {{getCaption()}} </mat-hint>\n <mat-error *ngIf=\"hasError()\">{{getErrorMessage()}}</mat-error>\n</mat-form-field>\n","import { Component } from '@angular/core';\nimport { FormControl, FormGroup, ValidatorFn } from '@angular/forms';\nimport { MatFormFieldAppearance } from '@angular/material/form-field';\nimport { TotsBaseColumnComponent, TotsTableHelper } from '@tots/table';\n\n@Component({\n selector: 'tots-select-column',\n templateUrl: './select-column.component.html',\n styleUrls: ['./select-column.component.css']\n})\nexport class SelectColumnComponent extends TotsBaseColumnComponent {\n\n input!: FormControl;\n protected options! : any[];\n\n constructor() {\n super();\n }\n\n ngOnInit(): void {\n this.loadInput();\n this.loadForm();\n this.loadChanges();\n this.options = this.column.extra.options || [];\n }\n\n loadChanges() {\n this.input.valueChanges\n .subscribe(res => {\n this.onAction.next({ key: 'input-change', item: { field_key: this.getFormKey(), item: this.item, value: res, valid: this.input.valid, index: this.index } });\n });\n }\n\n loadForm() {\n if(this.column.extra == undefined || this.column.extra.group == undefined){\n return;\n }\n\n let group: FormGroup = this.column.extra.group;\n if(group.get(this.getFormKey()) != undefined){\n return;\n }\n\n group.addControl(this.getFormKey(), this.input);\n }\n\n loadInput() {\n let value = TotsTableHelper.getItemValueByKey(this.item, this.column.field_key);\n this.input = new FormControl(value, this.getValidators());\n\n this.onAction.next({ key: 'input-create', item: { field_key: this.getFormKey(), input: this.input, index: this.index, column: this.column } });\n }\n\n protected getOptionValue(option:any) {\n return TotsTableHelper.getItemValueByKey(option, this.column.extra.field_select_key);\n }\n protected displayOption(option:any) {\n return TotsTableHelper.getItemValueByKey(option, this.column.extra.field_print_key);\n }\n\n getFormKey(): string {\n if(Array.isArray(this.column.field_key)){\n return this.column.field_key.join('_');\n } else {\n return this.column.field_key!;\n }\n }\n\n getValidators() : ValidatorFn[] | ValidatorFn | null {\n if (this.column.extra && this.column.extra.validators) {\n return this.column.extra.validators;\n }\n return null;\n }\n\n getErrorMessage() : string {\n if (!this.column.extra.errors) {\n return '';\n }\n\n for (const error of this.column.extra.errors) {\n if (this.input.hasError(error.name)) {\n return error.message;\n }\n }\n\n return '';\n }\n\n getAppearance() : MatFormFieldAppearance {\n if (this.column.extra && this.column.extra.appearance) {\n return this.column.extra.appearance;\n }\n return 'fill';\n }\n\n getLabel() : string | undefined {\n if (this.column.extra && this.column.extra.label) {\n return this.column.extra.label;\n }\n return undefined;\n }\n\n getClasses() : string {\n if (this.column.extra && this.column.extra.classes) {\n return this.column.extra.classes;\n }\n return '';\n }\n\n getPlaceholder() : string {\n if (this.column.extra && this.column.extra.placeholder) {\n return this.column.extra.placeholder;\n }\n return '';\n }\n\n getCaption() : string {\n if (this.column.extra && this.column.extra.caption) {\n return this.column.extra.caption;\n }\n return '';\n }\n\n hasError() : boolean {\n return this.input.invalid && (this.input.dirty || this.input.touched);\n }\n\n getInput() {\n return this.input;\n }\n}\n","<mat-form-field class=\"{{getClasses()}}\" [appearance]=\"getAppearance()\" (click)=\"$event.stopPropagation()\">\n <mat-label *ngIf=\"getLabel()\"> {{ getLabel() }} </mat-label>\n <mat-select [formControl]=\"input\" [placeholder]=\"getPlaceholder()\">\n <mat-option *ngFor=\"let option of options; let index=index;\" [value]=\"getOptionValue(option)\">\n {{ displayOption(option) }}\n </mat-option>\n </mat-select>\n <mat-hint *ngIf=\"getCaption()\" [align]=\"'end'\"> {{getCaption()}} </mat-hint>\n <mat-error *ngIf=\"hasError()\">{{getErrorMessage()}}</mat-error>\n</mat-form-field>\n","import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';\nimport { FormArray, FormControl, FormGroup } from '@angular/forms';\nimport { TotsListResponse } from '@tots/core';\nimport { TotsActionTable, TotsColumn, TotsTableComponent, TotsTableConfig } from '@tots/table';\n\n@Component({\n selector: 'tots-table-full-group',\n templateUrl: './tots-table-full-group.component.html',\n styleUrls: ['./tots-table-full-group.component.css']\n})\nexport class TotsTableFullGroupComponent {\n\n @ViewChild('tableComp') protected tableComp!: TotsTableComponent;\n\n @Input() config = new TotsTableConfig();\n @Input() pageIndex: number = 0;\n @Input() pageSize: number = 50;\n @Input() hasPagination: boolean = true;\n @Input() messageNotFound: string = \"No results found, please try with other search terms\";\n\n @Output() onAction = new EventEmitter<TotsActionTable>();\n\n formArrayMain : FormArray<FormGroup> = new FormArray<FormGroup>([]);\n\n protected onTableAction(action: TotsActionTable) {\n if (action.key == 'input-create') {\n this.addInputInGroup(action.item.input, action.item.index, action.item.column);\n\n } else if (action.key == 'input-change') {\n this.onAction.emit(action);\n setTimeout(() => {\n this.emitFormChange();\n });\n\n } else if (action.key == \"input-destroy\" ) {\n this.removeInputFromGroup(action.item.index, action.item.field_key);\n }\n\n this.onAction.emit(action);\n }\n\n private addInputInGroup(input: FormControl, index: number, column: TotsColumn) {\n let group = this.formArrayMain.at(index);\n \n if (group) {\n group.addControl(this.getFormKey(column), input);\n this.formArrayMain.setControl(index, group);\n\n } else {\n group = new FormGroup({});\n group.addControl(this.getFormKey(column), input);\n this.formArrayMain.push(group);\n this.emitFormChange();\n }\n \n }\n private removeInputFromGroup(index: number, field_key: string) {\n let formGroup = this.formArrayMain.at(index);\n if (!formGroup)\n return\n\n formGroup.removeControl(field_key);\n\n let keys = Object.keys(formGroup.controls);\n\n if (keys.length == 0) {\n this.formArrayMain.removeAt(index);\n this.emitFormChange();\n }\n }\n\n private getFormKey(column: TotsColumn): string {\n if(Array.isArray(column.field_key)){\n return column.field_key.join('_');\n } else {\n return column.field_key!;\n }\n }\n\n loadItems() {\n this.tableComp?.loadItems();\n }\n\n private emitFormChange() {\n this.onAction.emit({ key: 'form-change', item: { valid: this.formArrayMain.valid, values: this.formArrayMain.value } });\n }\n}\n","<tots-table #tableComp [config]=\"config\" [pageIndex]=\"pageIndex\" [pageSize]=\"pageSize\" [hasPagination]=\"hasPagination\" [messageNotFound]=\"messageNotFound\" (onAction)=\"onTableAction($event)\"></tots-table>\n","import { TotsColumn } from \"@tots/table\";\r\nimport { InputColumnComponent } from \"../columns/input-column/input-column.component\";\r\nimport { FormGroup } from \"@angular/forms\";\r\nimport { MatFormFieldAppearance } from \"@angular/material/form-field\";\r\nimport { TotsValidator } from \"../entities/tots-validator\";\r\n\r\nexport class TotsInputColumn extends TotsColumn {\r\n\tconstructor(id:string, fieldKey:string|string[], validators?:TotsValidator[], title?:string, formGroup?:FormGroup, label?:string, placeholder?:string, hint?:string, cssClass?:string, appearance?:MatFormFieldAppearance) {\r\n super(id, InputColumnComponent, fieldKey, title);\r\n this.extra = {\r\n group: formGroup,\r\n validators: validators?.map(v=> v.validator),\r\n errors: validators?.map(v=> {return {name:v.name, message:v.message}}),\r\n label: label,\r\n class: cssClass,\r\n placeholder: placeholder,\r\n caption: hint,\r\n appearance: appearance\r\n }\r\n }\r\n}","import { TotsColumn, TotsColumnOption } from \"@tots/table\";\r\nimport { SelectColumnComponent } from \"../columns/select-column/select-column.component\";\r\nimport { FormGroup } from \"@angular/forms\";\r\nimport { MatFormFieldAppearance } from \"@angular/material/form-field\";\r\nimport { TotsValidator } from \"../entities/tots-validator\";\r\n\r\nexport class TotsSelectColumn extends TotsColumn {\r\n\tconstructor(id:string, fieldKey:string|string[], options:TotsColumnOption[], validators?:TotsValidator[], title?:string, formGroup?:FormGroup, label?:string, placeholder?:string, hint?:string, cssClass?:string, appearance?:MatFormFieldAppearance) {\r\n super(id, SelectColumnComponent, fieldKey, title);\r\n this.extra = {\r\n group: formGroup,\r\n options: options,\r\n field_select_key: \"value\",\r\n field_print_key: \"caption\",\r\n validators: validators?.map(v=> v.validator),\r\n errors: validators?.map(v=> {return {name:v.name, message:v.message}}),\r\n label: label,\r\n class: cssClass,\r\n placeholder: placeholder,\r\n caption: hint,\r\n appearance: appearance\r\n }\r\n }\r\n}","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\n\n/** Angular Material */\nimport { MatInputModule } from '@angular/material/input';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatSelectModule } from '@angular/material/select';\n\n/** Tots Libraries */\nimport { TotsTableModule } from '@tots/table';\n\n/** Columns */\nimport { InputColumnComponent } from './columns/input-column/input-column.component';\nimport { SelectColumnComponent } from './columns/select-column/select-column.component';\n\n/** Components */\nimport { TotsTableFullGroupComponent } from './components/tots-table-full-group/tots-table-full-group.component';\n\n\n\n\n\n@NgModule({\n declarations: [\n /** Columns */\n InputColumnComponent,\n SelectColumnComponent,\n\n /** Components */\n TotsTableFullGroupComponent\n ],\n imports: [\n CommonModule,\n FormsModule,\n ReactiveFormsModule,\n\n /** Angular Material */\n MatFormFieldModule,\n MatInputModule,\n MatSelectModule,\n\n /** Tots Libraries */\n TotsTableModule\n ],\n exports: [\n /** Columns */\n InputColumnComponent,\n\n /** Components */\n TotsTableFullGroupComponent\n ]\n})\nexport class TotsEditableColumnsModule { }\n","/*\n * Public API Surface of editable-columns\n */\n\n/**\n * Entities\n */\nexport * from './lib/entities/tots-validator';\n\n/**\n * Columns\n */\nexport * from './lib/columns/input-column/input-column.component';\nexport * from './lib/columns/select-column/select-column.component';\n\n/**\n * Components\n */\nexport * from './lib/components/tots-table-full-group/tots-table-full-group.component';\n\n/**\n * Factories\n */\nexport * from './lib/column-factories/tots-input-column';\nexport * from './lib/column-factories/tots-select-column';\n\n/**\n * Modules\n */\nexport * from './lib/editable-columns.module';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["i4","i1"],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { TotsColumn, TotsColumnOption } from "@tots/table";
|
|
2
|
+
import { FormGroup } from "@angular/forms";
|
|
3
|
+
import { MatFormFieldAppearance } from "@angular/material/form-field";
|
|
4
|
+
import { TotsValidator } from "../entities/tots-validator";
|
|
5
|
+
export declare class TotsSelectColumn extends TotsColumn {
|
|
6
|
+
constructor(id: string, fieldKey: string | string[], options: TotsColumnOption[], validators?: TotsValidator[], title?: string, formGroup?: FormGroup, label?: string, placeholder?: string, hint?: string, cssClass?: string, appearance?: MatFormFieldAppearance);
|
|
7
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { FormControl, ValidatorFn } from '@angular/forms';
|
|
2
|
+
import { MatFormFieldAppearance } from '@angular/material/form-field';
|
|
3
|
+
import { TotsBaseColumnComponent } from '@tots/table';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export declare class SelectColumnComponent extends TotsBaseColumnComponent {
|
|
6
|
+
input: FormControl;
|
|
7
|
+
protected options: any[];
|
|
8
|
+
constructor();
|
|
9
|
+
ngOnInit(): void;
|
|
10
|
+
loadChanges(): void;
|
|
11
|
+
loadForm(): void;
|
|
12
|
+
loadInput(): void;
|
|
13
|
+
protected getOptionValue(option: any): any;
|
|
14
|
+
protected displayOption(option: any): any;
|
|
15
|
+
getFormKey(): string;
|
|
16
|
+
getValidators(): ValidatorFn[] | ValidatorFn | null;
|
|
17
|
+
getErrorMessage(): string;
|
|
18
|
+
getAppearance(): MatFormFieldAppearance;
|
|
19
|
+
getLabel(): string | undefined;
|
|
20
|
+
getClasses(): string;
|
|
21
|
+
getPlaceholder(): string;
|
|
22
|
+
getCaption(): string;
|
|
23
|
+
hasError(): boolean;
|
|
24
|
+
getInput(): FormControl<any>;
|
|
25
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<SelectColumnComponent, never>;
|
|
26
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<SelectColumnComponent, "tots-select-column", never, {}, {}, never, never, false, never>;
|
|
27
|
+
}
|
|
@@ -16,6 +16,7 @@ export declare class TotsTableFullGroupComponent {
|
|
|
16
16
|
private removeInputFromGroup;
|
|
17
17
|
private getFormKey;
|
|
18
18
|
loadItems(): void;
|
|
19
|
+
private emitFormChange;
|
|
19
20
|
static ɵfac: i0.ɵɵFactoryDeclaration<TotsTableFullGroupComponent, never>;
|
|
20
21
|
static ɵcmp: i0.ɵɵComponentDeclaration<TotsTableFullGroupComponent, "tots-table-full-group", never, { "config": { "alias": "config"; "required": false; }; "pageIndex": { "alias": "pageIndex"; "required": false; }; "pageSize": { "alias": "pageSize"; "required": false; }; "hasPagination": { "alias": "hasPagination"; "required": false; }; "messageNotFound": { "alias": "messageNotFound"; "required": false; }; }, { "onAction": "onAction"; }, never, never, false, never>;
|
|
21
22
|
}
|
|
@@ -1,13 +1,15 @@
|
|
|
1
1
|
import * as i0 from "@angular/core";
|
|
2
2
|
import * as i1 from "./columns/input-column/input-column.component";
|
|
3
|
-
import * as i2 from "./
|
|
4
|
-
import * as i3 from "
|
|
5
|
-
import * as i4 from "@angular/
|
|
6
|
-
import * as i5 from "@angular/
|
|
7
|
-
import * as i6 from "@angular/material/
|
|
8
|
-
import * as i7 from "@
|
|
3
|
+
import * as i2 from "./columns/select-column/select-column.component";
|
|
4
|
+
import * as i3 from "./components/tots-table-full-group/tots-table-full-group.component";
|
|
5
|
+
import * as i4 from "@angular/common";
|
|
6
|
+
import * as i5 from "@angular/forms";
|
|
7
|
+
import * as i6 from "@angular/material/form-field";
|
|
8
|
+
import * as i7 from "@angular/material/input";
|
|
9
|
+
import * as i8 from "@angular/material/select";
|
|
10
|
+
import * as i9 from "@tots/table";
|
|
9
11
|
export declare class TotsEditableColumnsModule {
|
|
10
12
|
static ɵfac: i0.ɵɵFactoryDeclaration<TotsEditableColumnsModule, never>;
|
|
11
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<TotsEditableColumnsModule, [typeof i1.InputColumnComponent, typeof i2.TotsTableFullGroupComponent], [typeof
|
|
13
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<TotsEditableColumnsModule, [typeof i1.InputColumnComponent, typeof i2.SelectColumnComponent, typeof i3.TotsTableFullGroupComponent], [typeof i4.CommonModule, typeof i5.FormsModule, typeof i5.ReactiveFormsModule, typeof i6.MatFormFieldModule, typeof i7.MatInputModule, typeof i8.MatSelectModule, typeof i9.TotsTableModule], [typeof i1.InputColumnComponent, typeof i3.TotsTableFullGroupComponent]>;
|
|
12
14
|
static ɵinj: i0.ɵɵInjectorDeclaration<TotsEditableColumnsModule>;
|
|
13
15
|
}
|
package/package.json
CHANGED
package/public-api.d.ts
CHANGED
|
@@ -6,6 +6,7 @@ export * from './lib/entities/tots-validator';
|
|
|
6
6
|
* Columns
|
|
7
7
|
*/
|
|
8
8
|
export * from './lib/columns/input-column/input-column.component';
|
|
9
|
+
export * from './lib/columns/select-column/select-column.component';
|
|
9
10
|
/**
|
|
10
11
|
* Components
|
|
11
12
|
*/
|
|
@@ -14,6 +15,7 @@ export * from './lib/components/tots-table-full-group/tots-table-full-group.comp
|
|
|
14
15
|
* Factories
|
|
15
16
|
*/
|
|
16
17
|
export * from './lib/column-factories/tots-input-column';
|
|
18
|
+
export * from './lib/column-factories/tots-select-column';
|
|
17
19
|
/**
|
|
18
20
|
* Modules
|
|
19
21
|
*/
|