@3cr/viewer-browser 0.0.196 → 0.0.220

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 (370) hide show
  1. package/.circleci/config.yml +46 -22
  2. package/.prettierrc +6 -0
  3. package/components.d.ts +23 -10
  4. package/dist/Viewer3CR.js +37 -46
  5. package/dist/Viewer3CR.mjs +22640 -20897
  6. package/dist/Viewer3CR.umd.js +37 -46
  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 +23 -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 +26 -29
  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 +35 -45
  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 +14 -4
  59. package/src/components/demo/__tests__/DemoModal.spec.ts +9 -8
  60. package/src/components/demo/__tests__/DemoPatientModal.spec.ts +11 -10
  61. package/src/components/demo/__tests__/options.spec.ts +1 -1
  62. package/src/components/demo/licence/__tests__/DemoLicenceEnableCloudStorageModal.spec.ts +11 -10
  63. package/src/components/demo/licence/__tests__/DemoLicenceInfoModal.spec.ts +21 -11
  64. package/src/components/demo/licence/__tests__/DemoLicenceSendToPartyModal.spec.ts +10 -10
  65. package/src/components/demo/licence/__tests__/DemoLicenceShareToMobileModal.spec.ts +14 -13
  66. package/src/components/demo/options.ts +54 -59
  67. package/src/components/demo/patient/__tests__/DemoPatientEnableCloudStorageModal.spec.ts +11 -10
  68. package/src/components/demo/patient/__tests__/DemoPatientInfoModal.spec.ts +12 -11
  69. package/src/components/demo/patient/__tests__/DemoPatientSendToPartyModal.spec.ts +10 -10
  70. package/src/components/demo/patient/__tests__/DemoPatientShareToMobileModal.spec.ts +14 -13
  71. package/src/components/modal/ActionRail.vue +7 -11
  72. package/src/components/modal/AskAI.vue +35 -50
  73. package/src/components/modal/CloseViewerModal.vue +22 -57
  74. package/src/components/modal/MftpWebGL3DRModal.vue +152 -570
  75. package/src/components/modal/ViewerActionRail.vue +50 -39
  76. package/src/components/modal/ViewerNavigationDrawer.vue +10 -8
  77. package/src/components/modal/ViewerNavigationDrawerContent.vue +82 -49
  78. package/src/components/modal/ViewerNavigationDrawerFooter.vue +57 -60
  79. package/src/components/modal/ViewerNavigationDrawerHeader.vue +13 -48
  80. package/src/components/modal/ViewerScanView.vue +114 -0
  81. package/src/components/modal/WebGL3DR.vue +84 -0
  82. package/src/components/modal/__tests__/ActionRail.spec.ts +10 -0
  83. package/src/components/modal/__tests__/AskAI.spec.ts +33 -0
  84. package/src/components/modal/__tests__/CloseViewerModal.spec.ts +24 -14
  85. package/src/components/modal/__tests__/MftpWebGL3DRModal.spec.ts +147 -176
  86. package/src/components/modal/__tests__/ViewerActionRail.spec.ts +11 -0
  87. package/src/components/modal/__tests__/ViewerNavigationDrawer.spec.ts +10 -12
  88. package/src/components/modal/__tests__/ViewerNavigationDrawerContent.spec.ts +4 -22
  89. package/src/components/modal/__tests__/ViewerNavigationDrawerFooter.spec.ts +35 -32
  90. package/src/components/modal/__tests__/ViewerNavigationDrawerHeader.spec.ts +11 -9
  91. package/src/components/modal/__tests__/ViewerScanView.spec.ts +60 -0
  92. package/src/components/modal/__tests__/WebGL3DR.spec.ts +57 -0
  93. package/src/components/modal/actions/Flip3dAction.vue +1 -1
  94. package/src/components/modal/actions/FlipHorizontalAction.vue +5 -10
  95. package/src/components/modal/actions/FlipVerticalAction.vue +5 -10
  96. package/src/components/modal/actions/FullscreenAction.vue +6 -11
  97. package/src/components/modal/actions/HideViewAction.vue +38 -0
  98. package/src/components/modal/actions/NavigationCubeAction.vue +7 -14
  99. package/src/components/modal/actions/PanAction.vue +4 -4
  100. package/src/components/modal/actions/ResetViewAction.vue +1 -1
  101. package/src/components/modal/actions/Rotate2dAction.vue +8 -20
  102. package/src/components/modal/actions/Slice3dAction.vue +10 -32
  103. package/src/components/modal/actions/ZoomAction.vue +1 -1
  104. package/src/components/modal/actions/__tests__/Action.spec.ts +8 -9
  105. package/src/components/modal/actions/__tests__/Flip3dAction.spec.ts +6 -8
  106. package/src/components/modal/actions/__tests__/FlipHorizontalAction.spec.ts +6 -7
  107. package/src/components/modal/actions/__tests__/FlipVerticalAction.spec.ts +6 -7
  108. package/src/components/modal/actions/__tests__/FullscreenAction.spec.ts +9 -10
  109. package/src/components/modal/actions/__tests__/NavigationCubeAction.spec.ts +11 -11
  110. package/src/components/modal/actions/__tests__/PanAction.spec.ts +9 -10
  111. package/src/components/modal/actions/__tests__/ResetViewAction.spec.ts +7 -7
  112. package/src/components/modal/actions/__tests__/Rotate2dAction.spec.ts +6 -8
  113. package/src/components/modal/actions/__tests__/Slice3dAction.spec.ts +23 -5
  114. package/src/components/modal/actions/__tests__/ZoomAction.spec.ts +8 -10
  115. package/src/components/modal/buttons/AutoAnnotateBtn.vue +29 -0
  116. package/src/components/modal/buttons/__tests__/AutoAnnotateBtn.spec.ts +28 -0
  117. package/src/components/modal/menus/FileMenu.vue +80 -0
  118. package/src/components/modal/menus/SettingsMenu.vue +111 -0
  119. package/src/components/modal/menus/__tests__/FileMenu.spec.ts +110 -0
  120. package/src/components/modal/menus/__tests__/SettingsMenu.spec.ts +71 -0
  121. package/src/components/shared/DoubleSliderSelector.vue +142 -0
  122. package/src/components/shared/UpdateSnackbar.vue +72 -0
  123. package/src/components/{selectors → shared}/ValueSelector.vue +9 -12
  124. package/src/components/shared/__tests__/DoubleSliderSelector.spec.ts +83 -0
  125. package/src/components/shared/__tests__/LoadingSpinner.spec.ts +9 -0
  126. package/src/components/shared/__tests__/UpdateSnackbar.spec.ts +116 -0
  127. package/src/components/shared/__tests__/ValueSelector.spec.ts +39 -0
  128. package/src/components/shared/__tests__/VerticalSliderSelector.spec.ts +50 -0
  129. package/src/components/views/AnnotationTreeView.vue +234 -0
  130. package/src/components/{modal/ViewerDisplaySettings.vue → views/DisplaySettings.vue} +7 -15
  131. package/src/components/views/MarkupTreeView.vue +199 -0
  132. package/src/components/views/McadObjectTreeView.vue +119 -0
  133. package/src/components/views/__tests__/AnnotationTreeView.spec.ts +62 -0
  134. package/src/components/{modal/__tests__/ViewerDisplaySettings.spec.ts → views/__tests__/DisplaySettings.spec.ts} +24 -20
  135. package/src/components/views/__tests__/MarkupTreeView.spec.ts +41 -0
  136. package/src/components/views/__tests__/McadObjectTreeView.spec.ts +47 -0
  137. package/src/components/views/modals/DataOverlayModal.vue +89 -0
  138. package/src/components/views/modals/DataOverlayModalManager.vue +104 -0
  139. package/src/components/views/modals/__tests__/DataOverlayModal.spec.ts +33 -0
  140. package/src/components/views/modals/__tests__/DataOverlayModalManager.spec.ts +93 -0
  141. package/src/components/views/shared/MaskIcon.vue +44 -0
  142. package/src/components/views/shared/ObjectColor.vue +31 -0
  143. package/src/components/views/shared/ObjectLabel.vue +30 -0
  144. package/src/components/views/shared/Opacity.vue +66 -0
  145. package/src/components/views/shared/VisibilityBtn.vue +25 -0
  146. package/src/components/views/shared/__tests__/MaskIcon.spec.ts +10 -0
  147. package/src/components/views/shared/__tests__/ObjectColor.spec.ts +10 -0
  148. package/src/components/views/shared/__tests__/ObjectLabel.spec.ts +10 -0
  149. package/src/components/views/shared/__tests__/Opacity.spec.ts +24 -0
  150. package/src/components/views/shared/__tests__/VisibilityBtn.spec.ts +11 -0
  151. package/src/components/views/types/annotation-tree-view-item-child-action.ts +6 -0
  152. package/src/components/views/types/annotation-tree-view-item-child.ts +9 -0
  153. package/src/components/views/types/annotation-tree-view-item.ts +13 -0
  154. package/src/components/views/types/markup-tree-view-item-child.ts +6 -0
  155. package/src/components/views/types/markup-tree-view-item.ts +14 -0
  156. package/src/components/views/types/mcad-object-tree-view-item.ts +13 -0
  157. package/src/composables/__tests__/useAnnotations.spec.ts +35 -0
  158. package/src/composables/__tests__/useEventListener.spec.ts +32 -0
  159. package/src/composables/__tests__/useIntroJs.spec.ts +51 -0
  160. package/src/composables/__tests__/useMarkups.spec.ts +39 -0
  161. package/src/composables/__tests__/useMcadObjects.spec.ts +36 -0
  162. package/src/composables/__tests__/useMouse.spec.ts +20 -0
  163. package/src/{components/modal/composables → composables}/__tests__/useNavigationCubeObserver.spec.ts +17 -12
  164. package/src/{dataLayer → composables}/__tests__/useViewer3cr.spec.ts +1 -2
  165. package/src/composables/useAnnotations.ts +37 -0
  166. package/src/composables/useEventListener.ts +25 -0
  167. package/src/composables/useIntroJs.ts +125 -0
  168. package/src/composables/useMarkups.ts +41 -0
  169. package/src/composables/useMcadObjects.ts +32 -0
  170. package/src/composables/useMouse.ts +14 -0
  171. package/src/{components/modal/composables → composables}/useNavigationCubeObserver.ts +35 -25
  172. package/src/composables/useScanMovement.ts +25 -0
  173. package/src/composables/useScanSliders.ts +36 -0
  174. package/src/composables/useVersion3cr.ts +7 -0
  175. package/src/composables/useViewer3cr.ts +7 -0
  176. package/src/composables/useViewerOptions.ts +35 -0
  177. package/src/{dataLayer → functions}/__tests__/clamp.spec.ts +1 -2
  178. package/src/functions/__tests__/layoutOverlayStyle.spec.ts +325 -0
  179. package/src/{helpers/__tests__/model-helper.spec.ts → functions/__tests__/modelHelper.spec.ts} +77 -40
  180. package/src/{notifications → functions}/__tests__/notification.spec.ts +19 -29
  181. package/src/functions/__tests__/parseAction.spec.ts +9 -0
  182. package/src/functions/__tests__/parseCallToAction.spec.ts +11 -0
  183. package/src/functions/__tests__/parseDataOverlay.spec.ts +15 -0
  184. package/src/functions/__tests__/parseDataOverlayData.spec.ts +9 -0
  185. package/src/functions/__tests__/parseDataOverlayEvent.spec.ts +10 -0
  186. package/src/functions/__tests__/parseMcadEvent.spec.ts +10 -0
  187. package/src/functions/layoutOverlayStyle.ts +84 -0
  188. package/src/{helpers → functions}/modelHelper.ts +79 -18
  189. package/src/{notifications → functions}/notification.ts +12 -14
  190. package/src/functions/parseAction.ts +9 -0
  191. package/src/functions/parseCallToAction.ts +9 -0
  192. package/src/functions/parseDataOverlay.ts +10 -0
  193. package/src/functions/parseDataOverlayData.ts +10 -0
  194. package/src/functions/parseDataOverlayEvent.ts +17 -0
  195. package/src/functions/parseMcadEvent.ts +10 -0
  196. package/src/functions/rgbaToCss.ts +13 -0
  197. package/src/main.ts +48 -9
  198. package/src/{dataLayer → models}/__tests__/eventHandlers.spec.ts +2 -3
  199. package/src/models/__tests__/loadViewerOptions.spec.ts +72 -0
  200. package/src/models/__tests__/loadViewerPayload.spec.ts +10 -0
  201. package/src/models/__tests__/scanState.spec.ts +190 -0
  202. package/src/models/callbacks.ts +4 -0
  203. package/src/models/loadViewerOptions.ts +40 -0
  204. package/src/models/loadViewerPayload.ts +24 -0
  205. package/src/{dataLayer → models}/scanState.ts +63 -74
  206. package/src/plugins/__tests__/usePlugins.spec.ts +12 -0
  207. package/src/plugins/__tests__/vuetify.spec.ts +3 -4
  208. package/src/plugins/usePlugins.ts +8 -0
  209. package/src/plugins/vuetify.ts +31 -65
  210. package/src/services/{gpt/__tests__ → __tests__}/gpt.service.spec.ts +2 -2
  211. package/src/services/__tests__/service-worker.service.spec.ts +32 -0
  212. package/src/{dataLayer/__tests__/viewer3cr.spec.ts → services/__tests__/viewer-3cr.service.spec.ts} +97 -36
  213. package/src/services/gpt.service.ts +17 -0
  214. package/src/services/service-worker.service.ts +16 -0
  215. package/src/{dataLayer/viewer3cr.ts → services/viewer-3cr.service.ts} +269 -150
  216. package/src/types/action.ts +13 -0
  217. package/src/types/call-to-action.ts +9 -0
  218. package/src/types/colour.ts +6 -0
  219. package/src/types/data-overlay-angle.ts +16 -0
  220. package/src/types/data-overlay-annotation.ts +18 -0
  221. package/src/types/data-overlay-data.ts +15 -0
  222. package/src/types/data-overlay-info.ts +14 -0
  223. package/src/types/data-overlay-interaction.ts +15 -0
  224. package/src/types/data-overlay-length.ts +16 -0
  225. package/src/types/data-overlay-markup.ts +7 -0
  226. package/src/types/data-overlay-mcad.ts +20 -0
  227. package/src/types/data-overlay-polygon.ts +18 -0
  228. package/src/types/data-overlay.ts +16 -0
  229. package/src/types/gpt-question.ts +4 -0
  230. package/src/types/gpt-response-payload.ts +6 -0
  231. package/src/types/mcad-object-interaction.ts +15 -0
  232. package/src/types/segment-angle.ts +5 -0
  233. package/src/types/vector2.ts +4 -0
  234. package/src/types/vector3.ts +5 -0
  235. package/test/fakers/action-data.faker.ts +11 -0
  236. package/test/fakers/action.faker.ts +19 -0
  237. package/test/fakers/call-to-action.faker.ts +17 -0
  238. package/test/fakers/colour.faker.ts +17 -0
  239. package/test/fakers/data-overlay-angle.faker.ts +37 -0
  240. package/test/fakers/data-overlay-annotation.faker.ts +41 -0
  241. package/test/fakers/data-overlay-data.faker.ts +97 -0
  242. package/test/fakers/data-overlay-info.faker.ts +29 -0
  243. package/test/fakers/data-overlay-interaction.faker.ts +62 -0
  244. package/test/fakers/data-overlay-length.faker.ts +37 -0
  245. package/test/fakers/data-overlay-mcad.faker.ts +40 -0
  246. package/test/fakers/data-overlay-polygon.faker.ts +39 -0
  247. package/test/fakers/gpt-question.faker.ts +11 -0
  248. package/test/fakers/gpt-response.faker.ts +12 -0
  249. package/test/fakers/invert-transform.faker.ts +16 -0
  250. package/test/fakers/mcad-object-interaction.faker.ts +22 -0
  251. package/test/fakers/orientation.faker.ts +17 -0
  252. package/test/fakers/segment-angle.faker.ts +12 -0
  253. package/test/fakers/vector2.faker.ts +12 -0
  254. package/test/fakers/vector3.faker.ts +16 -0
  255. package/test/plugins/findByTestId.ts +25 -0
  256. package/test/plugins/vuetify.ts +16 -0
  257. package/test/setup.ts +16 -5
  258. package/tsconfig.json +4 -15
  259. package/vite.config.mts +20 -46
  260. package/vitest.config.mts +24 -43
  261. package/index.ts +0 -72
  262. package/src/assets/images/dark/3DICOM.png +0 -0
  263. package/src/assets/images/dark/3dicom-logo.svg +0 -1
  264. package/src/assets/images/light/3DICOM.png +0 -0
  265. package/src/assets/images/light/3dicom-logo.svg +0 -1
  266. package/src/assets/logo.png +0 -0
  267. package/src/assets/logo.svg +0 -6
  268. package/src/components/WebGL3DR.vue +0 -102
  269. package/src/components/__tests__/webgl3dr.spec.ts +0 -37
  270. package/src/components/icons/liver.vue +0 -21
  271. package/src/components/loading/__tests__/loading-spinner.spec.ts +0 -11
  272. package/src/components/modal/ViewerAnnotationModal.vue +0 -115
  273. package/src/components/modal/ViewerAnnotations.vue +0 -283
  274. package/src/components/modal/__tests__/ViewerAnnotationModal.spec.ts +0 -79
  275. package/src/components/modal/composables/useEventListener.ts +0 -22
  276. package/src/components/selectors/__tests__/value-selector.spec.ts +0 -53
  277. package/src/components/sliders/DoubleSliderSelector.vue +0 -141
  278. package/src/components/sliders/__tests__/double-slider-selector.spec.ts +0 -104
  279. package/src/components/sliders/__tests__/vertical-slider-selector.spec.ts +0 -61
  280. package/src/dataLayer/__tests__/getIconForPreset.spec.ts +0 -40
  281. package/src/dataLayer/__tests__/patchDataOverlay.spec.ts +0 -88
  282. package/src/dataLayer/__tests__/scanState.spec.ts +0 -93
  283. package/src/dataLayer/getIconForPreset.ts +0 -11
  284. package/src/dataLayer/patchDataOverlay.ts +0 -101
  285. package/src/dataLayer/useViewer3cr.ts +0 -7
  286. package/src/helpers/__tests__/layout-overlay-style.spec.ts +0 -290
  287. package/src/helpers/__tests__/utils.spec.ts +0 -70
  288. package/src/helpers/layoutOverlayStyle.ts +0 -96
  289. package/src/helpers/utils.ts +0 -16
  290. package/src/models/Callbacks.ts +0 -2
  291. package/src/models/LoadViewerOptions.ts +0 -31
  292. package/src/models/LoadViewerPayload.ts +0 -9
  293. package/src/models/__tests__/load-viewer-options.spec.ts +0 -22
  294. package/src/plugins/__tests__/index.spec.ts +0 -19
  295. package/src/plugins/index.ts +0 -17
  296. package/src/services/gpt/gpt.service.ts +0 -27
  297. package/static/3cr-types-browser/index.ts +0 -74
  298. package/static/3cr-types-browser/types/Action.ts +0 -6
  299. package/static/3cr-types-browser/types/AlphaKeys.ts +0 -5
  300. package/static/3cr-types-browser/types/AnchorPoint.ts +0 -12
  301. package/static/3cr-types-browser/types/CallToAction.ts +0 -5
  302. package/static/3cr-types-browser/types/ColourData.ts +0 -7
  303. package/static/3cr-types-browser/types/ColourPresetData.ts +0 -9
  304. package/static/3cr-types-browser/types/CurrentDataOverlayState.ts +0 -6
  305. package/static/3cr-types-browser/types/CurrentScanState.ts +0 -22
  306. package/static/3cr-types-browser/types/DataOverlay.ts +0 -22
  307. package/static/3cr-types-browser/types/DataOverlayActions.ts +0 -14
  308. package/static/3cr-types-browser/types/DataOverlayData.ts +0 -8
  309. package/static/3cr-types-browser/types/DataOverlayEvent.ts +0 -8
  310. package/static/3cr-types-browser/types/DecryptionKey.ts +0 -4
  311. package/static/3cr-types-browser/types/DisplaySettings.ts +0 -10
  312. package/static/3cr-types-browser/types/EmptyPayload.ts +0 -3
  313. package/static/3cr-types-browser/types/EnumPayload.ts +0 -4
  314. package/static/3cr-types-browser/types/FileManagementActions.ts +0 -11
  315. package/static/3cr-types-browser/types/FlipValue.ts +0 -7
  316. package/static/3cr-types-browser/types/FrontEndInterfaces.ts +0 -14
  317. package/static/3cr-types-browser/types/GradientKeys.ts +0 -7
  318. package/static/3cr-types-browser/types/GreyscalePresetData.ts +0 -6
  319. package/static/3cr-types-browser/types/InitialDataOverlayState.ts +0 -6
  320. package/static/3cr-types-browser/types/InitialScanState.ts +0 -19
  321. package/static/3cr-types-browser/types/InteractionType.ts +0 -8
  322. package/static/3cr-types-browser/types/InteractivityActions.ts +0 -6
  323. package/static/3cr-types-browser/types/InteractivityState.ts +0 -4
  324. package/static/3cr-types-browser/types/InvertTransformData.ts +0 -6
  325. package/static/3cr-types-browser/types/LayoutActions.ts +0 -6
  326. package/static/3cr-types-browser/types/LayoutData.ts +0 -7
  327. package/static/3cr-types-browser/types/LoadDataSet.ts +0 -6
  328. package/static/3cr-types-browser/types/LoadSessionState.ts +0 -4
  329. package/static/3cr-types-browser/types/LocalLoadDataset.ts +0 -3
  330. package/static/3cr-types-browser/types/MovementData.ts +0 -7
  331. package/static/3cr-types-browser/types/NavigationCubeActions.ts +0 -8
  332. package/static/3cr-types-browser/types/NavigationCubeData.ts +0 -12
  333. package/static/3cr-types-browser/types/NavigationCubeTransform.ts +0 -9
  334. package/static/3cr-types-browser/types/NotificationPayload.ts +0 -7
  335. package/static/3cr-types-browser/types/NotificationsActions.ts +0 -6
  336. package/static/3cr-types-browser/types/Object.ts +0 -1
  337. package/static/3cr-types-browser/types/ObjectColour.ts +0 -7
  338. package/static/3cr-types-browser/types/ObjectIcon.ts +0 -5
  339. package/static/3cr-types-browser/types/ObjectInvert.ts +0 -7
  340. package/static/3cr-types-browser/types/ObjectSize.ts +0 -7
  341. package/static/3cr-types-browser/types/ObjectSize2D.ts +0 -7
  342. package/static/3cr-types-browser/types/ObjectVisible.ts +0 -5
  343. package/static/3cr-types-browser/types/PositionData.ts +0 -14
  344. package/static/3cr-types-browser/types/PresetsActions.ts +0 -4
  345. package/static/3cr-types-browser/types/RotationValue.ts +0 -7
  346. package/static/3cr-types-browser/types/ScanMovementActions.ts +0 -27
  347. package/static/3cr-types-browser/types/ScanMovementData.ts +0 -3
  348. package/static/3cr-types-browser/types/ScanOrientationActions.ts +0 -6
  349. package/static/3cr-types-browser/types/ScanStateActions.ts +0 -4
  350. package/static/3cr-types-browser/types/ScanView.ts +0 -6
  351. package/static/3cr-types-browser/types/SettingsData.ts +0 -12
  352. package/static/3cr-types-browser/types/SlicerData.ts +0 -9
  353. package/static/3cr-types-browser/types/SliderValue.ts +0 -4
  354. package/static/3cr-types-browser/types/SlidersActions.ts +0 -18
  355. package/static/3cr-types-browser/types/Vector2Data.ts +0 -5
  356. package/static/3cr-types-browser/types/Vector3Data.ts +0 -6
  357. package/static/3cr-types-browser/types/VectorMovementData.ts +0 -8
  358. package/static/3cr-types-browser/types/ViewInteractiveMode.ts +0 -5
  359. package/static/3cr-types-browser/types/ViewOrientation.ts +0 -8
  360. package/static/3cr-types-browser/types/ViewOrientations.ts +0 -10
  361. package/static/3cr-types-browser/types/ViewSelectionActions.ts +0 -9
  362. package/static/3cr-types-browser/types/ViewToggleData.ts +0 -7
  363. package/static/3cr-types-browser/types/VolumeOrientation.ts +0 -7
  364. package/test/helper.ts +0 -44
  365. /package/src/components/{loading → shared}/LoadingSpinner.vue +0 -0
  366. /package/src/components/{sliders → shared}/VerticalSliderSelector.vue +0 -0
  367. /package/{config.ts → src/config.ts} +0 -0
  368. /package/src/{dataLayer → functions}/clamp.ts +0 -0
  369. /package/src/{dataLayer → models}/eventHandlers.ts +0 -0
  370. /package/{static/3cr-types-browser/types/ActionData.ts → src/types/action-data.ts} +0 -0
@@ -1,47 +1,48 @@
1
- import { describe, expect, it } from "vitest";
2
- import { AnchorPoint, ScanView, ViewInteractiveMode } from "@3cr/types-ts";
3
- import {
4
- inflateInitialScanState,
5
- inflateScanState,
6
- } from "@/helpers/modelHelper";
1
+ import { AnchorPoint, PatientPosition, ScanView, ViewInteractiveMode } from '@3cr/types-ts';
2
+ import { inflateInitialScanState, inflateScanState } from '@/functions/modelHelper';
7
3
 
8
- describe("inflateScanState", () => {
9
- it("should inflateScanState", () => {
4
+ describe('model helper tests', () => {
5
+ it('should inflateScanState', () => {
10
6
  expect(inflateScanState()).toStrictEqual({
11
- Version: "1.0.0",
7
+ Version: '1.0.0',
12
8
  ScanMovement: {
13
- Version: '1.1.0',
9
+ Version: '1.1.0'
14
10
  },
15
11
  Display: {
16
- Version: "1.0.0",
12
+ Version: '1.0.0',
17
13
  Brightness: 50,
18
14
  Contrast: 50,
19
15
  Opacity: 50,
20
16
  WindowLower: 0,
21
17
  WindowUpper: 100,
22
18
  ThresholdLower: 0,
23
- ThresholdUpper: 100,
19
+ ThresholdUpper: 100
20
+ },
21
+ Colour: {
22
+ AlphaGradient: [],
23
+ ColourGradient: [],
24
+ Name: '',
25
+ Version: '1.0.0'
24
26
  },
25
- Colour: null,
26
27
  CurrentView: ScanView.Volume,
27
28
  Slice: {
28
- Version: "1.0.0",
29
+ Version: '1.0.0',
29
30
  TransverseLower: 0,
30
31
  TransverseUpper: 0,
31
32
  SagittalLower: 0,
32
33
  SagittalUpper: 0,
33
34
  CoronalLower: 0,
34
- CoronalUpper: 0,
35
+ CoronalUpper: 0
35
36
  },
36
37
  InteractionSettings: {
37
- Version: "1.0.0",
38
+ Version: '1.0.0',
38
39
  PanSensivitity: 0,
39
40
  ZoomSensitivity: 0,
40
41
  RotateSensitivity: 0,
41
42
  CameraRotateSensitivity: 0,
42
43
  KeyboardEnabled: true,
43
44
  MouseEnabled: true,
44
- InteractionMode: ViewInteractiveMode.STATIC,
45
+ InteractionMode: ViewInteractiveMode.STATIC
45
46
  },
46
47
  Orientations: {
47
48
  Version: '1.0.0',
@@ -51,7 +52,7 @@ describe("inflateScanState", () => {
51
52
  VerticalFlip: false,
52
53
  HorizontalFlip: false,
53
54
  Rotation: 0,
54
- Slice: 0,
55
+ Slice: 0
55
56
  },
56
57
  Sagittal: {
57
58
  Version: '1.0.0',
@@ -59,7 +60,7 @@ describe("inflateScanState", () => {
59
60
  VerticalFlip: false,
60
61
  HorizontalFlip: false,
61
62
  Rotation: 0,
62
- Slice: 0,
63
+ Slice: 0
63
64
  },
64
65
  Coronal: {
65
66
  Version: '1.0.0',
@@ -67,7 +68,7 @@ describe("inflateScanState", () => {
67
68
  VerticalFlip: false,
68
69
  HorizontalFlip: false,
69
70
  Rotation: 0,
70
- Slice: 0,
71
+ Slice: 0
71
72
  },
72
73
  Volume: {
73
74
  Version: '1.1.0',
@@ -81,33 +82,33 @@ describe("inflateScanState", () => {
81
82
  }
82
83
  },
83
84
  Layout: {
84
- Version: "1.0.0",
85
+ Version: '1.0.0',
85
86
  SwitchOnViewChange: false,
86
- PositionData: [],
87
+ PositionData: []
87
88
  },
88
89
  NavigationCube: {
89
- Version: "1.0.0",
90
+ Version: '1.0.0',
90
91
  Transform: {
91
- Version: "1.0.0",
92
+ Version: '1.0.0',
92
93
  AnchorPoint: AnchorPoint.DEFAULT,
93
94
  Position: {
94
- Version: "1.0.0",
95
+ Version: '1.0.0',
95
96
  X: 0,
96
- Y: 0,
97
+ Y: 0
97
98
  },
98
99
  Size: {
99
- Version: "1.0.0",
100
+ Version: '1.0.0',
100
101
  X: 0,
101
- Y: 0,
102
- },
102
+ Y: 0
103
+ }
103
104
  },
104
105
  Visibility: {
105
- Version: "1.0.0",
106
- Value: false,
106
+ Version: '1.0.0',
107
+ Value: false
107
108
  },
108
109
  Interactivity: {
109
- Version: "1.0.0",
110
- Value: false,
110
+ Version: '1.0.0',
111
+ Value: false
111
112
  },
112
113
  Colour: {
113
114
  Version: '1.1.0',
@@ -123,27 +124,63 @@ describe("inflateScanState", () => {
123
124
  B: 0.8,
124
125
  A: 1.0
125
126
  }
126
- },
127
+ }
127
128
  });
128
129
  });
129
- });
130
130
 
131
- describe("inflateInitialScanState", () => {
132
- it("should inflateInitialScanState", () => {
131
+ it('should inflateInitialScanState', () => {
133
132
  expect(inflateInitialScanState()).toStrictEqual({
134
- Version: "1.0.0",
133
+ Version: '1.0.0',
135
134
  XSlices: 0,
136
135
  YSlices: 0,
137
136
  ZSlices: 0,
138
137
  XSpacing: 0,
139
138
  YSpacing: 0,
140
139
  ZSpacing: 0,
141
- Modality: "CT",
140
+ Modality: 'CT',
142
141
  HuUpper: 0,
143
142
  HuLower: 0,
144
143
  DefaultDisplaySettings: inflateScanState(),
144
+ ImageDirectionX: {
145
+ Version: '1.2.1',
146
+ X: 0,
147
+ Y: 0,
148
+ Z: 0
149
+ },
150
+ ImageDirectionY: {
151
+ Version: '1.2.1',
152
+ X: 0,
153
+ Y: 0,
154
+ Z: 0
155
+ },
156
+ ImageDirectionZ: {
157
+ Version: '1.2.1',
158
+ X: 0,
159
+ Y: 0,
160
+ Z: 0
161
+ },
162
+ ImageOrientationX: {
163
+ Version: '1.2.1',
164
+ X: 0,
165
+ Y: 0,
166
+ Z: 0
167
+ },
168
+ ImageOrientationY: {
169
+ Version: '1.2.1',
170
+ X: 0,
171
+ Y: 0,
172
+ Z: 0
173
+ },
174
+ ImageOrigin: {
175
+ Version: '1.2.1',
176
+ X: 0,
177
+ Y: 0,
178
+ Z: 0
179
+ },
180
+ PatientPosition: PatientPosition.LFS,
181
+ Tilt: 0,
145
182
  GreyscalePresets: [],
146
- ColourPresets: [],
183
+ ColourPresets: []
147
184
  });
148
185
  });
149
186
  });
@@ -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,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
+ }