@acorex/components 19.10.3 → 19.10.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (36) hide show
  1. package/decorators/lib/components/heading/heading.component.d.ts +1 -3
  2. package/fesm2022/acorex-components-color-palette.mjs +1 -1
  3. package/fesm2022/acorex-components-color-palette.mjs.map +1 -1
  4. package/fesm2022/acorex-components-conversation.mjs +2 -2
  5. package/fesm2022/acorex-components-conversation.mjs.map +1 -1
  6. package/fesm2022/acorex-components-cron-job.mjs +6 -6
  7. package/fesm2022/acorex-components-cron-job.mjs.map +1 -1
  8. package/fesm2022/acorex-components-decorators.mjs +3 -5
  9. package/fesm2022/acorex-components-decorators.mjs.map +1 -1
  10. package/fesm2022/acorex-components-phone-box.mjs +1 -1
  11. package/fesm2022/acorex-components-phone-box.mjs.map +1 -1
  12. package/fesm2022/acorex-components-query-builder.mjs +1 -1
  13. package/fesm2022/acorex-components-query-builder.mjs.map +1 -1
  14. package/fesm2022/acorex-components-rest-api-generator.mjs +356 -0
  15. package/fesm2022/acorex-components-rest-api-generator.mjs.map +1 -0
  16. package/fesm2022/acorex-components-search-box.mjs +7 -22
  17. package/fesm2022/acorex-components-search-box.mjs.map +1 -1
  18. package/fesm2022/acorex-components-select-box.mjs +8 -17
  19. package/fesm2022/acorex-components-select-box.mjs.map +1 -1
  20. package/fesm2022/acorex-components-text-box.mjs +2 -2
  21. package/fesm2022/acorex-components-text-box.mjs.map +1 -1
  22. package/fesm2022/acorex-components-wysiwyg.mjs +1 -1
  23. package/fesm2022/acorex-components-wysiwyg.mjs.map +1 -1
  24. package/package.json +5 -1
  25. package/rest-api-generator/README.md +3 -0
  26. package/rest-api-generator/index.d.ts +8 -0
  27. package/rest-api-generator/lib/query-params/query-params.component.d.ts +16 -0
  28. package/rest-api-generator/lib/request-body/request-body.component.d.ts +22 -0
  29. package/rest-api-generator/lib/request-headers/request-headers.component.d.ts +22 -0
  30. package/rest-api-generator/lib/rest-api-auth/rest-api-auth.component.d.ts +22 -0
  31. package/rest-api-generator/lib/rest-api-generator.component.d.ts +14 -0
  32. package/rest-api-generator/lib/rest-api-generator.module.d.ts +19 -0
  33. package/rest-api-generator/lib/rest-api-generator.service.d.ts +7 -0
  34. package/rest-api-generator/lib/types.d.ts +20 -0
  35. package/search-box/lib/search-box.component.d.ts +2 -1
  36. package/select-box/lib/select-box.component.d.ts +2 -1
@@ -0,0 +1,356 @@
1
+ import * as i0 from '@angular/core';
2
+ import { signal, Injectable, inject, effect, ChangeDetectionStrategy, ViewEncapsulation, Component, afterNextRender, input, output, NgModule } from '@angular/core';
3
+ import * as i1 from '@acorex/components/text-box';
4
+ import { AXTextBoxModule } from '@acorex/components/text-box';
5
+ import * as i2 from '@acorex/components/decorators';
6
+ import { AXDecoratorModule } from '@acorex/components/decorators';
7
+ import * as i3 from '@acorex/components/button';
8
+ import { AXButtonModule } from '@acorex/components/button';
9
+ import * as i4 from '@angular/forms';
10
+ import { FormsModule } from '@angular/forms';
11
+ import * as i1$1 from '@acorex/components/text-area';
12
+ import { AXTextAreaModule } from '@acorex/components/text-area';
13
+ import * as i2$1 from '@acorex/components/selection-list';
14
+ import { AXSelectionListModule } from '@acorex/components/selection-list';
15
+ import * as i3$1 from '@acorex/components/select-box';
16
+ import { AXSelectBoxModule } from '@acorex/components/select-box';
17
+ import * as i4$1 from '@acorex/components/tabs';
18
+ import { AXTabsModule } from '@acorex/components/tabs';
19
+
20
+ class AXRestApiGeneratorService {
21
+ constructor() {
22
+ this.outPutJSON = signal({
23
+ url: '',
24
+ method: 'GET',
25
+ headers: {
26
+ Authorization: '',
27
+ ContentType: '',
28
+ },
29
+ queries: [{}],
30
+ body: '',
31
+ });
32
+ }
33
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.3", ngImport: i0, type: AXRestApiGeneratorService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
34
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "19.0.3", ngImport: i0, type: AXRestApiGeneratorService }); }
35
+ }
36
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.3", ngImport: i0, type: AXRestApiGeneratorService, decorators: [{
37
+ type: Injectable
38
+ }] });
39
+
40
+ class AXQueryParamsComponent {
41
+ constructor() {
42
+ this.service = inject(AXRestApiGeneratorService);
43
+ this.queryParamsArray = signal(this.service.outPutJSON().queries);
44
+ this.#eff = effect(() => {
45
+ this.service.outPutJSON.update((prev) => ({ ...prev, queries: this.queryParamsArray() }));
46
+ });
47
+ }
48
+ addQueryParamsHandler() {
49
+ this.queryParamsArray.update((prev) => [...prev, { tempId: String(Math.random()) }]);
50
+ }
51
+ removeQueryParamsHandler(id) {
52
+ this.queryParamsArray.update((prev) => {
53
+ const copy = [...prev];
54
+ const filter = copy.filter((item) => item.tempId !== id);
55
+ return filter;
56
+ });
57
+ }
58
+ queryParamsValueHandler(e, id) {
59
+ this.queryParamsArray.update((prev) => {
60
+ const copy = [...prev];
61
+ const find = copy.find((item) => item.tempId === id);
62
+ Object.keys(find).forEach((key) => {
63
+ if (key !== 'tempId') {
64
+ find[key] = e.value;
65
+ }
66
+ });
67
+ return copy;
68
+ });
69
+ }
70
+ queryParamsKeyHandler(e, id) {
71
+ this.queryParamsArray.update((prev) => {
72
+ const copy = [...prev];
73
+ const find = copy.find((item) => item.tempId === id);
74
+ Object.keys(find).forEach((key) => {
75
+ if (key !== 'tempId') {
76
+ delete find[key];
77
+ }
78
+ });
79
+ find[e.value] = '';
80
+ return copy;
81
+ });
82
+ }
83
+ #eff;
84
+ setInitialState(item, type) {
85
+ for (const [key, value] of Object.entries(item)) {
86
+ if (key !== 'tempId') {
87
+ if (type === 'key') {
88
+ return key;
89
+ }
90
+ else if (type === 'value') {
91
+ return value;
92
+ }
93
+ }
94
+ }
95
+ return '';
96
+ }
97
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.3", ngImport: i0, type: AXQueryParamsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
98
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.0.3", type: AXQueryParamsComponent, isStandalone: false, selector: "ax-query-params", ngImport: i0, template: "<div class=\"ax-query-params-container\">\n <div class=\"ax-query-params-header\">\n <ax-text>Query Params</ax-text>\n <ax-button look=\"blank\" class=\"ax-sm\" color=\"primary\" text=\"add\" (onClick)=\"addQueryParamsHandler()\"></ax-button>\n </div>\n\n <div class=\"ax-query-params-value-container\">\n @for (item of queryParamsArray(); track item) {\n <div class=\"ax-query-params-value\">\n <ax-text-box (onValueChanged)=\"queryParamsKeyHandler($event, item.tempId)\" placeholder=\"key\" [ngModel]=\"setInitialState(item, 'key')\"></ax-text-box>\n <ax-text-box\n (onValueChanged)=\"queryParamsValueHandler($event, item.tempId)\"\n placeholder=\"value\"\n [ngModel]=\"setInitialState(item, 'value')\"\n ></ax-text-box>\n <ax-button look=\"blank\" class=\"ax-sm\" color=\"danger\" (onClick)=\"removeQueryParamsHandler(item.tempId)\">\n <ax-prefix>\n <ax-icon icon=\"fa-solid fa-trash-can\"></ax-icon>\n </ax-prefix>\n </ax-button>\n </div>\n }\n </div>\n</div>\n", styles: ["ax-query-params{padding-inline:.5rem;padding-top:1rem;display:flex;flex-direction:column;align-items:flex-start;justify-content:center}ax-query-params .ax-query-params-value-container{display:flex;flex-direction:column;gap:.5rem}ax-query-params .ax-query-params-value-container .ax-query-params-value{display:flex;gap:.5rem;align-items:center}ax-query-params .ax-query-params-header{display:flex;align-items:center;gap:.5rem;margin-block:.5rem}\n"], dependencies: [{ kind: "component", type: i1.AXTextBoxComponent, selector: "ax-text-box", inputs: ["disabled", "tabIndex", "readonly", "value", "state", "name", "id", "placeholder", "maxLength", "allowNull", "type", "autoComplete", "look", "mask-options", "class"], outputs: ["onBlur", "onFocus", "valueChange", "stateChange", "onValueChanged", "readonlyChange", "disabledChange", "onKeyDown", "onKeyUp", "onKeyPress"] }, { kind: "component", type: i2.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i2.AXDecoratorGenericComponent, selector: "ax-footer, ax-header, ax-content, ax-divider, ax-form-hint, ax-prefix, ax-suffix, ax-text, ax-title, ax-subtitle, ax-placeholder, ax-overlay" }, { kind: "component", type: i3.AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected", "type", "loadingText"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange", "disabledChange", "loadingTextChange"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
99
+ }
100
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.3", ngImport: i0, type: AXQueryParamsComponent, decorators: [{
101
+ type: Component,
102
+ args: [{ selector: 'ax-query-params', standalone: false, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"ax-query-params-container\">\n <div class=\"ax-query-params-header\">\n <ax-text>Query Params</ax-text>\n <ax-button look=\"blank\" class=\"ax-sm\" color=\"primary\" text=\"add\" (onClick)=\"addQueryParamsHandler()\"></ax-button>\n </div>\n\n <div class=\"ax-query-params-value-container\">\n @for (item of queryParamsArray(); track item) {\n <div class=\"ax-query-params-value\">\n <ax-text-box (onValueChanged)=\"queryParamsKeyHandler($event, item.tempId)\" placeholder=\"key\" [ngModel]=\"setInitialState(item, 'key')\"></ax-text-box>\n <ax-text-box\n (onValueChanged)=\"queryParamsValueHandler($event, item.tempId)\"\n placeholder=\"value\"\n [ngModel]=\"setInitialState(item, 'value')\"\n ></ax-text-box>\n <ax-button look=\"blank\" class=\"ax-sm\" color=\"danger\" (onClick)=\"removeQueryParamsHandler(item.tempId)\">\n <ax-prefix>\n <ax-icon icon=\"fa-solid fa-trash-can\"></ax-icon>\n </ax-prefix>\n </ax-button>\n </div>\n }\n </div>\n</div>\n", styles: ["ax-query-params{padding-inline:.5rem;padding-top:1rem;display:flex;flex-direction:column;align-items:flex-start;justify-content:center}ax-query-params .ax-query-params-value-container{display:flex;flex-direction:column;gap:.5rem}ax-query-params .ax-query-params-value-container .ax-query-params-value{display:flex;gap:.5rem;align-items:center}ax-query-params .ax-query-params-header{display:flex;align-items:center;gap:.5rem;margin-block:.5rem}\n"] }]
103
+ }] });
104
+
105
+ class AXRequestBodyComponent {
106
+ constructor() {
107
+ this.service = inject(AXRestApiGeneratorService);
108
+ this.value = signal(null);
109
+ this.selectedItem = signal({ id: null, text: '', placeHolder: '' });
110
+ this.#init = afterNextRender(() => {
111
+ const type = this.service.outPutJSON().headers.ContentType;
112
+ if (type) {
113
+ switch (type) {
114
+ case 'text/plain':
115
+ this.value.set(1);
116
+ break;
117
+ case 'application/json':
118
+ this.value.set(2);
119
+ break;
120
+ case 'multipart/form-data':
121
+ this.value.set(3);
122
+ break;
123
+ case 'application/xml':
124
+ this.value.set(4);
125
+ break;
126
+ }
127
+ }
128
+ else {
129
+ this.value.set(2);
130
+ }
131
+ });
132
+ this.items = [
133
+ { id: 1, text: 'None', placeHolder: '' },
134
+ { id: 2, text: 'Json', placeHolder: '{"key" : "value"}' },
135
+ { id: 3, text: 'Form', placeHolder: 'key1=value1' },
136
+ { id: 4, text: 'XML', placeHolder: '<data></data>' },
137
+ ];
138
+ }
139
+ #init;
140
+ bodyReqHandler(e) {
141
+ const find = this.items.find((item) => item.id === e.value);
142
+ this.selectedItem.set(find);
143
+ }
144
+ bodyTextHandler(e) {
145
+ const type = this.selectedItem().text;
146
+ let contentType;
147
+ switch (type) {
148
+ case 'None':
149
+ contentType = 'text/plain';
150
+ break;
151
+ case 'Json':
152
+ contentType = 'application/json';
153
+ break;
154
+ case 'Form':
155
+ contentType = 'multipart/form-data';
156
+ break;
157
+ case 'XML':
158
+ contentType = 'application/xml';
159
+ break;
160
+ }
161
+ this.service.outPutJSON.update((prev) => ({ ...prev, body: e.value }));
162
+ this.service.outPutJSON.update((prev) => {
163
+ const copy = { ...prev };
164
+ copy.headers.ContentType = contentType;
165
+ return copy;
166
+ });
167
+ }
168
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.3", ngImport: i0, type: AXRequestBodyComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
169
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.0.3", type: AXRequestBodyComponent, isStandalone: false, selector: "ax-request-body", ngImport: i0, template: "<ax-selection-list [showControl]=\"true\" look=\"solid\" [items]=\"items\" [(ngModel)]=\"value\" (onValueChanged)=\"bodyReqHandler($event)\"> </ax-selection-list>\n<ax-text-area [(ngModel)]=\"service.outPutJSON().body\" (onValueChanged)=\"bodyTextHandler($event)\" [placeholder]=\"selectedItem().placeHolder\"> </ax-text-area>\n", styles: ["ax-request-body{padding-inline:.5rem;padding-top:1rem;display:flex;flex-direction:column;align-items:flex-start;justify-content:center}\n"], dependencies: [{ kind: "component", type: i1$1.AXTextAreaComponent, selector: "ax-text-area", inputs: ["disabled", "tabIndex", "readonly", "value", "state", "name", "placeholder", "maxLength", "look", "rows", "allowResize", "showCounter", "class"], outputs: ["onBlur", "onFocus", "valueChange", "stateChange", "onValueChanged", "readonlyChange", "disabledChange", "onKeyDown", "onKeyUp", "onKeyPress"] }, { kind: "component", type: i2$1.AXSelectionListComponent, selector: "ax-selection-list", inputs: ["id", "name", "disabled", "readonly", "tabIndex", "size", "value", "valueField", "textField", "disabledField", "readonlyField", "multiple", "direction", "customTemplate", "showControl", "items", "look"], outputs: ["onValueChanged", "onBlur", "onFocus"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
170
+ }
171
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.3", ngImport: i0, type: AXRequestBodyComponent, decorators: [{
172
+ type: Component,
173
+ args: [{ selector: 'ax-request-body', standalone: false, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ax-selection-list [showControl]=\"true\" look=\"solid\" [items]=\"items\" [(ngModel)]=\"value\" (onValueChanged)=\"bodyReqHandler($event)\"> </ax-selection-list>\n<ax-text-area [(ngModel)]=\"service.outPutJSON().body\" (onValueChanged)=\"bodyTextHandler($event)\" [placeholder]=\"selectedItem().placeHolder\"> </ax-text-area>\n", styles: ["ax-request-body{padding-inline:.5rem;padding-top:1rem;display:flex;flex-direction:column;align-items:flex-start;justify-content:center}\n"] }]
174
+ }] });
175
+
176
+ class AXRequestHeadersComponent {
177
+ constructor() {
178
+ this.service = inject(AXRestApiGeneratorService);
179
+ this.headersArray = signal(this.filterUnnecessaryKey());
180
+ this.#eff = effect(() => {
181
+ this.service.outPutJSON.update((prev) => {
182
+ const copy = { ...prev };
183
+ const copyHeader = { Authorization: copy.headers.Authorization, ContentType: copy.headers.ContentType };
184
+ copy.headers = copyHeader;
185
+ this.headersArray().forEach((item) => {
186
+ Object.assign(copy.headers, item);
187
+ });
188
+ return copy;
189
+ });
190
+ });
191
+ }
192
+ addHeadersHandler() {
193
+ this.headersArray.update((prev) => [...prev, { tempId: String(Math.random()) }]);
194
+ }
195
+ removeHeadersHandler(id) {
196
+ this.headersArray.update((prev) => {
197
+ const copy = [...prev];
198
+ const filter = copy.filter((item) => item.tempId !== id);
199
+ return filter;
200
+ });
201
+ }
202
+ headersValueHandler(e, id) {
203
+ this.headersArray.update((prev) => {
204
+ const copy = [...prev];
205
+ const find = copy.find((item) => item.tempId === id);
206
+ Object.keys(find).forEach((key) => {
207
+ if (key !== 'tempId') {
208
+ find[key] = e.value;
209
+ }
210
+ });
211
+ return copy;
212
+ });
213
+ }
214
+ headersKeyHandler(e, id) {
215
+ this.headersArray.update((prev) => {
216
+ const copy = [...prev];
217
+ const find = copy.find((item) => item.tempId === id);
218
+ Object.keys(find).forEach((key) => {
219
+ if (key !== 'tempId') {
220
+ delete find[key];
221
+ }
222
+ });
223
+ find[e.value] = '';
224
+ return copy;
225
+ });
226
+ }
227
+ #eff;
228
+ setInitialState(item, type) {
229
+ for (const [key, value] of Object.entries(item)) {
230
+ if (key !== 'tempId') {
231
+ if (type === 'key') {
232
+ return key;
233
+ }
234
+ else if (type === 'value') {
235
+ return value;
236
+ }
237
+ }
238
+ }
239
+ return '';
240
+ }
241
+ filterUnnecessaryKey() {
242
+ const allHeaders = { ...this.service.outPutJSON().headers };
243
+ Object.keys(allHeaders).forEach((key) => {
244
+ if (key === 'Authorization' || key === 'ContentType') {
245
+ delete allHeaders[key];
246
+ }
247
+ });
248
+ return [allHeaders];
249
+ }
250
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.3", ngImport: i0, type: AXRequestHeadersComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
251
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.0.3", type: AXRequestHeadersComponent, isStandalone: false, selector: "ax-request-headers", ngImport: i0, template: "<div class=\"ax-headers-container\">\n <div class=\"ax-headers-header\">\n <ax-text>Headers</ax-text>\n <ax-button look=\"blank\" class=\"ax-sm\" color=\"primary\" text=\"add\" (onClick)=\"addHeadersHandler()\"></ax-button>\n </div>\n\n <div class=\"ax-headers-value-container\">\n @for (item of headersArray(); track item.tempId) {\n <div class=\"ax-headers-value\">\n <ax-text-box [ngModel]=\"setInitialState(item, 'key')\" (onValueChanged)=\"headersKeyHandler($event, item.tempId)\" placeholder=\"key\"></ax-text-box>\n <ax-text-box [ngModel]=\"setInitialState(item, 'value')\" (onValueChanged)=\"headersValueHandler($event, item.tempId)\" placeholder=\"value\"></ax-text-box>\n <ax-button look=\"blank\" class=\"ax-sm\" color=\"danger\" (onClick)=\"removeHeadersHandler(item.tempId)\">\n <ax-prefix>\n <ax-icon icon=\"fa-solid fa-trash-can\"></ax-icon>\n </ax-prefix>\n </ax-button>\n </div>\n }\n </div>\n</div>\n", styles: ["ax-request-headers{padding-inline:.5rem;padding-top:1rem;display:flex;flex-direction:column;align-items:flex-start;justify-content:center}ax-request-headers .ax-headers-value-container{display:flex;flex-direction:column;gap:.5rem}ax-request-headers .ax-headers-value-container .ax-headers-value{display:flex;gap:.5rem;align-items:center}ax-request-headers .ax-headers-header{display:flex;align-items:center;gap:.5rem;margin-block:.5rem}\n"], dependencies: [{ kind: "component", type: i1.AXTextBoxComponent, selector: "ax-text-box", inputs: ["disabled", "tabIndex", "readonly", "value", "state", "name", "id", "placeholder", "maxLength", "allowNull", "type", "autoComplete", "look", "mask-options", "class"], outputs: ["onBlur", "onFocus", "valueChange", "stateChange", "onValueChanged", "readonlyChange", "disabledChange", "onKeyDown", "onKeyUp", "onKeyPress"] }, { kind: "component", type: i2.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i2.AXDecoratorGenericComponent, selector: "ax-footer, ax-header, ax-content, ax-divider, ax-form-hint, ax-prefix, ax-suffix, ax-text, ax-title, ax-subtitle, ax-placeholder, ax-overlay" }, { kind: "component", type: i3.AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected", "type", "loadingText"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange", "disabledChange", "loadingTextChange"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
252
+ }
253
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.3", ngImport: i0, type: AXRequestHeadersComponent, decorators: [{
254
+ type: Component,
255
+ args: [{ selector: 'ax-request-headers', standalone: false, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"ax-headers-container\">\n <div class=\"ax-headers-header\">\n <ax-text>Headers</ax-text>\n <ax-button look=\"blank\" class=\"ax-sm\" color=\"primary\" text=\"add\" (onClick)=\"addHeadersHandler()\"></ax-button>\n </div>\n\n <div class=\"ax-headers-value-container\">\n @for (item of headersArray(); track item.tempId) {\n <div class=\"ax-headers-value\">\n <ax-text-box [ngModel]=\"setInitialState(item, 'key')\" (onValueChanged)=\"headersKeyHandler($event, item.tempId)\" placeholder=\"key\"></ax-text-box>\n <ax-text-box [ngModel]=\"setInitialState(item, 'value')\" (onValueChanged)=\"headersValueHandler($event, item.tempId)\" placeholder=\"value\"></ax-text-box>\n <ax-button look=\"blank\" class=\"ax-sm\" color=\"danger\" (onClick)=\"removeHeadersHandler(item.tempId)\">\n <ax-prefix>\n <ax-icon icon=\"fa-solid fa-trash-can\"></ax-icon>\n </ax-prefix>\n </ax-button>\n </div>\n }\n </div>\n</div>\n", styles: ["ax-request-headers{padding-inline:.5rem;padding-top:1rem;display:flex;flex-direction:column;align-items:flex-start;justify-content:center}ax-request-headers .ax-headers-value-container{display:flex;flex-direction:column;gap:.5rem}ax-request-headers .ax-headers-value-container .ax-headers-value{display:flex;gap:.5rem;align-items:center}ax-request-headers .ax-headers-header{display:flex;align-items:center;gap:.5rem;margin-block:.5rem}\n"] }]
256
+ }] });
257
+
258
+ class AXRestApiAuthComponent {
259
+ constructor() {
260
+ this.service = inject(AXRestApiGeneratorService);
261
+ this.value = signal(null);
262
+ this.#init = afterNextRender(() => {
263
+ const token = this.service.outPutJSON().headers.Authorization;
264
+ if (token) {
265
+ this.value.set(2);
266
+ }
267
+ else {
268
+ this.value.set(1);
269
+ }
270
+ });
271
+ this.selectedItem = signal({ id: null, text: '', placeHolder: '' });
272
+ this.items = [
273
+ { id: 1, text: 'None', placeHolder: '' },
274
+ { id: 2, text: 'Bearer Token', placeHolder: 'Token' },
275
+ ];
276
+ }
277
+ #init;
278
+ authTypeHandler(e) {
279
+ const find = this.items.find((item) => item.id === e.value);
280
+ this.selectedItem.set(find);
281
+ if (e.value === 1) {
282
+ this.service.outPutJSON.update((prev) => {
283
+ const copy = { ...prev };
284
+ copy.headers.Authorization = '';
285
+ return copy;
286
+ });
287
+ }
288
+ }
289
+ authInputHandler(e) {
290
+ this.service.outPutJSON.update((prev) => {
291
+ const copy = { ...prev };
292
+ copy.headers.Authorization = e.value;
293
+ return copy;
294
+ });
295
+ }
296
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.3", ngImport: i0, type: AXRestApiAuthComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
297
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.0.3", type: AXRestApiAuthComponent, isStandalone: false, selector: "ax-rest-api-auth", ngImport: i0, template: "<ax-selection-list [showControl]=\"true\" look=\"solid\" [items]=\"items\" [(ngModel)]=\"value\" (onValueChanged)=\"authTypeHandler($event)\"> </ax-selection-list>\n\n@if (selectedItem().text !== 'None') {\n <ax-text-box [(ngModel)]=\"service.outPutJSON().headers.Authorization\" (onValueChanged)=\"authInputHandler($event)\" [placeholder]=\"selectedItem().placeHolder\">\n </ax-text-box>\n}\n", styles: ["ax-rest-api-auth{padding-inline:.5rem;padding-top:1rem;display:flex;flex-direction:column;align-items:flex-start;justify-content:center}\n"], dependencies: [{ kind: "component", type: i1.AXTextBoxComponent, selector: "ax-text-box", inputs: ["disabled", "tabIndex", "readonly", "value", "state", "name", "id", "placeholder", "maxLength", "allowNull", "type", "autoComplete", "look", "mask-options", "class"], outputs: ["onBlur", "onFocus", "valueChange", "stateChange", "onValueChanged", "readonlyChange", "disabledChange", "onKeyDown", "onKeyUp", "onKeyPress"] }, { kind: "component", type: i2$1.AXSelectionListComponent, selector: "ax-selection-list", inputs: ["id", "name", "disabled", "readonly", "tabIndex", "size", "value", "valueField", "textField", "disabledField", "readonlyField", "multiple", "direction", "customTemplate", "showControl", "items", "look"], outputs: ["onValueChanged", "onBlur", "onFocus"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
298
+ }
299
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.3", ngImport: i0, type: AXRestApiAuthComponent, decorators: [{
300
+ type: Component,
301
+ args: [{ selector: 'ax-rest-api-auth', standalone: false, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ax-selection-list [showControl]=\"true\" look=\"solid\" [items]=\"items\" [(ngModel)]=\"value\" (onValueChanged)=\"authTypeHandler($event)\"> </ax-selection-list>\n\n@if (selectedItem().text !== 'None') {\n <ax-text-box [(ngModel)]=\"service.outPutJSON().headers.Authorization\" (onValueChanged)=\"authInputHandler($event)\" [placeholder]=\"selectedItem().placeHolder\">\n </ax-text-box>\n}\n", styles: ["ax-rest-api-auth{padding-inline:.5rem;padding-top:1rem;display:flex;flex-direction:column;align-items:flex-start;justify-content:center}\n"] }]
302
+ }] });
303
+
304
+ class AXRestApiGeneratorComponent {
305
+ constructor() {
306
+ this.value = input();
307
+ this.onValueChange = output();
308
+ this.service = inject(AXRestApiGeneratorService);
309
+ this.#init = afterNextRender(() => {
310
+ if (this.value()) {
311
+ this.service.outPutJSON.set(this.value());
312
+ }
313
+ });
314
+ this.#eff = effect(() => {
315
+ this.onValueChange.emit(this.service.outPutJSON());
316
+ });
317
+ }
318
+ #init;
319
+ #eff;
320
+ urlHandler(e) {
321
+ this.service.outPutJSON.update((prev) => ({ ...prev, url: e.value }));
322
+ }
323
+ methodHandler(e) {
324
+ this.service.outPutJSON.update((prev) => ({ ...prev, method: e.value }));
325
+ }
326
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.3", ngImport: i0, type: AXRestApiGeneratorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
327
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "19.0.3", type: AXRestApiGeneratorComponent, isStandalone: false, selector: "ax-rest-api-generator", inputs: { value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onValueChange: "onValueChange" }, providers: [AXRestApiGeneratorService], ngImport: i0, template: "<div class=\"ax-url-input-container\">\n <ax-text-box [(ngModel)]=\"service.outPutJSON().url\" placeholder=\"URL\" (onValueChanged)=\"urlHandler($event)\">\n <ax-clear-button></ax-clear-button>\n <ax-suffix>\n <ax-select-box\n [(ngModel)]=\"service.outPutJSON().method\"\n (onValueChanged)=\"methodHandler($event)\"\n [dataSource]=\"['GET', 'POST', 'DELETE', 'PUT', 'PATCH']\"\n >\n </ax-select-box\n ></ax-suffix>\n </ax-text-box>\n</div>\n\n<ax-tabs [content]=\"cronTab\" look=\"with-line\" [fitParent]=\"true\" location=\"bottom\">\n <ax-tab-item key=\"1\" text=\"Params\">\n <ax-content> <ax-query-params></ax-query-params> </ax-content>\n </ax-tab-item>\n <ax-tab-item key=\"2\" text=\"Body\">\n <ax-content><ax-request-body></ax-request-body></ax-content>\n </ax-tab-item>\n <ax-tab-item key=\"3\" text=\"Auth\">\n <ax-content> <ax-rest-api-auth></ax-rest-api-auth></ax-content>\n </ax-tab-item>\n <ax-tab-item key=\"4\" text=\"Headers\">\n <ax-content> <ax-request-headers></ax-request-headers></ax-content>\n </ax-tab-item>\n</ax-tabs>\n\n<ng-template [axTabContent] #cronTab=\"axTabContent\"> </ng-template>\n", styles: ["ax-rest-api-generator{min-width:40rem}ax-rest-api-generator ax-select-box ax-dropdown-box{--ax-comp-editor-border-width: 0px !important}ax-rest-api-generator ax-select-box ax-dropdown-box.ax-editor-container{--ax-comp-editor-box-outline-width: 0}ax-rest-api-generator .ax-select-box{border:0}ax-rest-api-generator .ax-url-input-container{margin-bottom:1rem}\n"], dependencies: [{ kind: "component", type: i1.AXTextBoxComponent, selector: "ax-text-box", inputs: ["disabled", "tabIndex", "readonly", "value", "state", "name", "id", "placeholder", "maxLength", "allowNull", "type", "autoComplete", "look", "mask-options", "class"], outputs: ["onBlur", "onFocus", "valueChange", "stateChange", "onValueChanged", "readonlyChange", "disabledChange", "onKeyDown", "onKeyUp", "onKeyPress"] }, { kind: "component", type: i2.AXDecoratorClearButtonComponent, selector: "ax-clear-button", inputs: ["icon"] }, { kind: "component", type: i2.AXDecoratorGenericComponent, selector: "ax-footer, ax-header, ax-content, ax-divider, ax-form-hint, ax-prefix, ax-suffix, ax-text, ax-title, ax-subtitle, ax-placeholder, ax-overlay" }, { kind: "component", type: i3$1.AXSelectBoxComponent, selector: "ax-select-box", inputs: ["disabled", "readonly", "tabIndex", "placeholder", "minValue", "maxValue", "value", "state", "name", "id", "type", "look", "multiple", "valueField", "textField", "textTemplate", "selectedItems", "dataSource", "caption", "itemTemplate", "selectedTemplate", "emptyTemplate", "loadingTemplate", "dropdownWidth", "searchBoxAutoFocus"], outputs: ["valueChange", "stateChange", "onValueChanged", "onBlur", "onFocus", "readonlyChange", "disabledChange", "onOpened", "onClosed"] }, { kind: "component", type: i4$1.AXTabsComponent, selector: "ax-tabs", inputs: ["look", "location", "fitParent", "minWidth", "content"], outputs: ["onActiveTabChanged"] }, { kind: "component", type: i4$1.AXTabItemComponent, selector: "ax-tab-item", inputs: ["disabled", "text", "key", "headerTemplate", "active"], outputs: ["disabledChange", "onClick", "onBlur", "onFocus", "activeChange"] }, { kind: "directive", type: i4$1.AXTabContentDirective, selector: "[axTabContent]", inputs: ["axTabContent"], exportAs: ["axTabContent"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: AXQueryParamsComponent, selector: "ax-query-params" }, { kind: "component", type: AXRequestBodyComponent, selector: "ax-request-body" }, { kind: "component", type: AXRestApiAuthComponent, selector: "ax-rest-api-auth" }, { kind: "component", type: AXRequestHeadersComponent, selector: "ax-request-headers" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
328
+ }
329
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.3", ngImport: i0, type: AXRestApiGeneratorComponent, decorators: [{
330
+ type: Component,
331
+ args: [{ selector: 'ax-rest-api-generator', standalone: false, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [AXRestApiGeneratorService], template: "<div class=\"ax-url-input-container\">\n <ax-text-box [(ngModel)]=\"service.outPutJSON().url\" placeholder=\"URL\" (onValueChanged)=\"urlHandler($event)\">\n <ax-clear-button></ax-clear-button>\n <ax-suffix>\n <ax-select-box\n [(ngModel)]=\"service.outPutJSON().method\"\n (onValueChanged)=\"methodHandler($event)\"\n [dataSource]=\"['GET', 'POST', 'DELETE', 'PUT', 'PATCH']\"\n >\n </ax-select-box\n ></ax-suffix>\n </ax-text-box>\n</div>\n\n<ax-tabs [content]=\"cronTab\" look=\"with-line\" [fitParent]=\"true\" location=\"bottom\">\n <ax-tab-item key=\"1\" text=\"Params\">\n <ax-content> <ax-query-params></ax-query-params> </ax-content>\n </ax-tab-item>\n <ax-tab-item key=\"2\" text=\"Body\">\n <ax-content><ax-request-body></ax-request-body></ax-content>\n </ax-tab-item>\n <ax-tab-item key=\"3\" text=\"Auth\">\n <ax-content> <ax-rest-api-auth></ax-rest-api-auth></ax-content>\n </ax-tab-item>\n <ax-tab-item key=\"4\" text=\"Headers\">\n <ax-content> <ax-request-headers></ax-request-headers></ax-content>\n </ax-tab-item>\n</ax-tabs>\n\n<ng-template [axTabContent] #cronTab=\"axTabContent\"> </ng-template>\n", styles: ["ax-rest-api-generator{min-width:40rem}ax-rest-api-generator ax-select-box ax-dropdown-box{--ax-comp-editor-border-width: 0px !important}ax-rest-api-generator ax-select-box ax-dropdown-box.ax-editor-container{--ax-comp-editor-box-outline-width: 0}ax-rest-api-generator .ax-select-box{border:0}ax-rest-api-generator .ax-url-input-container{margin-bottom:1rem}\n"] }]
332
+ }] });
333
+
334
+ const COMPONENT = [AXRestApiGeneratorComponent, AXQueryParamsComponent, AXRequestBodyComponent, AXRestApiAuthComponent, AXRequestHeadersComponent];
335
+ const MODULES = [AXTextBoxModule, AXDecoratorModule, AXSelectBoxModule, AXTabsModule, AXButtonModule, AXTextAreaModule, AXSelectionListModule, FormsModule];
336
+ class AXRestApiGeneratorModule {
337
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.3", ngImport: i0, type: AXRestApiGeneratorModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
338
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "19.0.3", ngImport: i0, type: AXRestApiGeneratorModule, declarations: [AXRestApiGeneratorComponent, AXQueryParamsComponent, AXRequestBodyComponent, AXRestApiAuthComponent, AXRequestHeadersComponent], imports: [AXTextBoxModule, AXDecoratorModule, AXSelectBoxModule, AXTabsModule, AXButtonModule, AXTextAreaModule, AXSelectionListModule, FormsModule], exports: [AXRestApiGeneratorComponent, AXQueryParamsComponent, AXRequestBodyComponent, AXRestApiAuthComponent, AXRequestHeadersComponent] }); }
339
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "19.0.3", ngImport: i0, type: AXRestApiGeneratorModule, imports: [MODULES] }); }
340
+ }
341
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.3", ngImport: i0, type: AXRestApiGeneratorModule, decorators: [{
342
+ type: NgModule,
343
+ args: [{
344
+ declarations: [...COMPONENT],
345
+ imports: [...MODULES],
346
+ exports: [...COMPONENT],
347
+ providers: [],
348
+ }]
349
+ }] });
350
+
351
+ /**
352
+ * Generated bundle index. Do not edit.
353
+ */
354
+
355
+ export { AXQueryParamsComponent, AXRequestBodyComponent, AXRequestHeadersComponent, AXRestApiAuthComponent, AXRestApiGeneratorComponent, AXRestApiGeneratorModule, AXRestApiGeneratorService };
356
+ //# sourceMappingURL=acorex-components-rest-api-generator.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"acorex-components-rest-api-generator.mjs","sources":["../../../../libs/components/rest-api-generator/src/lib/rest-api-generator.service.ts","../../../../libs/components/rest-api-generator/src/lib/query-params/query-params.component.ts","../../../../libs/components/rest-api-generator/src/lib/query-params/query-params.component.html","../../../../libs/components/rest-api-generator/src/lib/request-body/request-body.component.ts","../../../../libs/components/rest-api-generator/src/lib/request-body/request-body.component.html","../../../../libs/components/rest-api-generator/src/lib/request-headers/request-headers.component.ts","../../../../libs/components/rest-api-generator/src/lib/request-headers/request-headers.component.html","../../../../libs/components/rest-api-generator/src/lib/rest-api-auth/rest-api-auth.component.ts","../../../../libs/components/rest-api-generator/src/lib/rest-api-auth/rest-api-auth.component.html","../../../../libs/components/rest-api-generator/src/lib/rest-api-generator.component.ts","../../../../libs/components/rest-api-generator/src/lib/rest-api-generator.component.html","../../../../libs/components/rest-api-generator/src/lib/rest-api-generator.module.ts","../../../../libs/components/rest-api-generator/src/acorex-components-rest-api-generator.ts"],"sourcesContent":["import { Injectable, signal } from '@angular/core';\nimport { AXRestApiOutput } from './types';\n\n@Injectable()\nexport class AXRestApiGeneratorService {\n outPutJSON = signal<AXRestApiOutput>({\n url: '',\n method: 'GET',\n headers: {\n Authorization: '',\n ContentType: '',\n },\n queries: [{}],\n body: '',\n });\n}\n","import { AXValueChangedEvent } from '@acorex/components/common';\nimport { ChangeDetectionStrategy, Component, effect, inject, signal, ViewEncapsulation } from '@angular/core';\nimport { AXRestApiGeneratorService } from '../rest-api-generator.service';\nimport { Queries } from '../types';\n\n@Component({\n selector: 'ax-query-params',\n templateUrl: './query-params.component.html',\n styleUrls: ['./query-params.component.scss'],\n standalone: false,\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AXQueryParamsComponent {\n protected service = inject(AXRestApiGeneratorService);\n\n protected queryParamsArray = signal<Queries[]>(this.service.outPutJSON().queries);\n\n protected addQueryParamsHandler() {\n this.queryParamsArray.update((prev) => [...prev, { tempId: String(Math.random()) }]);\n }\n\n protected removeQueryParamsHandler(id: string) {\n this.queryParamsArray.update((prev) => {\n const copy = [...prev];\n const filter = copy.filter((item) => item.tempId !== id);\n return filter;\n });\n }\n\n protected queryParamsValueHandler(e: AXValueChangedEvent<any>, id: string) {\n this.queryParamsArray.update((prev) => {\n const copy = [...prev];\n const find = copy.find((item) => item.tempId === id);\n Object.keys(find).forEach((key) => {\n if (key !== 'tempId') {\n find[key] = e.value;\n }\n });\n return copy;\n });\n }\n\n protected queryParamsKeyHandler(e: AXValueChangedEvent<any>, id: string) {\n this.queryParamsArray.update((prev) => {\n const copy = [...prev];\n const find = copy.find((item) => item.tempId === id);\n Object.keys(find).forEach((key) => {\n if (key !== 'tempId') {\n delete find[key];\n }\n });\n find[e.value] = '';\n return copy;\n });\n }\n\n #eff = effect(() => {\n this.service.outPutJSON.update((prev) => ({ ...prev, queries: this.queryParamsArray() }));\n });\n\n protected setInitialState(item: Queries, type: string) {\n for (const [key, value] of Object.entries(item)) {\n if (key !== 'tempId') {\n if (type === 'key') {\n return key;\n } else if (type === 'value') {\n return value;\n }\n }\n }\n return '';\n }\n}\n","<div class=\"ax-query-params-container\">\n <div class=\"ax-query-params-header\">\n <ax-text>Query Params</ax-text>\n <ax-button look=\"blank\" class=\"ax-sm\" color=\"primary\" text=\"add\" (onClick)=\"addQueryParamsHandler()\"></ax-button>\n </div>\n\n <div class=\"ax-query-params-value-container\">\n @for (item of queryParamsArray(); track item) {\n <div class=\"ax-query-params-value\">\n <ax-text-box (onValueChanged)=\"queryParamsKeyHandler($event, item.tempId)\" placeholder=\"key\" [ngModel]=\"setInitialState(item, 'key')\"></ax-text-box>\n <ax-text-box\n (onValueChanged)=\"queryParamsValueHandler($event, item.tempId)\"\n placeholder=\"value\"\n [ngModel]=\"setInitialState(item, 'value')\"\n ></ax-text-box>\n <ax-button look=\"blank\" class=\"ax-sm\" color=\"danger\" (onClick)=\"removeQueryParamsHandler(item.tempId)\">\n <ax-prefix>\n <ax-icon icon=\"fa-solid fa-trash-can\"></ax-icon>\n </ax-prefix>\n </ax-button>\n </div>\n }\n </div>\n</div>\n","import { AXValueChangedEvent } from '@acorex/components/common';\nimport { afterNextRender, ChangeDetectionStrategy, Component, inject, signal, ViewEncapsulation } from '@angular/core';\nimport { AXRestApiGeneratorService } from '../rest-api-generator.service';\n\n@Component({\n selector: 'ax-request-body',\n templateUrl: './request-body.component.html',\n styleUrls: ['./request-body.component.scss'],\n standalone: false,\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AXRequestBodyComponent {\n protected service = inject(AXRestApiGeneratorService);\n\n protected value = signal(null);\n\n protected selectedItem = signal({ id: null, text: '', placeHolder: '' });\n\n #init = afterNextRender(() => {\n const type = this.service.outPutJSON().headers.ContentType;\n\n if (type) {\n switch (type) {\n case 'text/plain':\n this.value.set(1);\n break;\n case 'application/json':\n this.value.set(2);\n break;\n case 'multipart/form-data':\n this.value.set(3);\n break;\n case 'application/xml':\n this.value.set(4);\n break;\n }\n } else {\n this.value.set(2);\n }\n });\n\n protected items = [\n { id: 1, text: 'None', placeHolder: '' },\n { id: 2, text: 'Json', placeHolder: '{\"key\" : \"value\"}' },\n { id: 3, text: 'Form', placeHolder: 'key1=value1' },\n { id: 4, text: 'XML', placeHolder: '<data></data>' },\n ];\n\n protected bodyReqHandler(e: AXValueChangedEvent<any>) {\n const find = this.items.find((item) => item.id === e.value);\n this.selectedItem.set(find);\n }\n\n protected bodyTextHandler(e: AXValueChangedEvent<any>) {\n const type = this.selectedItem().text;\n let contentType: string;\n\n switch (type) {\n case 'None':\n contentType = 'text/plain';\n break;\n case 'Json':\n contentType = 'application/json';\n break;\n case 'Form':\n contentType = 'multipart/form-data';\n break;\n case 'XML':\n contentType = 'application/xml';\n break;\n }\n this.service.outPutJSON.update((prev) => ({ ...prev, body: e.value }));\n\n this.service.outPutJSON.update((prev) => {\n const copy = { ...prev };\n copy.headers.ContentType = contentType;\n return copy;\n });\n }\n}\n","<ax-selection-list [showControl]=\"true\" look=\"solid\" [items]=\"items\" [(ngModel)]=\"value\" (onValueChanged)=\"bodyReqHandler($event)\"> </ax-selection-list>\n<ax-text-area [(ngModel)]=\"service.outPutJSON().body\" (onValueChanged)=\"bodyTextHandler($event)\" [placeholder]=\"selectedItem().placeHolder\"> </ax-text-area>\n","import { AXValueChangedEvent } from '@acorex/components/common';\nimport { ChangeDetectionStrategy, Component, effect, inject, signal, ViewEncapsulation } from '@angular/core';\nimport { AXRestApiGeneratorService } from '../rest-api-generator.service';\nimport { HeadersDynamic } from '../types';\n\n@Component({\n selector: 'ax-request-headers',\n templateUrl: './request-headers.component.html',\n styleUrls: ['./request-headers.component.scss'],\n standalone: false,\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AXRequestHeadersComponent {\n protected service = inject(AXRestApiGeneratorService);\n\n protected headersArray = signal<HeadersDynamic[]>(this.filterUnnecessaryKey());\n\n protected addHeadersHandler() {\n this.headersArray.update((prev) => [...prev, { tempId: String(Math.random()) }]);\n }\n\n protected removeHeadersHandler(id: string) {\n this.headersArray.update((prev) => {\n const copy = [...prev];\n const filter = copy.filter((item) => item.tempId !== id);\n return filter;\n });\n }\n\n protected headersValueHandler(e: AXValueChangedEvent<any>, id: string) {\n this.headersArray.update((prev) => {\n const copy = [...prev];\n const find = copy.find((item) => item.tempId === id);\n Object.keys(find).forEach((key) => {\n if (key !== 'tempId') {\n find[key] = e.value;\n }\n });\n return copy;\n });\n }\n\n protected headersKeyHandler(e: AXValueChangedEvent<any>, id: string) {\n this.headersArray.update((prev) => {\n const copy = [...prev];\n const find = copy.find((item) => item.tempId === id);\n Object.keys(find).forEach((key) => {\n if (key !== 'tempId') {\n delete find[key];\n }\n });\n find[e.value] = '';\n return copy;\n });\n }\n\n #eff = effect(() => {\n this.service.outPutJSON.update((prev) => {\n const copy = { ...prev };\n const copyHeader = { Authorization: copy.headers.Authorization, ContentType: copy.headers.ContentType };\n copy.headers = copyHeader;\n this.headersArray().forEach((item) => {\n Object.assign(copy.headers, item);\n });\n return copy;\n });\n });\n\n protected setInitialState(item: HeadersDynamic, type: string) {\n for (const [key, value] of Object.entries(item)) {\n if (key !== 'tempId') {\n if (type === 'key') {\n return key;\n } else if (type === 'value') {\n return value;\n }\n }\n }\n return '';\n }\n\n protected filterUnnecessaryKey() {\n const allHeaders = { ...this.service.outPutJSON().headers };\n\n Object.keys(allHeaders).forEach((key) => {\n if (key === 'Authorization' || key === 'ContentType') {\n delete allHeaders[key];\n }\n });\n\n return [allHeaders];\n }\n}\n","<div class=\"ax-headers-container\">\n <div class=\"ax-headers-header\">\n <ax-text>Headers</ax-text>\n <ax-button look=\"blank\" class=\"ax-sm\" color=\"primary\" text=\"add\" (onClick)=\"addHeadersHandler()\"></ax-button>\n </div>\n\n <div class=\"ax-headers-value-container\">\n @for (item of headersArray(); track item.tempId) {\n <div class=\"ax-headers-value\">\n <ax-text-box [ngModel]=\"setInitialState(item, 'key')\" (onValueChanged)=\"headersKeyHandler($event, item.tempId)\" placeholder=\"key\"></ax-text-box>\n <ax-text-box [ngModel]=\"setInitialState(item, 'value')\" (onValueChanged)=\"headersValueHandler($event, item.tempId)\" placeholder=\"value\"></ax-text-box>\n <ax-button look=\"blank\" class=\"ax-sm\" color=\"danger\" (onClick)=\"removeHeadersHandler(item.tempId)\">\n <ax-prefix>\n <ax-icon icon=\"fa-solid fa-trash-can\"></ax-icon>\n </ax-prefix>\n </ax-button>\n </div>\n }\n </div>\n</div>\n","import { AXValueChangedEvent } from '@acorex/components/common';\nimport { afterNextRender, ChangeDetectionStrategy, Component, inject, signal, ViewEncapsulation } from '@angular/core';\nimport { AXRestApiGeneratorService } from '../rest-api-generator.service';\n\n@Component({\n selector: 'ax-rest-api-auth',\n templateUrl: './rest-api-auth.component.html',\n styleUrls: ['./rest-api-auth.component.scss'],\n standalone: false,\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AXRestApiAuthComponent {\n protected service = inject(AXRestApiGeneratorService);\n\n protected value = signal(null);\n\n #init = afterNextRender(() => {\n const token = this.service.outPutJSON().headers.Authorization;\n if (token) {\n this.value.set(2);\n } else {\n this.value.set(1);\n }\n });\n\n protected selectedItem = signal({ id: null, text: '', placeHolder: '' });\n\n protected items = [\n { id: 1, text: 'None', placeHolder: '' },\n { id: 2, text: 'Bearer Token', placeHolder: 'Token' },\n ];\n\n protected authTypeHandler(e: AXValueChangedEvent<any>) {\n const find = this.items.find((item) => item.id === e.value);\n this.selectedItem.set(find);\n\n if (e.value === 1) {\n this.service.outPutJSON.update((prev) => {\n const copy = { ...prev };\n copy.headers.Authorization = '';\n return copy;\n });\n }\n }\n\n protected authInputHandler(e: AXValueChangedEvent<any>) {\n this.service.outPutJSON.update((prev) => {\n const copy = { ...prev };\n copy.headers.Authorization = e.value;\n return copy;\n });\n }\n}\n","<ax-selection-list [showControl]=\"true\" look=\"solid\" [items]=\"items\" [(ngModel)]=\"value\" (onValueChanged)=\"authTypeHandler($event)\"> </ax-selection-list>\n\n@if (selectedItem().text !== 'None') {\n <ax-text-box [(ngModel)]=\"service.outPutJSON().headers.Authorization\" (onValueChanged)=\"authInputHandler($event)\" [placeholder]=\"selectedItem().placeHolder\">\n </ax-text-box>\n}\n","import { AXValueChangedEvent } from '@acorex/components/common';\nimport { afterNextRender, ChangeDetectionStrategy, Component, effect, inject, input, output, ViewEncapsulation } from '@angular/core';\nimport { AXRestApiGeneratorService } from './rest-api-generator.service';\nimport { AXRestApiOutput } from './types';\n\n@Component({\n selector: 'ax-rest-api-generator',\n templateUrl: './rest-api-generator.component.html',\n styleUrls: ['./rest-api-generator.component.scss'],\n standalone: false,\n encapsulation: ViewEncapsulation.None,\n changeDetection: ChangeDetectionStrategy.OnPush,\n providers: [AXRestApiGeneratorService],\n})\nexport class AXRestApiGeneratorComponent {\n value = input<AXRestApiOutput>();\n\n onValueChange = output<AXRestApiOutput>();\n\n protected service = inject(AXRestApiGeneratorService);\n\n #init = afterNextRender(() => {\n if (this.value()) {\n this.service.outPutJSON.set(this.value());\n }\n });\n\n #eff = effect(() => {\n this.onValueChange.emit(this.service.outPutJSON());\n });\n\n protected urlHandler(e: AXValueChangedEvent<any>) {\n this.service.outPutJSON.update((prev) => ({ ...prev, url: e.value }));\n }\n\n protected methodHandler(e: AXValueChangedEvent<any>) {\n this.service.outPutJSON.update((prev) => ({ ...prev, method: e.value }));\n }\n}\n","<div class=\"ax-url-input-container\">\n <ax-text-box [(ngModel)]=\"service.outPutJSON().url\" placeholder=\"URL\" (onValueChanged)=\"urlHandler($event)\">\n <ax-clear-button></ax-clear-button>\n <ax-suffix>\n <ax-select-box\n [(ngModel)]=\"service.outPutJSON().method\"\n (onValueChanged)=\"methodHandler($event)\"\n [dataSource]=\"['GET', 'POST', 'DELETE', 'PUT', 'PATCH']\"\n >\n </ax-select-box\n ></ax-suffix>\n </ax-text-box>\n</div>\n\n<ax-tabs [content]=\"cronTab\" look=\"with-line\" [fitParent]=\"true\" location=\"bottom\">\n <ax-tab-item key=\"1\" text=\"Params\">\n <ax-content> <ax-query-params></ax-query-params> </ax-content>\n </ax-tab-item>\n <ax-tab-item key=\"2\" text=\"Body\">\n <ax-content><ax-request-body></ax-request-body></ax-content>\n </ax-tab-item>\n <ax-tab-item key=\"3\" text=\"Auth\">\n <ax-content> <ax-rest-api-auth></ax-rest-api-auth></ax-content>\n </ax-tab-item>\n <ax-tab-item key=\"4\" text=\"Headers\">\n <ax-content> <ax-request-headers></ax-request-headers></ax-content>\n </ax-tab-item>\n</ax-tabs>\n\n<ng-template [axTabContent] #cronTab=\"axTabContent\"> </ng-template>\n","import { AXButtonModule } from '@acorex/components/button';\nimport { AXDecoratorModule } from '@acorex/components/decorators';\nimport { AXSelectBoxModule } from '@acorex/components/select-box';\nimport { AXSelectionListModule } from '@acorex/components/selection-list';\nimport { AXTabsModule } from '@acorex/components/tabs';\nimport { AXTextAreaModule } from '@acorex/components/text-area';\nimport { AXTextBoxModule } from '@acorex/components/text-box';\nimport { NgModule } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { AXQueryParamsComponent } from './query-params/query-params.component';\nimport { AXRequestBodyComponent } from './request-body/request-body.component';\nimport { AXRequestHeadersComponent } from './request-headers/request-headers.component';\nimport { AXRestApiAuthComponent } from './rest-api-auth/rest-api-auth.component';\nimport { AXRestApiGeneratorComponent } from './rest-api-generator.component';\n\nconst COMPONENT = [AXRestApiGeneratorComponent, AXQueryParamsComponent, AXRequestBodyComponent, AXRestApiAuthComponent, AXRequestHeadersComponent];\n\nconst MODULES = [AXTextBoxModule, AXDecoratorModule, AXSelectBoxModule, AXTabsModule, AXButtonModule, AXTextAreaModule, AXSelectionListModule, FormsModule];\n\n@NgModule({\n declarations: [...COMPONENT],\n imports: [...MODULES],\n exports: [...COMPONENT],\n providers: [],\n})\nexport class AXRestApiGeneratorModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":["i1","i2","i3","i4","i5","i6.AXQueryParamsComponent","i7.AXRequestBodyComponent","i8.AXRestApiAuthComponent","i9.AXRequestHeadersComponent"],"mappings":"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"}
@@ -1,7 +1,7 @@
1
1
  import * as i3 from '@acorex/components/common';
2
2
  import { MXInputBaseValueComponent, MXLookComponent, AXSearchableComponent, AXComponent, AXFocusableComponent, AXClearableComponent, AXValuableComponent, AXNgModelDelayedValueChangedDirective } from '@acorex/components/common';
3
3
  import * as i0 from '@angular/core';
4
- import { forwardRef, HostBinding, Input, Optional, Inject, ViewEncapsulation, ChangeDetectionStrategy, Component, NgModule } from '@angular/core';
4
+ import { input, forwardRef, HostBinding, Input, Optional, Inject, ViewEncapsulation, ChangeDetectionStrategy, Component, NgModule } from '@angular/core';
5
5
  import * as i1 from '@angular/forms';
6
6
  import { NG_VALUE_ACCESSOR, FormsModule } from '@angular/forms';
7
7
  import { classes } from 'polytype';
@@ -30,6 +30,7 @@ class AXSearchBoxComponent extends classes((MXInputBaseValueComponent), MXLookCo
30
30
  * @defaultValue 500
31
31
  */
32
32
  this.delayTime = 500;
33
+ this.type = input();
33
34
  }
34
35
  /**
35
36
  * Handles changes to the model and triggers a search in the parent component if available.
@@ -44,15 +45,10 @@ class AXSearchBoxComponent extends classes((MXInputBaseValueComponent), MXLookCo
44
45
  }
45
46
  /** @ignore */
46
47
  get __hostClass() {
47
- return [
48
- 'ax-editor-container',
49
- `ax-${this.look}`,
50
- `${this.disabled ? 'ax-state-disabled' : ''}`,
51
- this.classNames,
52
- ];
48
+ return ['ax-editor-container', `ax-${this.look}`, `${this.disabled ? 'ax-state-disabled' : ''}`, this.classNames];
53
49
  }
54
50
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.3", ngImport: i0, type: AXSearchBoxComponent, deps: [{ token: AXSearchableComponent, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
55
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.0.3", type: AXSearchBoxComponent, isStandalone: false, selector: "ax-search-box", inputs: { disabled: "disabled", readonly: "readonly", tabIndex: "tabIndex", placeholder: "placeholder", value: "value", state: "state", name: "name", id: "id", look: "look", classNames: ["class", "classNames"], delayTime: "delayTime" }, outputs: { valueChange: "valueChange", stateChange: "stateChange", onValueChanged: "onValueChanged", onBlur: "onBlur", onFocus: "onFocus", readonlyChange: "readonlyChange", disabledChange: "disabledChange", onKeyDown: "onKeyDown", onKeyUp: "onKeyUp", onKeyPress: "onKeyPress" }, host: { properties: { "class": "this.__hostClass" } }, providers: [
51
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.0.3", type: AXSearchBoxComponent, isStandalone: false, selector: "ax-search-box", inputs: { disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: false, isRequired: false, transformFunction: null }, readonly: { classPropertyName: "readonly", publicName: "readonly", isSignal: false, isRequired: false, transformFunction: null }, tabIndex: { classPropertyName: "tabIndex", publicName: "tabIndex", isSignal: false, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: false, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: false, isRequired: false, transformFunction: null }, state: { classPropertyName: "state", publicName: "state", isSignal: false, isRequired: false, transformFunction: null }, name: { classPropertyName: "name", publicName: "name", isSignal: false, isRequired: false, transformFunction: null }, id: { classPropertyName: "id", publicName: "id", isSignal: false, isRequired: false, transformFunction: null }, look: { classPropertyName: "look", publicName: "look", isSignal: false, isRequired: false, transformFunction: null }, classNames: { classPropertyName: "classNames", publicName: "class", isSignal: false, isRequired: false, transformFunction: null }, delayTime: { classPropertyName: "delayTime", publicName: "delayTime", isSignal: false, isRequired: false, transformFunction: null }, type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { valueChange: "valueChange", stateChange: "stateChange", onValueChanged: "onValueChanged", onBlur: "onBlur", onFocus: "onFocus", readonlyChange: "readonlyChange", disabledChange: "disabledChange", onKeyDown: "onKeyDown", onKeyUp: "onKeyUp", onKeyPress: "onKeyPress" }, host: { properties: { "class": "this.__hostClass" } }, providers: [
56
52
  { provide: AXComponent, useExisting: AXSearchBoxComponent },
57
53
  { provide: AXFocusableComponent, useExisting: AXSearchBoxComponent },
58
54
  { provide: AXClearableComponent, useExisting: AXSearchBoxComponent },
@@ -62,22 +58,11 @@ class AXSearchBoxComponent extends classes((MXInputBaseValueComponent), MXLookCo
62
58
  useExisting: forwardRef(() => AXSearchBoxComponent),
63
59
  multi: true,
64
60
  },
65
- ], usesInheritance: true, ngImport: i0, template: "<ng-content select=\"ax-prefix\">\n <ax-prefix>\n <ax-icon class=\"ax-icon ax-icon-search\"></ax-icon>\n </ax-prefix>\n</ng-content>\n<input\n #input\n class=\"ax-input\"\n [attr.name]=\"name\"\n [attr.placeholder]=\"placeholder ?? 'search' | translate | async\"\n [class.ax-state-disabled]=\"disabled\"\n [class.ax-state-readonly]=\"readonly\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [tabindex]=\"tabIndex\"\n [ngModel]=\"value\"\n [delayTime]=\"delayTime\"\n (axDelayedValueChanged)=\"_handleModelChange($event)\"\n (keydown)=\"emitOnKeydownEvent($event)\"\n (keyup)=\"emitOnKeyupEvent($event)\"\n (keypress)=\"emitOnKeypressEvent($event)\"\n (focus)=\"emitOnFocusEvent($event)\"\n (blur)=\"emitOnBlurEvent($event)\"\n/>\n\n@if (input.value && !disabled && !readonly) {\n <ng-content select=\"ax-clear-button\"></ng-content>\n}\n<ng-content select=\"ax-suffix\"> </ng-content>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i2.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i2.AXDecoratorGenericComponent, selector: "ax-footer, ax-header, ax-content, ax-divider, ax-form-hint, ax-prefix, ax-suffix, ax-text, ax-title, ax-subtitle, ax-placeholder, ax-overlay" }, { kind: "directive", type: i3.AXNgModelDelayedValueChangedDirective, selector: "[axDelayedValueChanged]", inputs: ["delayTime"], outputs: ["axDelayedValueChanged", "axDelayTimeChange"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.AXTranslatorPipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
61
+ ], usesInheritance: true, ngImport: i0, template: "<ng-content select=\"ax-prefix\">\n <ax-prefix>\n <ax-icon class=\"ax-icon ax-icon-search\"></ax-icon>\n </ax-prefix>\n</ng-content>\n<input\n #input\n class=\"ax-input\"\n [attr.name]=\"name\"\n [attr.type]=\"type()\"\n [attr.placeholder]=\"placeholder ?? 'search' | translate | async\"\n [class.ax-state-disabled]=\"disabled\"\n [class.ax-state-readonly]=\"readonly\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [tabindex]=\"tabIndex\"\n [ngModel]=\"value\"\n [delayTime]=\"delayTime\"\n (axDelayedValueChanged)=\"_handleModelChange($event)\"\n (keydown)=\"emitOnKeydownEvent($event)\"\n (keyup)=\"emitOnKeyupEvent($event)\"\n (keypress)=\"emitOnKeypressEvent($event)\"\n (focus)=\"emitOnFocusEvent($event)\"\n (blur)=\"emitOnBlurEvent($event)\"\n/>\n\n@if (input.value && !disabled && !readonly) {\n <ng-content select=\"ax-clear-button\"></ng-content>\n}\n<ng-content select=\"ax-suffix\"> </ng-content>\n", styles: ["ax-search-box input::-webkit-outer-spin-button,ax-search-box input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}ax-search-box input[type=number]{-moz-appearance:textfield}\n"], dependencies: [{ kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i2.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i2.AXDecoratorGenericComponent, selector: "ax-footer, ax-header, ax-content, ax-divider, ax-form-hint, ax-prefix, ax-suffix, ax-text, ax-title, ax-subtitle, ax-placeholder, ax-overlay" }, { kind: "directive", type: i3.AXNgModelDelayedValueChangedDirective, selector: "[axDelayedValueChanged]", inputs: ["delayTime"], outputs: ["axDelayedValueChanged", "axDelayTimeChange"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.AXTranslatorPipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
66
62
  }
67
63
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.3", ngImport: i0, type: AXSearchBoxComponent, decorators: [{
68
64
  type: Component,
69
- args: [{ selector: 'ax-search-box', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, inputs: ['disabled', 'readonly', 'tabIndex', 'placeholder', 'value', 'state', 'name', 'id', 'look'], outputs: [
70
- 'valueChange',
71
- 'stateChange',
72
- 'onValueChanged',
73
- 'onBlur',
74
- 'onFocus',
75
- 'readonlyChange',
76
- 'disabledChange',
77
- 'onKeyDown',
78
- 'onKeyUp',
79
- 'onKeyPress',
80
- ], providers: [
65
+ args: [{ selector: 'ax-search-box', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, inputs: ['disabled', 'readonly', 'tabIndex', 'placeholder', 'value', 'state', 'name', 'id', 'look'], outputs: ['valueChange', 'stateChange', 'onValueChanged', 'onBlur', 'onFocus', 'readonlyChange', 'disabledChange', 'onKeyDown', 'onKeyUp', 'onKeyPress'], providers: [
81
66
  { provide: AXComponent, useExisting: AXSearchBoxComponent },
82
67
  { provide: AXFocusableComponent, useExisting: AXSearchBoxComponent },
83
68
  { provide: AXClearableComponent, useExisting: AXSearchBoxComponent },
@@ -87,7 +72,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.3", ngImpor
87
72
  useExisting: forwardRef(() => AXSearchBoxComponent),
88
73
  multi: true,
89
74
  },
90
- ], standalone: false, template: "<ng-content select=\"ax-prefix\">\n <ax-prefix>\n <ax-icon class=\"ax-icon ax-icon-search\"></ax-icon>\n </ax-prefix>\n</ng-content>\n<input\n #input\n class=\"ax-input\"\n [attr.name]=\"name\"\n [attr.placeholder]=\"placeholder ?? 'search' | translate | async\"\n [class.ax-state-disabled]=\"disabled\"\n [class.ax-state-readonly]=\"readonly\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [tabindex]=\"tabIndex\"\n [ngModel]=\"value\"\n [delayTime]=\"delayTime\"\n (axDelayedValueChanged)=\"_handleModelChange($event)\"\n (keydown)=\"emitOnKeydownEvent($event)\"\n (keyup)=\"emitOnKeyupEvent($event)\"\n (keypress)=\"emitOnKeypressEvent($event)\"\n (focus)=\"emitOnFocusEvent($event)\"\n (blur)=\"emitOnBlurEvent($event)\"\n/>\n\n@if (input.value && !disabled && !readonly) {\n <ng-content select=\"ax-clear-button\"></ng-content>\n}\n<ng-content select=\"ax-suffix\"> </ng-content>\n" }]
75
+ ], standalone: false, template: "<ng-content select=\"ax-prefix\">\n <ax-prefix>\n <ax-icon class=\"ax-icon ax-icon-search\"></ax-icon>\n </ax-prefix>\n</ng-content>\n<input\n #input\n class=\"ax-input\"\n [attr.name]=\"name\"\n [attr.type]=\"type()\"\n [attr.placeholder]=\"placeholder ?? 'search' | translate | async\"\n [class.ax-state-disabled]=\"disabled\"\n [class.ax-state-readonly]=\"readonly\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [tabindex]=\"tabIndex\"\n [ngModel]=\"value\"\n [delayTime]=\"delayTime\"\n (axDelayedValueChanged)=\"_handleModelChange($event)\"\n (keydown)=\"emitOnKeydownEvent($event)\"\n (keyup)=\"emitOnKeyupEvent($event)\"\n (keypress)=\"emitOnKeypressEvent($event)\"\n (focus)=\"emitOnFocusEvent($event)\"\n (blur)=\"emitOnBlurEvent($event)\"\n/>\n\n@if (input.value && !disabled && !readonly) {\n <ng-content select=\"ax-clear-button\"></ng-content>\n}\n<ng-content select=\"ax-suffix\"> </ng-content>\n", styles: ["ax-search-box input::-webkit-outer-spin-button,ax-search-box input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}ax-search-box input[type=number]{-moz-appearance:textfield}\n"] }]
91
76
  }], ctorParameters: () => [{ type: i3.AXSearchableComponent, decorators: [{
92
77
  type: Optional
93
78
  }, {