@wemake4u/form-player-se 1.0.2 → 1.0.4

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.
@@ -1,7 +1,13 @@
1
1
  import { Component } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { SirioButtonComponent } from 'ngx-sirio-lib';
4
+ import { Texts } from '../locale/locale-it';
2
5
  import * as i0 from "@angular/core";
6
+ import * as i1 from "../services/programmability.service";
7
+ import * as i2 from "@angular/common";
3
8
  export class ObjectURLRendererComponent {
4
9
  params;
10
+ Texts = Texts;
5
11
  agInit(params) {
6
12
  this.params = params;
7
13
  }
@@ -16,16 +22,15 @@ export class ObjectURLRendererComponent {
16
22
  return false;
17
23
  }
18
24
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ObjectURLRendererComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
19
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: ObjectURLRendererComponent, selector: "ng-component", ngImport: i0, template: `<a aria-label="View" title="View" href="javascript:void(0)" (click)="onClick($event)"><span class="fas fa-paperclip"></span></a>`, isInline: true });
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" });
20
26
  }
21
27
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ObjectURLRendererComponent, decorators: [{
22
28
  type: Component,
23
- args: [{
24
- template: `<a aria-label="View" title="View" href="javascript:void(0)" (click)="onClick($event)"><span class="fas fa-paperclip"></span></a>`,
25
- }]
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" }]
26
30
  }] });
27
31
  export class DeleteRowCellRenderer {
28
32
  params;
33
+ Texts = Texts;
29
34
  agInit(params) {
30
35
  this.params = params;
31
36
  }
@@ -38,12 +43,62 @@ export class DeleteRowCellRenderer {
38
43
  return false;
39
44
  }
40
45
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DeleteRowCellRenderer, deps: [], target: i0.ɵɵFactoryTarget.Component });
41
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: DeleteRowCellRenderer, selector: "ng-component", ngImport: i0, template: `<button aria-label="Remove" title="Remove" class="sirio-btn sirio-btn-icon" (click)="onClick($event)"><span class="fas fa-trash"></span></button>`, isInline: true });
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" });
42
47
  }
43
48
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DeleteRowCellRenderer, decorators: [{
44
49
  type: Component,
45
- args: [{
46
- template: `<button aria-label="Remove" title="Remove" class="sirio-btn sirio-btn-icon" (click)="onClick($event)"><span class="fas fa-trash"></span></button>`,
47
- }]
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
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZENlbGxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXNpcmlvL3NyYy9saWIvdXRpbHMvZ3JpZENlbGxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTzFDLE1BQU0sT0FBTywwQkFBMEI7SUFDckMsTUFBTSxDQUF1QjtJQUU3QixNQUFNLENBQUMsTUFBMkI7UUFDaEMsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7SUFDdkIsQ0FBQztJQUVELE9BQU8sQ0FBQyxLQUFZO1FBQ2xCLE1BQU0sT0FBTyxHQUFHLEdBQUcsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN0RCxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxRQUFRLENBQUMsQ0FBQztRQUMvQixVQUFVLENBQUMsR0FBRyxFQUFFO1lBQ2QsR0FBRyxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUMvQixDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDWCxDQUFDO0lBRUQsT0FBTztRQUNMLE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQzt3R0FqQlUsMEJBQTBCOzRGQUExQiwwQkFBMEIsb0RBRjNCLGtJQUFrSTs7NEZBRWpJLDBCQUEwQjtrQkFIdEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsa0lBQWtJO2lCQUM3STs7QUF3QkQsTUFBTSxPQUFPLHFCQUFxQjtJQUNoQyxNQUFNLENBQU07SUFFWixNQUFNLENBQUMsTUFBVztRQUNoQixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztJQUN2QixDQUFDO0lBRUQsT0FBTyxDQUFDLEtBQVk7UUFFbEIsSUFBSSxRQUFRLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLElBQUksT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLEtBQUssVUFBVSxFQUFFLENBQUM7WUFDbEYsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDNUIsQ0FBQztJQUNILENBQUM7SUFFRCxPQUFPO1FBQ0wsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDO3dHQWhCVSxxQkFBcUI7NEZBQXJCLHFCQUFxQixvREFGdEIsbUpBQW1KOzs0RkFFbEoscUJBQXFCO2tCQUhqQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxtSkFBbUo7aUJBQzlKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IElDZWxsUmVuZGVyZXJBbmd1bGFyQ29tcCB9IGZyb20gJ2FnLWdyaWQtYW5ndWxhcic7XHJcbmltcG9ydCB7IElDZWxsUmVuZGVyZXJQYXJhbXMgfSBmcm9tICdhZy1ncmlkLWNvbW11bml0eSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICB0ZW1wbGF0ZTogYDxhIGFyaWEtbGFiZWw9XCJWaWV3XCIgdGl0bGU9XCJWaWV3XCIgaHJlZj1cImphdmFzY3JpcHQ6dm9pZCgwKVwiIChjbGljayk9XCJvbkNsaWNrKCRldmVudClcIj48c3BhbiBjbGFzcz1cImZhcyBmYS1wYXBlcmNsaXBcIj48L3NwYW4+PC9hPmAsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBPYmplY3RVUkxSZW5kZXJlckNvbXBvbmVudCBpbXBsZW1lbnRzIElDZWxsUmVuZGVyZXJBbmd1bGFyQ29tcCB7XHJcbiAgcGFyYW1zITogSUNlbGxSZW5kZXJlclBhcmFtcztcclxuXHJcbiAgYWdJbml0KHBhcmFtczogSUNlbGxSZW5kZXJlclBhcmFtcyk6IHZvaWQge1xyXG4gICAgdGhpcy5wYXJhbXMgPSBwYXJhbXM7XHJcbiAgfVxyXG5cclxuICBvbkNsaWNrKGV2ZW50OiBFdmVudCkge1xyXG4gICAgY29uc3QgZmlsZVVSTCA9IFVSTC5jcmVhdGVPYmplY3RVUkwodGhpcy5wYXJhbXMuZGF0YSk7XHJcbiAgICB3aW5kb3cub3BlbihmaWxlVVJMLCAnX2JsYW5rJyk7XHJcbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcclxuICAgICAgVVJMLnJldm9rZU9iamVjdFVSTChmaWxlVVJMKTtcclxuICAgIH0sIDEwMDApO1xyXG4gIH1cclxuXHJcbiAgcmVmcmVzaCgpOiBib29sZWFuIHtcclxuICAgIHJldHVybiBmYWxzZTtcclxuICB9XHJcbn1cclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHRlbXBsYXRlOiBgPGJ1dHRvbiBhcmlhLWxhYmVsPVwiUmVtb3ZlXCIgdGl0bGU9XCJSZW1vdmVcIiBjbGFzcz1cInNpcmlvLWJ0biBzaXJpby1idG4taWNvblwiIChjbGljayk9XCJvbkNsaWNrKCRldmVudClcIj48c3BhbiBjbGFzcz1cImZhcyBmYS10cmFzaFwiPjwvc3Bhbj48L2J1dHRvbj5gLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRGVsZXRlUm93Q2VsbFJlbmRlcmVyIGltcGxlbWVudHMgSUNlbGxSZW5kZXJlckFuZ3VsYXJDb21wIHtcclxuICBwYXJhbXM6IGFueTtcclxuXHJcbiAgYWdJbml0KHBhcmFtczogYW55KTogdm9pZCB7XHJcbiAgICB0aGlzLnBhcmFtcyA9IHBhcmFtcztcclxuICB9XHJcblxyXG4gIG9uQ2xpY2soZXZlbnQ6IEV2ZW50KSB7XHJcblxyXG4gICAgaWYgKCdyZW1vdmUnIGluIHRoaXMucGFyYW1zLmRhdGEgJiYgdHlwZW9mIHRoaXMucGFyYW1zLmRhdGEucmVtb3ZlID09PSAnZnVuY3Rpb24nKSB7XHJcbiAgICAgIHRoaXMucGFyYW1zLmRhdGEucmVtb3ZlKCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICByZWZyZXNoKCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIGZhbHNlO1xyXG4gIH1cclxufVxyXG4iXX0=
52
+ export class ActionsCellRenderer {
53
+ programmability;
54
+ constructor(programmability) {
55
+ this.programmability = programmability;
56
+ }
57
+ params;
58
+ agInit(params) {
59
+ this.params = params;
60
+ }
61
+ refresh() {
62
+ return false;
63
+ }
64
+ evaluateBoolean(value) {
65
+ const options = {
66
+ proxyFn: (options) => {
67
+ options.extend["getParams"] = () => this.params;
68
+ options.extend["getData"] = () => this.getData();
69
+ }
70
+ };
71
+ return this.programmability.evaluateBoolean(this.getFormGroup(), value, options);
72
+ }
73
+ evaluateString(value) {
74
+ return this.programmability.evaluateString(this.getFormGroup(), value);
75
+ }
76
+ clickButton(action, event) {
77
+ if (action.click) {
78
+ const options = {
79
+ cacheable: false,
80
+ proxyFn: (options) => {
81
+ options.extend["getParams"] = () => this.params;
82
+ options.extend["getAction"] = () => action;
83
+ options.extend["getData"] = () => this.getData();
84
+ }
85
+ };
86
+ return this.programmability.evaluate(this.getFormGroup(), action.click, options);
87
+ }
88
+ }
89
+ getData() {
90
+ return this.params.data;
91
+ }
92
+ getFormGroup() {
93
+ return this.params.formGroup;
94
+ }
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 });
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"] }] });
97
+ }
98
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ActionsCellRenderer, decorators: [{
99
+ type: Component,
100
+ args: [{ standalone: true, imports: [
101
+ CommonModule, SirioButtonComponent
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" }]
103
+ }], ctorParameters: () => [{ type: i1.ProgrammabilityService }] });
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":"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","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"]}