@3cr/viewer-browser 0.0.200 → 0.0.246

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 (383) hide show
  1. package/.circleci/config.yml +46 -22
  2. package/.prettierrc +6 -0
  3. package/components.d.ts +27 -10
  4. package/dist/Viewer3CR.js +36 -45
  5. package/dist/Viewer3CR.mjs +26893 -21667
  6. package/dist/Viewer3CR.umd.js +36 -45
  7. package/dist/android-chrome-192x192.png +0 -0
  8. package/dist/android-chrome-512x512.png +0 -0
  9. package/dist/apple-touch-icon.png +0 -0
  10. package/dist/browserconfig.xml +9 -0
  11. package/dist/favicon-16x16.png +0 -0
  12. package/dist/favicon-32x32.png +0 -0
  13. package/dist/favicon.ico +0 -0
  14. package/dist/mstile-144x144.png +0 -0
  15. package/dist/mstile-150x150.png +0 -0
  16. package/dist/mstile-310x150.png +0 -0
  17. package/dist/mstile-310x310.png +0 -0
  18. package/dist/mstile-70x70.png +0 -0
  19. package/dist/safari-pinned-tab.svg +50 -0
  20. package/dist/site.webmanifest +19 -0
  21. package/index.html +34 -41
  22. package/package.json +24 -20
  23. package/playground/android-chrome-192x192.png +0 -0
  24. package/playground/android-chrome-512x512.png +0 -0
  25. package/playground/apple-touch-icon.png +0 -0
  26. package/playground/browserconfig.xml +9 -0
  27. package/playground/favicon-16x16.png +0 -0
  28. package/playground/favicon-32x32.png +0 -0
  29. package/playground/favicon.ico +0 -0
  30. package/playground/index.html +30 -41
  31. package/playground/mstile-144x144.png +0 -0
  32. package/playground/mstile-150x150.png +0 -0
  33. package/playground/mstile-310x150.png +0 -0
  34. package/playground/mstile-310x310.png +0 -0
  35. package/playground/mstile-70x70.png +0 -0
  36. package/playground/safari-pinned-tab.svg +50 -0
  37. package/playground/site.webmanifest +19 -0
  38. package/playground/sw.js +15 -1
  39. package/public/android-chrome-192x192.png +0 -0
  40. package/public/android-chrome-512x512.png +0 -0
  41. package/public/apple-touch-icon.png +0 -0
  42. package/public/browserconfig.xml +9 -0
  43. package/public/favicon-16x16.png +0 -0
  44. package/public/favicon-32x32.png +0 -0
  45. package/public/favicon.ico +0 -0
  46. package/public/mstile-144x144.png +0 -0
  47. package/public/mstile-150x150.png +0 -0
  48. package/public/mstile-310x150.png +0 -0
  49. package/public/mstile-310x310.png +0 -0
  50. package/public/mstile-70x70.png +0 -0
  51. package/public/safari-pinned-tab.svg +50 -0
  52. package/public/site.webmanifest +19 -0
  53. package/src/App.vue +55 -50
  54. package/src/__tests__/app.spec.ts +7 -8
  55. package/{__tests__/index.spec.ts → src/__tests__/main.spec.ts} +5 -6
  56. package/src/assets/logos/3dicom/white-mini.svg +20 -0
  57. package/src/assets/logos/3dicom/white.svg +30 -0
  58. package/src/assets/styles.scss +18 -4
  59. package/src/components/demo/DemoPatientModal.vue +12 -22
  60. package/src/components/demo/__tests__/DemoModal.spec.ts +9 -8
  61. package/src/components/demo/__tests__/DemoPatientModal.spec.ts +11 -10
  62. package/src/components/demo/__tests__/options.spec.ts +1 -1
  63. package/src/components/demo/licence/DemoLicenceInfoModal.vue +11 -29
  64. package/src/components/demo/licence/__tests__/DemoLicenceEnableCloudStorageModal.spec.ts +11 -10
  65. package/src/components/demo/licence/__tests__/DemoLicenceInfoModal.spec.ts +21 -11
  66. package/src/components/demo/licence/__tests__/DemoLicenceSendToPartyModal.spec.ts +10 -10
  67. package/src/components/demo/licence/__tests__/DemoLicenceShareToMobileModal.spec.ts +14 -13
  68. package/src/components/demo/options.ts +74 -76
  69. package/src/components/demo/patient/DemoPatientInfoModal.vue +11 -29
  70. package/src/components/demo/patient/__tests__/DemoPatientEnableCloudStorageModal.spec.ts +11 -10
  71. package/src/components/demo/patient/__tests__/DemoPatientInfoModal.spec.ts +12 -11
  72. package/src/components/demo/patient/__tests__/DemoPatientSendToPartyModal.spec.ts +10 -10
  73. package/src/components/demo/patient/__tests__/DemoPatientShareToMobileModal.spec.ts +14 -13
  74. package/src/components/modal/ActionRail.vue +7 -11
  75. package/src/components/modal/AskAI.vue +35 -50
  76. package/src/components/modal/CloseViewerModal.vue +22 -57
  77. package/src/components/modal/MftpWebGL3DRModal.vue +230 -635
  78. package/src/components/modal/ViewerActionRail.vue +44 -39
  79. package/src/components/modal/ViewerNavigationDrawer.vue +10 -8
  80. package/src/components/modal/ViewerNavigationDrawerContent.vue +91 -49
  81. package/src/components/modal/ViewerNavigationDrawerFooter.vue +83 -63
  82. package/src/components/modal/ViewerNavigationDrawerHeader.vue +14 -44
  83. package/src/components/modal/ViewerScanView.vue +114 -0
  84. package/src/components/modal/WebGL3DR.vue +91 -0
  85. package/src/components/modal/__tests__/ActionRail.spec.ts +10 -0
  86. package/src/components/modal/__tests__/AskAI.spec.ts +33 -0
  87. package/src/components/modal/__tests__/CloseViewerModal.spec.ts +24 -14
  88. package/src/components/modal/__tests__/MftpWebGL3DRModal.spec.ts +147 -176
  89. package/src/components/modal/__tests__/ViewerActionRail.spec.ts +11 -0
  90. package/src/components/modal/__tests__/ViewerNavigationDrawer.spec.ts +10 -12
  91. package/src/components/modal/__tests__/ViewerNavigationDrawerContent.spec.ts +4 -22
  92. package/src/components/modal/__tests__/ViewerNavigationDrawerFooter.spec.ts +35 -32
  93. package/src/components/modal/__tests__/ViewerNavigationDrawerHeader.spec.ts +14 -11
  94. package/src/components/modal/__tests__/ViewerScanView.spec.ts +60 -0
  95. package/src/components/modal/__tests__/WebGL3DR.spec.ts +57 -0
  96. package/src/components/modal/actions/Flip3dAction.vue +1 -1
  97. package/src/components/modal/actions/FlipHorizontalAction.vue +5 -10
  98. package/src/components/modal/actions/FlipVerticalAction.vue +5 -10
  99. package/src/components/modal/actions/FullscreenAction.vue +6 -11
  100. package/src/components/modal/actions/NavigationCubeAction.vue +7 -14
  101. package/src/components/modal/actions/PanAction.vue +4 -4
  102. package/src/components/modal/actions/ResetViewAction.vue +1 -1
  103. package/src/components/modal/actions/Rotate2dAction.vue +8 -20
  104. package/src/components/modal/actions/Slice3dAction.vue +10 -32
  105. package/src/components/modal/actions/ZoomAction.vue +1 -1
  106. package/src/components/modal/actions/__tests__/Action.spec.ts +8 -9
  107. package/src/components/modal/actions/__tests__/Flip3dAction.spec.ts +6 -8
  108. package/src/components/modal/actions/__tests__/FlipHorizontalAction.spec.ts +6 -7
  109. package/src/components/modal/actions/__tests__/FlipVerticalAction.spec.ts +6 -7
  110. package/src/components/modal/actions/__tests__/FullscreenAction.spec.ts +9 -10
  111. package/src/components/modal/actions/__tests__/NavigationCubeAction.spec.ts +11 -11
  112. package/src/components/modal/actions/__tests__/PanAction.spec.ts +9 -10
  113. package/src/components/modal/actions/__tests__/ResetViewAction.spec.ts +7 -7
  114. package/src/components/modal/actions/__tests__/Rotate2dAction.spec.ts +6 -8
  115. package/src/components/modal/actions/__tests__/Slice3dAction.spec.ts +23 -5
  116. package/src/components/modal/actions/__tests__/ZoomAction.spec.ts +8 -10
  117. package/src/components/modal/buttons/AutoAnnotateBtn.vue +197 -0
  118. package/src/components/modal/buttons/__tests__/AutoAnnotateBtn.spec.ts +28 -0
  119. package/src/components/modal/menus/FileMenu.vue +73 -0
  120. package/src/components/modal/menus/SettingsMenu.vue +106 -0
  121. package/src/components/modal/menus/__tests__/FileMenu.spec.ts +110 -0
  122. package/src/components/modal/menus/__tests__/SettingsMenu.spec.ts +71 -0
  123. package/src/components/navigation/mcad/McadGlobalActions.vue +20 -0
  124. package/src/components/navigation/mcad/McadGlobalOpacitySlider.vue +103 -0
  125. package/src/components/navigation/mcad/McadGlobalScanViewBtn.vue +28 -0
  126. package/src/components/navigation/mcad/McadGlobalVisibilityBtn.vue +38 -0
  127. package/src/components/shared/DoubleSliderSelector.vue +142 -0
  128. package/src/components/{loading → shared}/LoadingSpinner.vue +27 -36
  129. package/src/components/shared/UpdateSnackbar.vue +72 -0
  130. package/src/components/{selectors → shared}/ValueSelector.vue +9 -12
  131. package/src/components/shared/__tests__/DoubleSliderSelector.spec.ts +83 -0
  132. package/src/components/shared/__tests__/LoadingSpinner.spec.ts +9 -0
  133. package/src/components/shared/__tests__/UpdateSnackbar.spec.ts +116 -0
  134. package/src/components/shared/__tests__/ValueSelector.spec.ts +39 -0
  135. package/src/components/shared/__tests__/VerticalSliderSelector.spec.ts +50 -0
  136. package/src/components/views/AnnotationTreeView.vue +236 -0
  137. package/src/components/{modal/ViewerDisplaySettings.vue → views/DisplaySettings.vue} +7 -15
  138. package/src/components/views/MarkupTreeView.vue +201 -0
  139. package/src/components/views/McadObjectTreeView.vue +129 -0
  140. package/src/components/views/__tests__/AnnotationTreeView.spec.ts +62 -0
  141. package/src/components/{modal/__tests__/ViewerDisplaySettings.spec.ts → views/__tests__/DisplaySettings.spec.ts} +24 -20
  142. package/src/components/views/__tests__/MarkupTreeView.spec.ts +41 -0
  143. package/src/components/views/__tests__/McadObjectTreeView.spec.ts +47 -0
  144. package/src/components/views/modals/DataOverlayGeneralModal.vue +71 -0
  145. package/src/components/views/modals/DataOverlayMarkupModal.vue +60 -0
  146. package/src/components/views/modals/DataOverlayModal.vue +88 -0
  147. package/src/components/views/shared/MaskIcon.vue +44 -0
  148. package/src/components/views/shared/ObjectColor.vue +31 -0
  149. package/src/components/views/shared/ObjectLabel.vue +30 -0
  150. package/src/components/views/shared/Opacity.vue +65 -0
  151. package/src/components/views/shared/VisibilityBtn.vue +25 -0
  152. package/src/components/views/shared/__tests__/MaskIcon.spec.ts +10 -0
  153. package/src/components/views/shared/__tests__/ObjectColor.spec.ts +10 -0
  154. package/src/components/views/shared/__tests__/ObjectLabel.spec.ts +10 -0
  155. package/src/components/views/shared/__tests__/Opacity.spec.ts +24 -0
  156. package/src/components/views/shared/__tests__/VisibilityBtn.spec.ts +11 -0
  157. package/src/components/views/types/annotation-tree-view-item-child-action.ts +6 -0
  158. package/src/components/views/types/annotation-tree-view-item-child.ts +9 -0
  159. package/src/components/views/types/annotation-tree-view-item.ts +13 -0
  160. package/src/components/views/types/markup-tree-view-item-child.ts +6 -0
  161. package/src/components/views/types/markup-tree-view-item.ts +14 -0
  162. package/src/components/views/types/mcad-object-tree-view-item.ts +13 -0
  163. package/src/composables/__tests__/useAnnotations.spec.ts +35 -0
  164. package/src/composables/__tests__/useEventListener.spec.ts +32 -0
  165. package/src/composables/__tests__/useIntroJs.spec.ts +51 -0
  166. package/src/composables/__tests__/useMarkups.spec.ts +39 -0
  167. package/src/composables/__tests__/useMcadObjects.spec.ts +36 -0
  168. package/src/composables/__tests__/useMouse.spec.ts +20 -0
  169. package/src/{components/modal/composables → composables}/__tests__/useNavigationCubeObserver.spec.ts +17 -12
  170. package/src/{dataLayer → composables}/__tests__/useViewer3cr.spec.ts +1 -2
  171. package/src/composables/useAnnotations.ts +37 -0
  172. package/src/composables/useDebounce.ts +11 -0
  173. package/src/composables/useEventListener.ts +25 -0
  174. package/src/composables/useIntroJs.ts +142 -0
  175. package/src/composables/useMarkups.ts +41 -0
  176. package/src/composables/useMcadObjects.ts +32 -0
  177. package/src/composables/useMouse.ts +14 -0
  178. package/src/{components/modal/composables → composables}/useNavigationCubeObserver.ts +35 -25
  179. package/src/composables/useScanMovement.ts +25 -0
  180. package/src/composables/useScanSliders.ts +36 -0
  181. package/src/composables/useVersion3cr.ts +7 -0
  182. package/src/composables/useViewer3cr.ts +7 -0
  183. package/src/composables/useViewerOptions.ts +36 -0
  184. package/src/{dataLayer → functions}/__tests__/clamp.spec.ts +1 -2
  185. package/src/functions/__tests__/layoutOverlayStyle.spec.ts +325 -0
  186. package/src/{helpers/__tests__/model-helper.spec.ts → functions/__tests__/modelHelper.spec.ts} +77 -40
  187. package/src/{notifications → functions}/__tests__/notification.spec.ts +19 -29
  188. package/src/functions/__tests__/parseAction.spec.ts +9 -0
  189. package/src/functions/__tests__/parseCallToAction.spec.ts +11 -0
  190. package/src/functions/__tests__/parseDataOverlay.spec.ts +15 -0
  191. package/src/functions/__tests__/parseDataOverlayData.spec.ts +9 -0
  192. package/src/functions/__tests__/parseDataOverlayEvent.spec.ts +10 -0
  193. package/src/functions/__tests__/parseMcadEvent.spec.ts +10 -0
  194. package/src/functions/guards/isDataOverlayAngle.ts +6 -0
  195. package/src/functions/guards/isDataOverlayLength.ts +6 -0
  196. package/src/functions/guards/isDataOverlayPolygon.ts +6 -0
  197. package/src/functions/layoutOverlayStyle.ts +84 -0
  198. package/src/{helpers → functions}/modelHelper.ts +81 -18
  199. package/src/functions/notification.ts +82 -0
  200. package/src/functions/parseAction.ts +9 -0
  201. package/src/functions/parseCallToAction.ts +9 -0
  202. package/src/functions/parseDataOverlay.ts +10 -0
  203. package/src/functions/parseDataOverlayData.ts +10 -0
  204. package/src/functions/parseDataOverlayEvent.ts +17 -0
  205. package/src/functions/parseMcadEvent.ts +10 -0
  206. package/src/functions/rgbaToCss.ts +13 -0
  207. package/src/main.ts +57 -9
  208. package/src/{dataLayer → models}/__tests__/eventHandlers.spec.ts +2 -3
  209. package/src/models/__tests__/loadViewerOptions.spec.ts +72 -0
  210. package/src/models/__tests__/loadViewerPayload.spec.ts +10 -0
  211. package/src/models/__tests__/scanState.spec.ts +190 -0
  212. package/src/models/callbacks.ts +4 -0
  213. package/src/models/loadViewerOptions.ts +79 -0
  214. package/src/models/loadViewerPayload.ts +17 -0
  215. package/src/{dataLayer → models}/scanState.ts +63 -74
  216. package/src/plugins/__tests__/usePlugins.spec.ts +12 -0
  217. package/src/plugins/__tests__/vuetify.spec.ts +3 -4
  218. package/src/plugins/usePlugins.ts +8 -0
  219. package/src/plugins/vuetify.ts +31 -65
  220. package/src/services/{gpt/__tests__ → __tests__}/gpt.service.spec.ts +2 -2
  221. package/src/services/__tests__/service-worker.service.spec.ts +32 -0
  222. package/src/{dataLayer/__tests__/viewer3cr.spec.ts → services/__tests__/viewer-3cr.service.spec.ts} +97 -36
  223. package/src/services/gpt.service.ts +17 -0
  224. package/src/services/service-worker.service.ts +16 -0
  225. package/src/{dataLayer/viewer3cr.ts → services/viewer-3cr.service.ts} +281 -150
  226. package/src/tools/data-overlay.tool.ts +71 -0
  227. package/src/types/action.ts +13 -0
  228. package/src/types/call-to-action.ts +9 -0
  229. package/src/types/colour.ts +6 -0
  230. package/src/types/data-overlay-angle.ts +16 -0
  231. package/src/types/data-overlay-annotation.ts +18 -0
  232. package/src/types/data-overlay-data.ts +15 -0
  233. package/src/types/data-overlay-event.ts +5 -0
  234. package/src/types/data-overlay-info.ts +18 -0
  235. package/src/types/data-overlay-interaction.ts +15 -0
  236. package/src/types/data-overlay-length.ts +16 -0
  237. package/src/types/data-overlay-markup.ts +7 -0
  238. package/src/types/data-overlay-mcad.ts +20 -0
  239. package/src/types/data-overlay-polygon.ts +18 -0
  240. package/src/types/data-overlay.ts +16 -0
  241. package/src/types/demo-type.ts +4 -0
  242. package/src/types/gpt-question.ts +4 -0
  243. package/src/types/gpt-response-payload.ts +6 -0
  244. package/src/types/mcad-object-interaction.ts +15 -0
  245. package/src/types/segment-angle.ts +5 -0
  246. package/src/types/vector2.ts +4 -0
  247. package/src/types/vector3.ts +5 -0
  248. package/test/fakers/action-data.faker.ts +11 -0
  249. package/test/fakers/action.faker.ts +19 -0
  250. package/test/fakers/call-to-action.faker.ts +17 -0
  251. package/test/fakers/colour.faker.ts +17 -0
  252. package/test/fakers/data-overlay-angle.faker.ts +37 -0
  253. package/test/fakers/data-overlay-annotation.faker.ts +41 -0
  254. package/test/fakers/data-overlay-data.faker.ts +97 -0
  255. package/test/fakers/data-overlay-info.faker.ts +29 -0
  256. package/test/fakers/data-overlay-interaction.faker.ts +62 -0
  257. package/test/fakers/data-overlay-length.faker.ts +37 -0
  258. package/test/fakers/data-overlay-mcad.faker.ts +40 -0
  259. package/test/fakers/data-overlay-polygon.faker.ts +39 -0
  260. package/test/fakers/gpt-question.faker.ts +11 -0
  261. package/test/fakers/gpt-response.faker.ts +12 -0
  262. package/test/fakers/invert-transform.faker.ts +16 -0
  263. package/test/fakers/mcad-object-interaction.faker.ts +22 -0
  264. package/test/fakers/orientation.faker.ts +17 -0
  265. package/test/fakers/segment-angle.faker.ts +12 -0
  266. package/test/fakers/vector2.faker.ts +12 -0
  267. package/test/fakers/vector3.faker.ts +16 -0
  268. package/test/plugins/findByTestId.ts +25 -0
  269. package/test/plugins/vuetify.ts +16 -0
  270. package/test/setup.ts +16 -5
  271. package/tsconfig.json +4 -15
  272. package/vite.config.mts +20 -46
  273. package/vitest.config.mts +24 -43
  274. package/index.ts +0 -72
  275. package/src/assets/images/dark/3DICOM.png +0 -0
  276. package/src/assets/images/dark/3dicom-logo.svg +0 -1
  277. package/src/assets/images/light/3DICOM.png +0 -0
  278. package/src/assets/images/light/3dicom-logo.svg +0 -1
  279. package/src/assets/logo.png +0 -0
  280. package/src/assets/logo.svg +0 -6
  281. package/src/components/WebGL3DR.vue +0 -102
  282. package/src/components/__tests__/webgl3dr.spec.ts +0 -37
  283. package/src/components/icons/liver.vue +0 -21
  284. package/src/components/loading/__tests__/loading-spinner.spec.ts +0 -11
  285. package/src/components/modal/ViewerAnnotationModal.vue +0 -111
  286. package/src/components/modal/ViewerAnnotations.vue +0 -289
  287. package/src/components/modal/__tests__/ViewerAnnotationModal.spec.ts +0 -79
  288. package/src/components/modal/composables/useEventListener.ts +0 -22
  289. package/src/components/selectors/__tests__/value-selector.spec.ts +0 -53
  290. package/src/components/sliders/DoubleSliderSelector.vue +0 -141
  291. package/src/components/sliders/__tests__/double-slider-selector.spec.ts +0 -104
  292. package/src/components/sliders/__tests__/vertical-slider-selector.spec.ts +0 -61
  293. package/src/dataLayer/__tests__/getIconForPreset.spec.ts +0 -40
  294. package/src/dataLayer/__tests__/patchDataOverlay.spec.ts +0 -88
  295. package/src/dataLayer/__tests__/scanState.spec.ts +0 -93
  296. package/src/dataLayer/getIconForPreset.ts +0 -11
  297. package/src/dataLayer/patchDataOverlay.ts +0 -101
  298. package/src/dataLayer/useViewer3cr.ts +0 -7
  299. package/src/helpers/__tests__/layout-overlay-style.spec.ts +0 -290
  300. package/src/helpers/__tests__/utils.spec.ts +0 -70
  301. package/src/helpers/layoutOverlayStyle.ts +0 -96
  302. package/src/helpers/utils.ts +0 -16
  303. package/src/models/Callbacks.ts +0 -2
  304. package/src/models/LoadViewerOptions.ts +0 -31
  305. package/src/models/LoadViewerPayload.ts +0 -9
  306. package/src/models/__tests__/load-viewer-options.spec.ts +0 -22
  307. package/src/notifications/notification.ts +0 -50
  308. package/src/plugins/__tests__/index.spec.ts +0 -19
  309. package/src/plugins/index.ts +0 -17
  310. package/src/services/gpt/gpt.service.ts +0 -35
  311. package/static/3cr-types-browser/index.ts +0 -74
  312. package/static/3cr-types-browser/types/Action.ts +0 -6
  313. package/static/3cr-types-browser/types/AlphaKeys.ts +0 -5
  314. package/static/3cr-types-browser/types/AnchorPoint.ts +0 -12
  315. package/static/3cr-types-browser/types/CallToAction.ts +0 -5
  316. package/static/3cr-types-browser/types/ColourData.ts +0 -7
  317. package/static/3cr-types-browser/types/ColourPresetData.ts +0 -9
  318. package/static/3cr-types-browser/types/CurrentDataOverlayState.ts +0 -6
  319. package/static/3cr-types-browser/types/CurrentScanState.ts +0 -22
  320. package/static/3cr-types-browser/types/DataOverlay.ts +0 -22
  321. package/static/3cr-types-browser/types/DataOverlayActions.ts +0 -14
  322. package/static/3cr-types-browser/types/DataOverlayData.ts +0 -8
  323. package/static/3cr-types-browser/types/DataOverlayEvent.ts +0 -8
  324. package/static/3cr-types-browser/types/DecryptionKey.ts +0 -4
  325. package/static/3cr-types-browser/types/DisplaySettings.ts +0 -10
  326. package/static/3cr-types-browser/types/EmptyPayload.ts +0 -3
  327. package/static/3cr-types-browser/types/EnumPayload.ts +0 -4
  328. package/static/3cr-types-browser/types/FileManagementActions.ts +0 -11
  329. package/static/3cr-types-browser/types/FlipValue.ts +0 -7
  330. package/static/3cr-types-browser/types/FrontEndInterfaces.ts +0 -14
  331. package/static/3cr-types-browser/types/GradientKeys.ts +0 -7
  332. package/static/3cr-types-browser/types/GreyscalePresetData.ts +0 -6
  333. package/static/3cr-types-browser/types/InitialDataOverlayState.ts +0 -6
  334. package/static/3cr-types-browser/types/InitialScanState.ts +0 -19
  335. package/static/3cr-types-browser/types/InteractionType.ts +0 -8
  336. package/static/3cr-types-browser/types/InteractivityActions.ts +0 -6
  337. package/static/3cr-types-browser/types/InteractivityState.ts +0 -4
  338. package/static/3cr-types-browser/types/InvertTransformData.ts +0 -6
  339. package/static/3cr-types-browser/types/LayoutActions.ts +0 -6
  340. package/static/3cr-types-browser/types/LayoutData.ts +0 -7
  341. package/static/3cr-types-browser/types/LoadDataSet.ts +0 -6
  342. package/static/3cr-types-browser/types/LoadSessionState.ts +0 -4
  343. package/static/3cr-types-browser/types/LocalLoadDataset.ts +0 -3
  344. package/static/3cr-types-browser/types/MovementData.ts +0 -7
  345. package/static/3cr-types-browser/types/NavigationCubeActions.ts +0 -8
  346. package/static/3cr-types-browser/types/NavigationCubeData.ts +0 -12
  347. package/static/3cr-types-browser/types/NavigationCubeTransform.ts +0 -9
  348. package/static/3cr-types-browser/types/NotificationPayload.ts +0 -7
  349. package/static/3cr-types-browser/types/NotificationsActions.ts +0 -6
  350. package/static/3cr-types-browser/types/Object.ts +0 -1
  351. package/static/3cr-types-browser/types/ObjectColour.ts +0 -7
  352. package/static/3cr-types-browser/types/ObjectIcon.ts +0 -5
  353. package/static/3cr-types-browser/types/ObjectInvert.ts +0 -7
  354. package/static/3cr-types-browser/types/ObjectSize.ts +0 -7
  355. package/static/3cr-types-browser/types/ObjectSize2D.ts +0 -7
  356. package/static/3cr-types-browser/types/ObjectVisible.ts +0 -5
  357. package/static/3cr-types-browser/types/PositionData.ts +0 -14
  358. package/static/3cr-types-browser/types/PresetsActions.ts +0 -4
  359. package/static/3cr-types-browser/types/RotationValue.ts +0 -7
  360. package/static/3cr-types-browser/types/ScanMovementActions.ts +0 -27
  361. package/static/3cr-types-browser/types/ScanMovementData.ts +0 -3
  362. package/static/3cr-types-browser/types/ScanOrientationActions.ts +0 -6
  363. package/static/3cr-types-browser/types/ScanStateActions.ts +0 -4
  364. package/static/3cr-types-browser/types/ScanView.ts +0 -6
  365. package/static/3cr-types-browser/types/SettingsData.ts +0 -12
  366. package/static/3cr-types-browser/types/SlicerData.ts +0 -9
  367. package/static/3cr-types-browser/types/SliderValue.ts +0 -4
  368. package/static/3cr-types-browser/types/SlidersActions.ts +0 -18
  369. package/static/3cr-types-browser/types/Vector2Data.ts +0 -5
  370. package/static/3cr-types-browser/types/Vector3Data.ts +0 -6
  371. package/static/3cr-types-browser/types/VectorMovementData.ts +0 -8
  372. package/static/3cr-types-browser/types/ViewInteractiveMode.ts +0 -5
  373. package/static/3cr-types-browser/types/ViewOrientation.ts +0 -8
  374. package/static/3cr-types-browser/types/ViewOrientations.ts +0 -10
  375. package/static/3cr-types-browser/types/ViewSelectionActions.ts +0 -9
  376. package/static/3cr-types-browser/types/ViewToggleData.ts +0 -7
  377. package/static/3cr-types-browser/types/VolumeOrientation.ts +0 -7
  378. package/test/helper.ts +0 -44
  379. /package/src/components/{sliders → shared}/VerticalSliderSelector.vue +0 -0
  380. /package/{config.ts → src/config.ts} +0 -0
  381. /package/src/{dataLayer → functions}/clamp.ts +0 -0
  382. /package/src/{dataLayer → models}/eventHandlers.ts +0 -0
  383. /package/{static/3cr-types-browser/types/ActionData.ts → src/types/action-data.ts} +0 -0
@@ -1,30 +1,20 @@
1
- import { describe, expect, it, vi } from "vitest";
2
- import { useNotification } from "@kyvg/vue3-notification";
3
- import { handleNotification } from "@/notifications/notification";
1
+ import { useNotification } from '@kyvg/vue3-notification';
2
+ import { handleNotification } from '@/functions/notification';
4
3
  import {
5
4
  FileManagementActions,
6
5
  InteractivityActions,
7
6
  NotificationPayload,
8
7
  NotificationsActions,
9
- SlidersActions,
10
- } from "@3cr/types-ts";
11
- const { notify } = useNotification();
8
+ SlidersActions
9
+ } from '@3cr/types-ts';
12
10
 
13
- vi.mock("@kyvg/vue3-notification", async (importOriginal) => {
14
- const mod = (await importOriginal()) as object;
15
- return {
16
- ...mod,
17
- useNotification: vi.fn().mockReturnValue({
18
- notify: vi.fn(),
19
- }),
20
- };
21
- });
11
+ describe('notification.ts', () => {
12
+ const { notify } = useNotification();
22
13
 
23
- describe("notification.ts", () => {
24
14
  it(`should handleNotification InteractivityActions.in01`, () => {
25
15
  const notification: NotificationPayload = {
26
16
  Action: InteractivityActions.in01,
27
- Code: "S00001",
17
+ Code: 'S00001'
28
18
  } as NotificationPayload;
29
19
  handleNotification(NotificationsActions.no01, JSON.stringify(notification));
30
20
  expect(notify).not.toHaveBeenCalled();
@@ -33,7 +23,7 @@ describe("notification.ts", () => {
33
23
  it(`should handleNotification InteractivityActions.in02`, () => {
34
24
  const notification: NotificationPayload = {
35
25
  Action: InteractivityActions.in02,
36
- Code: "S00001",
26
+ Code: 'S00001'
37
27
  } as NotificationPayload;
38
28
  handleNotification(NotificationsActions.no01, JSON.stringify(notification));
39
29
  expect(notify).not.toHaveBeenCalled();
@@ -42,7 +32,7 @@ describe("notification.ts", () => {
42
32
  it(`should handleNotification InteractivityActions.in03`, () => {
43
33
  const notification: NotificationPayload = {
44
34
  Action: InteractivityActions.in03,
45
- Code: "S00001",
35
+ Code: 'S00001'
46
36
  } as NotificationPayload;
47
37
  handleNotification(NotificationsActions.no01, JSON.stringify(notification));
48
38
  expect(notify).not.toHaveBeenCalled();
@@ -51,7 +41,7 @@ describe("notification.ts", () => {
51
41
  it(`should handleNotification InteractivityActions.in04`, () => {
52
42
  const notification: NotificationPayload = {
53
43
  Action: InteractivityActions.in04,
54
- Code: "S00001",
44
+ Code: 'S00001'
55
45
  } as NotificationPayload;
56
46
  handleNotification(NotificationsActions.no01, JSON.stringify(notification));
57
47
  expect(notify).not.toHaveBeenCalled();
@@ -60,7 +50,7 @@ describe("notification.ts", () => {
60
50
  it(`should handleNotification SlidersActions.sl01`, () => {
61
51
  const notification: NotificationPayload = {
62
52
  Action: SlidersActions.sl01,
63
- Code: "S00001",
53
+ Code: 'S00001'
64
54
  } as NotificationPayload;
65
55
  handleNotification(NotificationsActions.no01, JSON.stringify(notification));
66
56
  expect(notify).not.toHaveBeenCalled();
@@ -69,52 +59,52 @@ describe("notification.ts", () => {
69
59
  it(`should handleNotification success [MUTED] FileManagementActions.fm01`, () => {
70
60
  const notification: NotificationPayload = {
71
61
  Action: FileManagementActions.fm01,
72
- Code: "S00001",
62
+ Code: 'S00001'
73
63
  } as NotificationPayload;
74
64
  handleNotification(NotificationsActions.no01, JSON.stringify(notification));
75
65
  expect(notify).not.toHaveBeenCalledWith({
76
66
  title: notification.Code,
77
67
  text: notification.Action,
78
- type: "success",
68
+ type: 'success'
79
69
  });
80
70
  });
81
71
 
82
72
  it(`should handleNotification info [MUTED] FileManagementActions.fm01`, () => {
83
73
  const notification: NotificationPayload = {
84
74
  Action: FileManagementActions.fm01,
85
- Code: "I00001",
75
+ Code: 'I00001'
86
76
  } as NotificationPayload;
87
77
  handleNotification(NotificationsActions.no04, JSON.stringify(notification));
88
78
  expect(notify).not.toHaveBeenCalledWith({
89
79
  title: notification.Code,
90
80
  text: notification.Action,
91
- type: "info",
81
+ type: 'info'
92
82
  });
93
83
  });
94
84
 
95
85
  it(`should handleNotification failure FileManagementActions.fm01`, () => {
96
86
  const notification: NotificationPayload = {
97
87
  Action: FileManagementActions.fm01,
98
- Code: "F00001",
88
+ Code: 'F00001'
99
89
  } as NotificationPayload;
100
90
  handleNotification(NotificationsActions.no03, JSON.stringify(notification));
101
91
  expect(notify).toHaveBeenCalledWith({
102
92
  title: notification.Code,
103
93
  text: notification.Action,
104
- type: "error",
94
+ type: 'error'
105
95
  });
106
96
  });
107
97
 
108
98
  it(`should handleNotification warning FileManagementActions.fm01`, () => {
109
99
  const notification: NotificationPayload = {
110
100
  Action: FileManagementActions.fm01,
111
- Code: "A00001",
101
+ Code: 'A00001'
112
102
  } as NotificationPayload;
113
103
  handleNotification(NotificationsActions.no02, JSON.stringify(notification));
114
104
  expect(notify).toHaveBeenCalledWith({
115
105
  title: notification.Code,
116
106
  text: notification.Action,
117
- type: "warn",
107
+ type: 'warn'
118
108
  });
119
109
  });
120
110
  });
@@ -0,0 +1,9 @@
1
+ import { parseAction } from '@/functions/parseAction';
2
+ import { ActionFaker } from '@test/fakers/action.faker';
3
+
4
+ describe('parseAction tests', () => {
5
+ it('should parse', () => {
6
+ const result = parseAction(ActionFaker.randomRaw());
7
+ expect(typeof result.ActionData).not.toBe('string');
8
+ });
9
+ });
@@ -0,0 +1,11 @@
1
+ import { parseCallToAction } from '@/functions/parseCallToAction';
2
+ import { CallToActionFaker } from '@test/fakers/call-to-action.faker';
3
+
4
+ describe('parseCallToAction tests', () => {
5
+ it('should parse', () => {
6
+ const result = parseCallToAction(CallToActionFaker.randomRaw());
7
+ result.Actions.forEach((action) => {
8
+ expect(typeof action.ActionData).not.toBe('string');
9
+ });
10
+ });
11
+ });
@@ -0,0 +1,15 @@
1
+ import { parseDataOverlay } from '@/functions/parseDataOverlay';
2
+ import { DataOverlayAnnotationFaker } from '@test/fakers/data-overlay-annotation.faker';
3
+
4
+ describe('parseDataOverlay tests', () => {
5
+ it('should parse', () => {
6
+ const result = parseDataOverlay(DataOverlayAnnotationFaker.randomRaw());
7
+ expect(typeof result.CallToAction).not.toBe('string');
8
+ });
9
+
10
+ it('should parse with null', () => {
11
+ const result = DataOverlayAnnotationFaker.randomRaw();
12
+ result.CallToAction = null;
13
+ expect(typeof result.CallToAction).not.toBe('string');
14
+ });
15
+ });
@@ -0,0 +1,9 @@
1
+ import { DataOverlayDataFaker } from '@test/fakers/data-overlay-data.faker';
2
+ import { parseDataOverlayData } from '@/functions/parseDataOverlayData';
3
+
4
+ describe('parseDataOverlayData tests', () => {
5
+ it('should parse', () => {
6
+ const result = parseDataOverlayData(DataOverlayDataFaker.annotationRaw());
7
+ expect(typeof result.Data).not.toBe('string');
8
+ });
9
+ });
@@ -0,0 +1,10 @@
1
+ import { DataOverlayDataFaker } from '@test/fakers/data-overlay-data.faker';
2
+ import { parseDataOverlayEvent } from '@/functions/parseDataOverlayEvent';
3
+ import { Interactiontype } from '@3cr/types-ts';
4
+
5
+ describe('parseDataOverlayEvent tests', () => {
6
+ it('should parse', () => {
7
+ const result = parseDataOverlayEvent(DataOverlayDataFaker.angleEventRaw(Interactiontype.HOVER_START));
8
+ expect(typeof result.Data).not.toBe('string');
9
+ });
10
+ });
@@ -0,0 +1,10 @@
1
+ import { Interactiontype } from '@3cr/types-ts';
2
+ import { parseMcadEvent } from '@/functions/parseMcadEvent';
3
+ import { McadObjectInteractionFaker } from '@test/fakers/mcad-object-interaction.faker';
4
+
5
+ describe('parseMcadEvent tests', () => {
6
+ it('should parse', () => {
7
+ const result = parseMcadEvent(McadObjectInteractionFaker.randomRaw(Interactiontype.HOVER_START));
8
+ expect(typeof result.Mcad.CallToAction).not.toBe('string');
9
+ });
10
+ });
@@ -0,0 +1,6 @@
1
+ import { DataOverlayAngle } from '@/types/data-overlay-angle';
2
+ import { DataOverlay } from '@/types/data-overlay';
3
+
4
+ export function isDataOverlayAngle(markup: DataOverlay): markup is DataOverlayAngle {
5
+ return 'SegmentAngles' in markup;
6
+ }
@@ -0,0 +1,6 @@
1
+ import { DataOverlayLength } from '@/types/data-overlay-length';
2
+ import { DataOverlay } from '@/types/data-overlay';
3
+
4
+ export function isDataOverlayLength(markup: DataOverlay): markup is DataOverlayLength {
5
+ return 'SegmentLengths' in markup;
6
+ }
@@ -0,0 +1,6 @@
1
+ import { DataOverlayPolygon } from '@/types/data-overlay-polygon';
2
+ import { DataOverlay } from '@/types/data-overlay';
3
+
4
+ export function isDataOverlayPolygon(markup: DataOverlay): markup is DataOverlayPolygon {
5
+ return 'Area' in markup;
6
+ }
@@ -0,0 +1,84 @@
1
+ import { AnchorPoint, PositionData } from '@3cr/types-ts';
2
+ import { isFullscreen } from '@/models/scanState';
3
+
4
+ export function generateDivStyleForLayout(layout: PositionData, canvas: HTMLCanvasElement) {
5
+ const padding: string = '0px';
6
+ const props: Record<string, any> = { position: 'absolute' };
7
+
8
+ if (layout.Anchor === AnchorPoint.TOP) {
9
+ props['left'] = '50%';
10
+ props['transform'] = 'translateX(-50%)';
11
+ } else if (layout.Anchor === AnchorPoint.BOTTOM) {
12
+ props['left'] = '50%';
13
+ props['transform'] = 'translateX(-50%)';
14
+ } else if (layout.Anchor === AnchorPoint.LEFT) {
15
+ props['top'] = '50%';
16
+ props['transform'] = 'translateY(-50%)';
17
+ } else if (layout.Anchor === AnchorPoint.RIGHT) {
18
+ props['top'] = '50%';
19
+ props['transform'] = 'translateY(-50%)';
20
+ }
21
+
22
+ if (
23
+ layout.Anchor === AnchorPoint.TOP_LEFT ||
24
+ layout.Anchor === AnchorPoint.TOP ||
25
+ layout.Anchor === AnchorPoint.TOP_RIGHT ||
26
+ layout.Anchor === AnchorPoint.CENTER
27
+ ) {
28
+ props['top'] = padding;
29
+ }
30
+ if (
31
+ layout.Anchor === AnchorPoint.LEFT ||
32
+ layout.Anchor === AnchorPoint.BOTTOM_LEFT ||
33
+ layout.Anchor === AnchorPoint.TOP_LEFT ||
34
+ layout.Anchor === AnchorPoint.CENTER
35
+ ) {
36
+ props['left'] = padding;
37
+ }
38
+ if (
39
+ layout.Anchor === AnchorPoint.RIGHT ||
40
+ layout.Anchor === AnchorPoint.TOP_RIGHT ||
41
+ layout.Anchor === AnchorPoint.BOTTOM_RIGHT
42
+ ) {
43
+ props['right'] = padding;
44
+ }
45
+ if (
46
+ layout.Anchor === AnchorPoint.BOTTOM ||
47
+ layout.Anchor === AnchorPoint.BOTTOM_LEFT ||
48
+ layout.Anchor === AnchorPoint.BOTTOM_RIGHT
49
+ ) {
50
+ props['bottom'] = padding;
51
+ }
52
+ if (layout.Anchor === AnchorPoint.TOP_LEFT || layout.Anchor === AnchorPoint.CENTER) {
53
+ props['border-top-left-radius'] = padding;
54
+ }
55
+ if (layout.Anchor === AnchorPoint.TOP_RIGHT || layout.Anchor === AnchorPoint.CENTER) {
56
+ props['border-top-right-radius'] = padding;
57
+ }
58
+ if (layout.Anchor === AnchorPoint.BOTTOM_LEFT || layout.Anchor === AnchorPoint.CENTER) {
59
+ props['border-bottom-left-radius'] = padding;
60
+ }
61
+ if (layout.Anchor === AnchorPoint.BOTTOM_RIGHT || layout.Anchor === AnchorPoint.CENTER) {
62
+ props['border-bottom-right-radius'] = padding;
63
+ }
64
+
65
+ props['width'] = `calc(${layout.MaxSize.X * 100}% - ${padding})`;
66
+ props['height'] = `calc(${layout.MaxSize.Y * 100}% - ${padding})`;
67
+
68
+ if (layout.Anchor === AnchorPoint.CENTER) {
69
+ const adjustment = !isFullscreen.value ? canvas.clientHeight / 3 : 0;
70
+ props['width'] = `calc(${layout.MaxSize.X * 100}% - ${adjustment}px - ${padding} - ${padding})`;
71
+ props['height'] = `calc(${layout.MaxSize.Y * 100}% - ${padding} - ${padding})`;
72
+ }
73
+
74
+ if (layout.AspectRatio === 1) {
75
+ if (layout.MaxSize.X === 1) {
76
+ props['width'] = `calc(${layout.MaxSize.Y * canvas.clientHeight}px)`;
77
+ }
78
+ if (layout.MaxSize.Y === 1) {
79
+ props['height'] = `calc(${layout.MaxSize.X * canvas.clientWidth}px)`;
80
+ }
81
+ }
82
+
83
+ return props;
84
+ }
@@ -1,17 +1,22 @@
1
1
  import {
2
- AnchorPoint, CurrentDataOverlayState,
2
+ AnchorPoint,
3
+ CurrentDataOverlayState,
4
+ CurrentMcadState,
3
5
  CurrentScanState,
6
+ GraphicType,
4
7
  InitialDataOverlayState,
8
+ InitialMcadState,
5
9
  InitialScanState,
10
+ PatientPosition,
6
11
  ScanView,
7
- ViewInteractiveMode,
12
+ ViewInteractiveMode
8
13
  } from '@3cr/types-ts';
9
14
 
10
15
  export function inflateScanState(): CurrentScanState {
11
16
  return {
12
17
  Version: '1.0.0',
13
18
  ScanMovement: {
14
- Version: '1.1.0',
19
+ Version: '1.1.0'
15
20
  },
16
21
  Display: {
17
22
  Version: '1.0.0',
@@ -21,7 +26,7 @@ export function inflateScanState(): CurrentScanState {
21
26
  WindowLower: 0,
22
27
  WindowUpper: 100,
23
28
  ThresholdLower: 0,
24
- ThresholdUpper: 100,
29
+ ThresholdUpper: 100
25
30
  },
26
31
  CurrentView: ScanView.Volume,
27
32
  Slice: {
@@ -31,7 +36,7 @@ export function inflateScanState(): CurrentScanState {
31
36
  SagittalLower: 0,
32
37
  SagittalUpper: 0,
33
38
  CoronalLower: 0,
34
- CoronalUpper: 0,
39
+ CoronalUpper: 0
35
40
  },
36
41
  InteractionSettings: {
37
42
  Version: '1.0.0',
@@ -41,7 +46,7 @@ export function inflateScanState(): CurrentScanState {
41
46
  CameraRotateSensitivity: 0,
42
47
  KeyboardEnabled: true,
43
48
  MouseEnabled: true,
44
- InteractionMode: ViewInteractiveMode.STATIC,
49
+ InteractionMode: ViewInteractiveMode.STATIC
45
50
  },
46
51
  Orientations: {
47
52
  Version: '1.0.0',
@@ -51,7 +56,7 @@ export function inflateScanState(): CurrentScanState {
51
56
  VerticalFlip: false,
52
57
  HorizontalFlip: false,
53
58
  Rotation: 0,
54
- Slice: 0,
59
+ Slice: 0
55
60
  },
56
61
  Sagittal: {
57
62
  Version: '1.0.0',
@@ -59,7 +64,7 @@ export function inflateScanState(): CurrentScanState {
59
64
  VerticalFlip: false,
60
65
  HorizontalFlip: false,
61
66
  Rotation: 0,
62
- Slice: 0,
67
+ Slice: 0
63
68
  },
64
69
  Coronal: {
65
70
  Version: '1.0.0',
@@ -67,7 +72,7 @@ export function inflateScanState(): CurrentScanState {
67
72
  VerticalFlip: false,
68
73
  HorizontalFlip: false,
69
74
  Rotation: 0,
70
- Slice: 0,
75
+ Slice: 0
71
76
  },
72
77
  Volume: {
73
78
  Version: '1.1.0',
@@ -83,32 +88,38 @@ export function inflateScanState(): CurrentScanState {
83
88
  Layout: {
84
89
  Version: '1.0.0',
85
90
  SwitchOnViewChange: false,
86
- PositionData: [],
91
+ PositionData: []
92
+ },
93
+ Colour: {
94
+ Version: '1.0.0',
95
+ ColourGradient: [],
96
+ AlphaGradient: [],
97
+ Name: ''
87
98
  },
88
- Colour: null,
89
99
  NavigationCube: {
90
100
  Version: '1.0.0',
101
+ NavCubeGraphicType: GraphicType.BODY_SYMBOL,
91
102
  Transform: {
92
103
  Version: '1.0.0',
93
104
  AnchorPoint: AnchorPoint.DEFAULT,
94
105
  Position: {
95
106
  Version: '1.0.0',
96
107
  X: 0,
97
- Y: 0,
108
+ Y: 0
98
109
  },
99
110
  Size: {
100
111
  Version: '1.0.0',
101
112
  X: 0,
102
- Y: 0,
103
- },
113
+ Y: 0
114
+ }
104
115
  },
105
116
  Visibility: {
106
117
  Version: '1.0.0',
107
- Value: false,
118
+ Value: false
108
119
  },
109
120
  Interactivity: {
110
121
  Version: '1.0.0',
111
- Value: false,
122
+ Value: false
112
123
  },
113
124
  Colour: {
114
125
  Version: '1.1.0',
@@ -124,7 +135,7 @@ export function inflateScanState(): CurrentScanState {
124
135
  B: 0.8,
125
136
  A: 1.0
126
137
  }
127
- },
138
+ }
128
139
  };
129
140
  }
130
141
 
@@ -141,8 +152,46 @@ export function inflateInitialScanState(): InitialScanState {
141
152
  HuUpper: 0,
142
153
  HuLower: 0,
143
154
  DefaultDisplaySettings: inflateScanState(),
155
+ ImageDirectionX: {
156
+ Version: '1.2.1',
157
+ X: 0,
158
+ Y: 0,
159
+ Z: 0
160
+ },
161
+ ImageDirectionY: {
162
+ Version: '1.2.1',
163
+ X: 0,
164
+ Y: 0,
165
+ Z: 0
166
+ },
167
+ ImageDirectionZ: {
168
+ Version: '1.2.1',
169
+ X: 0,
170
+ Y: 0,
171
+ Z: 0
172
+ },
173
+ ImageOrientationX: {
174
+ Version: '1.2.1',
175
+ X: 0,
176
+ Y: 0,
177
+ Z: 0
178
+ },
179
+ ImageOrientationY: {
180
+ Version: '1.2.1',
181
+ X: 0,
182
+ Y: 0,
183
+ Z: 0
184
+ },
185
+ ImageOrigin: {
186
+ Version: '1.2.1',
187
+ X: 0,
188
+ Y: 0,
189
+ Z: 0
190
+ },
191
+ PatientPosition: PatientPosition.LFS,
192
+ Tilt: 0,
144
193
  GreyscalePresets: [],
145
- ColourPresets: [],
194
+ ColourPresets: []
146
195
  };
147
196
  }
148
197
 
@@ -159,3 +208,17 @@ export function inflateInitialDataOverlayState(): InitialDataOverlayState {
159
208
  DataOverlay: inflateDataOverlayState()
160
209
  };
161
210
  }
211
+
212
+ export function inflateInitialMcadObjectState(): InitialMcadState {
213
+ return {
214
+ Version: '1.1.0',
215
+ Models: inflateMcadObjectState()
216
+ };
217
+ }
218
+
219
+ export function inflateMcadObjectState(): CurrentMcadState {
220
+ return {
221
+ Version: '1.1.0',
222
+ Models: []
223
+ };
224
+ }
@@ -0,0 +1,82 @@
1
+ import { InteractivityActions, NavigationCubeActions, NotificationPayload, NotificationsActions } from '@3cr/types-ts';
2
+ import { useNotification } from '@kyvg/vue3-notification';
3
+ import { t } from '@3cr/translations-ts';
4
+
5
+ const { notify } = useNotification();
6
+
7
+ type NotificationType = 'success' | 'info' | 'warn' | 'error';
8
+
9
+ function getNotificationType(action: NotificationsActions): NotificationType {
10
+ switch (action) {
11
+ case NotificationsActions.no01:
12
+ return 'success';
13
+
14
+ case NotificationsActions.no02:
15
+ return 'error';
16
+
17
+ case NotificationsActions.no03:
18
+ return 'warn';
19
+
20
+ default:
21
+ case NotificationsActions.no04:
22
+ return 'info';
23
+ }
24
+ }
25
+
26
+ function getNotificationTitle(action: NotificationsActions): string {
27
+ switch (action) {
28
+ case NotificationsActions.no01:
29
+ return 'Success';
30
+
31
+ case NotificationsActions.no02:
32
+ return 'Error';
33
+
34
+ case NotificationsActions.no03:
35
+ return 'Warning';
36
+
37
+ default:
38
+ case NotificationsActions.no04:
39
+ return 'Information';
40
+ }
41
+ }
42
+
43
+ function getNotificationText(notification: NotificationPayload): string {
44
+ return t(notification.Code, {});
45
+ }
46
+
47
+ function shouldDisplayNotification(action: NotificationsActions, notification: NotificationPayload): boolean {
48
+ // Hide type specific messages
49
+ const hiddenTypes = [NotificationsActions.no01, NotificationsActions.no04];
50
+ if (hiddenTypes.includes(action)) {
51
+ return false;
52
+ }
53
+
54
+ // Hide all slider actions
55
+ if (notification.Action.startsWith('sl')) {
56
+ return false;
57
+ }
58
+
59
+ // Hide action specific messages
60
+ const hiddenActions = [
61
+ InteractivityActions.in01,
62
+ InteractivityActions.in02,
63
+ InteractivityActions.in03,
64
+ InteractivityActions.in04,
65
+ NavigationCubeActions.nc01
66
+ ] as string[];
67
+ if (hiddenActions.includes(notification.Action)) {
68
+ return false;
69
+ }
70
+
71
+ return true;
72
+ }
73
+
74
+ export async function handleNotification(action: NotificationsActions, message: string) {
75
+ const notification = JSON.parse(message) as NotificationPayload;
76
+ if (shouldDisplayNotification(action, notification)) {
77
+ const title = getNotificationTitle(action);
78
+ const text = getNotificationText(notification);
79
+ const type = getNotificationType(action);
80
+ notify({ title, text, type });
81
+ }
82
+ }
@@ -0,0 +1,9 @@
1
+ import { Action, ActionRaw } from '@/types/action';
2
+ import { ActionData } from '@/types/action-data';
3
+
4
+ export function parseAction(data: ActionRaw): Action {
5
+ return {
6
+ ...data,
7
+ ActionData: JSON.parse(data.ActionData) as ActionData
8
+ };
9
+ }
@@ -0,0 +1,9 @@
1
+ import { CallToAction, CallToActionRaw } from '@/types/call-to-action';
2
+ import { parseAction } from '@/functions/parseAction';
3
+
4
+ export function parseCallToAction(data: CallToActionRaw): CallToAction {
5
+ return {
6
+ ...data,
7
+ Actions: data.Actions.map((action) => parseAction(action))
8
+ };
9
+ }
@@ -0,0 +1,10 @@
1
+ import { DataOverlay, DataOverlayRaw } from '@/types/data-overlay';
2
+ import { parseCallToAction } from '@/functions/parseCallToAction';
3
+ import { CallToActionRaw } from '@/types/call-to-action';
4
+
5
+ export function parseDataOverlay(data: DataOverlayRaw): DataOverlay {
6
+ return {
7
+ ...data,
8
+ CallToAction: data.CallToAction ? parseCallToAction(JSON.parse(data.CallToAction) as CallToActionRaw) : null
9
+ };
10
+ }
@@ -0,0 +1,10 @@
1
+ import { DataOverlay, DataOverlayRaw } from '@/types/data-overlay';
2
+ import { parseDataOverlay } from '@/functions/parseDataOverlay';
3
+ import { DataOverlayData, DataOverlayDataRaw } from '@/types/data-overlay-data';
4
+
5
+ export function parseDataOverlayData<T extends DataOverlay>(data: DataOverlayDataRaw): DataOverlayData<T> {
6
+ return {
7
+ ...data,
8
+ Data: parseDataOverlay(JSON.parse(data.Data) as DataOverlayRaw) as T
9
+ };
10
+ }
@@ -0,0 +1,17 @@
1
+ import { DataOverlay, DataOverlayRaw } from '@/types/data-overlay';
2
+ import { DataOverlayData, DataOverlayDataRaw } from '@/types/data-overlay-data';
3
+ import { parseDataOverlay } from '@/functions/parseDataOverlay';
4
+ import { DataOverlayInteraction, DataOverlayInteractionRaw } from '@/types/data-overlay-interaction';
5
+
6
+ type DataOverlayEvent<T extends DataOverlay> = DataOverlayData<DataOverlayInteraction<T>>;
7
+
8
+ export function parseDataOverlayEvent<T extends DataOverlay>(data: DataOverlayDataRaw): DataOverlayEvent<T> {
9
+ const interaction = JSON.parse(data.Data) as DataOverlayInteractionRaw<DataOverlayRaw>;
10
+ return {
11
+ ...data,
12
+ Data: {
13
+ ...interaction,
14
+ DataOverlay: parseDataOverlay(interaction.DataOverlay) as T
15
+ }
16
+ };
17
+ }
@@ -0,0 +1,10 @@
1
+ import { parseDataOverlay } from '@/functions/parseDataOverlay';
2
+ import { McadObjectInteraction, McadObjectInteractionRaw } from '@/types/mcad-object-interaction';
3
+ import { DataOverlayMcad } from '@/types/data-overlay-mcad';
4
+
5
+ export function parseMcadEvent(data: McadObjectInteractionRaw): McadObjectInteraction {
6
+ return {
7
+ ...data,
8
+ Mcad: parseDataOverlay(data.Mcad) as DataOverlayMcad
9
+ };
10
+ }