@decaf-ts/for-angular 0.0.3 → 0.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (87) hide show
  1. package/LICENSE.md +659 -21
  2. package/README.md +37 -242
  3. package/dist/lib/README.md +92 -0
  4. package/dist/lib/assets/i18n/en.json +131 -0
  5. package/dist/lib/assets/images/angular-logo.svg +45 -0
  6. package/dist/lib/assets/images/decaf-logo-black.svg +22 -0
  7. package/dist/lib/assets/images/decaf-logo-lw.svg +50 -0
  8. package/dist/lib/assets/images/decaf-logo-white.svg +22 -0
  9. package/dist/lib/assets/images/decaf-logo.svg +54 -0
  10. package/dist/lib/components/component-renderer/component-renderer.component.d.ts +267 -0
  11. package/dist/lib/components/crud-field/crud-field.component.d.ts +447 -0
  12. package/dist/lib/components/crud-form/crud-form.component.d.ts +102 -0
  13. package/dist/lib/components/model-renderer/model-renderer.component.d.ts +97 -0
  14. package/dist/lib/engine/DynamicModule.d.ts +17 -0
  15. package/dist/{for-angular → lib}/engine/NgxCrudFormField.d.ts +37 -30
  16. package/dist/lib/engine/NgxFormService.d.ts +167 -0
  17. package/dist/lib/engine/NgxRenderingEngine.d.ts +128 -0
  18. package/dist/lib/engine/NgxRenderingEngine2.d.ts +251 -0
  19. package/dist/lib/engine/ValidatorFactory.d.ts +15 -0
  20. package/dist/lib/engine/constants.d.ts +151 -0
  21. package/dist/lib/engine/decorators.d.ts +25 -0
  22. package/dist/lib/engine/index.d.ts +15 -0
  23. package/dist/lib/engine/types.d.ts +293 -0
  24. package/dist/lib/esm2022/components/component-renderer/component-renderer.component.mjs +309 -0
  25. package/dist/lib/esm2022/components/crud-field/crud-field.component.mjs +288 -0
  26. package/dist/lib/esm2022/components/crud-form/constants.mjs +14 -0
  27. package/dist/lib/esm2022/components/crud-form/crud-form.component.mjs +140 -0
  28. package/dist/lib/esm2022/components/crud-form/types.mjs +2 -0
  29. package/dist/lib/esm2022/components/model-renderer/model-renderer.component.mjs +137 -0
  30. package/dist/lib/esm2022/engine/DynamicModule.mjs +18 -0
  31. package/dist/lib/esm2022/engine/NgxCrudFormField.mjs +117 -0
  32. package/dist/lib/esm2022/engine/NgxFormService.mjs +315 -0
  33. package/dist/lib/esm2022/engine/NgxRenderingEngine.mjs +194 -0
  34. package/dist/lib/esm2022/engine/NgxRenderingEngine2.mjs +333 -0
  35. package/dist/lib/esm2022/engine/ValidatorFactory.mjs +102 -0
  36. package/dist/lib/esm2022/engine/constants.mjs +160 -0
  37. package/dist/lib/esm2022/engine/decorators.mjs +38 -0
  38. package/dist/lib/esm2022/engine/index.mjs +16 -0
  39. package/dist/lib/esm2022/engine/types.mjs +2 -0
  40. package/dist/lib/esm2022/for-angular.module.mjs +118 -0
  41. package/dist/lib/esm2022/interfaces.mjs +2 -0
  42. package/dist/lib/esm2022/public-apis.mjs +13 -0
  43. package/dist/lib/fesm2022/decaf-ts-for-angular.mjs +2138 -0
  44. package/dist/lib/fesm2022/decaf-ts-for-angular.mjs.map +1 -0
  45. package/dist/lib/for-angular.module.d.ts +44 -0
  46. package/dist/lib/interfaces.d.ts +28 -0
  47. package/dist/lib/public-apis.d.ts +12 -0
  48. package/package.json +74 -25
  49. package/dist/for-angular/README.md +0 -297
  50. package/dist/for-angular/assets/i18n/en.json +0 -21
  51. package/dist/for-angular/components/decaf-crud-field/decaf-crud-field.component.d.ts +0 -22
  52. package/dist/for-angular/components/decaf-crud-form/decaf-crud-form.component.d.ts +0 -28
  53. package/dist/for-angular/components/decaf-model-renderer/decaf-model-renderer.component.d.ts +0 -20
  54. package/dist/for-angular/directives/decaf-field.directive.d.ts +0 -8
  55. package/dist/for-angular/engine/DynamicModule.d.ts +0 -2
  56. package/dist/for-angular/engine/NgxFormService.d.ts +0 -119
  57. package/dist/for-angular/engine/NgxRenderingEngine.d.ts +0 -17
  58. package/dist/for-angular/engine/ValidatorFactory.d.ts +0 -4
  59. package/dist/for-angular/engine/constants.d.ts +0 -10
  60. package/dist/for-angular/engine/decorators.d.ts +0 -1
  61. package/dist/for-angular/engine/index.d.ts +0 -5
  62. package/dist/for-angular/engine/types.d.ts +0 -32
  63. package/dist/for-angular/esm2022/components/decaf-crud-field/decaf-crud-field.component.mjs +0 -66
  64. package/dist/for-angular/esm2022/components/decaf-crud-form/constants.mjs +0 -14
  65. package/dist/for-angular/esm2022/components/decaf-crud-form/decaf-crud-form.component.mjs +0 -84
  66. package/dist/for-angular/esm2022/components/decaf-crud-form/types.mjs +0 -2
  67. package/dist/for-angular/esm2022/components/decaf-model-renderer/decaf-model-renderer.component.mjs +0 -46
  68. package/dist/for-angular/esm2022/directives/decaf-field.directive.mjs +0 -23
  69. package/dist/for-angular/esm2022/engine/DynamicModule.mjs +0 -3
  70. package/dist/for-angular/esm2022/engine/NgxCrudFormField.mjs +0 -118
  71. package/dist/for-angular/esm2022/engine/NgxFormService.mjs +0 -232
  72. package/dist/for-angular/esm2022/engine/NgxRenderingEngine.mjs +0 -35
  73. package/dist/for-angular/esm2022/engine/ValidatorFactory.mjs +0 -48
  74. package/dist/for-angular/esm2022/engine/constants.mjs +0 -12
  75. package/dist/for-angular/esm2022/engine/decorators.mjs +0 -17
  76. package/dist/for-angular/esm2022/engine/index.mjs +0 -6
  77. package/dist/for-angular/esm2022/engine/types.mjs +0 -2
  78. package/dist/for-angular/esm2022/interfaces.mjs +0 -2
  79. package/dist/for-angular/esm2022/public-apis.mjs +0 -5
  80. package/dist/for-angular/fesm2022/decaf-ts-for-angular.mjs +0 -675
  81. package/dist/for-angular/fesm2022/decaf-ts-for-angular.mjs.map +0 -1
  82. package/dist/for-angular/interfaces.d.ts +0 -8
  83. package/dist/for-angular/public-apis.d.ts +0 -4
  84. /package/dist/{for-angular/components/decaf-crud-form → lib/components/crud-form}/constants.d.ts +0 -0
  85. /package/dist/{for-angular/components/decaf-crud-form → lib/components/crud-form}/types.d.ts +0 -0
  86. /package/dist/{for-angular → lib}/esm2022/decaf-ts-for-angular.mjs +0 -0
  87. /package/dist/{for-angular → lib}/index.d.ts +0 -0
@@ -0,0 +1,50 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <svg id="Layer_2" data-name="Layer 2" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 166.75 39.77">
3
+ <defs>
4
+ <style>
5
+ .cls-1 {
6
+ fill: none;
7
+ }
8
+
9
+ .cls-2 {
10
+ clip-path: url(#clippath-1);
11
+ }
12
+
13
+ .cls-3 {
14
+ fill: #fff;
15
+ }
16
+
17
+ .cls-4 {
18
+ clip-path: url(#clippath);
19
+ }
20
+ </style>
21
+ <clipPath id="clippath">
22
+ <polygon class="cls-1" points="39.77 0 9.93 0 4.96 4.96 0 9.93 0 39.77 29.86 39.77 39.77 29.86 39.77 0"/>
23
+ </clipPath>
24
+ <clipPath id="clippath-1">
25
+ <rect class="cls-1" x="-5" y="-5" width="49.77" height="49.77"/>
26
+ </clipPath>
27
+ </defs>
28
+ <g id="Layer_1-2" data-name="Layer 1">
29
+ <g>
30
+ <g>
31
+ <g class="cls-4">
32
+ <g class="cls-2">
33
+ <image width="104" height="104" transform="translate(-5 -5) scale(.48)" xlink:href=""/>
34
+ </g>
35
+ </g>
36
+ <g>
37
+ <polygon class="cls-3" points="9.94 14.93 4.97 14.93 4.97 29.87 4.97 29.87 4.97 34.8 4.97 34.8 4.97 34.81 9.94 34.81 9.94 34.8 19.89 34.8 19.89 29.87 9.94 29.87 9.94 14.93"/>
38
+ <polygon class="cls-3" points="19.89 14.91 19.89 19.91 19.89 24.9 24.85 24.9 24.85 19.91 29.82 19.91 29.82 14.91 19.89 14.91"/>
39
+ </g>
40
+ </g>
41
+ <g>
42
+ <path class="cls-3" d="M54.7,34.98V4.76h9.86c4.46,0,8.17,1.31,11.14,3.93,2.97,2.62,4.45,6.35,4.45,11.18s-1.48,8.56-4.45,11.18c-2.97,2.62-6.68,3.93-11.14,3.93h-9.86ZM60.43,30.01h3.65c2.93,0,5.37-.82,7.32-2.46,1.96-1.64,2.93-4.2,2.93-7.68s-.98-6.05-2.93-7.71c-1.96-1.65-4.4-2.48-7.32-2.48h-3.65v20.33Z"/>
43
+ <path class="cls-3" d="M98.75,27.73h5.21c-.41,2.3-1.55,4.14-3.43,5.53-1.88,1.38-4.17,2.07-6.87,2.07-3.42,0-6.13-1.12-8.15-3.37-2.01-2.24-3.02-4.89-3.02-7.94s.94-5.71,2.82-7.88,4.52-3.26,7.91-3.26,6.08,1.04,7.91,3.11c1.83,2.07,2.74,4.53,2.74,7.38,0,.63-.03,1.24-.09,1.81h-16.16c.2,1.76.84,3.15,1.91,4.19,1.07,1.04,2.45,1.55,4.13,1.55,2.81,0,4.5-1.06,5.08-3.19ZM93.24,16.85c-3.1,0-4.92,1.61-5.47,4.83h10.77c-.12-1.44-.64-2.6-1.59-3.5-.94-.89-2.18-1.34-3.71-1.34Z"/>
44
+ <path class="cls-3" d="M117.09,35.32c-3.33,0-6.02-1.07-8.06-3.22-2.04-2.14-3.06-4.81-3.06-8.01s1.02-5.86,3.06-8.01c2.04-2.14,4.73-3.22,8.06-3.22,2.81,0,5.2.76,7.17,2.29,1.97,1.53,3.07,3.53,3.3,6h-5.3c-.2-1.06-.78-1.95-1.72-2.65-.94-.7-2.05-1.06-3.32-1.06-1.8,0-3.19.62-4.19,1.86-1,1.24-1.5,2.83-1.5,4.79s.51,3.55,1.52,4.79c1.01,1.24,2.43,1.86,4.26,1.86,1.25,0,2.32-.32,3.24-.97.91-.65,1.5-1.52,1.76-2.61h5.39c-.35,2.39-1.5,4.35-3.45,5.87s-4.34,2.29-7.15,2.29Z"/>
45
+ <path class="cls-3" d="M139.46,12.88c2.81,0,5.09.74,6.84,2.22,1.75,1.48,2.63,3.45,2.63,5.89v13.99h-5.26v-3.24c-.46,1.09-1.28,1.96-2.46,2.61s-2.54.97-4.11.97c-2.14,0-3.9-.61-5.26-1.83-1.36-1.22-2.04-2.78-2.04-4.68,0-2.1.75-3.77,2.26-5.01,1.51-1.24,3.49-1.86,5.95-1.86h4.04c1.07,0,1.61-.49,1.61-1.47,0-1.06-.4-1.94-1.2-2.61-.8-.68-1.89-1.01-3.28-1.01s-2.45.36-3.28,1.08c-.83.72-1.27,1.6-1.33,2.63h-4.78c.14-2.22,1.09-4.05,2.85-5.5,1.75-1.45,4.02-2.18,6.8-2.18ZM138.38,31.4c1.65,0,2.95-.52,3.89-1.55.94-1.04,1.41-2.39,1.41-4.06v-.35h-4.91c-1.13,0-2.04.29-2.74.86-.7.58-1.04,1.34-1.04,2.29,0,.83.31,1.51.93,2.03s1.44.78,2.46.78Z"/>
46
+ <path class="cls-3" d="M155.02,34.98v-17.31h-4.3v-4.45h4.3v-2.03c0-2.22.71-3.99,2.13-5.31s3.32-1.99,5.69-1.99h3.91v4.49h-3.3c-.93,0-1.67.27-2.24.82-.56.55-.85,1.29-.85,2.24v1.77h6.39v4.45h-6.39v17.31h-5.34Z"/>
47
+ </g>
48
+ </g>
49
+ </g>
50
+ </svg>
@@ -0,0 +1,22 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <svg id="Layer_2" data-name="Layer 2" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 166.75 39.77">
3
+ <defs>
4
+ <style>
5
+ .cls-1 {
6
+ fill: #fff;
7
+ }
8
+ </style>
9
+ </defs>
10
+ <g id="Layer_1-2" data-name="Layer 1">
11
+ <g>
12
+ <g>
13
+ <path class="cls-1" d="M54.7,34.98V4.76h9.86c4.46,0,8.17,1.31,11.14,3.93,2.97,2.62,4.45,6.35,4.45,11.18s-1.48,8.56-4.45,11.18c-2.97,2.62-6.68,3.93-11.14,3.93h-9.86ZM60.43,30.01h3.65c2.93,0,5.37-.82,7.32-2.46,1.96-1.64,2.93-4.2,2.93-7.68s-.98-6.05-2.93-7.71c-1.96-1.65-4.4-2.48-7.32-2.48h-3.65v20.33Z"/>
14
+ <path class="cls-1" d="M98.75,27.73h5.21c-.41,2.3-1.55,4.14-3.43,5.53-1.88,1.38-4.17,2.07-6.87,2.07-3.42,0-6.13-1.12-8.15-3.37-2.01-2.24-3.02-4.89-3.02-7.94s.94-5.71,2.82-7.88,4.52-3.26,7.91-3.26,6.08,1.04,7.91,3.11c1.83,2.07,2.74,4.53,2.74,7.38,0,.63-.03,1.24-.09,1.81h-16.16c.2,1.76.84,3.15,1.91,4.19,1.07,1.04,2.45,1.55,4.13,1.55,2.81,0,4.5-1.06,5.08-3.19ZM93.24,16.85c-3.1,0-4.92,1.61-5.47,4.83h10.77c-.12-1.44-.64-2.6-1.59-3.5-.94-.89-2.18-1.34-3.71-1.34Z"/>
15
+ <path class="cls-1" d="M117.09,35.32c-3.33,0-6.02-1.07-8.06-3.22-2.04-2.14-3.06-4.81-3.06-8.01s1.02-5.86,3.06-8.01c2.04-2.14,4.73-3.22,8.06-3.22,2.81,0,5.2.76,7.17,2.29,1.97,1.53,3.07,3.53,3.3,6h-5.3c-.2-1.06-.78-1.95-1.72-2.65-.94-.7-2.05-1.06-3.32-1.06-1.8,0-3.19.62-4.19,1.86-1,1.24-1.5,2.83-1.5,4.79s.51,3.55,1.52,4.79c1.01,1.24,2.43,1.86,4.26,1.86,1.25,0,2.32-.32,3.24-.97.91-.65,1.5-1.52,1.76-2.61h5.39c-.35,2.39-1.5,4.35-3.45,5.87s-4.34,2.29-7.15,2.29Z"/>
16
+ <path class="cls-1" d="M139.46,12.88c2.81,0,5.09.74,6.84,2.22,1.75,1.48,2.63,3.45,2.63,5.89v13.99h-5.26v-3.24c-.46,1.09-1.28,1.96-2.46,2.61s-2.54.97-4.11.97c-2.14,0-3.9-.61-5.26-1.83-1.36-1.22-2.04-2.78-2.04-4.68,0-2.1.75-3.77,2.26-5.01,1.51-1.24,3.49-1.86,5.95-1.86h4.04c1.07,0,1.61-.49,1.61-1.47,0-1.06-.4-1.94-1.2-2.61-.8-.68-1.89-1.01-3.28-1.01s-2.45.36-3.28,1.08c-.83.72-1.27,1.6-1.33,2.63h-4.78c.14-2.22,1.09-4.05,2.85-5.5,1.75-1.45,4.02-2.18,6.8-2.18ZM138.38,31.4c1.65,0,2.95-.52,3.89-1.55.94-1.04,1.41-2.39,1.41-4.06v-.35h-4.91c-1.13,0-2.04.29-2.74.86-.7.58-1.04,1.34-1.04,2.29,0,.83.31,1.51.93,2.03s1.44.78,2.46.78Z"/>
17
+ <path class="cls-1" d="M155.02,34.98v-17.31h-4.3v-4.45h4.3v-2.03c0-2.22.71-3.99,2.13-5.31s3.32-1.99,5.69-1.99h3.91v4.49h-3.3c-.93,0-1.67.27-2.24.82-.56.55-.85,1.29-.85,2.24v1.77h6.39v4.45h-6.39v17.31h-5.34Z"/>
18
+ </g>
19
+ <path class="cls-1" d="M9.93,0l-4.97,4.96L0,9.93v29.83h29.86l9.91-9.91V0H9.93ZM19.89,34.8h-9.94s-4.97,0-4.97,0h0s0,0,0,0v-4.94h0v-14.94h4.97v14.94h9.94v4.94ZM29.82,19.91h-4.97v4.99h-4.96v-9.99h9.93v4.99Z"/>
20
+ </g>
21
+ </g>
22
+ </svg>
@@ -0,0 +1,54 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <svg id="Layer_2" data-name="Layer 2" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 166.75 39.77">
3
+ <defs>
4
+ <style>
5
+ .cls-1 {
6
+ fill: none;
7
+ }
8
+
9
+ .cls-2 {
10
+ clip-path: url(#clippath-1);
11
+ }
12
+
13
+ .cls-3 {
14
+ fill: #141414;
15
+ }
16
+
17
+ .cls-4 {
18
+ fill: #fff;
19
+ }
20
+
21
+ .cls-5 {
22
+ clip-path: url(#clippath);
23
+ }
24
+ </style>
25
+ <clipPath id="clippath">
26
+ <polygon class="cls-1" points="39.77 0 9.93 0 4.96 4.96 0 9.93 0 39.77 29.86 39.77 39.77 29.86 39.77 0"/>
27
+ </clipPath>
28
+ <clipPath id="clippath-1">
29
+ <rect class="cls-1" x="-5" y="-5" width="49.77" height="49.77"/>
30
+ </clipPath>
31
+ </defs>
32
+ <g id="Layer_1-2" data-name="Layer 1">
33
+ <g>
34
+ <g>
35
+ <g class="cls-5">
36
+ <g class="cls-2">
37
+ <image width="104" height="105" transform="translate(-5 -5.4) scale(.48)" xlink:href=""/>
38
+ </g>
39
+ </g>
40
+ <g>
41
+ <polygon class="cls-4" points="9.94 14.93 4.97 14.93 4.97 29.87 4.97 29.87 4.97 34.8 4.97 34.8 4.97 34.81 9.94 34.81 9.94 34.8 19.89 34.8 19.89 29.87 9.94 29.87 9.94 14.93"/>
42
+ <polygon class="cls-4" points="19.89 14.91 19.89 19.91 19.89 24.9 24.85 24.9 24.85 19.91 29.82 19.91 29.82 14.91 19.89 14.91"/>
43
+ </g>
44
+ </g>
45
+ <g>
46
+ <path class="cls-3" d="M54.7,34.98V4.76h9.86c4.46,0,8.17,1.31,11.14,3.93,2.97,2.62,4.45,6.35,4.45,11.18s-1.48,8.56-4.45,11.18c-2.97,2.62-6.68,3.93-11.14,3.93h-9.86ZM60.43,30.01h3.65c2.93,0,5.37-.82,7.32-2.46,1.96-1.64,2.93-4.2,2.93-7.68s-.98-6.05-2.93-7.71c-1.96-1.65-4.4-2.48-7.32-2.48h-3.65v20.33Z"/>
47
+ <path class="cls-3" d="M98.75,27.73h5.21c-.41,2.3-1.55,4.14-3.43,5.53-1.88,1.38-4.17,2.07-6.87,2.07-3.42,0-6.13-1.12-8.15-3.37-2.01-2.24-3.02-4.89-3.02-7.94s.94-5.71,2.82-7.88,4.52-3.26,7.91-3.26,6.08,1.04,7.91,3.11c1.83,2.07,2.74,4.53,2.74,7.38,0,.63-.03,1.24-.09,1.81h-16.16c.2,1.76.84,3.15,1.91,4.19,1.07,1.04,2.45,1.55,4.13,1.55,2.81,0,4.5-1.06,5.08-3.19ZM93.24,16.85c-3.1,0-4.92,1.61-5.47,4.83h10.77c-.12-1.44-.64-2.6-1.59-3.5-.94-.89-2.18-1.34-3.71-1.34Z"/>
48
+ <path class="cls-3" d="M117.09,35.32c-3.33,0-6.02-1.07-8.06-3.22-2.04-2.14-3.06-4.81-3.06-8.01s1.02-5.86,3.06-8.01c2.04-2.14,4.73-3.22,8.06-3.22,2.81,0,5.2.76,7.17,2.29,1.97,1.53,3.07,3.53,3.3,6h-5.3c-.2-1.06-.78-1.95-1.72-2.65-.94-.7-2.05-1.06-3.32-1.06-1.8,0-3.19.62-4.19,1.86-1,1.24-1.5,2.83-1.5,4.79s.51,3.55,1.52,4.79c1.01,1.24,2.43,1.86,4.26,1.86,1.25,0,2.32-.32,3.24-.97.91-.65,1.5-1.52,1.76-2.61h5.39c-.35,2.39-1.5,4.35-3.45,5.87s-4.34,2.29-7.15,2.29Z"/>
49
+ <path class="cls-3" d="M139.46,12.88c2.81,0,5.09.74,6.84,2.22,1.75,1.48,2.63,3.45,2.63,5.89v13.99h-5.26v-3.24c-.46,1.09-1.28,1.96-2.46,2.61s-2.54.97-4.11.97c-2.14,0-3.9-.61-5.26-1.83-1.36-1.22-2.04-2.78-2.04-4.68,0-2.1.75-3.77,2.26-5.01,1.51-1.24,3.49-1.86,5.95-1.86h4.04c1.07,0,1.61-.49,1.61-1.47,0-1.06-.4-1.94-1.2-2.61-.8-.68-1.89-1.01-3.28-1.01s-2.45.36-3.28,1.08c-.83.72-1.27,1.6-1.33,2.63h-4.78c.14-2.22,1.09-4.05,2.85-5.5,1.75-1.45,4.02-2.18,6.8-2.18ZM138.38,31.4c1.65,0,2.95-.52,3.89-1.55.94-1.04,1.41-2.39,1.41-4.06v-.35h-4.91c-1.13,0-2.04.29-2.74.86-.7.58-1.04,1.34-1.04,2.29,0,.83.31,1.51.93,2.03s1.44.78,2.46.78Z"/>
50
+ <path class="cls-3" d="M155.02,34.98v-17.31h-4.3v-4.45h4.3v-2.03c0-2.22.71-3.99,2.13-5.31s3.32-1.99,5.69-1.99h3.91v4.49h-3.3c-.93,0-1.67.27-2.24.82-.56.55-.85,1.29-.85,2.24v1.77h6.39v4.45h-6.39v17.31h-5.34Z"/>
51
+ </g>
52
+ </g>
53
+ </g>
54
+ </svg>
@@ -0,0 +1,267 @@
1
+ import { ComponentRef, EnvironmentInjector, EventEmitter, OnDestroy, OnInit, TemplateRef, ViewContainerRef } from '@angular/core';
2
+ import { ModelRenderCustomEvent } from '../../engine';
3
+ import { Logger } from '@decaf-ts/logging';
4
+ import * as i0 from "@angular/core";
5
+ /**
6
+ * @description Dynamic component renderer for Decaf Angular applications.
7
+ * @summary This component provides a flexible way to dynamically render Angular components
8
+ * at runtime based on a tag name. It handles the creation, property binding, and event
9
+ * subscription for dynamically loaded components. This is particularly useful for
10
+ * building configurable UIs where components need to be determined at runtime.
11
+ *
12
+ * @component {ComponentRendererComponent}
13
+ * @example
14
+ * <ngx-decaf-component-renderer
15
+ * [tag]="tag"
16
+ * [globals]="globals"
17
+ * (listenEvent)="listenEvent($event)">
18
+ * </ngx-decaf-component-renderer>
19
+ *
20
+ * @mermaid
21
+ * classDiagram
22
+ * class ComponentRendererComponent {
23
+ * +ViewContainerRef vcr
24
+ * +string tag
25
+ * +Record~string, unknown~ globals
26
+ * +EnvironmentInjector injector
27
+ * +ComponentRef~unknown~ component
28
+ * +EventEmitter~ModelRenderCustomEvent~ listenEvent
29
+ * +ngOnInit()
30
+ * +ngOnDestroy()
31
+ * +ngOnChanges(changes)
32
+ * -createComponent(tag, globals)
33
+ * -subscribeEvents()
34
+ * -unsubscribeEvents()
35
+ * }
36
+ * ComponentRendererComponent --|> OnInit
37
+ * ComponentRendererComponent --|> OnChanges
38
+ * ComponentRendererComponent --|> OnDestroy
39
+ *
40
+ * @implements {OnInit}
41
+ * @implements {OnChanges}
42
+ * @implements {OnDestroy}
43
+ */
44
+ export declare class ComponentRendererComponent implements OnInit, OnDestroy {
45
+ /**
46
+ * @description Reference to the container where the dynamic component will be rendered.
47
+ * @summary This ViewContainerRef provides the container where the dynamically created
48
+ * component will be inserted into the DOM. It's marked as static to ensure it's available
49
+ * during the ngOnInit lifecycle hook when the component is created.
50
+ *
51
+ * @type {ViewContainerRef}
52
+ * @memberOf ComponentRendererComponent
53
+ */
54
+ vcr: ViewContainerRef;
55
+ /**
56
+ * @description The tag name of the component to be dynamically rendered.
57
+ * @summary This input property specifies which component should be rendered by providing
58
+ * its registered tag name. The tag must correspond to a component that has been registered
59
+ * with the NgxRenderingEngine2. This is a required input as it determines which component
60
+ * to create.
61
+ *
62
+ * @type {string}
63
+ * @required
64
+ * @memberOf ComponentRendererComponent
65
+ */
66
+ tag: string;
67
+ /**
68
+ * @description Global properties to pass to the rendered component.
69
+ * @summary This input property allows passing a set of properties to the dynamically
70
+ * rendered component. These properties will be mapped to the component's inputs if they
71
+ * match. Properties that don't match any input on the target component will be filtered out
72
+ * with a warning.
73
+ *
74
+ * @type {Record<string, unknown>}
75
+ * @default {}
76
+ * @memberOf ComponentRendererComponent
77
+ */
78
+ globals: Record<string, unknown>;
79
+ /**
80
+ * @description Injector used for dependency injection in the dynamic component.
81
+ * @summary This injector is used when creating the dynamic component to provide it with
82
+ * access to the application's dependency injection system. It ensures that the dynamically
83
+ * created component can access the same services and dependencies as statically created
84
+ * components.
85
+ *
86
+ * @type {EnvironmentInjector}
87
+ * @memberOf ComponentRendererComponent
88
+ */
89
+ injector: EnvironmentInjector;
90
+ /**
91
+ * @description Reference to the dynamically created component.
92
+ * @summary This property holds a reference to the ComponentRef of the dynamically created
93
+ * component. It's used to interact with the component instance, subscribe to its events,
94
+ * and properly destroy it when the renderer is destroyed.
95
+ *
96
+ * @type {ComponentRef<unknown>}
97
+ * @memberOf ComponentRendererComponent
98
+ */
99
+ component: ComponentRef<unknown>;
100
+ /**
101
+ * @description Event emitter for events from the rendered component.
102
+ * @summary This output property emits events that originate from the dynamically rendered
103
+ * component. It allows the parent component to listen for and respond to events from the
104
+ * dynamic component, creating a communication channel between the parent and the dynamically
105
+ * rendered child.
106
+ *
107
+ * @type {EventEmitter<ModelRenderCustomEvent>}
108
+ * @memberOf ComponentRendererComponent
109
+ */
110
+ listenEvent: EventEmitter<ModelRenderCustomEvent>;
111
+ /**
112
+ * @description Logger instance for the component.
113
+ * @summary This property holds a Logger instance specific to this component.
114
+ * It's used to log information, warnings, and errors related to the component's
115
+ * operations, particularly useful for debugging and monitoring the dynamic
116
+ * component rendering process.
117
+ *
118
+ * @type {Logger}
119
+ * @memberOf ComponentRendererComponent
120
+ */
121
+ logger: Logger;
122
+ parent: any;
123
+ inner?: TemplateRef<any>;
124
+ /**
125
+ * @description Creates an instance of ComponentRendererComponent.
126
+ * @summary Initializes a new ComponentRendererComponent. This component doesn't require
127
+ * any dependencies to be injected in its constructor as it uses the inject function to
128
+ * obtain the EnvironmentInjector.
129
+ *
130
+ * @memberOf ComponentRendererComponent
131
+ */
132
+ constructor();
133
+ /**
134
+ * @description Initializes the component after Angular first displays the data-bound properties.
135
+ * @summary Sets up the component by creating the dynamic component specified by the tag input.
136
+ * This method is called once when the component is initialized and triggers the dynamic
137
+ * component creation process with the provided tag name and global properties.
138
+ *
139
+ * @mermaid
140
+ * sequenceDiagram
141
+ * participant A as Angular Lifecycle
142
+ * participant C as ComponentRendererComponent
143
+ * participant R as NgxRenderingEngine2
144
+ *
145
+ * A->>C: ngOnInit()
146
+ * C->>C: createComponent(tag, globals)
147
+ * C->>R: components(tag)
148
+ * R-->>C: Return component constructor
149
+ * C->>C: Process component inputs
150
+ * C->>C: Create component instance
151
+ * C->>C: subscribeEvents()
152
+ *
153
+ * @return {void}
154
+ * @memberOf ComponentRendererComponent
155
+ */
156
+ ngOnInit(): void;
157
+ /**
158
+ * @description Cleans up resources when the component is destroyed.
159
+ * @summary Performs cleanup operations when the component is being destroyed by Angular.
160
+ * This includes unsubscribing from all event emitters of the dynamic component and
161
+ * destroying the rendering engine instance to prevent memory leaks.
162
+ *
163
+ * @mermaid
164
+ * sequenceDiagram
165
+ * participant A as Angular Lifecycle
166
+ * participant C as ComponentRendererComponent
167
+ * participant R as NgxRenderingEngine2
168
+ *
169
+ * A->>C: ngOnDestroy()
170
+ * alt component exists
171
+ * C->>C: unsubscribeEvents()
172
+ * C->>R: destroy()
173
+ * end
174
+ *
175
+ * @return {Promise<void>} A promise that resolves when cleanup is complete
176
+ * @memberOf ComponentRendererComponent
177
+ */
178
+ ngOnDestroy(): Promise<void>;
179
+ /**
180
+ * @description Creates and renders a dynamic component.
181
+ * @summary This method handles the creation of a dynamic component based on the provided tag.
182
+ * It retrieves the component constructor from the rendering engine, processes its inputs,
183
+ * filters out unmapped properties, creates the component instance, and sets up event subscriptions.
184
+ *
185
+ * @param {string} tag - The tag name of the component to create
186
+ * @param {KeyValue} globals - Global properties to pass to the component
187
+ * @return {void}
188
+ *
189
+ * @mermaid
190
+ * sequenceDiagram
191
+ * participant C as ComponentRendererComponent
192
+ * participant R as NgxRenderingEngine2
193
+ * participant V as ViewContainerRef
194
+ *
195
+ * C->>R: components(tag)
196
+ * R-->>C: Return component constructor
197
+ * C->>C: reflectComponentType(component)
198
+ * C->>C: Process input properties
199
+ * C->>C: Filter unmapped properties
200
+ * C->>V: clear()
201
+ * C->>R: createComponent(component, props, metadata, vcr, injector, [])
202
+ * R-->>C: Return component reference
203
+ * C->>C: subscribeEvents()
204
+ *
205
+ * @private
206
+ * @memberOf ComponentRendererComponent
207
+ */
208
+ private createComponent;
209
+ createParentComponent(): void;
210
+ /**
211
+ * @description Subscribes to events emitted by the dynamic component.
212
+ * @summary This method sets up subscriptions to all EventEmitter properties of the
213
+ * dynamically created component. When an event is emitted by the dynamic component,
214
+ * it is captured and re-emitted through the listenEvent output property with additional
215
+ * metadata about the event source.
216
+ *
217
+ * @mermaid
218
+ * sequenceDiagram
219
+ * participant C as ComponentRendererComponent
220
+ * participant D as Dynamic Component
221
+ * participant P as Parent Component
222
+ *
223
+ * C->>C: subscribeEvents()
224
+ * C->>D: Get instance properties
225
+ * loop For each property
226
+ * C->>C: Check if property is EventEmitter
227
+ * alt is EventEmitter
228
+ * C->>D: Subscribe to event
229
+ * D-->>C: Event emitted
230
+ * C->>P: Re-emit event with metadata
231
+ * end
232
+ * end
233
+ *
234
+ * @private
235
+ * @return {void}
236
+ * @memberOf ComponentRendererComponent
237
+ */
238
+ private subscribeEvents;
239
+ /**
240
+ * @description Unsubscribes from all events of the dynamic component.
241
+ * @summary This method cleans up event subscriptions when the component is being destroyed.
242
+ * It iterates through all properties of the dynamic component instance and unsubscribes
243
+ * from any EventEmitter properties to prevent memory leaks and unexpected behavior after
244
+ * the component is destroyed.
245
+ *
246
+ * @mermaid
247
+ * sequenceDiagram
248
+ * participant C as ComponentRendererComponent
249
+ * participant D as Dynamic Component
250
+ *
251
+ * C->>C: unsubscribeEvents()
252
+ * C->>D: Get instance properties
253
+ * loop For each property
254
+ * C->>C: Check if property is EventEmitter
255
+ * alt is EventEmitter
256
+ * C->>D: Unsubscribe from event
257
+ * end
258
+ * end
259
+ *
260
+ * @private
261
+ * @return {void}
262
+ * @memberOf ComponentRendererComponent
263
+ */
264
+ private unsubscribeEvents;
265
+ static ɵfac: i0.ɵɵFactoryDeclaration<ComponentRendererComponent, never>;
266
+ static ɵcmp: i0.ɵɵComponentDeclaration<ComponentRendererComponent, "ngx-decaf-component-renderer", never, { "tag": { "alias": "tag"; "required": true; }; "globals": { "alias": "globals"; "required": false; }; "parent": { "alias": "parent"; "required": false; }; }, { "listenEvent": "listenEvent"; }, never, never, true, never>;
267
+ }