@ohif/app 3.7.0-beta.9 → 3.7.0-beta.90

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 (66) hide show
  1. package/dist/{917.bundle.0edb40e9d9467dd3a189.js → 12.bundle.c51f9611deb347508909.js} +6 -6
  2. package/dist/{295.bundle.957b1159fec14b9199a1.js → 125.bundle.253395f320b72180da63.js} +6 -6
  3. package/dist/{351.bundle.0742237651aef9694a65.js → 181.bundle.73fc96c6b3ab1fabedc8.js} +226 -204
  4. package/dist/{351.css → 181.css} +1 -1
  5. package/dist/{744.bundle.c459c690581bc8a522d8.js → 19.bundle.a858382f8b2b4ba8d3cb.js} +240 -375
  6. package/dist/{606.bundle.5d876f5f3dd8287f0a28.js → 202.bundle.96bbb4547a346fe3921f.js} +1420 -750
  7. package/dist/{926.bundle.dbc9d0e591cb9217fda2.js → 220.bundle.f7e1c96c94245e70f2be.js} +990 -400
  8. package/dist/221.bundle.e2afcda7523b858d7edb.js +1723 -0
  9. package/dist/221.css +2 -0
  10. package/dist/{664.bundle.09abae984223969d1bde.js → 23.bundle.e008ad788170f2ed5569.js} +5 -6
  11. package/dist/{976.bundle.3f8bfb620791f4508420.js → 236.bundle.80a95257cee3c60edce1.js} +88 -104
  12. package/dist/{55.bundle.550a823e75eb608e8d5e.js → 250.bundle.4bebed43526c7e06344f.js} +52 -36
  13. package/dist/{973.bundle.5aa91607481865ead93f.js → 281.bundle.1d024348a9e68cabcb75.js} +18 -14
  14. package/dist/{82.bundle.978be6f7595202cd342b.js → 342.bundle.4949499cddc0e73aed86.js} +1765 -476
  15. package/dist/{404.bundle.83acdec604ed84f4b772.js → 359.bundle.293ba004301607ab27ff.js} +46 -131
  16. package/dist/{192.bundle.655fc9c5aeff41110aa9.js → 370.bundle.28d7737cee0832695236.js} +113 -99
  17. package/dist/{790.bundle.08e37fd3b64af8dd8e78.js → 410.bundle.492283c5b53922d55610.js} +11 -9
  18. package/dist/{151.bundle.31ea35044218837bf73f.js → 417.bundle.af0a207c29b109f84159.js} +49 -17
  19. package/dist/{569.bundle.c8e771a8d28e237b32be.js → 451.bundle.1c714bfb8b66d3a5adfb.js} +86 -106
  20. package/dist/{581.bundle.dc6197189f7c88c27d4c.js → 471.bundle.4aaec34d87b0c93687c1.js} +78 -99
  21. package/dist/{199.bundle.251f86c6e2eee85c49a5.js → 506.bundle.0e2f4377f64c0c78e5f9.js} +11 -9
  22. package/dist/{531.bundle.2a82fb1d69e5b57cc72b.js → 530.bundle.a03b6f942ace3e1baa1e.js} +726 -447
  23. package/dist/579.css +1 -0
  24. package/dist/{935.bundle.deeffff0e4f7b528e3c3.js → 604.bundle.a51f83e64004bca5f497.js} +2 -3
  25. package/dist/613.bundle.b5c524ec95748332cb1d.js +532 -0
  26. package/dist/{984.bundle.0c8b7d8388a662ad5ebc.js → 663.bundle.5bed0c9a4ac30d4be7e9.js} +68 -38
  27. package/dist/{205.bundle.b5a473c200dcf2bbcdb4.js → 686.bundle.dccef1f36e4bc79bcc48.js} +6 -6
  28. package/dist/{50.bundle.bec52570fe00c2ccced8.js → 687.bundle.aefdf23ca61906e42117.js} +218 -9
  29. package/dist/{331.bundle.bd0c13931a21d53086c9.js → 743.bundle.4bfe6e562ffb2c22708f.js} +26281 -21326
  30. package/dist/{728.bundle.d13856835357400fef82.js → 774.bundle.7528cba56a1407357144.js} +95 -64
  31. package/dist/{381.bundle.0905e683605fcbc0895f.js → 775.bundle.2285e7e0e67878948c0d.js} +16 -16
  32. package/dist/{283.bundle.b43e001c27e02b0199aa.js → 782.bundle.98fa888b2e3f8ad7d37e.js} +117 -67
  33. package/dist/{642.bundle.1ab1e9ea67caeaedb189.js → 814.bundle.5ab8b6dbbade2e65975f.js} +6 -6
  34. package/dist/{799.bundle.758558e64147e5aad612.js → 822.bundle.00de6455c18be0307b41.js} +81 -34
  35. package/dist/831.bundle.83658f62fcc769043605.js +16700 -0
  36. package/dist/{707.bundle.9622c314b0ea3488d69a.js → 877.bundle.896122a750e45a7719ae.js} +1022 -708
  37. package/dist/{953.bundle.3b0189ebc11cf0946f18.js → 886.bundle.7324d84913daffb6a4c4.js} +34 -29
  38. package/dist/945.min.worker.js +1 -1
  39. package/dist/945.min.worker.js.map +1 -1
  40. package/dist/{270.bundle.4564621556b0f963a004.js → 957.bundle.8c09a01840ab8aa32734.js} +7093 -987
  41. package/dist/{208.bundle.05451122c341d80d3c22.js → 99.bundle.eff869422ff7114f5403.js} +85 -104
  42. package/dist/_redirects +1 -1
  43. package/dist/app-config.js +35 -17
  44. package/dist/{app.bundle.d2ebd2fcc8b88864ebeb.js → app.bundle.ccda811fb90f522f9ec2.js} +71937 -66734
  45. package/dist/app.bundle.css +13 -12
  46. package/dist/assets/yandex-browser-manifest.json +1 -1
  47. package/dist/cornerstoneDICOMImageLoader.min.js +1 -1
  48. package/dist/cornerstoneDICOMImageLoader.min.js.map +1 -1
  49. package/dist/{dicom-microscopy-viewer.bundle.aa60bdf008c32c39cfd7.js → dicom-microscopy-viewer.bundle.2c146384eb9466d02ff8.js} +5 -4
  50. package/dist/es6-shim.min.js +3569 -2
  51. package/dist/google.js +8 -7
  52. package/dist/index.html +1 -1
  53. package/dist/{index.worker.1c69152d710fa7b84bce.worker.js → index.worker.e62ecca63f1a2e124230.worker.js} +2 -2
  54. package/dist/index.worker.e62ecca63f1a2e124230.worker.js.map +1 -0
  55. package/dist/init-service-worker.js +3 -5
  56. package/dist/oidc-client.min.js +10857 -39
  57. package/dist/polyfill.min.js +184 -1
  58. package/dist/silent-refresh.html +18 -9
  59. package/dist/sw.js +1 -1
  60. package/package.json +20 -22
  61. package/dist/616.bundle.d0581701281977bea39b.js +0 -685
  62. package/dist/780.bundle.fd0f13dc92e9caa0581e.js +0 -4769
  63. package/dist/index.worker.1c69152d710fa7b84bce.worker.js.map +0 -1
  64. /package/dist/{806.css → 19.css} +0 -0
  65. /package/dist/{55.css → 250.css} +0 -0
  66. /package/dist/{707.css → 877.css} +0 -0
@@ -1,22 +1,22 @@
1
1
  "use strict";
2
- (globalThis["webpackChunk"] = globalThis["webpackChunk"] || []).push([[799],{
2
+ (self["webpackChunk"] = self["webpackChunk"] || []).push([[822],{
3
3
 
4
- /***/ 91799:
4
+ /***/ 86822:
5
5
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
6
6
 
7
7
  __webpack_require__.r(__webpack_exports__);
8
8
  /* harmony export */ __webpack_require__.d(__webpack_exports__, {
9
9
  /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
10
10
  /* harmony export */ });
11
- /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(32735);
12
- /* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(60216);
11
+ /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(43001);
12
+ /* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3827);
13
13
  /* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(prop_types__WEBPACK_IMPORTED_MODULE_1__);
14
- /* harmony import */ var _ohif_core__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(48501);
15
- /* harmony import */ var _ohif_ui__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(28619);
16
- /* harmony import */ var react_i18next__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(21572);
17
- /* harmony import */ var _cornerstonejs_tools__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(57270);
18
- /* harmony import */ var _getContextModule__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(43418);
19
- /* harmony import */ var _cornerstonejs_core__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(77331);
14
+ /* harmony import */ var _ohif_core__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(67869);
15
+ /* harmony import */ var _ohif_ui__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(71783);
16
+ /* harmony import */ var react_i18next__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(69190);
17
+ /* harmony import */ var _cornerstonejs_tools__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(14957);
18
+ /* harmony import */ var _getContextModule__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(41832);
19
+ /* harmony import */ var _cornerstonejs_core__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(3743);
20
20
  function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
21
21
 
22
22
 
@@ -32,30 +32,29 @@ const {
32
32
  function TrackedCornerstoneViewport(props) {
33
33
  const {
34
34
  displaySets,
35
- viewportIndex,
35
+ viewportId,
36
36
  viewportLabel,
37
37
  servicesManager,
38
- extensionManager,
39
- viewportOptions
38
+ extensionManager
40
39
  } = props;
41
40
  const {
42
41
  t
43
- } = (0,react_i18next__WEBPACK_IMPORTED_MODULE_4__/* .useTranslation */ .$G)('TrackedViewport');
42
+ } = (0,react_i18next__WEBPACK_IMPORTED_MODULE_4__/* .useTranslation */ .$G)('Common');
44
43
  const {
45
44
  measurementService,
46
- cornerstoneViewportService
45
+ cornerstoneViewportService,
46
+ viewportGridService
47
47
  } = servicesManager.services;
48
48
 
49
49
  // Todo: handling more than one displaySet on the same viewport
50
50
  const displaySet = displaySets[0];
51
- const [trackedMeasurements] = (0,_getContextModule__WEBPACK_IMPORTED_MODULE_6__/* .useTrackedMeasurements */ .I)();
51
+ const [trackedMeasurements, sendTrackedMeasurementsEvent] = (0,_getContextModule__WEBPACK_IMPORTED_MODULE_6__/* .useTrackedMeasurements */ .I)();
52
52
  const [isTracked, setIsTracked] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(false);
53
53
  const [trackedMeasurementUID, setTrackedMeasurementUID] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(null);
54
54
  const [viewportElem, setViewportElem] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(null);
55
55
  const {
56
56
  trackedSeries
57
57
  } = trackedMeasurements.context;
58
- const viewportId = viewportOptions.viewportId;
59
58
  const {
60
59
  SeriesDate,
61
60
  SeriesDescription,
@@ -69,10 +68,11 @@ function TrackedCornerstoneViewport(props) {
69
68
  PatientAge,
70
69
  SliceThickness,
71
70
  SpacingBetweenSlices,
71
+ StudyDate,
72
72
  ManufacturerModelName
73
73
  } = displaySet.images[0];
74
74
  const updateIsTracked = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(() => {
75
- const viewport = cornerstoneViewportService.getCornerstoneViewportByIndex(viewportIndex);
75
+ const viewport = cornerstoneViewportService.getCornerstoneViewport(viewportId);
76
76
  if (viewport instanceof _cornerstonejs_core__WEBPACK_IMPORTED_MODULE_7__.BaseVolumeViewport) {
77
77
  // A current image id will only exist for volume viewports that can have measurements tracked.
78
78
  // Typically these are those volume viewports for the series of acquisition.
@@ -87,7 +87,7 @@ function TrackedCornerstoneViewport(props) {
87
87
  if (trackedSeries.includes(SeriesInstanceUID) !== isTracked) {
88
88
  setIsTracked(!isTracked);
89
89
  }
90
- }, [isTracked, trackedMeasurements, viewportIndex, SeriesInstanceUID]);
90
+ }, [isTracked, trackedMeasurements, viewportId, SeriesInstanceUID]);
91
91
  const onElementEnabled = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(evt => {
92
92
  if (evt.detail.element !== viewportElem) {
93
93
  // The VOLUME_VIEWPORT_NEW_VOLUME event allows updateIsTracked to reliably fetch the image id for a volume viewport.
@@ -103,7 +103,7 @@ function TrackedCornerstoneViewport(props) {
103
103
  const {
104
104
  unsubscribe
105
105
  } = cornerstoneViewportService.subscribe(cornerstoneViewportService.EVENTS.VIEWPORT_DATA_CHANGED, props => {
106
- if (props.viewportIndex !== viewportIndex) {
106
+ if (props.viewportId !== viewportId) {
107
107
  return;
108
108
  }
109
109
  updateIsTracked();
@@ -111,7 +111,7 @@ function TrackedCornerstoneViewport(props) {
111
111
  return () => {
112
112
  unsubscribe();
113
113
  };
114
- }, [updateIsTracked, viewportIndex]);
114
+ }, [updateIsTracked, viewportId]);
115
115
  (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(() => {
116
116
  if (isTracked) {
117
117
  _cornerstonejs_tools__WEBPACK_IMPORTED_MODULE_5__.annotation.config.style.setViewportToolStyles(viewportId, {
@@ -132,13 +132,60 @@ function TrackedCornerstoneViewport(props) {
132
132
  _cornerstonejs_tools__WEBPACK_IMPORTED_MODULE_5__.annotation.config.style.setViewportToolStyles(viewportId, {});
133
133
  };
134
134
  }, [isTracked]);
135
+
136
+ /**
137
+ * The effect for listening to measurement service measurement added events
138
+ * and in turn firing an event to update the measurement tracking state machine.
139
+ * The TrackedCornerstoneViewport is the best place for this because when
140
+ * a measurement is added, at least one TrackedCornerstoneViewport will be in
141
+ * the DOM and thus can react to the events fired.
142
+ */
143
+ (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(() => {
144
+ const added = measurementService.EVENTS.MEASUREMENT_ADDED;
145
+ const addedRaw = measurementService.EVENTS.RAW_MEASUREMENT_ADDED;
146
+ const subscriptions = [];
147
+ [added, addedRaw].forEach(evt => {
148
+ subscriptions.push(measurementService.subscribe(evt, _ref => {
149
+ let {
150
+ source,
151
+ measurement
152
+ } = _ref;
153
+ const {
154
+ activeViewportId
155
+ } = viewportGridService.getState();
156
+
157
+ // Each TrackedCornerstoneViewport receives the MeasurementService's events.
158
+ // Only send the tracked measurements event for the active viewport to avoid
159
+ // sending it more than once.
160
+ if (viewportId === activeViewportId) {
161
+ const {
162
+ referenceStudyUID: StudyInstanceUID,
163
+ referenceSeriesUID: SeriesInstanceUID
164
+ } = measurement;
165
+ sendTrackedMeasurementsEvent('SET_DIRTY', {
166
+ SeriesInstanceUID
167
+ });
168
+ sendTrackedMeasurementsEvent('TRACK_SERIES', {
169
+ viewportId,
170
+ StudyInstanceUID,
171
+ SeriesInstanceUID
172
+ });
173
+ }
174
+ }).unsubscribe);
175
+ });
176
+ return () => {
177
+ subscriptions.forEach(unsub => {
178
+ unsub();
179
+ });
180
+ };
181
+ }, [measurementService, sendTrackedMeasurementsEvent, viewportId, viewportGridService]);
135
182
  function switchMeasurement(direction) {
136
183
  const newTrackedMeasurementUID = _getNextMeasurementUID(direction, servicesManager, trackedMeasurementUID, trackedMeasurements);
137
184
  if (!newTrackedMeasurementUID) {
138
185
  return;
139
186
  }
140
187
  setTrackedMeasurementUID(newTrackedMeasurementUID);
141
- measurementService.jumpToMeasurement(viewportIndex, newTrackedMeasurementUID);
188
+ measurementService.jumpToMeasurement(viewportId, newTrackedMeasurementUID);
142
189
  }
143
190
  const getCornerstoneViewport = () => {
144
191
  const {
@@ -159,8 +206,7 @@ function TrackedCornerstoneViewport(props) {
159
206
  getStatusComponent: () => _getStatusComponent(isTracked),
160
207
  studyData: {
161
208
  label: viewportLabel,
162
- studyDate: formatDate(SeriesDate),
163
- // TODO: This is series date. Is that ok?
209
+ studyDate: formatDate(SeriesDate) || formatDate(StudyDate) || t('NoStudyDate'),
164
210
  currentSeries: SeriesNumber,
165
211
  // TODO - switch entire currentSeries to be UID based or actual position based
166
212
  seriesDescription: SeriesDescription,
@@ -169,18 +215,19 @@ function TrackedCornerstoneViewport(props) {
169
215
  patientSex: PatientSex || '',
170
216
  patientAge: PatientAge || '',
171
217
  MRN: PatientID || '',
172
- thickness: SliceThickness ? `${parseFloat(SliceThickness).toFixed(2)}mm` : '',
218
+ thickness: SliceThickness ? `${parseFloat(SliceThickness).toFixed(2)}` : '',
219
+ thicknessUnits: 'mm',
173
220
  spacing: SpacingBetweenSlices !== undefined ? `${parseFloat(SpacingBetweenSlices).toFixed(2)}mm` : '',
174
221
  scanner: ManufacturerModelName || ''
175
222
  }
176
223
  }
177
224
  }), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("div", {
178
- className: "relative flex flex-row w-full h-full overflow-hidden"
225
+ className: "relative flex h-full w-full flex-row overflow-hidden"
179
226
  }, getCornerstoneViewport()));
180
227
  }
181
228
  TrackedCornerstoneViewport.propTypes = {
182
229
  displaySets: prop_types__WEBPACK_IMPORTED_MODULE_1___default().arrayOf((prop_types__WEBPACK_IMPORTED_MODULE_1___default().object).isRequired).isRequired,
183
- viewportIndex: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().number).isRequired,
230
+ viewportId: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().string).isRequired,
184
231
  dataSource: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().object),
185
232
  children: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().node),
186
233
  customProps: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().object)
@@ -195,12 +242,12 @@ function _getNextMeasurementUID(direction, servicesManager, trackedMeasurementId
195
242
  } = servicesManager.services;
196
243
  const measurements = measurementService.getMeasurements();
197
244
  const {
198
- activeViewportIndex,
245
+ activeViewportId,
199
246
  viewports
200
247
  } = viewportGridService.getState();
201
248
  const {
202
249
  displaySetInstanceUIDs: activeViewportDisplaySetInstanceUIDs
203
- } = viewports[activeViewportIndex];
250
+ } = viewports.get(activeViewportId);
204
251
  const {
205
252
  trackedSeries
206
253
  } = trackedMeasurements.context;
@@ -249,19 +296,19 @@ function _getStatusComponent(isTracked) {
249
296
  className: "flex pt-1"
250
297
  }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement(_ohif_ui__WEBPACK_IMPORTED_MODULE_3__/* .Icon */ .JO, {
251
298
  name: "info-link",
252
- className: "w-4 text-primary-main"
299
+ className: "text-primary-main w-4"
253
300
  })), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("div", {
254
- className: "flex ml-4"
301
+ className: "ml-4 flex"
255
302
  }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("span", {
256
- className: "text-base text-common-light"
303
+ className: "text-common-light text-base"
257
304
  }, isTracked ? /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement(react__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, "Series is", /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("span", {
258
305
  className: "font-bold text-white"
259
- }, " tracked"), " and can be viewed ", /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("br", null), " in the measurement panel") : /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement(react__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, "Measurements for", /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("span", {
306
+ }, " tracked"), " and can be viewed ", /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("br", null), ' ', "in the measurement panel") : /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement(react__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, "Measurements for", /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("span", {
260
307
  className: "font-bold text-white"
261
308
  }, " untracked "), "series ", /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("br", null), " will not be shown in the ", /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("br", null), " measurements panel"))))
262
309
  }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement(_ohif_ui__WEBPACK_IMPORTED_MODULE_3__/* .Icon */ .JO, {
263
310
  name: trackedIcon,
264
- className: "text-primary-light"
311
+ className: "text-aqua-pale"
265
312
  })));
266
313
  }
267
314
  /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (TrackedCornerstoneViewport);