@tots/editable-columns 15.0.1 → 16.0.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/column-factories/tots-input-column.mjs +18 -0
- package/esm2022/lib/columns/input-column/input-column.component.mjs +107 -0
- package/{esm2020 → esm2022}/lib/components/tots-table-full-group/tots-table-full-group.component.mjs +4 -4
- package/esm2022/lib/editable-columns.module.mjs +68 -0
- package/esm2022/lib/entities/tots-validator.mjs +8 -0
- package/esm2022/public-api.mjs +24 -0
- package/{fesm2020 → fesm2022}/tots-editable-columns.mjs +68 -41
- package/fesm2022/tots-editable-columns.mjs.map +1 -0
- package/lib/column-factories/tots-input-column.d.ts +7 -0
- package/lib/columns/input-column/input-column.component.d.ts +4 -4
- package/lib/components/tots-table-full-group/tots-table-full-group.component.d.ts +1 -1
- package/lib/editable-columns.module.d.ts +1 -1
- package/lib/entities/tots-validator.d.ts +7 -0
- package/package.json +9 -15
- package/public-api.d.ts +8 -0
- package/esm2020/lib/columns/input-column/input-column.component.mjs +0 -107
- package/esm2020/lib/editable-columns.module.mjs +0 -68
- package/esm2020/public-api.mjs +0 -16
- package/fesm2015/tots-editable-columns.mjs +0 -260
- package/fesm2015/tots-editable-columns.mjs.map +0 -1
- package/fesm2020/tots-editable-columns.mjs.map +0 -1
- /package/{esm2020 → esm2022}/tots-editable-columns.mjs +0 -0
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { TotsColumn } from "@tots/table";
|
|
2
|
+
import { InputColumnComponent } from "../columns/input-column/input-column.component";
|
|
3
|
+
export class TotsInputColumn extends TotsColumn {
|
|
4
|
+
constructor(id, fieldKey, validators, title, formGroup, label, placeholder, hint, cssClass, appearance) {
|
|
5
|
+
super(id, InputColumnComponent, fieldKey, title);
|
|
6
|
+
this.extra = {
|
|
7
|
+
group: formGroup,
|
|
8
|
+
validators: validators?.map(v => v.validator),
|
|
9
|
+
errors: validators?.map(v => { return { name: v.name, message: v.message }; }),
|
|
10
|
+
label: label,
|
|
11
|
+
class: cssClass,
|
|
12
|
+
placeholder: placeholder,
|
|
13
|
+
caption: hint,
|
|
14
|
+
appearance: appearance
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG90cy1pbnB1dC1jb2x1bW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90b3RzL2VkaXRhYmxlLWNvbHVtbnMvc3JjL2xpYi9jb2x1bW4tZmFjdG9yaWVzL3RvdHMtaW5wdXQtY29sdW1uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDekMsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0RBQWdELENBQUM7QUFLdEYsTUFBTSxPQUFPLGVBQWdCLFNBQVEsVUFBVTtJQUM5QyxZQUFZLEVBQVMsRUFBRSxRQUF3QixFQUFFLFVBQTJCLEVBQUUsS0FBYSxFQUFFLFNBQW9CLEVBQUUsS0FBYSxFQUFFLFdBQW1CLEVBQUUsSUFBWSxFQUFFLFFBQWdCLEVBQUUsVUFBa0M7UUFDbE4sS0FBSyxDQUFDLEVBQUUsRUFBRSxvQkFBb0IsRUFBRSxRQUFRLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDakQsSUFBSSxDQUFDLEtBQUssR0FBRztZQUNULEtBQUssRUFBRSxTQUFTO1lBQ2hCLFVBQVUsRUFBRSxVQUFVLEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQSxFQUFFLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQztZQUM1QyxNQUFNLEVBQUUsVUFBVSxFQUFFLEdBQUcsQ0FBQyxDQUFDLENBQUEsRUFBRSxHQUFFLE9BQU8sRUFBQyxJQUFJLEVBQUMsQ0FBQyxDQUFDLElBQUksRUFBRSxPQUFPLEVBQUMsQ0FBQyxDQUFDLE9BQU8sRUFBQyxDQUFBLENBQUEsQ0FBQyxDQUFDO1lBQ3RFLEtBQUssRUFBRSxLQUFLO1lBQ1osS0FBSyxFQUFFLFFBQVE7WUFDZixXQUFXLEVBQUUsV0FBVztZQUN4QixPQUFPLEVBQUUsSUFBSTtZQUNiLFVBQVUsRUFBRSxVQUFVO1NBQ3pCLENBQUE7SUFDTCxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUb3RzQ29sdW1uIH0gZnJvbSBcIkB0b3RzL3RhYmxlXCI7XHJcbmltcG9ydCB7IElucHV0Q29sdW1uQ29tcG9uZW50IH0gZnJvbSBcIi4uL2NvbHVtbnMvaW5wdXQtY29sdW1uL2lucHV0LWNvbHVtbi5jb21wb25lbnRcIjtcclxuaW1wb3J0IHsgRm9ybUdyb3VwIH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XHJcbmltcG9ydCB7IE1hdEZvcm1GaWVsZEFwcGVhcmFuY2UgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvZm9ybS1maWVsZFwiO1xyXG5pbXBvcnQgeyBUb3RzVmFsaWRhdG9yIH0gZnJvbSBcIi4uL2VudGl0aWVzL3RvdHMtdmFsaWRhdG9yXCI7XHJcblxyXG5leHBvcnQgY2xhc3MgVG90c0lucHV0Q29sdW1uIGV4dGVuZHMgVG90c0NvbHVtbiB7XHJcblx0Y29uc3RydWN0b3IoaWQ6c3RyaW5nLCBmaWVsZEtleTpzdHJpbmd8c3RyaW5nW10sIHZhbGlkYXRvcnM/OlRvdHNWYWxpZGF0b3JbXSwgdGl0bGU/OnN0cmluZywgZm9ybUdyb3VwPzpGb3JtR3JvdXAsIGxhYmVsPzpzdHJpbmcsIHBsYWNlaG9sZGVyPzpzdHJpbmcsIGhpbnQ/OnN0cmluZywgY3NzQ2xhc3M/OnN0cmluZywgYXBwZWFyYW5jZT86TWF0Rm9ybUZpZWxkQXBwZWFyYW5jZSkge1xyXG4gICAgICAgIHN1cGVyKGlkLCBJbnB1dENvbHVtbkNvbXBvbmVudCwgZmllbGRLZXksIHRpdGxlKTtcclxuICAgICAgICB0aGlzLmV4dHJhID0ge1xyXG4gICAgICAgICAgICBncm91cDogZm9ybUdyb3VwLFxyXG4gICAgICAgICAgICB2YWxpZGF0b3JzOiB2YWxpZGF0b3JzPy5tYXAodj0+IHYudmFsaWRhdG9yKSxcclxuICAgICAgICAgICAgZXJyb3JzOiB2YWxpZGF0b3JzPy5tYXAodj0+IHtyZXR1cm4ge25hbWU6di5uYW1lLCBtZXNzYWdlOnYubWVzc2FnZX19KSxcclxuICAgICAgICAgICAgbGFiZWw6IGxhYmVsLFxyXG4gICAgICAgICAgICBjbGFzczogY3NzQ2xhc3MsXHJcbiAgICAgICAgICAgIHBsYWNlaG9sZGVyOiBwbGFjZWhvbGRlcixcclxuICAgICAgICAgICAgY2FwdGlvbjogaGludCxcclxuICAgICAgICAgICAgYXBwZWFyYW5jZTogYXBwZWFyYW5jZVxyXG4gICAgICAgIH1cclxuICAgIH1cclxufSJdfQ==
|
|
@@ -0,0 +1,107 @@
|
|
|
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/input";
|
|
9
|
+
export class InputColumnComponent extends TotsBaseColumnComponent {
|
|
10
|
+
constructor() {
|
|
11
|
+
super();
|
|
12
|
+
}
|
|
13
|
+
ngOnInit() {
|
|
14
|
+
this.loadInput();
|
|
15
|
+
this.loadForm();
|
|
16
|
+
this.loadChanges();
|
|
17
|
+
}
|
|
18
|
+
loadChanges() {
|
|
19
|
+
this.input.valueChanges
|
|
20
|
+
.subscribe(res => {
|
|
21
|
+
this.onAction.next({ key: 'input-change', item: { field_key: this.getFormKey(), item: this.item, value: res, valid: this.input.valid, index: this.index } });
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
loadForm() {
|
|
25
|
+
if (this.column.extra == undefined || this.column.extra.group == undefined) {
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
let group = this.column.extra.group;
|
|
29
|
+
if (group.get(this.getFormKey()) != undefined) {
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
group.addControl(this.getFormKey(), this.input);
|
|
33
|
+
}
|
|
34
|
+
loadInput() {
|
|
35
|
+
let value = TotsTableHelper.getItemValueByKey(this.item, this.column.field_key);
|
|
36
|
+
this.input = new FormControl(value, this.getValidators());
|
|
37
|
+
this.onAction.next({ key: 'input-create', item: { field_key: this.getFormKey(), input: this.input, index: this.index, column: this.column } });
|
|
38
|
+
}
|
|
39
|
+
getFormKey() {
|
|
40
|
+
if (Array.isArray(this.column.field_key)) {
|
|
41
|
+
return this.column.field_key.join('_');
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
return this.column.field_key;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
getValidators() {
|
|
48
|
+
if (this.column.extra && this.column.extra.validators) {
|
|
49
|
+
return this.column.extra.validators;
|
|
50
|
+
}
|
|
51
|
+
return null;
|
|
52
|
+
}
|
|
53
|
+
getErrorMessage() {
|
|
54
|
+
if (!this.column.extra.errors) {
|
|
55
|
+
return '';
|
|
56
|
+
}
|
|
57
|
+
for (const error of this.column.extra.errors) {
|
|
58
|
+
if (this.input.hasError(error.name)) {
|
|
59
|
+
return error.message;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
return '';
|
|
63
|
+
}
|
|
64
|
+
getAppearance() {
|
|
65
|
+
if (this.column.extra && this.column.extra.appearance) {
|
|
66
|
+
return this.column.extra.appearance;
|
|
67
|
+
}
|
|
68
|
+
return 'fill';
|
|
69
|
+
}
|
|
70
|
+
getLabel() {
|
|
71
|
+
if (this.column.extra && this.column.extra.label) {
|
|
72
|
+
return this.column.extra.label;
|
|
73
|
+
}
|
|
74
|
+
return undefined;
|
|
75
|
+
}
|
|
76
|
+
getClass() {
|
|
77
|
+
if (this.column.extra && this.column.extra.class) {
|
|
78
|
+
return this.column.extra.class;
|
|
79
|
+
}
|
|
80
|
+
return '';
|
|
81
|
+
}
|
|
82
|
+
getPlaceholder() {
|
|
83
|
+
if (this.column.extra && this.column.extra.placeholder) {
|
|
84
|
+
return this.column.extra.placeholder;
|
|
85
|
+
}
|
|
86
|
+
return '';
|
|
87
|
+
}
|
|
88
|
+
getCaption() {
|
|
89
|
+
if (this.column.extra && this.column.extra.caption) {
|
|
90
|
+
return this.column.extra.caption;
|
|
91
|
+
}
|
|
92
|
+
return '';
|
|
93
|
+
}
|
|
94
|
+
hasError() {
|
|
95
|
+
return this.input.invalid && (this.input.dirty || this.input.touched);
|
|
96
|
+
}
|
|
97
|
+
getInput() {
|
|
98
|
+
return this.input;
|
|
99
|
+
}
|
|
100
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: InputColumnComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
101
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.11", type: InputColumnComponent, selector: "tots-input-column", usesInheritance: true, ngImport: i0, 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"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { 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: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }] }); }
|
|
102
|
+
}
|
|
103
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: InputColumnComponent, decorators: [{
|
|
104
|
+
type: Component,
|
|
105
|
+
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"] }]
|
|
106
|
+
}], ctorParameters: function () { return []; } });
|
|
107
|
+
//# 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 } 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 {\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\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"]}
|
package/{esm2020 → esm2022}/lib/components/tots-table-full-group/tots-table-full-group.component.mjs
RENAMED
|
@@ -58,10 +58,10 @@ export class TotsTableFullGroupComponent {
|
|
|
58
58
|
return column.field_key;
|
|
59
59
|
}
|
|
60
60
|
}
|
|
61
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: TotsTableFullGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
62
|
+
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"] }] }); }
|
|
61
63
|
}
|
|
62
|
-
|
|
63
|
-
TotsTableFullGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", 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"] }] });
|
|
64
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableFullGroupComponent, decorators: [{
|
|
64
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: TotsTableFullGroupComponent, decorators: [{
|
|
65
65
|
type: Component,
|
|
66
66
|
args: [{ selector: 'tots-table-full-group', template: "<tots-table #tableComp [config]=\"config\" [pageIndex]=\"pageIndex\" [pageSize]=\"pageSize\" [hasPagination]=\"hasPagination\" [messageNotFound]=\"messageNotFound\" (onAction)=\"onTableAction($event)\"></tots-table>\n" }]
|
|
67
67
|
}], propDecorators: { tableComp: [{
|
|
@@ -80,4 +80,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
|
|
|
80
80
|
}], onAction: [{
|
|
81
81
|
type: Output
|
|
82
82
|
}] } });
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG90cy10YWJsZS1mdWxsLWdyb3VwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RvdHMvZWRpdGFibGUtY29sdW1ucy9zcmMvbGliL2NvbXBvbmVudHMvdG90cy10YWJsZS1mdWxsLWdyb3VwL3RvdHMtdGFibGUtZnVsbC1ncm91cC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90b3RzL2VkaXRhYmxlLWNvbHVtbnMvc3JjL2xpYi9jb21wb25lbnRzL3RvdHMtdGFibGUtZnVsbC1ncm91cC90b3RzLXRhYmxlLWZ1bGwtZ3JvdXAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbEYsT0FBTyxFQUFFLFNBQVMsRUFBZSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNuRSxPQUFPLEVBQW1ELGVBQWUsRUFBRSxNQUFNLGFBQWEsQ0FBQzs7O0FBTy9GLE1BQU0sT0FBTywyQkFBMkI7SUFMeEM7UUFTVyxXQUFNLEdBQUcsSUFBSSxlQUFlLEVBQUUsQ0FBQztRQUMvQixjQUFTLEdBQVcsQ0FBQyxDQUFDO1FBQ3RCLGFBQVEsR0FBVyxFQUFFLENBQUM7UUFDdEIsa0JBQWEsR0FBWSxJQUFJLENBQUM7UUFDOUIsb0JBQWUsR0FBVyxzREFBc0QsQ0FBQztRQUVoRixhQUFRLEdBQUcsSUFBSSxZQUFZLEVBQW1CLENBQUM7S0FrRDFEO0lBOUNDLGFBQWEsQ0FBQyxNQUF1QjtRQUNuQyxJQUFHLE1BQU0sQ0FBQyxHQUFHLElBQUksY0FBYyxFQUFDO1lBQzlCLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztTQUNsQjthQUFNLElBQUksTUFBTSxDQUFDLEdBQUcsSUFBSSxjQUFjLEVBQUU7WUFDdkMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxNQUFNLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1NBQ2hGO2FBQU0sSUFBSSxNQUFNLENBQUMsR0FBRyxJQUFJLGNBQWMsRUFBRTtZQUN2QyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUMzQixVQUFVLENBQUMsR0FBRyxFQUFFO2dCQUNkLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsR0FBRyxFQUFFLGFBQWEsRUFBRSxJQUFJLEVBQUUsRUFBRSxLQUFLLEVBQUUsSUFBSSxDQUFDLGFBQWMsQ0FBQyxLQUFLLEVBQUUsTUFBTSxFQUFFLElBQUksQ0FBQyxhQUFhLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBQzVILENBQUMsQ0FBQyxDQUFDO1lBQ0gsT0FBTztTQUNSO1FBQ0QsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDN0IsQ0FBQztJQUVELGVBQWUsQ0FBQyxLQUFrQixFQUFFLEtBQWEsRUFBRSxNQUFrQjtRQUNuRSxJQUFJLEtBQUssR0FBRyxJQUFJLENBQUMsYUFBYSxFQUFFLEVBQUUsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMxQyxJQUFHLEtBQUssSUFBSSxTQUFTLEVBQUM7WUFDcEIsT0FBTztTQUNSO1FBQ0QsS0FBSyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ25ELENBQUM7SUFFRCxTQUFTO1FBQ1AsWUFBWTtRQUNaLElBQUksS0FBSyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsWUFBWSxFQUFFLENBQUM7UUFDMUMseUJBQXlCO1FBQ3pCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxTQUFTLENBQVksRUFBRSxDQUFDLENBQUM7UUFDbEQsc0JBQXNCO1FBQ3RCLElBQUcsS0FBSyxJQUFJLFNBQVMsRUFBQztZQUNwQixPQUFPO1NBQ1I7UUFDRCxrQ0FBa0M7UUFDbEMsS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDeEIsSUFBSSxLQUFLLEdBQUcsSUFBSSxTQUFTLENBQUMsRUFBRSxDQUFDLENBQUM7WUFDOUIsSUFBSSxDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDbEMsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsVUFBVSxDQUFDLE1BQWtCO1FBQzNCLElBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLEVBQUM7WUFDakMsT0FBTyxNQUFNLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUNuQzthQUFNO1lBQ0wsT0FBTyxNQUFNLENBQUMsU0FBVSxDQUFDO1NBQzFCO0lBQ0gsQ0FBQzsrR0EzRFUsMkJBQTJCO21HQUEzQiwyQkFBMkIsd1ZDVHhDLDJOQUNBOzs0RkRRYSwyQkFBMkI7a0JBTHZDLFNBQVM7K0JBQ0UsdUJBQXVCOzhCQU1ULFNBQVM7c0JBQWhDLFNBQVM7dUJBQUMsV0FBVztnQkFFYixNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csZUFBZTtzQkFBdkIsS0FBSztnQkFFSSxRQUFRO3NCQUFqQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybUFycmF5LCBGb3JtQ29udHJvbCwgRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgVG90c0FjdGlvblRhYmxlLCBUb3RzQ29sdW1uLCBUb3RzVGFibGVDb21wb25lbnQsIFRvdHNUYWJsZUNvbmZpZyB9IGZyb20gJ0B0b3RzL3RhYmxlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndG90cy10YWJsZS1mdWxsLWdyb3VwJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3RvdHMtdGFibGUtZnVsbC1ncm91cC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3RvdHMtdGFibGUtZnVsbC1ncm91cC5jb21wb25lbnQuY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgVG90c1RhYmxlRnVsbEdyb3VwQ29tcG9uZW50IHtcblxuICBAVmlld0NoaWxkKCd0YWJsZUNvbXAnKSB0YWJsZUNvbXAhOiBUb3RzVGFibGVDb21wb25lbnQ7XG5cbiAgQElucHV0KCkgY29uZmlnID0gbmV3IFRvdHNUYWJsZUNvbmZpZygpO1xuICBASW5wdXQoKSBwYWdlSW5kZXg6IG51bWJlciA9IDA7XG4gIEBJbnB1dCgpIHBhZ2VTaXplOiBudW1iZXIgPSA1MDtcbiAgQElucHV0KCkgaGFzUGFnaW5hdGlvbjogYm9vbGVhbiA9IHRydWU7XG4gIEBJbnB1dCgpIG1lc3NhZ2VOb3RGb3VuZDogc3RyaW5nID0gXCJObyByZXN1bHRzIGZvdW5kLCBwbGVhc2UgdHJ5IHdpdGggb3RoZXIgc2VhcmNoIHRlcm1zXCI7XG5cbiAgQE91dHB1dCgpIG9uQWN0aW9uID0gbmV3IEV2ZW50RW1pdHRlcjxUb3RzQWN0aW9uVGFibGU+KCk7XG5cbiAgZm9ybUFycmF5TWFpbj86IEZvcm1BcnJheTxGb3JtR3JvdXA+O1xuXG4gIG9uVGFibGVBY3Rpb24oYWN0aW9uOiBUb3RzQWN0aW9uVGFibGUpIHtcbiAgICBpZihhY3Rpb24ua2V5ID09ICdsb2FkZWQtaXRlbXMnKXtcbiAgICAgIHRoaXMubG9hZEdyb3VwKCk7XG4gICAgfSBlbHNlIGlmIChhY3Rpb24ua2V5ID09ICdpbnB1dC1jcmVhdGUnKSB7XG4gICAgICB0aGlzLmFkZElucHV0SW5Hcm91cChhY3Rpb24uaXRlbS5pbnB1dCwgYWN0aW9uLml0ZW0uaW5kZXgsIGFjdGlvbi5pdGVtLmNvbHVtbik7XG4gICAgfSBlbHNlIGlmIChhY3Rpb24ua2V5ID09ICdpbnB1dC1jaGFuZ2UnKSB7XG4gICAgICB0aGlzLm9uQWN0aW9uLmVtaXQoYWN0aW9uKTtcbiAgICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICB0aGlzLm9uQWN0aW9uLmVtaXQoeyBrZXk6ICdmb3JtLWNoYW5nZScsIGl0ZW06IHsgdmFsaWQ6IHRoaXMuZm9ybUFycmF5TWFpbiEudmFsaWQsIHZhbHVlczogdGhpcy5mb3JtQXJyYXlNYWluPy52YWx1ZSB9IH0pO1xuICAgICAgfSk7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIHRoaXMub25BY3Rpb24uZW1pdChhY3Rpb24pO1xuICB9XG5cbiAgYWRkSW5wdXRJbkdyb3VwKGlucHV0OiBGb3JtQ29udHJvbCwgaW5kZXg6IG51bWJlciwgY29sdW1uOiBUb3RzQ29sdW1uKSB7XG4gICAgbGV0IGdyb3VwID0gdGhpcy5mb3JtQXJyYXlNYWluPy5hdChpbmRleCk7XG4gICAgaWYoZ3JvdXAgPT0gdW5kZWZpbmVkKXtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgZ3JvdXAuYWRkQ29udHJvbCh0aGlzLmdldEZvcm1LZXkoY29sdW1uKSwgaW5wdXQpO1xuICB9XG5cbiAgbG9hZEdyb3VwKCkge1xuICAgIC8vIEdldCBJdGVtc1xuICAgIGxldCBpdGVtcyA9IHRoaXMudGFibGVDb21wLmdldERhdGFJdGVtcygpO1xuICAgIC8vIENyZWF0ZSBtYWluIGFycmF5IGZvcm1cbiAgICB0aGlzLmZvcm1BcnJheU1haW4gPSBuZXcgRm9ybUFycmF5PEZvcm1Hcm91cD4oW10pO1xuICAgIC8vIFZlcmlmeSBpZiB1bmRlZmluZWRcbiAgICBpZihpdGVtcyA9PSB1bmRlZmluZWQpe1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICAvLyBDcmVhdGUgZm9ybSBncm91cCBmb3IgZWFjaCBpdGVtXG4gICAgaXRlbXMuZGF0YS5mb3JFYWNoKGl0ZW0gPT4ge1xuICAgICAgbGV0IGdyb3VwID0gbmV3IEZvcm1Hcm91cCh7fSk7XG4gICAgICB0aGlzLmZvcm1BcnJheU1haW4/LnB1c2goZ3JvdXApO1xuICAgIH0pO1xuICB9XG5cbiAgZ2V0Rm9ybUtleShjb2x1bW46IFRvdHNDb2x1bW4pOiBzdHJpbmcge1xuICAgIGlmKEFycmF5LmlzQXJyYXkoY29sdW1uLmZpZWxkX2tleSkpe1xuICAgICAgcmV0dXJuIGNvbHVtbi5maWVsZF9rZXkuam9pbignXycpO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gY29sdW1uLmZpZWxkX2tleSE7XG4gICAgfVxuICB9XG59XG4iLCI8dG90cy10YWJsZSAjdGFibGVDb21wIFtjb25maWddPVwiY29uZmlnXCIgW3BhZ2VJbmRleF09XCJwYWdlSW5kZXhcIiBbcGFnZVNpemVdPVwicGFnZVNpemVcIiBbaGFzUGFnaW5hdGlvbl09XCJoYXNQYWdpbmF0aW9uXCIgW21lc3NhZ2VOb3RGb3VuZF09XCJtZXNzYWdlTm90Rm91bmRcIiAob25BY3Rpb24pPVwib25UYWJsZUFjdGlvbigkZXZlbnQpXCI+PC90b3RzLXRhYmxlPlxuIl19
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
4
|
+
/** Angular Material */
|
|
5
|
+
import { MatInputModule } from '@angular/material/input';
|
|
6
|
+
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
7
|
+
/** Tots Libraries */
|
|
8
|
+
import { TotsTableModule } from '@tots/table';
|
|
9
|
+
/** Columns */
|
|
10
|
+
import { InputColumnComponent } from './columns/input-column/input-column.component';
|
|
11
|
+
/** Components */
|
|
12
|
+
import { TotsTableFullGroupComponent } from './components/tots-table-full-group/tots-table-full-group.component';
|
|
13
|
+
import * as i0 from "@angular/core";
|
|
14
|
+
export class TotsEditableColumnsModule {
|
|
15
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: TotsEditableColumnsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
16
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.11", ngImport: i0, type: TotsEditableColumnsModule, declarations: [
|
|
17
|
+
/** Columns */
|
|
18
|
+
InputColumnComponent,
|
|
19
|
+
/** Components */
|
|
20
|
+
TotsTableFullGroupComponent], imports: [CommonModule,
|
|
21
|
+
FormsModule,
|
|
22
|
+
ReactiveFormsModule,
|
|
23
|
+
/** Angular Material */
|
|
24
|
+
MatFormFieldModule,
|
|
25
|
+
MatInputModule,
|
|
26
|
+
/** Tots Libraries */
|
|
27
|
+
TotsTableModule], exports: [
|
|
28
|
+
/** Columns */
|
|
29
|
+
InputColumnComponent,
|
|
30
|
+
/** Components */
|
|
31
|
+
TotsTableFullGroupComponent] }); }
|
|
32
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: TotsEditableColumnsModule, imports: [CommonModule,
|
|
33
|
+
FormsModule,
|
|
34
|
+
ReactiveFormsModule,
|
|
35
|
+
/** Angular Material */
|
|
36
|
+
MatFormFieldModule,
|
|
37
|
+
MatInputModule,
|
|
38
|
+
/** Tots Libraries */
|
|
39
|
+
TotsTableModule] }); }
|
|
40
|
+
}
|
|
41
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: TotsEditableColumnsModule, decorators: [{
|
|
42
|
+
type: NgModule,
|
|
43
|
+
args: [{
|
|
44
|
+
declarations: [
|
|
45
|
+
/** Columns */
|
|
46
|
+
InputColumnComponent,
|
|
47
|
+
/** Components */
|
|
48
|
+
TotsTableFullGroupComponent
|
|
49
|
+
],
|
|
50
|
+
imports: [
|
|
51
|
+
CommonModule,
|
|
52
|
+
FormsModule,
|
|
53
|
+
ReactiveFormsModule,
|
|
54
|
+
/** Angular Material */
|
|
55
|
+
MatFormFieldModule,
|
|
56
|
+
MatInputModule,
|
|
57
|
+
/** Tots Libraries */
|
|
58
|
+
TotsTableModule
|
|
59
|
+
],
|
|
60
|
+
exports: [
|
|
61
|
+
/** Columns */
|
|
62
|
+
InputColumnComponent,
|
|
63
|
+
/** Components */
|
|
64
|
+
TotsTableFullGroupComponent
|
|
65
|
+
]
|
|
66
|
+
}]
|
|
67
|
+
}] });
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWRpdGFibGUtY29sdW1ucy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90b3RzL2VkaXRhYmxlLWNvbHVtbnMvc3JjL2xpYi9lZGl0YWJsZS1jb2x1bW5zLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFbEUsdUJBQXVCO0FBQ3ZCLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUVsRSxxQkFBcUI7QUFDckIsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUU5QyxjQUFjO0FBQ2QsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sK0NBQStDLENBQUM7QUFFckYsaUJBQWlCO0FBQ2pCLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLG9FQUFvRSxDQUFDOztBQXFDakgsTUFBTSxPQUFPLHlCQUF5QjsrR0FBekIseUJBQXlCO2dIQUF6Qix5QkFBeUI7WUExQmxDLGNBQWM7WUFDZCxvQkFBb0I7WUFFcEIsaUJBQWlCO1lBQ2pCLDJCQUEyQixhQUczQixZQUFZO1lBQ1osV0FBVztZQUNYLG1CQUFtQjtZQUVuQix1QkFBdUI7WUFDdkIsa0JBQWtCO1lBQ2xCLGNBQWM7WUFFZCxxQkFBcUI7WUFDckIsZUFBZTtZQUdmLGNBQWM7WUFDZCxvQkFBb0I7WUFFcEIsaUJBQWlCO1lBQ2pCLDJCQUEyQjtnSEFHbEIseUJBQXlCLFlBbkJsQyxZQUFZO1lBQ1osV0FBVztZQUNYLG1CQUFtQjtZQUVuQix1QkFBdUI7WUFDdkIsa0JBQWtCO1lBQ2xCLGNBQWM7WUFFZCxxQkFBcUI7WUFDckIsZUFBZTs7NEZBVU4seUJBQXlCO2tCQTdCckMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUU7d0JBRVosY0FBYzt3QkFDZCxvQkFBb0I7d0JBRXBCLGlCQUFpQjt3QkFDakIsMkJBQTJCO3FCQUM1QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3dCQUNYLG1CQUFtQjt3QkFFbkIsdUJBQXVCO3dCQUN2QixrQkFBa0I7d0JBQ2xCLGNBQWM7d0JBRWQscUJBQXFCO3dCQUNyQixlQUFlO3FCQUNoQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsY0FBYzt3QkFDZCxvQkFBb0I7d0JBRXBCLGlCQUFpQjt3QkFDakIsMkJBQTJCO3FCQUM1QjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbi8qKiBBbmd1bGFyIE1hdGVyaWFsICovXG5pbXBvcnQgeyBNYXRJbnB1dE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcbmltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xuXG4vKiogVG90cyBMaWJyYXJpZXMgKi9cbmltcG9ydCB7IFRvdHNUYWJsZU1vZHVsZSB9IGZyb20gJ0B0b3RzL3RhYmxlJztcblxuLyoqIENvbHVtbnMgKi9cbmltcG9ydCB7IElucHV0Q29sdW1uQ29tcG9uZW50IH0gZnJvbSAnLi9jb2x1bW5zL2lucHV0LWNvbHVtbi9pbnB1dC1jb2x1bW4uY29tcG9uZW50JztcblxuLyoqIENvbXBvbmVudHMgKi9cbmltcG9ydCB7IFRvdHNUYWJsZUZ1bGxHcm91cENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy90b3RzLXRhYmxlLWZ1bGwtZ3JvdXAvdG90cy10YWJsZS1mdWxsLWdyb3VwLmNvbXBvbmVudCc7XG5cblxuXG5cblxuXG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1xuXG4gICAgLyoqIENvbHVtbnMgKi9cbiAgICBJbnB1dENvbHVtbkNvbXBvbmVudCxcblxuICAgIC8qKiBDb21wb25lbnRzICovXG4gICAgVG90c1RhYmxlRnVsbEdyb3VwQ29tcG9uZW50XG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgRm9ybXNNb2R1bGUsXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcblxuICAgIC8qKiBBbmd1bGFyIE1hdGVyaWFsICovXG4gICAgTWF0Rm9ybUZpZWxkTW9kdWxlLFxuICAgIE1hdElucHV0TW9kdWxlLFxuXG4gICAgLyoqIFRvdHMgTGlicmFyaWVzICovXG4gICAgVG90c1RhYmxlTW9kdWxlXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICAvKiogQ29sdW1ucyAqL1xuICAgIElucHV0Q29sdW1uQ29tcG9uZW50LFxuXG4gICAgLyoqIENvbXBvbmVudHMgKi9cbiAgICBUb3RzVGFibGVGdWxsR3JvdXBDb21wb25lbnRcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBUb3RzRWRpdGFibGVDb2x1bW5zTW9kdWxlIHsgfVxuIl19
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export class TotsValidator {
|
|
2
|
+
constructor(validator, name, message) {
|
|
3
|
+
this.validator = validator;
|
|
4
|
+
this.name = name;
|
|
5
|
+
this.message = message;
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG90cy12YWxpZGF0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90b3RzL2VkaXRhYmxlLWNvbHVtbnMvc3JjL2xpYi9lbnRpdGllcy90b3RzLXZhbGlkYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLE9BQU8sYUFBYTtJQUt0QixZQUFZLFNBQXFCLEVBQUUsSUFBVyxFQUFFLE9BQWM7UUFDMUQsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7UUFDM0IsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7UUFDakIsSUFBSSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7SUFDM0IsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVmFsaWRhdG9yRm4gfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIlxuXG5leHBvcnQgY2xhc3MgVG90c1ZhbGlkYXRvciB7XG4gICAgdmFsaWRhdG9yOiBWYWxpZGF0b3JGbjtcbiAgICBuYW1lOiBzdHJpbmc7XG4gICAgbWVzc2FnZTogc3RyaW5nO1xuICAgIFxuICAgIGNvbnN0cnVjdG9yKHZhbGlkYXRvcjpWYWxpZGF0b3JGbiwgbmFtZTpzdHJpbmcsIG1lc3NhZ2U6c3RyaW5nKSB7XG4gICAgICAgIHRoaXMudmFsaWRhdG9yID0gdmFsaWRhdG9yO1xuICAgICAgICB0aGlzLm5hbWUgPSBuYW1lO1xuICAgICAgICB0aGlzLm1lc3NhZ2UgPSBtZXNzYWdlO1xuICAgIH1cbn0iXX0=
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Public API Surface of editable-columns
|
|
3
|
+
*/
|
|
4
|
+
/**
|
|
5
|
+
* Entities
|
|
6
|
+
*/
|
|
7
|
+
export * from './lib/entities/tots-validator';
|
|
8
|
+
/**
|
|
9
|
+
* Columns
|
|
10
|
+
*/
|
|
11
|
+
export * from './lib/columns/input-column/input-column.component';
|
|
12
|
+
/**
|
|
13
|
+
* Components
|
|
14
|
+
*/
|
|
15
|
+
export * from './lib/components/tots-table-full-group/tots-table-full-group.component';
|
|
16
|
+
/**
|
|
17
|
+
* Factories
|
|
18
|
+
*/
|
|
19
|
+
export * from './lib/column-factories/tots-input-column';
|
|
20
|
+
/**
|
|
21
|
+
* Modules
|
|
22
|
+
*/
|
|
23
|
+
export * from './lib/editable-columns.module';
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3RvdHMvZWRpdGFibGUtY29sdW1ucy9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVIOztHQUVHO0FBQ0gsY0FBYywrQkFBK0IsQ0FBQztBQUU5Qzs7R0FFRztBQUNILGNBQWMsbURBQW1ELENBQUM7QUFFbEU7O0dBRUc7QUFDSCxjQUFjLHdFQUF3RSxDQUFDO0FBRXZGOztHQUVHO0FBQ0gsY0FBYywwQ0FBMEMsQ0FBQztBQUV6RDs7R0FFRztBQUNILGNBQWMsK0JBQStCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGVkaXRhYmxlLWNvbHVtbnNcbiAqL1xuXG4vKipcbiAqIEVudGl0aWVzXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2VudGl0aWVzL3RvdHMtdmFsaWRhdG9yJztcblxuLyoqXG4gKiBDb2x1bW5zXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbHVtbnMvaW5wdXQtY29sdW1uL2lucHV0LWNvbHVtbi5jb21wb25lbnQnO1xuXG4vKipcbiAqIENvbXBvbmVudHNcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy90b3RzLXRhYmxlLWZ1bGwtZ3JvdXAvdG90cy10YWJsZS1mdWxsLWdyb3VwLmNvbXBvbmVudCc7XG5cbi8qKlxuICogRmFjdG9yaWVzXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbHVtbi1mYWN0b3JpZXMvdG90cy1pbnB1dC1jb2x1bW4nO1xuXG4vKipcbiAqIE1vZHVsZXNcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZWRpdGFibGUtY29sdW1ucy5tb2R1bGUnO1xuIl19
|
|
@@ -3,7 +3,7 @@ import { Component, EventEmitter, ViewChild, Input, Output, NgModule } from '@an
|
|
|
3
3
|
import * as i2 from '@angular/forms';
|
|
4
4
|
import { FormControl, FormArray, FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
5
5
|
import * as i1$1 from '@tots/table';
|
|
6
|
-
import { TotsBaseColumnComponent, TotsTableHelper, TotsTableConfig, TotsTableModule } from '@tots/table';
|
|
6
|
+
import { TotsBaseColumnComponent, TotsTableHelper, TotsTableConfig, TotsColumn, TotsTableModule } from '@tots/table';
|
|
7
7
|
import * as i1 from '@angular/common';
|
|
8
8
|
import { CommonModule } from '@angular/common';
|
|
9
9
|
import * as i3 from '@angular/material/form-field';
|
|
@@ -11,7 +11,15 @@ 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
13
|
|
|
14
|
-
class
|
|
14
|
+
class TotsValidator {
|
|
15
|
+
constructor(validator, name, message) {
|
|
16
|
+
this.validator = validator;
|
|
17
|
+
this.name = name;
|
|
18
|
+
this.message = message;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
class InputColumnComponent extends TotsBaseColumnComponent {
|
|
15
23
|
constructor() {
|
|
16
24
|
super();
|
|
17
25
|
}
|
|
@@ -78,9 +86,9 @@ class InputColumn extends TotsBaseColumnComponent {
|
|
|
78
86
|
}
|
|
79
87
|
return undefined;
|
|
80
88
|
}
|
|
81
|
-
|
|
82
|
-
if (this.column.extra && this.column.extra.
|
|
83
|
-
return this.column.extra.
|
|
89
|
+
getClass() {
|
|
90
|
+
if (this.column.extra && this.column.extra.class) {
|
|
91
|
+
return this.column.extra.class;
|
|
84
92
|
}
|
|
85
93
|
return '';
|
|
86
94
|
}
|
|
@@ -102,12 +110,12 @@ class InputColumn extends TotsBaseColumnComponent {
|
|
|
102
110
|
getInput() {
|
|
103
111
|
return this.input;
|
|
104
112
|
}
|
|
113
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: InputColumnComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
114
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.11", type: InputColumnComponent, selector: "tots-input-column", usesInheritance: true, ngImport: i0, 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"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { 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: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }] }); }
|
|
105
115
|
}
|
|
106
|
-
|
|
107
|
-
InputColumn.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", type: InputColumn, selector: "tots-input-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 <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"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { 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: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }] });
|
|
108
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: InputColumn, decorators: [{
|
|
116
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: InputColumnComponent, decorators: [{
|
|
109
117
|
type: Component,
|
|
110
|
-
args: [{ selector: 'tots-input-column', template: "<mat-form-field class=\"{{
|
|
118
|
+
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"] }]
|
|
111
119
|
}], ctorParameters: function () { return []; } });
|
|
112
120
|
|
|
113
121
|
class TotsTableFullGroupComponent {
|
|
@@ -165,10 +173,10 @@ class TotsTableFullGroupComponent {
|
|
|
165
173
|
return column.field_key;
|
|
166
174
|
}
|
|
167
175
|
}
|
|
176
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: TotsTableFullGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
177
|
+
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"] }] }); }
|
|
168
178
|
}
|
|
169
|
-
|
|
170
|
-
TotsTableFullGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.3", 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"] }] });
|
|
171
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsTableFullGroupComponent, decorators: [{
|
|
179
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: TotsTableFullGroupComponent, decorators: [{
|
|
172
180
|
type: Component,
|
|
173
181
|
args: [{ selector: 'tots-table-full-group', template: "<tots-table #tableComp [config]=\"config\" [pageIndex]=\"pageIndex\" [pageSize]=\"pageSize\" [hasPagination]=\"hasPagination\" [messageNotFound]=\"messageNotFound\" (onAction)=\"onTableAction($event)\"></tots-table>\n" }]
|
|
174
182
|
}], propDecorators: { tableComp: [{
|
|
@@ -188,39 +196,55 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
|
|
|
188
196
|
type: Output
|
|
189
197
|
}] } });
|
|
190
198
|
|
|
199
|
+
class TotsInputColumn extends TotsColumn {
|
|
200
|
+
constructor(id, fieldKey, validators, title, formGroup, label, placeholder, hint, cssClass, appearance) {
|
|
201
|
+
super(id, InputColumnComponent, fieldKey, title);
|
|
202
|
+
this.extra = {
|
|
203
|
+
group: formGroup,
|
|
204
|
+
validators: validators?.map(v => v.validator),
|
|
205
|
+
errors: validators?.map(v => { return { name: v.name, message: v.message }; }),
|
|
206
|
+
label: label,
|
|
207
|
+
class: cssClass,
|
|
208
|
+
placeholder: placeholder,
|
|
209
|
+
caption: hint,
|
|
210
|
+
appearance: appearance
|
|
211
|
+
};
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
|
|
191
215
|
class TotsEditableColumnsModule {
|
|
216
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: TotsEditableColumnsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
217
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.11", ngImport: i0, type: TotsEditableColumnsModule, declarations: [
|
|
218
|
+
/** Columns */
|
|
219
|
+
InputColumnComponent,
|
|
220
|
+
/** Components */
|
|
221
|
+
TotsTableFullGroupComponent], imports: [CommonModule,
|
|
222
|
+
FormsModule,
|
|
223
|
+
ReactiveFormsModule,
|
|
224
|
+
/** Angular Material */
|
|
225
|
+
MatFormFieldModule,
|
|
226
|
+
MatInputModule,
|
|
227
|
+
/** Tots Libraries */
|
|
228
|
+
TotsTableModule], exports: [
|
|
229
|
+
/** Columns */
|
|
230
|
+
InputColumnComponent,
|
|
231
|
+
/** Components */
|
|
232
|
+
TotsTableFullGroupComponent] }); }
|
|
233
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: TotsEditableColumnsModule, imports: [CommonModule,
|
|
234
|
+
FormsModule,
|
|
235
|
+
ReactiveFormsModule,
|
|
236
|
+
/** Angular Material */
|
|
237
|
+
MatFormFieldModule,
|
|
238
|
+
MatInputModule,
|
|
239
|
+
/** Tots Libraries */
|
|
240
|
+
TotsTableModule] }); }
|
|
192
241
|
}
|
|
193
|
-
|
|
194
|
-
TotsEditableColumnsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.0.3", ngImport: i0, type: TotsEditableColumnsModule, declarations: [
|
|
195
|
-
/** Columns */
|
|
196
|
-
InputColumn,
|
|
197
|
-
/** Components */
|
|
198
|
-
TotsTableFullGroupComponent], imports: [CommonModule,
|
|
199
|
-
FormsModule,
|
|
200
|
-
ReactiveFormsModule,
|
|
201
|
-
/** Angular Material */
|
|
202
|
-
MatFormFieldModule,
|
|
203
|
-
MatInputModule,
|
|
204
|
-
/** Tots Libraries */
|
|
205
|
-
TotsTableModule], exports: [
|
|
206
|
-
/** Columns */
|
|
207
|
-
InputColumn,
|
|
208
|
-
/** Components */
|
|
209
|
-
TotsTableFullGroupComponent] });
|
|
210
|
-
TotsEditableColumnsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsEditableColumnsModule, imports: [CommonModule,
|
|
211
|
-
FormsModule,
|
|
212
|
-
ReactiveFormsModule,
|
|
213
|
-
/** Angular Material */
|
|
214
|
-
MatFormFieldModule,
|
|
215
|
-
MatInputModule,
|
|
216
|
-
/** Tots Libraries */
|
|
217
|
-
TotsTableModule] });
|
|
218
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImport: i0, type: TotsEditableColumnsModule, decorators: [{
|
|
242
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: TotsEditableColumnsModule, decorators: [{
|
|
219
243
|
type: NgModule,
|
|
220
244
|
args: [{
|
|
221
245
|
declarations: [
|
|
222
246
|
/** Columns */
|
|
223
|
-
|
|
247
|
+
InputColumnComponent,
|
|
224
248
|
/** Components */
|
|
225
249
|
TotsTableFullGroupComponent
|
|
226
250
|
],
|
|
@@ -236,7 +260,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
|
|
|
236
260
|
],
|
|
237
261
|
exports: [
|
|
238
262
|
/** Columns */
|
|
239
|
-
|
|
263
|
+
InputColumnComponent,
|
|
240
264
|
/** Components */
|
|
241
265
|
TotsTableFullGroupComponent
|
|
242
266
|
]
|
|
@@ -246,10 +270,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.3", ngImpor
|
|
|
246
270
|
/*
|
|
247
271
|
* Public API Surface of editable-columns
|
|
248
272
|
*/
|
|
273
|
+
/**
|
|
274
|
+
* Entities
|
|
275
|
+
*/
|
|
249
276
|
|
|
250
277
|
/**
|
|
251
278
|
* Generated bundle index. Do not edit.
|
|
252
279
|
*/
|
|
253
280
|
|
|
254
|
-
export {
|
|
281
|
+
export { InputColumnComponent, TotsEditableColumnsModule, TotsInputColumn, TotsTableFullGroupComponent, TotsValidator };
|
|
255
282
|
//# sourceMappingURL=tots-editable-columns.mjs.map
|
|
@@ -0,0 +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 } 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 {\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\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 { 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') 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>;\n\n onTableAction(action: TotsActionTable) {\n if(action.key == 'loaded-items'){\n this.loadGroup();\n } else if (action.key == 'input-create') {\n this.addInputInGroup(action.item.input, action.item.index, action.item.column);\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 return;\n }\n this.onAction.emit(action);\n }\n\n addInputInGroup(input: FormControl, index: number, column: TotsColumn) {\n let group = this.formArrayMain?.at(index);\n if(group == undefined){\n return;\n }\n group.addControl(this.getFormKey(column), input);\n }\n\n loadGroup() {\n // Get Items\n let items = this.tableComp.getDataItems();\n // Create main array form\n this.formArrayMain = new FormArray<FormGroup>([]);\n // Verify if undefined\n if(items == undefined){\n return;\n }\n // Create form group for each item\n items.data.forEach(item => {\n let group = new FormGroup({});\n this.formArrayMain?.push(group);\n });\n }\n\n 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","<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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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { TotsColumn } 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 TotsInputColumn extends TotsColumn {
|
|
6
|
+
constructor(id: string, fieldKey: string | string[], validators?: TotsValidator[], title?: string, formGroup?: FormGroup, label?: string, placeholder?: string, hint?: string, cssClass?: string, appearance?: MatFormFieldAppearance);
|
|
7
|
+
}
|
|
@@ -2,7 +2,7 @@ import { FormControl, ValidatorFn } from '@angular/forms';
|
|
|
2
2
|
import { MatFormFieldAppearance } from '@angular/material/form-field';
|
|
3
3
|
import { TotsBaseColumnComponent } from '@tots/table';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
|
-
export declare class
|
|
5
|
+
export declare class InputColumnComponent extends TotsBaseColumnComponent {
|
|
6
6
|
input: FormControl;
|
|
7
7
|
constructor();
|
|
8
8
|
ngOnInit(): void;
|
|
@@ -14,11 +14,11 @@ export declare class InputColumn extends TotsBaseColumnComponent {
|
|
|
14
14
|
getErrorMessage(): string;
|
|
15
15
|
getAppearance(): MatFormFieldAppearance;
|
|
16
16
|
getLabel(): string | undefined;
|
|
17
|
-
|
|
17
|
+
getClass(): string;
|
|
18
18
|
getPlaceholder(): string;
|
|
19
19
|
getCaption(): string;
|
|
20
20
|
hasError(): boolean;
|
|
21
21
|
getInput(): FormControl<any>;
|
|
22
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<
|
|
23
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<
|
|
22
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<InputColumnComponent, never>;
|
|
23
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<InputColumnComponent, "tots-input-column", never, {}, {}, never, never, false, never>;
|
|
24
24
|
}
|
|
@@ -16,5 +16,5 @@ export declare class TotsTableFullGroupComponent {
|
|
|
16
16
|
loadGroup(): void;
|
|
17
17
|
getFormKey(column: TotsColumn): string;
|
|
18
18
|
static ɵfac: i0.ɵɵFactoryDeclaration<TotsTableFullGroupComponent, never>;
|
|
19
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TotsTableFullGroupComponent, "tots-table-full-group", never, { "config": "config"; "pageIndex": "pageIndex"; "pageSize": "pageSize"; "hasPagination": "hasPagination"; "messageNotFound": "messageNotFound"; }, { "onAction": "onAction"; }, never, never, false, never>;
|
|
19
|
+
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>;
|
|
20
20
|
}
|
|
@@ -8,6 +8,6 @@ import * as i6 from "@angular/material/input";
|
|
|
8
8
|
import * as i7 from "@tots/table";
|
|
9
9
|
export declare class TotsEditableColumnsModule {
|
|
10
10
|
static ɵfac: i0.ɵɵFactoryDeclaration<TotsEditableColumnsModule, never>;
|
|
11
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<TotsEditableColumnsModule, [typeof i1.
|
|
11
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<TotsEditableColumnsModule, [typeof i1.InputColumnComponent, typeof i2.TotsTableFullGroupComponent], [typeof i3.CommonModule, typeof i4.FormsModule, typeof i4.ReactiveFormsModule, typeof i5.MatFormFieldModule, typeof i6.MatInputModule, typeof i7.TotsTableModule], [typeof i1.InputColumnComponent, typeof i2.TotsTableFullGroupComponent]>;
|
|
12
12
|
static ɵinj: i0.ɵɵInjectorDeclaration<TotsEditableColumnsModule>;
|
|
13
13
|
}
|