@wemake4u/form-player-se 1.0.3 → 1.0.5
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/directives/date.directive.mjs +93 -0
- package/esm2022/lib/directives/disable-form.directive.mjs +42 -0
- package/esm2022/lib/directives/disable.directive.mjs +39 -6
- package/esm2022/lib/directives/number.directive.mjs +111 -0
- package/esm2022/lib/dynamic-fields/dynamic-fields.component.mjs +17 -8
- package/esm2022/lib/dynamic-form/dynamic-form.component.mjs +70 -58
- package/esm2022/lib/locale/locale-it.mjs +2 -1
- package/esm2022/lib/utils/gridCells.mjs +10 -7
- package/esm2022/lib/utils/gridUtils.mjs +75 -0
- package/esm2022/lib/utils/groupByRow.mjs +2 -1
- package/fesm2022/wemake4u-form-player-se.mjs +455 -90
- package/fesm2022/wemake4u-form-player-se.mjs.map +1 -1
- package/lib/directives/date.directive.d.ts +8 -0
- package/lib/directives/disable-form.directive.d.ts +17 -0
- package/lib/directives/disable.directive.d.ts +11 -3
- package/lib/directives/number.directive.d.ts +16 -0
- package/lib/dynamic-fields/dynamic-fields.component.d.ts +1 -0
- package/lib/dynamic-form/dynamic-form.component.d.ts +8 -5
- package/lib/locale/locale-it.d.ts +1 -0
- package/lib/utils/gridCells.d.ts +34 -0
- package/lib/utils/gridUtils.d.ts +4 -0
- package/lib/utils/groupByRow.d.ts +1 -0
- package/package.json +1 -1
|
@@ -8,10 +8,11 @@ export const Texts = {
|
|
|
8
8
|
PreviousSection: "Sezione precedente",
|
|
9
9
|
NextSection: "Sezione successiva",
|
|
10
10
|
Show: "Visualizza",
|
|
11
|
+
Remove: "Rimuovi",
|
|
11
12
|
Close: "Chiudi",
|
|
12
13
|
Name: "Nome",
|
|
13
14
|
Size: "Dimensione",
|
|
14
15
|
Type: "Tipo",
|
|
15
16
|
Actions: "Azioni"
|
|
16
17
|
};
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jYWxlLWl0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXNpcmlvL3NyYy9saWIvbG9jYWxlL2xvY2FsZS1pdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQUMsTUFBTSxLQUFLLEdBQUc7SUFDbkIsWUFBWSxFQUFFLHVCQUF1QjtJQUNyQyxNQUFNLEVBQUUsUUFBUTtJQUNoQixVQUFVLEVBQUUsbUJBQW1CO0lBQy9CLFdBQVcsRUFBRSxpQkFBaUI7SUFDOUIsT0FBTyxFQUFFLFVBQVU7SUFDbkIsVUFBVSxFQUFFLFNBQVM7SUFDckIsZUFBZSxFQUFFLG9CQUFvQjtJQUNyQyxXQUFXLEVBQUUsb0JBQW9CO0lBQ2pDLElBQUksRUFBRSxZQUFZO0lBQ2xCLE1BQU0sRUFBRSxTQUFTO0lBQ2pCLEtBQUssRUFBRSxRQUFRO0lBQ2YsSUFBSSxFQUFFLE1BQU07SUFDWixJQUFJLEVBQUUsWUFBWTtJQUNsQixJQUFJLEVBQUUsTUFBTTtJQUNaLE9BQU8sRUFBRSxRQUFRO0NBQ2xCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgVGV4dHMgPSB7XHJcbiAgVHlwZVRvU2VhcmNoOiBcIkRpZ2l0YSBwZXIgY2VyY2FyZS4uLlwiLFxyXG4gIFVwbG9hZDogXCJVcGxvYWRcIixcclxuICBTY3JvbGxMZWZ0OiBcIlNjb3JyaSBhIHNpbmlzdHJhXCIsXHJcbiAgU2Nyb2xsUmlnaHQ6IFwiU2NvcnJpIGEgZGVzdHJhXCIsXHJcbiAgQWRkSXRlbTogXCJBZ2dpdW5naVwiLFxyXG4gIFJlbW92ZUl0ZW06IFwiUmltdW92aVwiLFxyXG4gIFByZXZpb3VzU2VjdGlvbjogXCJTZXppb25lIHByZWNlZGVudGVcIixcclxuICBOZXh0U2VjdGlvbjogXCJTZXppb25lIHN1Y2Nlc3NpdmFcIixcclxuICBTaG93OiBcIlZpc3VhbGl6emFcIixcclxuICBSZW1vdmU6IFwiUmltdW92aVwiLFxyXG4gIENsb3NlOiBcIkNoaXVkaVwiLFxyXG4gIE5hbWU6IFwiTm9tZVwiLFxyXG4gIFNpemU6IFwiRGltZW5zaW9uZVwiLFxyXG4gIFR5cGU6IFwiVGlwb1wiLFxyXG4gIEFjdGlvbnM6IFwiQXppb25pXCJcclxufTtcclxuIl19
|
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
import { Component } from '@angular/core';
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
3
|
import { SirioButtonComponent } from 'ngx-sirio-lib';
|
|
4
|
+
import { Texts } from '../locale/locale-it';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
import * as i1 from "../services/programmability.service";
|
|
6
7
|
import * as i2 from "@angular/common";
|
|
7
8
|
export class ObjectURLRendererComponent {
|
|
8
9
|
params;
|
|
10
|
+
Texts = Texts;
|
|
9
11
|
agInit(params) {
|
|
10
12
|
this.params = params;
|
|
11
13
|
}
|
|
@@ -20,14 +22,15 @@ export class ObjectURLRendererComponent {
|
|
|
20
22
|
return false;
|
|
21
23
|
}
|
|
22
24
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ObjectURLRendererComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
23
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ObjectURLRendererComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<a aria-label=\"
|
|
25
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ObjectURLRendererComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<a [attr.aria-label]=\"Texts.Show\" title=\"{{ Texts.Show }}\" href=\"javascript:void(0)\" (click)=\"onClick($event)\">\r\n <span class=\"fas fa-paperclip\"></span>\r\n</a>\r\n" });
|
|
24
26
|
}
|
|
25
27
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ObjectURLRendererComponent, decorators: [{
|
|
26
28
|
type: Component,
|
|
27
|
-
args: [{ standalone: true, template: "<a aria-label=\"
|
|
29
|
+
args: [{ standalone: true, template: "<a [attr.aria-label]=\"Texts.Show\" title=\"{{ Texts.Show }}\" href=\"javascript:void(0)\" (click)=\"onClick($event)\">\r\n <span class=\"fas fa-paperclip\"></span>\r\n</a>\r\n" }]
|
|
28
30
|
}] });
|
|
29
31
|
export class DeleteRowCellRenderer {
|
|
30
32
|
params;
|
|
33
|
+
Texts = Texts;
|
|
31
34
|
agInit(params) {
|
|
32
35
|
this.params = params;
|
|
33
36
|
}
|
|
@@ -40,11 +43,11 @@ export class DeleteRowCellRenderer {
|
|
|
40
43
|
return false;
|
|
41
44
|
}
|
|
42
45
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DeleteRowCellRenderer, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
43
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DeleteRowCellRenderer, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<
|
|
46
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DeleteRowCellRenderer, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<a [attr.aria-label]=\"Texts.Remove\" title=\"{{ Texts.Remove }}\" href=\"javascript:void(0)\" (click)=\"onClick($event)\">\r\n <span class=\"fas fa-trash\"></span>\r\n</a>\r\n" });
|
|
44
47
|
}
|
|
45
48
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DeleteRowCellRenderer, decorators: [{
|
|
46
49
|
type: Component,
|
|
47
|
-
args: [{ standalone: true, template: "<
|
|
50
|
+
args: [{ standalone: true, template: "<a [attr.aria-label]=\"Texts.Remove\" title=\"{{ Texts.Remove }}\" href=\"javascript:void(0)\" (click)=\"onClick($event)\">\r\n <span class=\"fas fa-trash\"></span>\r\n</a>\r\n" }]
|
|
48
51
|
}] });
|
|
49
52
|
export class ActionsCellRenderer {
|
|
50
53
|
programmability;
|
|
@@ -90,12 +93,12 @@ export class ActionsCellRenderer {
|
|
|
90
93
|
return this.params.formGroup;
|
|
91
94
|
}
|
|
92
95
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ActionsCellRenderer, deps: [{ token: i1.ProgrammabilityService }], target: i0.ɵɵFactoryTarget.Component });
|
|
93
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ActionsCellRenderer, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<ng-container *ngFor=\"let action of params.component.actions\">\r\n
|
|
96
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ActionsCellRenderer, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<div class=\"btn-small-group\">\r\n <ng-container *ngFor=\"let action of params.component.actions\">\r\n <ngx-sirio-button class=\"btn-small\"\r\n [ariaLabel]=\"evaluateString(action.label)\"\r\n [title]=\"evaluateString(action.label)\"\r\n [color]=\"null\"\r\n [disabled]=\"evaluateBoolean(action.disabled)\"\r\n (clickEvent)=\"clickButton(action, $event)\"\r\n [icon]=\"evaluateString(action.icon)\">\r\n </ngx-sirio-button>\r\n </ng-container>\r\n</div>\r\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: SirioButtonComponent, selector: "ngx-sirio-button", inputs: ["ariaExpanded", "ariaControls", "ariaActivedescendant", "ariaHaspopup", "ariaLabel", "ariaRequired", "ariaInvalid", "ariaDescribedby", "icon", "title", "role", "color", "isFloating", "isExtended", "isLight", "isSmall", "disabled", "isDropdown", "type", "dismissType", "isBtnBlock"], outputs: ["clickEvent", "focusEvent", "blurEvent"] }] });
|
|
94
97
|
}
|
|
95
98
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ActionsCellRenderer, decorators: [{
|
|
96
99
|
type: Component,
|
|
97
100
|
args: [{ standalone: true, imports: [
|
|
98
101
|
CommonModule, SirioButtonComponent
|
|
99
|
-
], template: "<ng-container *ngFor=\"let action of params.component.actions\">\r\n
|
|
102
|
+
], template: "<div class=\"btn-small-group\">\r\n <ng-container *ngFor=\"let action of params.component.actions\">\r\n <ngx-sirio-button class=\"btn-small\"\r\n [ariaLabel]=\"evaluateString(action.label)\"\r\n [title]=\"evaluateString(action.label)\"\r\n [color]=\"null\"\r\n [disabled]=\"evaluateBoolean(action.disabled)\"\r\n (clickEvent)=\"clickButton(action, $event)\"\r\n [icon]=\"evaluateString(action.icon)\">\r\n </ngx-sirio-button>\r\n </ng-container>\r\n</div>\r\n" }]
|
|
100
103
|
}], ctorParameters: () => [{ type: i1.ProgrammabilityService }] });
|
|
101
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
104
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gridCells.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/utils/gridCells.ts","../../../../../projects/ngx-sirio/src/lib/utils/cell-templates/objectUrl.component.html","../../../../../projects/ngx-sirio/src/lib/utils/cell-templates/delete.component.html","../../../../../projects/ngx-sirio/src/lib/utils/cell-templates/actions.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ICellRendererAngularComp } from 'ag-grid-angular';\r\nimport { ICellRendererParams } from 'ag-grid-community';\r\nimport { SirioButtonComponent } from 'ngx-sirio-lib';\r\nimport { ProgrammabilityService, EvaluateOptions } from '../services/programmability.service';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { ProxyOptions } from '../services/proxy.service';\r\n\r\nimport { Texts } from '../locale/locale-it';\r\n\r\n@Component({\r\n  templateUrl: './cell-templates/objectUrl.component.html',\r\n  standalone: true\r\n})\r\nexport class ObjectURLRendererComponent implements ICellRendererAngularComp {\r\n  params!: ICellRendererParams;\r\n\r\n  Texts = Texts;\r\n\r\n  agInit(params: ICellRendererParams): void {\r\n    this.params = params;\r\n  }\r\n\r\n  onClick(event: Event) {\r\n    const fileURL = URL.createObjectURL(this.params.data);\r\n    window.open(fileURL, '_blank');\r\n    setTimeout(() => {\r\n      URL.revokeObjectURL(fileURL);\r\n    }, 1000);\r\n  }\r\n\r\n  refresh(): boolean {\r\n    return false;\r\n  }\r\n}\r\n\r\n@Component({\r\n  templateUrl: './cell-templates/delete.component.html',\r\n  standalone: true\r\n})\r\nexport class DeleteRowCellRenderer implements ICellRendererAngularComp {\r\n  params: any;\r\n\r\n  Texts = Texts;\r\n\r\n  agInit(params: any): void {\r\n    this.params = params;\r\n  }\r\n\r\n  onClick(event: Event) {\r\n\r\n    if ('remove' in this.params.data && typeof this.params.data.remove === 'function') {\r\n      this.params.data.remove();\r\n    }\r\n  }\r\n\r\n  refresh(): boolean {\r\n    return false;\r\n  }\r\n}\r\n\r\n@Component({\r\n  templateUrl: './cell-templates/actions.component.html',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule, SirioButtonComponent\r\n  ]\r\n})\r\nexport class ActionsCellRenderer implements ICellRendererAngularComp {\r\n\r\n  constructor(private programmability: ProgrammabilityService) { }\r\n\r\n  params: any;\r\n\r\n  agInit(params: any): void {\r\n    this.params = params;\r\n  }\r\n\r\n  refresh(): boolean {\r\n    return false;\r\n  }\r\n\r\n  evaluateBoolean(value: boolean | string | null): boolean | null {\r\n\r\n    const options: EvaluateOptions = {\r\n      proxyFn: (options: ProxyOptions) => {\r\n        options.extend[\"getParams\"] = () => this.params;\r\n        options.extend[\"getData\"] = () => this.getData();\r\n      }\r\n    }\r\n\r\n    return this.programmability.evaluateBoolean(this.getFormGroup(), value, options);\r\n  }\r\n\r\n  evaluateString(value: string | null): string {\r\n    return this.programmability.evaluateString(this.getFormGroup(), value);\r\n  }\r\n\r\n  clickButton(action: any, event: any) {\r\n    if (action.click) {\r\n\r\n      const options: EvaluateOptions = {\r\n        cacheable: false,\r\n        proxyFn: (options: ProxyOptions) => {\r\n          options.extend[\"getParams\"] = () => this.params;\r\n          options.extend[\"getAction\"] = () => action;\r\n          options.extend[\"getData\"] = () => this.getData();\r\n        }\r\n      }\r\n\r\n      return this.programmability.evaluate(this.getFormGroup(), action.click, options);\r\n    }    \r\n  }\r\n\r\n  private getData(): any {\r\n    return this.params.data;\r\n\r\n  }\r\n\r\n  private getFormGroup(): FormGroup {\r\n    return this.params.formGroup as FormGroup;\r\n  }\r\n}\r\n\r\n","<a [attr.aria-label]=\"Texts.Show\" title=\"{{ Texts.Show }}\" href=\"javascript:void(0)\" (click)=\"onClick($event)\">\r\n  <span class=\"fas fa-paperclip\"></span>\r\n</a>\r\n","<a [attr.aria-label]=\"Texts.Remove\" title=\"{{ Texts.Remove }}\" href=\"javascript:void(0)\" (click)=\"onClick($event)\">\r\n  <span class=\"fas fa-trash\"></span>\r\n</a>\r\n","<div class=\"btn-small-group\">\r\n  <ng-container *ngFor=\"let action of params.component.actions\">\r\n    <ngx-sirio-button class=\"btn-small\"\r\n                      [ariaLabel]=\"evaluateString(action.label)\"\r\n                      [title]=\"evaluateString(action.label)\"\r\n                      [color]=\"null\"\r\n                      [disabled]=\"evaluateBoolean(action.disabled)\"\r\n                      (clickEvent)=\"clickButton(action, $event)\"\r\n                      [icon]=\"evaluateString(action.icon)\">\r\n    </ngx-sirio-button>\r\n  </ng-container>\r\n</div>\r\n"]}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
const GRID_CELL_CLASSNAME = "ag-cell";
|
|
2
|
+
function getEventPath(event) {
|
|
3
|
+
const path = [];
|
|
4
|
+
let currentTarget = event.target;
|
|
5
|
+
while (currentTarget) {
|
|
6
|
+
path.push(currentTarget);
|
|
7
|
+
currentTarget = currentTarget.parentElement;
|
|
8
|
+
}
|
|
9
|
+
return path;
|
|
10
|
+
}
|
|
11
|
+
function getAllFocusableElementsOf(el) {
|
|
12
|
+
return Array.from(el.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])')).filter((focusableEl) => {
|
|
13
|
+
return focusableEl.tabIndex !== -1 && !focusableEl.hasAttribute('disabled');
|
|
14
|
+
});
|
|
15
|
+
}
|
|
16
|
+
export const GridUtils = {
|
|
17
|
+
navigateInsideCell({ event }) {
|
|
18
|
+
const { key, shiftKey } = event;
|
|
19
|
+
const path = getEventPath(event);
|
|
20
|
+
const isTabForward = key === "Tab" && shiftKey === false;
|
|
21
|
+
const isTabBackward = key === "Tab" && shiftKey === true;
|
|
22
|
+
let suppressEvent = false;
|
|
23
|
+
// Handle cell children tabbing
|
|
24
|
+
if (isTabForward || isTabBackward) {
|
|
25
|
+
const eGridCell = path.find((el) => {
|
|
26
|
+
if (el.classList === undefined)
|
|
27
|
+
return false;
|
|
28
|
+
return el.classList.contains(GRID_CELL_CLASSNAME);
|
|
29
|
+
});
|
|
30
|
+
if (!eGridCell) {
|
|
31
|
+
return suppressEvent;
|
|
32
|
+
}
|
|
33
|
+
const focusableChildrenElements = getAllFocusableElementsOf(eGridCell);
|
|
34
|
+
const lastCellChildEl = focusableChildrenElements[focusableChildrenElements.length - 1];
|
|
35
|
+
const firstCellChildEl = focusableChildrenElements[0];
|
|
36
|
+
// Suppress keyboard event if tabbing forward within the cell and the current focused element is not the last child
|
|
37
|
+
if (focusableChildrenElements.length === 0) {
|
|
38
|
+
return false;
|
|
39
|
+
}
|
|
40
|
+
const currentIndex = focusableChildrenElements.indexOf(document.activeElement);
|
|
41
|
+
if (isTabForward) {
|
|
42
|
+
const isLastChildFocused = lastCellChildEl && document.activeElement === lastCellChildEl;
|
|
43
|
+
if (!isLastChildFocused) {
|
|
44
|
+
suppressEvent = true;
|
|
45
|
+
if (currentIndex !== -1 || document.activeElement === eGridCell) {
|
|
46
|
+
event.preventDefault();
|
|
47
|
+
focusableChildrenElements[currentIndex + 1].focus();
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
// Suppress keyboard event if tabbing backwards within the cell, and the current focused element is not the first child
|
|
52
|
+
else {
|
|
53
|
+
const cellHasFocusedChildren = eGridCell.contains(document.activeElement) &&
|
|
54
|
+
eGridCell !== document.activeElement;
|
|
55
|
+
// Manually set focus to the last child element if cell doesn't have focused children
|
|
56
|
+
if (!cellHasFocusedChildren) {
|
|
57
|
+
lastCellChildEl.focus();
|
|
58
|
+
// Cancel keyboard press, so that it doesn't focus on the last child and then pass through the keyboard press to
|
|
59
|
+
// move to the 2nd last child element
|
|
60
|
+
event.preventDefault();
|
|
61
|
+
}
|
|
62
|
+
const isFirstChildFocused = firstCellChildEl && document.activeElement === firstCellChildEl;
|
|
63
|
+
if (!isFirstChildFocused) {
|
|
64
|
+
suppressEvent = true;
|
|
65
|
+
if (currentIndex !== -1 || document.activeElement === eGridCell) {
|
|
66
|
+
event.preventDefault();
|
|
67
|
+
focusableChildrenElements[currentIndex - 1].focus();
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
return suppressEvent;
|
|
73
|
+
},
|
|
74
|
+
};
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gridUtils.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/utils/gridUtils.ts"],"names":[],"mappings":"AAEA,MAAM,mBAAmB,GAAG,SAAS,CAAC;AAEtC,SAAS,YAAY,CAAC,KAAY;IAChC,MAAM,IAAI,GAAkB,EAAE,CAAC;IAC/B,IAAI,aAAa,GAAQ,KAAK,CAAC,MAAM,CAAC;IACtC,OAAO,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACzB,aAAa,GAAG,aAAa,CAAC,aAAa,CAAC;IAC9C,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAED,SAAS,yBAAyB,CAAC,EAAe;IAChD,OAAO,KAAK,CAAC,IAAI,CACf,EAAE,CAAC,gBAAgB,CACjB,0EAA0E,CAC3E,CACF,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,EAAE;QACvB,OAAO,WAAW,CAAC,QAAQ,KAAK,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;IAC9E,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,CAAC,MAAM,SAAS,GAAG;IACvB,kBAAkB,CAAC,EAAE,KAAK,EAAoC;QAC5D,MAAM,EAAE,GAAG,EAAE,QAAQ,EAAE,GAAG,KAAK,CAAC;QAChC,MAAM,IAAI,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC;QACjC,MAAM,YAAY,GAAG,GAAG,KAAK,KAAK,IAAI,QAAQ,KAAK,KAAK,CAAC;QACzD,MAAM,aAAa,GAAG,GAAG,KAAK,KAAK,IAAI,QAAQ,KAAK,IAAI,CAAC;QACzD,IAAI,aAAa,GAAG,KAAK,CAAC;QAC1B,+BAA+B;QAC/B,IAAI,YAAY,IAAI,aAAa,EAAE,CAAC;YAClC,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE;gBACjC,IAAI,EAAE,CAAC,SAAS,KAAK,SAAS;oBAAE,OAAO,KAAK,CAAC;gBAC7C,OAAO,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,mBAAmB,CAAC,CAAC;YACpD,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,SAAS,EAAE,CAAC;gBACf,OAAO,aAAa,CAAC;YACvB,CAAC;YACD,MAAM,yBAAyB,GAAG,yBAAyB,CAAC,SAAS,CAAC,CAAC;YACvE,MAAM,eAAe,GACnB,yBAAyB,CAAC,yBAAyB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;YAClE,MAAM,gBAAgB,GAAG,yBAAyB,CAAC,CAAC,CAAC,CAAC;YACtD,mHAAmH;YACnH,IAAI,yBAAyB,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC3C,OAAO,KAAK,CAAC;YACf,CAAC;YACD,MAAM,YAAY,GAAG,yBAAyB,CAAC,OAAO,CACpD,QAAQ,CAAC,aAA4B,CACtC,CAAC;YACF,IAAI,YAAY,EAAE,CAAC;gBACjB,MAAM,kBAAkB,GACtB,eAAe,IAAI,QAAQ,CAAC,aAAa,KAAK,eAAe,CAAC;gBAChE,IAAI,CAAC,kBAAkB,EAAE,CAAC;oBACxB,aAAa,GAAG,IAAI,CAAC;oBACrB,IAAI,YAAY,KAAK,CAAC,CAAC,IAAI,QAAQ,CAAC,aAAa,KAAK,SAAS,EAAE,CAAC;wBAChE,KAAK,CAAC,cAAc,EAAE,CAAC;wBACvB,yBAAyB,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC;oBACtD,CAAC;gBACH,CAAC;YACH,CAAC;YACD,uHAAuH;iBAClH,CAAC;gBACJ,MAAM,sBAAsB,GAC1B,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,aAAa,CAAC;oBAC1C,SAAS,KAAK,QAAQ,CAAC,aAAa,CAAC;gBACvC,qFAAqF;gBACrF,IAAI,CAAC,sBAAsB,EAAE,CAAC;oBAC5B,eAAe,CAAC,KAAK,EAAE,CAAC;oBACxB,gHAAgH;oBAChH,qCAAqC;oBACrC,KAAK,CAAC,cAAc,EAAE,CAAC;gBACzB,CAAC;gBACD,MAAM,mBAAmB,GACvB,gBAAgB,IAAI,QAAQ,CAAC,aAAa,KAAK,gBAAgB,CAAC;gBAClE,IAAI,CAAC,mBAAmB,EAAE,CAAC;oBACzB,aAAa,GAAG,IAAI,CAAC;oBACrB,IAAI,YAAY,KAAK,CAAC,CAAC,IAAI,QAAQ,CAAC,aAAa,KAAK,SAAS,EAAE,CAAC;wBAChE,KAAK,CAAC,cAAc,EAAE,CAAC;wBACvB,yBAAyB,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC;oBACtD,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC;QACD,OAAO,aAAa,CAAC;IACvB,CAAC;CAGF,CAAC","sourcesContent":["import { SuppressKeyboardEventParams } from 'ag-grid-community';\r\n\r\nconst GRID_CELL_CLASSNAME = \"ag-cell\";\r\n\r\nfunction getEventPath(event: Event): HTMLElement[] {\r\n  const path: HTMLElement[] = [];\r\n  let currentTarget: any = event.target;\r\n  while (currentTarget) {\r\n    path.push(currentTarget);\r\n    currentTarget = currentTarget.parentElement;\r\n  }\r\n  return path;\r\n}\r\n\r\nfunction getAllFocusableElementsOf(el: HTMLElement) {\r\n  return Array.from<HTMLElement>(\r\n    el.querySelectorAll(\r\n      'button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"])',\r\n    )\r\n  ).filter((focusableEl) => {\r\n    return focusableEl.tabIndex !== -1 && !focusableEl.hasAttribute('disabled');\r\n  });\r\n}\r\n\r\nexport const GridUtils = {\r\n  navigateInsideCell({ event }: SuppressKeyboardEventParams<any>) {\r\n    const { key, shiftKey } = event;    \r\n    const path = getEventPath(event);\r\n    const isTabForward = key === \"Tab\" && shiftKey === false;\r\n    const isTabBackward = key === \"Tab\" && shiftKey === true;\r\n    let suppressEvent = false;\r\n    // Handle cell children tabbing\r\n    if (isTabForward || isTabBackward) {\r\n      const eGridCell = path.find((el) => {\r\n        if (el.classList === undefined) return false;\r\n        return el.classList.contains(GRID_CELL_CLASSNAME);\r\n      });\r\n      if (!eGridCell) {\r\n        return suppressEvent;\r\n      }\r\n      const focusableChildrenElements = getAllFocusableElementsOf(eGridCell);\r\n      const lastCellChildEl =\r\n        focusableChildrenElements[focusableChildrenElements.length - 1];\r\n      const firstCellChildEl = focusableChildrenElements[0];\r\n      // Suppress keyboard event if tabbing forward within the cell and the current focused element is not the last child\r\n      if (focusableChildrenElements.length === 0) {\r\n        return false;\r\n      }\r\n      const currentIndex = focusableChildrenElements.indexOf(\r\n        document.activeElement as HTMLElement,\r\n      );\r\n      if (isTabForward) {\r\n        const isLastChildFocused =\r\n          lastCellChildEl && document.activeElement === lastCellChildEl;\r\n        if (!isLastChildFocused) {\r\n          suppressEvent = true;\r\n          if (currentIndex !== -1 || document.activeElement === eGridCell) {\r\n            event.preventDefault();\r\n            focusableChildrenElements[currentIndex + 1].focus();\r\n          }\r\n        }\r\n      }\r\n      // Suppress keyboard event if tabbing backwards within the cell, and the current focused element is not the first child\r\n      else {\r\n        const cellHasFocusedChildren =\r\n          eGridCell.contains(document.activeElement) &&\r\n          eGridCell !== document.activeElement;\r\n        // Manually set focus to the last child element if cell doesn't have focused children\r\n        if (!cellHasFocusedChildren) {\r\n          lastCellChildEl.focus();\r\n          // Cancel keyboard press, so that it doesn't focus on the last child and then pass through the keyboard press to\r\n          // move to the 2nd last child element\r\n          event.preventDefault();\r\n        }\r\n        const isFirstChildFocused =\r\n          firstCellChildEl && document.activeElement === firstCellChildEl;\r\n        if (!isFirstChildFocused) {\r\n          suppressEvent = true;\r\n          if (currentIndex !== -1 || document.activeElement === eGridCell) {\r\n            event.preventDefault();\r\n            focusableChildrenElements[currentIndex - 1].focus();\r\n          }\r\n        }\r\n      }\r\n    }\r\n    return suppressEvent;\r\n  },\r\n\r\n  \r\n};\r\n"]}
|
|
@@ -4,6 +4,7 @@ export function groupByRow(forms) {
|
|
|
4
4
|
type: form.type,
|
|
5
5
|
name: form.name,
|
|
6
6
|
title: form.title,
|
|
7
|
+
disabled: form.disabled,
|
|
7
8
|
path: form.path,
|
|
8
9
|
rows: groupRowsRecursively(form.components)
|
|
9
10
|
}));
|
|
@@ -27,4 +28,4 @@ function groupRowsRecursively(components) {
|
|
|
27
28
|
components
|
|
28
29
|
}));
|
|
29
30
|
}
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JvdXBCeVJvdy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1zaXJpby9zcmMvbGliL3V0aWxzL2dyb3VwQnlSb3cudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0NBLE1BQU0sVUFBVSxVQUFVLENBQUMsS0FBYTtJQUN0QyxPQUFPLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQ3hCLEVBQUUsRUFBRSxJQUFJLENBQUMsRUFBRTtRQUNYLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSTtRQUNmLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSTtRQUNmLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSztRQUNqQixRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVE7UUFDdkIsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJO1FBQ2YsSUFBSSxFQUFFLG9CQUFvQixDQUFDLElBQUksQ0FBQyxVQUFVLENBQUM7S0FDNUMsQ0FBQyxDQUFDLENBQUM7QUFDTixDQUFDO0FBRUQsU0FBUyxvQkFBb0IsQ0FBQyxVQUF1QjtJQUNuRCxNQUFNLFVBQVUsR0FBRyxJQUFJLEdBQUcsRUFBMEIsQ0FBQztJQUVyRCxTQUFTLGdCQUFnQixDQUFDLFNBQW9CO1FBQzVDLE1BQU0sR0FBRyxHQUFHLFNBQVMsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDO1FBRWpDLElBQUksQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDekIsVUFBVSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDMUIsQ0FBQztRQUVELE1BQU0sRUFBRSxVQUFVLEVBQUUsR0FBRyxLQUFLLEVBQUUsR0FBRyxTQUFTLENBQUM7UUFFM0MsVUFBVSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUUsQ0FBQyxJQUFJLENBQUM7WUFDeEIsR0FBRyxLQUFLO1lBQ1IsSUFBSSxFQUFFLFVBQVUsQ0FBQyxDQUFDLENBQUMsb0JBQW9CLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLFNBQVM7U0FDaEUsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELFVBQVUsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDO0lBRTdELE9BQU8sS0FBSyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsRUFBRSxVQUFVLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNsRSxHQUFHO1FBQ0gsVUFBVTtLQUNYLENBQUMsQ0FBQyxDQUFDO0FBQ04sQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImludGVyZmFjZSBGb3JtIHtcclxuICBpZDogc3RyaW5nO1xyXG4gIHR5cGU6IHN0cmluZztcclxuICBuYW1lOiBzdHJpbmc7XHJcbiAgdGl0bGU6IHN0cmluZztcclxuICBkaXNhYmxlZDogc3RyaW5nIHwgYm9vbGVhbiB8IG51bGw7XHJcbiAgcGF0aDogc3RyaW5nIHwgbnVsbDtcclxuICBjb21wb25lbnRzOiBDb21wb25lbnRbXTtcclxufVxyXG5cclxuaW50ZXJmYWNlIENvbXBvbmVudCB7XHJcbiAgaWQ6IHN0cmluZztcclxuICBsYXlvdXQ6IHsgY29sdW1uczogbnVtYmVyIHwgbnVsbCwgcm93OiBzdHJpbmcgfTtcclxuICBjb21wb25lbnRzPzogQ29tcG9uZW50W107XHJcbiAgW2tleTogc3RyaW5nXTogYW55O1xyXG59XHJcblxyXG5pbnRlcmZhY2UgUm93Q29tcG9uZW50IHtcclxuICBpZDogc3RyaW5nO1xyXG4gIGxheW91dDogeyBjb2x1bW5zOiBudW1iZXIgfCBudWxsLCByb3c6IHN0cmluZyB9O1xyXG4gIHJvd3M/OiBSb3dHcm91cFtdO1xyXG4gIFtrZXk6IHN0cmluZ106IGFueTtcclxufVxyXG5cclxuaW50ZXJmYWNlIFJvd0dyb3VwIHtcclxuICByb3c6IHN0cmluZztcclxuICBjb21wb25lbnRzOiBSb3dDb21wb25lbnRbXTtcclxufVxyXG5cclxuaW50ZXJmYWNlIEdyb3VwZWRGb3JtIHtcclxuICBpZDogc3RyaW5nO1xyXG4gIHRpdGxlOiBzdHJpbmc7XHJcbiAgcm93czogUm93R3JvdXBbXTtcclxuICBba2V5OiBzdHJpbmddOiBhbnk7XHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBncm91cEJ5Um93KGZvcm1zOiBGb3JtW10pOiBHcm91cGVkRm9ybVtdIHtcclxuICByZXR1cm4gZm9ybXMubWFwKGZvcm0gPT4gKHtcclxuICAgIGlkOiBmb3JtLmlkLFxyXG4gICAgdHlwZTogZm9ybS50eXBlLFxyXG4gICAgbmFtZTogZm9ybS5uYW1lLFxyXG4gICAgdGl0bGU6IGZvcm0udGl0bGUsXHJcbiAgICBkaXNhYmxlZDogZm9ybS5kaXNhYmxlZCxcclxuICAgIHBhdGg6IGZvcm0ucGF0aCxcclxuICAgIHJvd3M6IGdyb3VwUm93c1JlY3Vyc2l2ZWx5KGZvcm0uY29tcG9uZW50cylcclxuICB9KSk7XHJcbn1cclxuXHJcbmZ1bmN0aW9uIGdyb3VwUm93c1JlY3Vyc2l2ZWx5KGNvbXBvbmVudHM6IENvbXBvbmVudFtdKTogUm93R3JvdXBbXSB7XHJcbiAgY29uc3QgZ3JvdXBlZE1hcCA9IG5ldyBNYXA8c3RyaW5nLCBSb3dDb21wb25lbnRbXT4oKTtcclxuXHJcbiAgZnVuY3Rpb24gcHJvY2Vzc0NvbXBvbmVudChjb21wb25lbnQ6IENvbXBvbmVudCkge1xyXG4gICAgY29uc3Qgcm93ID0gY29tcG9uZW50LmxheW91dC5yb3c7XHJcblxyXG4gICAgaWYgKCFncm91cGVkTWFwLmhhcyhyb3cpKSB7XHJcbiAgICAgIGdyb3VwZWRNYXAuc2V0KHJvdywgW10pO1xyXG4gICAgfVxyXG5cclxuICAgIGNvbnN0IHsgY29tcG9uZW50cywgLi4ucHJvcHMgfSA9IGNvbXBvbmVudDtcclxuXHJcbiAgICBncm91cGVkTWFwLmdldChyb3cpIS5wdXNoKHtcclxuICAgICAgLi4ucHJvcHMsXHJcbiAgICAgIHJvd3M6IGNvbXBvbmVudHMgPyBncm91cFJvd3NSZWN1cnNpdmVseShjb21wb25lbnRzKSA6IHVuZGVmaW5lZFxyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICBjb21wb25lbnRzLmZvckVhY2goY29tcG9uZW50ID0+IHByb2Nlc3NDb21wb25lbnQoY29tcG9uZW50KSk7XHJcblxyXG4gIHJldHVybiBBcnJheS5mcm9tKGdyb3VwZWRNYXAuZW50cmllcygpKS5tYXAoKFtyb3csIGNvbXBvbmVudHNdKSA9PiAoe1xyXG4gICAgcm93LFxyXG4gICAgY29tcG9uZW50c1xyXG4gIH0pKTtcclxufVxyXG4iXX0=
|