@decaf-ts/for-angular 0.0.4 → 0.0.6
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/LICENSE.md +646 -144
- package/README.md +37 -242
- package/dist/lib/README.md +92 -0
- package/dist/lib/assets/i18n/en.json +131 -0
- package/dist/lib/assets/images/angular-logo.svg +45 -0
- package/dist/lib/assets/images/decaf-logo-black.svg +22 -0
- package/dist/lib/assets/images/decaf-logo-lw.svg +50 -0
- package/dist/lib/assets/images/decaf-logo-white.svg +22 -0
- package/dist/lib/assets/images/decaf-logo.svg +54 -0
- package/dist/lib/components/component-renderer/component-renderer.component.d.ts +267 -0
- package/dist/lib/components/crud-field/crud-field.component.d.ts +445 -0
- package/dist/{for-angular/components/decaf-crud-form → lib/components/crud-form}/constants.d.ts +0 -0
- package/dist/lib/components/crud-form/crud-form.component.d.ts +102 -0
- package/dist/{for-angular/components/decaf-crud-form → lib/components/crud-form}/types.d.ts +0 -0
- package/dist/lib/components/model-renderer/model-renderer.component.d.ts +96 -0
- package/dist/lib/engine/DynamicModule.d.ts +17 -0
- package/dist/{for-angular → lib}/engine/NgxCrudFormField.d.ts +21 -17
- package/dist/lib/engine/NgxFormService.d.ts +167 -0
- package/dist/lib/engine/NgxRenderingEngine.d.ts +127 -0
- package/dist/lib/engine/NgxRenderingEngine2.d.ts +250 -0
- package/dist/lib/engine/ValidatorFactory.d.ts +15 -0
- package/dist/lib/engine/constants.d.ts +151 -0
- package/dist/lib/engine/decorators.d.ts +25 -0
- package/dist/lib/engine/index.d.ts +15 -0
- package/dist/lib/engine/types.d.ts +294 -0
- package/dist/lib/esm2022/components/component-renderer/component-renderer.component.mjs +312 -0
- package/dist/lib/esm2022/components/crud-field/crud-field.component.mjs +297 -0
- package/dist/lib/esm2022/components/crud-form/constants.mjs +14 -0
- package/dist/lib/esm2022/components/crud-form/crud-form.component.mjs +139 -0
- package/dist/lib/esm2022/components/crud-form/types.mjs +2 -0
- package/dist/lib/esm2022/components/model-renderer/model-renderer.component.mjs +138 -0
- package/dist/{for-angular → lib}/esm2022/decaf-ts-for-angular.mjs +0 -0
- package/dist/lib/esm2022/engine/DynamicModule.mjs +18 -0
- package/dist/lib/esm2022/engine/NgxCrudFormField.mjs +123 -0
- package/dist/lib/esm2022/engine/NgxFormService.mjs +315 -0
- package/dist/lib/esm2022/engine/NgxRenderingEngine.mjs +192 -0
- package/dist/lib/esm2022/engine/NgxRenderingEngine2.mjs +332 -0
- package/dist/lib/esm2022/engine/ValidatorFactory.mjs +102 -0
- package/dist/lib/esm2022/engine/constants.mjs +160 -0
- package/dist/lib/esm2022/engine/decorators.mjs +38 -0
- package/dist/lib/esm2022/engine/index.mjs +16 -0
- package/dist/lib/esm2022/engine/types.mjs +2 -0
- package/dist/lib/esm2022/for-angular.module.mjs +118 -0
- package/dist/lib/esm2022/interfaces.mjs +2 -0
- package/dist/lib/esm2022/public-apis.mjs +13 -0
- package/dist/lib/fesm2022/decaf-ts-for-angular.mjs +2152 -0
- package/dist/lib/fesm2022/decaf-ts-for-angular.mjs.map +1 -0
- package/dist/lib/for-angular.module.d.ts +45 -0
- package/dist/{for-angular → lib}/index.d.ts +0 -0
- package/dist/lib/interfaces.d.ts +28 -0
- package/dist/lib/public-apis.d.ts +12 -0
- package/package.json +71 -26
- package/dist/for-angular/README.md +0 -297
- package/dist/for-angular/assets/i18n/en.json +0 -21
- package/dist/for-angular/components/decaf-crud-field/decaf-crud-field.component.d.ts +0 -49
- package/dist/for-angular/components/decaf-crud-form/decaf-crud-form.component.d.ts +0 -28
- package/dist/for-angular/components/decaf-model-renderer/decaf-model-renderer.component.d.ts +0 -20
- package/dist/for-angular/engine/DynamicModule.d.ts +0 -2
- package/dist/for-angular/engine/NgxFormService.d.ts +0 -119
- package/dist/for-angular/engine/NgxRenderingEngine.d.ts +0 -18
- package/dist/for-angular/engine/ValidatorFactory.d.ts +0 -4
- package/dist/for-angular/engine/constants.d.ts +0 -13
- package/dist/for-angular/engine/decorators.d.ts +0 -1
- package/dist/for-angular/engine/index.d.ts +0 -5
- package/dist/for-angular/engine/types.d.ts +0 -44
- package/dist/for-angular/esm2022/components/decaf-crud-field/decaf-crud-field.component.mjs +0 -129
- package/dist/for-angular/esm2022/components/decaf-crud-form/constants.mjs +0 -14
- package/dist/for-angular/esm2022/components/decaf-crud-form/decaf-crud-form.component.mjs +0 -80
- package/dist/for-angular/esm2022/components/decaf-crud-form/types.mjs +0 -2
- package/dist/for-angular/esm2022/components/decaf-model-renderer/decaf-model-renderer.component.mjs +0 -47
- package/dist/for-angular/esm2022/engine/DynamicModule.mjs +0 -3
- package/dist/for-angular/esm2022/engine/NgxCrudFormField.mjs +0 -115
- package/dist/for-angular/esm2022/engine/NgxFormService.mjs +0 -235
- package/dist/for-angular/esm2022/engine/NgxRenderingEngine.mjs +0 -84
- package/dist/for-angular/esm2022/engine/ValidatorFactory.mjs +0 -48
- package/dist/for-angular/esm2022/engine/constants.mjs +0 -15
- package/dist/for-angular/esm2022/engine/decorators.mjs +0 -14
- package/dist/for-angular/esm2022/engine/index.mjs +0 -6
- package/dist/for-angular/esm2022/engine/types.mjs +0 -2
- package/dist/for-angular/esm2022/interfaces.mjs +0 -2
- package/dist/for-angular/esm2022/public-apis.mjs +0 -6
- package/dist/for-angular/fesm2022/decaf-ts-for-angular.mjs +0 -759
- package/dist/for-angular/fesm2022/decaf-ts-for-angular.mjs.map +0 -1
- package/dist/for-angular/interfaces.d.ts +0 -8
- package/dist/for-angular/public-apis.d.ts +0 -5
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
import { UIKeys } from '@decaf-ts/ui-decorators';
|
|
2
|
+
import { VALIDATION_PARENT_KEY } from '@decaf-ts/decorator-validation';
|
|
3
|
+
/**
|
|
4
|
+
* @description Angular engine key constants
|
|
5
|
+
* @summary Contains key strings used by the Angular rendering engine for reflection,
|
|
6
|
+
* dynamic component creation, and other engine operations.
|
|
7
|
+
* @typedef {Object} AngularEngineKeys
|
|
8
|
+
* @property {string} REFLECT - Prefix for reflection metadata keys
|
|
9
|
+
* @property {string} DYNAMIC - Key for dynamic component identification
|
|
10
|
+
* @property {string} ANNOTATIONS - Key for component annotations
|
|
11
|
+
* @property {string} ECMP - Key for embedded components
|
|
12
|
+
* @property {string} NG_REFLECT - Prefix for Angular reflection attributes
|
|
13
|
+
* @property {string} RENDERED - Prefix for rendered component markers
|
|
14
|
+
* @property {string} MAPPER - Key for property mappers
|
|
15
|
+
* @property {string} CHILDREN - Key for child components
|
|
16
|
+
* @property {string} LISTABLE - Key for listable components
|
|
17
|
+
* @property {string} RENDER - Key for renderable components
|
|
18
|
+
* @property {string} RENDERED_ID - Template for rendered component IDs
|
|
19
|
+
* @property {string} PARENT - Key for comparison decorators and validators
|
|
20
|
+
* @const AngularEngineKeys
|
|
21
|
+
* @memberOf module:engine
|
|
22
|
+
*/
|
|
23
|
+
export const AngularEngineKeys = {
|
|
24
|
+
REFLECT: `${UIKeys.REFLECT}.angular.`,
|
|
25
|
+
DYNAMIC: 'dynamic-component',
|
|
26
|
+
ANNOTATIONS: '__annotations__',
|
|
27
|
+
ECMP: 'ecmp',
|
|
28
|
+
NG_REFLECT: 'ng-reflect-',
|
|
29
|
+
RENDERED: 'rendered-as-',
|
|
30
|
+
MAPPER: 'mapper',
|
|
31
|
+
CHILDREN: 'children',
|
|
32
|
+
LISTABLE: 'listable',
|
|
33
|
+
RENDER: 'render',
|
|
34
|
+
RENDERED_ID: 'rendered-as-{0}',
|
|
35
|
+
PARENT: '_parent',
|
|
36
|
+
VALIDATION_PARENT_KEY: VALIDATION_PARENT_KEY
|
|
37
|
+
};
|
|
38
|
+
/**
|
|
39
|
+
* @description Form validation state constants
|
|
40
|
+
* @summary Contains constants representing the possible validation states of a form.
|
|
41
|
+
* These are used to check and handle form validation throughout the application.
|
|
42
|
+
* @typedef {Object} FormConstants
|
|
43
|
+
* @property {string} VALID - Constant representing a valid form state
|
|
44
|
+
* @property {string} INVALID - Constant representing an invalid form state
|
|
45
|
+
* @const FormConstants
|
|
46
|
+
* @memberOf module:engine
|
|
47
|
+
*/
|
|
48
|
+
export const FormConstants = {
|
|
49
|
+
VALID: 'VALID',
|
|
50
|
+
INVALID: 'INVALID',
|
|
51
|
+
};
|
|
52
|
+
/**
|
|
53
|
+
* @description Event name constants
|
|
54
|
+
* @summary Enum containing constants for event names used throughout the application.
|
|
55
|
+
* These are used to standardize event naming and handling.
|
|
56
|
+
* @enum {string}
|
|
57
|
+
* @readonly
|
|
58
|
+
* @property {string} BACK_BUTTON_NAVIGATION - Event fired when back button navigation ends
|
|
59
|
+
* @property {string} REFRESH_EVENT - Event fired when a refresh action occurs
|
|
60
|
+
* @property {string} CLICK_EVENT - Event fired when a click action occurs
|
|
61
|
+
* @property {string} SUBMIT_EVENT - Event fired when a form submission occurs
|
|
62
|
+
* @memberOf module:engine
|
|
63
|
+
*/
|
|
64
|
+
export var EventConstants;
|
|
65
|
+
(function (EventConstants) {
|
|
66
|
+
EventConstants["BACK_BUTTON_NAVIGATION"] = "backButtonNavigationEndEvent";
|
|
67
|
+
EventConstants["REFRESH_EVENT"] = "RefreshEvent";
|
|
68
|
+
EventConstants["CLICK_EVENT"] = "ClickEvent";
|
|
69
|
+
EventConstants["SUBMIT_EVENT"] = "SubmitEvent";
|
|
70
|
+
})(EventConstants || (EventConstants = {}));
|
|
71
|
+
/**
|
|
72
|
+
* @description Logger level constants
|
|
73
|
+
* @summary Enum defining the logging levels used in the application's logging system.
|
|
74
|
+
* Lower values represent more verbose logging, while higher values represent more critical logs.
|
|
75
|
+
* @enum {number}
|
|
76
|
+
* @readonly
|
|
77
|
+
* @property {number} ALL - Log everything (most verbose)
|
|
78
|
+
* @property {number} DEBUG - Log debug information
|
|
79
|
+
* @property {number} INFO - Log informational messages
|
|
80
|
+
* @property {number} WARN - Log warnings
|
|
81
|
+
* @property {number} ERROR - Log errors
|
|
82
|
+
* @property {number} CRITICAL - Log critical errors (least verbose)
|
|
83
|
+
* @memberOf module:engine
|
|
84
|
+
*/
|
|
85
|
+
export var LoggerLevels;
|
|
86
|
+
(function (LoggerLevels) {
|
|
87
|
+
LoggerLevels[LoggerLevels["ALL"] = 0] = "ALL";
|
|
88
|
+
LoggerLevels[LoggerLevels["DEBUG"] = 1] = "DEBUG";
|
|
89
|
+
LoggerLevels[LoggerLevels["INFO"] = 2] = "INFO";
|
|
90
|
+
LoggerLevels[LoggerLevels["WARN"] = 3] = "WARN";
|
|
91
|
+
LoggerLevels[LoggerLevels["ERROR"] = 4] = "ERROR";
|
|
92
|
+
LoggerLevels[LoggerLevels["CRITICAL"] = 5] = "CRITICAL";
|
|
93
|
+
})(LoggerLevels || (LoggerLevels = {}));
|
|
94
|
+
;
|
|
95
|
+
/**
|
|
96
|
+
* @description Route direction constants
|
|
97
|
+
* @summary Enum defining the possible navigation directions in the application.
|
|
98
|
+
* Used for controlling navigation flow and animation directions.
|
|
99
|
+
* @enum {string}
|
|
100
|
+
* @readonly
|
|
101
|
+
* @property {string} BACK - Navigate back to the previous page
|
|
102
|
+
* @property {string} FORWARD - Navigate forward to the next page
|
|
103
|
+
* @property {string} ROOT - Navigate to the root/home page
|
|
104
|
+
* @memberOf module:engine
|
|
105
|
+
*/
|
|
106
|
+
export var RouteDirections;
|
|
107
|
+
(function (RouteDirections) {
|
|
108
|
+
RouteDirections["BACK"] = "back";
|
|
109
|
+
RouteDirections["FORWARD"] = "forward";
|
|
110
|
+
RouteDirections["ROOT"] = "root";
|
|
111
|
+
})(RouteDirections || (RouteDirections = {}));
|
|
112
|
+
/**
|
|
113
|
+
* @description Component tag name constants
|
|
114
|
+
* @summary Enum defining the tag names for custom components used in the application.
|
|
115
|
+
* These tag names are used for component registration and rendering.
|
|
116
|
+
* @enum {string}
|
|
117
|
+
* @readonly
|
|
118
|
+
* @property {string} LIST_ITEM - Tag name for list item component
|
|
119
|
+
* @property {string} LIST_INFINITE - Tag name for infinite scrolling list component
|
|
120
|
+
* @property {string} LIST_PAGINATED - Tag name for paginated list component
|
|
121
|
+
* @memberOf module:engine
|
|
122
|
+
*/
|
|
123
|
+
export var ComponentsTagNames;
|
|
124
|
+
(function (ComponentsTagNames) {
|
|
125
|
+
ComponentsTagNames["LIST_ITEM"] = "ngx-decaf-list-item";
|
|
126
|
+
ComponentsTagNames["LIST_INFINITE"] = "ngx-decaf-list-infinite";
|
|
127
|
+
ComponentsTagNames["LIST_PAGINATED"] = "ngx-decaf-list-paginated";
|
|
128
|
+
})(ComponentsTagNames || (ComponentsTagNames = {}));
|
|
129
|
+
/**
|
|
130
|
+
* @description Base component property name constants
|
|
131
|
+
* @summary Enum defining the standard property names used by base components in the application.
|
|
132
|
+
* These property names are used for consistent property access across components.
|
|
133
|
+
* @enum {string}
|
|
134
|
+
* @readonly
|
|
135
|
+
* @property {string} MODEL - Property name for the component's data model
|
|
136
|
+
* @property {string} LOCALE - Property name for localization settings
|
|
137
|
+
* @property {string} PK - Property name for primary key
|
|
138
|
+
* @property {string} ITEMS - Property name for collection items
|
|
139
|
+
* @property {string} ROUTE - Property name for routing information
|
|
140
|
+
* @property {string} OPERATIONS - Property name for available operations
|
|
141
|
+
* @property {string} UID - Property name for unique identifier
|
|
142
|
+
* @property {string} TRANSLATABLE - Property name for translation flag
|
|
143
|
+
* @property {string} MAPPER - Property name for property mapper
|
|
144
|
+
* @property {string} INITIALIZED - Property name for initialization state
|
|
145
|
+
* @memberOf module:engine
|
|
146
|
+
*/
|
|
147
|
+
export var BaseComponentProps;
|
|
148
|
+
(function (BaseComponentProps) {
|
|
149
|
+
BaseComponentProps["MODEL"] = "model";
|
|
150
|
+
BaseComponentProps["LOCALE"] = "locale";
|
|
151
|
+
BaseComponentProps["PK"] = "pk";
|
|
152
|
+
BaseComponentProps["ITEMS"] = "items";
|
|
153
|
+
BaseComponentProps["ROUTE"] = "route";
|
|
154
|
+
BaseComponentProps["OPERATIONS"] = "operations";
|
|
155
|
+
BaseComponentProps["UID"] = "uid";
|
|
156
|
+
BaseComponentProps["TRANSLATABLE"] = "translatable";
|
|
157
|
+
BaseComponentProps["MAPPER"] = "mapper";
|
|
158
|
+
BaseComponentProps["INITIALIZED"] = "initialized";
|
|
159
|
+
})(BaseComponentProps || (BaseComponentProps = {}));
|
|
160
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../src/lib/engine/constants.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAC;AACjD,OAAO,EAAE,qBAAqB,EAAE,MAAM,gCAAgC,CAAC;AAEvE;;;;;;;;;;;;;;;;;;;GAmBG;AACH,MAAM,CAAC,MAAM,iBAAiB,GAAG;IAC/B,OAAO,EAAE,GAAG,MAAM,CAAC,OAAO,WAAW;IACrC,OAAO,EAAE,mBAAmB;IAC5B,WAAW,EAAE,iBAAiB;IAC9B,IAAI,EAAE,MAAM;IACZ,UAAU,EAAE,aAAa;IACzB,QAAQ,EAAE,cAAc;IACxB,MAAM,EAAE,QAAQ;IAChB,QAAQ,EAAE,UAAU;IACpB,QAAQ,EAAE,UAAU;IACpB,MAAM,EAAE,QAAQ;IAChB,WAAW,EAAE,iBAAiB;IAC9B,MAAM,EAAE,SAAS;IACjB,qBAAqB,EAAE,qBAAqB;CAC7C,CAAC;AAEF;;;;;;;;;GASG;AACH,MAAM,CAAC,MAAM,aAAa,GAAG;IAC3B,KAAK,EAAE,OAAO;IACd,OAAO,EAAE,SAAS;CACnB,CAAC;AAEF;;;;;;;;;;;GAWG;AACH,MAAM,CAAN,IAAY,cAKX;AALD,WAAY,cAAc;IACxB,yEAAuD,CAAA;IACvD,gDAA8B,CAAA;IAC9B,4CAA0B,CAAA;IAC1B,8CAA4B,CAAA;AAC9B,CAAC,EALW,cAAc,KAAd,cAAc,QAKzB;AAED;;;;;;;;;;;;;GAaG;AACH,MAAM,CAAN,IAAY,YAOX;AAPD,WAAY,YAAY;IACtB,6CAAO,CAAA;IACP,iDAAS,CAAA;IACT,+CAAQ,CAAA;IACR,+CAAQ,CAAA;IACR,iDAAS,CAAA;IACT,uDAAY,CAAA;AACd,CAAC,EAPW,YAAY,KAAZ,YAAY,QAOvB;AAAA,CAAC;AAEF;;;;;;;;;;GAUG;AACH,MAAM,CAAN,IAAY,eAIX;AAJD,WAAY,eAAe;IACzB,gCAAa,CAAA;IACb,sCAAmB,CAAA;IACnB,gCAAa,CAAA;AACf,CAAC,EAJW,eAAe,KAAf,eAAe,QAI1B;AAGD;;;;;;;;;;GAUG;AACH,MAAM,CAAN,IAAY,kBAIX;AAJD,WAAY,kBAAkB;IAC5B,uDAAiC,CAAA;IACjC,+DAAyC,CAAA;IACzC,iEAA2C,CAAA;AAC7C,CAAC,EAJW,kBAAkB,KAAlB,kBAAkB,QAI7B;AAED;;;;;;;;;;;;;;;;;GAiBG;AACH,MAAM,CAAN,IAAY,kBAWX;AAXD,WAAY,kBAAkB;IAC5B,qCAAe,CAAA;IACf,uCAAiB,CAAA;IACjB,+BAAS,CAAA;IACT,qCAAe,CAAA;IACf,qCAAe,CAAA;IACf,+CAAyB,CAAA;IACzB,iCAAW,CAAA;IACX,mDAA6B,CAAA;IAC7B,uCAAiB,CAAA;IACjB,iDAA2B,CAAA;AAC7B,CAAC,EAXW,kBAAkB,KAAlB,kBAAkB,QAW7B","sourcesContent":["import { UIKeys } from '@decaf-ts/ui-decorators';\nimport { VALIDATION_PARENT_KEY } from '@decaf-ts/decorator-validation';\n\n/**\n * @description Angular engine key constants\n * @summary Contains key strings used by the Angular rendering engine for reflection,\n * dynamic component creation, and other engine operations.\n * @typedef {Object} AngularEngineKeys\n * @property {string} REFLECT - Prefix for reflection metadata keys\n * @property {string} DYNAMIC - Key for dynamic component identification\n * @property {string} ANNOTATIONS - Key for component annotations\n * @property {string} ECMP - Key for embedded components\n * @property {string} NG_REFLECT - Prefix for Angular reflection attributes\n * @property {string} RENDERED - Prefix for rendered component markers\n * @property {string} MAPPER - Key for property mappers\n * @property {string} CHILDREN - Key for child components\n * @property {string} LISTABLE - Key for listable components\n * @property {string} RENDER - Key for renderable components\n * @property {string} RENDERED_ID - Template for rendered component IDs\n * @property {string} PARENT - Key for comparison decorators and validators\n * @const AngularEngineKeys\n * @memberOf module:engine\n */\nexport const AngularEngineKeys = {\n  REFLECT: `${UIKeys.REFLECT}.angular.`,\n  DYNAMIC: 'dynamic-component',\n  ANNOTATIONS: '__annotations__',\n  ECMP: 'ecmp',\n  NG_REFLECT: 'ng-reflect-',\n  RENDERED: 'rendered-as-',\n  MAPPER: 'mapper',\n  CHILDREN: 'children',\n  LISTABLE: 'listable',\n  RENDER: 'render',\n  RENDERED_ID: 'rendered-as-{0}',\n  PARENT: '_parent',\n  VALIDATION_PARENT_KEY: VALIDATION_PARENT_KEY\n};\n\n/**\n * @description Form validation state constants\n * @summary Contains constants representing the possible validation states of a form.\n * These are used to check and handle form validation throughout the application.\n * @typedef {Object} FormConstants\n * @property {string} VALID - Constant representing a valid form state\n * @property {string} INVALID - Constant representing an invalid form state\n * @const FormConstants\n * @memberOf module:engine\n */\nexport const FormConstants = {\n  VALID: 'VALID',\n  INVALID: 'INVALID',\n};\n\n/**\n * @description Event name constants\n * @summary Enum containing constants for event names used throughout the application.\n * These are used to standardize event naming and handling.\n * @enum {string}\n * @readonly\n * @property {string} BACK_BUTTON_NAVIGATION - Event fired when back button navigation ends\n * @property {string} REFRESH_EVENT - Event fired when a refresh action occurs\n * @property {string} CLICK_EVENT - Event fired when a click action occurs\n * @property {string} SUBMIT_EVENT - Event fired when a form submission occurs\n * @memberOf module:engine\n */\nexport enum EventConstants {\n  BACK_BUTTON_NAVIGATION = 'backButtonNavigationEndEvent',\n  REFRESH_EVENT = 'RefreshEvent',\n  CLICK_EVENT = 'ClickEvent',\n  SUBMIT_EVENT = 'SubmitEvent',\n}\n\n/**\n * @description Logger level constants\n * @summary Enum defining the logging levels used in the application's logging system.\n * Lower values represent more verbose logging, while higher values represent more critical logs.\n * @enum {number}\n * @readonly\n * @property {number} ALL - Log everything (most verbose)\n * @property {number} DEBUG - Log debug information\n * @property {number} INFO - Log informational messages\n * @property {number} WARN - Log warnings\n * @property {number} ERROR - Log errors\n * @property {number} CRITICAL - Log critical errors (least verbose)\n * @memberOf module:engine\n */\nexport enum LoggerLevels {\n  ALL = 0,\n  DEBUG = 1,\n  INFO = 2,\n  WARN = 3,\n  ERROR = 4,\n  CRITICAL = 5\n};\n\n/**\n * @description Route direction constants\n * @summary Enum defining the possible navigation directions in the application.\n * Used for controlling navigation flow and animation directions.\n * @enum {string}\n * @readonly\n * @property {string} BACK - Navigate back to the previous page\n * @property {string} FORWARD - Navigate forward to the next page\n * @property {string} ROOT - Navigate to the root/home page\n * @memberOf module:engine\n */\nexport enum RouteDirections {\n  BACK = 'back',\n  FORWARD = 'forward',\n  ROOT = 'root',\n}\n\n\n/**\n * @description Component tag name constants\n * @summary Enum defining the tag names for custom components used in the application.\n * These tag names are used for component registration and rendering.\n * @enum {string}\n * @readonly\n * @property {string} LIST_ITEM - Tag name for list item component\n * @property {string} LIST_INFINITE - Tag name for infinite scrolling list component\n * @property {string} LIST_PAGINATED - Tag name for paginated list component\n * @memberOf module:engine\n */\nexport enum ComponentsTagNames {\n  LIST_ITEM = 'ngx-decaf-list-item',\n  LIST_INFINITE = 'ngx-decaf-list-infinite',\n  LIST_PAGINATED = 'ngx-decaf-list-paginated',\n}\n\n/**\n * @description Base component property name constants\n * @summary Enum defining the standard property names used by base components in the application.\n * These property names are used for consistent property access across components.\n * @enum {string}\n * @readonly\n * @property {string} MODEL - Property name for the component's data model\n * @property {string} LOCALE - Property name for localization settings\n * @property {string} PK - Property name for primary key\n * @property {string} ITEMS - Property name for collection items\n * @property {string} ROUTE - Property name for routing information\n * @property {string} OPERATIONS - Property name for available operations\n * @property {string} UID - Property name for unique identifier\n * @property {string} TRANSLATABLE - Property name for translation flag\n * @property {string} MAPPER - Property name for property mapper\n * @property {string} INITIALIZED - Property name for initialization state\n * @memberOf module:engine\n */\nexport enum BaseComponentProps {\n  MODEL = 'model',\n  LOCALE = 'locale',\n  PK = 'pk',\n  ITEMS = 'items',\n  ROUTE = 'route',\n  OPERATIONS = 'operations',\n  UID = 'uid',\n  TRANSLATABLE = 'translatable',\n  MAPPER = 'mapper',\n  INITIALIZED = 'initialized',\n}\n\n\n"]}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { apply, metadata } from '@decaf-ts/reflection';
|
|
2
|
+
import { NgxRenderingEngine2 } from './NgxRenderingEngine2';
|
|
3
|
+
import { AngularEngineKeys } from './constants';
|
|
4
|
+
import { InternalError } from '@decaf-ts/db-decorators';
|
|
5
|
+
import { reflectComponentType } from '@angular/core';
|
|
6
|
+
/**
|
|
7
|
+
* @description Marks an Angular component as dynamically loadable
|
|
8
|
+
* @summary Decorator that registers an Angular component with the NgxRenderingEngine2 for dynamic loading.
|
|
9
|
+
* This decorator must be applied before the @Component decorator to properly extract component metadata.
|
|
10
|
+
* It adds metadata to the component class and registers it with the rendering engine using its selector.
|
|
11
|
+
* @function Dynamic
|
|
12
|
+
* @return {Function} A decorator function that can be applied to Angular component classes
|
|
13
|
+
* @mermaid
|
|
14
|
+
* sequenceDiagram
|
|
15
|
+
* participant C as Component Class
|
|
16
|
+
* participant D as Dynamic Decorator
|
|
17
|
+
* participant R as NgxRenderingEngine2
|
|
18
|
+
* participant M as Angular Metadata
|
|
19
|
+
* C->>D: Apply decorator
|
|
20
|
+
* D->>M: reflectComponentType()
|
|
21
|
+
* M-->>D: Return component metadata
|
|
22
|
+
* alt No metadata found
|
|
23
|
+
* D->>D: Throw InternalError
|
|
24
|
+
* else Metadata found
|
|
25
|
+
* D->>R: registerComponent(selector, constructor)
|
|
26
|
+
* D->>C: Apply metadata
|
|
27
|
+
* end
|
|
28
|
+
* @category Decorators
|
|
29
|
+
*/
|
|
30
|
+
export function Dynamic() {
|
|
31
|
+
return apply((original) => {
|
|
32
|
+
const metadata = reflectComponentType(original);
|
|
33
|
+
if (!metadata)
|
|
34
|
+
throw new InternalError(`Could not find Component metadata. @Dynamic decorator must come above @Component`);
|
|
35
|
+
NgxRenderingEngine2.registerComponent(metadata.selector, original);
|
|
36
|
+
}, metadata(NgxRenderingEngine2.key(AngularEngineKeys.DYNAMIC), true));
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVjb3JhdG9ycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvZW5naW5lL2RlY29yYXRvcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLEtBQUssRUFBRSxRQUFRLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFaEQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3hELE9BQU8sRUFBRSxvQkFBb0IsRUFBUSxNQUFNLGVBQWUsQ0FBQztBQUUzRDs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0F1Qkc7QUFDSCxNQUFNLFVBQVUsT0FBTztJQUNyQixPQUFPLEtBQUssQ0FDVixDQUFDLFFBQWdCLEVBQUUsRUFBRTtRQUNuQixNQUFNLFFBQVEsR0FBRyxvQkFBb0IsQ0FBQyxRQUF5QixDQUFDLENBQUM7UUFFakUsSUFBSSxDQUFDLFFBQVE7WUFDWCxNQUFNLElBQUksYUFBYSxDQUNyQixrRkFBa0YsQ0FDbkYsQ0FBQztRQUVKLG1CQUFtQixDQUFDLGlCQUFpQixDQUNuQyxRQUFRLENBQUMsUUFBUSxFQUNqQixRQUEyQyxDQUM1QyxDQUFDO0lBQ0osQ0FBQyxFQUNELFFBQVEsQ0FBQyxtQkFBbUIsQ0FBQyxHQUFHLENBQUMsaUJBQWlCLENBQUMsT0FBTyxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQ25FLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYXBwbHksIG1ldGFkYXRhIH0gZnJvbSAnQGRlY2FmLXRzL3JlZmxlY3Rpb24nO1xuaW1wb3J0IHsgTmd4UmVuZGVyaW5nRW5naW5lMiB9IGZyb20gJy4vTmd4UmVuZGVyaW5nRW5naW5lMic7XG5pbXBvcnQgeyBBbmd1bGFyRW5naW5lS2V5cyB9IGZyb20gJy4vY29uc3RhbnRzJztcbmltcG9ydCB7IENvbnN0cnVjdG9yIH0gZnJvbSAnQGRlY2FmLXRzL2RlY29yYXRvci12YWxpZGF0aW9uJztcbmltcG9ydCB7IEludGVybmFsRXJyb3IgfSBmcm9tICdAZGVjYWYtdHMvZGItZGVjb3JhdG9ycyc7XG5pbXBvcnQgeyByZWZsZWN0Q29tcG9uZW50VHlwZSwgVHlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBNYXJrcyBhbiBBbmd1bGFyIGNvbXBvbmVudCBhcyBkeW5hbWljYWxseSBsb2FkYWJsZVxuICogQHN1bW1hcnkgRGVjb3JhdG9yIHRoYXQgcmVnaXN0ZXJzIGFuIEFuZ3VsYXIgY29tcG9uZW50IHdpdGggdGhlIE5neFJlbmRlcmluZ0VuZ2luZTIgZm9yIGR5bmFtaWMgbG9hZGluZy5cbiAqIFRoaXMgZGVjb3JhdG9yIG11c3QgYmUgYXBwbGllZCBiZWZvcmUgdGhlIEBDb21wb25lbnQgZGVjb3JhdG9yIHRvIHByb3Blcmx5IGV4dHJhY3QgY29tcG9uZW50IG1ldGFkYXRhLlxuICogSXQgYWRkcyBtZXRhZGF0YSB0byB0aGUgY29tcG9uZW50IGNsYXNzIGFuZCByZWdpc3RlcnMgaXQgd2l0aCB0aGUgcmVuZGVyaW5nIGVuZ2luZSB1c2luZyBpdHMgc2VsZWN0b3IuXG4gKiBAZnVuY3Rpb24gRHluYW1pY1xuICogQHJldHVybiB7RnVuY3Rpb259IEEgZGVjb3JhdG9yIGZ1bmN0aW9uIHRoYXQgY2FuIGJlIGFwcGxpZWQgdG8gQW5ndWxhciBjb21wb25lbnQgY2xhc3Nlc1xuICogQG1lcm1haWRcbiAqIHNlcXVlbmNlRGlhZ3JhbVxuICogICBwYXJ0aWNpcGFudCBDIGFzIENvbXBvbmVudCBDbGFzc1xuICogICBwYXJ0aWNpcGFudCBEIGFzIER5bmFtaWMgRGVjb3JhdG9yXG4gKiAgIHBhcnRpY2lwYW50IFIgYXMgTmd4UmVuZGVyaW5nRW5naW5lMlxuICogICBwYXJ0aWNpcGFudCBNIGFzIEFuZ3VsYXIgTWV0YWRhdGFcbiAqICAgQy0+PkQ6IEFwcGx5IGRlY29yYXRvclxuICogICBELT4+TTogcmVmbGVjdENvbXBvbmVudFR5cGUoKVxuICogICBNLS0+PkQ6IFJldHVybiBjb21wb25lbnQgbWV0YWRhdGFcbiAqICAgYWx0IE5vIG1ldGFkYXRhIGZvdW5kXG4gKiAgICAgRC0+PkQ6IFRocm93IEludGVybmFsRXJyb3JcbiAqICAgZWxzZSBNZXRhZGF0YSBmb3VuZFxuICogICAgIEQtPj5SOiByZWdpc3RlckNvbXBvbmVudChzZWxlY3RvciwgY29uc3RydWN0b3IpXG4gKiAgICAgRC0+PkM6IEFwcGx5IG1ldGFkYXRhXG4gKiAgIGVuZFxuICogQGNhdGVnb3J5IERlY29yYXRvcnNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIER5bmFtaWMoKSB7XG4gIHJldHVybiBhcHBseShcbiAgICAob3JpZ2luYWw6IG9iamVjdCkgPT4ge1xuICAgICAgY29uc3QgbWV0YWRhdGEgPSByZWZsZWN0Q29tcG9uZW50VHlwZShvcmlnaW5hbCBhcyBUeXBlPHVua25vd24+KTtcblxuICAgICAgaWYgKCFtZXRhZGF0YSlcbiAgICAgICAgdGhyb3cgbmV3IEludGVybmFsRXJyb3IoXG4gICAgICAgICAgYENvdWxkIG5vdCBmaW5kIENvbXBvbmVudCBtZXRhZGF0YS4gQER5bmFtaWMgZGVjb3JhdG9yIG11c3QgY29tZSBhYm92ZSBAQ29tcG9uZW50YFxuICAgICAgICApO1xuXG4gICAgICBOZ3hSZW5kZXJpbmdFbmdpbmUyLnJlZ2lzdGVyQ29tcG9uZW50KFxuICAgICAgICBtZXRhZGF0YS5zZWxlY3RvcixcbiAgICAgICAgb3JpZ2luYWwgYXMgdW5rbm93biBhcyBDb25zdHJ1Y3Rvcjx1bmtub3duPlxuICAgICAgKTtcbiAgICB9LFxuICAgIG1ldGFkYXRhKE5neFJlbmRlcmluZ0VuZ2luZTIua2V5KEFuZ3VsYXJFbmdpbmVLZXlzLkRZTkFNSUMpLCB0cnVlKVxuICApO1xufVxuIl19
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @module engine
|
|
3
|
+
* @description Angular rendering engine for Decaf applications
|
|
4
|
+
* @summary The engine module provides core functionality for rendering Angular components
|
|
5
|
+
* in Decaf applications. It includes constants, decorators, rendering engines, and utility types
|
|
6
|
+
* that enable dynamic component creation, property mapping, and component lifecycle management.
|
|
7
|
+
* Key exports include {@link NgxRenderingEngine}, {@link DynamicModule}, and various decorators
|
|
8
|
+
* for component configuration.
|
|
9
|
+
*/
|
|
10
|
+
export * from './constants';
|
|
11
|
+
export * from './decorators';
|
|
12
|
+
export * from './DynamicModule';
|
|
13
|
+
export * from './NgxRenderingEngine';
|
|
14
|
+
export * from './NgxRenderingEngine2';
|
|
15
|
+
export * from './types';
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL2VuZ2luZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7R0FRRztBQUNILGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbW9kdWxlIGVuZ2luZVxuICogQGRlc2NyaXB0aW9uIEFuZ3VsYXIgcmVuZGVyaW5nIGVuZ2luZSBmb3IgRGVjYWYgYXBwbGljYXRpb25zXG4gKiBAc3VtbWFyeSBUaGUgZW5naW5lIG1vZHVsZSBwcm92aWRlcyBjb3JlIGZ1bmN0aW9uYWxpdHkgZm9yIHJlbmRlcmluZyBBbmd1bGFyIGNvbXBvbmVudHNcbiAqIGluIERlY2FmIGFwcGxpY2F0aW9ucy4gSXQgaW5jbHVkZXMgY29uc3RhbnRzLCBkZWNvcmF0b3JzLCByZW5kZXJpbmcgZW5naW5lcywgYW5kIHV0aWxpdHkgdHlwZXNcbiAqIHRoYXQgZW5hYmxlIGR5bmFtaWMgY29tcG9uZW50IGNyZWF0aW9uLCBwcm9wZXJ0eSBtYXBwaW5nLCBhbmQgY29tcG9uZW50IGxpZmVjeWNsZSBtYW5hZ2VtZW50LlxuICogS2V5IGV4cG9ydHMgaW5jbHVkZSB7QGxpbmsgTmd4UmVuZGVyaW5nRW5naW5lfSwge0BsaW5rIER5bmFtaWNNb2R1bGV9LCBhbmQgdmFyaW91cyBkZWNvcmF0b3JzXG4gKiBmb3IgY29tcG9uZW50IGNvbmZpZ3VyYXRpb24uXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vY29uc3RhbnRzJztcbmV4cG9ydCAqIGZyb20gJy4vZGVjb3JhdG9ycyc7XG5leHBvcnQgKiBmcm9tICcuL0R5bmFtaWNNb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9OZ3hSZW5kZXJpbmdFbmdpbmUnO1xuZXhwb3J0ICogZnJvbSAnLi9OZ3hSZW5kZXJpbmdFbmdpbmUyJztcbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMnO1xuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/lib/engine/types.ts"],"names":[],"mappings":"","sourcesContent":["import { IonCheckbox, IonInput, IonSelect, IonTextarea } from '@ionic/angular';\nimport { TextFieldTypes } from '@ionic/core';\nimport { EnvironmentInjector, Injector, Type } from '@angular/core';\nimport { FormControl, FormGroup } from '@angular/forms';\nimport { FieldProperties } from '@decaf-ts/ui-decorators';\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport type KeyValue = Record<string, any>;\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport type FunctionLike = (...args: any[]) => any;\n\n/**\n * @description Element size options for UI components\n * @summary Defines the possible size values that can be applied to UI elements.\n * These sizes control the dimensions and layout behavior of components.\n * @typedef {('small'|'medium'|'large'|'xlarge'|'2xlarge'|'auto'|'expand'|'block')} ElementSizes\n * @memberOf module:engine\n */\nexport type ElementSizes =\n  | 'small'\n  | 'medium'\n  | 'large'\n  | 'xlarge'\n  | '2xlarge'\n  | 'auto'\n  | 'expand'\n  | 'block';\n\n/**\n * @description Basic position options for UI elements\n * @summary Defines the possible position values that can be applied to UI elements.\n * These positions control the alignment and placement of components.\n * @typedef {('left'|'center'|'right'|'top'|'bottom')} ElementPositions\n * @memberOf module:engine\n */\nexport type ElementPositions = 'left' | 'center' | 'right' | 'top' | 'bottom';\n\n/**\n * @description Extended position options for flex layouts\n * @summary Extends the basic ElementPositions with additional flex-specific position values.\n * These positions are used for controlling alignment and distribution in flex containers.\n * @typedef {(ElementPositions|'stretch'|'middle'|'around'|'between')} FlexPositions\n * @memberOf module:engine\n */\nexport type FlexPositions =\n  | ElementPositions\n  | 'stretch'\n  | 'middle'\n  | 'around'\n  | 'between';\n\n/**\n * @description Update mode options for form fields\n * @summary Defines when form field values should be updated in the model.\n * - 'change': Update on every change event\n * - 'blur': Update when the field loses focus\n * - 'submit': Update only when the form is submitted\n * @typedef {('change'|'blur'|'submit')} FieldUpdateMode\n * @memberOf module:engine\n */\nexport type FieldUpdateMode = 'change' | 'blur' | 'submit';\n\n/**\n * @description Metadata structure for Angular components\n * @summary Defines the structure of metadata for Angular components, including\n * change detection strategy, selector, standalone status, imports, template, and styles.\n * This is used for reflection and dynamic component creation.\n * @interface ComponentMetadata\n * @property {number} changeDetection - The change detection strategy number\n * @property {string} selector - The CSS selector for the component\n * @property {boolean} standalone - Whether the component is standalone\n * @property imports - Array of imported modules/components\n * @property {string} template - The HTML template for the component\n * @property {string[]} styles - Array of CSS styles for the component\n * @memberOf module:engine\n */\nexport interface ComponentMetadata {\n  changeDetection: number;\n  selector: string;\n  standalone: boolean;\n  imports: (new (...args: unknown[]) => unknown)[];\n  template: string;\n  styles: string[];\n}\n\n/**\n * @description Output structure from the Angular rendering engine\n * @summary Defines the structure of the output produced by the NgxRenderingEngine\n * when rendering a component. Contains the component type, inputs, injector,\n * content nodes, and child components.\n * @typedef {Object} AngularDynamicOutput\n * @property {Type<unknown>} component - The Angular component type\n * @property {string} [rendererId] - Optional unique ID for the rendered component\n * @property {Record<string, unknown>} [inputs] - Optional input properties for the component\n * @property {Injector} [injector] - Optional Angular injector for dependency injection\n * @property {Node[][]} [content] - Optional content nodes for projection\n * @property {AngularDynamicOutput[]} [children] - Optional child components\n * @property {Type<unknown>} [instance] - Optional component instance\n * @property {FormGroup} [formGroup] - Optional component FormGroup\n * @property {FormControl} [formControl] - Optional component FormControl\n * @memberOf module:engine\n */\nexport interface AngularDynamicOutput {\n  component: Type<unknown>;\n  rendererId?: string;\n  inputs?: Record<string, unknown>;\n  injector?: Injector;\n  content?: Node[][];\n  children?: AngularDynamicOutput[];\n  instance?: Type<unknown>;\n  formGroup?: FormGroup;\n  formControl?: FormControl;\n}\n\n/**\n * @description Interface for models that can be rendered\n * @summary Defines the basic structure for models that can be rendered by the engine.\n * Contains an optional rendererId that uniquely identifies the rendered instance.\n * @interface RenderedModel\n * @property {string} [rendererId] - Optional unique ID for the rendered model instance\n * @memberOf module:engine\n */\nexport interface RenderedModel {\n  rendererId?: string;\n}\n\n/**\n * @description Possible input types for form fields\n * @summary Defines the possible input types that can be used in form fields.\n * Includes standard HTML input types like checkbox, radio, and select,\n * as well as Ionic's TextFieldTypes and textarea.\n * @typedef {('checkbox'|'radio'|'select'|TextFieldTypes|'textarea')} PossibleInputTypes\n * @memberOf module:engine\n */\nexport type PossibleInputTypes =\n  | 'checkbox'\n  | 'radio'\n  | 'select'\n  | TextFieldTypes\n  | 'textarea';\n\n/**\n * @description Field definition for Angular components\n * @summary A comprehensive type that combines properties from various Ionic components\n * to define the structure of a field in an Angular form. It omits certain properties\n * from IonInput, picks specific properties from IonSelect, IonTextarea, and IonCheckbox,\n * and adds custom properties like type and className.\n * @typedef {Object} AngularFieldDefinition\n * @property {PossibleInputTypes} type - The type of input field\n * @property {string|string[]} className - CSS class name(s) for the field\n * @property {string} [cancelText] - Text for the cancel button (from IonSelect)\n * @property {string} [interface] - Interface style for select (from IonSelect)\n * @property {string} [selectedText] - Text for selected option (from IonSelect)\n * @property {Object} [interfaceOptions] - Options for the interface (from IonSelect)\n * @property {number} [rows] - Number of rows for textarea (from IonTextarea)\n * @property {number} [cols] - Number of columns for textarea (from IonTextarea)\n * @property {string} [alignment] - Alignment of checkbox (from IonCheckbox)\n * @property {string} [justify] - Justification of checkbox (from IonCheckbox)\n * @property {boolean} [checked] - Whether checkbox is checked (from IonCheckbox)\n * @memberOf module:engine\n */\nexport type AngularFieldDefinition = Omit<\n  IonInput,\n  | 'ionInput'\n  | 'ionFocus'\n  | 'ionChange'\n  | 'ionBlur'\n  | 'getInputElement'\n  | 'setFocus'\n  | 'label'\n  | 'el'\n  | 'z'\n  | 'type'\n> &\n  Pick<\n    IonSelect,\n    'cancelText' | 'interface' | 'selectedText' | 'interfaceOptions'\n  > &\n  Pick<IonTextarea, 'rows' | 'cols'> &\n  Pick<IonCheckbox, 'alignment' | 'justify' | 'checked'> & {\n  type: PossibleInputTypes;\n  className: string | string[];\n} & Record<string, unknown>;\n\n/**\n * @description String or boolean representation of a boolean value\n * @summary Represents a value that can be either a boolean or a string representation of a boolean.\n * This is useful for handling attribute values that can be specified as either strings or booleans.\n * @typedef {('true'|'false'|boolean)} StringOrBoolean\n * @memberOf module:engine\n */\nexport type StringOrBoolean = 'true' | 'false' | boolean;\n\n/**\n * @description Option type for select inputs\n * @summary Extends the InputOption interface with a selected property to indicate\n * whether the option is selected by default.\n * @memberOf module:engine\n */\nexport type SelectOption = InputOption & { selected?: boolean };\n\n/**\n * @description Option type for radio inputs\n * @summary Extends the InputOption interface with a checked property to indicate\n * whether the option is checked by default.\n * @memberOf module:engine\n */\nexport type RadioOption = InputOption & { checked?: boolean };\n\n/**\n * @description Option type for checkbox inputs\n * @summary Alias for RadioOption, as checkbox options have the same structure as radio options.\n * @typedef {RadioOption} CheckboxOption\n * @memberOf module:engine\n */\nexport type CheckboxOption = RadioOption;\n\n/**\n * @description Base option type for input components\n * @summary Defines the common structure for options used in select, radio, and checkbox inputs.\n * Contains properties for the display text, value, disabled state, CSS class, and icon.\n * @interface InputOption\n * @property {string} text - The display text for the option\n * @property {string|number} value - The value associated with the option\n * @property {StringOrBoolean} [disabled] - Whether the option is disabled\n * @property {string} [className] - CSS class name for styling the option\n * @property {string} [icon] - Icon to display with the option\n * @memberOf module:engine\n */\nexport interface InputOption {\n  text: string;\n  value: string | number;\n  disabled?: StringOrBoolean;\n  className?: string;\n  icon?: string;\n}\n\n/**\n * @description Target options for HTML forms\n * @summary Defines the possible target values for HTML forms, including standard targets\n * like '_blank', '_self', '_parent', and '_top', as well as custom string values.\n * @typedef {('_blank'|'_self'|'_parent'|'_top'|string)} HTMLFormTarget\n * @memberOf module:engine\n */\nexport type HTMLFormTarget = '_blank' | '_self' | '_parent' | '_top' | string;\n\n// export interface IListItemProp {\n//   render?: string | boolean;\n//   translateProps?: string | string[];\n//   button?: StringOrBoolean;\n//   icon?: string;\n//   iconSlot?: 'start' | 'end';\n//   title?: string;\n//   descritpion?: string;\n//   info?: string;\n//   subinfo?: string;\n// }\n\n/**\n * @description Interface for list component refresh events\n * @summary Defines the structure of a refresh event for list components.\n * Contains an array of key-value pairs representing the new data for the list.\n * @interface IListComponentRefreshEvent\n * @property {KeyValue[]} data - Array of key-value pairs representing the new data\n * @memberOf module:engine\n */\nexport interface IListComponentRefreshEvent {\n  data: KeyValue[];\n}\n\nexport interface FormServiceControl {\n  control: FormGroup;\n  props: AngularFieldDefinition;\n}\n\n/**\n * @description Type for form service controls\n * @summary Defines the structure of form controls managed by the form service.\n * It's a nested record where the outer key is the form group name, the inner key\n * is the control name, and the value contains the form group and field properties.\n * @typedef {Record<string, Record<string, { control: FormGroup; props: AngularFieldDefinition }>>} FormServiceControls\n * @memberOf module:engine\n */\nexport type FormServiceControls = Record<\n  string,\n  Record<string, FormServiceControl>\n>;\n\n/**\n * @description Interface for model render custom events\n * @summary Defines the structure of custom events triggered during model rendering.\n * Contains the event detail, component name, and event name.\n * @interface ModelRenderCustomEvent\n * @property {BaseCustomEvent} detail - The detailed event information\n * @property {string} component - The component that triggered the event\n * @property {string} name - The name of the event\n * @memberOf module:engine\n */\nexport interface ModelRenderCustomEvent {\n  detail: BaseCustomEvent;\n  component: string;\n  name: string;\n}\n\n/**\n * @description Interface for list item custom events\n * @summary Defines the structure of custom events triggered by list items.\n * Extends BaseCustomEvent with additional properties for the action and primary key.\n * @interface ListItemCustomEvent\n * @property {string} action - The action performed on the list item\n * @property {string} [pk] - Optional primary key of the affected item\n * @property {any} data - The data associated with the event (inherited from BaseCustomEvent)\n * @property {HTMLElement} [target] - The target element (inherited from BaseCustomEvent)\n * @property {string} [name] - The name of the event (inherited from BaseCustomEvent)\n * @property {string} component - The component that triggered the event (inherited from BaseCustomEvent)\n * @memberOf module:engine\n */\nexport interface ListItemCustomEvent extends BaseCustomEvent {\n  action: string;\n  pk?: string;\n}\n\n/**\n * @description Base interface for custom events\n * @summary Defines the base structure for custom events in the application.\n * Contains properties for the event data, target element, name, and component.\n * @interface BaseCustomEvent\n * @property {any} data - The data associated with the event\n * @property {HTMLElement} [target] - The target element that triggered the event\n * @property {string} [name] - The name of the event\n * @property {string} component - The component that triggered the event\n * @memberOf module:engine\n */\nexport interface BaseCustomEvent {\n  data: unknown;\n  target?: HTMLElement;\n  name?: string;\n  component: string;\n}\n\n/**\n * @description Base interface for custom events\n * @summary Defines the base structure for custom events in the application.\n * Contains properties for the event data, target element, name, and component.\n * @interface BaseCustomEvent\n * @property {any} data - The data associated with the event\n * @property {HTMLElement} [target] - The target element that triggered the event\n * @property {string} [name] - The name of the event\n * @property {string} component - The component that triggered the event\n * @memberOf module:engine\n */\nexport type CrudFormEvent = BaseCustomEvent & {\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  handlers?: Record<string, any>;\n};\n\n\n\nexport interface ComponentInput extends FieldProperties {\n  updateMode?: FieldUpdateMode;\n  formGroup?: FormGroup;\n  formControl?: FormControl;\n}\n\nexport interface ComponentConfig {\n  component: string;\n  inputs: ComponentInput;\n  injector: EnvironmentInjector | Injector;\n  children?: ComponentConfig[];\n}\n\nexport type FormParentGroup = [FormGroup,  string];\n\n\n\n"]}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
import { NgModule, CUSTOM_ELEMENTS_SCHEMA, NO_ERRORS_SCHEMA } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { IonApp, IonRouterOutlet, IonSplitPane, IonImg, IonContent, IonText, IonButton, IonRouterLink, IonTitle } from '@ionic/angular/standalone';
|
|
4
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
5
|
+
import { TranslateModule, TranslatePipe } from '@ngx-translate/core';
|
|
6
|
+
import { Logging } from '@decaf-ts/logging';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
const ComponentsAndModules = [
|
|
9
|
+
IonApp,
|
|
10
|
+
IonRouterOutlet,
|
|
11
|
+
IonSplitPane,
|
|
12
|
+
IonImg,
|
|
13
|
+
IonText,
|
|
14
|
+
IonTitle,
|
|
15
|
+
IonButton,
|
|
16
|
+
IonRouterLink,
|
|
17
|
+
IonContent,
|
|
18
|
+
CommonModule,
|
|
19
|
+
FormsModule,
|
|
20
|
+
ReactiveFormsModule,
|
|
21
|
+
TranslateModule,
|
|
22
|
+
TranslatePipe,
|
|
23
|
+
];
|
|
24
|
+
const log = Logging.for("for-angular");
|
|
25
|
+
export function getLogger(instance) {
|
|
26
|
+
return log.for(instance);
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* @description Main Angular module for the Decaf framework
|
|
30
|
+
* @summary The ForAngularModule provides the core functionality for integrating Decaf with Angular applications.
|
|
31
|
+
* It imports and exports common Angular and Ionic components and modules needed for Decaf applications,
|
|
32
|
+
* including form handling, translation support, and Ionic UI components. This module can be imported
|
|
33
|
+
* directly or via the forRoot() method for proper initialization in the application's root module.
|
|
34
|
+
*
|
|
35
|
+
* @class ForAngularModule
|
|
36
|
+
* @example
|
|
37
|
+
* ```typescript
|
|
38
|
+
* // In your app module:
|
|
39
|
+
* @NgModule({
|
|
40
|
+
* imports: [
|
|
41
|
+
* ForAngularModule.forRoot(),
|
|
42
|
+
* // other imports
|
|
43
|
+
* ],
|
|
44
|
+
* // ...
|
|
45
|
+
* })
|
|
46
|
+
* export class AppModule {}
|
|
47
|
+
* ```
|
|
48
|
+
*/
|
|
49
|
+
export class ForAngularModule {
|
|
50
|
+
/**
|
|
51
|
+
* @description Creates a module with providers for root module import
|
|
52
|
+
* @summary This static method provides the proper way to import the ForAngularModule in the application's
|
|
53
|
+
* root module. It returns a ModuleWithProviders object that includes the ForAngularModule itself.
|
|
54
|
+
* Using forRoot() ensures that the module and its providers are properly initialized and only
|
|
55
|
+
* instantiated once in the application.
|
|
56
|
+
*
|
|
57
|
+
* @return {ModuleWithProviders<ForAngularModule>} The module with its providers
|
|
58
|
+
*/
|
|
59
|
+
static forRoot() {
|
|
60
|
+
return {
|
|
61
|
+
ngModule: ForAngularModule,
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ForAngularModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
65
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: ForAngularModule, imports: [IonApp,
|
|
66
|
+
IonRouterOutlet,
|
|
67
|
+
IonSplitPane,
|
|
68
|
+
IonImg,
|
|
69
|
+
IonText,
|
|
70
|
+
IonTitle,
|
|
71
|
+
IonButton,
|
|
72
|
+
IonRouterLink,
|
|
73
|
+
IonContent,
|
|
74
|
+
CommonModule,
|
|
75
|
+
FormsModule,
|
|
76
|
+
ReactiveFormsModule,
|
|
77
|
+
TranslateModule,
|
|
78
|
+
TranslatePipe], exports: [IonApp,
|
|
79
|
+
IonRouterOutlet,
|
|
80
|
+
IonSplitPane,
|
|
81
|
+
IonImg,
|
|
82
|
+
IonText,
|
|
83
|
+
IonTitle,
|
|
84
|
+
IonButton,
|
|
85
|
+
IonRouterLink,
|
|
86
|
+
IonContent,
|
|
87
|
+
CommonModule,
|
|
88
|
+
FormsModule,
|
|
89
|
+
ReactiveFormsModule,
|
|
90
|
+
TranslateModule,
|
|
91
|
+
TranslatePipe] }); }
|
|
92
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ForAngularModule, imports: [IonApp,
|
|
93
|
+
IonRouterOutlet,
|
|
94
|
+
IonSplitPane,
|
|
95
|
+
IonImg,
|
|
96
|
+
IonText,
|
|
97
|
+
IonTitle,
|
|
98
|
+
IonButton,
|
|
99
|
+
IonContent,
|
|
100
|
+
CommonModule,
|
|
101
|
+
FormsModule,
|
|
102
|
+
ReactiveFormsModule,
|
|
103
|
+
TranslateModule,
|
|
104
|
+
CommonModule,
|
|
105
|
+
FormsModule,
|
|
106
|
+
ReactiveFormsModule,
|
|
107
|
+
TranslateModule] }); }
|
|
108
|
+
}
|
|
109
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ForAngularModule, decorators: [{
|
|
110
|
+
type: NgModule,
|
|
111
|
+
args: [{
|
|
112
|
+
imports: ComponentsAndModules,
|
|
113
|
+
declarations: [],
|
|
114
|
+
exports: ComponentsAndModules,
|
|
115
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA, NO_ERRORS_SCHEMA],
|
|
116
|
+
}]
|
|
117
|
+
}] });
|
|
118
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9yLWFuZ3VsYXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi9mb3ItYW5ndWxhci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxzQkFBc0IsRUFBdUIsZ0JBQWdCLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkcsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFDTCxNQUFNLEVBQ04sZUFBZSxFQUNmLFlBQVksRUFDWixNQUFNLEVBQ04sVUFBVSxFQUNWLE9BQU8sRUFDUCxTQUFTLEVBQ1QsYUFBYSxFQUNiLFFBQVEsRUFDVCxNQUFNLDJCQUEyQixDQUFDO0FBQ25DLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZUFBZSxFQUFFLGFBQWEsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3JFLE9BQU8sRUFBVSxPQUFPLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQzs7QUFHcEQsTUFBTSxvQkFBb0IsR0FBRztJQUMzQixNQUFNO0lBQ04sZUFBZTtJQUNmLFlBQVk7SUFDWixNQUFNO0lBQ04sT0FBTztJQUNQLFFBQVE7SUFDUixTQUFTO0lBQ1QsYUFBYTtJQUNiLFVBQVU7SUFDVixZQUFZO0lBQ1osV0FBVztJQUNYLG1CQUFtQjtJQUNuQixlQUFlO0lBQ2YsYUFBYTtDQUNkLENBQUM7QUFFRixNQUFNLEdBQUcsR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLGFBQWEsQ0FBQyxDQUFDO0FBQ3ZDLE1BQU0sVUFBVSxTQUFTLENBQUMsUUFBeUM7SUFDakUsT0FBTyxHQUFHLENBQUMsR0FBRyxDQUFDLFFBQWlDLENBQUMsQ0FBQztBQUNwRCxDQUFDO0FBRUQ7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBb0JHO0FBT0gsTUFBTSxPQUFPLGdCQUFnQjtJQUMzQjs7Ozs7Ozs7T0FRRztJQUNILE1BQU0sQ0FBQyxPQUFPO1FBQ1osT0FBTztZQUNMLFFBQVEsRUFBRSxnQkFBZ0I7U0FDM0IsQ0FBQztJQUNKLENBQUM7K0dBZFUsZ0JBQWdCO2dIQUFoQixnQkFBZ0IsWUFoRDNCLE1BQU07WUFDTixlQUFlO1lBQ2YsWUFBWTtZQUNaLE1BQU07WUFDTixPQUFPO1lBQ1AsUUFBUTtZQUNSLFNBQVM7WUFDVCxhQUFhO1lBQ2IsVUFBVTtZQUNWLFlBQVk7WUFDWixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLGVBQWU7WUFDZixhQUFhLGFBYmIsTUFBTTtZQUNOLGVBQWU7WUFDZixZQUFZO1lBQ1osTUFBTTtZQUNOLE9BQU87WUFDUCxRQUFRO1lBQ1IsU0FBUztZQUNULGFBQWE7WUFDYixVQUFVO1lBQ1YsWUFBWTtZQUNaLFdBQVc7WUFDWCxtQkFBbUI7WUFDbkIsZUFBZTtZQUNmLGFBQWE7Z0hBbUNGLGdCQUFnQixZQWhEM0IsTUFBTTtZQUNOLGVBQWU7WUFDZixZQUFZO1lBQ1osTUFBTTtZQUNOLE9BQU87WUFDUCxRQUFRO1lBQ1IsU0FBUztZQUVULFVBQVU7WUFDVixZQUFZO1lBQ1osV0FBVztZQUNYLG1CQUFtQjtZQUNuQixlQUFlO1lBSGYsWUFBWTtZQUNaLFdBQVc7WUFDWCxtQkFBbUI7WUFDbkIsZUFBZTs7NEZBb0NKLGdCQUFnQjtrQkFONUIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsb0JBQW9CO29CQUM3QixZQUFZLEVBQUUsRUFBRTtvQkFDaEIsT0FBTyxFQUFFLG9CQUFvQjtvQkFDN0IsT0FBTyxFQUFFLENBQUMsc0JBQXNCLEVBQUUsZ0JBQWdCLENBQUM7aUJBQ3BEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUsIENVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIE1vZHVsZVdpdGhQcm92aWRlcnMsIE5PX0VSUk9SU19TQ0hFTUF9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7XG4gIElvbkFwcCxcbiAgSW9uUm91dGVyT3V0bGV0LFxuICBJb25TcGxpdFBhbmUsXG4gIElvbkltZyxcbiAgSW9uQ29udGVudCxcbiAgSW9uVGV4dCxcbiAgSW9uQnV0dG9uLFxuICBJb25Sb3V0ZXJMaW5rLFxuICBJb25UaXRsZVxufSBmcm9tICdAaW9uaWMvYW5ndWxhci9zdGFuZGFsb25lJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgVHJhbnNsYXRlTW9kdWxlLCBUcmFuc2xhdGVQaXBlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5pbXBvcnQgeyBMb2dnZXIsIExvZ2dpbmcgfSBmcm9tICdAZGVjYWYtdHMvbG9nZ2luZyc7XG5pbXBvcnQgeyBGdW5jdGlvbkxpa2UgfSBmcm9tICcuL2VuZ2luZSc7XG5cbmNvbnN0IENvbXBvbmVudHNBbmRNb2R1bGVzID0gW1xuICBJb25BcHAsXG4gIElvblJvdXRlck91dGxldCxcbiAgSW9uU3BsaXRQYW5lLFxuICBJb25JbWcsXG4gIElvblRleHQsXG4gIElvblRpdGxlLFxuICBJb25CdXR0b24sXG4gIElvblJvdXRlckxpbmssXG4gIElvbkNvbnRlbnQsXG4gIENvbW1vbk1vZHVsZSxcbiAgRm9ybXNNb2R1bGUsXG4gIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gIFRyYW5zbGF0ZU1vZHVsZSxcbiAgVHJhbnNsYXRlUGlwZSxcbl07XG5cbmNvbnN0IGxvZyA9IExvZ2dpbmcuZm9yKFwiZm9yLWFuZ3VsYXJcIik7XG5leHBvcnQgZnVuY3Rpb24gZ2V0TG9nZ2VyKGluc3RhbmNlOiBzdHJpbmcgfCBGdW5jdGlvbkxpa2UgfCB1bmtub3duKTogTG9nZ2VyIHtcbiAgcmV0dXJuIGxvZy5mb3IoaW5zdGFuY2UgYXMgc3RyaW5nIHwgRnVuY3Rpb25MaWtlKTtcbn1cblxuLyoqXG4gKiBAZGVzY3JpcHRpb24gTWFpbiBBbmd1bGFyIG1vZHVsZSBmb3IgdGhlIERlY2FmIGZyYW1ld29ya1xuICogQHN1bW1hcnkgVGhlIEZvckFuZ3VsYXJNb2R1bGUgcHJvdmlkZXMgdGhlIGNvcmUgZnVuY3Rpb25hbGl0eSBmb3IgaW50ZWdyYXRpbmcgRGVjYWYgd2l0aCBBbmd1bGFyIGFwcGxpY2F0aW9ucy5cbiAqIEl0IGltcG9ydHMgYW5kIGV4cG9ydHMgY29tbW9uIEFuZ3VsYXIgYW5kIElvbmljIGNvbXBvbmVudHMgYW5kIG1vZHVsZXMgbmVlZGVkIGZvciBEZWNhZiBhcHBsaWNhdGlvbnMsXG4gKiBpbmNsdWRpbmcgZm9ybSBoYW5kbGluZywgdHJhbnNsYXRpb24gc3VwcG9ydCwgYW5kIElvbmljIFVJIGNvbXBvbmVudHMuIFRoaXMgbW9kdWxlIGNhbiBiZSBpbXBvcnRlZFxuICogZGlyZWN0bHkgb3IgdmlhIHRoZSBmb3JSb290KCkgbWV0aG9kIGZvciBwcm9wZXIgaW5pdGlhbGl6YXRpb24gaW4gdGhlIGFwcGxpY2F0aW9uJ3Mgcm9vdCBtb2R1bGUuXG4gKlxuICogQGNsYXNzIEZvckFuZ3VsYXJNb2R1bGVcbiAqIEBleGFtcGxlXG4gKiBgYGB0eXBlc2NyaXB0XG4gKiAvLyBJbiB5b3VyIGFwcCBtb2R1bGU6XG4gKiBATmdNb2R1bGUoe1xuICogICBpbXBvcnRzOiBbXG4gKiAgICAgRm9yQW5ndWxhck1vZHVsZS5mb3JSb290KCksXG4gKiAgICAgLy8gb3RoZXIgaW1wb3J0c1xuICogICBdLFxuICogICAvLyAuLi5cbiAqIH0pXG4gKiBleHBvcnQgY2xhc3MgQXBwTW9kdWxlIHt9XG4gKiBgYGBcbiAqL1xuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogQ29tcG9uZW50c0FuZE1vZHVsZXMsXG4gIGRlY2xhcmF0aW9uczogW10sXG4gIGV4cG9ydHM6IENvbXBvbmVudHNBbmRNb2R1bGVzLFxuICBzY2hlbWFzOiBbQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQSwgTk9fRVJST1JTX1NDSEVNQV0sXG59KVxuZXhwb3J0IGNsYXNzIEZvckFuZ3VsYXJNb2R1bGUge1xuICAvKipcbiAgICogQGRlc2NyaXB0aW9uIENyZWF0ZXMgYSBtb2R1bGUgd2l0aCBwcm92aWRlcnMgZm9yIHJvb3QgbW9kdWxlIGltcG9ydFxuICAgKiBAc3VtbWFyeSBUaGlzIHN0YXRpYyBtZXRob2QgcHJvdmlkZXMgdGhlIHByb3BlciB3YXkgdG8gaW1wb3J0IHRoZSBGb3JBbmd1bGFyTW9kdWxlIGluIHRoZSBhcHBsaWNhdGlvbidzXG4gICAqIHJvb3QgbW9kdWxlLiBJdCByZXR1cm5zIGEgTW9kdWxlV2l0aFByb3ZpZGVycyBvYmplY3QgdGhhdCBpbmNsdWRlcyB0aGUgRm9yQW5ndWxhck1vZHVsZSBpdHNlbGYuXG4gICAqIFVzaW5nIGZvclJvb3QoKSBlbnN1cmVzIHRoYXQgdGhlIG1vZHVsZSBhbmQgaXRzIHByb3ZpZGVycyBhcmUgcHJvcGVybHkgaW5pdGlhbGl6ZWQgYW5kIG9ubHlcbiAgICogaW5zdGFudGlhdGVkIG9uY2UgaW4gdGhlIGFwcGxpY2F0aW9uLlxuICAgKlxuICAgKiBAcmV0dXJuIHtNb2R1bGVXaXRoUHJvdmlkZXJzPEZvckFuZ3VsYXJNb2R1bGU+fSBUaGUgbW9kdWxlIHdpdGggaXRzIHByb3ZpZGVyc1xuICAgKi9cbiAgc3RhdGljIGZvclJvb3QoKTogTW9kdWxlV2l0aFByb3ZpZGVyczxGb3JBbmd1bGFyTW9kdWxlPiB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG5nTW9kdWxlOiBGb3JBbmd1bGFyTW9kdWxlLFxuICAgIH07XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJmYWNlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvaW50ZXJmYWNlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgRWxlbWVudFJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEBkZXNjcmlwdGlvbiBJbnRlcmZhY2UgZm9yIGNvbXBvbmVudHMgdGhhdCBob2xkIGFuIEVsZW1lbnRSZWZcbiAqIEBzdW1tYXJ5IERlZmluZXMgYSBjb21wb25lbnQgaG9sZGVyIGludGVyZmFjZSB0aGF0IHByb3ZpZGVzIGFjY2VzcyB0byB0aGUgdW5kZXJseWluZyBET00gZWxlbWVudCB0aHJvdWdoIEVsZW1lbnRSZWZcbiAqIEBpbnRlcmZhY2UgQ29tcG9uZW50SG9sZGVyXG4gKiBAbWVtYmVyT2YgbW9kdWxlOmZvci1hbmd1bGFyXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ29tcG9uZW50SG9sZGVyIHtcbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBSZWZlcmVuY2UgdG8gdGhlIGNvbXBvbmVudCdzIERPTSBlbGVtZW50XG4gICAqIEBwcm9wZXJ0eSB7RWxlbWVudFJlZn0gY29tcG9uZW50IC0gVGhlIEVsZW1lbnRSZWYgaW5zdGFuY2UgcHJvdmlkaW5nIGFjY2VzcyB0byB0aGUgbmF0aXZlIERPTSBlbGVtZW50XG4gICAqL1xuICBjb21wb25lbnQ6IEVsZW1lbnRSZWY7XG59XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEludGVyZmFjZSBmb3IgZm9ybSBjb21wb25lbnRzIHRoYXQgaG9sZCBib3RoIGFuIEVsZW1lbnRSZWYgYW5kIGEgRm9ybUdyb3VwXG4gKiBAc3VtbWFyeSBFeHRlbmRzIENvbXBvbmVudEhvbGRlciB0byBpbmNsdWRlIGEgRm9ybUdyb3VwIGZvciBmb3JtIGhhbmRsaW5nIGNhcGFiaWxpdGllc1xuICogQGludGVyZmFjZSBGb3JtRWxlbWVudFxuICogQG1lbWJlck9mIG1vZHVsZTpmb3ItYW5ndWxhclxuICovXG5leHBvcnQgaW50ZXJmYWNlIEZvcm1FbGVtZW50IGV4dGVuZHMgQ29tcG9uZW50SG9sZGVyIHtcbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvbiBUaGUgQW5ndWxhciBGb3JtR3JvdXAgYXNzb2NpYXRlZCB3aXRoIHRoaXMgZm9ybSBlbGVtZW50XG4gICAqIEBwcm9wZXJ0eSB7Rm9ybUdyb3VwfHVuZGVmaW5lZH0gZm9ybUdyb3VwIC0gVGhlIGZvcm0gZ3JvdXAgaW5zdGFuY2UgZm9yIG1hbmFnaW5nIGZvcm0gY29udHJvbHMgYW5kIHZhbGlkYXRpb25cbiAgICovXG4gIGZvcm1Hcm91cDogRm9ybUdyb3VwIHwgdW5kZWZpbmVkO1xufVxuIl19
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import '@decaf-ts/ui-decorators';
|
|
2
|
+
export * from './components/model-renderer/model-renderer.component';
|
|
3
|
+
export * from './components/crud-field/crud-field.component';
|
|
4
|
+
export * from './components/crud-form/crud-form.component';
|
|
5
|
+
export * from './engine';
|
|
6
|
+
/**
|
|
7
|
+
* @description Angular integration for the Decaf framework
|
|
8
|
+
* @summary This module provides Angular components and services for integrating with the Decaf framework.
|
|
9
|
+
* It includes components for rendering models, CRUD operations, and form handling, as well as
|
|
10
|
+
* rendering engines and utility functions to facilitate Angular application development with Decaf.
|
|
11
|
+
* @module for-angular
|
|
12
|
+
*/
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL3B1YmxpYy1hcGlzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8seUJBQXlCLENBQUM7QUFDakMsY0FBYyxzREFBc0QsQ0FBQztBQUNyRSxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsNENBQTRDLENBQUM7QUFDM0QsY0FBYyxVQUFVLENBQUM7QUFFekI7Ozs7OztHQU1HIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICdAZGVjYWYtdHMvdWktZGVjb3JhdG9ycyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvbW9kZWwtcmVuZGVyZXIvbW9kZWwtcmVuZGVyZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9jcnVkLWZpZWxkL2NydWQtZmllbGQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9jcnVkLWZvcm0vY3J1ZC1mb3JtLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2VuZ2luZSc7XG5cbi8qKlxuICogQGRlc2NyaXB0aW9uIEFuZ3VsYXIgaW50ZWdyYXRpb24gZm9yIHRoZSBEZWNhZiBmcmFtZXdvcmtcbiAqIEBzdW1tYXJ5IFRoaXMgbW9kdWxlIHByb3ZpZGVzIEFuZ3VsYXIgY29tcG9uZW50cyBhbmQgc2VydmljZXMgZm9yIGludGVncmF0aW5nIHdpdGggdGhlIERlY2FmIGZyYW1ld29yay5cbiAqIEl0IGluY2x1ZGVzIGNvbXBvbmVudHMgZm9yIHJlbmRlcmluZyBtb2RlbHMsIENSVUQgb3BlcmF0aW9ucywgYW5kIGZvcm0gaGFuZGxpbmcsIGFzIHdlbGwgYXNcbiAqIHJlbmRlcmluZyBlbmdpbmVzIGFuZCB1dGlsaXR5IGZ1bmN0aW9ucyB0byBmYWNpbGl0YXRlIEFuZ3VsYXIgYXBwbGljYXRpb24gZGV2ZWxvcG1lbnQgd2l0aCBEZWNhZi5cbiAqIEBtb2R1bGUgZm9yLWFuZ3VsYXJcbiAqL1xuIl19
|