@decaf-ts/for-angular 0.0.25 → 0.0.26

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (78) hide show
  1. package/fesm2022/decaf-ts-for-angular.mjs +1465 -1488
  2. package/fesm2022/decaf-ts-for-angular.mjs.map +1 -1
  3. package/index.d.ts +7470 -3
  4. package/package.json +14 -17
  5. package/components/component-renderer/component-renderer.component.d.ts +0 -278
  6. package/components/crud-field/crud-field.component.d.ts +0 -611
  7. package/components/crud-form/constants.d.ts +0 -5
  8. package/components/crud-form/crud-form.component.d.ts +0 -288
  9. package/components/crud-form/types.d.ts +0 -17
  10. package/components/empty-state/empty-state.component.d.ts +0 -300
  11. package/components/fieldset/fieldset.component.d.ts +0 -555
  12. package/components/filter/filter.component.d.ts +0 -514
  13. package/components/for-angular-components.module.d.ts +0 -20
  14. package/components/index.d.ts +0 -16
  15. package/components/layout/layout.component.d.ts +0 -110
  16. package/components/list/list.component.d.ts +0 -848
  17. package/components/list-item/list-item.component.d.ts +0 -390
  18. package/components/model-renderer/model-renderer.component.d.ts +0 -97
  19. package/components/pagination/constants.d.ts +0 -7
  20. package/components/pagination/pagination.component.d.ts +0 -264
  21. package/components/searchbar/searchbar.component.d.ts +0 -407
  22. package/components/stepped-form/stepped-form.component.d.ts +0 -255
  23. package/directives/collapsable.directive.d.ts +0 -9
  24. package/directives/index.d.ts +0 -1
  25. package/engine/DynamicModule.d.ts +0 -17
  26. package/engine/NgxBaseComponent.d.ts +0 -541
  27. package/engine/NgxCrudFormField.d.ts +0 -123
  28. package/engine/NgxFormService.d.ts +0 -601
  29. package/engine/NgxRenderingEngine.d.ts +0 -282
  30. package/engine/ValidatorFactory.d.ts +0 -15
  31. package/engine/constants.d.ts +0 -168
  32. package/engine/decorators.d.ts +0 -25
  33. package/engine/index.d.ts +0 -18
  34. package/engine/interfaces.d.ts +0 -271
  35. package/engine/types.d.ts +0 -200
  36. package/esm2022/components/component-renderer/component-renderer.component.mjs +0 -321
  37. package/esm2022/components/crud-field/crud-field.component.mjs +0 -518
  38. package/esm2022/components/crud-form/constants.mjs +0 -14
  39. package/esm2022/components/crud-form/crud-form.component.mjs +0 -259
  40. package/esm2022/components/crud-form/types.mjs +0 -2
  41. package/esm2022/components/empty-state/empty-state.component.mjs +0 -345
  42. package/esm2022/components/fieldset/fieldset.component.mjs +0 -677
  43. package/esm2022/components/filter/filter.component.mjs +0 -700
  44. package/esm2022/components/for-angular-components.module.mjs +0 -84
  45. package/esm2022/components/index.mjs +0 -20
  46. package/esm2022/components/layout/layout.component.mjs +0 -150
  47. package/esm2022/components/list/list.component.mjs +0 -1238
  48. package/esm2022/components/list-item/list-item.component.mjs +0 -405
  49. package/esm2022/components/model-renderer/model-renderer.component.mjs +0 -144
  50. package/esm2022/components/pagination/constants.mjs +0 -2
  51. package/esm2022/components/pagination/pagination.component.mjs +0 -321
  52. package/esm2022/components/searchbar/searchbar.component.mjs +0 -491
  53. package/esm2022/components/stepped-form/stepped-form.component.mjs +0 -306
  54. package/esm2022/decaf-ts-for-angular.mjs +0 -5
  55. package/esm2022/directives/collapsable.directive.mjs +0 -29
  56. package/esm2022/directives/index.mjs +0 -2
  57. package/esm2022/engine/DynamicModule.mjs +0 -18
  58. package/esm2022/engine/NgxBaseComponent.mjs +0 -541
  59. package/esm2022/engine/NgxCrudFormField.mjs +0 -137
  60. package/esm2022/engine/NgxFormService.mjs +0 -917
  61. package/esm2022/engine/NgxRenderingEngine.mjs +0 -376
  62. package/esm2022/engine/ValidatorFactory.mjs +0 -106
  63. package/esm2022/engine/constants.mjs +0 -170
  64. package/esm2022/engine/decorators.mjs +0 -38
  65. package/esm2022/engine/index.mjs +0 -19
  66. package/esm2022/engine/interfaces.mjs +0 -4
  67. package/esm2022/engine/types.mjs +0 -2
  68. package/esm2022/for-angular-common.module.mjs +0 -84
  69. package/esm2022/helpers/index.mjs +0 -13
  70. package/esm2022/helpers/utils.mjs +0 -436
  71. package/esm2022/i18n/Loader.mjs +0 -86
  72. package/esm2022/i18n/data/en.json +0 -85
  73. package/esm2022/public-apis.mjs +0 -15
  74. package/for-angular-common.module.d.ts +0 -50
  75. package/helpers/index.d.ts +0 -12
  76. package/helpers/utils.d.ts +0 -279
  77. package/i18n/Loader.d.ts +0 -43
  78. package/public-apis.d.ts +0 -14
@@ -1,137 +0,0 @@
1
- import { RenderingError } from '@decaf-ts/ui-decorators';
2
- import { InternalError, OperationKeys } from '@decaf-ts/db-decorators';
3
- import { inject } from '@angular/core';
4
- import { NgxFormService } from './NgxFormService';
5
- import { sf } from '@decaf-ts/decorator-validation';
6
- import { TranslateService } from '@ngx-translate/core';
7
- import { EventConstants } from './constants';
8
- /**
9
- * @class NgxCrudFormField
10
- * @implements {FieldProperties}
11
- * @implements {ControlValueAccessor}
12
- * @summary Abstract class representing a CRUD form field for Angular applications
13
- * @description This class provides the base implementation for CRUD form fields in Angular,
14
- * implementing both CrudFormField and ControlValueAccessor interfaces.
15
- */
16
- export class NgxCrudFormField {
17
- constructor() {
18
- this.translateService = inject(TranslateService);
19
- this.validationErrorEventDispateched = false;
20
- // protected constructor() {}
21
- /**
22
- * @summary String formatting function
23
- * @description Provides access to the sf function for error message formatting
24
- * @prop {function(string, ...string): string} sf - String formatting function
25
- */
26
- this.sf = sf;
27
- /**
28
- * @summary Change callback function
29
- * @description Function called when the field value changes
30
- * @property {function(): unknown} onChange - onChange event handler
31
- */
32
- // eslint-disable-next-line @typescript-eslint/no-empty-function
33
- this.onChange = () => { };
34
- /**
35
- * @summary Touch callback function
36
- * @description Function called when the field is touched
37
- * @property {function(): unknown} onTouch - onTouch event handler
38
- */
39
- // eslint-disable-next-line @typescript-eslint/no-empty-function
40
- this.onTouch = () => { };
41
- }
42
- /**
43
- * @summary Write value to the field
44
- * @description Sets the value of the field
45
- * @param {string} obj - The value to be set
46
- */
47
- writeValue(obj) {
48
- this.value = obj;
49
- }
50
- /**
51
- * @summary Register change callback
52
- * @description Registers a function to be called when the field value changes
53
- * @param {function(): unknown} fn - The function to be called on change
54
- */
55
- registerOnChange(fn) {
56
- this.onChange = fn;
57
- }
58
- /**
59
- * @summary Register touch callback
60
- * @description Registers a function to be called when the field is touched
61
- * @param {function(): unknown} fn - The function to be called on touch
62
- */
63
- registerOnTouched(fn) {
64
- this.onTouch = fn;
65
- }
66
- /**
67
- * @summary Set disabled state
68
- * @description Sets the disabled state of the field
69
- * @param {boolean} isDisabled - Whether the field should be disabled
70
- */
71
- setDisabledState(isDisabled) {
72
- this.disabled = isDisabled;
73
- }
74
- /**
75
- * @summary After view initialization logic
76
- * @description Performs necessary setup after the view has been initialized
77
- * @returns {HTMLElement} The parent element of the field
78
- */
79
- afterViewInit() {
80
- let parent;
81
- switch (this.operation) {
82
- case OperationKeys.READ:
83
- case OperationKeys.DELETE:
84
- return this.component.nativeElement.parentElement;
85
- case OperationKeys.CREATE:
86
- case OperationKeys.UPDATE:
87
- try {
88
- parent = NgxFormService.getParentEl(this.component.nativeElement, 'div');
89
- }
90
- catch (e) {
91
- throw new RenderingError(`Unable to retrieve parent form element for the ${this.operation}: ${e instanceof Error ? e.message : e}`);
92
- }
93
- // NgxFormService.register(parent.id, this.formGroup, this as AngularFieldDefinition);
94
- return parent;
95
- default:
96
- throw new InternalError(`Invalid operation: ${this.operation}`);
97
- }
98
- }
99
- /**
100
- * @summary Cleanup on component destruction
101
- * @description Unregisters the field when the component is destroyed
102
- */
103
- onDestroy() {
104
- if (this.formGroup)
105
- NgxFormService.unregister(this.formGroup);
106
- }
107
- /**
108
- * @summary Get field errors
109
- * @description Retrieves all errors associated with the field
110
- * @returns {string|void} An array of error objects
111
- */
112
- getErrors(parent) {
113
- const formControl = this.formControl;
114
- if (formControl) {
115
- const accordionComponent = parent.closest('ngx-decaf-fieldset')?.querySelector('ion-accordion-group');
116
- if ((!formControl.pristine || formControl.touched) && !formControl.valid) {
117
- const errors = Object.keys(formControl.errors ?? {}).map(key => ({
118
- key: key,
119
- message: key,
120
- }));
121
- if (errors.length) {
122
- if (accordionComponent && !this.validationErrorEventDispateched) {
123
- const validationErrorEvent = new CustomEvent(EventConstants.VALIDATION_ERROR, {
124
- detail: { fieldName: this.name, hasErrors: true },
125
- bubbles: true
126
- });
127
- accordionComponent.dispatchEvent(validationErrorEvent);
128
- this.validationErrorEventDispateched = true;
129
- }
130
- }
131
- for (const error of errors)
132
- return `* ${this.sf(this.translateService.instant(`errors.${error?.['message']}`), this[error?.['key']] ?? "")}`;
133
- }
134
- }
135
- }
136
- }
137
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"NgxCrudFormField.js","sourceRoot":"","sources":["../../../../src/lib/engine/NgxCrudFormField.ts"],"names":[],"mappings":"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","sourcesContent":["import { CrudOperationKeys, FieldProperties, RenderingError } from '@decaf-ts/ui-decorators';\nimport { KeyValue, PossibleInputTypes } from './types';\nimport { CrudOperations, InternalError, OperationKeys } from '@decaf-ts/db-decorators';\nimport { ControlValueAccessor, FormControl, FormGroup } from '@angular/forms';\nimport { ElementRef, inject } from '@angular/core';\nimport { NgxFormService } from './NgxFormService';\nimport { sf } from '@decaf-ts/decorator-validation';\nimport { TranslateService } from '@ngx-translate/core';\nimport { EventConstants } from './constants';\n\n/**\n * @class NgxCrudFormField\n * @implements {FieldProperties}\n * @implements {ControlValueAccessor}\n * @summary Abstract class representing a CRUD form field for Angular applications\n * @description This class provides the base implementation for CRUD form fields in Angular,\n * implementing both CrudFormField and ControlValueAccessor interfaces.\n */\nexport abstract class NgxCrudFormField implements ControlValueAccessor, FieldProperties {\n  /**\n   * @summary Reference to the component's element\n   * @description ElementRef representing the component's native element\n   */\n  component!: ElementRef;\n\n  /**\n   * @summary Current CRUD operation\n   * @description Represents the current CRUD operation being performed\n   */\n  operation!: CrudOperations;\n\n  /**\n   * @summary Form group for the field\n   * @description Angular FormGroup instance for the field\n   */\n  formGroup!: FormGroup | undefined;\n\n  formControl!: FormControl;\n\n  name!: string;\n\n  path!: string;\n\n  childOf?: string;\n\n  type!: PossibleInputTypes;\n\n  disabled?: boolean;\n\n  uid?: string;\n\n  page!: number;\n\n  // Validation\n\n  format?: string;\n  hidden?: boolean | CrudOperationKeys[];\n  max?: number | Date;\n  maxlength?: number;\n  min?: number | Date;\n  minlength?: number;\n  pattern?: string | undefined;\n  readonly?: boolean;\n  required?: boolean;\n  step?: number;\n  equals?: string;\n  different?: string;\n  lessThan?: string;\n  lessThanOrEqual?: string;\n  greaterThan?: string;\n  greaterThanOrEqual?: string;\n\n  value!: string | number | Date;\n\n  multiple!: boolean;\n\n  protected translateService = inject(TranslateService);\n\n  private validationErrorEventDispateched: boolean = false;\n\n  /**\n   * @summary Parent HTML element\n   * @description Reference to the parent HTML element of the field\n   */\n  protected parent?: HTMLElement;\n\n  // protected constructor() {}\n\n  /**\n   * @summary String formatting function\n   * @description Provides access to the sf function for error message formatting\n   * @prop {function(string, ...string): string} sf - String formatting function\n   */\n  sf = sf;\n\n  /**\n   * @summary Change callback function\n   * @description Function called when the field value changes\n   * @property {function(): unknown} onChange - onChange event handler\n   */\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange: () => unknown = () => {};\n\n  /**\n   * @summary Touch callback function\n   * @description Function called when the field is touched\n   * @property {function(): unknown} onTouch - onTouch event handler\n   */\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouch: () => unknown = () => {};\n\n  /**\n   * @summary Write value to the field\n   * @description Sets the value of the field\n   * @param {string} obj - The value to be set\n   */\n  writeValue(obj: string): void {\n    this.value = obj;\n  }\n\n  /**\n   * @summary Register change callback\n   * @description Registers a function to be called when the field value changes\n   * @param {function(): unknown} fn - The function to be called on change\n   */\n  registerOnChange(fn: () => unknown): void {\n    this.onChange = fn;\n  }\n\n  /**\n   * @summary Register touch callback\n   * @description Registers a function to be called when the field is touched\n   * @param {function(): unknown} fn - The function to be called on touch\n   */\n  registerOnTouched(fn: () => unknown): void {\n    this.onTouch = fn;\n  }\n\n  /**\n   * @summary Set disabled state\n   * @description Sets the disabled state of the field\n   * @param {boolean} isDisabled - Whether the field should be disabled\n   */\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  /**\n   * @summary After view initialization logic\n   * @description Performs necessary setup after the view has been initialized\n   * @returns {HTMLElement} The parent element of the field\n   */\n  afterViewInit(): HTMLElement {\n    let parent: HTMLElement;\n    switch (this.operation) {\n      case OperationKeys.READ:\n      case OperationKeys.DELETE:\n        return this.component.nativeElement.parentElement;\n      case OperationKeys.CREATE:\n      case OperationKeys.UPDATE:\n        try {\n          parent = NgxFormService.getParentEl(this.component.nativeElement, 'div');\n        } catch (e: unknown) {\n          throw new RenderingError(`Unable to retrieve parent form element for the ${this.operation}: ${e instanceof Error ? e.message : e}`);\n        }\n        // NgxFormService.register(parent.id, this.formGroup, this as AngularFieldDefinition);\n        return parent;\n      default:\n        throw new InternalError(`Invalid operation: ${this.operation}`);\n    }\n  }\n\n  /**\n   * @summary Cleanup on component destruction\n   * @description Unregisters the field when the component is destroyed\n   */\n  onDestroy(): void {\n    if(this.formGroup)\n      NgxFormService.unregister(this.formGroup);\n  }\n\n  /**\n   * @summary Get field errors\n   * @description Retrieves all errors associated with the field\n   * @returns {string|void} An array of error objects\n   */\n  getErrors(parent: HTMLElement): string | void {\n    const formControl = this.formControl;\n    if(formControl) {\n      const accordionComponent = parent.closest('ngx-decaf-fieldset')?.querySelector('ion-accordion-group');\n      if((!formControl.pristine || formControl.touched) && !formControl.valid) {\n        const errors: Record<string, string>[] = Object.keys(formControl.errors ?? {}).map(key => ({\n          key: key,\n          message: key,\n        }));\n        if(errors.length) {\n          if(accordionComponent && !this.validationErrorEventDispateched) {\n            const validationErrorEvent = new CustomEvent(EventConstants.VALIDATION_ERROR, {\n              detail: {fieldName: this.name, hasErrors: true},\n              bubbles: true\n            });\n            accordionComponent.dispatchEvent(validationErrorEvent);\n            this.validationErrorEventDispateched = true;\n          }\n        }\n        for(const error of errors)\n          return `* ${this.sf(this.translateService.instant(`errors.${error?.['message']}`), (this as KeyValue)[error?.['key']] ?? \"\")}`;\n      }\n    }\n\n  }\n}\n"]}