http-request-manager 18.15.33 → 18.15.34

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 (300) hide show
  1. package/TEST_COVERAGE_SUMMARY.md +458 -0
  2. package/ng-package.json +8 -0
  3. package/package.json +4 -13
  4. package/src/docs/ADVANCED_WEBSOCKET.md +633 -0
  5. package/src/docs/ARCHITECTURE.md +633 -0
  6. package/src/docs/BATCH_REQUEST_README.md +467 -0
  7. package/src/docs/COMPLETE_API_REFERENCE.md +1037 -0
  8. package/src/docs/DATABASE_README.md +1195 -0
  9. package/src/docs/ENCRYPTION_README.md +403 -0
  10. package/src/docs/HTTP_MANAGER_README.md +628 -0
  11. package/src/docs/HTTP_SINGNALS_MANAGER_README.md +654 -0
  12. package/src/docs/HTTP_STATE_MANAGER_README.md +1391 -0
  13. package/src/docs/INTERCEPTOR_README.md +549 -0
  14. package/src/docs/LOCAL_STORAGE_README.md +1056 -0
  15. package/src/docs/LOCAL_STORAGE_SIGNALS_README.md +338 -0
  16. package/src/docs/LOGGER_README.md +310 -0
  17. package/src/docs/MESSAGE_TRACKER_README.md +518 -0
  18. package/src/docs/MESSAGE_TRACKER_SIGNALS_README.md +563 -0
  19. package/src/docs/MODELS_README.md +1264 -0
  20. package/src/docs/SIGNAL_SERVICES_README.md +238 -0
  21. package/src/docs/SQL_DIXIE_README.md +574 -0
  22. package/src/docs/STORE_STATE_MANAGER_README.md +556 -0
  23. package/src/docs/STORE_STATE_SIGNALS_README.md +600 -0
  24. package/src/docs/UPLOAD_REQUEST_README.md +324 -0
  25. package/src/docs/UTILS_README.md +1604 -0
  26. package/src/docs/WEBSOCKET_MESSAGE_SERVICE.md +799 -0
  27. package/src/docs/WEBSOCKET_SIGNALS_README.md +641 -0
  28. package/src/docs/WEBSOCKET_SINGLETON_REFACTORING.md +201 -0
  29. package/src/docs/WS_MANAGER_README.md +613 -0
  30. package/src/lib/http-request-manager.module.ts +147 -0
  31. package/src/lib/http-request-services-demo/database-data-demo/database-data-demo.component.html +116 -0
  32. package/src/lib/http-request-services-demo/database-data-demo/database-data-demo.component.scss +0 -0
  33. package/src/lib/http-request-services-demo/database-data-demo/database-data-demo.component.ts +255 -0
  34. package/src/lib/http-request-services-demo/http-request-services-demo.component.html +123 -0
  35. package/src/lib/http-request-services-demo/http-request-services-demo.component.scss +6 -0
  36. package/src/lib/http-request-services-demo/http-request-services-demo.component.ts +53 -0
  37. package/src/lib/http-request-services-demo/local-storage-demo/local-storage-demo.component.html +195 -0
  38. package/src/lib/http-request-services-demo/local-storage-demo/local-storage-demo.component.scss +17 -0
  39. package/src/lib/http-request-services-demo/local-storage-demo/local-storage-demo.component.ts +208 -0
  40. package/src/lib/http-request-services-demo/local-storage-signals-demo/local-storage-signals-demo.component.html +200 -0
  41. package/src/lib/http-request-services-demo/local-storage-signals-demo/local-storage-signals-demo.component.scss +17 -0
  42. package/src/lib/http-request-services-demo/local-storage-signals-demo/local-storage-signals-demo.component.ts +214 -0
  43. package/src/lib/http-request-services-demo/request-manager-basic-demo/file-downloader/download-file/download-file.component.html +53 -0
  44. package/src/lib/http-request-services-demo/request-manager-basic-demo/file-downloader/download-file/download-file.component.scss +60 -0
  45. package/src/lib/http-request-services-demo/request-manager-basic-demo/file-downloader/download-file/download-file.component.ts +72 -0
  46. package/src/lib/http-request-services-demo/request-manager-basic-demo/file-downloader/file-download.module.ts +28 -0
  47. package/src/lib/http-request-services-demo/request-manager-basic-demo/file-downloader/file-downloader.component.html +10 -0
  48. package/src/lib/http-request-services-demo/request-manager-basic-demo/file-downloader/file-downloader.component.scss +29 -0
  49. package/src/lib/http-request-services-demo/request-manager-basic-demo/file-downloader/file-downloader.component.ts +100 -0
  50. package/src/lib/http-request-services-demo/request-manager-basic-demo/file-downloader/models/download-labels-model.ts +22 -0
  51. package/src/lib/http-request-services-demo/request-manager-basic-demo/file-downloader/spinner/spinner.component.html +8 -0
  52. package/src/lib/http-request-services-demo/request-manager-basic-demo/file-downloader/spinner/spinner.component.scss +19 -0
  53. package/src/lib/http-request-services-demo/request-manager-basic-demo/file-downloader/spinner/spinner.component.ts +26 -0
  54. package/src/lib/http-request-services-demo/request-manager-basic-demo/models/app-session.model.ts +30 -0
  55. package/src/lib/http-request-services-demo/request-manager-basic-demo/models/app.model.ts +19 -0
  56. package/src/lib/http-request-services-demo/request-manager-basic-demo/models/get-sample.model.ts +25 -0
  57. package/src/lib/http-request-services-demo/request-manager-basic-demo/models/sample-ai-prompt.ts +19 -0
  58. package/src/lib/http-request-services-demo/request-manager-basic-demo/models/sample-client-details.ts +24 -0
  59. package/src/lib/http-request-services-demo/request-manager-basic-demo/models/sample-client-info.ts +30 -0
  60. package/src/lib/http-request-services-demo/request-manager-basic-demo/models/sample-client.model.ts +49 -0
  61. package/src/lib/http-request-services-demo/request-manager-basic-demo/models/sample-mapper-client-info.ts +33 -0
  62. package/src/lib/http-request-services-demo/request-manager-basic-demo/request-manager-basic-demo.component.html +279 -0
  63. package/src/lib/http-request-services-demo/request-manager-basic-demo/request-manager-basic-demo.component.scss +24 -0
  64. package/src/lib/http-request-services-demo/request-manager-basic-demo/request-manager-basic-demo.component.ts +461 -0
  65. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/download-file/download-file.component.html +53 -0
  66. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/download-file/download-file.component.scss +60 -0
  67. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/download-file/download-file.component.ts +72 -0
  68. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/file-download.module.ts +28 -0
  69. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/file-downloader.component.html +10 -0
  70. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/file-downloader.component.scss +29 -0
  71. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/file-downloader.component.ts +100 -0
  72. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/models/download-labels-model.ts +22 -0
  73. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/spinner/spinner.component.html +8 -0
  74. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/spinner/spinner.component.scss +19 -0
  75. package/src/lib/http-request-services-demo/request-manager-demo/file-downloader/spinner/spinner.component.ts +26 -0
  76. package/src/lib/http-request-services-demo/request-manager-demo/models/app-session.model.ts +30 -0
  77. package/src/lib/http-request-services-demo/request-manager-demo/models/app.model.ts +19 -0
  78. package/src/lib/http-request-services-demo/request-manager-demo/models/get-sample.model.ts +25 -0
  79. package/src/lib/http-request-services-demo/request-manager-demo/models/sample-ai-prompt.ts +19 -0
  80. package/src/lib/http-request-services-demo/request-manager-demo/models/sample-client-details.ts +24 -0
  81. package/src/lib/http-request-services-demo/request-manager-demo/models/sample-client-info.ts +30 -0
  82. package/src/lib/http-request-services-demo/request-manager-demo/models/sample-client.model.ts +49 -0
  83. package/src/lib/http-request-services-demo/request-manager-demo/models/sample-mapper-client-info.ts +33 -0
  84. package/src/lib/http-request-services-demo/request-manager-demo/request-manager-demo.component.html +622 -0
  85. package/src/lib/http-request-services-demo/request-manager-demo/request-manager-demo.component.scss +106 -0
  86. package/src/lib/http-request-services-demo/request-manager-demo/request-manager-demo.component.ts +687 -0
  87. package/src/lib/http-request-services-demo/request-manager-state-demo/request-manager-state-demo.component.html +418 -0
  88. package/src/lib/http-request-services-demo/request-manager-state-demo/request-manager-state-demo.component.scss +24 -0
  89. package/src/lib/http-request-services-demo/request-manager-state-demo/request-manager-state-demo.component.ts +576 -0
  90. package/src/lib/http-request-services-demo/request-manager-state-demo/services/state-manager-demo.service.ts +89 -0
  91. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/services/state-data-request.service.ts +119 -0
  92. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-ai-messaging/ws-ai-messaging.component.css +0 -0
  93. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-ai-messaging/ws-ai-messaging.component.html +3 -0
  94. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-ai-messaging/ws-ai-messaging.component.ts +16 -0
  95. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-chats/ws-chats.component.css +0 -0
  96. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-chats/ws-chats.component.html +3 -0
  97. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-chats/ws-chats.component.ts +16 -0
  98. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-data-control/ws-data-control.component.css +31 -0
  99. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-data-control/ws-data-control.component.html +94 -0
  100. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-data-control/ws-data-control.component.scss +41 -0
  101. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-data-control/ws-data-control.component.spec.ts +203 -0
  102. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-data-control/ws-data-control.component.ts +144 -0
  103. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-messaging/ws-messaging.component.css +11 -0
  104. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-messaging/ws-messaging.component.html +102 -0
  105. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-messaging/ws-messaging.component.spec.ts +40 -0
  106. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-messaging/ws-messaging.component.ts +230 -0
  107. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-notifications/ws-notifications.component.css +30 -0
  108. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-notifications/ws-notifications.component.html +172 -0
  109. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-notifications/ws-notifications.component.spec.ts +31 -0
  110. package/src/lib/http-request-services-demo/request-manager-ws-demo/components/ws-notifications/ws-notifications.component.ts +239 -0
  111. package/src/lib/http-request-services-demo/request-manager-ws-demo/models/oidc-client.model.ts +31 -0
  112. package/src/lib/http-request-services-demo/request-manager-ws-demo/models/user-data.model.ts +32 -0
  113. package/src/lib/http-request-services-demo/request-manager-ws-demo/request-manager-ws-demo.component.css +0 -0
  114. package/src/lib/http-request-services-demo/request-manager-ws-demo/request-manager-ws-demo.component.html +84 -0
  115. package/src/lib/http-request-services-demo/request-manager-ws-demo/request-manager-ws-demo.component.ts +40 -0
  116. package/src/lib/http-request-services-demo/request-manager-ws-demo/services/index.ts +3 -0
  117. package/src/lib/http-request-services-demo/request-manager-ws-demo/services/jwt-token.service.ts +62 -0
  118. package/src/lib/http-request-services-demo/request-manager-ws-demo/services/message-service-demo.service.ts +83 -0
  119. package/src/lib/http-request-services-demo/request-manager-ws-demo/services/notification-service-demo.service.ts +147 -0
  120. package/src/lib/http-request-services-demo/request-manager-ws-demo/services/state-service-demo.service.ts +168 -0
  121. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/download-file/download-file.component.html +53 -0
  122. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/download-file/download-file.component.scss +60 -0
  123. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/download-file/download-file.component.ts +72 -0
  124. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/file-download.module.ts +28 -0
  125. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/file-downloader.component.html +10 -0
  126. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/file-downloader.component.scss +29 -0
  127. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/file-downloader.component.ts +100 -0
  128. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/models/download-labels-model.ts +22 -0
  129. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/spinner/spinner.component.html +8 -0
  130. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/spinner/spinner.component.scss +19 -0
  131. package/src/lib/http-request-services-demo/request-signals-manager-demo/file-downloader/spinner/spinner.component.ts +26 -0
  132. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/app-session.model.ts +30 -0
  133. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/app.model.ts +19 -0
  134. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/get-sample.model.ts +25 -0
  135. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/sample-ai-prompt.ts +19 -0
  136. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/sample-client-details.ts +24 -0
  137. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/sample-client-info.ts +30 -0
  138. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/sample-client.model.ts +49 -0
  139. package/src/lib/http-request-services-demo/request-signals-manager-demo/models/sample-mapper-client-info.ts +33 -0
  140. package/src/lib/http-request-services-demo/request-signals-manager-demo/request-signals-manager-demo.component.html +380 -0
  141. package/src/lib/http-request-services-demo/request-signals-manager-demo/request-signals-manager-demo.component.scss +24 -0
  142. package/src/lib/http-request-services-demo/request-signals-manager-demo/request-signals-manager-demo.component.ts +410 -0
  143. package/src/lib/http-request-services-demo/store-state-manager-demo/models/settings.model.ts +28 -0
  144. package/src/lib/http-request-services-demo/store-state-manager-demo/services/settings-state.service.ts +49 -0
  145. package/src/lib/http-request-services-demo/store-state-manager-demo/store-state-manager-demo.component.css +0 -0
  146. package/src/lib/http-request-services-demo/store-state-manager-demo/store-state-manager-demo.component.html +23 -0
  147. package/src/lib/http-request-services-demo/store-state-manager-demo/store-state-manager-demo.component.ts +36 -0
  148. package/src/lib/http-request-services-demo/store-state-signals-demo/store-state-signals-demo.component.ts +161 -0
  149. package/src/lib/http-request-services-demo/upload-demo/models/index.ts +1 -0
  150. package/src/lib/http-request-services-demo/upload-demo/models/upload-state.model.ts +30 -0
  151. package/src/lib/http-request-services-demo/upload-demo/upload-demo.component.html +89 -0
  152. package/src/lib/http-request-services-demo/upload-demo/upload-demo.component.scss +160 -0
  153. package/src/lib/http-request-services-demo/upload-demo/upload-demo.component.spec.ts +101 -0
  154. package/src/lib/http-request-services-demo/upload-demo/upload-demo.component.ts +136 -0
  155. package/src/lib/index.ts +3 -0
  156. package/src/lib/interceptors/credentials.interceptor.ts +16 -0
  157. package/src/lib/interceptors/index.ts +6 -0
  158. package/src/lib/interceptors/models/error-settings.model.ts +22 -0
  159. package/src/lib/interceptors/models/index.ts +2 -0
  160. package/src/lib/interceptors/proxy-debugger.interceptor.ts +46 -0
  161. package/src/lib/interceptors/request-error.interceptor.ts +65 -0
  162. package/src/lib/interceptors/request-header.interceptor.ts +56 -0
  163. package/src/lib/message-display/README.md +509 -0
  164. package/src/lib/message-display/index.ts +4 -0
  165. package/src/lib/message-display/models/action.model.ts +27 -0
  166. package/src/lib/message-display/models/communication-message.model.ts +77 -0
  167. package/src/lib/message-display/models/display-config.model.ts +35 -0
  168. package/src/lib/message-display/models/display-rule.interface.ts +28 -0
  169. package/src/lib/message-display/models/display-strategy.interface.ts +8 -0
  170. package/src/lib/message-display/models/index.ts +6 -0
  171. package/src/lib/message-display/models/slide.model.ts +24 -0
  172. package/src/lib/message-display/rules/default-display-rules.ts +35 -0
  173. package/src/lib/message-display/services/message-display-router.service.ts +63 -0
  174. package/src/lib/message-display/strategies/snackbar.strategy.ts +46 -0
  175. package/src/lib/models/batch-options.model.ts +33 -0
  176. package/src/lib/models/batch-progress.model.ts +19 -0
  177. package/src/lib/models/batch-request-state.model.ts +40 -0
  178. package/src/lib/models/batch-result.model.ts +30 -0
  179. package/src/lib/models/config-http-options.model.ts +45 -0
  180. package/src/lib/models/config-local-storage-options.model.ts +27 -0
  181. package/src/lib/models/config-options.model.ts +27 -0
  182. package/src/lib/models/config-token.model.ts +9 -0
  183. package/src/lib/models/data-type.enum.ts +5 -0
  184. package/src/lib/models/database-storage.model.ts +24 -0
  185. package/src/lib/models/index.ts +16 -0
  186. package/src/lib/models/retry-options.model.ts +22 -0
  187. package/src/lib/models/upload-validation-error.model.ts +46 -0
  188. package/src/lib/services/SQL-DixieJS service/dexie-query-executor.ts +246 -0
  189. package/src/lib/services/SQL-DixieJS service/dexie-sql.service.ts +31 -0
  190. package/src/lib/services/SQL-DixieJS service/index.ts +4 -0
  191. package/src/lib/services/SQL-DixieJS service/models/execution-plan.model.ts +52 -0
  192. package/src/lib/services/SQL-DixieJS service/models/index.ts +3 -0
  193. package/src/lib/services/SQL-DixieJS service/models/sql-errors.model.ts +13 -0
  194. package/src/lib/services/SQL-DixieJS service/models/sql-options.model.ts +3 -0
  195. package/src/lib/services/SQL-DixieJS service/query-planner.ts +284 -0
  196. package/src/lib/services/SQL-DixieJS service/schema-validator.ts +217 -0
  197. package/src/lib/services/SQL-DixieJS service/sql-parser.ts +35 -0
  198. package/src/lib/services/database-manager-service/database.manager.service.ts +384 -0
  199. package/src/lib/services/database-manager-service/db.storage.service.ts +240 -0
  200. package/src/lib/services/database-manager-service/index.ts +4 -0
  201. package/src/lib/services/database-manager-service/models/index.ts +2 -0
  202. package/src/lib/services/database-manager-service/models/table-schema.ts +33 -0
  203. package/src/lib/services/index.ts +20 -0
  204. package/src/lib/services/local-storage-manager-service/index.ts +4 -0
  205. package/src/lib/services/local-storage-manager-service/local-storage-manager.service.spec.ts +71 -0
  206. package/src/lib/services/local-storage-manager-service/local-storage-manager.service.ts +567 -0
  207. package/src/lib/services/local-storage-manager-service/local-storage-signals-manager.service.spec.ts +67 -0
  208. package/src/lib/services/local-storage-manager-service/local-storage-signals-manager.service.ts +437 -0
  209. package/src/lib/services/local-storage-manager-service/models/global-store-options.model.ts +30 -0
  210. package/src/lib/services/local-storage-manager-service/models/index.ts +6 -0
  211. package/src/lib/services/local-storage-manager-service/models/setting-options.model.ts +35 -0
  212. package/src/lib/services/local-storage-manager-service/models/storage-data.model.ts +24 -0
  213. package/src/lib/services/local-storage-manager-service/models/storage-option.model.ts +32 -0
  214. package/src/lib/services/local-storage-manager-service/models/storage-type.enum.ts +5 -0
  215. package/src/lib/services/request-manager-services/README.md +282 -0
  216. package/src/lib/services/request-manager-services/http-manager-signals.service.ts +674 -0
  217. package/src/lib/services/request-manager-services/http-manager.service.spec.ts +353 -0
  218. package/src/lib/services/request-manager-services/http-manager.service.ts +727 -0
  219. package/src/lib/services/request-manager-services/index.ts +8 -0
  220. package/src/lib/services/request-manager-services/request-signals.service.ts +372 -0
  221. package/src/lib/services/request-manager-services/request.service.ts +435 -0
  222. package/src/lib/services/request-manager-services/rxjs-operators/countdown.ts +17 -0
  223. package/src/lib/services/request-manager-services/rxjs-operators/delay-retry.ts +16 -0
  224. package/src/lib/services/request-manager-services/rxjs-operators/index.ts +4 -0
  225. package/src/lib/services/request-manager-services/rxjs-operators/request-polling.ts +35 -0
  226. package/src/lib/services/request-manager-services/rxjs-operators/request-streaming.ts +468 -0
  227. package/src/lib/services/request-manager-state-service/http-manager-state.store.spec.ts +665 -0
  228. package/src/lib/services/request-manager-state-service/http-manager-state.store.ts +2395 -0
  229. package/src/lib/services/request-manager-state-service/index.ts +3 -0
  230. package/src/lib/services/request-manager-state-service/models/api-request.model.ts +86 -0
  231. package/src/lib/services/request-manager-state-service/models/index.ts +14 -0
  232. package/src/lib/services/request-manager-state-service/models/operation-result.model.ts +18 -0
  233. package/src/lib/services/request-manager-state-service/models/parsing-result.model.ts +21 -0
  234. package/src/lib/services/request-manager-state-service/models/request-options.model.ts +37 -0
  235. package/src/lib/services/request-manager-state-service/models/stream-config.model.ts +20 -0
  236. package/src/lib/services/request-manager-state-service/models/stream-event-metadata.model.ts +23 -0
  237. package/src/lib/services/request-manager-state-service/models/stream-event.model.ts +23 -0
  238. package/src/lib/services/request-manager-state-service/models/stream-output.model.ts +23 -0
  239. package/src/lib/services/request-manager-state-service/models/stream-progress.model.ts +24 -0
  240. package/src/lib/services/request-manager-state-service/models/stream-type.enum.ts +13 -0
  241. package/src/lib/services/request-manager-state-service/models/ws-options.model.ts +42 -0
  242. package/src/lib/services/store-state-manager-service/index.ts +4 -0
  243. package/src/lib/services/store-state-manager-service/models/index.ts +3 -0
  244. package/src/lib/services/store-state-manager-service/models/state-operation-result.model.ts +30 -0
  245. package/src/lib/services/store-state-manager-service/models/state-storage-options.model.ts +24 -0
  246. package/src/lib/services/store-state-manager-service/store-state-manager-signals.service.ts +169 -0
  247. package/src/lib/services/store-state-manager-service/store-state-manager.service.ts +153 -0
  248. package/src/lib/services/utils/app.service.spec.ts +25 -0
  249. package/src/lib/services/utils/app.service.ts +21 -0
  250. package/src/lib/services/utils/encryption/README.md +79 -0
  251. package/src/lib/services/utils/encryption/asymmetrical-encryption.service.ts +282 -0
  252. package/src/lib/services/utils/encryption/encryption-test.service.ts +39 -0
  253. package/src/lib/services/utils/encryption/index.ts +5 -0
  254. package/src/lib/services/utils/encryption/random.ts +81 -0
  255. package/src/lib/services/utils/encryption/symmetrical-encryption.service.ts +106 -0
  256. package/src/lib/services/utils/headers.service.spec.ts +80 -0
  257. package/src/lib/services/utils/headers.service.ts +18 -0
  258. package/src/lib/services/utils/index.ts +9 -0
  259. package/src/lib/services/utils/logger.service.ts +90 -0
  260. package/src/lib/services/utils/models/index.ts +4 -0
  261. package/src/lib/services/utils/models/normalized-request-options.model.ts +24 -0
  262. package/src/lib/services/utils/models/path-tracker-state.model.ts +20 -0
  263. package/src/lib/services/utils/models/query-params-tracker-options.model.ts +24 -0
  264. package/src/lib/services/utils/models/query-tracker-state.model.ts +23 -0
  265. package/src/lib/services/utils/object-merger.service.spec.ts +18 -0
  266. package/src/lib/services/utils/object-merger.service.ts +78 -0
  267. package/src/lib/services/utils/path-query.service.spec.ts +117 -0
  268. package/src/lib/services/utils/path-query.service.ts +69 -0
  269. package/src/lib/services/utils/query-params-tracker.service.ts +442 -0
  270. package/src/lib/services/utils/random-color.utils.ts +83 -0
  271. package/src/lib/services/utils/utils.service.spec.ts +165 -0
  272. package/src/lib/services/utils/utils.service.ts +192 -0
  273. package/src/lib/services/ws-manager-service/index.ts +13 -0
  274. package/src/lib/services/ws-manager-service/message-tracker-signals.service.ts +147 -0
  275. package/src/lib/services/ws-manager-service/message-tracker.service.ts +477 -0
  276. package/src/lib/services/ws-manager-service/models/channel-info.model.ts +29 -0
  277. package/src/lib/services/ws-manager-service/models/channel-message-data.model.ts +24 -0
  278. package/src/lib/services/ws-manager-service/models/channel-message.model.ts +36 -0
  279. package/src/lib/services/ws-manager-service/models/channel-type.enum.ts +6 -0
  280. package/src/lib/services/ws-manager-service/models/communication-type.enum.ts +5 -0
  281. package/src/lib/services/ws-manager-service/models/index.ts +10 -0
  282. package/src/lib/services/ws-manager-service/models/notification-message.model.ts +29 -0
  283. package/src/lib/services/ws-manager-service/models/public-message.model.ts +18 -0
  284. package/src/lib/services/ws-manager-service/models/state-message.model.ts +18 -0
  285. package/src/lib/services/ws-manager-service/models/ws-user.model.ts +38 -0
  286. package/src/lib/services/ws-manager-service/services/index.ts +4 -0
  287. package/src/lib/services/ws-manager-service/services/websocket-message.service.ts +129 -0
  288. package/src/lib/services/ws-manager-service/services/websocket.service.ts +434 -0
  289. package/src/lib/services/ws-manager-service/websocket-service/index.ts +1 -0
  290. package/src/lib/services/ws-manager-service/websocket-service/websocket-manager.service.ts +716 -0
  291. package/src/lib/services/ws-manager-service/websocket-services-complete.spec.ts +596 -0
  292. package/src/lib/services/ws-manager-service/websocket-signals-manager.service.ts +141 -0
  293. package/src/public-api.ts +19 -0
  294. package/tsconfig.lib.json +34 -0
  295. package/tsconfig.lib.prod.json +10 -0
  296. package/tsconfig.spec.json +14 -0
  297. package/fesm2022/http-request-manager.mjs +0 -13688
  298. package/fesm2022/http-request-manager.mjs.map +0 -1
  299. package/http-request-manager-18.15.33.tgz +0 -0
  300. package/types/http-request-manager.d.ts +0 -3968
@@ -0,0 +1,622 @@
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
+ <!-- Parallel Requests Section -->
302
+ <div>
303
+ <div style="display: flex; align-items: center; gap: 1rem; margin-bottom: 1rem;">
304
+ <h2 style="flex: 1; margin: 0;">Parallel Requests</h2>
305
+ <button
306
+ mat-raised-button
307
+ color="primary"
308
+ (click)="onExecuteParallelBatch()"
309
+ [disabled]="isParallelLoading"
310
+ style="min-width: 200px;">
311
+ <mat-icon>sync</mat-icon>
312
+ <span style="margin-left: 8px;">
313
+ {{ isParallelLoading ? 'Loading...' : 'Fetch 5 Users' }}
314
+ </span>
315
+ </button>
316
+ </div>
317
+
318
+ <!-- Loading Indicator -->
319
+ @if (isParallelLoading) {
320
+ <div style="margin: 1rem 0;">
321
+ <mat-progress-bar mode="indeterminate"></mat-progress-bar>
322
+ <p style="margin-top: 0.5rem; color: #666;">
323
+ Executing parallel requests (concurrency: 3)...
324
+ </p>
325
+ </div>
326
+ }
327
+
328
+ <!-- Results -->
329
+ @if (parallelResults) {
330
+ <div style="margin: 1rem 0;">
331
+ <mat-card appearance="outlined">
332
+ <mat-card-content>
333
+ <div style="display: grid; gap: 0.5rem;">
334
+ @for (result of parallelResults; track $index; let i = $index) {
335
+ <div
336
+ style="padding: 0.75rem; border-radius: 4px; border: 1px solid;
337
+ {{ result ? 'background: #e3f2fd; border-color: #2196f3;' :
338
+ 'background: #ffebee; border-color: #f44336;' }}">
339
+ @if (result) {
340
+ <div style="display: flex; align-items: center; gap: 0.5rem; justify-content: space-between;">
341
+ <div style="display: flex; align-items: center; gap: 0.5rem;">
342
+ <mat-icon style="color: #2196f3; font-size: 18px;">check_circle</mat-icon>
343
+ <strong>User #{{ result.id }}:</strong>
344
+ <span>{{ result.name }}</span>
345
+ </div>
346
+ <span style="color: #2196f3; font-weight: bold;">Complete</span>
347
+ </div>
348
+ } @else {
349
+ <div style="display: flex; align-items: center; gap: 0.5rem; justify-content: space-between;">
350
+ <div style="display: flex; align-items: center; gap: 0.5rem;">
351
+ <mat-icon style="color: #f44336; font-size: 18px;">error</mat-icon>
352
+ <strong>Request {{ i + 1 }}:</strong>
353
+ <span>Failed</span>
354
+ </div>
355
+ <span style="color: #f44336; font-weight: bold;">Error</span>
356
+ </div>
357
+ }
358
+ </div>
359
+ }
360
+ </div>
361
+ </mat-card-content>
362
+ </mat-card>
363
+ </div>
364
+ }
365
+
366
+ <!-- Execution Metrics -->
367
+ @if (parallelExecutionTime !== undefined) {
368
+ <div style="background: #f5f5f5; padding: 1rem; border-radius: 4px; margin: 1rem 0;">
369
+ <div style="display: flex; gap: 2rem;">
370
+ <div>
371
+ <strong>⏱Execution Time:</strong>
372
+ <span style="margin-left: 0.5rem; color: #4caf50;">
373
+ {{ formatTime(parallelExecutionTime) }}
374
+ </span>
375
+ </div>
376
+ <div>
377
+ <strong>Mode:</strong>
378
+ <span style="margin-left: 0.5rem;">Parallel</span>
379
+ </div>
380
+ </div>
381
+ </div>
382
+ }
383
+
384
+ <!-- Error Display -->
385
+ @if (parallelError) {
386
+ <div style="margin-top: 1rem;">
387
+ <mat-error>{{ parallelError }}</mat-error>
388
+ </div>
389
+ }
390
+ </div>
391
+
392
+ <!-- Sequential Requests Section -->
393
+ <div>
394
+ <div style="display: flex; align-items: center; gap: 1rem; margin-bottom: 1rem;">
395
+ <h2 style="flex: 1; margin: 0;">Sequential Requests</h2>
396
+ <button
397
+ mat-raised-button
398
+ color="accent"
399
+ (click)="onExecuteSequentialBatch()"
400
+ [disabled]="isSequentialLoading"
401
+ style="min-width: 200px;">
402
+ <mat-icon>timeline</mat-icon>
403
+ <span style="margin-left: 8px;">
404
+ {{ isSequentialLoading ? 'Loading...' : 'Fetch 5 Todos' }}
405
+ </span>
406
+ </button>
407
+ </div>
408
+
409
+ <!-- Loading Indicator -->
410
+ @if (isSequentialLoading) {
411
+ <div style="margin: 1rem 0;">
412
+ <mat-progress-bar mode="indeterminate"></mat-progress-bar>
413
+ <p style="margin-top: 0.5rem; color: #666;">
414
+ Executing sequential requests (one at a time)...
415
+ </p>
416
+ </div>
417
+ }
418
+
419
+ <!-- Results -->
420
+ @if (sequentialResults) {
421
+ <div style="margin: 1rem 0;">
422
+ <mat-card appearance="outlined">
423
+ <mat-card-content>
424
+ <div style="display: grid; gap: 0.5rem;">
425
+ @for (result of sequentialResults; track $index; let i = $index) {
426
+ <div
427
+ style="padding: 0.75rem; border-radius: 4px; border: 1px solid;
428
+ {{ result ? 'background: #e3f2fd; border-color: #2196f3;' :
429
+ 'background: #ffebee; border-color: #f44336;' }}">
430
+ @if (result) {
431
+ <div style="display: flex; align-items: center; gap: 0.5rem; justify-content: space-between;">
432
+ <div style="display: flex; align-items: center; gap: 0.5rem;">
433
+ <mat-icon style="color: #2196f3; font-size: 18px;">check_circle</mat-icon>
434
+ <strong>Todo #{{ result.id }}:</strong>
435
+ <span style="flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;">
436
+ {{ result.title }}
437
+ </span>
438
+ </div>
439
+ </div>
440
+ } @else {
441
+ <div style="display: flex; align-items: center; gap: 0.5rem; justify-content: space-between;">
442
+ <div style="display: flex; align-items: center; gap: 0.5rem;">
443
+ <mat-icon style="color: #f44336; font-size: 18px;">error</mat-icon>
444
+ <strong>Request {{ i + 1 }}:</strong>
445
+ <span>Failed</span>
446
+ </div>
447
+ <span style="color: #f44336; font-weight: bold;">Error</span>
448
+ </div>
449
+ }
450
+ </div>
451
+ }
452
+ </div>
453
+ </mat-card-content>
454
+ </mat-card>
455
+ </div>
456
+ }
457
+
458
+ <!-- Execution Metrics -->
459
+ @if (sequentialExecutionTime !== undefined) {
460
+ <div style="background: #f5f5f5; padding: 1rem; border-radius: 4px; margin: 1rem 0;">
461
+ <div style="display: flex; gap: 2rem;">
462
+ <div>
463
+ <strong>Execution Time:</strong>
464
+ <span style="margin-left: 0.5rem; color: #4caf50;">
465
+ {{ formatTime(sequentialExecutionTime) }}
466
+ </span>
467
+ </div>
468
+ <div>
469
+ <strong>Mode:</strong>
470
+ <span style="margin-left: 0.5rem;">Sequential</span>
471
+ </div>
472
+ </div>
473
+ </div>
474
+ }
475
+ </div>
476
+
477
+ <!-- Stream Mode Section -->
478
+ <div>
479
+ <div style="display: flex; align-items: center; gap: 1rem; margin-bottom: 1rem;">
480
+ <h2 style="flex: 1; margin: 0;">Stream Mode (Real-time States)</h2>
481
+ <button
482
+ mat-raised-button
483
+ color="primary"
484
+ (click)="onExecuteStreamBatch()"
485
+ [disabled]="isStreamLoading"
486
+ style="min-width: 200px;">
487
+ <mat-icon>auto_awesome</mat-icon>
488
+ <span style="margin-left: 8px;">
489
+ {{ isStreamLoading ? 'Loading...' : 'Fetch 5 Posts' }}
490
+ </span>
491
+ </button>
492
+ </div>
493
+
494
+ <!-- Loading Indicator -->
495
+ @if (isStreamLoading) {
496
+ <div style="margin: 1rem 0;">
497
+ <mat-progress-bar mode="indeterminate"></mat-progress-bar>
498
+ <p style="margin-top: 0.5rem; color: #666;">
499
+ Executing parallel requests with real-time state updates...
500
+ </p>
501
+ </div>
502
+ }
503
+
504
+ <!-- Progress Bar -->
505
+ @if (streamProgress) {
506
+ <div style="background: #f5f5f5; padding: 1rem; border-radius: 4px; margin: 1rem 0;">
507
+ <div style="display: flex; gap: 2rem; margin-bottom: 0.5rem;">
508
+ <div>
509
+ <strong>Execution Time:</strong>
510
+ <span style="margin-left: 0.5rem; color: #4caf50;">
511
+ {{ formatTime(streamExecutionTime || 0) }}
512
+ </span>
513
+ </div>
514
+ <div>
515
+ <strong>Progress:</strong>
516
+ <span style="margin-left: 0.5rem;">
517
+ {{ streamProgress.completed }} / {{ streamProgress.total }} completed
518
+ </span>
519
+ </div>
520
+ <div>
521
+ <strong>Pending:</strong>
522
+ <span style="margin-left: 0.5rem;">
523
+ {{ streamProgress.pending }}
524
+ </span>
525
+ </div>
526
+ <div>
527
+ <strong>Failed:</strong>
528
+ <span style="margin-left: 0.5rem;">
529
+ {{ streamProgress.failed }}
530
+ </span>
531
+ </div>
532
+ </div>
533
+ <mat-progress-bar
534
+ mode="determinate"
535
+ [value]="streamProgress.percent"
536
+ color="accent">
537
+ </mat-progress-bar>
538
+ <p style="margin-top: 0.5rem; text-align: right; color: #666;">
539
+ {{ streamProgress.percent }}%
540
+ </p>
541
+ </div>
542
+ }
543
+
544
+ <!-- Error Display -->
545
+ @if (streamError) {
546
+ <div style="margin-top: 1rem;">
547
+ <mat-error>{{ streamError }}</mat-error>
548
+ </div>
549
+ }
550
+
551
+ <!-- Individual Request States -->
552
+ @if (streamBatchStates.length > 0) {
553
+ <div style="margin-top: 1rem;">
554
+ <mat-card appearance="outlined">
555
+ <mat-card-content>
556
+ <div style="display: grid; gap: 0.5rem;">
557
+ @for (state of filteredStreamStates; track state.index; let i = $index) {
558
+ <div
559
+ style="padding: 0.75rem; border-radius: 4px; border: 1px solid;
560
+ {{ isPendingState(state) ? 'background: #fff3e0; border-color: #ff9800;' :
561
+ isSuccessState(state) ? 'background: #e3f2fd; border-color: #2196f3;' :
562
+ 'background: #ffebee; border-color: #f44336;' }}">
563
+ @if (isPendingState(state)) {
564
+ <div style="display: flex; align-items: center; gap: 0.5rem;">
565
+ <mat-spinner diameter="16" style="margin-right: 0.5rem;"></mat-spinner>
566
+ <strong>Request {{ state.index + 1 }}:</strong>
567
+ <span>Loading...</span>
568
+ </div>
569
+ } @else if (isSuccessState(state)) {
570
+ <div style="display: flex; align-items: center; gap: 0.5rem;">
571
+ <mat-icon style="color: #2196f3; font-size: 18px;">check_circle</mat-icon>
572
+ <strong>Post #{{ state.data.id }}:</strong>
573
+ <span style="flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;">
574
+ {{ state.data.title }}
575
+ </span>
576
+ </div>
577
+ } @else {
578
+ <div style="display: flex; align-items: center; gap: 0.5rem;">
579
+ <mat-icon style="color: #f44336; font-size: 18px;">error</mat-icon>
580
+ <strong>Request {{ state.index + 1 }}:</strong>
581
+ <span>Failed</span>
582
+ <mat-chip style="margin-left: auto; font-size: 0.8em; background: #f44336; color: white;">
583
+ Error
584
+ </mat-chip>
585
+ </div>
586
+ }
587
+ </div>
588
+ }
589
+ </div>
590
+ </mat-card-content>
591
+ </mat-card>
592
+ </div>
593
+ }
594
+ </div>
595
+
596
+ <!-- Comparison Info -->
597
+ <div style="padding: 1rem; background: whitesmoke; border-radius: 4px; border: 1px solid #ccc;">
598
+ <h4 style="margin-top: 0;">Key Differences</h4>
599
+ <div style="display: grid; grid-template-columns: 1fr 1fr; gap: 1rem;">
600
+ <div>
601
+ <strong>Parallel:</strong>
602
+ <ul style="margin: 0.5rem 0 0 1rem; padding: 0;">
603
+ <li>Faster execution (concurrent)</li>
604
+ <li>Multiple requests simultaneously</li>
605
+ <li>Results may complete out of order</li>
606
+ <li>Best for: Independent requests</li>
607
+ </ul>
608
+ </div>
609
+ <div>
610
+ <strong>Sequential:</strong>
611
+ <ul style="margin: 0.5rem 0 0 1rem; padding: 0;">
612
+ <li>Slower execution (one-by-one)</li>
613
+ <li>Requests execute in order</li>
614
+ <li>Results always in request order</li>
615
+ <li>Best for: Dependent requests</li>
616
+ </ul>
617
+ </div>
618
+ </div>
619
+ </div>
620
+ </div>
621
+
622
+ </div>