@wemake4u/form-player-se 1.0.3 → 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.
- package/esm2022/lib/directives/date.directive.mjs +93 -0
- package/esm2022/lib/directives/disable.directive.mjs +18 -4
- package/esm2022/lib/directives/number.directive.mjs +108 -0
- package/esm2022/lib/dynamic-fields/dynamic-fields.component.mjs +16 -7
- package/esm2022/lib/dynamic-form/dynamic-form.component.mjs +18 -30
- 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/fesm2022/wemake4u-form-player-se.mjs +339 -59
- package/fesm2022/wemake4u-form-player-se.mjs.map +1 -1
- package/lib/directives/date.directive.d.ts +8 -0
- package/lib/directives/disable.directive.d.ts +5 -2
- 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 +1 -1
- 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/package.json +1 -1
|
@@ -205,17 +205,13 @@ export class DynamicFormComponent {
|
|
|
205
205
|
}
|
|
206
206
|
else if (component.key) {
|
|
207
207
|
let defaultValue = this.getDefaultValue(component);
|
|
208
|
-
const
|
|
208
|
+
const validators = this.getValidators(formGroup, component);
|
|
209
209
|
const options = {
|
|
210
|
-
validators:
|
|
210
|
+
validators: validators || [],
|
|
211
211
|
updateOn: this.getUpdateOn(component) || "change"
|
|
212
212
|
};
|
|
213
213
|
const control = formBuilder.control(defaultValue, options);
|
|
214
214
|
formGroup.addControl(component.key, control);
|
|
215
|
-
programmability?.watch(control);
|
|
216
|
-
if (component.type === 'number') {
|
|
217
|
-
this.useNumber(control);
|
|
218
|
-
}
|
|
219
215
|
}
|
|
220
216
|
}
|
|
221
217
|
});
|
|
@@ -226,22 +222,31 @@ export class DynamicFormComponent {
|
|
|
226
222
|
}
|
|
227
223
|
let currentGroup = formGroup;
|
|
228
224
|
this.splitPath(path).forEach((segment) => {
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
225
|
+
const existGroup = currentGroup.get(segment);
|
|
226
|
+
if (existGroup instanceof FormGroup) {
|
|
227
|
+
currentGroup = existGroup;
|
|
228
|
+
return;
|
|
229
|
+
}
|
|
230
|
+
else if (existGroup) {
|
|
231
|
+
throw new Error(`Cannot create form group because an element with path ${segment} already exists`);
|
|
232
|
+
}
|
|
233
|
+
else {
|
|
234
|
+
const segmentGroup = formBuilder.group({});
|
|
235
|
+
currentGroup.addControl(segment, segmentGroup);
|
|
236
|
+
currentGroup = segmentGroup;
|
|
237
|
+
}
|
|
232
238
|
});
|
|
233
239
|
return currentGroup;
|
|
234
240
|
}
|
|
235
241
|
getValidators(formGroup, component) {
|
|
236
242
|
const validators = [];
|
|
237
|
-
const noWatch = (control) => { };
|
|
238
243
|
if (component?.validate?.required === true) {
|
|
239
244
|
validators.push(Validators.required);
|
|
240
245
|
}
|
|
241
246
|
if (!Array.isArray(component.validations)) {
|
|
242
247
|
if (validators.length == 0)
|
|
243
248
|
return null;
|
|
244
|
-
return
|
|
249
|
+
return validators;
|
|
245
250
|
}
|
|
246
251
|
component.validations?.forEach((item) => {
|
|
247
252
|
if (!this.programmabilityService.isExpression(item.expression))
|
|
@@ -255,15 +260,7 @@ export class DynamicFormComponent {
|
|
|
255
260
|
});
|
|
256
261
|
if (validators.length == 0)
|
|
257
262
|
return null;
|
|
258
|
-
return
|
|
259
|
-
validators: validators,
|
|
260
|
-
watch: (control) => {
|
|
261
|
-
//let formGroup = control.parent as FormGroup;
|
|
262
|
-
//this.watch(formGroup, Array.from(set), () => {
|
|
263
|
-
// control.updateValueAndValidity();
|
|
264
|
-
//});
|
|
265
|
-
}
|
|
266
|
-
};
|
|
263
|
+
return validators;
|
|
267
264
|
}
|
|
268
265
|
validateFn(formGroup, item) {
|
|
269
266
|
return (control) => {
|
|
@@ -287,15 +284,6 @@ export class DynamicFormComponent {
|
|
|
287
284
|
return null;
|
|
288
285
|
};
|
|
289
286
|
}
|
|
290
|
-
useNumber(formControl) {
|
|
291
|
-
/* Required for Siro Input because the type number was not implemented correctly */
|
|
292
|
-
formControl.valueChanges.subscribe(value => {
|
|
293
|
-
const numericValue = value === '' ? null : parseFloat(value);
|
|
294
|
-
if (numericValue === null || !isNaN(numericValue)) {
|
|
295
|
-
formControl.setValue(numericValue, { emitEvent: false });
|
|
296
|
-
}
|
|
297
|
-
});
|
|
298
|
-
}
|
|
299
287
|
isFormComponent(component) {
|
|
300
288
|
switch (component.type) {
|
|
301
289
|
case "checkbox":
|
|
@@ -392,4 +380,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
392
380
|
}], activeNav: [{
|
|
393
381
|
type: Input
|
|
394
382
|
}] } });
|
|
395
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/dynamic-form/dynamic-form.component.ts","../../../../../projects/ngx-sirio/src/lib/dynamic-form/dynamic-form.component.html"],"names":[],"mappings":"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","sourcesContent":["/// <reference path=\"../types/typings.d.ts\" />\r\n\r\nimport {\r\n  Component, Input, Output, OnChanges, OnDestroy \r\n  , SimpleChanges, ViewEncapsulation, EventEmitter\r\n  , ViewChild\r\n} from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport {\r\n  FormBuilder, FormGroup, FormControl, FormControlOptions, AbstractControl\r\n  , ValidatorFn, Validators, ValidationErrors\r\n} from '@angular/forms';\r\nimport { ReactiveFormsModule } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport { ProgrammabilityService } from '../services/programmability.service';\r\nimport { patchForm } from '../utils/patchForm';\r\nimport { groupByRow } from '../utils/groupByRow';\r\nimport { CommandEvent, EventService } from '../services/event.service';\r\nimport { DynamicFieldsComponent } from '../dynamic-fields/dynamic-fields.component';\r\nimport {\r\n  SirioSidenavMobileComponent, SirioSidenavComponent, SirioSidenavItemComponent\r\n  , SirioButtonComponent, SirioStepperProgressBarComponent, SirioStepperProgressItemComponent\r\n  , SirioStepperProgressStatus, NgxSirioEvent\r\n} from 'ngx-sirio-lib';\r\nimport { RegisterService } from '../services/register.service';\r\nimport { RegisterDirective } from '../directives/register.directive';\r\nimport { Control } from '../controls/control'; \r\n\r\nimport { Texts } from '../locale/locale-it';\r\n\r\n@Component({\r\n  selector: 'app-dynamic-form',\r\n  templateUrl: './dynamic-form.component.html',\r\n  styleUrls: [\r\n    '../shared/bootstrap-grid.scss',\r\n    './dynamic-form.component.css'\r\n  ],\r\n  standalone: true,\r\n  imports: [CommonModule, ReactiveFormsModule\r\n    , RegisterDirective\r\n    , SirioSidenavMobileComponent, SirioSidenavComponent, SirioSidenavItemComponent\r\n    , SirioButtonComponent, SirioStepperProgressBarComponent, SirioStepperProgressItemComponent\r\n    , DynamicFieldsComponent],\r\n  providers: [\r\n    EventService, ProgrammabilityService, RegisterService\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class DynamicFormComponent implements OnChanges, OnDestroy {\r\n  @Input() schema: any;\r\n  @Input() formGroup!: FormGroup;\r\n  @Input() value: any = {};\r\n  @Input() showNav: boolean = true;\r\n  @Input() showNavButton: boolean = true;\r\n  @Input() showProgress: boolean = false;\r\n  @Input() progressStatus: boolean = true;\r\n  @Output() valueChange = new EventEmitter<any>();\r\n  @Output() initialized = new EventEmitter<FormGroup>();\r\n  @Output() onCommand = new EventEmitter<CommandEvent>();\r\n  @Output() activeNavChange = new EventEmitter<any>();\r\n\r\n  constructor(private fb: FormBuilder\r\n    , private programmabilityService: ProgrammabilityService\r\n    , private events: EventService\r\n    , private registerService: RegisterService\r\n  ) { }\r\n\r\n  Texts = Texts;\r\n\r\n  ngOnDestroy(): void {\r\n    this.clearHandlers();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['schema']) {\r\n      if (!this.formGroup) {\r\n        this.formGroup = this.fb.group({});\r\n      }\r\n\r\n      this.clearControls();\r\n\r\n      this.clearHandlers();\r\n\r\n      const schema = changes['schema'].currentValue;\r\n\r\n      this._forms = groupByRow(schema.forms ?? []);\r\n\r\n      this.buildForm();\r\n\r\n      if (this.value) {\r\n        this.patchValue(this.formGroup, this.value);\r\n      }\r\n\r\n      if (this.initialized)\r\n        this.initialized.emit(this.formGroup);\r\n\r\n      this.registerHandlers();      \r\n    }\r\n  }\r\n\r\n  get forms(): Array<any> {\r\n    return this._forms;\r\n  }\r\n\r\n  canPrevious(): boolean {\r\n    return this.getPrevious() != -1; \r\n  }\r\n\r\n  goPrevious() {\r\n    if (this.canPrevious()) {\r\n      this.activeNav = this.getPrevious();\r\n    }\r\n  }\r\n\r\n  canNext(): boolean {\r\n    return this.getNext() != -1;    \r\n  }\r\n\r\n  goNext() {\r\n    if (this.canNext()) { \r\n      this.activeNav = this.getNext();\r\n    }\r\n  }\r\n\r\n  getControls(): Control[] {\r\n    return this.registerService.getControls();\r\n  }\r\n\r\n  getControl(name: string): Control | undefined {\r\n    return this.registerService.getControl(name);\r\n  }\r\n\r\n  get activeNav(): number {\r\n    return this._activeNav;\r\n  }\r\n\r\n  @Input()\r\n  set activeNav(value: number) {\r\n    if (value >= 0 && value < this.getMaxNav()) {\r\n      this._activeNav = value;\r\n    }\r\n    setTimeout(() => {\r\n      this.activeNavChange.emit(this._activeNav);\r\n    });\r\n  }\r\n\r\n  getFormGroup(path: string | null): FormGroup {\r\n    const control = path ? this.formGroup.get(path) : this.formGroup;\r\n    if (!(control instanceof FormGroup)) {\r\n      throw new Error('Control is not a FormGroup');\r\n    }\r\n    return control;\r\n  }\r\n\r\n  getFormStatus(form: any): SirioStepperProgressStatus {\r\n\r\n    const index = this._forms.findIndex(f => f.id === form.id);\r\n\r\n    const current = index == this.activeNav;\r\n\r\n    if (current) {\r\n      return \"active\";\r\n    }\r\n    else if (this.progressStatus) {\r\n      const formGroup = this.getFormGroup(form.path);\r\n      return formGroup.valid ? \"success\" : \"error\";\r\n    }\r\n    else {\r\n      return \"active\";\r\n    }    \r\n  }\r\n\r\n  activateForm(title: string) {\r\n    const index = this.forms.findIndex(form => form.title === title);\r\n    if (index != -1)\r\n      this.activeNav = index;\r\n  }\r\n\r\n  private valueChangesSubscription: Subscription | null = null;\r\n  private onCommandSubscription: Subscription | null = null;\r\n\r\n  private _forms: Array<any> = [];\r\n\r\n  private _activeNav: number = 0;\r\n\r\n  private getNext(): number {\r\n    if (this.activeNav < this.getMaxNav() - 1) {\r\n      return this.activeNav + 1;\r\n    }\r\n    else {\r\n      return -1;\r\n    }\r\n  }\r\n\r\n  private getPrevious(): number {\r\n    if (this.activeNav > 0) {\r\n      return this.activeNav - 1;\r\n    }\r\n    else {\r\n      return -1;\r\n    }\r\n  }\r\n\r\n  private getMaxNav(): number {\r\n    return this._forms.length ?? 0;    \r\n  };\r\n\r\n  private clearControls(): void {\r\n    Object.keys(this.formGroup.controls).forEach(key => {\r\n      this.formGroup.removeControl(key);\r\n    });\r\n  }\r\n\r\n  private registerHandlers(): void {\r\n    this.valueChangesSubscription = this.formGroup.valueChanges.subscribe((value) => {\r\n      this.valueChange.emit(value);\r\n    });\r\n\r\n    this.onCommandSubscription = this.events.onCommand.subscribe((data) => {\r\n      if (this.onCommand)\r\n        this.onCommand.emit(data);\r\n    });\r\n  };\r\n\r\n  private clearHandlers(): void {\r\n    if (this.valueChangesSubscription) {\r\n      this.valueChangesSubscription.unsubscribe();\r\n    }\r\n\r\n    if (this.onCommandSubscription) {\r\n      this.onCommandSubscription.unsubscribe();\r\n    }\r\n  }\r\n\r\n  private buildForm() {\r\n    this.forms.forEach((form: any) => {\r\n      const currentGroup = this.applyPath(this.fb, this.formGroup, form.path);\r\n      form.rows?.forEach((row: any) => {\r\n        this.addControls(this.fb, currentGroup, row.components);\r\n      });\r\n    });\r\n  }\r\n\r\n  private addControls(formBuilder: FormBuilder, formGroup: FormGroup, components: Array<any>) {\r\n    let formComponent = this;\r\n\r\n    components?.forEach((component: any) => {\r\n      if (this.isFormComponent(component)) {\r\n        if (component.type === 'dynamiclist') {\r\n          if (component.path) {\r\n            let formArray = formBuilder.array<FormGroup>([]);\r\n\r\n            formGroup.addControl(component.path, formArray);\r\n\r\n            (formArray as any).addNewItem = function (): FormGroup {\r\n              let newGroup = formBuilder.group({});\r\n              component.rows?.forEach((row: any) => {\r\n                formComponent.addControls(formBuilder, newGroup, row.components);\r\n              });\r\n              formArray.push(newGroup);\r\n              return newGroup;\r\n            };\r\n          }\r\n        }\r\n        else if (component.type === 'group') {\r\n          const currentGroup = this.applyPath(formBuilder, formGroup, component.path);\r\n          component.rows?.forEach((row: any) => {\r\n            formComponent.addControls(formBuilder, currentGroup, row.components);\r\n          });\r\n        }\r\n        else if (component.key) {\r\n          let defaultValue = this.getDefaultValue(component);\r\n          const programmability = this.getValidators(formGroup, component);\r\n          const options: FormControlOptions = {\r\n            validators: programmability?.validators || [],\r\n            updateOn: this.getUpdateOn(component) || \"change\"\r\n          };\r\n          const control = formBuilder.control(defaultValue, options);\r\n          formGroup.addControl(component.key, control);\r\n          programmability?.watch(control!);          \r\n          if (component.type === 'number') {\r\n            this.useNumber(control as FormControl);\r\n          }\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  private applyPath(formBuilder: FormBuilder, formGroup: FormGroup, path: string) {\r\n    if (!path) {\r\n      return formGroup;\r\n    }\r\n    let currentGroup: FormGroup = formGroup;\r\n    this.splitPath(path).forEach((segment) => {\r\n      let newGroup = formBuilder.group({});\r\n      currentGroup.addControl(segment, newGroup);\r\n      currentGroup = newGroup;\r\n    });\r\n    return currentGroup;\r\n  }\r\n\r\n  private getValidators(formGroup: FormGroup, component: any)\r\n    : { validators: ValidatorFn[]; watch: (control: AbstractControl) => void } | null {\r\n\r\n    const validators: ValidatorFn[] = [];\r\n\r\n    const noWatch = (control: AbstractControl) => { };\r\n\r\n    if (component?.validate?.required === true) {\r\n      validators.push(Validators.required);\r\n    }\r\n\r\n    if (!Array.isArray(component.validations)) {\r\n      if (validators.length == 0)\r\n        return null;\r\n      return { validators: validators, watch: noWatch };\r\n    }\r\n\r\n    component.validations?.forEach((item: any) => {\r\n      if (!this.programmabilityService.isExpression(item.expression))\r\n        return;\r\n\r\n      if (item.type === \"validate\") {\r\n        validators.push(this.validateFn(formGroup, item));\r\n      }\r\n      else if (item.type === \"invalidate\") {\r\n        validators.push(this.invalidateFn(formGroup, item));\r\n      }      \r\n    });\r\n\r\n    if (validators.length == 0)\r\n      return null;\r\n\r\n    return {\r\n      validators: validators,\r\n      watch: (control) => {\r\n        //let formGroup = control.parent as FormGroup;\r\n        //this.watch(formGroup, Array.from(set), () => {\r\n        //  control.updateValueAndValidity();\r\n        //});\r\n      }\r\n    };\r\n  }\r\n\r\n  private validateFn(formGroup: FormGroup, item: any): ValidatorFn {\r\n    return (control: AbstractControl): ValidationErrors | null => {\r\n\r\n      //if (!control.touched)\r\n      //  return null;\r\n\r\n      var valid = this.programmabilityService.evaluateUnary(formGroup, item.expression, control.value);\r\n\r\n      if (!valid) {\r\n        return { error: true, message: item.message };\r\n      }\r\n      return null;\r\n    };\r\n  }\r\n\r\n  private invalidateFn(formGroup: FormGroup, item: any): ValidatorFn {\r\n    return (control: AbstractControl): ValidationErrors | null => {\r\n\r\n      //if (!control.touched)\r\n      //  return null;\r\n\r\n      var invalid = this.programmabilityService.evaluateUnary(formGroup, item.expression, control.value);\r\n\r\n      if (invalid) {\r\n        return { error: true, message: item.message };\r\n      }\r\n      return null;\r\n    };\r\n  }\r\n\r\n  private useNumber(formControl: FormControl) {\r\n    /* Required for Siro Input because the type number was not implemented correctly */\r\n    formControl.valueChanges.subscribe(value => {\r\n      const numericValue = value === '' ? null : parseFloat(value);\r\n      if (numericValue === null || !isNaN(numericValue)) {\r\n        formControl.setValue(numericValue, { emitEvent: false });\r\n      }\r\n    });\r\n  }\r\n\r\n  private isFormComponent(component: any): boolean {\r\n    switch (component.type) {\r\n      case \"checkbox\":\r\n      case \"checklist\":\r\n      case \"datetime\":\r\n      case \"dynamiclist\":\r\n      case \"filepicker\":\r\n      case \"group\":\r\n      case \"number\":\r\n      case \"radio\":\r\n      case \"select\":\r\n      case \"taglist\":\r\n      case \"textarea\":\r\n      case \"textfield\":\r\n      case \"range\":\r\n        return true;\r\n      default:\r\n        return false;\r\n    }\r\n  }\r\n\r\n  private getUpdateOn(component: any): any {\r\n    switch (component.type) {\r\n      case \"number\":\r\n      case \"textarea\":\r\n      case \"textfield\":\r\n        return \"blur\";\r\n      default:\r\n        return null;\r\n    }\r\n  }\r\n\r\n  private getDefaultValue(component: any): any {\r\n    switch (component.type) {\r\n      case \"textarea\":\r\n      case \"textfield\":\r\n      case \"radio\":\r\n      case \"select\":\r\n        return component.defaultValue as string;\r\n      case \"number\":\r\n        return component.defaultValue as number;\r\n      case \"checkbox\":\r\n        return component.defaultValue as boolean;\r\n      default:\r\n        return null;\r\n    }\r\n  }\r\n\r\n  private splitPath(path: string): string[] {\r\n    if (!path) {\r\n      return [];\r\n    }\r\n    return path\r\n      .split('.')\r\n      .map(segment => segment.trim())\r\n      .filter(segment => segment.length > 0);\r\n  }\r\n\r\n  private patchValue(formGroup: FormGroup, value: any) {\r\n    patchForm(formGroup, value);\r\n  }\r\n}\r\n","<form [formGroup]=\"formGroup\" class=\"ngs\">\r\n\r\n  <div class=\"container-fluid\">\r\n    <div class=\"row\">\r\n\r\n      <!-- #region progress -->\r\n      <ngx-sirio-stepper-progress-bar *ngIf=\"showProgress\"\r\n        (eventClick)=\"activateForm($event.data.label)\" \r\n        [hasDropdown]=\"true\" \r\n        [dropDownLabel]=\"Texts.Show\">\r\n        <ngx-sirio-stepper-progress-item *ngFor=\"let form of forms\"\r\n                                         [hasNavigation]=\"true\"\r\n                                         [status]=\"getFormStatus(form)\"\r\n                                         [label]=\"form.title\" />\r\n      </ngx-sirio-stepper-progress-bar>\r\n      <!-- #endregion -->\r\n\r\n      <ng-container *ngIf=\"showNav\">\r\n\r\n        <div class=\"col-md-4\">\r\n\r\n          <!-- #region sidenav -->\r\n          <ng-template #sidenavTemplate>\r\n            <ngx-sirio-sidenav>\r\n              <ng-container *ngFor=\"let form of forms, let sectionIndex = index\">\r\n                <ngx-sirio-sidenav-item [isActive]=\"activeNav == sectionIndex\" (click)=\"activeNav = sectionIndex\">\r\n                  {{ form.title }}\r\n                </ngx-sirio-sidenav-item>\r\n              </ng-container>\r\n            </ngx-sirio-sidenav>\r\n          </ng-template>\r\n\r\n          <ngx-sirio-sidenav-mobile class=\"d-block d-lg-none\"\r\n                                    openMenuLabel=\"Apri Menu\"\r\n                                    openMenuAriaLabel=\"Apri Menu\"\r\n                                    closeMenuLabel=\"Chiudi Menu\"\r\n                                    closeMenuAriaLabel=\"Chiudi Menu\">\r\n            <ng-container *ngTemplateOutlet=\"sidenavTemplate\"></ng-container>\r\n          </ngx-sirio-sidenav-mobile>\r\n          <div class=\"d-none d-lg-block\">\r\n            <ng-container *ngTemplateOutlet=\"sidenavTemplate\"></ng-container>\r\n          </div>\r\n          <!-- #endregion -->\r\n\r\n        </div>\r\n\r\n        <div class=\"col-md-1\">\r\n          <div class=\"separator-horizontal\"></div>\r\n        </div>\r\n\r\n      </ng-container>\r\n\r\n      <div class=\"content-element-form\" [ngClass]=\"showNav ? 'col-md-11' : 'col-md-16'\">\r\n\r\n        <ng-container *ngFor=\"let form of forms, let sectionIndex = index\">\r\n          <div *ngIf=\"activeNav == sectionIndex\"\r\n               #default\r\n               [register]=\"form\"\r\n               [componentRef]=\"default\">\r\n            <app-dynamic-fields [formGroup]=\"getFormGroup(form.path)\" [rows]=\"form.rows\"></app-dynamic-fields>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"showNavButton\">\r\n\r\n          <div class=\"row section-navs\">\r\n            <div class=\"col-8 col-md-8\">\r\n              <ngx-sirio-button [color]=\"null\" [disabled]=\"!canNext()\" (click)=\"goNext()\" class=\"nextSection\">\r\n                {{ Texts.NextSection }}\r\n                <span class=\"fa-solid fa-chevron-right\" style=\"margin-left: 10px\"></span>\r\n              </ngx-sirio-button>\r\n            </div>\r\n            <div class=\"col-8 col-md-8\">\r\n              <ngx-sirio-button [color]=\"null\" [disabled]=\"!canPrevious()\" (click)=\"goPrevious()\" class=\"prevSection\">\r\n                <span class=\"fa-solid fa-chevron-left\" style=\"margin-right: 10px\"></span>\r\n                {{ Texts.PreviousSection }}\r\n              </ngx-sirio-button>\r\n            </div>\r\n          </div>\r\n\r\n        </ng-container>\r\n\r\n\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n</form>\r\n\r\n\r\n\r\n"]}
|
|
383
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/dynamic-form/dynamic-form.component.ts","../../../../../projects/ngx-sirio/src/lib/dynamic-form/dynamic-form.component.html"],"names":[],"mappings":"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","sourcesContent":["/// <reference path=\"../types/typings.d.ts\" />\r\n\r\nimport {\r\n  Component, Input, Output, OnChanges, OnDestroy \r\n  , SimpleChanges, ViewEncapsulation, EventEmitter\r\n} from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport {\r\n  FormBuilder, FormGroup, FormControlOptions, AbstractControl\r\n  , ValidatorFn, Validators, ValidationErrors\r\n} from '@angular/forms';\r\nimport { ReactiveFormsModule } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport { ProgrammabilityService } from '../services/programmability.service';\r\nimport { patchForm } from '../utils/patchForm';\r\nimport { groupByRow } from '../utils/groupByRow';\r\nimport { CommandEvent, EventService } from '../services/event.service';\r\nimport { DynamicFieldsComponent } from '../dynamic-fields/dynamic-fields.component';\r\nimport {\r\n  SirioSidenavMobileComponent, SirioSidenavComponent, SirioSidenavItemComponent\r\n  , SirioButtonComponent, SirioStepperProgressBarComponent, SirioStepperProgressItemComponent\r\n  , SirioStepperProgressStatus\r\n} from 'ngx-sirio-lib';\r\nimport { RegisterService } from '../services/register.service';\r\nimport { RegisterDirective } from '../directives/register.directive';\r\nimport { Control } from '../controls/control'; \r\n\r\nimport { Texts } from '../locale/locale-it';\r\n\r\n@Component({\r\n  selector: 'app-dynamic-form',\r\n  templateUrl: './dynamic-form.component.html',\r\n  styleUrls: [\r\n    '../shared/bootstrap-grid.scss',\r\n    './dynamic-form.component.css'\r\n  ],\r\n  standalone: true,\r\n  imports: [CommonModule, ReactiveFormsModule\r\n    , RegisterDirective\r\n    , SirioSidenavMobileComponent, SirioSidenavComponent, SirioSidenavItemComponent\r\n    , SirioButtonComponent, SirioStepperProgressBarComponent, SirioStepperProgressItemComponent\r\n    , DynamicFieldsComponent],\r\n  providers: [\r\n    EventService, ProgrammabilityService, RegisterService\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class DynamicFormComponent implements OnChanges, OnDestroy {\r\n  @Input() schema: any;\r\n  @Input() formGroup!: FormGroup;\r\n  @Input() value: any = {};\r\n  @Input() showNav: boolean = true;\r\n  @Input() showNavButton: boolean = true;\r\n  @Input() showProgress: boolean = false;\r\n  @Input() progressStatus: boolean = true;\r\n  @Output() valueChange = new EventEmitter<any>();\r\n  @Output() initialized = new EventEmitter<FormGroup>();\r\n  @Output() onCommand = new EventEmitter<CommandEvent>();\r\n  @Output() activeNavChange = new EventEmitter<any>();\r\n\r\n  constructor(private fb: FormBuilder\r\n    , private programmabilityService: ProgrammabilityService\r\n    , private events: EventService\r\n    , private registerService: RegisterService\r\n  ) { }\r\n\r\n  Texts = Texts;\r\n\r\n  ngOnDestroy(): void {\r\n    this.clearHandlers();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['schema']) {\r\n      if (!this.formGroup) {\r\n        this.formGroup = this.fb.group({});\r\n      }\r\n\r\n      this.clearControls();\r\n\r\n      this.clearHandlers();\r\n\r\n      const schema = changes['schema'].currentValue;\r\n\r\n      this._forms = groupByRow(schema.forms ?? []);\r\n\r\n      this.buildForm();\r\n\r\n      if (this.value) {\r\n        this.patchValue(this.formGroup, this.value);\r\n      }\r\n\r\n      if (this.initialized)\r\n        this.initialized.emit(this.formGroup);\r\n\r\n      this.registerHandlers();      \r\n    }\r\n  }\r\n\r\n  get forms(): Array<any> {\r\n    return this._forms;\r\n  }\r\n\r\n  canPrevious(): boolean {\r\n    return this.getPrevious() != -1; \r\n  }\r\n\r\n  goPrevious() {\r\n    if (this.canPrevious()) {\r\n      this.activeNav = this.getPrevious();\r\n    }\r\n  }\r\n\r\n  canNext(): boolean {\r\n    return this.getNext() != -1;    \r\n  }\r\n\r\n  goNext() {\r\n    if (this.canNext()) { \r\n      this.activeNav = this.getNext();\r\n    }\r\n  }\r\n\r\n  getControls(): Control[] {\r\n    return this.registerService.getControls();\r\n  }\r\n\r\n  getControl(name: string): Control | undefined {\r\n    return this.registerService.getControl(name);\r\n  }\r\n\r\n  get activeNav(): number {\r\n    return this._activeNav;\r\n  }\r\n\r\n  @Input()\r\n  set activeNav(value: number) {\r\n    if (value >= 0 && value < this.getMaxNav()) {\r\n      this._activeNav = value;\r\n    }\r\n    setTimeout(() => {\r\n      this.activeNavChange.emit(this._activeNav);\r\n    });\r\n  }\r\n\r\n  getFormGroup(path: string | null): FormGroup {\r\n    const control = path ? this.formGroup.get(path) : this.formGroup;\r\n    if (!(control instanceof FormGroup)) {\r\n      throw new Error('Control is not a FormGroup');\r\n    }\r\n    return control;\r\n  }\r\n\r\n  getFormStatus(form: any): SirioStepperProgressStatus {\r\n\r\n    const index = this._forms.findIndex(f => f.id === form.id);\r\n\r\n    const current = index == this.activeNav;\r\n\r\n    if (current) {\r\n      return \"active\";\r\n    }\r\n    else if (this.progressStatus) {\r\n      const formGroup = this.getFormGroup(form.path);\r\n      return formGroup.valid ? \"success\" : \"error\";\r\n    }\r\n    else {\r\n      return \"active\";\r\n    }    \r\n  }\r\n\r\n  activateForm(title: string) {\r\n    const index = this.forms.findIndex(form => form.title === title);\r\n    if (index != -1)\r\n      this.activeNav = index;\r\n  }\r\n\r\n  private valueChangesSubscription: Subscription | null = null;\r\n  private onCommandSubscription: Subscription | null = null;\r\n\r\n  private _forms: Array<any> = [];\r\n\r\n  private _activeNav: number = 0;\r\n\r\n  private getNext(): number {\r\n    if (this.activeNav < this.getMaxNav() - 1) {\r\n      return this.activeNav + 1;\r\n    }\r\n    else {\r\n      return -1;\r\n    }\r\n  }\r\n\r\n  private getPrevious(): number {\r\n    if (this.activeNav > 0) {\r\n      return this.activeNav - 1;\r\n    }\r\n    else {\r\n      return -1;\r\n    }\r\n  }\r\n\r\n  private getMaxNav(): number {\r\n    return this._forms.length ?? 0;    \r\n  };\r\n\r\n  private clearControls(): void {\r\n    Object.keys(this.formGroup.controls).forEach(key => {\r\n      this.formGroup.removeControl(key);\r\n    });\r\n  }\r\n\r\n  private registerHandlers(): void {\r\n    this.valueChangesSubscription = this.formGroup.valueChanges.subscribe((value) => {\r\n      this.valueChange.emit(value);\r\n    });\r\n\r\n    this.onCommandSubscription = this.events.onCommand.subscribe((data) => {\r\n      if (this.onCommand)\r\n        this.onCommand.emit(data);\r\n    });\r\n  };\r\n\r\n  private clearHandlers(): void {\r\n    if (this.valueChangesSubscription) {\r\n      this.valueChangesSubscription.unsubscribe();\r\n    }\r\n\r\n    if (this.onCommandSubscription) {\r\n      this.onCommandSubscription.unsubscribe();\r\n    }\r\n  }\r\n\r\n  private buildForm() {\r\n    this.forms.forEach((form: any) => {\r\n      const currentGroup = this.applyPath(this.fb, this.formGroup, form.path);\r\n      form.rows?.forEach((row: any) => {\r\n        this.addControls(this.fb, currentGroup, row.components);\r\n      });\r\n    });\r\n  }\r\n\r\n  private addControls(formBuilder: FormBuilder, formGroup: FormGroup, components: Array<any>) {\r\n    let formComponent = this;\r\n\r\n    components?.forEach((component: any) => {\r\n      if (this.isFormComponent(component)) {\r\n        if (component.type === 'dynamiclist') {\r\n          if (component.path) {\r\n            let formArray = formBuilder.array<FormGroup>([]);\r\n\r\n            formGroup.addControl(component.path, formArray);\r\n\r\n            (formArray as any).addNewItem = function (): FormGroup {\r\n              let newGroup = formBuilder.group({});\r\n              component.rows?.forEach((row: any) => {\r\n                formComponent.addControls(formBuilder, newGroup, row.components);\r\n              });\r\n              formArray.push(newGroup);\r\n              return newGroup;\r\n            };\r\n          }\r\n        }\r\n        else if (component.type === 'group') {\r\n          const currentGroup = this.applyPath(formBuilder, formGroup, component.path);\r\n          component.rows?.forEach((row: any) => {\r\n            formComponent.addControls(formBuilder, currentGroup, row.components);\r\n          });\r\n        }\r\n        else if (component.key) {\r\n          let defaultValue = this.getDefaultValue(component);\r\n          const validators = this.getValidators(formGroup, component);\r\n          const options: FormControlOptions = {\r\n            validators: validators || [],\r\n            updateOn: this.getUpdateOn(component) || \"change\"\r\n          };\r\n          const control = formBuilder.control(defaultValue, options);\r\n          formGroup.addControl(component.key, control);\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  private applyPath(formBuilder: FormBuilder, formGroup: FormGroup, path: string) {\r\n    if (!path) {\r\n      return formGroup;\r\n    }\r\n    let currentGroup: FormGroup = formGroup;\r\n    this.splitPath(path).forEach((segment) => {\r\n      const existGroup = currentGroup.get(segment);\r\n      if (existGroup instanceof FormGroup) {\r\n        currentGroup = existGroup;\r\n        return;\r\n      }\r\n      else if (existGroup) {\r\n        throw new Error(`Cannot create form group because an element with path ${segment} already exists`);\r\n      }\r\n      else {\r\n        const segmentGroup = formBuilder.group({});\r\n        currentGroup.addControl(segment, segmentGroup);\r\n        currentGroup = segmentGroup;\r\n      } \r\n    });\r\n    return currentGroup;\r\n  }\r\n\r\n  private getValidators(formGroup: FormGroup, component: any): ValidatorFn[] | null {\r\n\r\n    const validators: ValidatorFn[] = [];\r\n\r\n    if (component?.validate?.required === true) {\r\n      validators.push(Validators.required);\r\n    }\r\n\r\n    if (!Array.isArray(component.validations)) {\r\n      if (validators.length == 0)\r\n        return null;\r\n      return validators;\r\n    }\r\n\r\n    component.validations?.forEach((item: any) => {\r\n      if (!this.programmabilityService.isExpression(item.expression))\r\n        return;\r\n\r\n      if (item.type === \"validate\") {\r\n        validators.push(this.validateFn(formGroup, item));\r\n      }\r\n      else if (item.type === \"invalidate\") {\r\n        validators.push(this.invalidateFn(formGroup, item));\r\n      }      \r\n    });\r\n\r\n    if (validators.length == 0)\r\n      return null;\r\n\r\n    return validators;\r\n  }\r\n\r\n  private validateFn(formGroup: FormGroup, item: any): ValidatorFn {\r\n    return (control: AbstractControl): ValidationErrors | null => {\r\n\r\n      //if (!control.touched)\r\n      //  return null;\r\n\r\n      var valid = this.programmabilityService.evaluateUnary(formGroup, item.expression, control.value);\r\n\r\n      if (!valid) {\r\n        return { error: true, message: item.message };\r\n      }\r\n      return null;\r\n    };\r\n  }\r\n\r\n  private invalidateFn(formGroup: FormGroup, item: any): ValidatorFn {\r\n    return (control: AbstractControl): ValidationErrors | null => {\r\n\r\n      //if (!control.touched)\r\n      //  return null;\r\n\r\n      var invalid = this.programmabilityService.evaluateUnary(formGroup, item.expression, control.value);\r\n\r\n      if (invalid) {\r\n        return { error: true, message: item.message };\r\n      }\r\n      return null;\r\n    };\r\n  }\r\n\r\n  private isFormComponent(component: any): boolean {\r\n    switch (component.type) {\r\n      case \"checkbox\":\r\n      case \"checklist\":\r\n      case \"datetime\":\r\n      case \"dynamiclist\":\r\n      case \"filepicker\":\r\n      case \"group\":\r\n      case \"number\":\r\n      case \"radio\":\r\n      case \"select\":\r\n      case \"taglist\":\r\n      case \"textarea\":\r\n      case \"textfield\":\r\n      case \"range\":\r\n        return true;\r\n      default:\r\n        return false;\r\n    }\r\n  }\r\n\r\n  private getUpdateOn(component: any): any {\r\n    switch (component.type) {\r\n      case \"number\":\r\n      case \"textarea\":\r\n      case \"textfield\":\r\n        return \"blur\";\r\n      default:\r\n        return null;\r\n    }\r\n  }\r\n\r\n  private getDefaultValue(component: any): any {\r\n    switch (component.type) {\r\n      case \"textarea\":\r\n      case \"textfield\":\r\n      case \"radio\":\r\n      case \"select\":\r\n        return component.defaultValue as string;\r\n      case \"number\":\r\n        return component.defaultValue as number;\r\n      case \"checkbox\":\r\n        return component.defaultValue as boolean;\r\n      default:\r\n        return null;\r\n    }\r\n  }\r\n\r\n  private splitPath(path: string): string[] {\r\n    if (!path) {\r\n      return [];\r\n    }\r\n    return path\r\n      .split('.')\r\n      .map(segment => segment.trim())\r\n      .filter(segment => segment.length > 0);\r\n  }\r\n\r\n  private patchValue(formGroup: FormGroup, value: any) {\r\n    patchForm(formGroup, value);\r\n  }\r\n}\r\n","<form [formGroup]=\"formGroup\" class=\"ngs\">\r\n\r\n  <div class=\"container-fluid\">\r\n    <div class=\"row\">\r\n\r\n      <!-- #region progress -->\r\n      <ngx-sirio-stepper-progress-bar *ngIf=\"showProgress\"\r\n        (eventClick)=\"activateForm($event.data.label)\" \r\n        [hasDropdown]=\"true\" \r\n        [dropDownLabel]=\"Texts.Show\">\r\n        <ngx-sirio-stepper-progress-item *ngFor=\"let form of forms\"\r\n                                         [hasNavigation]=\"true\"\r\n                                         [status]=\"getFormStatus(form)\"\r\n                                         [label]=\"form.title\" />\r\n      </ngx-sirio-stepper-progress-bar>\r\n      <!-- #endregion -->\r\n\r\n      <ng-container *ngIf=\"showNav\">\r\n\r\n        <div class=\"col-md-4\">\r\n\r\n          <!-- #region sidenav -->\r\n          <ng-template #sidenavTemplate>\r\n            <ngx-sirio-sidenav>\r\n              <ng-container *ngFor=\"let form of forms, let sectionIndex = index\">\r\n                <ngx-sirio-sidenav-item [isActive]=\"activeNav == sectionIndex\" (click)=\"activeNav = sectionIndex\">\r\n                  {{ form.title }}\r\n                </ngx-sirio-sidenav-item>\r\n              </ng-container>\r\n            </ngx-sirio-sidenav>\r\n          </ng-template>\r\n\r\n          <ngx-sirio-sidenav-mobile class=\"d-block d-lg-none\"\r\n                                    openMenuLabel=\"Apri Menu\"\r\n                                    openMenuAriaLabel=\"Apri Menu\"\r\n                                    closeMenuLabel=\"Chiudi Menu\"\r\n                                    closeMenuAriaLabel=\"Chiudi Menu\">\r\n            <ng-container *ngTemplateOutlet=\"sidenavTemplate\"></ng-container>\r\n          </ngx-sirio-sidenav-mobile>\r\n          <div class=\"d-none d-lg-block\">\r\n            <ng-container *ngTemplateOutlet=\"sidenavTemplate\"></ng-container>\r\n          </div>\r\n          <!-- #endregion -->\r\n\r\n        </div>\r\n\r\n        <div class=\"col-md-1\">\r\n          <div class=\"separator-horizontal\"></div>\r\n        </div>\r\n\r\n      </ng-container>\r\n\r\n      <div class=\"content-element-form\" [ngClass]=\"showNav ? 'col-md-11' : 'col-md-16'\">\r\n\r\n        <ng-container *ngFor=\"let form of forms, let sectionIndex = index\">\r\n          <div *ngIf=\"activeNav == sectionIndex\"\r\n               #default\r\n               [register]=\"form\"\r\n               [componentRef]=\"default\">\r\n            <app-dynamic-fields [formGroup]=\"getFormGroup(form.path)\" [rows]=\"form.rows\"></app-dynamic-fields>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"showNavButton\">\r\n\r\n          <div class=\"row section-navs\">\r\n            <div class=\"col-8 col-md-8\">\r\n              <ngx-sirio-button [color]=\"null\" [disabled]=\"!canNext()\" (click)=\"goNext()\" class=\"nextSection\">\r\n                {{ Texts.NextSection }}\r\n                <span class=\"fa-solid fa-chevron-right\" style=\"margin-left: 10px\"></span>\r\n              </ngx-sirio-button>\r\n            </div>\r\n            <div class=\"col-8 col-md-8\">\r\n              <ngx-sirio-button [color]=\"null\" [disabled]=\"!canPrevious()\" (click)=\"goPrevious()\" class=\"prevSection\">\r\n                <span class=\"fa-solid fa-chevron-left\" style=\"margin-right: 10px\"></span>\r\n                {{ Texts.PreviousSection }}\r\n              </ngx-sirio-button>\r\n            </div>\r\n          </div>\r\n\r\n        </ng-container>\r\n\r\n\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n</form>\r\n\r\n\r\n\r\n"]}
|
|
@@ -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":"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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"]}
|