@decaf-ts/for-angular 0.0.8 → 0.0.10

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 (105) hide show
  1. package/dist/{lib/assets → assets}/i18n/en.json +10 -1
  2. package/dist/components/empty-state/empty-state.component.d.ts +301 -0
  3. package/dist/components/fieldset/fieldset.component.d.ts +199 -0
  4. package/dist/components/filter/filter.component.d.ts +505 -0
  5. package/dist/components/for-angular-components.module.d.ts +20 -0
  6. package/dist/components/index.d.ts +16 -0
  7. package/dist/components/layout/layout.component.d.ts +133 -0
  8. package/dist/components/list/constants.d.ts +29 -0
  9. package/dist/components/list/list.component.d.ts +849 -0
  10. package/dist/components/list-item/list-item.component.d.ts +390 -0
  11. package/dist/{lib/components → components}/model-renderer/model-renderer.component.d.ts +1 -1
  12. package/dist/components/pagination/constants.d.ts +7 -0
  13. package/dist/components/pagination/pagination.component.d.ts +264 -0
  14. package/dist/components/searchbar/searchbar.component.d.ts +407 -0
  15. package/dist/directives/collapsable.directive.d.ts +8 -0
  16. package/dist/directives/index.d.ts +1 -0
  17. package/dist/engine/NgxBaseComponent.d.ts +541 -0
  18. package/dist/{lib/engine → engine}/index.d.ts +1 -0
  19. package/dist/{lib/engine → engine}/types.d.ts +44 -0
  20. package/dist/{lib/esm2022 → esm2022}/components/component-renderer/component-renderer.component.mjs +3 -3
  21. package/dist/esm2022/components/crud-field/crud-field.component.mjs +301 -0
  22. package/dist/esm2022/components/crud-form/constants.mjs +14 -0
  23. package/dist/esm2022/components/crud-form/crud-form.component.mjs +139 -0
  24. package/dist/esm2022/components/crud-form/types.mjs +2 -0
  25. package/dist/esm2022/components/empty-state/empty-state.component.mjs +348 -0
  26. package/dist/esm2022/components/fieldset/fieldset.component.mjs +225 -0
  27. package/dist/esm2022/components/filter/filter.component.mjs +689 -0
  28. package/dist/esm2022/components/for-angular-components.module.mjs +71 -0
  29. package/dist/esm2022/components/index.mjs +20 -0
  30. package/dist/esm2022/components/layout/layout.component.mjs +176 -0
  31. package/dist/esm2022/components/list/constants.mjs +6 -0
  32. package/dist/esm2022/components/list/list.component.mjs +1236 -0
  33. package/dist/esm2022/components/list-item/list-item.component.mjs +408 -0
  34. package/dist/esm2022/components/model-renderer/model-renderer.component.mjs +138 -0
  35. package/dist/esm2022/components/pagination/constants.mjs +2 -0
  36. package/dist/esm2022/components/pagination/pagination.component.mjs +323 -0
  37. package/dist/esm2022/components/searchbar/searchbar.component.mjs +493 -0
  38. package/dist/esm2022/decaf-ts-for-angular.mjs +5 -0
  39. package/dist/esm2022/directives/collapsable.directive.mjs +28 -0
  40. package/dist/esm2022/directives/index.mjs +2 -0
  41. package/dist/esm2022/engine/DynamicModule.mjs +18 -0
  42. package/dist/esm2022/engine/NgxBaseComponent.mjs +539 -0
  43. package/dist/esm2022/engine/NgxCrudFormField.mjs +125 -0
  44. package/dist/esm2022/engine/NgxFormService.mjs +315 -0
  45. package/dist/esm2022/engine/NgxRenderingEngine.mjs +192 -0
  46. package/dist/esm2022/engine/NgxRenderingEngine2.mjs +332 -0
  47. package/dist/esm2022/engine/ValidatorFactory.mjs +102 -0
  48. package/dist/esm2022/engine/constants.mjs +160 -0
  49. package/dist/esm2022/engine/decorators.mjs +38 -0
  50. package/dist/esm2022/engine/index.mjs +17 -0
  51. package/dist/esm2022/engine/types.mjs +4 -0
  52. package/dist/esm2022/for-angular.module.mjs +118 -0
  53. package/dist/esm2022/helpers/index.mjs +13 -0
  54. package/dist/esm2022/helpers/utils.mjs +415 -0
  55. package/dist/esm2022/interfaces.mjs +2 -0
  56. package/dist/esm2022/public-apis.mjs +14 -0
  57. package/dist/fesm2022/decaf-ts-for-angular.mjs +7109 -0
  58. package/dist/fesm2022/decaf-ts-for-angular.mjs.map +1 -0
  59. package/dist/helpers/index.d.ts +12 -0
  60. package/dist/helpers/utils.d.ts +253 -0
  61. package/dist/{lib/public-apis.d.ts → public-apis.d.ts} +4 -3
  62. package/package.json +5 -3
  63. package/dist/lib/esm2022/components/crud-field/crud-field.component.mjs +0 -297
  64. package/dist/lib/esm2022/components/crud-form/constants.mjs +0 -14
  65. package/dist/lib/esm2022/components/crud-form/crud-form.component.mjs +0 -139
  66. package/dist/lib/esm2022/components/crud-form/types.mjs +0 -2
  67. package/dist/lib/esm2022/components/model-renderer/model-renderer.component.mjs +0 -138
  68. package/dist/lib/esm2022/decaf-ts-for-angular.mjs +0 -5
  69. package/dist/lib/esm2022/engine/DynamicModule.mjs +0 -18
  70. package/dist/lib/esm2022/engine/NgxCrudFormField.mjs +0 -123
  71. package/dist/lib/esm2022/engine/NgxFormService.mjs +0 -315
  72. package/dist/lib/esm2022/engine/NgxRenderingEngine.mjs +0 -192
  73. package/dist/lib/esm2022/engine/NgxRenderingEngine2.mjs +0 -332
  74. package/dist/lib/esm2022/engine/ValidatorFactory.mjs +0 -102
  75. package/dist/lib/esm2022/engine/constants.mjs +0 -160
  76. package/dist/lib/esm2022/engine/decorators.mjs +0 -38
  77. package/dist/lib/esm2022/engine/index.mjs +0 -16
  78. package/dist/lib/esm2022/engine/types.mjs +0 -2
  79. package/dist/lib/esm2022/for-angular.module.mjs +0 -118
  80. package/dist/lib/esm2022/interfaces.mjs +0 -2
  81. package/dist/lib/esm2022/public-apis.mjs +0 -13
  82. package/dist/lib/fesm2022/decaf-ts-for-angular.mjs +0 -2153
  83. package/dist/lib/fesm2022/decaf-ts-for-angular.mjs.map +0 -1
  84. /package/dist/{lib/README.md → README.md} +0 -0
  85. /package/dist/{lib/assets → assets}/images/angular-logo.svg +0 -0
  86. /package/dist/{lib/assets → assets}/images/decaf-logo-black.svg +0 -0
  87. /package/dist/{lib/assets → assets}/images/decaf-logo-lw.svg +0 -0
  88. /package/dist/{lib/assets → assets}/images/decaf-logo-white.svg +0 -0
  89. /package/dist/{lib/assets → assets}/images/decaf-logo.svg +0 -0
  90. /package/dist/{lib/components → components}/component-renderer/component-renderer.component.d.ts +0 -0
  91. /package/dist/{lib/components → components}/crud-field/crud-field.component.d.ts +0 -0
  92. /package/dist/{lib/components → components}/crud-form/constants.d.ts +0 -0
  93. /package/dist/{lib/components → components}/crud-form/crud-form.component.d.ts +0 -0
  94. /package/dist/{lib/components → components}/crud-form/types.d.ts +0 -0
  95. /package/dist/{lib/engine → engine}/DynamicModule.d.ts +0 -0
  96. /package/dist/{lib/engine → engine}/NgxCrudFormField.d.ts +0 -0
  97. /package/dist/{lib/engine → engine}/NgxFormService.d.ts +0 -0
  98. /package/dist/{lib/engine → engine}/NgxRenderingEngine.d.ts +0 -0
  99. /package/dist/{lib/engine → engine}/NgxRenderingEngine2.d.ts +0 -0
  100. /package/dist/{lib/engine → engine}/ValidatorFactory.d.ts +0 -0
  101. /package/dist/{lib/engine → engine}/constants.d.ts +0 -0
  102. /package/dist/{lib/engine → engine}/decorators.d.ts +0 -0
  103. /package/dist/{lib/for-angular.module.d.ts → for-angular.module.d.ts} +0 -0
  104. /package/dist/{lib/index.d.ts → index.d.ts} +0 -0
  105. /package/dist/{lib/interfaces.d.ts → interfaces.d.ts} +0 -0
@@ -1,138 +0,0 @@
1
- import { Component, EventEmitter, inject, Injector, Input, Output, TemplateRef, ViewChild, ViewContainerRef, } from '@angular/core';
2
- import { Model, sf } from '@decaf-ts/decorator-validation';
3
- import { NgComponentOutlet } from '@angular/common';
4
- import { AngularEngineKeys, BaseComponentProps, NgxRenderingEngine2, } from '../../engine';
5
- import { ForAngularModule } from 'src/lib/for-angular.module';
6
- import { ComponentRendererComponent } from '../component-renderer/component-renderer.component';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "@angular/common";
9
- /**
10
- * @description Component for rendering dynamic models
11
- * @summary This component is responsible for dynamically rendering models,
12
- * handling model changes, and managing event subscriptions for the rendered components.
13
- * It uses the NgxRenderingEngine2 to render the models and supports both string and Model inputs.
14
- * @class
15
- * @template M - Type extending Model
16
- * @param {Injector} injector - Angular Injector for dependency injection
17
- * @example
18
- * <ngx-decaf-model-renderer
19
- * [model]="myModel"
20
- * [globals]="globalVariables"
21
- * (listenEvent)="handleEvent($event)">
22
- * </ngx-decaf-model-renderer>
23
- * @mermaid
24
- * sequenceDiagram
25
- * participant App
26
- * participant ModelRenderer
27
- * participant RenderingEngine
28
- * participant Model
29
- * App->>ModelRenderer: Input model
30
- * ModelRenderer->>Model: Parse if string
31
- * Model-->>ModelRenderer: Parsed model
32
- * ModelRenderer->>RenderingEngine: Render model
33
- * RenderingEngine-->>ModelRenderer: Rendered output
34
- * ModelRenderer->>ModelRenderer: Subscribe to events
35
- * ModelRenderer-->>App: Emit events
36
- */
37
- export class ModelRendererComponent {
38
- constructor() {
39
- /**
40
- * @description Global variables to be passed to the rendered component
41
- */
42
- this.globals = {};
43
- /**
44
- * @description Event emitter for custom events from the rendered component
45
- */
46
- this.listenEvent = new EventEmitter();
47
- this.injector = inject(Injector);
48
- this.JSON = JSON;
49
- }
50
- // constructor() {}
51
- /**
52
- * @description Refreshes the rendered model
53
- * @param {string | M} model - The model to be rendered
54
- */
55
- refresh(model) {
56
- model =
57
- typeof model === 'string'
58
- ? Model.build({}, model)
59
- : model;
60
- this.output = model.render(this.globals || {}, this.vcr, this.injector, this.inner);
61
- if (this.output?.inputs)
62
- this.rendererId = sf(AngularEngineKeys.RENDERED_ID, this.output.inputs['rendererId']);
63
- this.instance = this.output?.instance;
64
- this.subscribeEvents();
65
- }
66
- /**
67
- * @description Lifecycle hook that is called when data-bound properties of a directive change
68
- * @param {SimpleChanges} changes - Object containing changes
69
- */
70
- ngOnChanges(changes) {
71
- if (changes[BaseComponentProps.MODEL]) {
72
- const { currentValue } = changes[BaseComponentProps.MODEL];
73
- this.refresh(currentValue);
74
- }
75
- }
76
- /**
77
- * @description Lifecycle hook that is called when a directive, pipe, or service is destroyed
78
- * @return {Promise<void>}
79
- */
80
- async ngOnDestroy() {
81
- if (this.instance) {
82
- this.unsubscribeEvents();
83
- await NgxRenderingEngine2.destroy();
84
- }
85
- this.output = undefined;
86
- }
87
- subscribeEvents() {
88
- if (this.instance) {
89
- const componentKeys = Object.keys(this.instance);
90
- for (const key of componentKeys) {
91
- const value = this.instance[key];
92
- if (value instanceof EventEmitter)
93
- this.instance[key].subscribe((event) => {
94
- this.listenEvent.emit({
95
- component: this.output?.component.name || '',
96
- name: key,
97
- ...event,
98
- });
99
- });
100
- }
101
- }
102
- }
103
- /**
104
- * @description Unsubscribes from events emitted by the rendered component
105
- */
106
- unsubscribeEvents() {
107
- if (this.instance) {
108
- const componentKeys = Object.keys(this.instance);
109
- for (const key of componentKeys) {
110
- const value = this.instance[key];
111
- if (value instanceof EventEmitter)
112
- this.instance[key].unsubscribe();
113
- }
114
- }
115
- }
116
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ModelRendererComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
117
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ModelRendererComponent, isStandalone: true, selector: "ngx-decaf-model-renderer", inputs: { model: "model", globals: "globals", rendererId: "rendererId" }, outputs: { listenEvent: "listenEvent" }, viewQueries: [{ propertyName: "inner", first: true, predicate: ["inner"], descendants: true, read: TemplateRef, static: true }, { propertyName: "vcr", first: true, predicate: ["componentOuter"], descendants: true, read: ViewContainerRef, static: true }], usesOnChanges: true, ngImport: i0, template: " <ng-template #componentOuter></ng-template>\n <ng-template #inner>\n <div [id]=\"rendererId || null\">\n @for (child of output?.children; track child) {\n @if(child?.children?.length) {\n <ngx-decaf-component-renderer [parent]=\"child\" />\n } @else {\n <ng-container\n #childComponents\n *ngComponentOutlet=\"\n child.component;\n injector: child.injector;\n inputs: child.inputs;\n content:child.content;\n \"\n />\n }\n }\n </div>\n </ng-template>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: ForAngularModule }, { kind: "directive", type: i1.NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }, { kind: "component", type: ComponentRendererComponent, selector: "ngx-decaf-component-renderer", inputs: ["tag", "globals", "model", "parent"], outputs: ["listenEvent"] }] }); }
118
- }
119
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ModelRendererComponent, decorators: [{
120
- type: Component,
121
- args: [{ standalone: true, imports: [ForAngularModule, NgComponentOutlet, ComponentRendererComponent], selector: 'ngx-decaf-model-renderer', template: " <ng-template #componentOuter></ng-template>\n <ng-template #inner>\n <div [id]=\"rendererId || null\">\n @for (child of output?.children; track child) {\n @if(child?.children?.length) {\n <ngx-decaf-component-renderer [parent]=\"child\" />\n } @else {\n <ng-container\n #childComponents\n *ngComponentOutlet=\"\n child.component;\n injector: child.injector;\n inputs: child.inputs;\n content:child.content;\n \"\n />\n }\n }\n </div>\n </ng-template>\n" }]
122
- }], propDecorators: { model: [{
123
- type: Input,
124
- args: [{ required: true }]
125
- }], globals: [{
126
- type: Input
127
- }], inner: [{
128
- type: ViewChild,
129
- args: ['inner', { read: TemplateRef, static: true }]
130
- }], rendererId: [{
131
- type: Input
132
- }], vcr: [{
133
- type: ViewChild,
134
- args: ['componentOuter', { static: true, read: ViewContainerRef }]
135
- }], listenEvent: [{
136
- type: Output
137
- }] } });
138
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"model-renderer.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/model-renderer/model-renderer.component.ts","../../../../../src/lib/components/model-renderer/model-renderer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  inject,\n  Injector,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport { Model, sf } from '@decaf-ts/decorator-validation';\nimport { NgComponentOutlet } from '@angular/common';\nimport {\n  AngularDynamicOutput,\n  AngularEngineKeys,\n  BaseComponentProps,\n  BaseCustomEvent,\n  NgxRenderingEngine2,\n  RenderedModel,\n} from '../../engine';\nimport { KeyValue, RendererCustomEvent } from 'src/lib/engine/types';\nimport { ForAngularModule } from 'src/lib/for-angular.module';\nimport { Renderable } from '@decaf-ts/ui-decorators';\nimport { ComponentRendererComponent } from '../component-renderer/component-renderer.component';\n\n/**\n * @description Component for rendering dynamic models\n * @summary This component is responsible for dynamically rendering models,\n * handling model changes, and managing event subscriptions for the rendered components.\n * It uses the NgxRenderingEngine2 to render the models and supports both string and Model inputs.\n * @class\n * @template M - Type extending Model\n * @param {Injector} injector - Angular Injector for dependency injection\n * @example\n * <ngx-decaf-model-renderer\n *   [model]=\"myModel\"\n *   [globals]=\"globalVariables\"\n *   (listenEvent)=\"handleEvent($event)\">\n * </ngx-decaf-model-renderer>\n * @mermaid\n * sequenceDiagram\n *   participant App\n *   participant ModelRenderer\n *   participant RenderingEngine\n *   participant Model\n *   App->>ModelRenderer: Input model\n *   ModelRenderer->>Model: Parse if string\n *   Model-->>ModelRenderer: Parsed model\n *   ModelRenderer->>RenderingEngine: Render model\n *   RenderingEngine-->>ModelRenderer: Rendered output\n *   ModelRenderer->>ModelRenderer: Subscribe to events\n *   ModelRenderer-->>App: Emit events\n */\n@Component({\n  standalone: true,\n  imports: [ForAngularModule, NgComponentOutlet, ComponentRendererComponent],\n  selector: 'ngx-decaf-model-renderer',\n  templateUrl: './model-renderer.component.html',\n  styleUrl: './model-renderer.component.scss',\n})\nexport class ModelRendererComponent<M extends Model>\n  implements OnChanges, OnDestroy, RenderedModel {\n\n  /**\n   * @description Input model to be rendered\n   * @summary Can be a Model instance or a JSON string representation of a model\n   */\n  @Input({ required: true })\n  model!: M | string | undefined;\n\n  /**\n   * @description Global variables to be passed to the rendered component\n   */\n  @Input()\n  globals: Record<string, unknown> = {};\n\n  /**\n   * @description Template reference for inner content\n   */\n  @ViewChild('inner', { read: TemplateRef, static: true })\n  inner?: TemplateRef<unknown>;\n\n  /**\n   * @description Output of the rendered model\n   */\n  output?: AngularDynamicOutput;\n\n  /**\n   * @description Unique identifier for the renderer\n   */\n  @Input()\n  rendererId?: string;\n\n  /**\n   * @description View container reference for dynamic component rendering\n   */\n  @ViewChild('componentOuter', { static: true, read: ViewContainerRef })\n  vcr!: ViewContainerRef;\n\n  /**\n   * @description Event emitter for custom events from the rendered component\n   */\n  @Output()\n  listenEvent = new EventEmitter<RendererCustomEvent>();\n\n  /**\n   * @description Instance of the NgxRenderingEngine2\n   */\n  private render!: NgxRenderingEngine2;\n\n  /**\n   * @description Instance of the rendered component\n   */\n  private instance!: KeyValue | undefined;\n\n  private injector: Injector = inject(Injector);\n\n  // constructor() {}\n\n  /**\n   * @description Refreshes the rendered model\n   * @param {string | M} model - The model to be rendered\n   */\n  private refresh(model: string | M) {\n    model =\n      typeof model === 'string'\n        ? (Model.build({}, model) as M)\n        : model;\n    this.output = (model as unknown as Renderable).render<AngularDynamicOutput>(\n      this.globals || {},\n      this.vcr,\n      this.injector,\n      this.inner,\n    );\n    if (this.output?.inputs)\n      this.rendererId = sf(\n        AngularEngineKeys.RENDERED_ID,\n        (this.output.inputs as Record<string, unknown>)['rendererId'] as string,\n      );\n    this.instance = this.output?.instance;\n    this.subscribeEvents();\n  }\n\n  /**\n   * @description Lifecycle hook that is called when data-bound properties of a directive change\n   * @param {SimpleChanges} changes - Object containing changes\n   */\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes[BaseComponentProps.MODEL]) {\n      const { currentValue } = changes[BaseComponentProps.MODEL];\n      this.refresh(currentValue);\n    }\n  }\n\n  /**\n   * @description Lifecycle hook that is called when a directive, pipe, or service is destroyed\n   * @return {Promise<void>}\n   */\n  async ngOnDestroy(): Promise<void> {\n    if (this.instance) {\n      this.unsubscribeEvents();\n      await NgxRenderingEngine2.destroy();\n    }\n    this.output = undefined;\n  }\n\n  private subscribeEvents(): void {\n    if (this.instance) {\n      const componentKeys = Object.keys(this.instance);\n      for (const key of componentKeys) {\n        const value = this.instance[key];\n        if (value instanceof EventEmitter)\n          (this.instance as KeyValue)[key].subscribe((event: Partial<BaseCustomEvent>) => {\n            this.listenEvent.emit({\n              component: this.output?.component.name || '',\n              name: key,\n              ...event,\n            } as RendererCustomEvent);\n          });\n      }\n    }\n  }\n\n  /**\n   * @description Unsubscribes from events emitted by the rendered component\n   */\n  private unsubscribeEvents(): void {\n    if (this.instance) {\n      const componentKeys = Object.keys(this.instance);\n      for (const key of componentKeys) {\n        const value = this.instance[key];\n        if (value instanceof EventEmitter)\n          this.instance[key].unsubscribe();\n      }\n    }\n  }\n\n  protected readonly JSON = JSON;\n}\n","  <ng-template #componentOuter></ng-template>\n  <ng-template #inner>\n    <div  [id]=\"rendererId || null\">\n      @for (child of output?.children; track child) {\n        @if(child?.children?.length) {\n          <ngx-decaf-component-renderer [parent]=\"child\" />\n        } @else {\n          <ng-container\n            #childComponents\n            *ngComponentOutlet=\"\n              child.component;\n              injector: child.injector;\n              inputs: child.inputs;\n              content:child.content;\n            \"\n          />\n        }\n      }\n    </div>\n  </ng-template>\n"]}
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './public-apis';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVjYWYtdHMtZm9yLWFuZ3VsYXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2RlY2FmLXRzLWZvci1hbmd1bGFyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxlQUFlLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljLWFwaXMnO1xuIl19
@@ -1,18 +0,0 @@
1
- /**
2
- * @description Abstract base class for dynamic Angular modules
3
- * @summary The DynamicModule serves as a base class for Angular modules that need to be
4
- * dynamically loaded or configured at runtime. It provides a common type for the rendering
5
- * engine to identify and work with dynamic modules.
6
- * @class DynamicModule
7
- * @example
8
- * ```typescript
9
- * @NgModule({
10
- * declarations: [MyComponent],
11
- * imports: [CommonModule]
12
- * })
13
- * export class MyDynamicModule extends DynamicModule {}
14
- * ```
15
- */
16
- export class DynamicModule {
17
- }
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRHluYW1pY01vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvZW5naW5lL0R5bmFtaWNNb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7O0dBY0c7QUFDSCxNQUFNLE9BQWdCLGFBQWE7Q0FBRyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGRlc2NyaXB0aW9uIEFic3RyYWN0IGJhc2UgY2xhc3MgZm9yIGR5bmFtaWMgQW5ndWxhciBtb2R1bGVzXG4gKiBAc3VtbWFyeSBUaGUgRHluYW1pY01vZHVsZSBzZXJ2ZXMgYXMgYSBiYXNlIGNsYXNzIGZvciBBbmd1bGFyIG1vZHVsZXMgdGhhdCBuZWVkIHRvIGJlXG4gKiBkeW5hbWljYWxseSBsb2FkZWQgb3IgY29uZmlndXJlZCBhdCBydW50aW1lLiBJdCBwcm92aWRlcyBhIGNvbW1vbiB0eXBlIGZvciB0aGUgcmVuZGVyaW5nXG4gKiBlbmdpbmUgdG8gaWRlbnRpZnkgYW5kIHdvcmsgd2l0aCBkeW5hbWljIG1vZHVsZXMuXG4gKiBAY2xhc3MgRHluYW1pY01vZHVsZVxuICogQGV4YW1wbGVcbiAqIGBgYHR5cGVzY3JpcHRcbiAqIEBOZ01vZHVsZSh7XG4gKiAgIGRlY2xhcmF0aW9uczogW015Q29tcG9uZW50XSxcbiAqICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV1cbiAqIH0pXG4gKiBleHBvcnQgY2xhc3MgTXlEeW5hbWljTW9kdWxlIGV4dGVuZHMgRHluYW1pY01vZHVsZSB7fVxuICogYGBgXG4gKi9cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBEeW5hbWljTW9kdWxlIHt9XG4iXX0=
@@ -1,123 +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
- /**
8
- * @class NgxCrudFormField
9
- * @implements {FieldProperties}
10
- * @implements {ControlValueAccessor}
11
- * @summary Abstract class representing a CRUD form field for Angular applications
12
- * @description This class provides the base implementation for CRUD form fields in Angular,
13
- * implementing both CrudFormField and ControlValueAccessor interfaces.
14
- */
15
- export class NgxCrudFormField {
16
- constructor() {
17
- this.translateService = inject(TranslateService);
18
- // protected constructor() {}
19
- /**
20
- * @summary String formatting function
21
- * @description Provides access to the sf function for error message formatting
22
- * @prop {function(string, ...string): string} sf - String formatting function
23
- */
24
- this.sf = sf;
25
- /**
26
- * @summary Change callback function
27
- * @description Function called when the field value changes
28
- * @property {function(): unknown} onChange - onChange event handler
29
- */
30
- this.onChange = () => { };
31
- /**
32
- * @summary Touch callback function
33
- * @description Function called when the field is touched
34
- * @property {function(): unknown} onTouch - onTouch event handler
35
- */
36
- this.onTouch = () => { };
37
- }
38
- /**
39
- * @summary Write value to the field
40
- * @description Sets the value of the field
41
- * @param {string} obj - The value to be set
42
- */
43
- writeValue(obj) {
44
- this.value = obj;
45
- }
46
- /**
47
- * @summary Register change callback
48
- * @description Registers a function to be called when the field value changes
49
- * @param {function(): unknown} fn - The function to be called on change
50
- */
51
- registerOnChange(fn) {
52
- this.onChange = fn;
53
- }
54
- /**
55
- * @summary Register touch callback
56
- * @description Registers a function to be called when the field is touched
57
- * @param {function(): unknown} fn - The function to be called on touch
58
- */
59
- registerOnTouched(fn) {
60
- this.onTouch = fn;
61
- }
62
- /**
63
- * @summary Set disabled state
64
- * @description Sets the disabled state of the field
65
- * @param {boolean} isDisabled - Whether the field should be disabled
66
- */
67
- setDisabledState(isDisabled) {
68
- this.disabled = isDisabled;
69
- }
70
- /**
71
- * @summary After view initialization logic
72
- * @description Performs necessary setup after the view has been initialized
73
- * @returns {HTMLElement} The parent element of the field
74
- */
75
- afterViewInit() {
76
- let parent;
77
- switch (this.operation) {
78
- case OperationKeys.READ:
79
- case OperationKeys.DELETE:
80
- return this.component.nativeElement.parentElement;
81
- case OperationKeys.CREATE:
82
- case OperationKeys.UPDATE:
83
- try {
84
- parent = NgxFormService.getParentEl(this.component.nativeElement, 'div');
85
- }
86
- catch (e) {
87
- throw new RenderingError(`Unable to retrieve parent form element for the ${this.operation}: ${e instanceof Error ? e.message : e}`);
88
- }
89
- // NgxFormService.register(parent.id, this.formGroup, this as AngularFieldDefinition);
90
- return parent;
91
- default:
92
- throw new InternalError(`Invalid operation: ${this.operation}`);
93
- }
94
- }
95
- /**
96
- * @summary Cleanup on component destruction
97
- * @description Unregisters the field when the component is destroyed
98
- */
99
- onDestroy() {
100
- if (this.formGroup)
101
- NgxFormService.unregister(this.formGroup);
102
- }
103
- /**
104
- * @summary Get field errors
105
- * @description Retrieves all errors associated with the field
106
- * @returns {string|void} An array of error objects
107
- */
108
- getErrors(parent) {
109
- const formControl = this.formControl;
110
- if ((!formControl.pristine || formControl.touched) && !formControl.valid) {
111
- const collapsableContainer = parent.closest('ion-accordion-group');
112
- if (collapsableContainer)
113
- collapsableContainer.setAttribute('value', 'open');
114
- const errors = Object.keys(formControl.errors ?? {}).map(key => ({
115
- key: key,
116
- message: key,
117
- }));
118
- for (const error of errors)
119
- return `* ${this.sf(this.translateService.instant(`errors.${error?.['message']}`), this[error?.['key']] ?? "")}`;
120
- }
121
- }
122
- }
123
- //# 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 { 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';\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  // Validation\n\n  format?: string;\n  hidden?: boolean;\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  private translateService = inject(TranslateService);\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  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  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.pristine || formControl.touched) && !formControl.valid) {\n      const collapsableContainer = parent.closest('ion-accordion-group');\n      if(collapsableContainer)\n        collapsableContainer.setAttribute('value', 'open');\n      const errors: Record<string, string>[] = Object.keys(formControl.errors ?? {}).map(key => ({\n        key: key,\n        message: key,\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"]}