@tak-ps/cloudtak 12.54.0 → 12.55.0

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 (456) hide show
  1. package/package.json +7 -3
  2. package/dist/types/src/App.vue.d.ts +0 -5
  3. package/dist/types/src/base/validators.d.ts +0 -9
  4. package/dist/types/src/components/Admin/AdminImports.vue.d.ts +0 -3
  5. package/dist/types/src/components/Admin/AdminLayers.vue.d.ts +0 -3
  6. package/dist/types/src/components/Admin/AdminMissionTemplate.vue.d.ts +0 -3
  7. package/dist/types/src/components/Admin/AdminMissionTemplateLog.vue.d.ts +0 -3
  8. package/dist/types/src/components/Admin/AdminMissionTemplates.vue.d.ts +0 -3
  9. package/dist/types/src/components/Admin/AdminOverlays.vue.d.ts +0 -3
  10. package/dist/types/src/components/Admin/AdminPalette.vue.d.ts +0 -3
  11. package/dist/types/src/components/Admin/AdminPaletteFeature.vue.d.ts +0 -3
  12. package/dist/types/src/components/Admin/AdminPalettes.vue.d.ts +0 -3
  13. package/dist/types/src/components/Admin/AdminServer.vue.d.ts +0 -3
  14. package/dist/types/src/components/Admin/AdminTasks.vue.d.ts +0 -3
  15. package/dist/types/src/components/Admin/AdminUser.vue.d.ts +0 -3
  16. package/dist/types/src/components/Admin/AdminUsers.vue.d.ts +0 -3
  17. package/dist/types/src/components/Admin/AdminVideos.vue.d.ts +0 -3
  18. package/dist/types/src/components/Admin/Server/ServerConnection.vue.d.ts +0 -3
  19. package/dist/types/src/components/Admin/Server/ServerInjectorModal.vue.d.ts +0 -11
  20. package/dist/types/src/components/Admin/Server/ServerInjectors.vue.d.ts +0 -3
  21. package/dist/types/src/components/Admin/Server/ServerPackages.vue.d.ts +0 -3
  22. package/dist/types/src/components/Admin/Server/ServerRepeaters.vue.d.ts +0 -3
  23. package/dist/types/src/components/Admin/Server/ServerVideos.vue.d.ts +0 -3
  24. package/dist/types/src/components/Admin/Tasks/AdminRawTasks.vue.d.ts +0 -3
  25. package/dist/types/src/components/Admin/Videos/AdminVideoLeases.vue.d.ts +0 -3
  26. package/dist/types/src/components/Admin/Videos/AdminVideoService.vue.d.ts +0 -3
  27. package/dist/types/src/components/Admin/Videos/VideoConfig.vue.d.ts +0 -7
  28. package/dist/types/src/components/Admin/Videos/VideoConfigPort.vue.d.ts +0 -8
  29. package/dist/types/src/components/CloudTAK/CoTView.vue.d.ts +0 -3
  30. package/dist/types/src/components/CloudTAK/CoordInput.vue.d.ts +0 -7
  31. package/dist/types/src/components/CloudTAK/DrawTools.vue.d.ts +0 -3
  32. package/dist/types/src/components/CloudTAK/FeatView.vue.d.ts +0 -8
  33. package/dist/types/src/components/CloudTAK/GeoJSONInput.vue.d.ts +0 -24
  34. package/dist/types/src/components/CloudTAK/MainMenu.vue.d.ts +0 -9
  35. package/dist/types/src/components/CloudTAK/MainMenuContents.vue.d.ts +0 -16
  36. package/dist/types/src/components/CloudTAK/Map.vue.d.ts +0 -8
  37. package/dist/types/src/components/CloudTAK/MapLoading.vue.d.ts +0 -3
  38. package/dist/types/src/components/CloudTAK/Menu/Debugger.vue.d.ts +0 -3
  39. package/dist/types/src/components/CloudTAK/Menu/MenuBasemaps.vue.d.ts +0 -3
  40. package/dist/types/src/components/CloudTAK/Menu/MenuChannels.vue.d.ts +0 -3
  41. package/dist/types/src/components/CloudTAK/Menu/MenuChats.vue.d.ts +0 -3
  42. package/dist/types/src/components/CloudTAK/Menu/MenuConnections.vue.d.ts +0 -3
  43. package/dist/types/src/components/CloudTAK/Menu/MenuContacts.vue.d.ts +0 -3
  44. package/dist/types/src/components/CloudTAK/Menu/MenuFeatures.vue.d.ts +0 -3
  45. package/dist/types/src/components/CloudTAK/Menu/MenuFeaturesDeleted.vue.d.ts +0 -3
  46. package/dist/types/src/components/CloudTAK/Menu/MenuFiles.vue.d.ts +0 -3
  47. package/dist/types/src/components/CloudTAK/Menu/MenuImport.vue.d.ts +0 -3
  48. package/dist/types/src/components/CloudTAK/Menu/MenuImports.vue.d.ts +0 -3
  49. package/dist/types/src/components/CloudTAK/Menu/MenuItemCard.vue.d.ts +0 -101
  50. package/dist/types/src/components/CloudTAK/Menu/MenuMission.vue.d.ts +0 -3
  51. package/dist/types/src/components/CloudTAK/Menu/MenuMissions.vue.d.ts +0 -3
  52. package/dist/types/src/components/CloudTAK/Menu/MenuOverlayExplorer.vue.d.ts +0 -3
  53. package/dist/types/src/components/CloudTAK/Menu/MenuOverlays.vue.d.ts +0 -3
  54. package/dist/types/src/components/CloudTAK/Menu/MenuPackage.vue.d.ts +0 -3
  55. package/dist/types/src/components/CloudTAK/Menu/MenuPackages.vue.d.ts +0 -3
  56. package/dist/types/src/components/CloudTAK/Menu/MenuRoutes.vue.d.ts +0 -3
  57. package/dist/types/src/components/CloudTAK/Menu/MenuRoutesNew.vue.d.ts +0 -3
  58. package/dist/types/src/components/CloudTAK/Menu/MenuSettings.vue.d.ts +0 -3
  59. package/dist/types/src/components/CloudTAK/Menu/MenuSettingsCallsign.vue.d.ts +0 -3
  60. package/dist/types/src/components/CloudTAK/Menu/MenuSettingsDisplay.vue.d.ts +0 -3
  61. package/dist/types/src/components/CloudTAK/Menu/MenuVideos.vue.d.ts +0 -3
  62. package/dist/types/src/components/CloudTAK/Menu/MenuVideosRemote.vue.d.ts +0 -3
  63. package/dist/types/src/components/CloudTAK/Menu/Mission/MissionContents.vue.d.ts +0 -11
  64. package/dist/types/src/components/CloudTAK/Menu/Mission/MissionCreate.vue.d.ts +0 -7
  65. package/dist/types/src/components/CloudTAK/Menu/Mission/MissionInfo.vue.d.ts +0 -11
  66. package/dist/types/src/components/CloudTAK/Menu/Mission/MissionInviteModal.vue.d.ts +0 -17
  67. package/dist/types/src/components/CloudTAK/Menu/Mission/MissionLayerCreate.vue.d.ts +0 -13
  68. package/dist/types/src/components/CloudTAK/Menu/Mission/MissionLayerEdit.vue.d.ts +0 -15
  69. package/dist/types/src/components/CloudTAK/Menu/Mission/MissionLayerTree.vue.d.ts +0 -15
  70. package/dist/types/src/components/CloudTAK/Menu/Mission/MissionLayers.vue.d.ts +0 -8
  71. package/dist/types/src/components/CloudTAK/Menu/Mission/MissionLog.vue.d.ts +0 -9
  72. package/dist/types/src/components/CloudTAK/Menu/Mission/MissionLogs.vue.d.ts +0 -7
  73. package/dist/types/src/components/CloudTAK/Menu/Mission/MissionTimeline.vue.d.ts +0 -7
  74. package/dist/types/src/components/CloudTAK/Menu/Mission/MissionUsers.vue.d.ts +0 -7
  75. package/dist/types/src/components/CloudTAK/Menu/Mission/PendingInvites.vue.d.ts +0 -11
  76. package/dist/types/src/components/CloudTAK/Menu/Overlays/TreeMission.vue.d.ts +0 -7
  77. package/dist/types/src/components/CloudTAK/Menu/Overlays/TreeVector.vue.d.ts +0 -13
  78. package/dist/types/src/components/CloudTAK/Menu/Videos/VideoLeaseModal.vue.d.ts +0 -16
  79. package/dist/types/src/components/CloudTAK/Menu/Videos/VideosRemoteFeed.vue.d.ts +0 -13
  80. package/dist/types/src/components/CloudTAK/Notifications.vue.d.ts +0 -3
  81. package/dist/types/src/components/CloudTAK/Query/Magnetic.vue.d.ts +0 -7
  82. package/dist/types/src/components/CloudTAK/Query/Reverse.vue.d.ts +0 -8
  83. package/dist/types/src/components/CloudTAK/Query/Sun.vue.d.ts +0 -7
  84. package/dist/types/src/components/CloudTAK/Query/Weather.vue.d.ts +0 -7
  85. package/dist/types/src/components/CloudTAK/QueryView.vue.d.ts +0 -3
  86. package/dist/types/src/components/CloudTAK/RangeInput.vue.d.ts +0 -7
  87. package/dist/types/src/components/CloudTAK/RangeRingsInput.vue.d.ts +0 -7
  88. package/dist/types/src/components/CloudTAK/util/Breadcrumb.vue.d.ts +0 -6
  89. package/dist/types/src/components/CloudTAK/util/ChannelInfo.vue.d.ts +0 -15
  90. package/dist/types/src/components/CloudTAK/util/ContactPuck.vue.d.ts +0 -7
  91. package/dist/types/src/components/CloudTAK/util/Coordinate.vue.d.ts +0 -67
  92. package/dist/types/src/components/CloudTAK/util/CoordinateType.vue.d.ts +0 -27
  93. package/dist/types/src/components/CloudTAK/util/CopyButton.vue.d.ts +0 -32
  94. package/dist/types/src/components/CloudTAK/util/CopyField.vue.d.ts +0 -122
  95. package/dist/types/src/components/CloudTAK/util/DrawOverlay.vue.d.ts +0 -3
  96. package/dist/types/src/components/CloudTAK/util/EmptyInfo.vue.d.ts +0 -24
  97. package/dist/types/src/components/CloudTAK/util/FeatureIcon.vue.d.ts +0 -23
  98. package/dist/types/src/components/CloudTAK/util/FeatureRow.vue.d.ts +0 -81
  99. package/dist/types/src/components/CloudTAK/util/FloatingAttachment.vue.d.ts +0 -17
  100. package/dist/types/src/components/CloudTAK/util/FloatingVideo.vue.d.ts +0 -27
  101. package/dist/types/src/components/CloudTAK/util/GroupSelect.vue.d.ts +0 -14
  102. package/dist/types/src/components/CloudTAK/util/JSONModal.vue.d.ts +0 -27
  103. package/dist/types/src/components/CloudTAK/util/Keywords.vue.d.ts +0 -6
  104. package/dist/types/src/components/CloudTAK/util/LineLength.vue.d.ts +0 -24
  105. package/dist/types/src/components/CloudTAK/util/MenuTemplate.vue.d.ts +0 -71
  106. package/dist/types/src/components/CloudTAK/util/MultipleSelect.vue.d.ts +0 -7
  107. package/dist/types/src/components/CloudTAK/util/NotificationIcon.vue.d.ts +0 -10
  108. package/dist/types/src/components/CloudTAK/util/NotificationToast.vue.d.ts +0 -13
  109. package/dist/types/src/components/CloudTAK/util/PolygonArea.vue.d.ts +0 -24
  110. package/dist/types/src/components/CloudTAK/util/PropertyBattery.vue.d.ts +0 -13
  111. package/dist/types/src/components/CloudTAK/util/PropertyBearing.vue.d.ts +0 -58
  112. package/dist/types/src/components/CloudTAK/util/PropertyCreator.vue.d.ts +0 -7
  113. package/dist/types/src/components/CloudTAK/util/PropertyDistance.vue.d.ts +0 -54
  114. package/dist/types/src/components/CloudTAK/util/PropertyElevation.vue.d.ts +0 -32
  115. package/dist/types/src/components/CloudTAK/util/PropertyEmail.vue.d.ts +0 -13
  116. package/dist/types/src/components/CloudTAK/util/PropertyLinks.vue.d.ts +0 -14
  117. package/dist/types/src/components/CloudTAK/util/PropertyMetadata.vue.d.ts +0 -7
  118. package/dist/types/src/components/CloudTAK/util/PropertyMilSym.vue.d.ts +0 -25
  119. package/dist/types/src/components/CloudTAK/util/PropertyPhone.vue.d.ts +0 -13
  120. package/dist/types/src/components/CloudTAK/util/PropertySpeed.vue.d.ts +0 -23
  121. package/dist/types/src/components/CloudTAK/util/PropertyStyle.vue.d.ts +0 -7
  122. package/dist/types/src/components/CloudTAK/util/PropertyTimes.vue.d.ts +0 -7
  123. package/dist/types/src/components/CloudTAK/util/PropertyType.vue.d.ts +0 -27
  124. package/dist/types/src/components/CloudTAK/util/SearchBox.vue.d.ts +0 -37
  125. package/dist/types/src/components/CloudTAK/util/SelectFeats.vue.d.ts +0 -7
  126. package/dist/types/src/components/CloudTAK/util/SettingsCallsign.vue.d.ts +0 -28
  127. package/dist/types/src/components/CloudTAK/util/Share.vue.d.ts +0 -14
  128. package/dist/types/src/components/CloudTAK/util/ShareToMission.vue.d.ts +0 -53
  129. package/dist/types/src/components/CloudTAK/util/ShareToPackage.vue.d.ts +0 -62
  130. package/dist/types/src/components/CloudTAK/util/SlideDownHeader.vue.d.ts +0 -41
  131. package/dist/types/src/components/CloudTAK/util/StandardItem.vue.d.ts +0 -18
  132. package/dist/types/src/components/CloudTAK/util/Subscriptions.vue.d.ts +0 -7
  133. package/dist/types/src/components/CloudTAK/util/VideoLeaseSourceType.vue.d.ts +0 -6
  134. package/dist/types/src/components/CloudTAK/util/WarnChannels.vue.d.ts +0 -7
  135. package/dist/types/src/components/CloudTAK/util/WarnConfiguration.vue.d.ts +0 -7
  136. package/dist/types/src/components/Configure.vue.d.ts +0 -3
  137. package/dist/types/src/components/ETL/Connection/AgencyBadge.vue.d.ts +0 -8
  138. package/dist/types/src/components/ETL/Connection/ConnectionFiles.vue.d.ts +0 -3
  139. package/dist/types/src/components/ETL/Connection/ConnectionTokens.vue.d.ts +0 -3
  140. package/dist/types/src/components/ETL/Connection/ConnectionVideos.vue.d.ts +0 -3
  141. package/dist/types/src/components/ETL/Connection/StatusDot.vue.d.ts +0 -13
  142. package/dist/types/src/components/ETL/Connection/TokenModal.vue.d.ts +0 -16
  143. package/dist/types/src/components/ETL/Connection.vue.d.ts +0 -3
  144. package/dist/types/src/components/ETL/ConnectionCard.vue.d.ts +0 -16
  145. package/dist/types/src/components/ETL/Connections.vue.d.ts +0 -3
  146. package/dist/types/src/components/ETL/Data.vue.d.ts +0 -3
  147. package/dist/types/src/components/ETL/Layer/LayerIncomingConfig.vue.d.ts +0 -27
  148. package/dist/types/src/components/ETL/Layer/LayerOutgoingConfig.vue.d.ts +0 -27
  149. package/dist/types/src/components/ETL/Layer/utils/QueryInput.vue.d.ts +0 -56
  150. package/dist/types/src/components/ETL/Layer/utils/StatusDot.vue.d.ts +0 -7
  151. package/dist/types/src/components/ETL/Layer.vue.d.ts +0 -3
  152. package/dist/types/src/components/Home.vue.d.ts +0 -13
  153. package/dist/types/src/components/Loading.vue.d.ts +0 -3
  154. package/dist/types/src/components/Login.vue.d.ts +0 -7
  155. package/dist/types/src/components/LostUser.vue.d.ts +0 -3
  156. package/dist/types/src/components/PageFooter.vue.d.ts +0 -3
  157. package/dist/types/src/components/ServerAdmin.vue.d.ts +0 -3
  158. package/dist/types/src/components/VideoWall/Main.vue.d.ts +0 -3
  159. package/dist/types/src/components/VideoWall.vue.d.ts +0 -13
  160. package/dist/types/src/components/util/GroupSelect.vue.d.ts +0 -14
  161. package/dist/types/src/components/util/InitialAuthor.vue.d.ts +0 -6
  162. package/dist/types/src/components/util/StatusDot.vue.d.ts +0 -8
  163. package/dist/types/src/components/util/Upload.vue.d.ts +0 -46
  164. package/dist/types/src/components/util/UploadLogo.vue.d.ts +0 -14
  165. package/dist/types/src/main.d.ts +0 -1
  166. package/dist/types/src/pages/admin/main.d.ts +0 -1
  167. package/dist/types/src/pages/connection/main.d.ts +0 -1
  168. package/dist/types/src/pages/docs/App.vue.d.ts +0 -4
  169. package/dist/types/src/pages/docs/main.d.ts +0 -1
  170. package/dist/types/src/pages/video/main.d.ts +0 -1
  171. package/dist/types/src/stores/brand.d.ts +0 -7
  172. package/dist/types/src/stores/float.d.ts +0 -42
  173. package/dist/types/src/test/setup.d.ts +0 -1
  174. package/dist/types/src/timediff.d.ts +0 -1
  175. package/dist/types/src/video.d.ts +0 -1
  176. package/src/App.vue +0 -341
  177. package/src/base/chatroom-chats.ts +0 -124
  178. package/src/base/chatroom.ts +0 -202
  179. package/src/base/cot.ts +0 -625
  180. package/src/base/database.ts +0 -150
  181. package/src/base/events.ts +0 -43
  182. package/src/base/filter.ts +0 -163
  183. package/src/base/handler.ts +0 -67
  184. package/src/base/icon.ts +0 -16
  185. package/src/base/notification.ts +0 -163
  186. package/src/base/overlay.ts +0 -558
  187. package/src/base/subscription-feature.ts +0 -224
  188. package/src/base/subscription-log.ts +0 -174
  189. package/src/base/subscription.ts +0 -489
  190. package/src/base/utils/styles.ts +0 -430
  191. package/src/base/validators.ts +0 -66
  192. package/src/components/Admin/AdminConfig.vue +0 -487
  193. package/src/components/Admin/AdminConnections.vue +0 -195
  194. package/src/components/Admin/AdminDatas.vue +0 -165
  195. package/src/components/Admin/AdminExport.vue +0 -121
  196. package/src/components/Admin/AdminImports.vue +0 -222
  197. package/src/components/Admin/AdminLayerTemplate.vue +0 -91
  198. package/src/components/Admin/AdminLayers.vue +0 -301
  199. package/src/components/Admin/AdminMissionTemplate.vue +0 -259
  200. package/src/components/Admin/AdminMissionTemplateLog.vue +0 -273
  201. package/src/components/Admin/AdminMissionTemplates.vue +0 -189
  202. package/src/components/Admin/AdminOverlays.vue +0 -232
  203. package/src/components/Admin/AdminOverlaysEdit.vue +0 -355
  204. package/src/components/Admin/AdminPalette.vue +0 -214
  205. package/src/components/Admin/AdminPaletteFeature.vue +0 -208
  206. package/src/components/Admin/AdminPalettes.vue +0 -189
  207. package/src/components/Admin/AdminServer.vue +0 -143
  208. package/src/components/Admin/AdminTasks.vue +0 -60
  209. package/src/components/Admin/AdminUser.vue +0 -263
  210. package/src/components/Admin/AdminUsers.vue +0 -183
  211. package/src/components/Admin/AdminVideos.vue +0 -60
  212. package/src/components/Admin/Server/ServerConnection.vue +0 -322
  213. package/src/components/Admin/Server/ServerInjectorModal.vue +0 -125
  214. package/src/components/Admin/Server/ServerInjectors.vue +0 -104
  215. package/src/components/Admin/Server/ServerPackages.vue +0 -159
  216. package/src/components/Admin/Server/ServerRepeaters.vue +0 -105
  217. package/src/components/Admin/Server/ServerVideos.vue +0 -83
  218. package/src/components/Admin/Tasks/AdminRawTasks.vue +0 -148
  219. package/src/components/Admin/Tasks/AdminTasks.vue +0 -286
  220. package/src/components/Admin/Videos/AdminVideoLeases.vue +0 -198
  221. package/src/components/Admin/Videos/AdminVideoService.vue +0 -67
  222. package/src/components/Admin/Videos/VideoConfig.vue +0 -132
  223. package/src/components/Admin/Videos/VideoConfigPath.vue +0 -58
  224. package/src/components/Admin/Videos/VideoConfigPort.vue +0 -40
  225. package/src/components/CloudTAK/CoTView.vue +0 -915
  226. package/src/components/CloudTAK/CoordInput.vue +0 -110
  227. package/src/components/CloudTAK/DrawTools.vue +0 -200
  228. package/src/components/CloudTAK/FeatView.vue +0 -242
  229. package/src/components/CloudTAK/GeoJSONInput.vue +0 -226
  230. package/src/components/CloudTAK/MainMenu.vue +0 -190
  231. package/src/components/CloudTAK/MainMenuContents.vue +0 -360
  232. package/src/components/CloudTAK/Map.vue +0 -972
  233. package/src/components/CloudTAK/MapLoading.vue +0 -31
  234. package/src/components/CloudTAK/Menu/Basemaps/EditModal.vue +0 -427
  235. package/src/components/CloudTAK/Menu/Debugger.vue +0 -118
  236. package/src/components/CloudTAK/Menu/Iconset/EditModal.vue +0 -118
  237. package/src/components/CloudTAK/Menu/MenuBasemaps.vue +0 -410
  238. package/src/components/CloudTAK/Menu/MenuChannels.vue +0 -206
  239. package/src/components/CloudTAK/Menu/MenuChat.vue +0 -222
  240. package/src/components/CloudTAK/Menu/MenuChats.vue +0 -167
  241. package/src/components/CloudTAK/Menu/MenuConnections.vue +0 -166
  242. package/src/components/CloudTAK/Menu/MenuContacts.vue +0 -245
  243. package/src/components/CloudTAK/Menu/MenuFeatures.vue +0 -718
  244. package/src/components/CloudTAK/Menu/MenuFeaturesDeleted.vue +0 -217
  245. package/src/components/CloudTAK/Menu/MenuFiles.vue +0 -433
  246. package/src/components/CloudTAK/Menu/MenuIcon.vue +0 -236
  247. package/src/components/CloudTAK/Menu/MenuIconset.vue +0 -128
  248. package/src/components/CloudTAK/Menu/MenuIconsets.vue +0 -266
  249. package/src/components/CloudTAK/Menu/MenuImport.vue +0 -198
  250. package/src/components/CloudTAK/Menu/MenuImports.vue +0 -199
  251. package/src/components/CloudTAK/Menu/MenuItemCard.vue +0 -240
  252. package/src/components/CloudTAK/Menu/MenuMission.vue +0 -324
  253. package/src/components/CloudTAK/Menu/MenuMissions.vue +0 -334
  254. package/src/components/CloudTAK/Menu/MenuOverlayExplorer.vue +0 -434
  255. package/src/components/CloudTAK/Menu/MenuOverlays.vue +0 -560
  256. package/src/components/CloudTAK/Menu/MenuPackage.vue +0 -340
  257. package/src/components/CloudTAK/Menu/MenuPackages.vue +0 -193
  258. package/src/components/CloudTAK/Menu/MenuRoutes.vue +0 -186
  259. package/src/components/CloudTAK/Menu/MenuRoutesNew.vue +0 -193
  260. package/src/components/CloudTAK/Menu/MenuSettings.vue +0 -95
  261. package/src/components/CloudTAK/Menu/MenuSettingsCallsign.vue +0 -12
  262. package/src/components/CloudTAK/Menu/MenuSettingsDisplay.vue +0 -144
  263. package/src/components/CloudTAK/Menu/MenuSettingsTokens.vue +0 -83
  264. package/src/components/CloudTAK/Menu/MenuVideos.vue +0 -436
  265. package/src/components/CloudTAK/Menu/MenuVideosRemote.vue +0 -203
  266. package/src/components/CloudTAK/Menu/Mission/MissionContents.vue +0 -211
  267. package/src/components/CloudTAK/Menu/Mission/MissionCreate.vue +0 -372
  268. package/src/components/CloudTAK/Menu/Mission/MissionInfo.vue +0 -331
  269. package/src/components/CloudTAK/Menu/Mission/MissionInviteModal.vue +0 -107
  270. package/src/components/CloudTAK/Menu/Mission/MissionLayerCreate.vue +0 -77
  271. package/src/components/CloudTAK/Menu/Mission/MissionLayerEdit.vue +0 -77
  272. package/src/components/CloudTAK/Menu/Mission/MissionLayerTree.vue +0 -194
  273. package/src/components/CloudTAK/Menu/Mission/MissionLayers.vue +0 -157
  274. package/src/components/CloudTAK/Menu/Mission/MissionLog.vue +0 -170
  275. package/src/components/CloudTAK/Menu/Mission/MissionLogs.vue +0 -194
  276. package/src/components/CloudTAK/Menu/Mission/MissionTimeline.vue +0 -142
  277. package/src/components/CloudTAK/Menu/Mission/MissionUsers.vue +0 -74
  278. package/src/components/CloudTAK/Menu/Mission/PendingInvites.vue +0 -130
  279. package/src/components/CloudTAK/Menu/Overlays/DeleteModal.vue +0 -57
  280. package/src/components/CloudTAK/Menu/Overlays/TreeCots.vue +0 -497
  281. package/src/components/CloudTAK/Menu/Overlays/TreeMission.vue +0 -32
  282. package/src/components/CloudTAK/Menu/Overlays/TreeVector.vue +0 -113
  283. package/src/components/CloudTAK/Menu/Settings/TokenModal.vue +0 -110
  284. package/src/components/CloudTAK/Menu/Videos/VideoLeaseModal.vue +0 -753
  285. package/src/components/CloudTAK/Menu/Videos/VideosRemoteFeed.vue +0 -75
  286. package/src/components/CloudTAK/Notifications.vue +0 -195
  287. package/src/components/CloudTAK/Query/Magnetic.vue +0 -80
  288. package/src/components/CloudTAK/Query/Reverse.vue +0 -65
  289. package/src/components/CloudTAK/Query/Sun.vue +0 -178
  290. package/src/components/CloudTAK/Query/Weather.vue +0 -195
  291. package/src/components/CloudTAK/QueryView.vue +0 -134
  292. package/src/components/CloudTAK/RadialMenu/LICENSE +0 -21
  293. package/src/components/CloudTAK/RadialMenu/README.md +0 -63
  294. package/src/components/CloudTAK/RadialMenu/RadialMenu.css +0 -85
  295. package/src/components/CloudTAK/RadialMenu/RadialMenu.js +0 -534
  296. package/src/components/CloudTAK/RadialMenu/RadialMenu.vue +0 -257
  297. package/src/components/CloudTAK/RangeInput.vue +0 -155
  298. package/src/components/CloudTAK/RangeRingsInput.vue +0 -269
  299. package/src/components/CloudTAK/util/Breadcrumb.vue +0 -85
  300. package/src/components/CloudTAK/util/ChannelInfo.vue +0 -25
  301. package/src/components/CloudTAK/util/Contact.vue +0 -131
  302. package/src/components/CloudTAK/util/ContactPuck.vue +0 -40
  303. package/src/components/CloudTAK/util/Coordinate.vue +0 -313
  304. package/src/components/CloudTAK/util/CoordinateType.vue +0 -134
  305. package/src/components/CloudTAK/util/CopyButton.vue +0 -67
  306. package/src/components/CloudTAK/util/CopyField.vue +0 -286
  307. package/src/components/CloudTAK/util/DrawOverlay.vue +0 -254
  308. package/src/components/CloudTAK/util/EmptyInfo.vue +0 -71
  309. package/src/components/CloudTAK/util/FeatureIcon.vue +0 -134
  310. package/src/components/CloudTAK/util/FeatureRow.vue +0 -206
  311. package/src/components/CloudTAK/util/FloatingAttachment.vue +0 -191
  312. package/src/components/CloudTAK/util/FloatingVideo.vue +0 -654
  313. package/src/components/CloudTAK/util/GenericSelect.vue +0 -125
  314. package/src/components/CloudTAK/util/GroupSelect.vue +0 -129
  315. package/src/components/CloudTAK/util/Icons.vue +0 -146
  316. package/src/components/CloudTAK/util/JSONModal.vue +0 -57
  317. package/src/components/CloudTAK/util/Keywords.vue +0 -31
  318. package/src/components/CloudTAK/util/LineLength.vue +0 -121
  319. package/src/components/CloudTAK/util/MenuItem.vue +0 -21
  320. package/src/components/CloudTAK/util/MenuTemplate.vue +0 -137
  321. package/src/components/CloudTAK/util/MultipleSelect.vue +0 -103
  322. package/src/components/CloudTAK/util/NotificationIcon.vue +0 -50
  323. package/src/components/CloudTAK/util/NotificationToast.vue +0 -125
  324. package/src/components/CloudTAK/util/PolygonArea.vue +0 -109
  325. package/src/components/CloudTAK/util/PropertyAttachments.vue +0 -224
  326. package/src/components/CloudTAK/util/PropertyBattery.vue +0 -44
  327. package/src/components/CloudTAK/util/PropertyBearing.vue +0 -148
  328. package/src/components/CloudTAK/util/PropertyCreator.vue +0 -61
  329. package/src/components/CloudTAK/util/PropertyDistance.vue +0 -182
  330. package/src/components/CloudTAK/util/PropertyElevation.vue +0 -84
  331. package/src/components/CloudTAK/util/PropertyEmail.vue +0 -44
  332. package/src/components/CloudTAK/util/PropertyLinks.vue +0 -148
  333. package/src/components/CloudTAK/util/PropertyMetadata.vue +0 -53
  334. package/src/components/CloudTAK/util/PropertyMilSym.vue +0 -62
  335. package/src/components/CloudTAK/util/PropertyPhone.vue +0 -61
  336. package/src/components/CloudTAK/util/PropertySensor.vue +0 -129
  337. package/src/components/CloudTAK/util/PropertySpeed.vue +0 -91
  338. package/src/components/CloudTAK/util/PropertyStyle.vue +0 -202
  339. package/src/components/CloudTAK/util/PropertyTimes.vue +0 -95
  340. package/src/components/CloudTAK/util/PropertyType.vue +0 -274
  341. package/src/components/CloudTAK/util/SearchBox.vue +0 -314
  342. package/src/components/CloudTAK/util/SelectFeats.vue +0 -190
  343. package/src/components/CloudTAK/util/SettingsCallsign.vue +0 -151
  344. package/src/components/CloudTAK/util/Share.vue +0 -496
  345. package/src/components/CloudTAK/util/ShareToMission.vue +0 -223
  346. package/src/components/CloudTAK/util/ShareToPackage.vue +0 -250
  347. package/src/components/CloudTAK/util/SlideDownHeader.vue +0 -92
  348. package/src/components/CloudTAK/util/StandardItem.vue +0 -42
  349. package/src/components/CloudTAK/util/Subscriptions.vue +0 -151
  350. package/src/components/CloudTAK/util/TagEntry.vue +0 -301
  351. package/src/components/CloudTAK/util/UploadImport.vue +0 -195
  352. package/src/components/CloudTAK/util/VideoLeaseSourceType.vue +0 -66
  353. package/src/components/CloudTAK/util/WarnChannels.vue +0 -56
  354. package/src/components/CloudTAK/util/WarnConfiguration.vue +0 -34
  355. package/src/components/Configure.vue +0 -259
  356. package/src/components/ETL/Connection/AgencyBadge.vue +0 -102
  357. package/src/components/ETL/Connection/AgencySelect.vue +0 -185
  358. package/src/components/ETL/Connection/CertificateLogin.vue +0 -75
  359. package/src/components/ETL/Connection/CertificateMachineUser.vue +0 -228
  360. package/src/components/ETL/Connection/CertificateP12.vue +0 -104
  361. package/src/components/ETL/Connection/CertificateRaw.vue +0 -50
  362. package/src/components/ETL/Connection/ConnectionData.vue +0 -174
  363. package/src/components/ETL/Connection/ConnectionFiles.vue +0 -182
  364. package/src/components/ETL/Connection/ConnectionGroups.vue +0 -181
  365. package/src/components/ETL/Connection/ConnectionLayer.vue +0 -180
  366. package/src/components/ETL/Connection/ConnectionTokens.vue +0 -147
  367. package/src/components/ETL/Connection/ConnectionVideos.vue +0 -151
  368. package/src/components/ETL/Connection/Events.vue +0 -88
  369. package/src/components/ETL/Connection/StatusDot.vue +0 -48
  370. package/src/components/ETL/Connection/TokenModal.vue +0 -136
  371. package/src/components/ETL/Connection.vue +0 -194
  372. package/src/components/ETL/ConnectionCard.vue +0 -265
  373. package/src/components/ETL/ConnectionEdit.vue +0 -448
  374. package/src/components/ETL/Connections.vue +0 -148
  375. package/src/components/ETL/Data/DataFiles.vue +0 -245
  376. package/src/components/ETL/Data/DataGroups.vue +0 -45
  377. package/src/components/ETL/Data/DataLayer.vue +0 -144
  378. package/src/components/ETL/Data/Location.vue +0 -238
  379. package/src/components/ETL/Data.vue +0 -259
  380. package/src/components/ETL/DataEdit.vue +0 -212
  381. package/src/components/ETL/Layer/LayerAlarm.vue +0 -307
  382. package/src/components/ETL/Layer/LayerDeployment.vue +0 -388
  383. package/src/components/ETL/Layer/LayerEnvironment.vue +0 -259
  384. package/src/components/ETL/Layer/LayerIncomingConfig.vue +0 -401
  385. package/src/components/ETL/Layer/LayerIncomingEnvironmentArcGIS.vue +0 -354
  386. package/src/components/ETL/Layer/LayerIncomingSchema.vue +0 -138
  387. package/src/components/ETL/Layer/LayerIncomingStyles.vue +0 -349
  388. package/src/components/ETL/Layer/LayerOutgoingConfig.vue +0 -204
  389. package/src/components/ETL/Layer/LayerOutgoingEnvironmentArcGIS.vue +0 -279
  390. package/src/components/ETL/Layer/utils/QueryInput.vue +0 -52
  391. package/src/components/ETL/Layer/utils/Schema.vue +0 -322
  392. package/src/components/ETL/Layer/utils/SchemaModal.vue +0 -77
  393. package/src/components/ETL/Layer/utils/StatusDot.vue +0 -38
  394. package/src/components/ETL/Layer/utils/StyleLinkModal.vue +0 -83
  395. package/src/components/ETL/Layer/utils/StyleLinks.vue +0 -139
  396. package/src/components/ETL/Layer/utils/StyleSingle.vue +0 -885
  397. package/src/components/ETL/Layer/utils/StyleTemplate.vue +0 -97
  398. package/src/components/ETL/Layer/utils/TaskModal.vue +0 -217
  399. package/src/components/ETL/Layer.vue +0 -560
  400. package/src/components/ETL/LayerEdit.vue +0 -276
  401. package/src/components/ETL/Styling/Layer.vue +0 -311
  402. package/src/components/ETL/Styling/ObjectInput.vue +0 -46
  403. package/src/components/ETL/Styling/Style.vue +0 -233
  404. package/src/components/Home.vue +0 -17
  405. package/src/components/Loading.vue +0 -42
  406. package/src/components/Login.vue +0 -198
  407. package/src/components/LostUser.vue +0 -31
  408. package/src/components/PageFooter.vue +0 -41
  409. package/src/components/ServerAdmin.vue +0 -408
  410. package/src/components/VideoWall/Main.vue +0 -79
  411. package/src/components/VideoWall.vue +0 -17
  412. package/src/components/util/DataSelect.vue +0 -148
  413. package/src/components/util/EsriFilter.vue +0 -140
  414. package/src/components/util/EsriPortal.vue +0 -422
  415. package/src/components/util/EsriPortalCreate.vue +0 -72
  416. package/src/components/util/EsriServer.vue +0 -368
  417. package/src/components/util/GroupSelect.vue +0 -166
  418. package/src/components/util/IconSelect.vue +0 -302
  419. package/src/components/util/InitialAuthor.vue +0 -28
  420. package/src/components/util/LayerSelect.vue +0 -162
  421. package/src/components/util/LayerTaskSelect.vue +0 -311
  422. package/src/components/util/LayerTemplateSelect.vue +0 -173
  423. package/src/components/util/LoginModal.vue +0 -110
  424. package/src/components/util/PublicTilesSelect.vue +0 -171
  425. package/src/components/util/StatusDot.vue +0 -31
  426. package/src/components/util/TableFooter.vue +0 -64
  427. package/src/components/util/TableHeader.vue +0 -127
  428. package/src/components/util/Upload.vue +0 -220
  429. package/src/components/util/UploadCSV.vue +0 -46
  430. package/src/components/util/UploadLogo.vue +0 -83
  431. package/src/components/util/UploadP12.vue +0 -93
  432. package/src/components/util/UserSelect.vue +0 -151
  433. package/src/derived-types.d.ts +0 -35243
  434. package/src/main.ts +0 -264
  435. package/src/pages/admin/main.ts +0 -208
  436. package/src/pages/connection/main.ts +0 -158
  437. package/src/pages/docs/App.vue +0 -19
  438. package/src/pages/docs/main.ts +0 -6
  439. package/src/pages/video/main.ts +0 -27
  440. package/src/std.ts +0 -152
  441. package/src/stores/brand.ts +0 -28
  442. package/src/stores/float.ts +0 -113
  443. package/src/stores/map.ts +0 -931
  444. package/src/stores/modules/draw.ts +0 -413
  445. package/src/stores/modules/icons.ts +0 -185
  446. package/src/stores/modules/menu.ts +0 -281
  447. package/src/test/setup.ts +0 -43
  448. package/src/timediff.ts +0 -33
  449. package/src/types.ts +0 -226
  450. package/src/video.ts +0 -27
  451. package/src/vite-env.d.ts +0 -9
  452. package/src/workers/atlas-connection.ts +0 -236
  453. package/src/workers/atlas-database.ts +0 -764
  454. package/src/workers/atlas-profile.ts +0 -374
  455. package/src/workers/atlas-team.ts +0 -90
  456. package/src/workers/atlas.ts +0 -81
@@ -1,654 +0,0 @@
1
- <template>
2
- <div
3
- ref='container'
4
- class='position-absolute bg-dark rounded border resizable-content text-white video-container'
5
- >
6
- <div
7
- style='height: 50px;'
8
- class='d-flex align-items-center px-2 py-2 border-bottom border-secondary'
9
- >
10
- <div
11
- ref='drag-handle'
12
- class='cursor-pointer'
13
- >
14
- <IconGripVertical
15
- :size='24'
16
- stroke='1'
17
- />
18
- </div>
19
-
20
- <StatusDot
21
- v-if='active && active.metadata'
22
- :status='active.metadata.active ? "success" : "unknown"'
23
- :dark='true'
24
- :title='active.metadata.active ? "Streaming" : "Unknown"'
25
- :size='24'
26
- />
27
-
28
- <VideoLeaseSourceType
29
- v-if='active && active.metadata'
30
- :source-type='active.metadata.source_type'
31
- :size='24'
32
- />
33
-
34
- <div
35
- class='mx-2'
36
- style='max-width: calc(100% - 100px);'
37
- >
38
- <div
39
- class='text-sm text-truncate'
40
- v-text='title'
41
- />
42
- <div
43
- v-if='active && active.metadata && active.metadata.source_model'
44
- class='subheader'
45
- v-text='active.metadata.source_model'
46
- />
47
- </div>
48
-
49
- <div class='btn-list ms-auto'>
50
- <span
51
- v-if='active && active.metadata'
52
- class='watchers-info'
53
- >
54
- <IconUsersGroup
55
- :size='24'
56
- stroke='1'
57
- />
58
- <span v-text='active.metadata.watchers + 1' />
59
- <span
60
- class='ms-1 watcher-text'
61
- v-text='active.metadata.watchers + 1 > 1 ? "Watchers" : "Watcher"'
62
- />
63
- </span>
64
-
65
- <TablerIconButton
66
- title='Close Video Player'
67
- @click='emit("close")'
68
- >
69
- <IconX
70
- :size='24'
71
- stroke='1'
72
- />
73
- </TablerIconButton>
74
- </div>
75
- </div>
76
- <div
77
- class='modal-body'
78
- :class='{ "modal-body--error": !!error }'
79
- :style='`height: calc(100% - 50px)`'
80
- >
81
- <div
82
- v-if='loading'
83
- class='col-12 d-flex align-items-center justify-content-center'
84
- >
85
- <TablerLoading label='Loading Stream' />
86
- </div>
87
- <template v-else-if='error'>
88
- <div class='error-state d-flex flex-column align-items-center justify-content-center text-center gap-3 h-100 w-100'>
89
- <div class='row g-2 w-100'>
90
- <TablerAlert
91
- class='error-alert w-100'
92
- title='Video Error'
93
- :compact='true'
94
- :err='error'
95
- />
96
- </div>
97
-
98
- <div class='row g-2 w-100 error-actions'>
99
- <div class='col-md-6'>
100
- <TablerButton
101
- class='w-100'
102
- @click='$emit("close")'
103
- >
104
- Close Player
105
- </TablerButton>
106
- </div>
107
- <div class='col-md-6'>
108
- <TablerButton
109
- class='w-100'
110
- @click='requestLease'
111
- >
112
- Retry
113
- </TablerButton>
114
- </div>
115
- </div>
116
- </div>
117
- </template>
118
- <template v-else-if='!video || !videoProtocols || !videoProtocols.hls'>
119
- <TablerNone
120
- label='HLS Streaming Protocol'
121
- :create='false'
122
- />
123
- </template>
124
- <template v-else>
125
- <video
126
- ref='videoTag'
127
- class='w-100 h-100 live-video'
128
- controls
129
- autoplay
130
- muted
131
- />
132
- </template>
133
- </div>
134
- </div>
135
- </template>
136
-
137
- <script setup lang='ts'>
138
- /**
139
- * FloatingVideo Component
140
- *
141
- * A draggable, resizable video player component for HLS live streaming.
142
- * Features resilient error handling, automatic retry logic, and MediaMTX muxer restart recovery.
143
- */
144
-
145
- import { ref, computed, onMounted, onUnmounted, nextTick, useTemplateRef } from 'vue'
146
- import { std, stdurl } from '../../../../src/std.ts';
147
- import StatusDot from './../../util/StatusDot.vue';
148
- import VideoLeaseSourceType from './VideoLeaseSourceType.vue';
149
- import type { VideoLeaseResponse, VideoLeaseMetadata } from '../../../types.ts';
150
- import Hls from 'hls.js'
151
- import { useFloatStore } from '../../../stores/float.ts';
152
- import type { VideoPane } from '../../../stores/float.ts';
153
- import {
154
- IconX,
155
- IconUsersGroup,
156
- IconGripVertical
157
- } from '@tabler/icons-vue';
158
- import {
159
- TablerNone,
160
- TablerAlert,
161
- TablerLoading,
162
- TablerButton,
163
- TablerIconButton,
164
- } from '@tak-ps/vue-tabler';
165
-
166
- // Store for managing floating panes
167
- const floatStore = useFloatStore();
168
-
169
- // Component props
170
- const props = defineProps({
171
- title: {
172
- type: String,
173
- default: 'Video Stream'
174
- },
175
- uid: {
176
- type: String,
177
- required: true // Unique identifier for this video pane
178
- }
179
- });
180
-
181
- // Template refs for DOM elements
182
- const videoTag = useTemplateRef<HTMLVideoElement>('videoTag');
183
- const container = useTemplateRef<HTMLElement>('container');
184
- const dragHandle = useTemplateRef<HTMLElement>('drag-handle');
185
-
186
- // Component events
187
- const emit = defineEmits(['close']);
188
-
189
- // UI state management
190
- const loading = ref(true);
191
- const error = ref<Error | undefined>();
192
-
193
- // HLS retry logic state
194
- const retryCount = ref(0);
195
- const maxRetries = ref(3); // Maximum retry attempts before giving up
196
-
197
- // HLS player instance
198
- const player = ref<Hls | undefined>()
199
-
200
- // Video streaming data
201
- const video = ref(floatStore.panes.get(props.uid) as VideoPane);
202
- const videoLease = ref<VideoLeaseResponse | undefined>(); // CloudTAK video lease
203
- const videoProtocols = ref<VideoLeaseMetadata["protocols"] | undefined>(); // Available streaming protocols
204
-
205
- // Drag and resize functionality
206
- const observer = ref<ResizeObserver | undefined>(); // Watches for container resize events
207
- const lastPosition = ref({ top: 0, left: 0 }) // Last mouse position during drag
208
-
209
- // Active stream metadata
210
- const active = ref();
211
-
212
- // Computed title - uses stream metadata name if available, falls back to prop
213
- const title = computed(() => {
214
- if (active.value && active.value.metadata) {
215
- return active.value.metadata.name;
216
- } else {
217
- return props.title;
218
- }
219
- });
220
-
221
- // Cleanup when component is unmounted
222
- onUnmounted(async () => {
223
- // Stop observing resize events
224
- if (observer.value) {
225
- observer.value.disconnect();
226
- }
227
-
228
- // Destroy HLS player instance
229
- if (player.value) {
230
- player.value.destroy();
231
- }
232
-
233
- // Clean up video lease from server
234
- await deleteLease();
235
- });
236
-
237
- // Initialize component when mounted
238
- onMounted(async () => {
239
- // Set up resize observer to sync container size with store
240
- observer.value = new ResizeObserver((entries) => {
241
- if (!entries.length) return;
242
-
243
- // Use requestAnimationFrame for smooth resize updates
244
- window.requestAnimationFrame(() => {
245
- if (video.value && video.value && container.value) {
246
- video.value.config.height = entries[0].contentRect.height;
247
- video.value.config.width = entries[0].contentRect.width;
248
- }
249
- });
250
- })
251
-
252
- // Initialize container position and size from stored config
253
- if (container.value && video.value) {
254
- container.value.style.top = video.value.config.y + 'px';
255
- container.value.style.left = video.value.config.x + 'px';
256
-
257
- container.value.style.height = video.value.config.height + 'px';
258
- container.value.style.width = video.value.config.width + 'px';
259
-
260
- // Start observing container for resize events
261
- observer.value.observe(container.value);
262
- }
263
-
264
- // Set up drag functionality
265
- if (dragHandle.value) {
266
- dragHandle.value.addEventListener('mousedown', dragStart);
267
- dragHandle.value.addEventListener('touchstart', touchStart, { passive: false });
268
- }
269
-
270
- // Start the video lease request process
271
- await requestLease();
272
- });
273
-
274
- /**
275
- * Drag functionality - allows user to move the video player around the screen
276
- */
277
- function dragStart(event: MouseEvent) {
278
- if (!container.value || !dragHandle.value) return;
279
-
280
- // Store initial mouse position
281
- lastPosition.value.left = event.clientX;
282
- lastPosition.value.top = event.clientY;
283
-
284
- // Add visual feedback for dragging state
285
- dragHandle.value.classList.add('dragging');
286
-
287
- // Attach drag event listeners
288
- container.value.addEventListener('mousemove', dragMove);
289
- container.value.addEventListener('mouseleave', dragEnd);
290
- container.value.addEventListener('mouseup', dragEnd);
291
- }
292
-
293
- function dragMove(event: MouseEvent) {
294
- if (!container.value || !dragHandle.value || !video.value) return;
295
-
296
- // Calculate new position based on mouse movement
297
- const dragElRect = container.value.getBoundingClientRect();
298
-
299
- // Update stored position in video config
300
- video.value.config.x = dragElRect.left + event.clientX - lastPosition.value.left;
301
- video.value.config.y = dragElRect.top + event.clientY - lastPosition.value.top;
302
-
303
- // Update last position for next move calculation
304
- lastPosition.value.left = event.clientX;
305
- lastPosition.value.top = event.clientY;
306
-
307
- // Apply new position to DOM element
308
- container.value.style.top = video.value.config.y + 'px';
309
- container.value.style.left = video.value.config.x + 'px';
310
- }
311
-
312
- function dragEnd() {
313
- if (!container.value || !dragHandle.value) return;
314
-
315
- // Remove drag event listeners
316
- container.value.removeEventListener('mousemove', dragMove);
317
- container.value.removeEventListener('mouseleave', dragEnd);
318
- container.value.removeEventListener('mouseup', dragEnd);
319
-
320
- // Remove visual feedback for dragging state
321
- dragHandle.value.classList.remove('dragging');
322
- }
323
-
324
- function touchStart(event: TouchEvent) {
325
- if (!container.value || !dragHandle.value) return;
326
- event.preventDefault();
327
-
328
- const touch = event.touches[0];
329
- lastPosition.value.left = touch.clientX;
330
- lastPosition.value.top = touch.clientY;
331
-
332
- dragHandle.value.classList.add('dragging');
333
-
334
- container.value.addEventListener('touchmove', touchMove, { passive: false });
335
- container.value.addEventListener('touchend', touchEnd);
336
- container.value.addEventListener('touchcancel', touchEnd);
337
- }
338
-
339
- function touchMove(event: TouchEvent) {
340
- if (!container.value || !dragHandle.value || !video.value) return;
341
- event.preventDefault();
342
-
343
- const touch = event.touches[0];
344
- const dragElRect = container.value.getBoundingClientRect();
345
-
346
- video.value.config.x = dragElRect.left + touch.clientX - lastPosition.value.left;
347
- video.value.config.y = dragElRect.top + touch.clientY - lastPosition.value.top;
348
-
349
- lastPosition.value.left = touch.clientX;
350
- lastPosition.value.top = touch.clientY;
351
-
352
- container.value.style.top = video.value.config.y + 'px';
353
- container.value.style.left = video.value.config.x + 'px';
354
- }
355
-
356
- function touchEnd() {
357
- if (!container.value || !dragHandle.value) return;
358
-
359
- container.value.removeEventListener('touchmove', touchMove);
360
- container.value.removeEventListener('touchend', touchEnd);
361
- container.value.removeEventListener('touchcancel', touchEnd);
362
-
363
- dragHandle.value.classList.remove('dragging');
364
- }
365
-
366
- /**
367
- * Clean up video lease from CloudTAK server when component is destroyed
368
- */
369
- async function deleteLease(): Promise<void> {
370
- if (!videoLease.value) return;
371
-
372
- try {
373
- // Delete the temporary video lease from server
374
- await std(`/api/video/lease/${videoLease.value.id}`, {
375
- method: 'DELETE',
376
- });
377
-
378
- loading.value = false;
379
- } catch (err) {
380
- loading.value = false;
381
- error.value = err instanceof Error ? err : new Error(String(err));
382
- }
383
- }
384
-
385
- /**
386
- * Create and configure HLS.js player with resilient settings for live streaming
387
- */
388
- async function createPlayer(): Promise<void> {
389
- try {
390
- const url = new URL(videoProtocols.value!.hls!.url);
391
-
392
- player.value = new Hls({
393
- enableWorker: true,
394
- lowLatencyMode: false, // More forgiving for stream restarts
395
- debug: false,
396
- backBufferLength: 90, // Keep more buffer for smoother playback
397
- maxBufferLength: 30, // Larger buffer for resilience
398
- maxMaxBufferLength: 600,
399
- liveSyncDurationCount: 3, // More tolerant of discontinuities
400
- liveMaxLatencyDurationCount: 10,
401
- xhrSetup: (xhr: XMLHttpRequest) => {
402
- // Add authentication if stream requires it
403
- if (url.username && url.password) {
404
- xhr.setRequestHeader('Authorization', 'Basic ' + btoa(`${url.username}:${url.password}`));
405
- }
406
- }
407
- });
408
-
409
- player.value.attachMedia(videoTag.value!);
410
-
411
- player.value.on(Hls.Events.MEDIA_ATTACHED, async () => {
412
- if (player.value) player.value.loadSource(url.toString());
413
- });
414
-
415
- // Auto-play when manifest is loaded and parsed
416
- player.value.on(Hls.Events.MANIFEST_PARSED, async () => {
417
- try {
418
- if (videoTag.value) await videoTag.value.play();
419
- } catch (err) {
420
- console.error("Error playing video:", err);
421
- }
422
- });
423
-
424
- // Enhanced error handling for MediaMTX muxer restarts and network issues
425
- player.value.on(Hls.Events.ERROR, (event, data) => {
426
- console.log("HLS Error:", data);
427
-
428
- switch (data.type) {
429
- case Hls.ErrorTypes.NETWORK_ERROR:
430
- if (!data.fatal) {
431
- handleStreamRestart(); // Handle muxer restart scenario
432
- break;
433
- } else {
434
- console.log("Fatal network error:", data);
435
- handleStreamError(data.error);
436
- break;
437
- }
438
- case Hls.ErrorTypes.MEDIA_ERROR:
439
- if (!data.fatal) {
440
- handleStreamRestart(); // Handle muxer restart scenario
441
- break;
442
- } else {
443
- console.log("Fatal media error:", data);
444
-
445
- if (data.details === 'bufferAddCodecError' && data.error instanceof Error && data.error.name === 'NotSupportedError') {
446
- error.value = new Error(`Your browser does not support the required video codec for this stream (${data.mimeType}`);
447
- } else if (player.value) {
448
- try {
449
- player.value.recoverMediaError();
450
- } catch {
451
- handleStreamError(data.error);
452
- }
453
- } else {
454
- handleStreamError(data.error);
455
- }
456
-
457
- break;
458
- }
459
- default:
460
- if (!data.fatal) return;
461
-
462
- // Handle other fatal errors with retry logic
463
- handleStreamError(data.error);
464
- break;
465
- }
466
- })
467
- } catch (err) {
468
- error.value = err instanceof Error ? err : new Error(String(err));
469
- }
470
- }
471
-
472
- /**
473
- * Handle MediaMTX muxer restarts gracefully
474
- * This occurs when MediaMTX creates new segment naming due to source hiccups
475
- */
476
- function handleStreamRestart(): void {
477
- const hls = player.value;
478
- if (!hls || !videoProtocols.value?.hls) return;
479
-
480
- console.log('Handling HLS stream restart (muxer restart detected)');
481
-
482
- try {
483
- hls.recoverMediaError();
484
- hls.stopLoad();
485
- hls.loadSource(hls.url!);
486
-
487
- const videoElement = hls.media;
488
- if (videoElement) {
489
- hls.once(Hls.Events.LEVEL_LOADED, () => {
490
- // Seek to the end (live edge) to bypass the stalled gap
491
- videoElement.currentTime = videoElement.duration;
492
- hls.startLoad();
493
- videoElement.play().catch(e => console.error("Play failed", e));
494
- });
495
- }
496
- } catch (err) {
497
- console.error('Error handling stream restart:', err);
498
- handleStreamError(err instanceof Error ? err : new Error(String(err)));
499
- }
500
- }
501
-
502
- /**
503
- * Handle stream errors with exponential backoff retry logic
504
- * Implements 3-attempt retry system with increasing delays: 1s, 2s, 4s
505
- */
506
- function handleStreamError(streamError: Error): void {
507
- if (retryCount.value < maxRetries.value) {
508
- // Calculate exponential backoff delay
509
- const delay = 1000 * Math.pow(2, retryCount.value); // 1s, 2s, 4s
510
- console.log(`Retrying stream in ${delay}ms (attempt ${retryCount.value + 1}/${maxRetries.value})`);
511
-
512
- retryCount.value++;
513
-
514
- // Retry after delay
515
- setTimeout(() => {
516
- if (player.value) {
517
- player.value.destroy();
518
- player.value = undefined;
519
- }
520
-
521
- createPlayer();
522
- }, delay);
523
- } else {
524
- // Max retries reached - give up and show error to user
525
- console.error('Max retries reached, giving up');
526
-
527
- if (player.value) {
528
- player.value.destroy();
529
- player.value = undefined;
530
- }
531
-
532
- error.value = streamError;
533
- retryCount.value = 0;
534
- }
535
- }
536
-
537
- /**
538
- * Request video lease from CloudTAK server and initialize streaming
539
- * Handles both existing active streams and creation of new temporary leases
540
- */
541
- async function requestLease(): Promise<void> {
542
- if (!video.value) {
543
- error.value = new Error('Video URL could not be loaded');
544
- return;
545
- } else if (!Hls.isSupported()) {
546
- error.value = new Error('HLS.js is not supported in this browser.');
547
- return;
548
- } else {
549
- error.value = undefined;
550
- }
551
-
552
- try {
553
- // Check if stream is already active on the server
554
- const url = stdurl('/api/video/active');
555
- url.searchParams.append('url', video.value.config.url)
556
- active.value = await std(url);
557
-
558
- if (active.value.metadata) {
559
- // Stream is already active - use existing protocols
560
- videoProtocols.value = active.value.metadata.protocols;
561
- loading.value = false;
562
- } else if (active.value.leasable) {
563
- // Stream can be leased - create temporary lease
564
- const lease = await std('/api/video/lease', {
565
- method: 'POST',
566
- body: {
567
- name: 'Temporary Lease',
568
- ephemeral: true, // Hidden from streaming list
569
- duration: 1 * 60 * 60, // 1 hour lease
570
- proxy: video.value.config.url // Proxy the external stream
571
- }
572
- }) as VideoLeaseResponse
573
-
574
- const { protocols } = await std(`/api/video/lease/${lease.path}/metadata`) as VideoLeaseMetadata;
575
-
576
- videoLease.value = lease;
577
- videoProtocols.value = protocols;
578
-
579
- loading.value = false;
580
- } else if (!active.value.leasable) {
581
- // Stream cannot be leased
582
- error.value = new Error(active.value.message || 'Could not start stream');
583
- }
584
-
585
- // Initialize HLS player if we have protocols available
586
- if (!error.value && videoProtocols.value && videoProtocols.value.hls) {
587
- retryCount.value = 0; // Reset retry count for new lease
588
- nextTick(() => {
589
- createPlayer();
590
- });
591
- }
592
- } catch (err) {
593
- loading.value = false;
594
- error.value = err instanceof Error ? err : new Error(String(err));
595
- }
596
- }
597
- </script>
598
-
599
- <style>
600
- .dragging {
601
- cursor: move !important;
602
- }
603
-
604
- .resizable-content {
605
- min-height: 300px;
606
- min-width: 400px;
607
- resize: both;
608
- overflow: hidden;
609
- }
610
-
611
- .video-container {
612
- container-type: inline-size;
613
- }
614
-
615
- .modal-body--error {
616
- display: flex;
617
- align-items: center;
618
- justify-content: center;
619
- }
620
-
621
- .error-state {
622
- padding: 1rem;
623
- max-width: 520px;
624
- }
625
-
626
- .error-alert,
627
- .error-actions {
628
- max-width: 480px;
629
- }
630
-
631
- @container (max-width: 500px) {
632
- .watchers-info .watcher-text {
633
- display: none;
634
- }
635
- }
636
-
637
- @container (max-width: 450px) {
638
- .watchers-info {
639
- display: none !important;
640
- }
641
- }
642
-
643
- .live-video::-webkit-media-controls-timeline {
644
- display: none;
645
- }
646
-
647
- .live-video::-webkit-media-controls-current-time-display {
648
- display: none;
649
- }
650
-
651
- .live-video::-webkit-media-controls-time-remaining-display {
652
- display: none;
653
- }
654
- </style>