http-request-manager 18.7.19 → 18.7.21

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 (198) hide show
  1. package/ARCHITECTURE.md +483 -0
  2. package/DATABASE_README.md +1176 -0
  3. package/HTTP_MANAGER_README.md +579 -0
  4. package/HTTP_SINGNALS_MANAGER_README.md +654 -0
  5. package/HTTP_STATE_MANAGER_README.md +948 -0
  6. package/INTERCEPTOR_README.md +549 -0
  7. package/LOCAL_STORAGE_README.md +1056 -0
  8. package/STORE_STATE_MANAGER_README.md +1322 -0
  9. package/UTILS_README.md +1186 -0
  10. package/WS_MANAGER_README.md +613 -0
  11. package/ng-package.json +8 -0
  12. package/package.json +1 -12
  13. package/src/lib/http-request-manager.module.ts +132 -0
  14. package/src/lib/http-request-services-demo/database-data-demo/database-data-demo.component.html +65 -0
  15. package/src/lib/http-request-services-demo/database-data-demo/database-data-demo.component.scss +0 -0
  16. package/src/lib/http-request-services-demo/database-data-demo/database-data-demo.component.ts +224 -0
  17. package/src/lib/http-request-services-demo/http-request-services-demo.component.html +114 -0
  18. package/src/lib/http-request-services-demo/http-request-services-demo.component.scss +6 -0
  19. package/src/lib/http-request-services-demo/http-request-services-demo.component.ts +52 -0
  20. package/src/lib/http-request-services-demo/local-storage-demo/local-storage-demo.component.html +195 -0
  21. package/src/lib/http-request-services-demo/local-storage-demo/local-storage-demo.component.scss +17 -0
  22. package/src/lib/http-request-services-demo/local-storage-demo/local-storage-demo.component.ts +206 -0
  23. package/src/lib/http-request-services-demo/local-storage-signals-demo/local-storage-signals-demo.component.html +200 -0
  24. package/src/lib/http-request-services-demo/local-storage-signals-demo/local-storage-signals-demo.component.scss +17 -0
  25. package/src/lib/http-request-services-demo/local-storage-signals-demo/local-storage-signals-demo.component.ts +212 -0
  26. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/download-file/download-file.component.html +53 -0
  27. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/download-file/download-file.component.scss +60 -0
  28. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/download-file/download-file.component.ts +72 -0
  29. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/file-download.module.ts +28 -0
  30. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/file-downloader.component.html +10 -0
  31. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/file-downloader.component.scss +29 -0
  32. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/file-downloader.component.ts +100 -0
  33. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/models/download-labels-model.ts +22 -0
  34. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/spinner/spinner.component.html +8 -0
  35. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/spinner/spinner.component.scss +19 -0
  36. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/spinner/spinner.component.ts +26 -0
  37. package/src/lib/http-request-services-demo/request-manager-demo/models/app-session.model.ts +30 -0
  38. package/src/lib/http-request-services-demo/request-manager-demo/models/app.model.ts +19 -0
  39. package/src/lib/http-request-services-demo/request-manager-demo/models/get-sample.model.ts +25 -0
  40. package/src/lib/http-request-services-demo/request-manager-demo/models/sample-ai-prompt.ts +19 -0
  41. package/src/lib/http-request-services-demo/request-manager-demo/models/sample-client-details.ts +24 -0
  42. package/src/lib/http-request-services-demo/request-manager-demo/models/sample-client-info.ts +30 -0
  43. package/src/lib/http-request-services-demo/request-manager-demo/models/sample-client.model.ts +49 -0
  44. package/src/lib/http-request-services-demo/request-manager-demo/models/sample-mapper-client-info.ts +33 -0
  45. package/src/lib/http-request-services-demo/request-manager-demo/request-manager-demo.component.html +392 -0
  46. package/src/lib/http-request-services-demo/request-manager-demo/request-manager-demo.component.scss +24 -0
  47. package/src/lib/http-request-services-demo/request-manager-demo/request-manager-demo.component.ts +461 -0
  48. package/src/lib/http-request-services-demo/request-manager-state-demo/request-manager-state-demo.component.html +393 -0
  49. package/src/lib/http-request-services-demo/request-manager-state-demo/request-manager-state-demo.component.scss +24 -0
  50. package/src/lib/http-request-services-demo/request-manager-state-demo/request-manager-state-demo.component.ts +421 -0
  51. package/src/lib/http-request-services-demo/request-manager-state-demo/services/state-manager-demo.service.ts +87 -0
  52. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/services/state-data-request.service.ts +120 -0
  53. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-ai-messaging/ws-ai-messaging.component.css +0 -0
  54. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-ai-messaging/ws-ai-messaging.component.html +3 -0
  55. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-ai-messaging/ws-ai-messaging.component.ts +16 -0
  56. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-chats/ws-chats.component.css +0 -0
  57. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-chats/ws-chats.component.html +3 -0
  58. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-chats/ws-chats.component.ts +16 -0
  59. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-data-control/ws-data-control.component.css +31 -0
  60. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-data-control/ws-data-control.component.html +72 -0
  61. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-data-control/ws-data-control.component.scss +41 -0
  62. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-data-control/ws-data-control.component.spec.ts +205 -0
  63. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-data-control/ws-data-control.component.ts +77 -0
  64. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-messaging/ws-messaging.component.css +11 -0
  65. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-messaging/ws-messaging.component.html +96 -0
  66. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-messaging/ws-messaging.component.spec.ts +31 -0
  67. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-messaging/ws-messaging.component.ts +229 -0
  68. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-notifications/ws-notifications.component.css +30 -0
  69. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-notifications/ws-notifications.component.html +172 -0
  70. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-notifications/ws-notifications.component.spec.ts +31 -0
  71. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-notifications/ws-notifications.component.ts +239 -0
  72. package/src/lib/http-request-services-demo/request-manager-ws-demo/models/oidc-client.model.ts +31 -0
  73. package/src/lib/http-request-services-demo/request-manager-ws-demo/models/user-data.model.ts +32 -0
  74. package/src/lib/http-request-services-demo/request-manager-ws-demo/request-manager-ws-demo.component.css +0 -0
  75. package/src/lib/http-request-services-demo/request-manager-ws-demo/request-manager-ws-demo.component.html +84 -0
  76. package/src/lib/http-request-services-demo/request-manager-ws-demo/request-manager-ws-demo.component.ts +41 -0
  77. package/src/lib/http-request-services-demo/request-manager-ws-demo/services/index.ts +3 -0
  78. package/src/lib/http-request-services-demo/request-manager-ws-demo/services/message-service-demo.service.ts +83 -0
  79. package/src/lib/http-request-services-demo/request-manager-ws-demo/services/notification-service-demo.service.ts +147 -0
  80. package/src/lib/http-request-services-demo/request-manager-ws-demo/services/state-service-demo.service.ts +158 -0
  81. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/download-file/download-file.component.html +53 -0
  82. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/download-file/download-file.component.scss +60 -0
  83. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/download-file/download-file.component.ts +72 -0
  84. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/file-download.module.ts +28 -0
  85. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/file-downloader.component.html +10 -0
  86. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/file-downloader.component.scss +29 -0
  87. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/file-downloader.component.ts +100 -0
  88. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/models/download-labels-model.ts +22 -0
  89. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/spinner/spinner.component.html +8 -0
  90. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/spinner/spinner.component.scss +19 -0
  91. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/spinner/spinner.component.ts +26 -0
  92. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/app-session.model.ts +30 -0
  93. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/app.model.ts +19 -0
  94. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/get-sample.model.ts +25 -0
  95. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/sample-ai-prompt.ts +19 -0
  96. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/sample-client-details.ts +24 -0
  97. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/sample-client-info.ts +30 -0
  98. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/sample-client.model.ts +49 -0
  99. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/sample-mapper-client-info.ts +33 -0
  100. package/src/lib/http-request-services-demo/request-signals-manager-demo/request-signals-manager-demo.component.html +380 -0
  101. package/src/lib/http-request-services-demo/request-signals-manager-demo/request-signals-manager-demo.component.scss +24 -0
  102. package/src/lib/http-request-services-demo/request-signals-manager-demo/request-signals-manager-demo.component.ts +410 -0
  103. package/src/lib/http-request-services-demo/store-state-manager-demo/models/settings.model.ts +28 -0
  104. package/src/lib/http-request-services-demo/store-state-manager-demo/services/settings-state.service.ts +48 -0
  105. package/src/lib/http-request-services-demo/store-state-manager-demo/store-state-manager-demo.component.css +0 -0
  106. package/src/lib/http-request-services-demo/store-state-manager-demo/store-state-manager-demo.component.html +23 -0
  107. package/src/lib/http-request-services-demo/store-state-manager-demo/store-state-manager-demo.component.ts +36 -0
  108. package/src/lib/index.ts +3 -0
  109. package/src/lib/interceptors/credentials.interceptor.ts +16 -0
  110. package/src/lib/interceptors/index.ts +6 -0
  111. package/src/lib/interceptors/models/error-settings.model.ts +22 -0
  112. package/src/lib/interceptors/models/index.ts +2 -0
  113. package/src/lib/interceptors/proxy-debugger.interceptor.ts +46 -0
  114. package/src/lib/interceptors/request-error.interceptor.ts +65 -0
  115. package/src/lib/interceptors/request-header.interceptor.ts +53 -0
  116. package/src/lib/models/config-http-options.model.ts +42 -0
  117. package/src/lib/models/config-local-storage-options.model.ts +27 -0
  118. package/src/lib/models/config-options.model.ts +27 -0
  119. package/src/lib/models/config-token.model.ts +9 -0
  120. package/src/lib/models/data-type.enum.ts +5 -0
  121. package/src/lib/models/database-storage.model.ts +24 -0
  122. package/src/lib/models/index.ts +12 -0
  123. package/src/lib/models/retry-options.model.ts +22 -0
  124. package/src/lib/services/database-manager-service/database.manager.service.ts +262 -0
  125. package/src/lib/services/database-manager-service/db.storage.service.ts +207 -0
  126. package/src/lib/services/database-manager-service/index.ts +4 -0
  127. package/src/lib/services/database-manager-service/models/index.ts +2 -0
  128. package/src/lib/services/database-manager-service/models/table-schema.ts +33 -0
  129. package/src/lib/services/index.ts +12 -0
  130. package/src/lib/services/local-storage-manager-service/index.ts +4 -0
  131. package/src/lib/services/local-storage-manager-service/local-storage-manager.service.spec.ts +71 -0
  132. package/src/lib/services/local-storage-manager-service/local-storage-manager.service.ts +426 -0
  133. package/src/lib/services/local-storage-manager-service/local-storage-signals-manager.service.spec.ts +67 -0
  134. package/src/lib/services/local-storage-manager-service/local-storage-signals-manager.service.ts +345 -0
  135. package/src/lib/services/local-storage-manager-service/models/global-store-options.model.ts +30 -0
  136. package/src/lib/services/local-storage-manager-service/models/index.ts +6 -0
  137. package/src/lib/services/local-storage-manager-service/models/setting-options.model.ts +35 -0
  138. package/src/lib/services/local-storage-manager-service/models/storage-data.model.ts +24 -0
  139. package/src/lib/services/local-storage-manager-service/models/storage-option.model.ts +32 -0
  140. package/src/lib/services/local-storage-manager-service/models/storage-type.enum.ts +5 -0
  141. package/src/lib/services/request-manager-services/README.md +268 -0
  142. package/src/lib/services/request-manager-services/http-manager-signals.service.ts +246 -0
  143. package/src/lib/services/request-manager-services/http-manager.service.spec.ts +232 -0
  144. package/src/lib/services/request-manager-services/http-manager.service.ts +274 -0
  145. package/src/lib/services/request-manager-services/index.ts +8 -0
  146. package/src/lib/services/request-manager-services/request-signals.service.ts +214 -0
  147. package/src/lib/services/request-manager-services/request.service.ts +309 -0
  148. package/src/lib/services/request-manager-services/rxjs-operators/countdown.ts +17 -0
  149. package/src/lib/services/request-manager-services/rxjs-operators/delay-retry.ts +16 -0
  150. package/src/lib/services/request-manager-services/rxjs-operators/index.ts +4 -0
  151. package/src/lib/services/request-manager-services/rxjs-operators/request-polling.ts +35 -0
  152. package/src/lib/services/request-manager-services/rxjs-operators/request-streaming.ts +436 -0
  153. package/src/lib/services/request-manager-state-service/http-manager-state.store.ts +1321 -0
  154. package/src/lib/services/request-manager-state-service/index.ts +3 -0
  155. package/src/lib/services/request-manager-state-service/models/api-request.model.ts +61 -0
  156. package/src/lib/services/request-manager-state-service/models/index.ts +6 -0
  157. package/src/lib/services/request-manager-state-service/models/request-options.model.ts +22 -0
  158. package/src/lib/services/request-manager-state-service/models/stream-type.enum.ts +13 -0
  159. package/src/lib/services/request-manager-state-service/models/ws-options.model.ts +39 -0
  160. package/src/lib/services/store-state-manager-service/index.ts +3 -0
  161. package/src/lib/services/store-state-manager-service/models/index.ts +2 -0
  162. package/src/lib/services/store-state-manager-service/models/state-storage-options.model.ts +24 -0
  163. package/src/lib/services/store-state-manager-service/store-state-manager.service.ts +88 -0
  164. package/src/lib/services/utils/app.service.spec.ts +25 -0
  165. package/src/lib/services/utils/app.service.ts +21 -0
  166. package/src/lib/services/utils/encryption/README.md +79 -0
  167. package/src/lib/services/utils/encryption/asymmetrical-encryption.service.ts +282 -0
  168. package/src/lib/services/utils/encryption/encryption-test.service.ts +39 -0
  169. package/src/lib/services/utils/encryption/index.ts +5 -0
  170. package/src/lib/services/utils/encryption/random.ts +81 -0
  171. package/src/lib/services/utils/encryption/symmetrical-encryption.service.ts +93 -0
  172. package/src/lib/services/utils/headers.service.spec.ts +80 -0
  173. package/src/lib/services/utils/headers.service.ts +18 -0
  174. package/src/lib/services/utils/index.ts +7 -0
  175. package/src/lib/services/utils/object-merger.service.spec.ts +18 -0
  176. package/src/lib/services/utils/object-merger.service.ts +78 -0
  177. package/src/lib/services/utils/path-query.service.spec.ts +117 -0
  178. package/src/lib/services/utils/path-query.service.ts +69 -0
  179. package/src/lib/services/utils/random-color.utils.ts +83 -0
  180. package/src/lib/services/utils/utils.service.spec.ts +165 -0
  181. package/src/lib/services/utils/utils.service.ts +192 -0
  182. package/src/lib/services/ws-manager-service/index.ts +4 -0
  183. package/src/lib/services/ws-manager-service/models/channel-info.model.ts +24 -0
  184. package/src/lib/services/ws-manager-service/models/channel-message-data.model.ts +24 -0
  185. package/src/lib/services/ws-manager-service/models/channel-message.model.ts +24 -0
  186. package/src/lib/services/ws-manager-service/models/communication-type.enum.ts +5 -0
  187. package/src/lib/services/ws-manager-service/models/index.ts +5 -0
  188. package/src/lib/services/ws-manager-service/models/ws-user.model.ts +38 -0
  189. package/src/lib/services/ws-manager-service/services/index.ts +3 -0
  190. package/src/lib/services/ws-manager-service/services/websocket.service.ts +392 -0
  191. package/src/public-api.ts +14 -0
  192. package/tsconfig.lib.json +32 -0
  193. package/tsconfig.lib.prod.json +10 -0
  194. package/tsconfig.spec.json +14 -0
  195. package/fesm2022/http-request-manager.mjs +0 -7634
  196. package/fesm2022/http-request-manager.mjs.map +0 -1
  197. package/http-request-manager-18.7.19.tgz +0 -0
  198. package/types/http-request-manager.d.ts +0 -2278
@@ -0,0 +1,25 @@
1
+ import { App } from "./app.model"
2
+ import { AppSession } from "./app-session.model"
3
+
4
+ export interface GetSampleInterface {
5
+ application: App,
6
+ session: AppSession
7
+ }
8
+
9
+ export class GetSample implements GetSampleInterface {
10
+
11
+ constructor(
12
+ public application = App.adapt(),
13
+ public session = AppSession.adapt(),
14
+ ) {}
15
+
16
+ static adapt(item?: any) {
17
+
18
+ return new GetSample(
19
+ (item?.application) ? App.adapt(item.application) : App.adapt(),
20
+ (item?.session) ? AppSession.adapt(item.session) : AppSession.adapt(),
21
+ )
22
+
23
+ }
24
+
25
+ }
@@ -0,0 +1,19 @@
1
+ export interface AIPromptInterface {
2
+ response: string
3
+ }
4
+
5
+ export class AIPrompt implements AIPromptInterface {
6
+
7
+ constructor(
8
+ public response = '',
9
+ ) {}
10
+
11
+ static adapt(item?: any): AIPrompt {
12
+
13
+ return new AIPrompt(
14
+ item?.response,
15
+ )
16
+
17
+ }
18
+
19
+ }
@@ -0,0 +1,24 @@
1
+ import { App } from "./app.model"
2
+
3
+ export interface ClientDetailsInterface {
4
+ prod: string,
5
+ dev: string,
6
+ }
7
+
8
+ export class ClientDetails implements ClientDetailsInterface {
9
+
10
+ constructor(
11
+ public prod = '',
12
+ public dev = '',
13
+ ) {}
14
+
15
+ static adapt(item?: any): ClientDetails {
16
+
17
+ return new ClientDetails(
18
+ item?.prod,
19
+ item?.dev,
20
+ )
21
+
22
+ }
23
+
24
+ }
@@ -0,0 +1,30 @@
1
+ export interface ClientInfoInterface {
2
+ domain: string
3
+ service: string
4
+ id: number
5
+ name: string
6
+ }
7
+
8
+ export class ClientInfo implements ClientInfoInterface {
9
+
10
+ constructor(
11
+ public domain = '',
12
+ public service = '',
13
+ public id = 0,
14
+ public name = '',
15
+ ) {}
16
+
17
+ static adapt(item?: any): ClientInfo {
18
+
19
+ return new ClientInfo(
20
+ item?.domain,
21
+ item?.service,
22
+ item?.id,
23
+ (item?.first_name || item?.last_name) ? `${item?.first_name} ${item?.last_name}` : '',
24
+ )
25
+
26
+ }
27
+
28
+ }
29
+
30
+
@@ -0,0 +1,49 @@
1
+ export interface ClientDataInterface {
2
+ id: string|number
3
+ name: string
4
+ domain: string
5
+ service: string
6
+ spiffe: string
7
+ secret: string
8
+ created: number
9
+ modified: number
10
+ icon: string
11
+ imageFile: string
12
+ email: string
13
+ }
14
+
15
+ export class ClientData implements ClientDataInterface {
16
+
17
+ constructor(
18
+ public id: string|number = 0,
19
+ public name = '',
20
+ public domain = '',
21
+ public service = '',
22
+ public spiffe = '',
23
+ public secret = '',
24
+ public created = 0,
25
+ public modified = 0,
26
+ public icon = '',
27
+ public imageFile = '',
28
+ public email = '',
29
+ ) {}
30
+
31
+ static adapt(item?: any): ClientData {
32
+
33
+ return new ClientData(
34
+ item?.id,
35
+ item?.name,
36
+ item?.domain,
37
+ item?.service,
38
+ item?.spiffe,
39
+ item?.secret,
40
+ item?.created,
41
+ item?.modified,
42
+ item?.icon,
43
+ item?.imageFile,
44
+ item?.email,
45
+ )
46
+
47
+ }
48
+
49
+ }
@@ -0,0 +1,33 @@
1
+ export interface ClientInfoMapperInterface {
2
+ id: number
3
+ first_name: string
4
+ last_name: string
5
+ email: string
6
+ }
7
+
8
+ export class ClientInfoMapper implements ClientInfoMapperInterface {
9
+
10
+ constructor(
11
+ public id = 0,
12
+ public first_name = '',
13
+ public last_name = '',
14
+ public email = '',
15
+ ) {}
16
+
17
+ static adapt(item?: any): ClientInfoMapper {
18
+
19
+ const first_name = (item?.name) ? item.name.split(' ')[0] : ''
20
+ const last_name = (item?.name) ? item.name.split(' ')[1] : ''
21
+
22
+ return new ClientInfoMapper(
23
+ item?.id,
24
+ first_name,
25
+ last_name,
26
+ item?.email,
27
+ )
28
+
29
+ }
30
+
31
+ }
32
+
33
+
@@ -0,0 +1,392 @@
1
+ <div style="margin: 2rem;">
2
+
3
+ <h2>
4
+ HTTP Request Manager
5
+ </h2>
6
+
7
+ <div [formGroup]="requestForm" style="margin-top: 2rem;">
8
+ <div style="display: flex; gap: .5rem">
9
+ <mat-form-field appearance="outline">
10
+ <mat-label>Adapter (Model)</mat-label>
11
+ <mat-select formControlName="adapter" #adapterSelect>
12
+ <mat-option>None</mat-option>
13
+ @for (adapter of sampleAdaptors; track adapter) {
14
+ <mat-option [value]="adapter.value">
15
+ {{adapter.label}}
16
+ </mat-option>
17
+ }
18
+ </mat-select>
19
+ </mat-form-field>
20
+ <mat-form-field appearance="outline">
21
+ <mat-label>Mapper (Model)</mat-label>
22
+ <mat-select formControlName="mapper" #mapperSelect>
23
+ <mat-option>None</mat-option>
24
+ @for (mapper of sampleMappers; track mapper) {
25
+ <mat-option [value]="mapper.value">
26
+ {{mapper.label}}
27
+ </mat-option>
28
+ }
29
+ </mat-select>
30
+ </mat-form-field>
31
+ </div>
32
+ @if (adapterSelect.value || mapperSelect.value) {
33
+ <div style="display: flex; margin-bottom: 2rem;">
34
+ <div style="flex:1" class="box">
35
+ <h3>Adapter (Incoming)</h3>
36
+ @if (adapterSelect.value) {
37
+ <div>
38
+ {{ props(adapterSelect.value) | json }}
39
+ </div>
40
+ } @else {
41
+ No Transformation
42
+ }
43
+ </div>
44
+ <div style="flex:1" class="box">
45
+ <h3>Mapper (Outgoing)</h3>
46
+ @if (mapperSelect.value) {
47
+ <div>
48
+ {{ props(mapperSelect.value) | json }}
49
+ </div>
50
+ } @else {
51
+ No Transformation
52
+ }
53
+ </div>
54
+ </div>
55
+ }
56
+ <div>
57
+ <mat-form-field appearance="outline">
58
+ <mat-label>RestPath (/ delimited)</mat-label>
59
+ <input matInput placeholder="clients/list" formControlName="path">
60
+ </mat-form-field>
61
+ </div>
62
+ <div>
63
+ <div formArrayName="headers">
64
+ @for (task of headers.controls; track task; let i = $index) {
65
+ <div [formGroupName]="i">
66
+ <div style="display: flex; gap: .5rem">
67
+ <mat-form-field appearance="outline">
68
+ <mat-label>Key</mat-label>
69
+ <input matInput placeholder="authentication" formControlName="key">
70
+ </mat-form-field>
71
+ <mat-form-field appearance="outline" style="flex:1">
72
+ <mat-label>Value</mat-label>
73
+ <input matInput placeholder="sample" formControlName="value">
74
+ </mat-form-field>
75
+ <div style="margin-top: .5rem;">
76
+ <button mat-icon-button (click)="removeHeader(i)">
77
+ <mat-icon>close</mat-icon>
78
+ </button>
79
+ </div>
80
+ </div>
81
+ </div>
82
+ }
83
+ </div>
84
+ <button mat-stroked-button (click)="addHeader()" class="btn">Add Header</button>
85
+ </div>
86
+ <div style="margin-top: 2rem; display: flex; flex-direction:column; gap: 1rem;">
87
+ <div>
88
+ <mat-slide-toggle #failedState>Retry on Failed</mat-slide-toggle>
89
+ @if (failedState.checked) {
90
+ <div style="display: flex; gap: .5rem; margin-top: 1rem;" formGroupName="retry">
91
+ <mat-form-field appearance="outline">
92
+ <mat-label>#of Times</mat-label>
93
+ <input matInput placeholder="3" formControlName="times" value="3">
94
+ </mat-form-field>
95
+ <mat-form-field appearance="outline">
96
+ <mat-label>Delay Until Next</mat-label>
97
+ <input matInput placeholder="3" formControlName="delay" value="3">
98
+ </mat-form-field>
99
+ </div>
100
+ }
101
+ </div>
102
+ <div>
103
+ <mat-slide-toggle #pollingState>Polling</mat-slide-toggle>
104
+ @if (pollingState.checked) {
105
+ <div>
106
+ <mat-form-field appearance="outline" style="margin-top: 1rem">
107
+ <mat-label>#of Seconds</mat-label>
108
+ <input matInput placeholder="3" formControlName="polling" value="3">
109
+ </mat-form-field>
110
+ </div>
111
+ }
112
+ </div>
113
+ </div>
114
+ </div>
115
+
116
+ <div style="margin-bottom: 1rem; margin-top: 2rem;">
117
+ @if ((isPending$ | async)) {
118
+ <mat-progress-bar mode="indeterminate"
119
+ ></mat-progress-bar>
120
+ }
121
+ @if (pollingState.checked && !(isPending$ | async)) {
122
+ <mat-progress-bar mode="determinate"
123
+ [value]="(this.countdown$ | async)"
124
+ ></mat-progress-bar>
125
+ }
126
+ </div>
127
+
128
+ <div style="margin-top: 1rem">
129
+ <mat-divider></mat-divider>
130
+ </div>
131
+
132
+ <div style="margin-top: 2rem">
133
+ <div style="display: flex;">
134
+ <h2 style="flex:1">GET Request</h2>
135
+ <div>
136
+ <button mat-raised-button (click)="onGetRequest()" class="btn">Request</button>
137
+ </div>
138
+ </div>
139
+
140
+ @if ((GET_error$ | async); as get_error) {
141
+ <div style="margin-top: .5rem;">
142
+ <mat-error>{{ get_error }}</mat-error>
143
+ </div>
144
+ }
145
+
146
+ @if ((GET$ | async); as dataRecord) {
147
+ <div style="margin-top: 1rem;">
148
+ <!-- <div [innerHTML]="(GET$ | async) | jsonv"></div> -->
149
+ {{ dataRecord | json }}
150
+ </div>
151
+ }
152
+
153
+ </div>
154
+
155
+ <div style="margin-top: 2rem">
156
+ <mat-divider></mat-divider>
157
+ </div>
158
+
159
+ <div style="margin-top: 2rem">
160
+ <div style="display: flex;">
161
+ <h2 style="flex:1">POST Request</h2>
162
+ <div>
163
+ <button mat-raised-button (click)="onCreateRequest()" class="btn">Request</button>
164
+ </div>
165
+ </div>
166
+
167
+ @if ((POST_error$ | async); as post_error) {
168
+ <div style="margin-top: .5rem;">
169
+ <mat-error>{{ post_error }}</mat-error>
170
+ </div>
171
+ }
172
+
173
+ @if ((POST$ | async); as dataRecord) {
174
+ <div style="margin-top: 1rem;">
175
+ <!-- <div [innerHTML]="(POST$ | async) | jsonv"></div> -->
176
+ {{ dataRecord | json }}
177
+ </div>
178
+ }
179
+
180
+ </div>
181
+
182
+ <div style="margin-top: 2rem">
183
+ <mat-divider></mat-divider>
184
+ </div>
185
+
186
+ <div style="margin-top: 2rem">
187
+ <div style="display: flex;">
188
+ <h2 style="flex:1">PUT Request</h2>
189
+ <div>
190
+ <button mat-raised-button (click)="onUpdateRequest()" class="btn">Request</button>
191
+ </div>
192
+ </div>
193
+
194
+ @if ((PUT_error$ | async); as put_error) {
195
+ <div style="margin-top: .5rem;">
196
+ <mat-error>{{ put_error }}</mat-error>
197
+ </div>
198
+ }
199
+
200
+ <h3>Include Record ID in the RestPath</h3>
201
+
202
+ @if ((PUT$ | async); as dataRecord) {
203
+ <div style="margin-top: 1rem;">
204
+ <!-- <div [innerHTML]="(PUT$ | async) | jsonv"></div> -->
205
+ {{ dataRecord | json }}
206
+ </div>
207
+ }
208
+
209
+ </div>
210
+
211
+ <div style="margin-top: 2rem">
212
+ <mat-divider></mat-divider>
213
+ </div>
214
+
215
+ <div style="margin-top: 2rem">
216
+ <div style="display: flex;">
217
+ <h2 style="flex:1">DELETE Request</h2>
218
+ <div>
219
+ <button mat-raised-button (click)="onDeleteRequest()" class="btn">Request</button>
220
+ </div>
221
+ </div>
222
+
223
+ <h3>Include Record ID in the RestPath</h3>
224
+
225
+ @if ((DELETE_error$ | async); as delete_error) {
226
+ <div style="margin-top: .5rem;">
227
+ <mat-error>{{ delete_error }}</mat-error>
228
+ </div>
229
+ }
230
+
231
+ @if ((DELETE$ | async); as dataRecord) {
232
+ <div style="margin-top: 1rem;">
233
+ <!-- <div [innerHTML]="(DELETE$ | async) | jsonv"></div> -->
234
+ {{ dataRecord | json }}
235
+ </div>
236
+ }
237
+
238
+ </div>
239
+
240
+ <div style="margin-top: 2rem">
241
+ <mat-divider></mat-divider>
242
+ </div>
243
+
244
+ <div style="margin-top: 2rem">
245
+ <div style="display: flex;">
246
+ <h2 style="flex:1">Streaming GET Request</h2>
247
+ <div style="display: flex; gap: 1rem; align-items: center;">
248
+ <div style="display: flex; gap: 1rem; align-items: center;">
249
+ {{ streamType }}
250
+ <button mat-icon-button [matMenuTriggerFor]="menu">
251
+ <mat-icon>data_usage</mat-icon>
252
+ </button>
253
+ </div>
254
+ <mat-menu #menu="matMenu">
255
+ <button mat-menu-item *ngFor="let item of streamTypes" (click)="onStreamType(item.id)">{{ item.value }}</button>
256
+ </mat-menu>
257
+ <button mat-raised-button (click)="onStreamRequest()" class="btn">Request</button>
258
+ </div>
259
+ </div>
260
+
261
+ <!-- <div *ngIf="(STREAM_error$ | async) as stream_error" style="margin-top: .5rem;">
262
+ <mat-error>{{ stream_error }}</mat-error>
263
+ </div> -->
264
+
265
+ <div style="margin-top: 1rem;">
266
+ @if ((STREAM$ | async); as data) {
267
+ <div class="container">
268
+ <table mat-table [dataSource]="data" class="mat-elevation-z8">
269
+
270
+ <!-- Dynamic columns -->
271
+ <ng-container *ngFor="let column of displayedColumns" [matColumnDef]="column">
272
+ <th mat-header-cell *matHeaderCellDef> {{ column | titlecase }} </th>
273
+ <td mat-cell *matCellDef="let element">
274
+ @if (isObject(element[column]); as objValue) {
275
+ <pre style="margin: 0; font-size: 0.8em; white-space: pre-wrap;">{{ objValue | json }}</pre>
276
+ } @else {
277
+ {{ element[column] }}
278
+ }
279
+ </td>
280
+ </ng-container>
281
+
282
+ <tr mat-header-row *matHeaderRowDef="displayedColumns"></tr>
283
+ <tr mat-row *matRowDef="let row; columns: displayedColumns;"></tr>
284
+ </table>
285
+
286
+ <!-- Debug info -->
287
+ <div style="margin-top: 1rem; font-size: 0.8em; color: #666;">
288
+ Columns: {{ displayedColumns.join(', ') }} | Records: {{ data.length }}
289
+ </div>
290
+ </div>
291
+ }
292
+ </div>
293
+
294
+ </div>
295
+
296
+ <div style="margin-top: 2rem">
297
+ <mat-divider></mat-divider>
298
+ </div>
299
+
300
+ <div style="margin-top: 2rem">
301
+ <div style="display: flex;">
302
+ <h2 style="flex:1; padding-top: .5rem;">AI -@if (AIType === 1) {
303
+ <span>STREAMING</span>
304
+ } POST Request</h2>
305
+ <div style="display: flex; gap: 1rem;">
306
+ <button mat-raised-button [matMenuTriggerFor]="menu" style="min-width: 120px;">
307
+ <mat-icon>lan</mat-icon>
308
+ @if (AIType === 0) {
309
+ <span>Server</span>
310
+ } @else {
311
+ Local
312
+ }
313
+ </button>
314
+ <mat-menu #menu="matMenu">
315
+ <button mat-menu-item (click)="onSelectAIType(0)">Server</button>
316
+ <button mat-menu-item (click)="onSelectAIType(1)">Local</button>
317
+ </mat-menu>
318
+ <div>
319
+ <button mat-raised-button (click)="onStreamPostRequest()" class="btn">Ask Me</button>
320
+ </div>
321
+ </div>
322
+ </div>
323
+
324
+ <div style="display: flex;">
325
+ <mat-form-field appearance="outline" style="flex:1">
326
+ <mat-label>Ask me a Question</mat-label>
327
+ <textarea matInput placeholder="Why is the sky blue?" [formControl]="questionControl"></textarea>
328
+ </mat-form-field>
329
+ </div>
330
+
331
+ @if ((STREAM_AI_error$ | async); as stream_error) {
332
+ <div style="margin-top: .5rem;">
333
+ <mat-error>{{ stream_error }}</mat-error>
334
+ </div>
335
+ }
336
+
337
+ @if (AIType === 1) {
338
+ <div style="color: red;">
339
+ You must have Ollama active and the 'phi3:latest' model to use this feature.
340
+ </div>
341
+ } @else {
342
+ <span style="color: gray;">
343
+ Define the RestPath to the API endpoint that will handle the AI request.
344
+ Use: 'ai/chat' for server
345
+ </span>
346
+ }
347
+
348
+ <div>
349
+ @if ((STREAM_AI$ | async); as data) {
350
+ <div style="margin-top: 1rem; font-size: 1.2rem; border-radius: 1rem; border: black 1px solid; padding: 2rem;">
351
+ <p style="margin-bottom: .5rem; white-space:pre-wrap; line-height: 1.6rem;">{{data}}</p>
352
+ </div>
353
+ }
354
+ </div>
355
+
356
+ </div>
357
+
358
+ <div style="margin-top: 1.5rem; margin-bottom: 1rem; line-height: 1.5rem;">
359
+ <mat-divider></mat-divider>
360
+ </div>
361
+
362
+ <div>
363
+ <div style="display: flex;">
364
+ <h2 style="flex:1; margin-bottom: 0; padding-top: .5rem; display: flex;">
365
+ <div>
366
+ Download File
367
+ </div>
368
+ <div style="flex:1; margin-left: 1rem;">
369
+ <mat-slide-toggle #disable>
370
+ @if (disable.checked) {
371
+ <span>
372
+ Enable
373
+ </span>
374
+ } @else {
375
+ Disable
376
+ }
377
+ </mat-slide-toggle>
378
+ </div>
379
+ </h2>
380
+ <div>
381
+ <app-file-downloader
382
+ [disabled]="disable.checked"
383
+ [delayError]="3"
384
+ [apiRequest]="downloadRequest"
385
+ (completed)="onDownloadCompleted()"
386
+ (failed)="onDownloadFailed($event)"
387
+ ></app-file-downloader>
388
+ </div>
389
+ </div>
390
+ </div>
391
+
392
+ </div>
@@ -0,0 +1,24 @@
1
+ .btn {
2
+ min-width: 120px;
3
+ }
4
+
5
+ .mat-mdc-row .mat-mdc-cell {
6
+ border-bottom: 1px solid transparent;
7
+ border-top: 1px solid transparent;
8
+ cursor: pointer;
9
+ }
10
+
11
+ .mat-mdc-row:hover .mat-mdc-cell {
12
+ border-color: currentColor;
13
+ background-color: whitesmoke;
14
+ }
15
+
16
+ .container {
17
+ height: 400px;
18
+ overflow: auto;
19
+ }
20
+
21
+ .box {
22
+ padding: 10px;
23
+ border: 1px solid #ccc;
24
+ }