@huntsman-cancer-institute/dictionary-editor 16.0.1 → 17.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.
Files changed (34) hide show
  1. package/components/detail.component.d.ts +90 -90
  2. package/components/home.component.d.ts +13 -13
  3. package/components/new-row.component.d.ts +20 -20
  4. package/dictionary-editor.component.d.ts +43 -43
  5. package/dictionary-editor.module.d.ts +24 -24
  6. package/dictionary-editor.routes.d.ts +4 -4
  7. package/esm2022/components/detail.component.mjs +606 -606
  8. package/esm2022/components/home.component.mjs +28 -28
  9. package/esm2022/components/new-row.component.mjs +81 -81
  10. package/esm2022/dictionary-editor.component.mjs +169 -169
  11. package/esm2022/dictionary-editor.module.mjs +76 -76
  12. package/esm2022/dictionary-editor.routes.mjs +14 -14
  13. package/esm2022/grid-editors/ag-grid-date-cell-editor.component.mjs +30 -30
  14. package/esm2022/grid-editors/ag-grid-editor.module.mjs +55 -55
  15. package/esm2022/grid-editors/datepicker.component.mjs +93 -93
  16. package/esm2022/grid-editors/select.editor.mjs +142 -142
  17. package/esm2022/grid-renderers/ag-grid-renderer.module.mjs +36 -36
  18. package/esm2022/grid-renderers/cell-renderer-validation.mjs +345 -345
  19. package/esm2022/grid-renderers/date.renderer.mjs +68 -68
  20. package/esm2022/grid-renderers/select.renderer.mjs +95 -95
  21. package/esm2022/huntsman-cancer-institute-dictionary-editor.mjs +4 -4
  22. package/esm2022/index.mjs +4 -4
  23. package/fesm2022/huntsman-cancer-institute-dictionary-editor.mjs +1718 -1718
  24. package/fesm2022/huntsman-cancer-institute-dictionary-editor.mjs.map +1 -1
  25. package/grid-editors/ag-grid-date-cell-editor.component.d.ts +11 -11
  26. package/grid-editors/ag-grid-editor.module.d.ts +15 -15
  27. package/grid-editors/datepicker.component.d.ts +16 -16
  28. package/grid-editors/select.editor.d.ts +30 -30
  29. package/grid-renderers/ag-grid-renderer.module.d.ts +10 -10
  30. package/grid-renderers/cell-renderer-validation.d.ts +69 -69
  31. package/grid-renderers/date.renderer.d.ts +15 -15
  32. package/grid-renderers/select.renderer.d.ts +17 -17
  33. package/index.d.ts +4 -4
  34. package/package.json +18 -10
@@ -1,138 +1,138 @@
1
- import { Component } from "@angular/core";
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "@angular/common";
4
- import * as i2 from "@angular/forms";
5
- //import {MatDialog, MatDialogConfig, MatDialogRef} from "@angular/material/dialog";
6
- //import {SpinnerDialogComponent} from "../popup/spinner-dialog.component";
7
- export class SelectEditor {
8
- get options() {
9
- if (this.using_selectOptionsPerRowFilterFunction) {
10
- return this._filteredOptions;
11
- }
12
- else {
13
- return this._options;
14
- }
15
- }
16
- set options(value) {
17
- this._options = value;
18
- }
19
- // private spinnerDialogRefs: MatDialogRef<SpinnerDialogComponent>[] = [];
20
- constructor() {
21
- this.using_selectOptionsPerRowFilterFunction = false;
22
- this._spinnerDialogIsOpen = false;
23
- }
24
- agInit(params) {
25
- this.params = params;
26
- this.options = [];
27
- this.optionsValueField = "";
28
- this.optionsDisplayField = "";
29
- if (this.params && this.params.column && this.params.column.colDef) {
30
- this.gridValueField = this.params.column.colDef.field;
31
- this.options = this.params.column.colDef.selectOptions;
32
- this.optionsValueField = this.params.column.colDef.selectOptionsValueField;
33
- this.optionsDisplayField = this.params.column.colDef.selectOptionsDisplayField;
34
- if (this.params.column.colDef.selectOptionsPerRowFilterFunction) {
35
- let backup = this.selectOptionsPerRowFilterFunction;
36
- try {
37
- this.selectOptionsPerRowFilterFunction = this.params.column.colDef.selectOptionsPerRowFilterFunction;
38
- this.using_selectOptionsPerRowFilterFunction = !!this.selectOptionsPerRowFilterFunction;
39
- }
40
- catch (e) {
41
- console.error("selectOptionsPerRowFilterFunction option has wrong signature for column : " + this.params.column.colDef.headerName + "\n"
42
- + " Requires signature (context:any, rowData: any, option: any) => boolean");
43
- this.selectOptionsPerRowFilterFunction = backup;
44
- this.using_selectOptionsPerRowFilterFunction = !!backup;
45
- }
46
- }
47
- this.context = this.params.column.colDef.context;
48
- this.fillGroupAttribute = this.params.column.colDef.fillGroupAttribute;
49
- this.fillAll = this.params.column.colDef.fillAll && ("" + this.params.column.colDef.fillAll).toLowerCase() !== "false";
50
- this.showFillButton = this.params.column.colDef.showFillButton && ("" + this.params.column.colDef.showFillButton).toLowerCase() !== "false";
51
- if (this._options
52
- && this.params.node
53
- && this.params.node.data
54
- && this.using_selectOptionsPerRowFilterFunction) {
55
- this._filteredOptions = this._options.filter((option) => {
56
- return this.selectOptionsPerRowFilterFunction(this.context, this.params.node.data, option);
57
- });
58
- }
59
- }
60
- if (this.params) {
61
- this.value = this.params.value ? "" + this.params.value : "";
62
- }
63
- if (this.showFillButton && !this.fillAll && (!this.fillGroupAttribute || this.fillGroupAttribute === "")) {
64
- throw new Error("Invalid state, cannot use fill button without specifying the fillGroupAttribute or fillAll.");
65
- }
66
- }
67
- ngOnDestroy() {
68
- if (this.params && this.params.node && this.params.node[(this.gridValueField + "_originalValue")]) {
69
- this.value = this.params.node[(this.gridValueField + "_originalValue")];
70
- }
71
- }
72
- onChange(event) {
73
- if (event && event.currentTarget) {
74
- if (this.params && this.params.node && !this.params.node[(this.gridValueField + "_originalValue")]) {
75
- this.params.node[(this.gridValueField + "_originalValue")] = this.value;
76
- }
77
- // This looks unnecessary, since this.value is linked to the value of the select component, but
78
- // because this also ends editing, it also queues the destruction of this component and the call to getValue.
79
- // The problem was that this.value isn't updated with the new value before this event fires,
80
- // so we need to update it manually here.
81
- this.value = event.currentTarget.value;
82
- this.params.node.setDataValue(this.gridValueField, this.value);
83
- }
84
- if (this.params) {
85
- // If the fill button, which is part of the editor, is activated, don't stop editing
86
- // immediately after making a selection.
87
- if (!this.showFillButton) {
88
- this.params.stopEditing();
89
- }
90
- }
91
- }
92
- getValue() {
93
- return this.value ? this.value : "";
94
- }
95
- isPopup() {
96
- return false;
97
- }
98
- onFillButtonClicked() {
99
- if (!this.fillAll && (!this.fillGroupAttribute || this.fillGroupAttribute === "")) {
100
- throw new Error('No column attribute "fillGroupAttribute" or "fillAll" specified. This is required to use the Fill functionality.');
101
- }
102
- if (this.params && this.params.column && this.params.column.gridApi && this.params.node && (this.fillAll || (this.fillGroupAttribute && this.fillGroupAttribute !== ""))) {
103
- let thisRowNode = this.params.node;
104
- //this.startSpinnerDialog();
105
- this.params.column.gridApi.forEachNodeAfterFilter((rowNode) => {
106
- if (rowNode && rowNode.data && thisRowNode && thisRowNode.data && (this.fillAll || rowNode.data[this.fillGroupAttribute] === thisRowNode.data[this.fillGroupAttribute])) {
107
- let spoofedEvent = {
108
- api: this.params.column.gridApi,
109
- colDef: this.params.column.colDef,
110
- column: this.params.column,
111
- columnApi: this.params.column.columnApi,
112
- context: undefined,
113
- data: rowNode.data,
114
- event: null,
115
- newValue: this.value,
116
- node: rowNode,
117
- oldValue: rowNode.data[this.gridValueField],
118
- rowIndex: rowNode.rowIndex,
119
- rowPinned: undefined,
120
- type: "cellValueChanged",
121
- value: this.value
122
- };
123
- rowNode.data[this.gridValueField] = this.value;
124
- rowNode.setDataValue(this.gridValueField, this.value);
125
- this.params.column.gridApi.dispatchEvent(spoofedEvent);
126
- }
127
- });
128
- this.params.column.gridApi.refreshCells();
129
- setTimeout(() => {
130
- //this.stopSpinnerDialogs();
131
- });
132
- }
133
- }
134
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SelectEditor, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
135
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: SelectEditor, selector: "ng-component", ngImport: i0, template: `
1
+ import { Component } from "@angular/core";
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/common";
4
+ import * as i2 from "@angular/forms";
5
+ //import {MatDialog, MatDialogConfig, MatDialogRef} from "@angular/material/dialog";
6
+ //import {SpinnerDialogComponent} from "../popup/spinner-dialog.component";
7
+ export class SelectEditor {
8
+ get options() {
9
+ if (this.using_selectOptionsPerRowFilterFunction) {
10
+ return this._filteredOptions;
11
+ }
12
+ else {
13
+ return this._options;
14
+ }
15
+ }
16
+ set options(value) {
17
+ this._options = value;
18
+ }
19
+ // private spinnerDialogRefs: MatDialogRef<SpinnerDialogComponent>[] = [];
20
+ constructor() {
21
+ this.using_selectOptionsPerRowFilterFunction = false;
22
+ this._spinnerDialogIsOpen = false;
23
+ }
24
+ agInit(params) {
25
+ this.params = params;
26
+ this.options = [];
27
+ this.optionsValueField = "";
28
+ this.optionsDisplayField = "";
29
+ if (this.params && this.params.column && this.params.column.colDef) {
30
+ this.gridValueField = this.params.column.colDef.field;
31
+ this.options = this.params.column.colDef.selectOptions;
32
+ this.optionsValueField = this.params.column.colDef.selectOptionsValueField;
33
+ this.optionsDisplayField = this.params.column.colDef.selectOptionsDisplayField;
34
+ if (this.params.column.colDef.selectOptionsPerRowFilterFunction) {
35
+ let backup = this.selectOptionsPerRowFilterFunction;
36
+ try {
37
+ this.selectOptionsPerRowFilterFunction = this.params.column.colDef.selectOptionsPerRowFilterFunction;
38
+ this.using_selectOptionsPerRowFilterFunction = !!this.selectOptionsPerRowFilterFunction;
39
+ }
40
+ catch (e) {
41
+ console.error("selectOptionsPerRowFilterFunction option has wrong signature for column : " + this.params.column.colDef.headerName + "\n"
42
+ + " Requires signature (context:any, rowData: any, option: any) => boolean");
43
+ this.selectOptionsPerRowFilterFunction = backup;
44
+ this.using_selectOptionsPerRowFilterFunction = !!backup;
45
+ }
46
+ }
47
+ this.context = this.params.column.colDef.context;
48
+ this.fillGroupAttribute = this.params.column.colDef.fillGroupAttribute;
49
+ this.fillAll = this.params.column.colDef.fillAll && ("" + this.params.column.colDef.fillAll).toLowerCase() !== "false";
50
+ this.showFillButton = this.params.column.colDef.showFillButton && ("" + this.params.column.colDef.showFillButton).toLowerCase() !== "false";
51
+ if (this._options
52
+ && this.params.node
53
+ && this.params.node.data
54
+ && this.using_selectOptionsPerRowFilterFunction) {
55
+ this._filteredOptions = this._options.filter((option) => {
56
+ return this.selectOptionsPerRowFilterFunction(this.context, this.params.node.data, option);
57
+ });
58
+ }
59
+ }
60
+ if (this.params) {
61
+ this.value = this.params.value ? "" + this.params.value : "";
62
+ }
63
+ if (this.showFillButton && !this.fillAll && (!this.fillGroupAttribute || this.fillGroupAttribute === "")) {
64
+ throw new Error("Invalid state, cannot use fill button without specifying the fillGroupAttribute or fillAll.");
65
+ }
66
+ }
67
+ ngOnDestroy() {
68
+ if (this.params && this.params.node && this.params.node[(this.gridValueField + "_originalValue")]) {
69
+ this.value = this.params.node[(this.gridValueField + "_originalValue")];
70
+ }
71
+ }
72
+ onChange(event) {
73
+ if (event && event.currentTarget) {
74
+ if (this.params && this.params.node && !this.params.node[(this.gridValueField + "_originalValue")]) {
75
+ this.params.node[(this.gridValueField + "_originalValue")] = this.value;
76
+ }
77
+ // This looks unnecessary, since this.value is linked to the value of the select component, but
78
+ // because this also ends editing, it also queues the destruction of this component and the call to getValue.
79
+ // The problem was that this.value isn't updated with the new value before this event fires,
80
+ // so we need to update it manually here.
81
+ this.value = event.currentTarget.value;
82
+ this.params.node.setDataValue(this.gridValueField, this.value);
83
+ }
84
+ if (this.params) {
85
+ // If the fill button, which is part of the editor, is activated, don't stop editing
86
+ // immediately after making a selection.
87
+ if (!this.showFillButton) {
88
+ this.params.stopEditing();
89
+ }
90
+ }
91
+ }
92
+ getValue() {
93
+ return this.value ? this.value : "";
94
+ }
95
+ isPopup() {
96
+ return false;
97
+ }
98
+ onFillButtonClicked() {
99
+ if (!this.fillAll && (!this.fillGroupAttribute || this.fillGroupAttribute === "")) {
100
+ throw new Error('No column attribute "fillGroupAttribute" or "fillAll" specified. This is required to use the Fill functionality.');
101
+ }
102
+ if (this.params && this.params.column && this.params.column.gridApi && this.params.node && (this.fillAll || (this.fillGroupAttribute && this.fillGroupAttribute !== ""))) {
103
+ let thisRowNode = this.params.node;
104
+ //this.startSpinnerDialog();
105
+ this.params.column.gridApi.forEachNodeAfterFilter((rowNode) => {
106
+ if (rowNode && rowNode.data && thisRowNode && thisRowNode.data && (this.fillAll || rowNode.data[this.fillGroupAttribute] === thisRowNode.data[this.fillGroupAttribute])) {
107
+ let spoofedEvent = {
108
+ api: this.params.column.gridApi,
109
+ colDef: this.params.column.colDef,
110
+ column: this.params.column,
111
+ columnApi: this.params.column.columnApi,
112
+ context: undefined,
113
+ data: rowNode.data,
114
+ event: null,
115
+ newValue: this.value,
116
+ node: rowNode,
117
+ oldValue: rowNode.data[this.gridValueField],
118
+ rowIndex: rowNode.rowIndex,
119
+ rowPinned: undefined,
120
+ type: "cellValueChanged",
121
+ value: this.value
122
+ };
123
+ rowNode.data[this.gridValueField] = this.value;
124
+ rowNode.setDataValue(this.gridValueField, this.value);
125
+ this.params.column.gridApi.dispatchEvent(spoofedEvent);
126
+ }
127
+ });
128
+ this.params.column.gridApi.refreshCells();
129
+ setTimeout(() => {
130
+ //this.stopSpinnerDialogs();
131
+ });
132
+ }
133
+ }
134
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: SelectEditor, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
135
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: SelectEditor, selector: "ng-component", ngImport: i0, template: `
136
136
  <div class="full-width full-height flex-column-container">
137
137
  <div class="full-height flex-stretch flex-row">
138
138
  <select class="full-width full-height" [(value)]="value" (change)="onChange($event)">
@@ -150,10 +150,10 @@ export class SelectEditor {
150
150
  <button class="full-height" (click)="onFillButtonClicked()">Fill</button>
151
151
  </div>
152
152
  </div>
153
- `, isInline: true, styles: [".full-width{width:100%}.full-height{height:100%}.flex-column-container{display:flex;flex-direction:row}.flex-row{display:flex}.flex-stretch{display:flex;flex:1}\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.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }] }); }
154
- }
155
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SelectEditor, decorators: [{
156
- type: Component,
153
+ `, isInline: true, styles: [".full-width{width:100%}.full-height{height:100%}.flex-column-container{display:flex;flex-direction:row}.flex-row{display:flex}.flex-stretch{display:flex;flex:1}\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.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }] }); }
154
+ }
155
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: SelectEditor, decorators: [{
156
+ type: Component,
157
157
  args: [{ template: `
158
158
  <div class="full-width full-height flex-column-container">
159
159
  <div class="full-height flex-stretch flex-row">
@@ -172,6 +172,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
172
172
  <button class="full-height" (click)="onFillButtonClicked()">Fill</button>
173
173
  </div>
174
174
  </div>
175
- `, styles: [".full-width{width:100%}.full-height{height:100%}.flex-column-container{display:flex;flex-direction:row}.flex-row{display:flex}.flex-stretch{display:flex;flex:1}\n"] }]
176
- }], ctorParameters: function () { return []; } });
177
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.editor.js","sourceRoot":"","sources":["../../../../projects/dictionary-editor/src/grid-editors/select.editor.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnDestroy} from \"@angular/core\";\r\nimport {ICellEditorAngularComp} from \"ag-grid-angular\";\r\n//import {MatDialog, MatDialogConfig, MatDialogRef} from \"@angular/material/dialog\";\r\n//import {SpinnerDialogComponent} from \"../popup/spinner-dialog.component\";\r\n\r\n@Component(\r\n  {\r\n    template:\r\n      `\r\n        <div class=\"full-width full-height flex-column-container\">\r\n          <div class=\"full-height flex-stretch flex-row\">\r\n            <select class=\"full-width full-height\" [(value)]=\"value\" (change)=\"onChange($event)\">\r\n              <option hidden>\r\n                Select An Option\r\n              </option>\r\n              <option\r\n                *ngFor=\"let option of options\"\r\n                value=\"{{option.hasOwnProperty(optionsValueField) ? option[optionsValueField] : (option.value) ? option.value : option }}\">\r\n                {{option.hasOwnProperty(optionsDisplayField) ? option[optionsDisplayField] : (option.display) ? option.display : option }}\r\n              </option>\r\n            </select>\r\n          </div>\r\n          <div *ngIf=\"showFillButton\" class=\"full-height flex-row button-container\">\r\n            <button class=\"full-height\" (click)=\"onFillButtonClicked()\">Fill</button>\r\n          </div>\r\n        </div>\r\n      `\r\n    ,\r\n    styles: [\r\n      `\r\n        .full-width {\r\n          width: 100%;\r\n        }\r\n\r\n        .full-height {\r\n          height: 100%;\r\n        }\r\n\r\n        .flex-column-container {\r\n          display: flex;\r\n          flex-direction: row;\r\n        }\r\n\r\n        .flex-row {\r\n          display: flex;\r\n        }\r\n\r\n        .flex-stretch {\r\n          display: flex;\r\n          flex: 1;\r\n        }\r\n      `\r\n    ]\r\n  }\r\n)\r\nexport class SelectEditor implements ICellEditorAngularComp, OnDestroy {\r\n    public params: any;\r\n    public value: any;\r\n    private _options: any[];\r\n    public get options(): any[] {\r\n        if (this.using_selectOptionsPerRowFilterFunction) {\r\n            return this._filteredOptions;\r\n        } else {\r\n            return this._options;\r\n        }\r\n    }\r\n    public set options(value: any[]) {\r\n        this._options = value;\r\n    }\r\n\r\n    public optionsValueField: string;\r\n    public optionsDisplayField: string;\r\n\r\n    // variables used for the optional per-row-filtering\r\n    public context: any;\r\n    protected using_selectOptionsPerRowFilterFunction: boolean = false;\r\n    protected selectOptionsPerRowFilterFunction: (context: any, rowData: any, option: any) => boolean;\r\n    private _filteredOptions: any[];\r\n\r\n\r\n\r\n    public gridValueField: string;\r\n\r\n    public showFillButton: boolean;\t\t// This represents whether the editor should show the \"Fill\" button,\r\n                                        // which is used to copy the value of this cell to other cells in this column in the grid\r\n    public fillGroupAttribute: string;\t\t// This attribute is used to specify which \"Group\" a particular\r\n                                            // row belongs to, which is used when the fill button is active.\r\n                                            // When clicked, the fill button will copy the data in that cell\r\n                                            // to the corresponding cells in rows of the same group.\r\n    public fillAll: boolean;                // If fillAll is set, all data will automatically be grouped together\r\n\r\n    private _spinnerDialogIsOpen: boolean = false;\r\n//    private spinnerDialogRefs: MatDialogRef<SpinnerDialogComponent>[] = [];\r\n\r\n    constructor(/*protected dialog: MatDialog*/) { }\r\n\r\n    agInit(params: any): void {\r\n        this.params = params;\r\n        this.options = [];\r\n        this.optionsValueField = \"\";\r\n        this.optionsDisplayField = \"\";\r\n\r\n        if (this.params && this.params.column && this.params.column.colDef) {\r\n            this.gridValueField = this.params.column.colDef.field;\r\n\r\n            this.options = this.params.column.colDef.selectOptions;\r\n            this.optionsValueField = this.params.column.colDef.selectOptionsValueField;\r\n            this.optionsDisplayField = this.params.column.colDef.selectOptionsDisplayField;\r\n\r\n            if (this.params.column.colDef.selectOptionsPerRowFilterFunction) {\r\n                let backup = this.selectOptionsPerRowFilterFunction;\r\n                try {\r\n                    this.selectOptionsPerRowFilterFunction = this.params.column.colDef.selectOptionsPerRowFilterFunction;\r\n                    this.using_selectOptionsPerRowFilterFunction = !!this.selectOptionsPerRowFilterFunction;\r\n                } catch (e) {\r\n                    console.error(\"selectOptionsPerRowFilterFunction option has wrong signature for column : \" + this.params.column.colDef.headerName + \"\\n\"\r\n                        + \"  Requires signature (context:any, rowData: any, option: any) => boolean\"\r\n                    );\r\n                    this.selectOptionsPerRowFilterFunction = backup;\r\n                    this.using_selectOptionsPerRowFilterFunction = !!backup;\r\n                }\r\n            }\r\n\r\n            this.context = this.params.column.colDef.context;\r\n\r\n            this.fillGroupAttribute = this.params.column.colDef.fillGroupAttribute;\r\n            this.fillAll = this.params.column.colDef.fillAll && (\"\" + this.params.column.colDef.fillAll).toLowerCase() !== \"false\";\r\n\r\n            this.showFillButton = this.params.column.colDef.showFillButton && (\"\" + this.params.column.colDef.showFillButton).toLowerCase() !== \"false\";\r\n\r\n            if (this._options\r\n                && this.params.node\r\n                && this.params.node.data\r\n                && this.using_selectOptionsPerRowFilterFunction) {\r\n\r\n                this._filteredOptions = this._options.filter((option: any) => {\r\n                    return this.selectOptionsPerRowFilterFunction(this.context, this.params.node.data, option);\r\n                });\r\n            }\r\n        }\r\n\r\n        if (this.params) {\r\n            this.value = this.params.value ? \"\" + this.params.value : \"\";\r\n        }\r\n\r\n        if (this.showFillButton && !this.fillAll && (!this.fillGroupAttribute || this.fillGroupAttribute === \"\")) {\r\n            throw new Error(\"Invalid state, cannot use fill button without specifying the fillGroupAttribute or fillAll.\");\r\n        }\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        if (this.params && this.params.node && this.params.node[(this.gridValueField + \"_originalValue\")]) {\r\n            this.value = this.params.node[(this.gridValueField + \"_originalValue\")];\r\n        }\r\n    }\r\n\r\n    onChange(event: any): void {\r\n        if (event && event.currentTarget) {\r\n\r\n            if (this.params && this.params.node && !this.params.node[(this.gridValueField + \"_originalValue\")]) {\r\n                this.params.node[(this.gridValueField + \"_originalValue\")] = this.value;\r\n            }\r\n\r\n            // This looks unnecessary, since this.value is linked to the value of the select component, but\r\n            // because this also ends editing, it also queues the destruction of this component and the call to getValue.\r\n            // The problem was that this.value isn't updated with the new value before this event fires,\r\n            // so we need to update it manually here.\r\n            this.value = event.currentTarget.value;\r\n            this.params.node.setDataValue(this.gridValueField, this.value);\r\n        }\r\n        if (this.params) {\r\n\r\n            //  If the fill button, which is part of the editor, is activated, don't stop editing\r\n            // immediately after making a selection.\r\n            if (!this.showFillButton) {\r\n                this.params.stopEditing();\r\n            }\r\n        }\r\n    }\r\n\r\n    getValue(): any {\r\n        return this.value ? this.value : \"\";\r\n    }\r\n\r\n    isPopup(): boolean {\r\n        return false;\r\n    }\r\n\r\n    onFillButtonClicked(): void {\r\n        if (!this.fillAll && (!this.fillGroupAttribute || this.fillGroupAttribute === \"\")) {\r\n            throw new Error('No column attribute \"fillGroupAttribute\" or \"fillAll\" specified. This is required to use the Fill functionality.');\r\n        }\r\n\r\n        if (this.params && this.params.column && this.params.column.gridApi && this.params.node && (this.fillAll || (this.fillGroupAttribute && this.fillGroupAttribute !== \"\"))) {\r\n            let thisRowNode = this.params.node;\r\n\r\n            //this.startSpinnerDialog();\r\n            this.params.column.gridApi.forEachNodeAfterFilter((rowNode) => {\r\n                if (rowNode && rowNode.data && thisRowNode && thisRowNode.data && (this.fillAll || rowNode.data[this.fillGroupAttribute] === thisRowNode.data[this.fillGroupAttribute])) {\r\n                    let spoofedEvent: any = {\r\n                        api: this.params.column.gridApi,\r\n                        colDef: this.params.column.colDef,\r\n                        column: this.params.column,\r\n                        columnApi: this.params.column.columnApi,\r\n                        context: undefined,\r\n                        data: rowNode.data,\r\n                        event: null,\r\n                        newValue: this.value,\r\n                        node: rowNode,\r\n                        oldValue: rowNode.data[this.gridValueField],\r\n                        rowIndex: rowNode.rowIndex,\r\n                        rowPinned: undefined,\r\n                        type: \"cellValueChanged\",\r\n                        value: this.value\r\n                    };\r\n\r\n                    rowNode.data[this.gridValueField] = this.value;\r\n                    rowNode.setDataValue(this.gridValueField, this.value);\r\n                    this.params.column.gridApi.dispatchEvent(spoofedEvent);\r\n                }\r\n            });\r\n\r\n            this.params.column.gridApi.refreshCells();\r\n            setTimeout(() => {\r\n                //this.stopSpinnerDialogs();\r\n            });\r\n        }\r\n    }\r\n\r\n\t/*\r\n    startSpinnerDialog(): MatDialogRef<SpinnerDialogComponent> {\r\n        if (this._spinnerDialogIsOpen) {\r\n            return null;\r\n        }\r\n\r\n        this._spinnerDialogIsOpen = true;\r\n\r\n        let configuration: MatDialogConfig = new MatDialogConfig();\r\n        configuration.data = {\r\n            message: \"Please wait...\",\r\n            strokeWidth: 3,\r\n            diameter: 30\r\n        };\r\n        configuration.width = \"13em\";\r\n        configuration.disableClose = true;\r\n\r\n        let dialogRef: MatDialogRef<SpinnerDialogComponent> = this.dialog.open(SpinnerDialogComponent, configuration);\r\n        dialogRef.afterClosed().subscribe(() => { this._spinnerDialogIsOpen = false; });\r\n        this.spinnerDialogRefs.push(dialogRef);\r\n\r\n        return dialogRef;\r\n    }\r\n\r\n    stopSpinnerDialogs(): void {\r\n        for (let dialogRef of this.spinnerDialogRefs) {\r\n            setTimeout(() => {\r\n                dialogRef.close();\r\n            });\r\n        }\r\n        this.spinnerDialogRefs = [];\r\n    }\r\n\t*/\r\n}\r\n"]}
175
+ `, styles: [".full-width{width:100%}.full-height{height:100%}.flex-column-container{display:flex;flex-direction:row}.flex-row{display:flex}.flex-stretch{display:flex;flex:1}\n"] }]
176
+ }], ctorParameters: () => [] });
177
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.editor.js","sourceRoot":"","sources":["../../../../projects/dictionary-editor/src/grid-editors/select.editor.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnDestroy} from \"@angular/core\";\r\nimport {ICellEditorAngularComp} from \"ag-grid-angular\";\r\n//import {MatDialog, MatDialogConfig, MatDialogRef} from \"@angular/material/dialog\";\r\n//import {SpinnerDialogComponent} from \"../popup/spinner-dialog.component\";\r\n\r\n@Component(\r\n  {\r\n    template:\r\n      `\r\n        <div class=\"full-width full-height flex-column-container\">\r\n          <div class=\"full-height flex-stretch flex-row\">\r\n            <select class=\"full-width full-height\" [(value)]=\"value\" (change)=\"onChange($event)\">\r\n              <option hidden>\r\n                Select An Option\r\n              </option>\r\n              <option\r\n                *ngFor=\"let option of options\"\r\n                value=\"{{option.hasOwnProperty(optionsValueField) ? option[optionsValueField] : (option.value) ? option.value : option }}\">\r\n                {{option.hasOwnProperty(optionsDisplayField) ? option[optionsDisplayField] : (option.display) ? option.display : option }}\r\n              </option>\r\n            </select>\r\n          </div>\r\n          <div *ngIf=\"showFillButton\" class=\"full-height flex-row button-container\">\r\n            <button class=\"full-height\" (click)=\"onFillButtonClicked()\">Fill</button>\r\n          </div>\r\n        </div>\r\n      `\r\n    ,\r\n    styles: [\r\n      `\r\n        .full-width {\r\n          width: 100%;\r\n        }\r\n\r\n        .full-height {\r\n          height: 100%;\r\n        }\r\n\r\n        .flex-column-container {\r\n          display: flex;\r\n          flex-direction: row;\r\n        }\r\n\r\n        .flex-row {\r\n          display: flex;\r\n        }\r\n\r\n        .flex-stretch {\r\n          display: flex;\r\n          flex: 1;\r\n        }\r\n      `\r\n    ]\r\n  }\r\n)\r\nexport class SelectEditor implements ICellEditorAngularComp, OnDestroy {\r\n    public params: any;\r\n    public value: any;\r\n    private _options: any[];\r\n    public get options(): any[] {\r\n        if (this.using_selectOptionsPerRowFilterFunction) {\r\n            return this._filteredOptions;\r\n        } else {\r\n            return this._options;\r\n        }\r\n    }\r\n    public set options(value: any[]) {\r\n        this._options = value;\r\n    }\r\n\r\n    public optionsValueField: string;\r\n    public optionsDisplayField: string;\r\n\r\n    // variables used for the optional per-row-filtering\r\n    public context: any;\r\n    protected using_selectOptionsPerRowFilterFunction: boolean = false;\r\n    protected selectOptionsPerRowFilterFunction: (context: any, rowData: any, option: any) => boolean;\r\n    private _filteredOptions: any[];\r\n\r\n\r\n\r\n    public gridValueField: string;\r\n\r\n    public showFillButton: boolean;\t\t// This represents whether the editor should show the \"Fill\" button,\r\n                                        // which is used to copy the value of this cell to other cells in this column in the grid\r\n    public fillGroupAttribute: string;\t\t// This attribute is used to specify which \"Group\" a particular\r\n                                            // row belongs to, which is used when the fill button is active.\r\n                                            // When clicked, the fill button will copy the data in that cell\r\n                                            // to the corresponding cells in rows of the same group.\r\n    public fillAll: boolean;                // If fillAll is set, all data will automatically be grouped together\r\n\r\n    private _spinnerDialogIsOpen: boolean = false;\r\n//    private spinnerDialogRefs: MatDialogRef<SpinnerDialogComponent>[] = [];\r\n\r\n    constructor(/*protected dialog: MatDialog*/) { }\r\n\r\n    agInit(params: any): void {\r\n        this.params = params;\r\n        this.options = [];\r\n        this.optionsValueField = \"\";\r\n        this.optionsDisplayField = \"\";\r\n\r\n        if (this.params && this.params.column && this.params.column.colDef) {\r\n            this.gridValueField = this.params.column.colDef.field;\r\n\r\n            this.options = this.params.column.colDef.selectOptions;\r\n            this.optionsValueField = this.params.column.colDef.selectOptionsValueField;\r\n            this.optionsDisplayField = this.params.column.colDef.selectOptionsDisplayField;\r\n\r\n            if (this.params.column.colDef.selectOptionsPerRowFilterFunction) {\r\n                let backup = this.selectOptionsPerRowFilterFunction;\r\n                try {\r\n                    this.selectOptionsPerRowFilterFunction = this.params.column.colDef.selectOptionsPerRowFilterFunction;\r\n                    this.using_selectOptionsPerRowFilterFunction = !!this.selectOptionsPerRowFilterFunction;\r\n                } catch (e) {\r\n                    console.error(\"selectOptionsPerRowFilterFunction option has wrong signature for column : \" + this.params.column.colDef.headerName + \"\\n\"\r\n                        + \"  Requires signature (context:any, rowData: any, option: any) => boolean\"\r\n                    );\r\n                    this.selectOptionsPerRowFilterFunction = backup;\r\n                    this.using_selectOptionsPerRowFilterFunction = !!backup;\r\n                }\r\n            }\r\n\r\n            this.context = this.params.column.colDef.context;\r\n\r\n            this.fillGroupAttribute = this.params.column.colDef.fillGroupAttribute;\r\n            this.fillAll = this.params.column.colDef.fillAll && (\"\" + this.params.column.colDef.fillAll).toLowerCase() !== \"false\";\r\n\r\n            this.showFillButton = this.params.column.colDef.showFillButton && (\"\" + this.params.column.colDef.showFillButton).toLowerCase() !== \"false\";\r\n\r\n            if (this._options\r\n                && this.params.node\r\n                && this.params.node.data\r\n                && this.using_selectOptionsPerRowFilterFunction) {\r\n\r\n                this._filteredOptions = this._options.filter((option: any) => {\r\n                    return this.selectOptionsPerRowFilterFunction(this.context, this.params.node.data, option);\r\n                });\r\n            }\r\n        }\r\n\r\n        if (this.params) {\r\n            this.value = this.params.value ? \"\" + this.params.value : \"\";\r\n        }\r\n\r\n        if (this.showFillButton && !this.fillAll && (!this.fillGroupAttribute || this.fillGroupAttribute === \"\")) {\r\n            throw new Error(\"Invalid state, cannot use fill button without specifying the fillGroupAttribute or fillAll.\");\r\n        }\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        if (this.params && this.params.node && this.params.node[(this.gridValueField + \"_originalValue\")]) {\r\n            this.value = this.params.node[(this.gridValueField + \"_originalValue\")];\r\n        }\r\n    }\r\n\r\n    onChange(event: any): void {\r\n        if (event && event.currentTarget) {\r\n\r\n            if (this.params && this.params.node && !this.params.node[(this.gridValueField + \"_originalValue\")]) {\r\n                this.params.node[(this.gridValueField + \"_originalValue\")] = this.value;\r\n            }\r\n\r\n            // This looks unnecessary, since this.value is linked to the value of the select component, but\r\n            // because this also ends editing, it also queues the destruction of this component and the call to getValue.\r\n            // The problem was that this.value isn't updated with the new value before this event fires,\r\n            // so we need to update it manually here.\r\n            this.value = event.currentTarget.value;\r\n            this.params.node.setDataValue(this.gridValueField, this.value);\r\n        }\r\n        if (this.params) {\r\n\r\n            //  If the fill button, which is part of the editor, is activated, don't stop editing\r\n            // immediately after making a selection.\r\n            if (!this.showFillButton) {\r\n                this.params.stopEditing();\r\n            }\r\n        }\r\n    }\r\n\r\n    getValue(): any {\r\n        return this.value ? this.value : \"\";\r\n    }\r\n\r\n    isPopup(): boolean {\r\n        return false;\r\n    }\r\n\r\n    onFillButtonClicked(): void {\r\n        if (!this.fillAll && (!this.fillGroupAttribute || this.fillGroupAttribute === \"\")) {\r\n            throw new Error('No column attribute \"fillGroupAttribute\" or \"fillAll\" specified. This is required to use the Fill functionality.');\r\n        }\r\n\r\n        if (this.params && this.params.column && this.params.column.gridApi && this.params.node && (this.fillAll || (this.fillGroupAttribute && this.fillGroupAttribute !== \"\"))) {\r\n            let thisRowNode = this.params.node;\r\n\r\n            //this.startSpinnerDialog();\r\n            this.params.column.gridApi.forEachNodeAfterFilter((rowNode) => {\r\n                if (rowNode && rowNode.data && thisRowNode && thisRowNode.data && (this.fillAll || rowNode.data[this.fillGroupAttribute] === thisRowNode.data[this.fillGroupAttribute])) {\r\n                    let spoofedEvent: any = {\r\n                        api: this.params.column.gridApi,\r\n                        colDef: this.params.column.colDef,\r\n                        column: this.params.column,\r\n                        columnApi: this.params.column.columnApi,\r\n                        context: undefined,\r\n                        data: rowNode.data,\r\n                        event: null,\r\n                        newValue: this.value,\r\n                        node: rowNode,\r\n                        oldValue: rowNode.data[this.gridValueField],\r\n                        rowIndex: rowNode.rowIndex,\r\n                        rowPinned: undefined,\r\n                        type: \"cellValueChanged\",\r\n                        value: this.value\r\n                    };\r\n\r\n                    rowNode.data[this.gridValueField] = this.value;\r\n                    rowNode.setDataValue(this.gridValueField, this.value);\r\n                    this.params.column.gridApi.dispatchEvent(spoofedEvent);\r\n                }\r\n            });\r\n\r\n            this.params.column.gridApi.refreshCells();\r\n            setTimeout(() => {\r\n                //this.stopSpinnerDialogs();\r\n            });\r\n        }\r\n    }\r\n\r\n\t/*\r\n    startSpinnerDialog(): MatDialogRef<SpinnerDialogComponent> {\r\n        if (this._spinnerDialogIsOpen) {\r\n            return null;\r\n        }\r\n\r\n        this._spinnerDialogIsOpen = true;\r\n\r\n        let configuration: MatDialogConfig = new MatDialogConfig();\r\n        configuration.data = {\r\n            message: \"Please wait...\",\r\n            strokeWidth: 3,\r\n            diameter: 30\r\n        };\r\n        configuration.width = \"13em\";\r\n        configuration.disableClose = true;\r\n\r\n        let dialogRef: MatDialogRef<SpinnerDialogComponent> = this.dialog.open(SpinnerDialogComponent, configuration);\r\n        dialogRef.afterClosed().subscribe(() => { this._spinnerDialogIsOpen = false; });\r\n        this.spinnerDialogRefs.push(dialogRef);\r\n\r\n        return dialogRef;\r\n    }\r\n\r\n    stopSpinnerDialogs(): void {\r\n        for (let dialogRef of this.spinnerDialogRefs) {\r\n            setTimeout(() => {\r\n                dialogRef.close();\r\n            });\r\n        }\r\n        this.spinnerDialogRefs = [];\r\n    }\r\n\t*/\r\n}\r\n"]}
@@ -1,36 +1,36 @@
1
- import { NgModule } from "@angular/core";
2
- import { CommonModule } from "@angular/common";
3
- import { FormsModule, ReactiveFormsModule } from "@angular/forms";
4
- import { SelectRenderer } from "./select.renderer";
5
- import { DateRenderer } from "./date.renderer";
6
- import * as i0 from "@angular/core";
7
- export class AgGridRendererModule {
8
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AgGridRendererModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
9
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: AgGridRendererModule, declarations: [SelectRenderer,
10
- DateRenderer], imports: [CommonModule,
11
- FormsModule,
12
- ReactiveFormsModule], exports: [SelectRenderer,
13
- DateRenderer] }); }
14
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AgGridRendererModule, imports: [CommonModule,
15
- FormsModule,
16
- ReactiveFormsModule] }); }
17
- }
18
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AgGridRendererModule, decorators: [{
19
- type: NgModule,
20
- args: [{
21
- imports: [
22
- CommonModule,
23
- FormsModule,
24
- ReactiveFormsModule,
25
- ],
26
- declarations: [
27
- SelectRenderer,
28
- DateRenderer
29
- ],
30
- exports: [
31
- SelectRenderer,
32
- DateRenderer
33
- ]
34
- }]
35
- }] });
36
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWctZ3JpZC1yZW5kZXJlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9kaWN0aW9uYXJ5LWVkaXRvci9zcmMvZ3JpZC1yZW5kZXJlcnMvYWctZ3JpZC1yZW5kZXJlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRWxFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNuRCxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7O0FBZ0I3QyxNQUFNLE9BQU8sb0JBQW9COytHQUFwQixvQkFBb0I7Z0hBQXBCLG9CQUFvQixpQkFSL0IsY0FBYztZQUNWLFlBQVksYUFOVixZQUFZO1lBQ1osV0FBVztZQUNYLG1CQUFtQixhQU96QixjQUFjO1lBQ1YsWUFBWTtnSEFHTCxvQkFBb0IsWUFiekIsWUFBWTtZQUNaLFdBQVc7WUFDWCxtQkFBbUI7OzRGQVdkLG9CQUFvQjtrQkFmaEMsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUU7d0JBQ0wsWUFBWTt3QkFDWixXQUFXO3dCQUNYLG1CQUFtQjtxQkFDdEI7b0JBQ0QsWUFBWSxFQUFFO3dCQUNoQixjQUFjO3dCQUNWLFlBQVk7cUJBQ2I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNYLGNBQWM7d0JBQ1YsWUFBWTtxQkFDYjtpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xyXG5cclxuaW1wb3J0IHsgU2VsZWN0UmVuZGVyZXIgfSBmcm9tIFwiLi9zZWxlY3QucmVuZGVyZXJcIjtcclxuaW1wb3J0IHtEYXRlUmVuZGVyZXJ9IGZyb20gXCIuL2RhdGUucmVuZGVyZXJcIjtcclxuQE5nTW9kdWxlKHtcclxuICAgIGltcG9ydHM6IFtcclxuICAgICAgICBDb21tb25Nb2R1bGUsXHJcbiAgICAgICAgRm9ybXNNb2R1bGUsXHJcbiAgICAgICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcclxuICAgIF0sXHJcbiAgICBkZWNsYXJhdGlvbnM6IFtcclxuXHRcdFNlbGVjdFJlbmRlcmVyLFxyXG4gICAgICBEYXRlUmVuZGVyZXJcclxuICAgIF0sXHJcbiAgICBleHBvcnRzOiBbXHJcblx0XHRTZWxlY3RSZW5kZXJlcixcclxuICAgICAgRGF0ZVJlbmRlcmVyXHJcbiAgICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBZ0dyaWRSZW5kZXJlck1vZHVsZSB7IH1cclxuIl19
1
+ import { NgModule } from "@angular/core";
2
+ import { CommonModule } from "@angular/common";
3
+ import { FormsModule, ReactiveFormsModule } from "@angular/forms";
4
+ import { SelectRenderer } from "./select.renderer";
5
+ import { DateRenderer } from "./date.renderer";
6
+ import * as i0 from "@angular/core";
7
+ export class AgGridRendererModule {
8
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: AgGridRendererModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
9
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.1.2", ngImport: i0, type: AgGridRendererModule, declarations: [SelectRenderer,
10
+ DateRenderer], imports: [CommonModule,
11
+ FormsModule,
12
+ ReactiveFormsModule], exports: [SelectRenderer,
13
+ DateRenderer] }); }
14
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: AgGridRendererModule, imports: [CommonModule,
15
+ FormsModule,
16
+ ReactiveFormsModule] }); }
17
+ }
18
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: AgGridRendererModule, decorators: [{
19
+ type: NgModule,
20
+ args: [{
21
+ imports: [
22
+ CommonModule,
23
+ FormsModule,
24
+ ReactiveFormsModule,
25
+ ],
26
+ declarations: [
27
+ SelectRenderer,
28
+ DateRenderer
29
+ ],
30
+ exports: [
31
+ SelectRenderer,
32
+ DateRenderer
33
+ ]
34
+ }]
35
+ }] });
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWctZ3JpZC1yZW5kZXJlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9kaWN0aW9uYXJ5LWVkaXRvci9zcmMvZ3JpZC1yZW5kZXJlcnMvYWctZ3JpZC1yZW5kZXJlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRWxFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNuRCxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7O0FBZ0I3QyxNQUFNLE9BQU8sb0JBQW9COzhHQUFwQixvQkFBb0I7K0dBQXBCLG9CQUFvQixpQkFSL0IsY0FBYztZQUNWLFlBQVksYUFOVixZQUFZO1lBQ1osV0FBVztZQUNYLG1CQUFtQixhQU96QixjQUFjO1lBQ1YsWUFBWTsrR0FHTCxvQkFBb0IsWUFiekIsWUFBWTtZQUNaLFdBQVc7WUFDWCxtQkFBbUI7OzJGQVdkLG9CQUFvQjtrQkFmaEMsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUU7d0JBQ0wsWUFBWTt3QkFDWixXQUFXO3dCQUNYLG1CQUFtQjtxQkFDdEI7b0JBQ0QsWUFBWSxFQUFFO3dCQUNoQixjQUFjO3dCQUNWLFlBQVk7cUJBQ2I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNYLGNBQWM7d0JBQ1YsWUFBWTtxQkFDYjtpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xyXG5cclxuaW1wb3J0IHsgU2VsZWN0UmVuZGVyZXIgfSBmcm9tIFwiLi9zZWxlY3QucmVuZGVyZXJcIjtcclxuaW1wb3J0IHtEYXRlUmVuZGVyZXJ9IGZyb20gXCIuL2RhdGUucmVuZGVyZXJcIjtcclxuQE5nTW9kdWxlKHtcclxuICAgIGltcG9ydHM6IFtcclxuICAgICAgICBDb21tb25Nb2R1bGUsXHJcbiAgICAgICAgRm9ybXNNb2R1bGUsXHJcbiAgICAgICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcclxuICAgIF0sXHJcbiAgICBkZWNsYXJhdGlvbnM6IFtcclxuXHRcdFNlbGVjdFJlbmRlcmVyLFxyXG4gICAgICBEYXRlUmVuZGVyZXJcclxuICAgIF0sXHJcbiAgICBleHBvcnRzOiBbXHJcblx0XHRTZWxlY3RSZW5kZXJlcixcclxuICAgICAgRGF0ZVJlbmRlcmVyXHJcbiAgICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBZ0dyaWRSZW5kZXJlck1vZHVsZSB7IH1cclxuIl19