@cendarsoss/pusher-js 8.4.11

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 (425) hide show
  1. package/.editorconfig +14 -0
  2. package/.github/ISSUE_TEMPLATE.md +11 -0
  3. package/.github/PULL_REQUEST_TEMPLATE.md +14 -0
  4. package/.github/dependabot.yml +14 -0
  5. package/.github/stale.yml +26 -0
  6. package/.github/workflows/release.yml +112 -0
  7. package/.github/workflows/release_pr.yml +43 -0
  8. package/.github/workflows/run-tests.yml +62 -0
  9. package/.gitmodules +3 -0
  10. package/.prettierrc +2 -0
  11. package/CHANGELOG.md +928 -0
  12. package/DELTA_COMPRESSION.md +365 -0
  13. package/DELTA_USAGE.md +179 -0
  14. package/IMPLEMENTATION_SUMMARY.md +261 -0
  15. package/IMPORT_GUIDE.md +638 -0
  16. package/LIBRARY_STRUCTURE_ANALYSIS.md +940 -0
  17. package/LICENCE +19 -0
  18. package/Makefile +14 -0
  19. package/README.md +709 -0
  20. package/TAG_FILTERING_CLIENT.md +471 -0
  21. package/bower.json +19 -0
  22. package/bun.lock +2695 -0
  23. package/dist/node/filter.js +252 -0
  24. package/dist/node/filter.js.map +1 -0
  25. package/dist/node/pusher.js +4434 -0
  26. package/dist/node/pusher.js.map +1 -0
  27. package/dist/web/filter.mjs +252 -0
  28. package/dist/web/filter.mjs.map +1 -0
  29. package/dist/web/pusher.mjs +5889 -0
  30. package/dist/web/pusher.mjs.map +1 -0
  31. package/examples/delta-compression-example.html +372 -0
  32. package/examples/delta-seamless-example.html +185 -0
  33. package/index.d.ts +36 -0
  34. package/integration_tests_server/index.js +176 -0
  35. package/integration_tests_server/package-lock.json +1177 -0
  36. package/integration_tests_server/package.json +15 -0
  37. package/interactive/.env +16 -0
  38. package/interactive/CONFLATION_TEST.md +73 -0
  39. package/interactive/DELTA_COMPRESSION_TESTING.md +262 -0
  40. package/interactive/bun.lock +208 -0
  41. package/interactive/package-lock.json +1075 -0
  42. package/interactive/package.json +32 -0
  43. package/interactive/public/app.js +1363 -0
  44. package/interactive/public/bundle-entry.js +14 -0
  45. package/interactive/public/conflation-test.html +508 -0
  46. package/interactive/public/conflation-test.js +785 -0
  47. package/interactive/public/delta-compression.js +1090 -0
  48. package/interactive/public/dist/bundle.js +5857 -0
  49. package/interactive/public/index.html +392 -0
  50. package/interactive/public/main.js +20 -0
  51. package/interactive/public/style.css +823 -0
  52. package/interactive/server.js +246 -0
  53. package/interactive/test-bundle.html +89 -0
  54. package/interactive/test-delta.js +146 -0
  55. package/node.js +1 -0
  56. package/package.json +94 -0
  57. package/pusher-with-encryption/index.js +1 -0
  58. package/react-native/index.d.ts +29 -0
  59. package/react-native/index.js +1 -0
  60. package/spec/config/jasmine/helpers/reporter.js +14 -0
  61. package/spec/config/jasmine/integration.json +13 -0
  62. package/spec/config/jasmine/unit.json +13 -0
  63. package/spec/config/jasmine/webpack.integration.js +33 -0
  64. package/spec/config/jasmine/webpack.unit.js +30 -0
  65. package/spec/config/karma/available_browsers.json +4957 -0
  66. package/spec/config/karma/config.ci.js +25 -0
  67. package/spec/config/karma/config.common.js +50 -0
  68. package/spec/config/karma/config.integration.js +26 -0
  69. package/spec/config/karma/config.unit.js +10 -0
  70. package/spec/config/karma/config.worker.js +34 -0
  71. package/spec/config/karma/integration.js +24 -0
  72. package/spec/config/karma/unit.js +20 -0
  73. package/spec/javascripts/helpers/mocks.js +274 -0
  74. package/spec/javascripts/helpers/node/integration.js +33 -0
  75. package/spec/javascripts/helpers/node/mock-dom-dependencies.ts +1 -0
  76. package/spec/javascripts/helpers/pusher_integration.js +1 -0
  77. package/spec/javascripts/helpers/pusher_integration_class.ts +12 -0
  78. package/spec/javascripts/helpers/timers/promises.js +9 -0
  79. package/spec/javascripts/helpers/waitsFor.js +37 -0
  80. package/spec/javascripts/helpers/web/integration.js +44 -0
  81. package/spec/javascripts/helpers/worker/mock-dom-dependencies.js +1 -0
  82. package/spec/javascripts/integration/core/cluster_config_spec.js +153 -0
  83. package/spec/javascripts/integration/core/falling_back_spec.js +195 -0
  84. package/spec/javascripts/integration/core/pusher_spec/index.js +68 -0
  85. package/spec/javascripts/integration/core/pusher_spec/test_builder.js +715 -0
  86. package/spec/javascripts/integration/core/timeout_configuration_spec.js +200 -0
  87. package/spec/javascripts/integration/core/transport_lists_spec.js +103 -0
  88. package/spec/javascripts/integration/index.node.js +12 -0
  89. package/spec/javascripts/integration/index.web.js +63 -0
  90. package/spec/javascripts/integration/index.worker.js +13 -0
  91. package/spec/javascripts/integration/web/dom/jsonp_spec.js +97 -0
  92. package/spec/javascripts/integration/web/dom/script_request_spec.js +90 -0
  93. package/spec/javascripts/polyfills/index.js +105 -0
  94. package/spec/javascripts/unit/core/channels/channel_spec.js +355 -0
  95. package/spec/javascripts/unit/core/channels/channels_spec.js +94 -0
  96. package/spec/javascripts/unit/core/channels/encrypted_channel_spec.js +343 -0
  97. package/spec/javascripts/unit/core/channels/presence_channel_spec.js +553 -0
  98. package/spec/javascripts/unit/core/channels/private_channel_spec.js +182 -0
  99. package/spec/javascripts/unit/core/config_spec.js +507 -0
  100. package/spec/javascripts/unit/core/connection/connection_manager_spec.js +656 -0
  101. package/spec/javascripts/unit/core/connection/connection_spec.js +286 -0
  102. package/spec/javascripts/unit/core/connection/handshake_spec.js +160 -0
  103. package/spec/javascripts/unit/core/connection/protocol_spec.js +420 -0
  104. package/spec/javascripts/unit/core/defaults_spec.js +26 -0
  105. package/spec/javascripts/unit/core/events_dispatcher_spec.js +385 -0
  106. package/spec/javascripts/unit/core/http/http_polling_socket_spec.js +60 -0
  107. package/spec/javascripts/unit/core/http/http_request_spec.js +185 -0
  108. package/spec/javascripts/unit/core/http/http_socket_spec.js +370 -0
  109. package/spec/javascripts/unit/core/http/http_streaming_socket_spec.js +56 -0
  110. package/spec/javascripts/unit/core/http/http_xhr_request_spec.js +164 -0
  111. package/spec/javascripts/unit/core/logger_spec.js +133 -0
  112. package/spec/javascripts/unit/core/pusher_spec.js +613 -0
  113. package/spec/javascripts/unit/core/pusher_with_encryption_spec.js +18 -0
  114. package/spec/javascripts/unit/core/strategies/best_connected_ever_strategy_spec.js +104 -0
  115. package/spec/javascripts/unit/core/strategies/delayed_strategy_spec.js +95 -0
  116. package/spec/javascripts/unit/core/strategies/first_connected_strategy_spec.js +68 -0
  117. package/spec/javascripts/unit/core/strategies/if_strategy_spec.js +165 -0
  118. package/spec/javascripts/unit/core/strategies/sequential_strategy_spec.js +213 -0
  119. package/spec/javascripts/unit/core/strategies/transport_strategy_spec.js +250 -0
  120. package/spec/javascripts/unit/core/strategies/websocket_prioritized_cached_strategy_spec.js +400 -0
  121. package/spec/javascripts/unit/core/timeline/timeline_spec.js +153 -0
  122. package/spec/javascripts/unit/core/transports/assistant_to_the_transport_manager_spec.js +223 -0
  123. package/spec/javascripts/unit/core/transports/hosts_and_ports_spec.js +85 -0
  124. package/spec/javascripts/unit/core/transports/transport_connection_spec.js +585 -0
  125. package/spec/javascripts/unit/core/transports/transport_manager_spec.js +64 -0
  126. package/spec/javascripts/unit/core/user_spec.js +303 -0
  127. package/spec/javascripts/unit/core/utils/periodic_timer_spec.js +74 -0
  128. package/spec/javascripts/unit/core/utils/timers_spec.js +157 -0
  129. package/spec/javascripts/unit/core/utils/url_store_spec.js +14 -0
  130. package/spec/javascripts/unit/core/watchlist_spec.js +48 -0
  131. package/spec/javascripts/unit/core_with_runtime/auth/channel_authorizer_spec.js +137 -0
  132. package/spec/javascripts/unit/core_with_runtime/auth/deprecated_channel_authorizer_spec.js +48 -0
  133. package/spec/javascripts/unit/core_with_runtime/auth/user_authorizer_spec.js +128 -0
  134. package/spec/javascripts/unit/core_with_runtime/readme.md +5 -0
  135. package/spec/javascripts/unit/index.node.js +11 -0
  136. package/spec/javascripts/unit/index.web.js +12 -0
  137. package/spec/javascripts/unit/index.worker.js +11 -0
  138. package/spec/javascripts/unit/isomorphic/transports/hosts_and_ports_spec.js +82 -0
  139. package/spec/javascripts/unit/isomorphic/transports/transports_spec.js +202 -0
  140. package/spec/javascripts/unit/node/timeline_sender_spec.js +83 -0
  141. package/spec/javascripts/unit/web/dom/dependency_loader_spec.js +249 -0
  142. package/spec/javascripts/unit/web/dom/jsonp_request_spec.js +130 -0
  143. package/spec/javascripts/unit/web/dom/script_receiver_factory_spec.js +68 -0
  144. package/spec/javascripts/unit/web/http/http_xdomain_request_spec.js +222 -0
  145. package/spec/javascripts/unit/web/pusher_authorizer_spec.js +64 -0
  146. package/spec/javascripts/unit/web/timeline/timeline_sender_spec.js +131 -0
  147. package/spec/javascripts/unit/web/transports/hosts_and_ports_spec.js +127 -0
  148. package/spec/javascripts/unit/web/transports/transports_spec.js +444 -0
  149. package/spec/javascripts/unit/worker/channel_authorizer_spec.js +156 -0
  150. package/spec/javascripts/unit/worker/timeline_sender_spec.js +76 -0
  151. package/src/core/auth/auth_transports.ts +18 -0
  152. package/src/core/auth/channel_authorizer.ts +64 -0
  153. package/src/core/auth/deprecated_channel_authorizer.ts +56 -0
  154. package/src/core/auth/options.ts +76 -0
  155. package/src/core/auth/user_authenticator.ts +62 -0
  156. package/src/core/base64.ts +49 -0
  157. package/src/core/channels/channel.ts +173 -0
  158. package/src/core/channels/channel_table.ts +7 -0
  159. package/src/core/channels/channels.ts +86 -0
  160. package/src/core/channels/encrypted_channel.ts +150 -0
  161. package/src/core/channels/filter.ts +342 -0
  162. package/src/core/channels/members.ts +80 -0
  163. package/src/core/channels/metadata.ts +5 -0
  164. package/src/core/channels/presence_channel.ts +113 -0
  165. package/src/core/channels/private_channel.ts +25 -0
  166. package/src/core/config.ts +189 -0
  167. package/src/core/connection/callbacks.ts +21 -0
  168. package/src/core/connection/connection.ts +160 -0
  169. package/src/core/connection/connection_manager.ts +371 -0
  170. package/src/core/connection/connection_manager_options.ts +14 -0
  171. package/src/core/connection/handshake/handshake_payload.ts +10 -0
  172. package/src/core/connection/handshake/index.ts +90 -0
  173. package/src/core/connection/protocol/action.ts +8 -0
  174. package/src/core/connection/protocol/message-types.ts +11 -0
  175. package/src/core/connection/protocol/protocol.ts +166 -0
  176. package/src/core/defaults.ts +66 -0
  177. package/src/core/delta/channel_state.ts +194 -0
  178. package/src/core/delta/decoders.ts +129 -0
  179. package/src/core/delta/index.ts +10 -0
  180. package/src/core/delta/manager.ts +504 -0
  181. package/src/core/delta/types.ts +60 -0
  182. package/src/core/errors.ts +69 -0
  183. package/src/core/events/callback.ts +6 -0
  184. package/src/core/events/callback_registry.ts +75 -0
  185. package/src/core/events/callback_table.ts +7 -0
  186. package/src/core/events/dispatcher.ts +84 -0
  187. package/src/core/http/ajax.ts +24 -0
  188. package/src/core/http/http_factory.ts +16 -0
  189. package/src/core/http/http_polling_socket.ts +24 -0
  190. package/src/core/http/http_request.ts +81 -0
  191. package/src/core/http/http_socket.ts +220 -0
  192. package/src/core/http/http_streaming_socket.ts +19 -0
  193. package/src/core/http/request_hooks.ts +9 -0
  194. package/src/core/http/socket_hooks.ts +11 -0
  195. package/src/core/http/state.ts +7 -0
  196. package/src/core/http/url_location.ts +6 -0
  197. package/src/core/logger.ts +66 -0
  198. package/src/core/options.ts +61 -0
  199. package/src/core/pusher-licence.js +7 -0
  200. package/src/core/pusher-with-encryption.js +1 -0
  201. package/src/core/pusher-with-encryption.ts +14 -0
  202. package/src/core/pusher.js +10 -0
  203. package/src/core/pusher.ts +412 -0
  204. package/src/core/reachability.ts +7 -0
  205. package/src/core/socket.ts +14 -0
  206. package/src/core/strategies/best_connected_ever_strategy.ts +81 -0
  207. package/src/core/strategies/delayed_strategy.ts +48 -0
  208. package/src/core/strategies/first_connected_strategy.ts +31 -0
  209. package/src/core/strategies/if_strategy.ts +34 -0
  210. package/src/core/strategies/sequential_strategy.ts +129 -0
  211. package/src/core/strategies/strategy.ts +8 -0
  212. package/src/core/strategies/strategy_builder.ts +67 -0
  213. package/src/core/strategies/strategy_options.ts +18 -0
  214. package/src/core/strategies/strategy_runner.ts +6 -0
  215. package/src/core/strategies/transport_strategy.ts +144 -0
  216. package/src/core/strategies/websocket_prioritized_cached_strategy.ts +157 -0
  217. package/src/core/timeline/level.ts +7 -0
  218. package/src/core/timeline/timeline.ts +90 -0
  219. package/src/core/timeline/timeline_sender.ts +33 -0
  220. package/src/core/timeline/timeline_transport.ts +11 -0
  221. package/src/core/transports/assistant_to_the_transport_manager.ts +104 -0
  222. package/src/core/transports/ping_delay_options.ts +7 -0
  223. package/src/core/transports/transport.ts +54 -0
  224. package/src/core/transports/transport_connection.ts +241 -0
  225. package/src/core/transports/transport_connection_options.ts +8 -0
  226. package/src/core/transports/transport_hooks.ts +16 -0
  227. package/src/core/transports/transport_manager.ts +52 -0
  228. package/src/core/transports/transports_table.ts +12 -0
  229. package/src/core/transports/url_scheme.ts +13 -0
  230. package/src/core/transports/url_schemes.ts +47 -0
  231. package/src/core/user.ts +186 -0
  232. package/src/core/util.ts +34 -0
  233. package/src/core/utils/collections.ts +353 -0
  234. package/src/core/utils/factory.ts +79 -0
  235. package/src/core/utils/flat_promise.ts +10 -0
  236. package/src/core/utils/timers/abstract_timer.ts +39 -0
  237. package/src/core/utils/timers/index.ts +39 -0
  238. package/src/core/utils/timers/scheduling.ts +11 -0
  239. package/src/core/utils/timers/timed_callback.ts +5 -0
  240. package/src/core/utils/url_store.ts +48 -0
  241. package/src/core/watchlist.ts +31 -0
  242. package/src/d.ts/constants/index.d.ts +5 -0
  243. package/src/d.ts/faye-websocket/faye-websocket.d.ts +21 -0
  244. package/src/d.ts/global/global.d.ts +1 -0
  245. package/src/d.ts/module/module.d.ts +12 -0
  246. package/src/d.ts/tweetnacl-util/index.d.ts +6 -0
  247. package/src/d.ts/window/events.d.ts +4 -0
  248. package/src/d.ts/window/sockjs.d.ts +3 -0
  249. package/src/d.ts/window/websocket.d.ts +4 -0
  250. package/src/d.ts/window/xmlhttprequest.d.ts +3 -0
  251. package/src/filter.ts +5 -0
  252. package/src/index.ts +8 -0
  253. package/src/runtimes/interface.ts +60 -0
  254. package/src/runtimes/isomorphic/auth/xhr_auth.ts +90 -0
  255. package/src/runtimes/isomorphic/default_strategy.ts +155 -0
  256. package/src/runtimes/isomorphic/http/http.ts +32 -0
  257. package/src/runtimes/isomorphic/http/http_xhr_request.ts +35 -0
  258. package/src/runtimes/isomorphic/runtime.ts +62 -0
  259. package/src/runtimes/isomorphic/timeline/xhr_timeline.ts +50 -0
  260. package/src/runtimes/isomorphic/transports/transport_connection_initializer.ts +19 -0
  261. package/src/runtimes/isomorphic/transports/transports.ts +83 -0
  262. package/src/runtimes/node/net_info.ts +10 -0
  263. package/src/runtimes/node/runtime.ts +68 -0
  264. package/src/runtimes/react-native/net_info.ts +42 -0
  265. package/src/runtimes/react-native/runtime.ts +65 -0
  266. package/src/runtimes/web/auth/jsonp_auth.ts +51 -0
  267. package/src/runtimes/web/browser.ts +24 -0
  268. package/src/runtimes/web/default_strategy.ts +201 -0
  269. package/src/runtimes/web/dom/dependencies.ts +16 -0
  270. package/src/runtimes/web/dom/dependency_loader.ts +93 -0
  271. package/src/runtimes/web/dom/json2.js +486 -0
  272. package/src/runtimes/web/dom/jsonp_request.ts +52 -0
  273. package/src/runtimes/web/dom/script_receiver.ts +8 -0
  274. package/src/runtimes/web/dom/script_receiver_factory.ts +57 -0
  275. package/src/runtimes/web/dom/script_request.ts +85 -0
  276. package/src/runtimes/web/http/http.ts +8 -0
  277. package/src/runtimes/web/http/http_xdomain_request.ts +37 -0
  278. package/src/runtimes/web/net_info.ts +50 -0
  279. package/src/runtimes/web/runtime.ts +174 -0
  280. package/src/runtimes/web/timeline/jsonp_timeline.ts +34 -0
  281. package/src/runtimes/web/transports/transport_connection_initializer.ts +39 -0
  282. package/src/runtimes/web/transports/transports.ts +67 -0
  283. package/src/runtimes/worker/auth/fetch_auth.ts +69 -0
  284. package/src/runtimes/worker/net_info.ts +10 -0
  285. package/src/runtimes/worker/runtime.ts +75 -0
  286. package/src/runtimes/worker/timeline/fetch_timeline.ts +39 -0
  287. package/tsconfig.json +18 -0
  288. package/types/spec/javascripts/helpers/node/mock-dom-dependencies.d.ts +1 -0
  289. package/types/spec/javascripts/helpers/pusher_integration_class.d.ts +4 -0
  290. package/types/src/core/auth/auth_transports.d.ts +9 -0
  291. package/types/src/core/auth/channel_authorizer.d.ts +3 -0
  292. package/types/src/core/auth/deprecated_channel_authorizer.d.ts +18 -0
  293. package/types/src/core/auth/options.d.ts +48 -0
  294. package/types/src/core/auth/user_authenticator.d.ts +3 -0
  295. package/types/src/core/base64.d.ts +1 -0
  296. package/types/src/core/channels/channel.d.ts +25 -0
  297. package/types/src/core/channels/channel_table.d.ts +5 -0
  298. package/types/src/core/channels/channels.d.ts +12 -0
  299. package/types/src/core/channels/encrypted_channel.d.ts +15 -0
  300. package/types/src/core/channels/filter.d.ts +33 -0
  301. package/types/src/core/channels/members.d.ts +14 -0
  302. package/types/src/core/channels/metadata.d.ts +4 -0
  303. package/types/src/core/channels/presence_channel.d.ts +13 -0
  304. package/types/src/core/channels/private_channel.d.ts +5 -0
  305. package/types/src/core/config.d.ts +31 -0
  306. package/types/src/core/connection/callbacks.d.ts +18 -0
  307. package/types/src/core/connection/connection.d.ts +16 -0
  308. package/types/src/core/connection/connection_manager.d.ts +50 -0
  309. package/types/src/core/connection/connection_manager_options.d.ts +11 -0
  310. package/types/src/core/connection/handshake/handshake_payload.d.ts +8 -0
  311. package/types/src/core/connection/handshake/index.d.ts +12 -0
  312. package/types/src/core/connection/protocol/action.d.ts +7 -0
  313. package/types/src/core/connection/protocol/message-types.d.ts +10 -0
  314. package/types/src/core/connection/protocol/protocol.d.ts +10 -0
  315. package/types/src/core/defaults.d.ts +26 -0
  316. package/types/src/core/delta/channel_state.d.ts +23 -0
  317. package/types/src/core/delta/decoders.d.ts +12 -0
  318. package/types/src/core/delta/index.d.ts +4 -0
  319. package/types/src/core/delta/manager.d.ts +27 -0
  320. package/types/src/core/delta/types.d.ts +50 -0
  321. package/types/src/core/errors.d.ts +28 -0
  322. package/types/src/core/events/callback.d.ts +5 -0
  323. package/types/src/core/events/callback_registry.d.ts +11 -0
  324. package/types/src/core/events/callback_table.d.ts +5 -0
  325. package/types/src/core/events/dispatcher.d.ts +14 -0
  326. package/types/src/core/http/ajax.d.ts +16 -0
  327. package/types/src/core/http/http_factory.d.ts +13 -0
  328. package/types/src/core/http/http_polling_socket.d.ts +3 -0
  329. package/types/src/core/http/http_request.d.ts +17 -0
  330. package/types/src/core/http/http_socket.d.ts +32 -0
  331. package/types/src/core/http/http_streaming_socket.d.ts +3 -0
  332. package/types/src/core/http/request_hooks.d.ts +6 -0
  333. package/types/src/core/http/socket_hooks.d.ts +8 -0
  334. package/types/src/core/http/state.d.ts +6 -0
  335. package/types/src/core/http/url_location.d.ts +5 -0
  336. package/types/src/core/logger.d.ts +11 -0
  337. package/types/src/core/options.d.ts +36 -0
  338. package/types/src/core/pusher-with-encryption.d.ts +5 -0
  339. package/types/src/core/pusher.d.ts +56 -0
  340. package/types/src/core/reachability.d.ts +5 -0
  341. package/types/src/core/socket.d.ts +12 -0
  342. package/types/src/core/strategies/best_connected_ever_strategy.d.ts +10 -0
  343. package/types/src/core/strategies/delayed_strategy.d.ts +15 -0
  344. package/types/src/core/strategies/first_connected_strategy.d.ts +8 -0
  345. package/types/src/core/strategies/if_strategy.d.ts +10 -0
  346. package/types/src/core/strategies/sequential_strategy.d.ts +16 -0
  347. package/types/src/core/strategies/strategy.d.ts +6 -0
  348. package/types/src/core/strategies/strategy_builder.d.ts +5 -0
  349. package/types/src/core/strategies/strategy_options.d.ts +16 -0
  350. package/types/src/core/strategies/strategy_runner.d.ts +5 -0
  351. package/types/src/core/strategies/transport_strategy.d.ts +15 -0
  352. package/types/src/core/strategies/websocket_prioritized_cached_strategy.d.ts +20 -0
  353. package/types/src/core/timeline/level.d.ts +6 -0
  354. package/types/src/core/timeline/timeline.d.ts +25 -0
  355. package/types/src/core/timeline/timeline_sender.d.ts +13 -0
  356. package/types/src/core/timeline/timeline_transport.d.ts +6 -0
  357. package/types/src/core/transports/assistant_to_the_transport_manager.d.ts +14 -0
  358. package/types/src/core/transports/ping_delay_options.d.ts +6 -0
  359. package/types/src/core/transports/transport.d.ts +8 -0
  360. package/types/src/core/transports/transport_connection.d.ts +35 -0
  361. package/types/src/core/transports/transport_connection_options.d.ts +6 -0
  362. package/types/src/core/transports/transport_hooks.d.ts +13 -0
  363. package/types/src/core/transports/transport_manager.d.ts +14 -0
  364. package/types/src/core/transports/transports_table.d.ts +10 -0
  365. package/types/src/core/transports/url_scheme.d.ts +11 -0
  366. package/types/src/core/transports/url_schemes.d.ts +4 -0
  367. package/types/src/core/user.d.ts +21 -0
  368. package/types/src/core/util.d.ts +8 -0
  369. package/types/src/core/utils/collections.d.ts +18 -0
  370. package/types/src/core/utils/factory.d.ts +29 -0
  371. package/types/src/core/utils/flat_promise.d.ts +6 -0
  372. package/types/src/core/utils/timers/abstract_timer.d.ts +10 -0
  373. package/types/src/core/utils/timers/index.d.ts +9 -0
  374. package/types/src/core/utils/timers/scheduling.d.ts +8 -0
  375. package/types/src/core/utils/timers/timed_callback.d.ts +4 -0
  376. package/types/src/core/utils/url_store.d.ts +4 -0
  377. package/types/src/core/watchlist.d.ts +8 -0
  378. package/types/src/runtimes/interface.d.ts +43 -0
  379. package/types/src/runtimes/isomorphic/auth/xhr_auth.d.ts +3 -0
  380. package/types/src/runtimes/isomorphic/default_strategy.d.ts +5 -0
  381. package/types/src/runtimes/isomorphic/http/http.d.ts +3 -0
  382. package/types/src/runtimes/isomorphic/http/http_xhr_request.d.ts +3 -0
  383. package/types/src/runtimes/isomorphic/runtime.d.ts +2 -0
  384. package/types/src/runtimes/isomorphic/timeline/xhr_timeline.d.ts +6 -0
  385. package/types/src/runtimes/isomorphic/transports/transport_connection_initializer.d.ts +1 -0
  386. package/types/src/runtimes/isomorphic/transports/transports.d.ts +5 -0
  387. package/types/src/runtimes/node/net_info.d.ts +6 -0
  388. package/types/src/runtimes/node/runtime.d.ts +3 -0
  389. package/types/src/runtimes/react-native/net_info.d.ts +8 -0
  390. package/types/src/runtimes/react-native/runtime.d.ts +3 -0
  391. package/types/src/runtimes/web/auth/jsonp_auth.d.ts +3 -0
  392. package/types/src/runtimes/web/browser.d.ts +19 -0
  393. package/types/src/runtimes/web/default_strategy.d.ts +5 -0
  394. package/types/src/runtimes/web/dom/dependencies.d.ts +4 -0
  395. package/types/src/runtimes/web/dom/dependency_loader.d.ts +10 -0
  396. package/types/src/runtimes/web/dom/jsonp_request.d.ts +10 -0
  397. package/types/src/runtimes/web/dom/script_receiver.d.ts +7 -0
  398. package/types/src/runtimes/web/dom/script_receiver_factory.d.ts +10 -0
  399. package/types/src/runtimes/web/dom/script_request.d.ts +9 -0
  400. package/types/src/runtimes/web/http/http.d.ts +2 -0
  401. package/types/src/runtimes/web/http/http_xdomain_request.d.ts +3 -0
  402. package/types/src/runtimes/web/net_info.d.ts +7 -0
  403. package/types/src/runtimes/web/runtime.d.ts +3 -0
  404. package/types/src/runtimes/web/timeline/jsonp_timeline.d.ts +6 -0
  405. package/types/src/runtimes/web/transports/transport_connection_initializer.d.ts +1 -0
  406. package/types/src/runtimes/web/transports/transports.d.ts +2 -0
  407. package/types/src/runtimes/worker/auth/fetch_auth.d.ts +3 -0
  408. package/types/src/runtimes/worker/net_info.d.ts +6 -0
  409. package/types/src/runtimes/worker/runtime.d.ts +3 -0
  410. package/types/src/runtimes/worker/timeline/fetch_timeline.d.ts +6 -0
  411. package/vite.config.js +52 -0
  412. package/vite.config.node.js +72 -0
  413. package/webpack/config.node.js +26 -0
  414. package/webpack/config.react-native.js +35 -0
  415. package/webpack/config.shared.js +50 -0
  416. package/webpack/config.web.js +36 -0
  417. package/webpack/config.worker.js +42 -0
  418. package/webpack/dev.server.js +17 -0
  419. package/webpack/hosting_config.js +6 -0
  420. package/with-encryption/index.d.ts +29 -0
  421. package/with-encryption/index.js +4 -0
  422. package/worker/index.d.ts +29 -0
  423. package/worker/index.js +1 -0
  424. package/worker/with-encryption/index.d.ts +29 -0
  425. package/worker/with-encryption/index.js +1 -0
@@ -0,0 +1,823 @@
1
+ /* Modern CSS Reset */
2
+ *,
3
+ *::before,
4
+ *::after {
5
+ box-sizing: border-box;
6
+ margin: 0;
7
+ padding: 0;
8
+ }
9
+
10
+ /* CSS Variables for theming */
11
+ :root {
12
+ --primary-color: #3b82f6;
13
+ --primary-dark: #1d4ed8;
14
+ --success-color: #10b981;
15
+ --success-dark: #059669;
16
+ --danger-color: #ef4444;
17
+ --danger-dark: #dc2626;
18
+ --warning-color: #f59e0b;
19
+ --secondary-color: #6b7280;
20
+ --dark-color: #1f2937;
21
+ --light-color: #f8fafc;
22
+ --border-color: #e5e7eb;
23
+ --text-color: #111827;
24
+ --text-muted: #6b7280;
25
+ --bg-color: #f1f5f9;
26
+ --panel-bg: #ffffff;
27
+ --shadow:
28
+ 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
29
+ --shadow-lg:
30
+ 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
31
+ --border-radius: 8px;
32
+ --border-radius-lg: 12px;
33
+ --transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
34
+ }
35
+
36
+ /* Toggle Switch */
37
+ .toggle-switch {
38
+ position: relative;
39
+ display: inline-block;
40
+ width: 44px;
41
+ height: 24px;
42
+ }
43
+
44
+ .toggle-switch input {
45
+ opacity: 0;
46
+ width: 0;
47
+ height: 0;
48
+ }
49
+
50
+ .toggle-slider {
51
+ position: absolute;
52
+ cursor: pointer;
53
+ top: 0;
54
+ left: 0;
55
+ right: 0;
56
+ bottom: 0;
57
+ background-color: var(--secondary-color);
58
+ transition: var(--transition);
59
+ border-radius: 24px;
60
+ }
61
+
62
+ .toggle-slider:before {
63
+ position: absolute;
64
+ content: "";
65
+ height: 18px;
66
+ width: 18px;
67
+ left: 3px;
68
+ bottom: 3px;
69
+ background-color: white;
70
+ transition: var(--transition);
71
+ border-radius: 50%;
72
+ }
73
+
74
+ .toggle-switch input:checked + .toggle-slider {
75
+ background-color: var(--success-color);
76
+ }
77
+
78
+ .toggle-switch input:checked + .toggle-slider:before {
79
+ transform: translateX(20px);
80
+ }
81
+
82
+ .toggle-switch input:disabled + .toggle-slider {
83
+ opacity: 0.5;
84
+ cursor: not-allowed;
85
+ }
86
+
87
+ /* Base styles */
88
+ body {
89
+ font-family:
90
+ -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue",
91
+ Arial, sans-serif;
92
+ background-color: var(--bg-color);
93
+ color: var(--text-color);
94
+ line-height: 1.6;
95
+ overflow-x: hidden;
96
+ }
97
+
98
+ .container {
99
+ max-width: 1400px;
100
+ margin: 0 auto;
101
+ padding: 20px;
102
+ }
103
+
104
+ /* Header */
105
+ .header {
106
+ display: flex;
107
+ justify-content: space-between;
108
+ align-items: center;
109
+ margin-bottom: 30px;
110
+ padding: 20px 0;
111
+ border-bottom: 2px solid var(--border-color);
112
+ }
113
+
114
+ .header h1 {
115
+ font-size: 2rem;
116
+ font-weight: 700;
117
+ color: var(--dark-color);
118
+ display: flex;
119
+ align-items: center;
120
+ gap: 12px;
121
+ }
122
+
123
+ .header h1 i {
124
+ color: var(--primary-color);
125
+ }
126
+
127
+ .connection-indicator {
128
+ display: flex;
129
+ align-items: center;
130
+ gap: 10px;
131
+ font-weight: 600;
132
+ font-size: 1.1rem;
133
+ }
134
+
135
+ .status-dot {
136
+ width: 12px;
137
+ height: 12px;
138
+ border-radius: 50%;
139
+ background-color: var(--danger-color);
140
+ transition: var(--transition);
141
+ }
142
+
143
+ .status-dot.connected {
144
+ background-color: var(--success-color);
145
+ box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.2);
146
+ }
147
+
148
+ .status-dot.connecting {
149
+ background-color: var(--warning-color);
150
+ animation: pulse 2s infinite;
151
+ }
152
+
153
+ @keyframes pulse {
154
+ 0%,
155
+ 100% {
156
+ opacity: 1;
157
+ }
158
+ 50% {
159
+ opacity: 0.5;
160
+ }
161
+ }
162
+
163
+ /* Main Grid Layout */
164
+ .main-grid {
165
+ display: grid;
166
+ grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
167
+ gap: 20px;
168
+ align-items: start;
169
+ }
170
+
171
+ /* Panel styles */
172
+ .panel {
173
+ background: var(--panel-bg);
174
+ border-radius: var(--border-radius-lg);
175
+ box-shadow: var(--shadow);
176
+ overflow: hidden;
177
+ transition: var(--transition);
178
+ border: 1px solid var(--border-color);
179
+ }
180
+
181
+ .panel:hover {
182
+ box-shadow: var(--shadow-lg);
183
+ transform: translateY(-2px);
184
+ }
185
+
186
+ .panel-header {
187
+ background: linear-gradient(
188
+ 135deg,
189
+ var(--primary-color),
190
+ var(--primary-dark)
191
+ );
192
+ color: white;
193
+ padding: 16px 20px;
194
+ display: flex;
195
+ align-items: center;
196
+ justify-content: space-between;
197
+ position: relative;
198
+ overflow: hidden;
199
+ }
200
+
201
+ .panel-header::before {
202
+ content: "";
203
+ position: absolute;
204
+ top: 0;
205
+ left: 0;
206
+ right: 0;
207
+ bottom: 0;
208
+ background: linear-gradient(
209
+ 45deg,
210
+ transparent,
211
+ rgba(255, 255, 255, 0.1),
212
+ transparent
213
+ );
214
+ transform: translateX(-100%);
215
+ transition: transform 0.6s;
216
+ }
217
+
218
+ .panel:hover .panel-header::before {
219
+ transform: translateX(100%);
220
+ }
221
+
222
+ .panel-header h2 {
223
+ font-size: 1.1rem;
224
+ font-weight: 600;
225
+ display: flex;
226
+ align-items: center;
227
+ gap: 8px;
228
+ }
229
+
230
+ .panel-controls {
231
+ display: flex;
232
+ gap: 8px;
233
+ }
234
+
235
+ .channel-count,
236
+ .member-count {
237
+ background: rgba(255, 255, 255, 0.2);
238
+ padding: 4px 8px;
239
+ border-radius: 12px;
240
+ font-size: 0.85rem;
241
+ font-weight: 600;
242
+ }
243
+
244
+ .panel-content {
245
+ padding: 20px;
246
+ }
247
+
248
+ /* Form Elements */
249
+ .input-group {
250
+ display: flex;
251
+ gap: 10px;
252
+ margin-bottom: 15px;
253
+ flex-wrap: wrap;
254
+ }
255
+
256
+ .input,
257
+ .textarea {
258
+ flex: 1;
259
+ padding: 12px 16px;
260
+ border: 2px solid var(--border-color);
261
+ border-radius: var(--border-radius);
262
+ font-size: 14px;
263
+ transition: var(--transition);
264
+ background: white;
265
+ min-width: 0;
266
+ }
267
+
268
+ .input:focus,
269
+ .textarea:focus {
270
+ outline: none;
271
+ border-color: var(--primary-color);
272
+ box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
273
+ }
274
+
275
+ .textarea {
276
+ min-height: 80px;
277
+ resize: vertical;
278
+ font-family: "Monaco", "Menlo", "Ubuntu Mono", monospace;
279
+ width: 100%;
280
+ }
281
+
282
+ /* Buttons */
283
+ .btn {
284
+ display: inline-flex;
285
+ align-items: center;
286
+ gap: 8px;
287
+ padding: 12px 20px;
288
+ border: none;
289
+ border-radius: var(--border-radius);
290
+ font-size: 14px;
291
+ font-weight: 600;
292
+ text-decoration: none;
293
+ cursor: pointer;
294
+ transition: var(--transition);
295
+ white-space: nowrap;
296
+ position: relative;
297
+ overflow: hidden;
298
+ }
299
+
300
+ .btn::before {
301
+ content: "";
302
+ position: absolute;
303
+ top: 0;
304
+ left: -100%;
305
+ width: 100%;
306
+ height: 100%;
307
+ background: linear-gradient(
308
+ 90deg,
309
+ transparent,
310
+ rgba(255, 255, 255, 0.2),
311
+ transparent
312
+ );
313
+ transition: left 0.5s;
314
+ }
315
+
316
+ .btn:hover::before {
317
+ left: 100%;
318
+ }
319
+
320
+ .btn-primary {
321
+ background: var(--primary-color);
322
+ color: white;
323
+ }
324
+
325
+ .btn-primary:hover {
326
+ background: var(--primary-dark);
327
+ transform: translateY(-1px);
328
+ }
329
+
330
+ .btn-success {
331
+ background: var(--success-color);
332
+ color: white;
333
+ }
334
+
335
+ .btn-success:hover {
336
+ background: var(--success-dark);
337
+ transform: translateY(-1px);
338
+ }
339
+
340
+ .btn-danger {
341
+ background: var(--danger-color);
342
+ color: white;
343
+ }
344
+
345
+ .btn-danger:hover {
346
+ background: var(--danger-dark);
347
+ transform: translateY(-1px);
348
+ }
349
+
350
+ .btn-secondary {
351
+ background: var(--secondary-color);
352
+ color: white;
353
+ }
354
+
355
+ .btn-secondary:hover {
356
+ background: #4b5563;
357
+ transform: translateY(-1px);
358
+ }
359
+
360
+ .btn-small {
361
+ padding: 8px 12px;
362
+ font-size: 12px;
363
+ }
364
+
365
+ .btn-outline {
366
+ background: transparent;
367
+ border: 1px solid var(--border-color);
368
+ color: var(--text-color);
369
+ }
370
+
371
+ .btn-outline:hover {
372
+ background: var(--light-color);
373
+ border-color: var(--primary-color);
374
+ }
375
+
376
+ .btn:disabled {
377
+ background: var(--secondary-color);
378
+ color: white;
379
+ cursor: not-allowed;
380
+ opacity: 0.6;
381
+ transform: none !important;
382
+ }
383
+
384
+ .button-group {
385
+ display: flex;
386
+ gap: 10px;
387
+ flex-wrap: wrap;
388
+ }
389
+
390
+ /* Channel suggestions */
391
+ .channel-suggestions {
392
+ margin-bottom: 20px;
393
+ padding: 15px;
394
+ background: var(--light-color);
395
+ border-radius: var(--border-radius);
396
+ border: 1px solid var(--border-color);
397
+ }
398
+
399
+ .suggestion-label {
400
+ font-size: 12px;
401
+ font-weight: 600;
402
+ color: var(--text-muted);
403
+ text-transform: uppercase;
404
+ letter-spacing: 0.5px;
405
+ margin-bottom: 8px;
406
+ display: block;
407
+ }
408
+
409
+ /* Subscribed channels */
410
+ .subscribed-channels {
411
+ display: flex;
412
+ flex-direction: column;
413
+ gap: 10px;
414
+ }
415
+
416
+ .channel-item {
417
+ display: flex;
418
+ justify-content: space-between;
419
+ align-items: center;
420
+ padding: 12px 16px;
421
+ background: var(--light-color);
422
+ border: 1px solid var(--border-color);
423
+ border-radius: var(--border-radius);
424
+ transition: var(--transition);
425
+ }
426
+
427
+ .channel-item:hover {
428
+ background: #e2e8f0;
429
+ border-color: var(--primary-color);
430
+ }
431
+
432
+ .channel-name {
433
+ font-weight: 600;
434
+ color: var(--text-color);
435
+ }
436
+
437
+ .channel-type {
438
+ font-size: 12px;
439
+ padding: 2px 8px;
440
+ border-radius: 12px;
441
+ font-weight: 600;
442
+ text-transform: uppercase;
443
+ }
444
+
445
+ .channel-type.public {
446
+ background: rgba(16, 185, 129, 0.1);
447
+ color: var(--success-color);
448
+ }
449
+
450
+ .channel-type.private {
451
+ background: rgba(59, 130, 246, 0.1);
452
+ color: var(--primary-color);
453
+ }
454
+
455
+ .channel-type.presence {
456
+ background: rgba(245, 158, 11, 0.1);
457
+ color: var(--warning-color);
458
+ }
459
+
460
+ /* Config display */
461
+ .config-display {
462
+ margin-bottom: 20px;
463
+ }
464
+
465
+ .config-display pre {
466
+ background: var(--dark-color);
467
+ color: #e5e7eb;
468
+ padding: 16px;
469
+ border-radius: var(--border-radius);
470
+ font-size: 12px;
471
+ overflow-x: auto;
472
+ border: 1px solid #374151;
473
+ }
474
+
475
+ /* Event filters */
476
+ .event-filters {
477
+ display: flex;
478
+ gap: 8px;
479
+ margin-bottom: 15px;
480
+ flex-wrap: wrap;
481
+ }
482
+
483
+ .filter-btn {
484
+ padding: 6px 12px;
485
+ border: 1px solid var(--border-color);
486
+ background: white;
487
+ border-radius: 20px;
488
+ font-size: 12px;
489
+ font-weight: 600;
490
+ cursor: pointer;
491
+ transition: var(--transition);
492
+ color: var(--text-muted);
493
+ }
494
+
495
+ .filter-btn.active,
496
+ .filter-btn:hover {
497
+ background: var(--primary-color);
498
+ color: white;
499
+ border-color: var(--primary-color);
500
+ }
501
+
502
+ /* Events and Webhooks Lists */
503
+ .events-container,
504
+ .webhooks-container {
505
+ max-height: 400px;
506
+ overflow-y: auto;
507
+ border: 1px solid var(--border-color);
508
+ border-radius: var(--border-radius);
509
+ background: white;
510
+ }
511
+
512
+ .events-list,
513
+ .webhooks-list {
514
+ list-style: none;
515
+ }
516
+
517
+ .event-item,
518
+ .webhook-item {
519
+ padding: 12px 16px;
520
+ border-bottom: 1px solid var(--border-color);
521
+ transition: var(--transition);
522
+ position: relative;
523
+ }
524
+
525
+ .event-item:last-child,
526
+ .webhook-item:last-child {
527
+ border-bottom: none;
528
+ }
529
+
530
+ .event-item:hover,
531
+ .webhook-item:hover {
532
+ background: var(--light-color);
533
+ }
534
+
535
+ .event-header {
536
+ display: flex;
537
+ justify-content: space-between;
538
+ align-items: center;
539
+ margin-bottom: 8px;
540
+ }
541
+
542
+ .event-title {
543
+ font-weight: 600;
544
+ color: var(--text-color);
545
+ }
546
+
547
+ .event-timestamp {
548
+ font-size: 12px;
549
+ color: var(--text-muted);
550
+ }
551
+
552
+ .event-data {
553
+ background: #f8fafc;
554
+ padding: 8px 12px;
555
+ border-radius: 4px;
556
+ font-family: "Monaco", "Menlo", "Ubuntu Mono", monospace;
557
+ font-size: 12px;
558
+ overflow-x: auto;
559
+ border: 1px solid var(--border-color);
560
+ }
561
+
562
+ /* Event type indicators */
563
+ .event-type {
564
+ display: inline-block;
565
+ padding: 2px 8px;
566
+ border-radius: 12px;
567
+ font-size: 11px;
568
+ font-weight: 600;
569
+ text-transform: uppercase;
570
+ margin-right: 8px;
571
+ }
572
+
573
+ .event-type.system {
574
+ background: rgba(107, 114, 128, 0.1);
575
+ color: var(--secondary-color);
576
+ }
577
+
578
+ .event-type.custom {
579
+ background: rgba(59, 130, 246, 0.1);
580
+ color: var(--primary-color);
581
+ }
582
+
583
+ .event-type.client {
584
+ background: rgba(16, 185, 129, 0.1);
585
+ color: var(--success-color);
586
+ }
587
+
588
+ .event-type.error {
589
+ background: rgba(239, 68, 68, 0.1);
590
+ color: var(--danger-color);
591
+ }
592
+
593
+ .event-type.member {
594
+ background: rgba(245, 158, 11, 0.1);
595
+ color: var(--warning-color);
596
+ }
597
+
598
+ /* Presence members */
599
+ .presence-channel {
600
+ margin-bottom: 15px;
601
+ padding: 12px;
602
+ background: var(--light-color);
603
+ border-radius: var(--border-radius);
604
+ font-size: 14px;
605
+ }
606
+
607
+ .presence-members {
608
+ display: flex;
609
+ flex-direction: column;
610
+ gap: 8px;
611
+ }
612
+
613
+ .member-item {
614
+ display: flex;
615
+ align-items: center;
616
+ gap: 12px;
617
+ padding: 12px;
618
+ background: white;
619
+ border: 1px solid var(--border-color);
620
+ border-radius: var(--border-radius);
621
+ transition: var(--transition);
622
+ }
623
+
624
+ .member-item:hover {
625
+ background: var(--light-color);
626
+ border-color: var(--primary-color);
627
+ }
628
+
629
+ .member-avatar {
630
+ width: 32px;
631
+ height: 32px;
632
+ border-radius: 50%;
633
+ object-fit: cover;
634
+ }
635
+
636
+ .member-info {
637
+ flex: 1;
638
+ }
639
+
640
+ .member-name {
641
+ font-weight: 600;
642
+ color: var(--text-color);
643
+ }
644
+
645
+ .member-id {
646
+ font-size: 12px;
647
+ color: var(--text-muted);
648
+ }
649
+
650
+ .member-badge {
651
+ background: var(--primary-color);
652
+ color: white;
653
+ padding: 2px 8px;
654
+ border-radius: 12px;
655
+ font-size: 11px;
656
+ font-weight: 600;
657
+ }
658
+
659
+ /* Statistics */
660
+ .stats-grid {
661
+ display: grid;
662
+ grid-template-columns: repeat(2, 1fr);
663
+ gap: 15px;
664
+ }
665
+
666
+ .stat-item {
667
+ text-align: center;
668
+ padding: 15px;
669
+ background: var(--light-color);
670
+ border-radius: var(--border-radius);
671
+ border: 1px solid var(--border-color);
672
+ transition: var(--transition);
673
+ }
674
+
675
+ .stat-item:hover {
676
+ background: #e2e8f0;
677
+ transform: translateY(-2px);
678
+ }
679
+
680
+ .stat-value {
681
+ font-size: 1.5rem;
682
+ font-weight: 700;
683
+ color: var(--primary-color);
684
+ margin-bottom: 4px;
685
+ }
686
+
687
+ .stat-label {
688
+ font-size: 12px;
689
+ color: var(--text-muted);
690
+ text-transform: uppercase;
691
+ font-weight: 600;
692
+ letter-spacing: 0.5px;
693
+ }
694
+
695
+ /* Notes */
696
+ .note {
697
+ background: rgba(59, 130, 246, 0.05);
698
+ border: 1px solid rgba(59, 130, 246, 0.2);
699
+ border-radius: var(--border-radius);
700
+ padding: 12px;
701
+ font-size: 13px;
702
+ color: var(--primary-dark);
703
+ margin-top: 15px;
704
+ display: flex;
705
+ align-items: center;
706
+ gap: 8px;
707
+ }
708
+
709
+ /* Responsive design */
710
+ @media (max-width: 768px) {
711
+ .container {
712
+ padding: 15px;
713
+ }
714
+
715
+ .header {
716
+ flex-direction: column;
717
+ gap: 15px;
718
+ text-align: center;
719
+ }
720
+
721
+ .header h1 {
722
+ font-size: 1.5rem;
723
+ }
724
+
725
+ .main-grid {
726
+ grid-template-columns: 1fr;
727
+ }
728
+
729
+ .input-group {
730
+ flex-direction: column;
731
+ }
732
+
733
+ .button-group {
734
+ flex-direction: column;
735
+ }
736
+
737
+ .btn {
738
+ justify-content: center;
739
+ }
740
+
741
+ .stats-grid {
742
+ grid-template-columns: 1fr;
743
+ }
744
+ }
745
+
746
+ /* Scrollbar styling */
747
+ .events-container::-webkit-scrollbar,
748
+ .webhooks-container::-webkit-scrollbar {
749
+ width: 6px;
750
+ }
751
+
752
+ .events-container::-webkit-scrollbar-track,
753
+ .webhooks-container::-webkit-scrollbar-track {
754
+ background: var(--light-color);
755
+ }
756
+
757
+ .events-container::-webkit-scrollbar-thumb,
758
+ .webhooks-container::-webkit-scrollbar-thumb {
759
+ background: var(--secondary-color);
760
+ border-radius: 3px;
761
+ }
762
+
763
+ .events-container::-webkit-scrollbar-thumb:hover,
764
+ .webhooks-container::-webkit-scrollbar-thumb:hover {
765
+ background: #4b5563;
766
+ }
767
+
768
+ /* Loading states */
769
+ .loading {
770
+ display: flex;
771
+ align-items: center;
772
+ justify-content: center;
773
+ padding: 40px;
774
+ color: var(--text-muted);
775
+ }
776
+
777
+ .spinner {
778
+ display: inline-block;
779
+ width: 20px;
780
+ height: 20px;
781
+ border: 2px solid var(--border-color);
782
+ border-radius: 50%;
783
+ border-top-color: var(--primary-color);
784
+ animation: spin 1s ease-in-out infinite;
785
+ margin-right: 10px;
786
+ }
787
+
788
+ @keyframes spin {
789
+ to {
790
+ transform: rotate(360deg);
791
+ }
792
+ }
793
+
794
+ /* Animation classes */
795
+ .fade-in {
796
+ animation: fadeIn 0.3s ease-in-out;
797
+ }
798
+
799
+ @keyframes fadeIn {
800
+ from {
801
+ opacity: 0;
802
+ transform: translateY(10px);
803
+ }
804
+ to {
805
+ opacity: 1;
806
+ transform: translateY(0);
807
+ }
808
+ }
809
+
810
+ .slide-up {
811
+ animation: slideUp 0.3s ease-out;
812
+ }
813
+
814
+ @keyframes slideUp {
815
+ from {
816
+ transform: translateY(20px);
817
+ opacity: 0;
818
+ }
819
+ to {
820
+ transform: translateY(0);
821
+ opacity: 1;
822
+ }
823
+ }