@devlearning/swagger-generator 1.1.21 โ†’ 1.1.23

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (56) hide show
  1. package/.vscode/launch.json +28 -28
  2. package/README-OLD.md +209 -209
  3. package/README.md +277 -277
  4. package/dist/api.constants.d.ts +1 -1
  5. package/dist/api.constants.js +22 -22
  6. package/dist/generators-writers/angular/api-angular-writer.js +38 -38
  7. package/dist/generators-writers/angular/constants.js +24 -24
  8. package/dist/generators-writers/angular/model-angular-writer.js +6 -6
  9. package/dist/generators-writers/dart/model-dart-writer.js +11 -4
  10. package/dist/generators-writers/dart/templates/api.mustache +143 -143
  11. package/dist/generators-writers/dart/templates/enum.mustache +14 -14
  12. package/dist/generators-writers/dart/templates/model.mustache +23 -23
  13. package/dist/generators-writers/nextjs/api-nextjs-writer.js +12 -12
  14. package/dist/generators-writers/nextjs/constants.js +4 -4
  15. package/dist/generators-writers/nextjs/model-nextjs-writer.js +6 -6
  16. package/dist/generators-writers/utils.d.ts +1 -0
  17. package/dist/generators-writers/utils.js +16 -4
  18. package/dist/templates/api.mustache +29 -0
  19. package/dist/templates/model.mustache +18 -0
  20. package/package.json +49 -49
  21. package/src/api.constants.ts +26 -26
  22. package/src/generator-old.ts +449 -449
  23. package/src/generator.ts +752 -752
  24. package/src/generators-writers/angular/api-angular-writer.ts +187 -187
  25. package/src/generators-writers/angular/constants.ts +36 -36
  26. package/src/generators-writers/angular/model-angular-writer.ts +65 -65
  27. package/src/generators-writers/angular/normalizator.ts +41 -41
  28. package/src/generators-writers/dart/api-dart-writer.ts +303 -303
  29. package/src/generators-writers/dart/model-dart-writer.ts +226 -219
  30. package/src/generators-writers/dart/models/import-definition-dart.ts +5 -5
  31. package/src/generators-writers/dart/normalizator.ts +72 -72
  32. package/src/generators-writers/dart/templates/api.mustache +143 -143
  33. package/src/generators-writers/dart/templates/enum.mustache +14 -14
  34. package/src/generators-writers/dart/templates/model.mustache +23 -23
  35. package/src/generators-writers/nextjs/api-nextjs-writer.ts +157 -157
  36. package/src/generators-writers/nextjs/constants.ts +5 -5
  37. package/src/generators-writers/nextjs/model-nextjs-writer.ts +61 -61
  38. package/src/generators-writers/utils.ts +111 -93
  39. package/src/index.ts +103 -103
  40. package/src/models/api-dto.ts +17 -17
  41. package/src/models/enum-value-dto.ts +3 -3
  42. package/src/models/model-dto.ts +9 -9
  43. package/src/models/parameter-dto.ts +7 -7
  44. package/src/models/property-dto.ts +4 -4
  45. package/src/models/swagger/swagger-component-property.ts +11 -11
  46. package/src/models/swagger/swagger-component.ts +17 -17
  47. package/src/models/swagger/swagger-content.ts +4 -4
  48. package/src/models/swagger/swagger-info.ts +3 -3
  49. package/src/models/swagger/swagger-method.ts +7 -7
  50. package/src/models/swagger/swagger-schema.ts +21 -21
  51. package/src/models/swagger/swagger.ts +38 -38
  52. package/src/models/type-dto.ts +7 -7
  53. package/src/swagger-downloader.ts +46 -46
  54. package/src/utils/logger.ts +73 -73
  55. package/src/utils/swagger-validator.ts +89 -89
  56. package/tsconfig.json +33 -33
package/README.md CHANGED
@@ -1,277 +1,277 @@
1
- # Swagger API Generator
2
-
3
- Generatore automatico di client API e modelli per **Angular**, **Next.js** e **Flutter/Dart** da specifiche Swagger/OpenAPI.
4
-
5
- [![npm version](https://img.shields.io/npm/v/@devlearning/swagger-generator.svg)](https://www.npmjs.com/package/@devlearning/swagger-generator)
6
- [![License: ISC](https://img.shields.io/badge/License-ISC-blue.svg)](https://opensource.org/licenses/ISC)
7
-
8
- ## ๐ŸŽฏ Caratteristiche
9
-
10
- - โœ… **Generazione automatica** di modelli e API da Swagger JSON
11
- - ๐ŸŽจ **Multi-framework**: Angular, Next.js, Flutter/Dart
12
- - ๐Ÿ”’ **Type-safe**: Tipizzazione forte per TypeScript e Dart
13
- - ๐Ÿ“ฆ **Zero dipendenze** nei file generati (configurabile)
14
- - ๐Ÿš€ **CLI semplice** da usare
15
- - ๐Ÿ”„ **Validazione** del documento Swagger prima della generazione
16
- - ๐Ÿ“ **Logging strutturato** per debugging
17
-
18
- ## ๐Ÿ“ฆ Installazione
19
-
20
- ```bash
21
- npm install @devlearning/swagger-generator --save-dev
22
- ```
23
-
24
- ## ๐Ÿš€ Utilizzo
25
-
26
- ### Da linea di comando
27
-
28
- ```bash
29
- npx swgen --url <swagger-url> --output <output-dir> --target <angular|next|flutter> [opzioni]
30
- ```
31
-
32
- ### Esempi
33
-
34
- #### Angular
35
- ```bash
36
- npx swgen \
37
- --url http://localhost:5000/swagger/v1/swagger.json \
38
- --output src/app/core/autogen \
39
- --target angular \
40
- --dateTimeLibrary moment
41
- ```
42
-
43
- #### Next.js
44
- ```bash
45
- npx swgen \
46
- --url https://api.example.com/swagger.json \
47
- --output src/lib/api \
48
- --target next \
49
- --dateTimeLibrary date-fns
50
- ```
51
-
52
- #### Flutter/Dart
53
- ```bash
54
- npx swgen \
55
- --url http://localhost:5000/swagger/v1/swagger.json \
56
- --output lib/core/api \
57
- --target flutter \
58
- --package my_app_name
59
- ```
60
-
61
- ### Opzioni
62
-
63
- | Opzione | Alias | Descrizione | Obbligatorio | Default |
64
- |---------|-------|-------------|--------------|---------|
65
- | `--url` | `-u` | URL del file swagger.json | โœ… | - |
66
- | `--output` | `-o` | Directory di output | โœ… | - |
67
- | `--target` | `-t` | Framework target (`angular`, `next`, `flutter`) | โœ… | - |
68
- | `--dateTimeLibrary` | `-d` | Libreria date (`moment`, `date-fns`) | โŒ | `date-fns` |
69
- | `--package` | `-p` | Nome package (solo Dart/Flutter) | โŒ | - |
70
- | `--api-client-name` | `-a` | Nome classe API unificata | โŒ | - |
71
-
72
- ### ๐Ÿ†• API Client Unificata
73
-
74
- Di default, il generatore crea classi API separate raggruppate per tag Swagger. Con l'opzione `--api-client-name`, puoi generare una **singola classe unificata** contenente tutti i metodi API.
75
-
76
- #### Esempio: Flutter con classe unificata
77
-
78
- ```bash
79
- npx swgen \
80
- --url http://localhost:5000/swagger/v1/swagger.json \
81
- --output lib/core/api \
82
- --target flutter \
83
- --package my_app \
84
- --api-client-name ApiClient
85
- ```
86
-
87
- Genera:
88
- ```dart
89
- // lib/core/api/api_client.dart
90
- class ApiClient {
91
- // Tutti i metodi API in una singola classe
92
- Future<User> getUser(String id) async { ... }
93
- Future<List<Product>> getProducts() async { ... }
94
- Future<void> createOrder(Order order) async { ... }
95
- // ...
96
- }
97
- ```
98
-
99
- #### Senza --api-client-name (comportamento predefinito)
100
-
101
- Genera classi separate per tag:
102
- ```dart
103
- // lib/core/api/users_api.dart
104
- class UsersApi { ... }
105
-
106
- // lib/core/api/products_api.dart
107
- class ProductsApi { ... }
108
-
109
- // lib/core/api/orders_api.dart
110
- class OrdersApi { ... }
111
- ```
112
-
113
- #### Quando usare la classe unificata?
114
-
115
- - โœ… Progetti piccoli/medi con pochi endpoint
116
- - โœ… Quando preferisci un singolo punto di accesso alle API
117
- - โœ… Per semplificare la dependency injection
118
-
119
- #### Quando usare classi separate?
120
-
121
- - โœ… Progetti grandi con molti endpoint
122
- - โœ… Quando vuoi separare le responsabilitร  per dominio
123
- - โœ… Per team diversi che lavorano su moduli diversi
124
-
125
- ## ๐Ÿ“ Struttura File Generati
126
-
127
- ### Angular
128
- ```
129
- output/
130
- โ”œโ”€โ”€ models/
131
- โ”‚ โ”œโ”€โ”€ user.model.ts
132
- โ”‚ โ”œโ”€โ”€ product.model.ts
133
- โ”‚ โ””โ”€โ”€ ...
134
- โ””โ”€โ”€ api/
135
- โ”œโ”€โ”€ user.api.ts
136
- โ”œโ”€โ”€ product.api.ts
137
- โ””โ”€โ”€ ...
138
- ```
139
-
140
- ### Next.js
141
- ```
142
- output/
143
- โ”œโ”€โ”€ models/
144
- โ”‚ โ”œโ”€โ”€ user.ts
145
- โ”‚ โ”œโ”€โ”€ product.ts
146
- โ”‚ โ””โ”€โ”€ ...
147
- โ””โ”€โ”€ api/
148
- โ”œโ”€โ”€ user-api.ts
149
- โ”œโ”€โ”€ product-api.ts
150
- โ””โ”€โ”€ ...
151
- ```
152
-
153
- ### Flutter/Dart
154
- ```
155
- lib/output/
156
- โ”œโ”€โ”€ user/
157
- โ”‚ โ”œโ”€โ”€ models/
158
- โ”‚ โ”‚ โ””โ”€โ”€ user.dart
159
- โ”‚ โ””โ”€โ”€ api/
160
- โ”‚ โ””โ”€โ”€ user_api.dart
161
- โ””โ”€โ”€ product/
162
- โ”œโ”€โ”€ models/
163
- โ”‚ โ””โ”€โ”€ product.dart
164
- โ””โ”€โ”€ api/
165
- โ””โ”€โ”€ product_api.dart
166
- ```
167
-
168
- ## ๐Ÿ”ง Integrazione nel Progetto
169
-
170
- ### Angular
171
-
172
- 1. Crea un service wrapper:
173
-
174
- ```typescript
175
- import { Injectable } from '@angular/core';
176
- import { HttpClient } from '@angular/common/http';
177
- import { environment } from '@env/environment';
178
-
179
- @Injectable({ providedIn: 'root' })
180
- export class ApiService {
181
- constructor(private http: HttpClient) {}
182
-
183
- // I tuoi metodi personalizzati qui
184
- }
185
- ```
186
-
187
- 2. Usa i modelli generati:
188
-
189
- ```typescript
190
- import { User } from './autogen/models/user.model';
191
- import { UserApi } from './autogen/api/user.api';
192
- ```
193
-
194
- ### Next.js
195
-
196
- ```typescript
197
- import { getUsers } from '@/lib/api/user-api';
198
- import { User } from '@/lib/api/models/user';
199
-
200
- export async function UsersPage() {
201
- const users = await getUsers();
202
- // ...
203
- }
204
- ```
205
-
206
- ### Flutter/Dart
207
-
208
- ```dart
209
- import 'package:my_app/core/api/user/api/user_api.dart';
210
- import 'package:my_app/core/api/user/models/user.dart';
211
-
212
- final userApi = UserApi();
213
- final users = await userApi.getUsers();
214
- ```
215
-
216
- ## ๐Ÿ› Risoluzione Problemi
217
-
218
- ### Errore: "Swagger validation failed"
219
- Il documento Swagger non รจ valido. Verifica:
220
- - Presenza di `openApi` version
221
- - Presenza di `paths` object
222
- - Struttura corretta delle definizioni
223
-
224
- ### Errore: "Cannot parse null data"
225
- L'API restituisce null per un tipo primitivo. Verifica che il backend ritorni sempre un valore valido.
226
-
227
- ### Tipi primitivi non funzionano (Dart)
228
- โœ… **RISOLTO** - Ora il generatore gestisce correttamente String, int, bool, double con conversioni automatiche.
229
-
230
- ## ๐Ÿ› ๏ธ Sviluppo
231
-
232
- ```bash
233
- # Clone repository
234
- git clone <repo-url>
235
-
236
- # Install dependencies
237
- npm install
238
-
239
- # Build
240
- npm run build
241
-
242
- # Test local
243
- npm run debug-angular
244
- npm run debug-nextjs
245
- npm run debug-flutter
246
- ```
247
-
248
- ## ๐Ÿ“ Script NPM
249
-
250
- | Script | Descrizione |
251
- |--------|-------------|
252
- | `npm run build` | Compila TypeScript e copia templates |
253
- | `npm run debug-angular` | Test con target Angular |
254
- | `npm run debug-nextjs` | Test con target Next.js |
255
- | `npm run debug-flutter` | Test con target Flutter |
256
- | `npm run deploy` | Pubblica su npm |
257
-
258
- ## ๐Ÿค Contribuire
259
-
260
- Contributi benvenuti! Per favore:
261
- 1. Fai fork del progetto
262
- 2. Crea un branch per la tua feature (`git checkout -b feature/amazing-feature`)
263
- 3. Commit dei cambiamenti (`git commit -m 'Add amazing feature'`)
264
- 4. Push del branch (`git push origin feature/amazing-feature`)
265
- 5. Apri una Pull Request
266
-
267
- ## ๐Ÿ“„ Licenza
268
-
269
- ISC License - vedi file LICENSE per dettagli
270
-
271
- ## ๐Ÿ™ Crediti
272
-
273
- Sviluppato da DeVLearninG Team
274
-
275
- ---
276
-
277
- **Note**: Questo tool รจ in sviluppo attivo. Per bug o feature request, apri una issue su GitHub.
1
+ # Swagger API Generator
2
+
3
+ Generatore automatico di client API e modelli per **Angular**, **Next.js** e **Flutter/Dart** da specifiche Swagger/OpenAPI.
4
+
5
+ [![npm version](https://img.shields.io/npm/v/@devlearning/swagger-generator.svg)](https://www.npmjs.com/package/@devlearning/swagger-generator)
6
+ [![License: ISC](https://img.shields.io/badge/License-ISC-blue.svg)](https://opensource.org/licenses/ISC)
7
+
8
+ ## ๐ŸŽฏ Caratteristiche
9
+
10
+ - โœ… **Generazione automatica** di modelli e API da Swagger JSON
11
+ - ๐ŸŽจ **Multi-framework**: Angular, Next.js, Flutter/Dart
12
+ - ๐Ÿ”’ **Type-safe**: Tipizzazione forte per TypeScript e Dart
13
+ - ๐Ÿ“ฆ **Zero dipendenze** nei file generati (configurabile)
14
+ - ๐Ÿš€ **CLI semplice** da usare
15
+ - ๐Ÿ”„ **Validazione** del documento Swagger prima della generazione
16
+ - ๐Ÿ“ **Logging strutturato** per debugging
17
+
18
+ ## ๐Ÿ“ฆ Installazione
19
+
20
+ ```bash
21
+ npm install @devlearning/swagger-generator --save-dev
22
+ ```
23
+
24
+ ## ๐Ÿš€ Utilizzo
25
+
26
+ ### Da linea di comando
27
+
28
+ ```bash
29
+ npx swgen --url <swagger-url> --output <output-dir> --target <angular|next|flutter> [opzioni]
30
+ ```
31
+
32
+ ### Esempi
33
+
34
+ #### Angular
35
+ ```bash
36
+ npx swgen \
37
+ --url http://localhost:5000/swagger/v1/swagger.json \
38
+ --output src/app/core/autogen \
39
+ --target angular \
40
+ --dateTimeLibrary moment
41
+ ```
42
+
43
+ #### Next.js
44
+ ```bash
45
+ npx swgen \
46
+ --url https://api.example.com/swagger.json \
47
+ --output src/lib/api \
48
+ --target next \
49
+ --dateTimeLibrary date-fns
50
+ ```
51
+
52
+ #### Flutter/Dart
53
+ ```bash
54
+ npx swgen \
55
+ --url http://localhost:5000/swagger/v1/swagger.json \
56
+ --output lib/core/api \
57
+ --target flutter \
58
+ --package my_app_name
59
+ ```
60
+
61
+ ### Opzioni
62
+
63
+ | Opzione | Alias | Descrizione | Obbligatorio | Default |
64
+ |---------|-------|-------------|--------------|---------|
65
+ | `--url` | `-u` | URL del file swagger.json | โœ… | - |
66
+ | `--output` | `-o` | Directory di output | โœ… | - |
67
+ | `--target` | `-t` | Framework target (`angular`, `next`, `flutter`) | โœ… | - |
68
+ | `--dateTimeLibrary` | `-d` | Libreria date (`moment`, `date-fns`) | โŒ | `date-fns` |
69
+ | `--package` | `-p` | Nome package (solo Dart/Flutter) | โŒ | - |
70
+ | `--api-client-name` | `-a` | Nome classe API unificata | โŒ | - |
71
+
72
+ ### ๐Ÿ†• API Client Unificata
73
+
74
+ Di default, il generatore crea classi API separate raggruppate per tag Swagger. Con l'opzione `--api-client-name`, puoi generare una **singola classe unificata** contenente tutti i metodi API.
75
+
76
+ #### Esempio: Flutter con classe unificata
77
+
78
+ ```bash
79
+ npx swgen \
80
+ --url http://localhost:5000/swagger/v1/swagger.json \
81
+ --output lib/core/api \
82
+ --target flutter \
83
+ --package my_app \
84
+ --api-client-name ApiClient
85
+ ```
86
+
87
+ Genera:
88
+ ```dart
89
+ // lib/core/api/api_client.dart
90
+ class ApiClient {
91
+ // Tutti i metodi API in una singola classe
92
+ Future<User> getUser(String id) async { ... }
93
+ Future<List<Product>> getProducts() async { ... }
94
+ Future<void> createOrder(Order order) async { ... }
95
+ // ...
96
+ }
97
+ ```
98
+
99
+ #### Senza --api-client-name (comportamento predefinito)
100
+
101
+ Genera classi separate per tag:
102
+ ```dart
103
+ // lib/core/api/users_api.dart
104
+ class UsersApi { ... }
105
+
106
+ // lib/core/api/products_api.dart
107
+ class ProductsApi { ... }
108
+
109
+ // lib/core/api/orders_api.dart
110
+ class OrdersApi { ... }
111
+ ```
112
+
113
+ #### Quando usare la classe unificata?
114
+
115
+ - โœ… Progetti piccoli/medi con pochi endpoint
116
+ - โœ… Quando preferisci un singolo punto di accesso alle API
117
+ - โœ… Per semplificare la dependency injection
118
+
119
+ #### Quando usare classi separate?
120
+
121
+ - โœ… Progetti grandi con molti endpoint
122
+ - โœ… Quando vuoi separare le responsabilitร  per dominio
123
+ - โœ… Per team diversi che lavorano su moduli diversi
124
+
125
+ ## ๐Ÿ“ Struttura File Generati
126
+
127
+ ### Angular
128
+ ```
129
+ output/
130
+ โ”œโ”€โ”€ models/
131
+ โ”‚ โ”œโ”€โ”€ user.model.ts
132
+ โ”‚ โ”œโ”€โ”€ product.model.ts
133
+ โ”‚ โ””โ”€โ”€ ...
134
+ โ””โ”€โ”€ api/
135
+ โ”œโ”€โ”€ user.api.ts
136
+ โ”œโ”€โ”€ product.api.ts
137
+ โ””โ”€โ”€ ...
138
+ ```
139
+
140
+ ### Next.js
141
+ ```
142
+ output/
143
+ โ”œโ”€โ”€ models/
144
+ โ”‚ โ”œโ”€โ”€ user.ts
145
+ โ”‚ โ”œโ”€โ”€ product.ts
146
+ โ”‚ โ””โ”€โ”€ ...
147
+ โ””โ”€โ”€ api/
148
+ โ”œโ”€โ”€ user-api.ts
149
+ โ”œโ”€โ”€ product-api.ts
150
+ โ””โ”€โ”€ ...
151
+ ```
152
+
153
+ ### Flutter/Dart
154
+ ```
155
+ lib/output/
156
+ โ”œโ”€โ”€ user/
157
+ โ”‚ โ”œโ”€โ”€ models/
158
+ โ”‚ โ”‚ โ””โ”€โ”€ user.dart
159
+ โ”‚ โ””โ”€โ”€ api/
160
+ โ”‚ โ””โ”€โ”€ user_api.dart
161
+ โ””โ”€โ”€ product/
162
+ โ”œโ”€โ”€ models/
163
+ โ”‚ โ””โ”€โ”€ product.dart
164
+ โ””โ”€โ”€ api/
165
+ โ””โ”€โ”€ product_api.dart
166
+ ```
167
+
168
+ ## ๐Ÿ”ง Integrazione nel Progetto
169
+
170
+ ### Angular
171
+
172
+ 1. Crea un service wrapper:
173
+
174
+ ```typescript
175
+ import { Injectable } from '@angular/core';
176
+ import { HttpClient } from '@angular/common/http';
177
+ import { environment } from '@env/environment';
178
+
179
+ @Injectable({ providedIn: 'root' })
180
+ export class ApiService {
181
+ constructor(private http: HttpClient) {}
182
+
183
+ // I tuoi metodi personalizzati qui
184
+ }
185
+ ```
186
+
187
+ 2. Usa i modelli generati:
188
+
189
+ ```typescript
190
+ import { User } from './autogen/models/user.model';
191
+ import { UserApi } from './autogen/api/user.api';
192
+ ```
193
+
194
+ ### Next.js
195
+
196
+ ```typescript
197
+ import { getUsers } from '@/lib/api/user-api';
198
+ import { User } from '@/lib/api/models/user';
199
+
200
+ export async function UsersPage() {
201
+ const users = await getUsers();
202
+ // ...
203
+ }
204
+ ```
205
+
206
+ ### Flutter/Dart
207
+
208
+ ```dart
209
+ import 'package:my_app/core/api/user/api/user_api.dart';
210
+ import 'package:my_app/core/api/user/models/user.dart';
211
+
212
+ final userApi = UserApi();
213
+ final users = await userApi.getUsers();
214
+ ```
215
+
216
+ ## ๐Ÿ› Risoluzione Problemi
217
+
218
+ ### Errore: "Swagger validation failed"
219
+ Il documento Swagger non รจ valido. Verifica:
220
+ - Presenza di `openApi` version
221
+ - Presenza di `paths` object
222
+ - Struttura corretta delle definizioni
223
+
224
+ ### Errore: "Cannot parse null data"
225
+ L'API restituisce null per un tipo primitivo. Verifica che il backend ritorni sempre un valore valido.
226
+
227
+ ### Tipi primitivi non funzionano (Dart)
228
+ โœ… **RISOLTO** - Ora il generatore gestisce correttamente String, int, bool, double con conversioni automatiche.
229
+
230
+ ## ๐Ÿ› ๏ธ Sviluppo
231
+
232
+ ```bash
233
+ # Clone repository
234
+ git clone <repo-url>
235
+
236
+ # Install dependencies
237
+ npm install
238
+
239
+ # Build
240
+ npm run build
241
+
242
+ # Test local
243
+ npm run debug-angular
244
+ npm run debug-nextjs
245
+ npm run debug-flutter
246
+ ```
247
+
248
+ ## ๐Ÿ“ Script NPM
249
+
250
+ | Script | Descrizione |
251
+ |--------|-------------|
252
+ | `npm run build` | Compila TypeScript e copia templates |
253
+ | `npm run debug-angular` | Test con target Angular |
254
+ | `npm run debug-nextjs` | Test con target Next.js |
255
+ | `npm run debug-flutter` | Test con target Flutter |
256
+ | `npm run deploy` | Pubblica su npm |
257
+
258
+ ## ๐Ÿค Contribuire
259
+
260
+ Contributi benvenuti! Per favore:
261
+ 1. Fai fork del progetto
262
+ 2. Crea un branch per la tua feature (`git checkout -b feature/amazing-feature`)
263
+ 3. Commit dei cambiamenti (`git commit -m 'Add amazing feature'`)
264
+ 4. Push del branch (`git push origin feature/amazing-feature`)
265
+ 5. Apri una Pull Request
266
+
267
+ ## ๐Ÿ“„ Licenza
268
+
269
+ ISC License - vedi file LICENSE per dettagli
270
+
271
+ ## ๐Ÿ™ Crediti
272
+
273
+ Sviluppato da DeVLearninG Team
274
+
275
+ ---
276
+
277
+ **Note**: Questo tool รจ in sviluppo attivo. Per bug o feature request, apri una issue su GitHub.
@@ -1,2 +1,2 @@
1
- export declare const API_PRE = "import { HttpClient } from '@angular/common/http';\nimport { Observable, catchError, map } from 'rxjs';\nimport * as Models from './model.autogenerated';\nimport { HttpHeaders } from \"@angular/common/http\";\n\nexport const httpOptions = {\n headers: new HttpHeaders({ 'Content-Type': 'application/json' }),\n};\n\nexport const httpOptionsMultipart = {};\n\nexport abstract class ApiAutogeneratedService {\n constructor(\n public _http: HttpClient,\n public _baseUrl: string,\n ) { }\n\n protected abstract _momentToString(moment: moment.Moment): string;\n protected abstract _handleRequest<T>(request: T): T;\n protected abstract _handleMultipart<T>(request: T): FormData;\n protected abstract _handleResponse<T>(response: T): T;\n protected abstract _handleError(error: any, obs: any): Observable<never>;\n";
1
+ export declare const API_PRE = "import { HttpClient } from '@angular/common/http';\nimport { Observable, catchError, map } from 'rxjs';\nimport * as Models from './model.autogenerated';\nimport { HttpHeaders } from \"@angular/common/http\";\n\nexport const httpOptions = {\n headers: new HttpHeaders({ 'Content-Type': 'application/json' }),\n};\n\nexport const httpOptionsMultipart = {};\n\nexport abstract class ApiAutogeneratedService {\n constructor(\n public _http: HttpClient,\n public _baseUrl: string,\n ) { }\n\n protected abstract _momentToString(moment: moment.Moment): string;\n protected abstract _handleRequest<T>(request: T): T;\n protected abstract _handleMultipart<T>(request: T): FormData;\n protected abstract _handleResponse<T>(response: T): T;\n protected abstract _handleError(error: any, obs: any, skipErrorHandling: boolean): Observable<never>;\n";
2
2
  export declare const API_POST = "}";
@@ -1,24 +1,24 @@
1
- export const API_PRE = `import { HttpClient } from '@angular/common/http';
2
- import { Observable, catchError, map } from 'rxjs';
3
- import * as Models from './model.autogenerated';
4
- import { HttpHeaders } from "@angular/common/http";
5
-
6
- export const httpOptions = {
7
- headers: new HttpHeaders({ 'Content-Type': 'application/json' }),
8
- };
9
-
10
- export const httpOptionsMultipart = {};
11
-
12
- export abstract class ApiAutogeneratedService {
13
- constructor(
14
- public _http: HttpClient,
15
- public _baseUrl: string,
16
- ) { }
17
-
18
- protected abstract _momentToString(moment: moment.Moment): string;
19
- protected abstract _handleRequest<T>(request: T): T;
20
- protected abstract _handleMultipart<T>(request: T): FormData;
21
- protected abstract _handleResponse<T>(response: T): T;
22
- protected abstract _handleError(error: any, obs: any): Observable<never>;
1
+ export const API_PRE = `import { HttpClient } from '@angular/common/http';
2
+ import { Observable, catchError, map } from 'rxjs';
3
+ import * as Models from './model.autogenerated';
4
+ import { HttpHeaders } from "@angular/common/http";
5
+
6
+ export const httpOptions = {
7
+ headers: new HttpHeaders({ 'Content-Type': 'application/json' }),
8
+ };
9
+
10
+ export const httpOptionsMultipart = {};
11
+
12
+ export abstract class ApiAutogeneratedService {
13
+ constructor(
14
+ public _http: HttpClient,
15
+ public _baseUrl: string,
16
+ ) { }
17
+
18
+ protected abstract _momentToString(moment: moment.Moment): string;
19
+ protected abstract _handleRequest<T>(request: T): T;
20
+ protected abstract _handleMultipart<T>(request: T): FormData;
21
+ protected abstract _handleResponse<T>(response: T): T;
22
+ protected abstract _handleError(error: any, obs: any, skipErrorHandling: boolean): Observable<never>;
23
23
  `;
24
24
  export const API_POST = `}`;