hellfire 0.28.4 → 0.28.6

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.
package/dist/index.js CHANGED
@@ -1537,237 +1537,6 @@ function v4(options, buf, offset) {
1537
1537
  return unsafeStringify(rnds);
1538
1538
  }
1539
1539
 
1540
- function ownKeys$4(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
1541
-
1542
- function _objectSpread$4(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$4(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$4(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
1543
- var SET_FILM_LAYOUT = 'FILM/SET_FILM_LAYOUT';
1544
- var SET_FILMS = 'FILM/SET_FILMS';
1545
- var ADD_FILMS = 'FILM/ADD_FILMS';
1546
- var REMOVE_FILMS = 'FILM/REMOVE_FILMS';
1547
- var SET_FILM_VALUE = 'FILM/SET_FILM_VALUE';
1548
- var EXCHANGE_FILM = 'FILM/EXCHANGE_FILM';
1549
- var SET_FILM_ACTIVE_INDEX = 'FILM/SET_FILM_ACTIVE_INDEX';
1550
- var CLEAR_FILMS = 'FILM/CLEAR_FILMS';
1551
- var initialState$4 = {
1552
- // 胶片添加模式 image or series
1553
- filmAddType: 'series',
1554
- films: [],
1555
- filmSizeType: '1417',
1556
- filmTemplate: [],
1557
- filmLayoutRow: 5,
1558
- filmLayoutCol: 4,
1559
- filmCurrentPage: 0,
1560
- // 选中的胶片图像viewport -1代表没有选中的
1561
- filmActiveIndex: -1,
1562
- filmPrinterSettings: [],
1563
- // 胶片区激活态的工具
1564
- filmActiveTool: 'Select'
1565
- };
1566
- var film = (function () {
1567
- var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState$4;
1568
- var action = arguments.length > 1 ? arguments[1] : undefined;
1569
-
1570
- switch (action.type) {
1571
- case SET_FILMS:
1572
- {
1573
- return _objectSpread$4(_objectSpread$4({}, state), {}, {
1574
- films: action.payload
1575
- });
1576
- }
1577
-
1578
- case ADD_FILMS:
1579
- {
1580
- var add_films_data = action.payload;
1581
-
1582
- if (!lodash$1.isArray(action.payload)) {
1583
- add_films_data = [action.payload];
1584
- }
1585
-
1586
- add_films_data = lodash$1.map(add_films_data, function (item) {
1587
- return _objectSpread$4({
1588
- id: v4()
1589
- }, item);
1590
- });
1591
-
1592
- var _films = lodash$1.cloneDeep(state.films); // _films最末尾如果有一些null的值,需要过滤掉
1593
-
1594
-
1595
- if (_films.length > 0) {
1596
- while (_films[_films.length - 1] === null) {
1597
- _films.pop();
1598
- }
1599
- }
1600
-
1601
- add_films_data = lodash$1.concat(_films, add_films_data);
1602
- return _objectSpread$4(_objectSpread$4({}, state), {}, {
1603
- films: add_films_data
1604
- });
1605
- }
1606
-
1607
- case EXCHANGE_FILM:
1608
- {
1609
- var _action$payload = action.payload,
1610
- originIndex = _action$payload.originIndex,
1611
- targetIndex = _action$payload.targetIndex;
1612
-
1613
- var _films2 = lodash$1.cloneDeep(state.films); // 插入到新位置
1614
-
1615
-
1616
- _films2.splice(targetIndex, 0, _films2.splice(originIndex, 1)[0]);
1617
-
1618
- return _objectSpread$4(_objectSpread$4({}, state), {}, {
1619
- films: _films2
1620
- });
1621
- }
1622
-
1623
- case REMOVE_FILMS:
1624
- {
1625
- var _films3 = lodash$1.cloneDeep(state.films);
1626
-
1627
- var removeIndex = action.payload;
1628
-
1629
- _films3.splice(removeIndex, 1);
1630
-
1631
- var total = _films3.length;
1632
- var _filmCurrentPage = state.filmCurrentPage;
1633
-
1634
- if (state.filmCurrentPage >= _.ceil(total / (state.filmLayoutRow * state.filmLayoutCol))) {
1635
- _filmCurrentPage -= 1;
1636
- }
1637
-
1638
- return _objectSpread$4(_objectSpread$4({}, state), {}, {
1639
- films: _films3,
1640
- filmActiveIndex: -1,
1641
- filmCurrentPage: _filmCurrentPage
1642
- });
1643
- }
1644
-
1645
- case CLEAR_FILMS:
1646
- {
1647
- return _objectSpread$4(_objectSpread$4({}, state), {}, {
1648
- films: [],
1649
- filmCurrentPage: 0,
1650
- filmActiveIndex: -1
1651
- });
1652
- }
1653
-
1654
- case SET_FILM_LAYOUT:
1655
- {
1656
- return _objectSpread$4(_objectSpread$4({}, state), {}, {
1657
- filmLayoutRow: action.payload.row,
1658
- filmLayoutCol: action.payload.col
1659
- });
1660
- }
1661
-
1662
- case SET_FILM_VALUE:
1663
- {
1664
- if (action.payload && action.payload.key && (action.payload.value || action.payload.value === false || action.payload.value === 0)) {
1665
- return _objectSpread$4(_objectSpread$4({}, state), {}, defineProperty({}, action.payload.key, action.payload.value));
1666
- } else {
1667
- return state;
1668
- }
1669
- }
1670
-
1671
- case SET_FILM_ACTIVE_INDEX:
1672
- {
1673
- var _action$payload2 = action.payload,
1674
- index = _action$payload2.index,
1675
- viewport = _action$payload2.viewport;
1676
-
1677
- var _films4 = lodash$1.cloneDeep(state.films);
1678
-
1679
- _films4[index].viewport = viewport;
1680
- return _objectSpread$4(_objectSpread$4({}, state), {}, {
1681
- films: _films4
1682
- });
1683
- }
1684
-
1685
- default:
1686
- {
1687
- return state;
1688
- }
1689
- }
1690
- });
1691
- function addFilm(value) {
1692
- return {
1693
- type: ADD_FILMS,
1694
- payload: value
1695
- };
1696
- }
1697
- function exchangeFilm(originIndex, targetIndex) {
1698
- return {
1699
- type: EXCHANGE_FILM,
1700
- payload: {
1701
- originIndex: originIndex,
1702
- targetIndex: targetIndex
1703
- }
1704
- };
1705
- }
1706
- function removeFilm(index) {
1707
- return {
1708
- type: REMOVE_FILMS,
1709
- payload: index
1710
- };
1711
- }
1712
- function setFilmReduxValue(key, value) {
1713
- return {
1714
- type: SET_FILM_VALUE,
1715
- payload: {
1716
- key: key,
1717
- value: value
1718
- }
1719
- };
1720
- }
1721
- function setFilmAddType(value) {
1722
- return setFilmReduxValue('filmAddType', value);
1723
- }
1724
- function setFilmSizeType(value) {
1725
- return setFilmReduxValue('filmSizeType', value);
1726
- }
1727
- function setFilmCurrentPage(value) {
1728
- return setFilmReduxValue('filmCurrentPage', value);
1729
- }
1730
- function setFilmActiveIndex(value) {
1731
- return setFilmReduxValue('filmActiveIndex', value);
1732
- }
1733
- function setFilmPrinterSettings(value) {
1734
- return setFilmReduxValue('filmPrinterSettings', value);
1735
- }
1736
- function setFilmActiveTool(value) {
1737
- return setFilmReduxValue('filmActiveTool', value);
1738
- }
1739
- function setFilmLayout(row, col) {
1740
- return {
1741
- type: SET_FILM_LAYOUT,
1742
- payload: {
1743
- row: row,
1744
- col: col
1745
- }
1746
- };
1747
- }
1748
- function setFilmViewport(index, viewport) {
1749
- return {
1750
- type: SET_FILM_ACTIVE_INDEX,
1751
- payload: {
1752
- index: index,
1753
- viewport: viewport
1754
- }
1755
- };
1756
- }
1757
- function clearFilms() {
1758
- return {
1759
- type: CLEAR_FILMS
1760
- };
1761
- }
1762
-
1763
- var tools$1 = redux.combineReducers({
1764
- customization: customization,
1765
- action: action,
1766
- layout: layout,
1767
- thumb: thumb,
1768
- film: film
1769
- });
1770
-
1771
1540
  var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};
1772
1541
 
1773
1542
  function unwrapExports (x) {
@@ -6671,9 +6440,9 @@ function generateImage (_ref) {
6671
6440
  };
6672
6441
  }
6673
6442
 
6674
- function ownKeys$5(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
6443
+ function ownKeys$4(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
6675
6444
 
6676
- function _objectSpread$5(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$5(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$5(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
6445
+ function _objectSpread$4(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$4(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$4(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
6677
6446
 
6678
6447
  var dicomToCornerstoneImage = function dicomToCornerstoneImage(dicom, _ref) {
6679
6448
  var WindowCenter = _ref.WindowCenter,
@@ -6730,7 +6499,7 @@ function bufferToImageUrl(buffer) {
6730
6499
  enableElement.canvas.height = image.height;
6731
6500
  enableElement.viewport = cornerstone.getDefaultViewportForImage(enableElement.element, image);
6732
6501
 
6733
- var _autoVoi = autoVoi(_objectSpread$5(_objectSpread$5({}, options), {}, {
6502
+ var _autoVoi = autoVoi(_objectSpread$4(_objectSpread$4({}, options), {}, {
6734
6503
  PixelData: new Int16Array(dicom.PixelData.buffer)
6735
6504
  })),
6736
6505
  _autoVoi2 = slicedToArray(_autoVoi, 2),
@@ -10348,9 +10117,9 @@ try {
10348
10117
 
10349
10118
  var regenerator = runtime_1;
10350
10119
 
10351
- function ownKeys$6(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
10120
+ function ownKeys$5(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
10352
10121
 
10353
- function _objectSpread$6(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$6(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$6(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
10122
+ function _objectSpread$5(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$5(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$5(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
10354
10123
  var taskPool = [];
10355
10124
  var numRequest = 0;
10356
10125
  var maxRequest = 4; // 最大并发数 可配置
@@ -10467,7 +10236,7 @@ function executeTask() {
10467
10236
  numRequest--;
10468
10237
 
10469
10238
  if (task.retry > 0) {
10470
- var _task = _objectSpread$6(_objectSpread$6({}, task), {}, {
10239
+ var _task = _objectSpread$5(_objectSpread$5({}, task), {}, {
10471
10240
  retry: task.retry - 1,
10472
10241
  priority: 999
10473
10242
  });
@@ -10535,9 +10304,9 @@ function changeCurrentTopPriority(value) {
10535
10304
  currentTopPriority += value;
10536
10305
  }
10537
10306
 
10538
- function ownKeys$7(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
10307
+ function ownKeys$6(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
10539
10308
 
10540
- function _objectSpread$7(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$7(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$7(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
10309
+ function _objectSpread$6(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$6(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$6(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
10541
10310
  var lastScrollSeriesUid = null;
10542
10311
  var highLevelPriority = 9999999999;
10543
10312
 
@@ -10656,7 +10425,7 @@ function loadAndCacheImagePlus(imageId, priority, forceRefresh) {
10656
10425
 
10657
10426
  function buildImageRequestTask(imageId) {
10658
10427
  var config = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
10659
- return _objectSpread$7(_objectSpread$7({
10428
+ return _objectSpread$6(_objectSpread$6({
10660
10429
  key: imageId
10661
10430
  }, config), {}, {
10662
10431
  execute: function execute() {
@@ -10921,9 +10690,9 @@ var RulerOverlayTool = /*#__PURE__*/function (_BaseTool) {
10921
10690
  return RulerOverlayTool;
10922
10691
  }(BaseTool$5);
10923
10692
 
10924
- function ownKeys$8(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
10693
+ function ownKeys$7(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
10925
10694
 
10926
- function _objectSpread$8(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$8(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$8(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
10695
+ function _objectSpread$7(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$7(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$7(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
10927
10696
  var triggerEvent$2 = cornerstoneTools.importInternal('util/triggerEvent');
10928
10697
  var external$a = cornerstoneTools.external,
10929
10698
  getToolState$5 = cornerstoneTools.getToolState,
@@ -10941,7 +10710,7 @@ var external$a = cornerstoneTools.external,
10941
10710
  */
10942
10711
 
10943
10712
  function scrollToIndex (element, newImageIdIndex, options, callback) {
10944
- var _options = _objectSpread$8({
10713
+ var _options = _objectSpread$7({
10945
10714
  eventTrigger: true,
10946
10715
  backToStart: false,
10947
10716
  backToEnd: false
@@ -11033,7 +10802,7 @@ function scrollToIndex (element, newImageIdIndex, options, callback) {
11033
10802
  startLoadingHandler(element);
11034
10803
  }
11035
10804
 
11036
- var eventData = _objectSpread$8({
10805
+ var eventData = _objectSpread$7({
11037
10806
  newImageIdIndex: newImageIdIndex,
11038
10807
  direction: newImageIdIndex - stackData.currentImageIdIndex
11039
10808
  }, _options);
@@ -14058,9 +13827,9 @@ var MprActionParameterImpl = /*#__PURE__*/function (_ActionParameter2) {
14058
13827
  return MprActionParameterImpl;
14059
13828
  }(ActionParameter);
14060
13829
 
14061
- function ownKeys$9(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
13830
+ function ownKeys$8(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
14062
13831
 
14063
- function _objectSpread$9(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$9(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$9(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
13832
+ function _objectSpread$8(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$8(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$8(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
14064
13833
  // vtkImageInterpolator methods
14065
13834
  // ----------------------------------------------------------------------------
14066
13835
 
@@ -14545,7 +14314,7 @@ function extend(publicAPI, model) {
14545
14314
  Object.assign(model, DEFAULT_VALUES, initialValues); // Inheritance
14546
14315
  // 因为浅拷贝的原因导致会缓存interpolationInfo在vtkAbstractImageInterpolator default value里面
14547
14316
 
14548
- vtkAbstractImageInterpolator.extend(publicAPI, model, _objectSpread$9({
14317
+ vtkAbstractImageInterpolator.extend(publicAPI, model, _objectSpread$8({
14549
14318
  interpolationInfo: {
14550
14319
  pointer: null,
14551
14320
  extent: [0, -1, 0, -1, 0, -1],
@@ -24755,9 +24524,9 @@ function _unsupportedIterableToArray$7(o, minLen) { if (!o) return; if (typeof o
24755
24524
 
24756
24525
  function _arrayLikeToArray$7(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
24757
24526
 
24758
- function ownKeys$a(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
24527
+ function ownKeys$9(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
24759
24528
 
24760
- function _objectSpread$a(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$a(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$a(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
24529
+ function _objectSpread$9(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$9(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$9(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
24761
24530
 
24762
24531
  function _createSuper$A(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$A(); return function _createSuperInternal() { var Super = getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return possibleConstructorReturn(this, result); }; }
24763
24532
 
@@ -24813,7 +24582,7 @@ var CentesisTool = /*#__PURE__*/function (_BaseAnnotationPlusTo) {
24813
24582
  color: undefined,
24814
24583
  invalidated: true,
24815
24584
  handles: {
24816
- end: _objectSpread$a(_objectSpread$a({}, point), {}, {
24585
+ end: _objectSpread$9(_objectSpread$9({}, point), {}, {
24817
24586
  highlight: true,
24818
24587
  active: true
24819
24588
  })
@@ -24859,7 +24628,7 @@ var CentesisTool = /*#__PURE__*/function (_BaseAnnotationPlusTo) {
24859
24628
 
24860
24629
  var v3Start = this._imagePointToPatientPoint(point, imagePlane);
24861
24630
 
24862
- centesisPathStoreCurrent.start = _objectSpread$a(_objectSpread$a({}, point), {}, {
24631
+ centesisPathStoreCurrent.start = _objectSpread$9(_objectSpread$9({}, point), {}, {
24863
24632
  index: index,
24864
24633
  v3: v3Start
24865
24634
  });
@@ -24870,7 +24639,7 @@ var CentesisTool = /*#__PURE__*/function (_BaseAnnotationPlusTo) {
24870
24639
 
24871
24640
  var v3End = this._imagePointToPatientPoint(point, imagePlane);
24872
24641
 
24873
- centesisPathStoreCurrent.end = _objectSpread$a(_objectSpread$a({}, point), {}, {
24642
+ centesisPathStoreCurrent.end = _objectSpread$9(_objectSpread$9({}, point), {}, {
24874
24643
  index: index,
24875
24644
  v3: v3End
24876
24645
  });
@@ -25099,9 +24868,9 @@ var CentesisPathTool = /*#__PURE__*/function (_BaseTool) {
25099
24868
  return CentesisPathTool;
25100
24869
  }(BaseTool$9);
25101
24870
 
25102
- function ownKeys$b(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
24871
+ function ownKeys$a(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
25103
24872
 
25104
- function _objectSpread$b(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$b(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$b(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
24873
+ function _objectSpread$a(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$a(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$a(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
25105
24874
  var EVENTS$3 = {
25106
24875
  RELATIVE_SYNC: 'cornerstonetoolsrelativesync',
25107
24876
  SELECT_POSITION: 'cornerstonetoolsselectposition',
@@ -25171,7 +24940,7 @@ function resetFalseColor(element, hasColormap) {
25171
24940
 
25172
24941
  if (hasColormap) {
25173
24942
  var enabledElement = cornerstone.getEnabledElement(element);
25174
- enabledElement.renderingTools = _objectSpread$b(_objectSpread$b({}, enabledElement.renderingTools), {}, {
24943
+ enabledElement.renderingTools = _objectSpread$a(_objectSpread$a({}, enabledElement.renderingTools), {}, {
25175
24944
  lastRenderedIsColor: true
25176
24945
  });
25177
24946
  viewport.colormap = cornerstone.colors.getColormap(colorMapId);
@@ -25190,7 +24959,7 @@ function setElementLastRenderedIsColorToTrue(element) {
25190
24959
 
25191
24960
  if (viewport.colormap) {
25192
24961
  var enabledElement = cornerstone.getEnabledElement(element);
25193
- enabledElement.renderingTools = _objectSpread$b(_objectSpread$b({}, enabledElement.renderingTools), {}, {
24962
+ enabledElement.renderingTools = _objectSpread$a(_objectSpread$a({}, enabledElement.renderingTools), {}, {
25194
24963
  lastRenderedIsColor: true
25195
24964
  });
25196
24965
  }
@@ -25342,6 +25111,12 @@ function reset$1(element, mode) {
25342
25111
  var globalToolState = cornerstoneTools.globalImageIdSpecificToolStateManager.saveToolState();
25343
25112
  cornerstoneToolStateReset(globalToolState);
25344
25113
  }
25114
+ function resetOnlyAndSync(element, mode) {
25115
+ resetOnly(element);
25116
+ cornerstone.triggerEvent(element, EVENTS$3.RELATIVE_SYNC, {
25117
+ activeTool: 'reset'
25118
+ });
25119
+ }
25345
25120
  function resetOnly(element) {
25346
25121
  var viewport = cornerstone.getViewport(element);
25347
25122
 
@@ -26474,9 +26249,9 @@ function getRealActiveIndex(mode, activeIndex, imageActiveIndex, MPR, mprActiveI
26474
26249
  return Surgery || CPR ? surgeryActiveIndex : MPR ? mprActiveIndex : mode === 'seriesMode' ? activeIndex : imageActiveIndex;
26475
26250
  }
26476
26251
 
26477
- function ownKeys$c(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
26252
+ function ownKeys$b(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
26478
26253
 
26479
- function _objectSpread$c(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$c(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$c(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
26254
+ function _objectSpread$b(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$b(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$b(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
26480
26255
 
26481
26256
  function _createSuper$E(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$E(); return function _createSuperInternal() { var Super = getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return possibleConstructorReturn(this, result); }; }
26482
26257
 
@@ -26539,7 +26314,7 @@ var CPRTool = /*#__PURE__*/function (_BaseAnnotationPlusTo) {
26539
26314
  number = data[data.length - 1].number + 1;
26540
26315
  }
26541
26316
 
26542
- this.centesisPathCacheSet(image.imageId, _objectSpread$c(_objectSpread$c({}, eventData.currentPoints.image), {}, {
26317
+ this.centesisPathCacheSet(image.imageId, _objectSpread$b(_objectSpread$b({}, eventData.currentPoints.image), {}, {
26543
26318
  v3: v3
26544
26319
  }), data, number);
26545
26320
  return {
@@ -27557,9 +27332,9 @@ function _unsupportedIterableToArray$8(o, minLen) { if (!o) return; if (typeof o
27557
27332
 
27558
27333
  function _arrayLikeToArray$8(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
27559
27334
 
27560
- function ownKeys$d(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
27335
+ function ownKeys$c(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
27561
27336
 
27562
- function _objectSpread$d(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$d(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$d(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
27337
+ function _objectSpread$c(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$c(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$c(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
27563
27338
 
27564
27339
  function _createSuper$F(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$F(); return function _createSuperInternal() { var Super = getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return possibleConstructorReturn(this, result); }; }
27565
27340
 
@@ -27821,7 +27596,7 @@ var CrosshairsMPRTool = /*#__PURE__*/function (_BaseTool) {
27821
27596
  }
27822
27597
 
27823
27598
  this.collectionEvent({
27824
- detail: _objectSpread$d(_objectSpread$d({}, evt.detail), {}, {
27599
+ detail: _objectSpread$c(_objectSpread$c({}, evt.detail), {}, {
27825
27600
  rotate: true,
27826
27601
  angle: angle,
27827
27602
  isVectorX: isVectorX,
@@ -28455,9 +28230,9 @@ function reset$2(key) {
28455
28230
  }
28456
28231
  }
28457
28232
 
28458
- function ownKeys$e(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
28233
+ function ownKeys$d(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
28459
28234
 
28460
- function _objectSpread$e(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$e(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$e(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
28235
+ function _objectSpread$d(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$d(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$d(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
28461
28236
 
28462
28237
  function _createSuper$H(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$H(); return function _createSuperInternal() { var Super = getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return possibleConstructorReturn(this, result); }; }
28463
28238
 
@@ -28683,7 +28458,7 @@ var AIAnalysisOverlayTool = /*#__PURE__*/function (_BaseAnnotationPlusTo) {
28683
28458
  var segmentations = lodash$1.map(item.segmentations, function (segmentation) {
28684
28459
  var info = lodash$1.pick(item, ['type', 'risk', 'intensity', 'avgAxisDiameter_mm', 'longAxisDiameter_mm', 'shortAxisDiameter_mm', 'characteristic', 'typeWithTexture']);
28685
28460
 
28686
- return _objectSpread$e(_objectSpread$e({}, segmentation), {}, {
28461
+ return _objectSpread$d(_objectSpread$d({}, segmentation), {}, {
28687
28462
  index: i + 1,
28688
28463
  info: info,
28689
28464
  instanceUid: item.instanceUid
@@ -29085,7 +28860,9 @@ var synchronizer = new cornerstoneTools.Synchronizer(cornerstone.EVENTS.NEW_IMAG
29085
28860
 
29086
28861
  var linkSynchronizer$1 = new cornerstoneTools.Synchronizer(EVENTS$3.RELATIVE_SYNC, cornerstoneTools.linkSynchronizer); // 图像模式下的同步
29087
28862
 
29088
- var linkImageModeSynchronizer$1 = new cornerstoneTools.Synchronizer(EVENTS$3.RELATIVE_SYNC, cornerstoneTools.linkImageModeSynchronizer); // 联动滚动
28863
+ var linkImageModeSynchronizer$1 = new cornerstoneTools.Synchronizer(EVENTS$3.RELATIVE_SYNC, cornerstoneTools.linkImageModeSynchronizer); // 胶片同步
28864
+
28865
+ var filmSynchronizer = new cornerstoneTools.Synchronizer(EVENTS$3.RELATIVE_SYNC, cornerstoneTools.linkImageModeSynchronizer); // 联动滚动
29089
28866
 
29090
28867
  var linkScrollSynchronizer = new cornerstoneTools.Synchronizer(cornerstoneTools.EVENTS.STACK_SCROLL, cornerstoneTools.stackScrollSynchronizer); // mpr窗值同步
29091
28868
 
@@ -29102,6 +28879,284 @@ cornerstone.registerImageLoader('mpr', mprImageLoader);
29102
28879
  cornerstone.registerImageLoader('centesis', centesisImageLoader);
29103
28880
  cornerstone.registerImageLoader('cpr', cprImageLoader);
29104
28881
 
28882
+ function ownKeys$e(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
28883
+
28884
+ function _objectSpread$e(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$e(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$e(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
28885
+ var SET_FILM_LAYOUT = 'FILM/SET_FILM_LAYOUT';
28886
+ var SET_FILMS = 'FILM/SET_FILMS';
28887
+ var ADD_FILMS = 'FILM/ADD_FILMS';
28888
+ var REMOVE_FILMS = 'FILM/REMOVE_FILMS';
28889
+ var SET_FILM_VALUE = 'FILM/SET_FILM_VALUE';
28890
+ var EXCHANGE_FILM = 'FILM/EXCHANGE_FILM';
28891
+ var SET_FILM_ACTIVE_INDEX = 'FILM/SET_FILM_ACTIVE_INDEX';
28892
+ var CLEAR_FILMS = 'FILM/CLEAR_FILMS';
28893
+ var SET_FILM_RELATIVE_INDEX = 'FILM/SET_FILM_RELATIVE_INDEX';
28894
+ var initialState$4 = {
28895
+ // 胶片添加模式 image or series
28896
+ filmAddType: 'series',
28897
+ films: [],
28898
+ filmSizeType: '1417',
28899
+ filmTemplate: [],
28900
+ filmLayoutRow: 5,
28901
+ filmLayoutCol: 4,
28902
+ filmCurrentPage: 0,
28903
+ // 选中的胶片图像viewport -1代表没有选中的
28904
+ filmActiveIndex: -1,
28905
+ filmRelativeIndexes: [],
28906
+ filmPrinterSettings: [],
28907
+ // 胶片区激活态的工具
28908
+ filmActiveTool: 'Select',
28909
+ filmSynchronizer: filmSynchronizer
28910
+ };
28911
+ var film = (function () {
28912
+ var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState$4;
28913
+ var action = arguments.length > 1 ? arguments[1] : undefined;
28914
+
28915
+ switch (action.type) {
28916
+ case SET_FILMS:
28917
+ {
28918
+ return _objectSpread$e(_objectSpread$e({}, state), {}, {
28919
+ films: action.payload
28920
+ });
28921
+ }
28922
+
28923
+ case ADD_FILMS:
28924
+ {
28925
+ var add_films_data = action.payload;
28926
+
28927
+ if (!lodash$1.isArray(action.payload)) {
28928
+ add_films_data = [action.payload];
28929
+ }
28930
+
28931
+ add_films_data = lodash$1.map(add_films_data, function (item) {
28932
+ return _objectSpread$e({
28933
+ id: v4()
28934
+ }, item);
28935
+ });
28936
+
28937
+ var _films = lodash$1.cloneDeep(state.films); // _films最末尾如果有一些null的值,需要过滤掉
28938
+
28939
+
28940
+ if (_films.length > 0) {
28941
+ while (_films[_films.length - 1] === null) {
28942
+ _films.pop();
28943
+ }
28944
+ }
28945
+
28946
+ add_films_data = lodash$1.concat(_films, add_films_data);
28947
+ return _objectSpread$e(_objectSpread$e({}, state), {}, {
28948
+ films: add_films_data
28949
+ });
28950
+ }
28951
+
28952
+ case EXCHANGE_FILM:
28953
+ {
28954
+ var _action$payload = action.payload,
28955
+ originIndex = _action$payload.originIndex,
28956
+ targetIndex = _action$payload.targetIndex;
28957
+
28958
+ var _films2 = lodash$1.cloneDeep(state.films); // 插入到新位置
28959
+
28960
+
28961
+ _films2.splice(targetIndex, 0, _films2.splice(originIndex, 1)[0]);
28962
+
28963
+ return _objectSpread$e(_objectSpread$e({}, state), {}, {
28964
+ films: _films2
28965
+ });
28966
+ }
28967
+
28968
+ case REMOVE_FILMS:
28969
+ {
28970
+ var _films3 = lodash$1.cloneDeep(state.films);
28971
+
28972
+ var removeIndexes = lodash$1.union([state.filmActiveIndex], state.filmRelativeIndexes);
28973
+ removeIndexes = removeIndexes.filter(function (item) {
28974
+ return item !== -1;
28975
+ });
28976
+ removeIndexes = removeIndexes.map(function (item) {
28977
+ return item + state.filmCurrentPage * (state.filmLayoutRow * state.filmLayoutCol);
28978
+ });
28979
+ _films3 = lodash$1.filter(_films3, function (item, index) {
28980
+ return !lodash$1.includes(removeIndexes, index);
28981
+ });
28982
+ var _filmCurrentPage = state.filmCurrentPage;
28983
+
28984
+ var maxPage = _.ceil(_films3.length / (state.filmLayoutRow * state.filmLayoutCol));
28985
+
28986
+ if (state.filmCurrentPage >= maxPage) {
28987
+ _filmCurrentPage = maxPage - 1;
28988
+ }
28989
+
28990
+ state.filmSynchronizer.destroy();
28991
+ return _objectSpread$e(_objectSpread$e({}, state), {}, {
28992
+ films: _films3,
28993
+ filmActiveIndex: -1,
28994
+ filmRelativeIndexes: [],
28995
+ filmCurrentPage: _filmCurrentPage
28996
+ });
28997
+ }
28998
+
28999
+ case CLEAR_FILMS:
29000
+ {
29001
+ state.filmSynchronizer.destroy();
29002
+ return _objectSpread$e(_objectSpread$e({}, state), {}, {
29003
+ films: [],
29004
+ filmCurrentPage: 0,
29005
+ filmActiveIndex: -1,
29006
+ filmRelativeIndexes: []
29007
+ });
29008
+ }
29009
+
29010
+ case SET_FILM_LAYOUT:
29011
+ {
29012
+ return _objectSpread$e(_objectSpread$e({}, state), {}, {
29013
+ filmLayoutRow: action.payload.row,
29014
+ filmLayoutCol: action.payload.col
29015
+ });
29016
+ }
29017
+
29018
+ case SET_FILM_VALUE:
29019
+ {
29020
+ if (action.payload && action.payload.key && (action.payload.value || action.payload.value === false || action.payload.value === 0)) {
29021
+ if (action.payload.key === 'filmCurrentPage') {
29022
+ state.filmSynchronizer.destroy();
29023
+ }
29024
+
29025
+ return _objectSpread$e(_objectSpread$e({}, state), {}, defineProperty({}, action.payload.key, action.payload.value));
29026
+ } else {
29027
+ return state;
29028
+ }
29029
+ }
29030
+
29031
+ case SET_FILM_RELATIVE_INDEX:
29032
+ {
29033
+ var index = action.payload;
29034
+
29035
+ var _filmRelativeIndexes = lodash$1.cloneDeep(state.filmRelativeIndexes);
29036
+
29037
+ if (!lodash$1.includes(_filmRelativeIndexes, index)) {
29038
+ _filmRelativeIndexes.push(index);
29039
+ } else {
29040
+ _filmRelativeIndexes.splice(lodash$1.indexOf(_filmRelativeIndexes, index), 1);
29041
+ }
29042
+
29043
+ var _filmActiveIndex = state.filmActiveIndex;
29044
+
29045
+ if (_filmActiveIndex === -1) {
29046
+ _filmActiveIndex = index;
29047
+ }
29048
+
29049
+ return _objectSpread$e(_objectSpread$e({}, state), {}, {
29050
+ filmRelativeIndexes: _filmRelativeIndexes,
29051
+ filmActiveIndex: _filmActiveIndex
29052
+ });
29053
+ }
29054
+
29055
+ case SET_FILM_ACTIVE_INDEX:
29056
+ {
29057
+ var _action$payload2 = action.payload,
29058
+ _index = _action$payload2.index,
29059
+ viewport = _action$payload2.viewport;
29060
+
29061
+ var _films4 = lodash$1.cloneDeep(state.films);
29062
+
29063
+ _films4[_index].viewport = viewport;
29064
+ return _objectSpread$e(_objectSpread$e({}, state), {}, {
29065
+ films: _films4
29066
+ });
29067
+ }
29068
+
29069
+ default:
29070
+ {
29071
+ return state;
29072
+ }
29073
+ }
29074
+ });
29075
+ function addFilm(value) {
29076
+ return {
29077
+ type: ADD_FILMS,
29078
+ payload: value
29079
+ };
29080
+ }
29081
+ function exchangeFilm(originIndex, targetIndex) {
29082
+ return {
29083
+ type: EXCHANGE_FILM,
29084
+ payload: {
29085
+ originIndex: originIndex,
29086
+ targetIndex: targetIndex
29087
+ }
29088
+ };
29089
+ }
29090
+ function removeFilm() {
29091
+ return {
29092
+ type: REMOVE_FILMS
29093
+ };
29094
+ }
29095
+ function setFilmReduxValue(key, value) {
29096
+ return {
29097
+ type: SET_FILM_VALUE,
29098
+ payload: {
29099
+ key: key,
29100
+ value: value
29101
+ }
29102
+ };
29103
+ }
29104
+ function setFilmRelativeIndex(index) {
29105
+ return {
29106
+ type: SET_FILM_RELATIVE_INDEX,
29107
+ payload: index
29108
+ };
29109
+ }
29110
+ function setFilmAddType(value) {
29111
+ return setFilmReduxValue('filmAddType', value);
29112
+ }
29113
+ function setFilmSizeType(value) {
29114
+ return setFilmReduxValue('filmSizeType', value);
29115
+ }
29116
+ function setFilmCurrentPage(value) {
29117
+ return setFilmReduxValue('filmCurrentPage', value);
29118
+ }
29119
+ function setFilmActiveIndex(value) {
29120
+ return setFilmReduxValue('filmActiveIndex', value);
29121
+ }
29122
+ function setFilmPrinterSettings(value) {
29123
+ return setFilmReduxValue('filmPrinterSettings', value);
29124
+ }
29125
+ function setFilmActiveTool(value) {
29126
+ return setFilmReduxValue('filmActiveTool', value);
29127
+ }
29128
+ function setFilmLayout(row, col) {
29129
+ return {
29130
+ type: SET_FILM_LAYOUT,
29131
+ payload: {
29132
+ row: row,
29133
+ col: col
29134
+ }
29135
+ };
29136
+ }
29137
+ function setFilmViewport(index, viewport) {
29138
+ return {
29139
+ type: SET_FILM_ACTIVE_INDEX,
29140
+ payload: {
29141
+ index: index,
29142
+ viewport: viewport
29143
+ }
29144
+ };
29145
+ }
29146
+ function clearFilms() {
29147
+ return {
29148
+ type: CLEAR_FILMS
29149
+ };
29150
+ }
29151
+
29152
+ var tools$1 = redux.combineReducers({
29153
+ customization: customization,
29154
+ action: action,
29155
+ layout: layout,
29156
+ thumb: thumb,
29157
+ film: film
29158
+ });
29159
+
29105
29160
  function ownKeys$f(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
29106
29161
 
29107
29162
  function _objectSpread$f(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$f(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$f(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
@@ -46398,7 +46453,7 @@ function _ref$1m() {
46398
46453
  return _ref$1m.apply(this, arguments);
46399
46454
  }
46400
46455
 
46401
- var css_248z$s = ".paladin-user-setting {\n padding: 0 20px;\n margin-bottom: 30px;\n font-size: 15px;\n}\n.paladin-user-setting p {\n font-size: 16px;\n}\n.paladin-user-setting .paladin-user-setting-remark {\n color: #d43f3a;\n margin: 10px 0 0 0;\n}\n.paladin-user-setting .paladin-user-setting-footer {\n margin-top: 15px;\n text-align: right;\n}\n.paladin-user-setting .paladin-user-setting-footer button {\n margin-left: 10px;\n}\n.paladin-user-setting .paladin-setting-radio {\n display: flex;\n}\n.paladin-user-setting .paladin-setting-radio .paladin-setting-radio-label {\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: center;\n}\n.paladin-user-setting .paladin-setting-radio .paladin-setting-radio-item {\n display: flex;\n flex-direction: row;\n margin-right: 10px;\n align-items: center;\n justify-content: center;\n}\n.paladin-user-setting .paladin-setting-radio .paladin-setting-radio-item .paladin-ipt {\n padding: 0 !important;\n margin: 0 3px 0 0 !important;\n}\n.paladin-user-setting .paladin-setting-radio .paladin-setting-radio-item input {\n display: flex;\n flex-direction: column;\n width: 20px;\n height: 20px;\n}\n.paladin-user-setting .paladin-setting-radio .paladin-setting-radio-item span {\n display: flex;\n flex-direction: column;\n}\n.paladin-user-setting .paladin-setting-hotkey {\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n}\n.paladin-user-setting .paladin-setting-hotkey .paladin-setting-hotkey-item {\n display: flex;\n flex-direction: column;\n flex: none;\n padding: 5px 10px;\n border: 1px solid #666;\n border-radius: 3px;\n margin-right: 10px;\n margin-bottom: 10px;\n}\n";
46456
+ var css_248z$s = ".paladin-user-setting {\n padding: 0 20px;\n margin-bottom: 30px;\n font-size: 15px;\n}\n.paladin-user-setting p {\n font-size: 16px;\n}\n.paladin-user-setting p svg {\n width: 10px;\n margin-right: 2px;\n}\n.paladin-user-setting .paladin-user-setting-remark {\n color: #d43f3a;\n margin: 10px 0 0 0;\n}\n.paladin-user-setting .paladin-user-setting-footer {\n margin-top: 15px;\n text-align: right;\n}\n.paladin-user-setting .paladin-user-setting-footer button {\n margin-left: 10px;\n}\n.paladin-user-setting .paladin-setting-radio {\n display: flex;\n}\n.paladin-user-setting .paladin-setting-radio .paladin-setting-radio-label {\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: center;\n}\n.paladin-user-setting .paladin-setting-radio .paladin-setting-radio-item {\n display: flex;\n flex-direction: row;\n margin-right: 10px;\n align-items: center;\n justify-content: center;\n}\n.paladin-user-setting .paladin-setting-radio .paladin-setting-radio-item .paladin-ipt {\n padding: 0 !important;\n margin: 0 3px 0 0 !important;\n}\n.paladin-user-setting .paladin-setting-radio .paladin-setting-radio-item input {\n display: flex;\n flex-direction: column;\n width: 20px;\n height: 20px;\n}\n.paladin-user-setting .paladin-setting-radio .paladin-setting-radio-item span {\n display: flex;\n flex-direction: column;\n}\n.paladin-user-setting .paladin-setting-hotkey {\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n}\n.paladin-user-setting .paladin-setting-hotkey .paladin-setting-hotkey-item {\n display: flex;\n flex-direction: column;\n flex: none;\n padding: 5px 10px;\n border: 1px solid #666;\n border-radius: 3px;\n margin-right: 10px;\n margin-bottom: 10px;\n}\n";
46402
46457
  styleInject$1(css_248z$s);
46403
46458
 
46404
46459
  var dicomSettingLeftMouseTools = ['StackScroll', 'Wwwc'];
@@ -46457,10 +46512,12 @@ var dicomSettingHotKeyDic = [{
46457
46512
  hotkey: 'X'
46458
46513
  }];
46459
46514
  var hotKeyIsOpen = window.localStorage.getItem('hellfire-hotkey-open') || 'open';
46515
+ var dicomBasicInfoFrom = window.localStorage.getItem('hellfire-dicom-basic-info-from') || 'dicom';
46460
46516
  var customDicomSetting = {
46461
46517
  leftMouseTool: 'Wwwc',
46462
46518
  rightMouseTool: 'Zoom',
46463
- hotKeyIsOpen: hotKeyIsOpen
46519
+ hotKeyIsOpen: hotKeyIsOpen,
46520
+ dicomBasicInfoFrom: dicomBasicInfoFrom
46464
46521
  };
46465
46522
 
46466
46523
  var saveCustomDicomSetting = function saveCustomDicomSetting() {
@@ -46473,6 +46530,19 @@ var saveCustomDicomSetting = function saveCustomDicomSetting() {
46473
46530
  customDicomSetting = Object.assign(customDicomSetting, _data);
46474
46531
  };
46475
46532
 
46533
+ function _extends$1o() { _extends$1o = Object.assign || 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$1o.apply(this, arguments); }
46534
+
46535
+ var _ref$1n = /*#__PURE__*/React__default.createElement("path", {
46536
+ d: "M24.571 16l2.464 2.411q.536.5.357 1.25-.214.732-.929.911l-3.357.857.946 3.321q.214.732-.339 1.25-.518.554-1.25.339l-3.321-.946-.857 3.357q-.179.714-.911.929-.214.036-.339.036-.554 0-.911-.393l-2.411-2.464-2.411 2.464q-.5.536-1.25.357-.732-.196-.911-.929l-.857-3.357-3.321.946q-.732.214-1.25-.339-.554-.518-.339-1.25l.946-3.321-3.357-.857q-.714-.179-.929-.911-.179-.75.357-1.25L2.855 16 .391 13.589q-.536-.5-.357-1.25.214-.732.929-.911l3.357-.857-.946-3.321Q3.16 6.518 3.713 6q.518-.554 1.25-.339l3.321.946.857-3.357q.179-.732.911-.911.732-.214 1.25.339l2.411 2.482 2.411-2.482q.518-.536 1.25-.339.732.179.911.911l.857 3.357 3.321-.946q.732-.214 1.25.339.554.518.339 1.25l-.946 3.321 3.357.857q.714.179.929.911.179.75-.357 1.25z"
46537
+ });
46538
+
46539
+ const SvgCertificate = props => /*#__PURE__*/React__default.createElement("svg", _extends$1o({
46540
+ width: 32,
46541
+ height: 32,
46542
+ viewBox: "0 0 32 32",
46543
+ fill: "currentColor"
46544
+ }, props), _ref$1n);
46545
+
46476
46546
  function ownKeys$J(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
46477
46547
 
46478
46548
  function _objectSpread$K(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys$J(Object(source), true).forEach(function (key) { defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys$J(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
@@ -46496,6 +46566,7 @@ var UserSettingModal = /*#__PURE__*/function (_Component) {
46496
46566
  defineProperty(assertThisInitialized(_this), "handleSave", function () {
46497
46567
  var dicomSettingChange = _this.props.dicomSettingChange;
46498
46568
  window.localStorage.setItem('hellfire-hotkey-open', _this.state.hotKeyIsOpen);
46569
+ window.localStorage.setItem('hellfire-dicom-basic-info-from', _this.state.dicomBasicInfoFrom);
46499
46570
 
46500
46571
  if (dicomSettingChange) {
46501
46572
  dicomSettingChange && dicomSettingChange({
@@ -46522,11 +46593,12 @@ var UserSettingModal = /*#__PURE__*/function (_Component) {
46522
46593
  var _this$state = this.state,
46523
46594
  leftMouseTool = _this$state.leftMouseTool,
46524
46595
  rightMouseTool = _this$state.rightMouseTool,
46525
- hotKeyIsOpen = _this$state.hotKeyIsOpen;
46596
+ hotKeyIsOpen = _this$state.hotKeyIsOpen,
46597
+ dicomBasicInfoFrom = _this$state.dicomBasicInfoFrom;
46526
46598
  var close = this.props.close;
46527
46599
  return /*#__PURE__*/React__default.createElement("div", {
46528
46600
  className: 'paladin-user-setting'
46529
- }, /*#__PURE__*/React__default.createElement("p", null, "\u9F20\u6807\u8BBE\u7F6E\uFF1A"), /*#__PURE__*/React__default.createElement("div", {
46601
+ }, /*#__PURE__*/React__default.createElement("p", null, /*#__PURE__*/React__default.createElement(SvgCertificate, null), "\u9F20\u6807\u8BBE\u7F6E\uFF1A"), /*#__PURE__*/React__default.createElement("div", {
46530
46602
  className: 'paladin-setting-radio'
46531
46603
  }, /*#__PURE__*/React__default.createElement("div", {
46532
46604
  className: 'paladin-setting-radio-label'
@@ -46567,7 +46639,36 @@ var UserSettingModal = /*#__PURE__*/function (_Component) {
46567
46639
  style: {
46568
46640
  marginTop: '30px'
46569
46641
  }
46570
- }, "\u5FEB\u6377\u952E\u8BF4\u660E\uFF1A"), /*#__PURE__*/React__default.createElement("div", {
46642
+ }, /*#__PURE__*/React__default.createElement(SvgCertificate, null), "\u57FA\u672C\u4FE1\u606F\u663E\u793A\u6765\u6E90"), /*#__PURE__*/React__default.createElement("div", {
46643
+ className: 'paladin-setting-radio',
46644
+ style: {
46645
+ marginBottom: '15px'
46646
+ }
46647
+ }, /*#__PURE__*/React__default.createElement("div", {
46648
+ className: 'paladin-setting-radio-item'
46649
+ }, /*#__PURE__*/React__default.createElement(Input$1, {
46650
+ type: "radio",
46651
+ checked: dicomBasicInfoFrom === 'dicom',
46652
+ onChange: function onChange(e) {
46653
+ _this2.setState({
46654
+ dicomBasicInfoFrom: 'dicom'
46655
+ });
46656
+ }
46657
+ }), /*#__PURE__*/React__default.createElement("span", null, "\u56FE\u50CF")), /*#__PURE__*/React__default.createElement("div", {
46658
+ className: 'paladin-setting-radio-item'
46659
+ }, /*#__PURE__*/React__default.createElement(Input$1, {
46660
+ type: "radio",
46661
+ checked: dicomBasicInfoFrom === 'study',
46662
+ onChange: function onChange(e) {
46663
+ _this2.setState({
46664
+ dicomBasicInfoFrom: 'study'
46665
+ });
46666
+ }
46667
+ }), /*#__PURE__*/React__default.createElement("span", null, "\u68C0\u67E5\u5217\u8868"))), /*#__PURE__*/React__default.createElement("p", {
46668
+ style: {
46669
+ marginTop: '30px'
46670
+ }
46671
+ }, /*#__PURE__*/React__default.createElement(SvgCertificate, null), "\u5FEB\u6377\u952E\u8BF4\u660E\uFF1A"), /*#__PURE__*/React__default.createElement("div", {
46571
46672
  className: 'paladin-setting-radio',
46572
46673
  style: {
46573
46674
  marginBottom: '15px'
@@ -46893,6 +46994,15 @@ var mergeProps$k = function mergeProps(propsFromState, propsFromDispatch, ownPro
46893
46994
  }
46894
46995
  },
46895
46996
  activeDicomFunction: function activeDicomFunction(toolName) {
46997
+ // 扫描定位线开关本地存储
46998
+ if (toolName === 'ReferenceLines') {
46999
+ if (propsFromState.ReferenceLines) {
47000
+ window.localStorage.setItem('hellfire-reference-line-default-state', 'close');
47001
+ } else {
47002
+ window.localStorage.setItem('hellfire-reference-line-default-state', 'open');
47003
+ }
47004
+ }
47005
+
46896
47006
  propsFromDispatch.activeDicomFunction(toolName);
46897
47007
  },
46898
47008
  prevImage: function prevImage() {
@@ -47851,18 +47961,18 @@ var ConnectedDicomTool = reactRedux.connect(mapStateToProps$k, {
47851
47961
  var css_248z$t = ".paladin-thumb-content {\n position: relative;\n height: 66px;\n width: 66px;\n border-width: 1px;\n border-style: solid;\n cursor: pointer;\n}\n.paladin-thumb-content .paladin-thumb-bottom {\n white-space: nowrap;\n position: absolute;\n bottom: 0;\n left: 50%;\n transform: translateX(-50%);\n color: #faa80a;\n text-align: center;\n font-size: 14px;\n z-index: 2;\n}\n.paladin-thumb-content .paladin-thumb-bottom-mobile {\n font-size: 10px;\n}\n.paladin-thumb-content .paladin-thumb-mask {\n position: absolute;\n width: 100%;\n height: 100%;\n z-index: 1;\n}\n.paladin-thumb-content .paladin-thumb-process {\n position: absolute;\n z-index: 1;\n top: 0;\n height: 4px;\n width: 100%;\n background: #ffffff;\n overflow: hidden;\n}\n.paladin-thumb-content .paladin-thumb-process .paladin-thumb-process-inner {\n background: #faa80a;\n height: 100%;\n}\n.mobile-thumb {\n width: 50px;\n height: 50px;\n}\n.paladin-thumb-svg {\n cursor: pointer;\n justify-content: center;\n}\n.paladin-thumb-svg svg {\n fill: #fff;\n}\n.paladin-thumb-svg:hover {\n background-color: #616772;\n}\n.paladin-thumb-button {\n cursor: pointer;\n justify-content: center;\n padding: 0 15px;\n}\n.paladin-thumb-button svg {\n fill: #fff;\n}\n.paladin-thumb-button:hover {\n background-color: #616772;\n}\n.paladin-thumb-button svg {\n width: 11px !important;\n}\n.paladin-fresh-button {\n cursor: pointer;\n justify-content: center;\n padding: 0 25px;\n}\n.paladin-fresh-button svg {\n fill: #fff;\n}\n.paladin-fresh-button:hover {\n background-color: #616772;\n}\n.paladin-fresh-button svg {\n width: 15px !important;\n}\n.paladin-thumb-study {\n cursor: pointer;\n font-size: 14px;\n line-height: 40px;\n padding: 0 12px;\n color: #ffffff;\n}\n.paladin-thumb-viewport {\n width: 100%;\n height: 100%;\n position: relative;\n overflow: hidden;\n}\n.paladin-thumb-viewport h4,\n.paladin-thumb-viewport p {\n font-size: 10px;\n}\n.paladin-thumb-study-wrapper {\n border-bottom: 1px solid #727882;\n}\n.paladin-thumb-context-wrapper {\n padding: 4px 2px;\n}\n";
47852
47962
  styleInject$1(css_248z$t);
47853
47963
 
47854
- function _extends$1o() { _extends$1o = Object.assign || 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$1o.apply(this, arguments); }
47964
+ function _extends$1p() { _extends$1p = Object.assign || 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$1p.apply(this, arguments); }
47855
47965
 
47856
- var _ref$1n = /*#__PURE__*/React__default.createElement("path", {
47966
+ var _ref$1o = /*#__PURE__*/React__default.createElement("path", {
47857
47967
  d: "M3658.026 10.064c5.915-.329 11.359 2.241 14.432 6.357l-5.498 2.292 14.488 7.78 4.678-15.768-5.437 2.266c-4.491-7.516-13.347-12.235-23.194-11.634-12.153.737-22.056 9.888-23.034 21.285l8.693.746c.612-7.121 7.003-12.847 14.872-13.324zM3661.635 45.864c-6.105.345-11.715-2.402-14.729-6.753l4.887-2.037-13.401-7.196-4.324 14.584 4.657-1.941c4.157 7.321 12.398 12.102 21.752 12.102.558 0 1.121-.017 1.687-.051 12.151-.737 22.054-9.888 23.032-21.285l-8.691-.746c-.615 7.12-7.005 12.846-14.87 13.323z"
47858
47968
  });
47859
47969
 
47860
- const SvgRefresh$1 = props => /*#__PURE__*/React__default.createElement("svg", _extends$1o({
47970
+ const SvgRefresh$1 = props => /*#__PURE__*/React__default.createElement("svg", _extends$1p({
47861
47971
  width: 60,
47862
47972
  height: 56,
47863
47973
  viewBox: "3630 0 60 56",
47864
47974
  fill: "currentColor"
47865
- }, props), _ref$1n);
47975
+ }, props), _ref$1o);
47866
47976
 
47867
47977
  var css_248z$u = ".loadingIndicator {\n position: absolute;\n top: 0;\n background: black;\n opacity: 1;\n width: 100%;\n height: 100%;\n text-align: center;\n z-index: 1;\n display: flex;\n align-items: center;\n justify-content: center;\n}\n.loadingIndicator .lds-ring {\n color: #999;\n position: absolute;\n left: 0;\n right: 0;\n top: 0;\n bottom: 0;\n width: 40px;\n height: 40px;\n margin: auto;\n}\n.loadingIndicator .lds-ring div {\n box-sizing: border-box;\n display: block;\n position: absolute;\n width: 40px;\n height: 40px;\n border: 4px solid silver;\n border-radius: 50%;\n animation: lds-ring 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite;\n border-color: silver transparent transparent transparent;\n}\n.loadingIndicator .lds-ring div:nth-child(1) {\n animation-delay: -0.45s;\n}\n.loadingIndicator .lds-ring div:nth-child(2) {\n animation-delay: -0.3s;\n}\n.loadingIndicator .lds-ring div:nth-child(3) {\n animation-delay: -0.15s;\n}\n@keyframes lds-ring {\n 0% {\n transform: rotate(0deg);\n }\n 100% {\n transform: rotate(360deg);\n }\n}\n.loadingIndicator .loadingIndicator-retry {\n width: 40px;\n color: #999;\n margin: 0 auto;\n font-size: 14px;\n}\n.loadingIndicator .indicatorContents h4 {\n font-size: 18px;\n margin: 0 auto 10px 0;\n}\n.loadingIndicator .indicatorContents h5 {\n font-size: 16px;\n margin: 0 auto 10px 0;\n}\n.loadingIndicator .indicatorContents p {\n margin: 4px auto;\n color: #999;\n font-size: 14px;\n}\n.loadingIndicator .indicatorContents .loadingIndicator-retry {\n width: 40px;\n margin: 20px auto 0 auto;\n}\n.loadingIndicator .indicatorContents-mini h4 {\n color: #fff;\n font-size: 12px;\n margin: 5px 0 5px 0;\n}\n.loadingIndicator .indicatorContents-mini .loadingIndicator-retry {\n width: 20px;\n font-size: 12px;\n}\n";
47868
47978
  styleInject$1(css_248z$u);
@@ -48608,9 +48718,65 @@ var ViewportOverlay = /*#__PURE__*/function (_PureComponent) {
48608
48718
  classCallCheck(this, ViewportOverlay);
48609
48719
 
48610
48720
  _this = _super.call(this, props);
48721
+
48722
+ defineProperty(assertThisInitialized(_this), "getPatientNameData", function () {
48723
+ var _this$state = _this.state,
48724
+ dicom = _this$state.dicom,
48725
+ basicInfoFrom = _this$state.basicInfoFrom;
48726
+ var basicInfoFromStudy = _this.props.basicInfoFromStudy;
48727
+
48728
+ if (basicInfoFrom && basicInfoFrom === 'study' && basicInfoFromStudy && basicInfoFromStudy.name) {
48729
+ return basicInfoFromStudy.name;
48730
+ } else {
48731
+ return dicom.PatientName.toString();
48732
+ }
48733
+ });
48734
+
48735
+ defineProperty(assertThisInitialized(_this), "getPatientSexData", function () {
48736
+ var _this$state2 = _this.state,
48737
+ dicom = _this$state2.dicom,
48738
+ basicInfoFrom = _this$state2.basicInfoFrom;
48739
+ var basicInfoFromStudy = _this.props.basicInfoFromStudy;
48740
+
48741
+ if (basicInfoFrom && basicInfoFrom === 'study' && basicInfoFromStudy && basicInfoFromStudy.patientSex) {
48742
+ return basicInfoFromStudy.patientSex;
48743
+ } else {
48744
+ return dicom.PatientSex.toString();
48745
+ }
48746
+ });
48747
+
48748
+ defineProperty(assertThisInitialized(_this), "getPatientAgeData", function () {
48749
+ var _this$state3 = _this.state,
48750
+ dicom = _this$state3.dicom,
48751
+ basicInfoFrom = _this$state3.basicInfoFrom;
48752
+ var basicInfoFromStudy = _this.props.basicInfoFromStudy;
48753
+
48754
+ if (basicInfoFrom && basicInfoFrom === 'study' && basicInfoFromStudy && basicInfoFromStudy.patientAge) {
48755
+ return basicInfoFromStudy.patientAge;
48756
+ } else {
48757
+ return dicom.PatientAge.toString();
48758
+ }
48759
+ });
48760
+
48761
+ defineProperty(assertThisInitialized(_this), "getPatientIDData", function () {
48762
+ var _this$state4 = _this.state,
48763
+ dicom = _this$state4.dicom,
48764
+ basicInfoFrom = _this$state4.basicInfoFrom;
48765
+ var basicInfoFromStudy = _this.props.basicInfoFromStudy;
48766
+
48767
+ if (basicInfoFrom && basicInfoFrom === 'study' && basicInfoFromStudy && basicInfoFromStudy.patientID) {
48768
+ return basicInfoFromStudy.patientID;
48769
+ } else {
48770
+ return dicom.PatientID.toString();
48771
+ }
48772
+ });
48773
+
48774
+ var _basicInfoFrom = window.localStorage.getItem('hellfire-dicom-basic-info-from') || 'dicom';
48775
+
48611
48776
  _this.state = {
48612
48777
  dicom: null,
48613
- fontSize: props.fontSize || 12
48778
+ fontSize: props.fontSize || 12,
48779
+ basicInfoFrom: _basicInfoFrom
48614
48780
  };
48615
48781
  return _this;
48616
48782
  }
@@ -48708,9 +48874,9 @@ var ViewportOverlay = /*#__PURE__*/function (_PureComponent) {
48708
48874
  return null;
48709
48875
  }
48710
48876
 
48711
- var _this$state = this.state,
48712
- dicom = _this$state.dicom,
48713
- fontSize = _this$state.fontSize;
48877
+ var _this$state5 = this.state,
48878
+ dicom = _this$state5.dicom,
48879
+ fontSize = _this$state5.fontSize;
48714
48880
 
48715
48881
  if (!dicom) {
48716
48882
  return null;
@@ -48751,10 +48917,10 @@ var ViewportOverlay = /*#__PURE__*/function (_PureComponent) {
48751
48917
  var institutionName = dicom.InstitutionName.toString();
48752
48918
  var manufacturer = dicom.Manufacturer.toString();
48753
48919
  var manufacturerModelName = dicom.ManufacturerModelName.toString();
48754
- var patientName = dicom.PatientName.toString();
48755
- var patientSex = dicom.PatientSex.toString();
48756
- var patientAge = dicom.PatientAge.toString();
48757
- var patientID = dicom.PatientID.toString();
48920
+ var patientName = this.getPatientNameData();
48921
+ var patientSex = this.getPatientSexData();
48922
+ var patientAge = this.getPatientAgeData();
48923
+ var patientID = this.getPatientIDData();
48758
48924
  var bodyPartExamined = dicom.BodyPartExamined.toString();
48759
48925
  var laterality = dicom.Laterality.toString() || dicom.ImageLaterality.toString() || ''; //左下
48760
48926
 
@@ -48845,31 +49011,31 @@ defineProperty(ViewportOverlay, "propTypes", {
48845
49011
  var css_248z$w = ".paladin-custom-scroll {\n cursor: pointer;\n background: #333333;\n position: relative;\n border-color: #727882;\n border-style: solid;\n border-width: 0;\n box-sizing: border-box;\n}\n.paladin-custom-scroll .paladin-custom-scroll-controller {\n position: absolute;\n width: 100%;\n height: 100%;\n}\n.paladin-custom-scroll .paladin-custom-scroll-controller .paladin-custom-scroll-box {\n position: absolute;\n top: 0;\n left: 0;\n height: 16px;\n width: 16px;\n background: rgba(91, 91, 91, 0.8);\n}\n.paladin-custom-scroll .paladin-custom-scroll-ctrl-up {\n width: 16px;\n height: 20px;\n background: #5b5b5b;\n position: absolute;\n top: 0;\n}\n.paladin-custom-scroll .paladin-custom-scroll-ctrl-up svg {\n color: #ccc;\n}\n.paladin-custom-scroll .paladin-custom-scroll-ctrl-down {\n width: 16px;\n height: 20px;\n background: #5b5b5b;\n position: absolute;\n bottom: 0;\n}\n.paladin-custom-scroll .paladin-custom-scroll-ctrl-down svg {\n color: #ccc;\n}\n";
48846
49012
  styleInject$1(css_248z$w);
48847
49013
 
48848
- function _extends$1p() { _extends$1p = Object.assign || 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$1p.apply(this, arguments); }
49014
+ function _extends$1q() { _extends$1q = Object.assign || 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$1q.apply(this, arguments); }
48849
49015
 
48850
- var _ref$1o = /*#__PURE__*/React__default.createElement("path", {
49016
+ var _ref$1p = /*#__PURE__*/React__default.createElement("path", {
48851
49017
  d: "M30.054 23.768l-2.964 2.946q-.339.339-.804.339t-.804-.339L16 17.232l-9.482 9.482q-.339.339-.804.339t-.804-.339l-2.964-2.946q-.339-.339-.339-.813t.339-.813L15.196 8.91q.339-.339.804-.339t.804.339l13.25 13.232q.339.339.339.813t-.339.813z"
48852
49018
  });
48853
49019
 
48854
- const SvgChevronUp = props => /*#__PURE__*/React__default.createElement("svg", _extends$1p({
49020
+ const SvgChevronUp = props => /*#__PURE__*/React__default.createElement("svg", _extends$1q({
48855
49021
  width: 32,
48856
49022
  height: 32,
48857
49023
  viewBox: "0 0 32 32",
48858
49024
  fill: "currentColor"
48859
- }, props), _ref$1o);
49025
+ }, props), _ref$1p);
48860
49026
 
48861
- function _extends$1q() { _extends$1q = Object.assign || 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$1q.apply(this, arguments); }
49027
+ function _extends$1r() { _extends$1r = Object.assign || 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$1r.apply(this, arguments); }
48862
49028
 
48863
- var _ref$1p = /*#__PURE__*/React__default.createElement("path", {
49029
+ var _ref$1q = /*#__PURE__*/React__default.createElement("path", {
48864
49030
  d: "M30.054 14.429l-13.25 13.232Q16.465 28 16 28t-.804-.339L1.946 14.429q-.339-.339-.339-.813t.339-.813L4.91 9.857q.339-.339.804-.339t.804.339L16 19.339l9.482-9.482q.339-.339.804-.339t.804.339l2.964 2.946q.339.339.339.813t-.339.813z"
48865
49031
  });
48866
49032
 
48867
- const SvgChevronDown = props => /*#__PURE__*/React__default.createElement("svg", _extends$1q({
49033
+ const SvgChevronDown = props => /*#__PURE__*/React__default.createElement("svg", _extends$1r({
48868
49034
  width: 32,
48869
49035
  height: 32,
48870
49036
  viewBox: "0 0 32 32",
48871
49037
  fill: "currentColor"
48872
- }, props), _ref$1p);
49038
+ }, props), _ref$1q);
48873
49039
 
48874
49040
  var css_248z$x = ".paladin-aiTips-wrapper {\n width: 100%;\n height: 100%;\n}\n.paladin-aiTips-content {\n width: 1px;\n height: 100%;\n background: #ffff00;\n position: absolute;\n top: 0;\n}\n";
48875
49041
  styleInject$1(css_248z$x);
@@ -50809,7 +50975,18 @@ var DicomViewport = /*#__PURE__*/function (_Component) {
50809
50975
  var _stack = lodash$1.cloneDeep(_props.stack); // 初始化的index
50810
50976
 
50811
50977
 
50812
- _this.setCurrentImageIdIndex(_props, _stack);
50978
+ _this.setCurrentImageIdIndex(_props, _stack); // originStudy中提取basicInfoFromStudy 供四角信息
50979
+
50980
+
50981
+ var basicInfoFromStudy;
50982
+
50983
+ if (_this.props.originStudy) {
50984
+ var currentStudy = lodash$1.find(_this.props.originStudy, {
50985
+ studyInstanceUID: _stack.studyInstanceUID
50986
+ });
50987
+
50988
+ basicInfoFromStudy = lodash$1.pick(currentStudy, ['name', 'patientAge', 'patientSex', 'patientID']);
50989
+ }
50813
50990
 
50814
50991
  _this.state = {
50815
50992
  isLoading: false,
@@ -50823,7 +51000,8 @@ var DicomViewport = /*#__PURE__*/function (_Component) {
50823
51000
  //mpr模式的层厚倍数
50824
51001
  forceRender: false,
50825
51002
  aiTipInCustomScroll: null,
50826
- centesisTipInCustomScroll: null
51003
+ centesisTipInCustomScroll: null,
51004
+ basicInfoFromStudy: basicInfoFromStudy
50827
51005
  };
50828
51006
  _this.onImageRendered = _this.onImageRendered.bind(assertThisInitialized(_this));
50829
51007
  _this.onNewImage = _this.onNewImage.bind(assertThisInitialized(_this));
@@ -50863,7 +51041,8 @@ var DicomViewport = /*#__PURE__*/function (_Component) {
50863
51041
  aiTipInCustomScroll = _this$state.aiTipInCustomScroll,
50864
51042
  centesisTipInCustomScroll = _this$state.centesisTipInCustomScroll,
50865
51043
  stack = _this$state.stack,
50866
- domError = _this$state.domError;
51044
+ domError = _this$state.domError,
51045
+ basicInfoFromStudy = _this$state.basicInfoFromStudy;
50867
51046
  var _this$props4 = this.props,
50868
51047
  showCustomScroll = _this$props4.showCustomScroll,
50869
51048
  mpr = _this$props4.mpr,
@@ -50939,6 +51118,7 @@ var DicomViewport = /*#__PURE__*/function (_Component) {
50939
51118
  viewport: viewport,
50940
51119
  imageId: imageId,
50941
51120
  stack: stack,
51121
+ basicInfoFromStudy: basicInfoFromStudy,
50942
51122
  sliceThickness: sliceThickness,
50943
51123
  cpr: CPR,
50944
51124
  mpr: mpr
@@ -51717,7 +51897,8 @@ var mapStateToProps$m = function mapStateToProps(state) {
51717
51897
  linkSynchronizer = _state$paladin$viewpo.linkSynchronizer,
51718
51898
  linkImageModeSynchronizer = _state$paladin$viewpo.linkImageModeSynchronizer,
51719
51899
  seriesCurrentIndex = _state$paladin$viewpo.seriesCurrentIndex,
51720
- positionSynchronizer = _state$paladin$viewpo.positionSynchronizer;
51900
+ positionSynchronizer = _state$paladin$viewpo.positionSynchronizer,
51901
+ originStudy = _state$paladin$viewpo.originStudy;
51721
51902
  return {
51722
51903
  activeTool: activeTool,
51723
51904
  originActiveTool: originActiveTool,
@@ -51740,7 +51921,8 @@ var mapStateToProps$m = function mapStateToProps(state) {
51740
51921
  ReferencePosition: ReferencePosition,
51741
51922
  CPR: CPR,
51742
51923
  referenceLineType: referenceLineType,
51743
- keyImages: keyImages
51924
+ keyImages: keyImages,
51925
+ originStudy: originStudy
51744
51926
  };
51745
51927
  };
51746
51928
 
@@ -54996,52 +55178,52 @@ function studySeriesDataCheck (studies) {
54996
55178
  var css_248z$F = ".paladin-film-tool {\n width: 220px;\n color: #c0c0c0;\n padding: 10px;\n font-size: 15px;\n}\n.paladin-film-tool .film-full-line {\n width: 100%;\n height: 1px;\n background: #777676;\n margin: 10px 0;\n}\n.paladin-film-tool .film-half-button,\n.paladin-film-tool .film-full-button {\n display: flex;\n justify-content: center;\n align-items: center;\n cursor: pointer;\n height: 40px;\n border: 1px solid #1c1c1c;\n box-sizing: border-box;\n}\n.paladin-film-tool .film-half-button svg,\n.paladin-film-tool .film-full-button svg {\n width: 18px;\n height: 18px;\n margin-right: 6px;\n}\n.paladin-film-tool .film-half-button {\n width: 50%;\n}\n.paladin-film-tool .film-full-button {\n width: 100%;\n}\n.paladin-film-tool .film-template-box {\n display: flex;\n width: 100%;\n height: 40px;\n border: 1px solid #1c1c1c;\n box-sizing: border-box;\n}\n.paladin-film-tool .film-template-box div {\n display: flex;\n flex: 1;\n cursor: pointer;\n align-items: center;\n}\n.paladin-film-tool .film-template-box .template-add {\n flex: none;\n padding-left: 5px;\n padding-right: 7px;\n border-right: 1px solid #1c1c1c;\n height: 100%;\n}\n.paladin-film-tool .film-template-box .template-select {\n justify-content: center;\n}\n.paladin-film-tool .film-template-box .template-select svg {\n width: 18px;\n margin-left: 3px;\n}\n.paladin-film-tool .film-template-box .template-setting {\n height: 100%;\n width: 20px;\n flex: none;\n padding-left: 7px;\n padding-right: 5px;\n border-left: 1px solid #1c1c1c;\n}\n.paladin-film-tool .film-template-box .template-setting svg {\n width: 20px;\n}\n.paladin-film-tool .film-size-box {\n margin: 20px 0;\n display: flex;\n align-items: center;\n}\n.paladin-film-tool .film-size-box span {\n display: flex;\n flex: none;\n margin-right: 8px;\n}\n.paladin-film-tool .film-size-box .film-size-select {\n height: 40px;\n display: flex;\n flex: 1;\n align-items: center;\n justify-content: center;\n border: 1px solid #1c1c1c;\n box-sizing: border-box;\n}\n.paladin-film-tool .film-size-box button {\n border: none;\n width: 100%;\n height: 100%;\n background: #353535;\n color: #c0c0c0;\n font-size: 15px;\n}\n.paladin-film-tool .film-size-box svg {\n width: 20px;\n}\n.paladin-film-tool .g-rgl-grid {\n padding: 12px;\n}\n.paladin-dropdown-custom {\n z-index: 99;\n left: 50px !important;\n}\n.paladin-menu-custom {\n width: 180px;\n background: #000000;\n color: #c0c0c0;\n padding: 0;\n}\n.paladin-menu-custom li {\n text-align: center;\n list-style: none;\n border-bottom: 1px solid #4D4D4D;\n padding: 6px 0;\n cursor: pointer;\n}\n.paladin-menu-custom li:last-child {\n border-bottom: none;\n}\n.rc-dropdown-hidden {\n display: none;\n}\n.paladin-film-print-modal-wrapper {\n overflow: hidden;\n}\n.paladin-film-print-modal-wrapper .paladin-modal-header {\n color: #fff;\n font-weight: normal;\n font-size: 16px;\n border-bottom: 1px solid #484849;\n}\n.paladin-film-print-modal-wrapper .paladin-modal-footer {\n border: none;\n}\n";
54997
55179
  styleInject$1(css_248z$F);
54998
55180
 
54999
- function _extends$1r() { _extends$1r = Object.assign || 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$1r.apply(this, arguments); }
55181
+ function _extends$1s() { _extends$1s = Object.assign || 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$1s.apply(this, arguments); }
55000
55182
 
55001
- var _ref$1q = /*#__PURE__*/React__default.createElement("path", {
55183
+ var _ref$1r = /*#__PURE__*/React__default.createElement("path", {
55002
55184
  "data-name": "\\u64A4\\u9500 \\u8FD4\\u56DE \\u64A4\\u56DE \\u4E0A\\u4E00\\u6B65",
55003
55185
  d: "M10.16 3.407H1.851L4.34.921a.54.54 0 00-.764-.762L.159 3.572a.538.538 0 000 .763l3.417 3.413a.54.54 0 00.764-.763L1.884 4.534h8.276a3.377 3.377 0 110 6.753H2.844a.563.563 0 100 1.126h7.316a4.5 4.5 0 000-9z",
55004
55186
  fill: "silver"
55005
55187
  });
55006
55188
 
55007
- const SvgFilmBack = props => /*#__PURE__*/React__default.createElement("svg", _extends$1r({
55189
+ const SvgFilmBack = props => /*#__PURE__*/React__default.createElement("svg", _extends$1s({
55008
55190
  width: 14.663,
55009
55191
  height: 12.411,
55010
55192
  viewBox: "0 0 14.663 12.411",
55011
55193
  fill: "currentColor"
55012
- }, props), _ref$1q);
55194
+ }, props), _ref$1r);
55013
55195
 
55014
- function _extends$1s() { _extends$1s = Object.assign || 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$1s.apply(this, arguments); }
55196
+ function _extends$1t() { _extends$1t = Object.assign || 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$1t.apply(this, arguments); }
55015
55197
 
55016
- var _ref$1r = /*#__PURE__*/React__default.createElement("path", {
55198
+ var _ref$1s = /*#__PURE__*/React__default.createElement("path", {
55017
55199
  d: "M.006 0v4.388h4.486V0zm6.287 0v4.388h4.487V0zm6.358 0v4.388h4.489V0zM0 6.199v4.388h4.486V6.199zm6.287 0v4.388h4.486V6.199zm6.358 0v4.388h4.486V6.199zM0 12.369v4.389h4.486v-4.389zm6.287 0v4.389h4.486v-4.389zm6.358 0v4.389h4.486v-4.389z",
55018
55200
  fill: "silver"
55019
55201
  });
55020
55202
 
55021
- const SvgFilmLayout = props => /*#__PURE__*/React__default.createElement("svg", _extends$1s({
55203
+ const SvgFilmLayout = props => /*#__PURE__*/React__default.createElement("svg", _extends$1t({
55022
55204
  width: 17.137,
55023
55205
  height: 16.762,
55024
55206
  viewBox: "0 0 17.137 16.762",
55025
55207
  fill: "currentColor"
55026
- }, props), _ref$1r);
55208
+ }, props), _ref$1s);
55027
55209
 
55028
- function _extends$1t() { _extends$1t = Object.assign || 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$1t.apply(this, arguments); }
55210
+ function _extends$1u() { _extends$1u = Object.assign || 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$1u.apply(this, arguments); }
55029
55211
 
55030
- var _ref$1s = /*#__PURE__*/React__default.createElement("path", {
55212
+ var _ref$1t = /*#__PURE__*/React__default.createElement("path", {
55031
55213
  d: "M8.933 7.751a.842.842 0 01.842.842v2.022a.842.842 0 01-.842.842H3.878a.842.842 0 01-.842-.842V8.593a.842.842 0 01.842-.842zm.674-7.75a1.179 1.179 0 011.178 1.115V1.686h.168a1.853 1.853 0 011.852 1.779v5.129a1.853 1.853 0 01-1.779 1.852h-.243V8.593A1.853 1.853 0 008.93 6.74H3.875a1.853 1.853 0 00-1.853 1.853v1.853h-.168A1.853 1.853 0 01.001 8.667V3.538A1.853 1.853 0 011.78 1.686h.243v-.505A1.179 1.179 0 013.138.003h.065zm.674 3.707h-.674a.505.505 0 00-.049 1.009H10.281a.506.506 0 100-1.011zm-.674-2.7h-6.4a.169.169 0 00-.166.138v.535H9.78v-.505a.168.168 0 00-.138-.166z",
55032
55214
  fill: "silver"
55033
55215
  });
55034
55216
 
55035
- const SvgPrint = props => /*#__PURE__*/React__default.createElement("svg", _extends$1t({
55217
+ const SvgPrint = props => /*#__PURE__*/React__default.createElement("svg", _extends$1u({
55036
55218
  width: 12.805,
55037
55219
  height: 11.457,
55038
55220
  viewBox: "0 0 12.805 11.457",
55039
55221
  fill: "currentColor"
55040
- }, props), _ref$1s);
55222
+ }, props), _ref$1t);
55041
55223
 
55042
- function _extends$1u() { _extends$1u = Object.assign || 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$1u.apply(this, arguments); }
55224
+ function _extends$1v() { _extends$1v = Object.assign || 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$1v.apply(this, arguments); }
55043
55225
 
55044
- var _ref$1t = /*#__PURE__*/React__default.createElement("path", {
55226
+ var _ref$1u = /*#__PURE__*/React__default.createElement("path", {
55045
55227
  d: "M9.357 0a1.149 1.149 0 011.147 1.086V1.641h.164a1.806 1.806 0 011.8 1.733v5a1.806 1.806 0 01-1.733 1.8h-.237V8.368a1.806 1.806 0 00-1.806-1.806H3.767a1.806 1.806 0 00-1.806 1.806v1.806h-.164a1.806 1.806 0 01-1.8-1.733v-5a1.806 1.806 0 011.733-1.8h.237v-.492A1.149 1.149 0 013.053.002h.063zm.657 3.611h-.657a.492.492 0 00-.047.983H10.014a.492.492 0 100-.985zM9.357.984H3.119a.164.164 0 00-.162.135v.522h6.566v-.492a.164.164 0 00-.135-.162z",
55046
55228
  fill: "silver"
55047
55229
  });
@@ -55051,13 +55233,13 @@ var _ref2$g = /*#__PURE__*/React__default.createElement("path", {
55051
55233
  fill: "silver"
55052
55234
  });
55053
55235
 
55054
- const SvgPrintSetting = props => /*#__PURE__*/React__default.createElement("svg", _extends$1u({
55236
+ const SvgPrintSetting = props => /*#__PURE__*/React__default.createElement("svg", _extends$1v({
55055
55237
  "data-name": "\\u7EC4 3872",
55056
55238
  width: 12.476,
55057
55239
  height: 12.949,
55058
55240
  viewBox: "0 0 12.476 12.949",
55059
55241
  fill: "currentColor"
55060
- }, props), _ref$1t, _ref2$g);
55242
+ }, props), _ref$1u, _ref2$g);
55061
55243
 
55062
55244
  function _createSuper$1C(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$1C(); return function _createSuperInternal() { var Super = getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return possibleConstructorReturn(this, result); }; }
55063
55245
 
@@ -55547,7 +55729,7 @@ module.exports = { "default": assign, __esModule: true };
55547
55729
 
55548
55730
  unwrapExports(assign$1);
55549
55731
 
55550
- var _extends$1v = createCommonjsModule(function (module, exports) {
55732
+ var _extends$1w = createCommonjsModule(function (module, exports) {
55551
55733
 
55552
55734
  exports.__esModule = true;
55553
55735
 
@@ -55572,7 +55754,7 @@ exports.default = _assign2.default || function (target) {
55572
55754
  };
55573
55755
  });
55574
55756
 
55575
- var _extends$1w = unwrapExports(_extends$1v);
55757
+ var _extends$1x = unwrapExports(_extends$1w);
55576
55758
 
55577
55759
  /*
55578
55760
  object-assign
@@ -57463,7 +57645,7 @@ var classnames = createCommonjsModule(function (module) {
57463
57645
  }());
57464
57646
  });
57465
57647
 
57466
- var _extends$1x = Object.assign || 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; };
57648
+ var _extends$1y = Object.assign || 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; };
57467
57649
 
57468
57650
  var _typeof$1 = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; };
57469
57651
 
@@ -57837,7 +58019,7 @@ function setOffset(elem, offset) {
57837
58019
  css$1(elem, ret);
57838
58020
  }
57839
58021
 
57840
- var util = _extends$1x({
58022
+ var util = _extends$1y({
57841
58023
  getWindow: function getWindow(node) {
57842
58024
  var doc = node.ownerDocument || node;
57843
58025
  return doc.defaultView || doc.parentWindow;
@@ -58104,7 +58286,7 @@ Object.defineProperty(exports, "__esModule", {
58104
58286
 
58105
58287
 
58106
58288
 
58107
- var _extends3 = _interopRequireDefault(_extends$1v);
58289
+ var _extends3 = _interopRequireDefault(_extends$1w);
58108
58290
 
58109
58291
 
58110
58292
 
@@ -58162,7 +58344,7 @@ Object.defineProperty(exports, "__esModule", {
58162
58344
 
58163
58345
 
58164
58346
 
58165
- var _extends3 = _interopRequireDefault(_extends$1v);
58347
+ var _extends3 = _interopRequireDefault(_extends$1w);
58166
58348
 
58167
58349
 
58168
58350
 
@@ -58496,7 +58678,7 @@ Object.defineProperty(exports, "__esModule", {
58496
58678
 
58497
58679
 
58498
58680
 
58499
- var _extends3 = _interopRequireDefault(_extends$1v);
58681
+ var _extends3 = _interopRequireDefault(_extends$1w);
58500
58682
 
58501
58683
 
58502
58684
 
@@ -60341,7 +60523,7 @@ function isPointsEq(a1, a2, isAlignPoint) {
60341
60523
 
60342
60524
  function getAlignFromPlacement(builtinPlacements, placementStr, align) {
60343
60525
  var baseAlign = builtinPlacements[placementStr] || {};
60344
- return _extends$1w({}, baseAlign, align);
60526
+ return _extends$1x({}, baseAlign, align);
60345
60527
  }
60346
60528
 
60347
60529
  function getAlignPopupClassName(builtinPlacements, prefixCls, align, isAlignPoint) {
@@ -62910,7 +63092,7 @@ var Animate = function (_React$Component) {
62910
63092
  if (Component) {
62911
63093
  var passedProps = props;
62912
63094
  if (typeof Component === 'string') {
62913
- passedProps = _extends$1w({
63095
+ passedProps = _extends$1x({
62914
63096
  className: props.className,
62915
63097
  style: props.style
62916
63098
  }, props.componentProps);
@@ -63263,7 +63445,7 @@ var Popup = function (_Component) {
63263
63445
  }
63264
63446
  }
63265
63447
 
63266
- var newStyle = _extends$1w({}, sizeStyle, style, this.getZIndexStyle());
63448
+ var newStyle = _extends$1x({}, sizeStyle, style, this.getZIndexStyle());
63267
63449
 
63268
63450
  var popupInnerProps = {
63269
63451
  className: className,
@@ -63296,7 +63478,7 @@ var Popup = function (_Component) {
63296
63478
  },
63297
63479
  React__default.createElement(
63298
63480
  PopupInner,
63299
- _extends$1w({
63481
+ _extends$1x({
63300
63482
  visible: true
63301
63483
  }, popupInnerProps),
63302
63484
  children
@@ -63329,7 +63511,7 @@ var Popup = function (_Component) {
63329
63511
  },
63330
63512
  React__default.createElement(
63331
63513
  PopupInner,
63332
- _extends$1w({
63514
+ _extends$1x({
63333
63515
  hiddenClassName: hiddenClassName
63334
63516
  }, popupInnerProps),
63335
63517
  children
@@ -64117,7 +64299,7 @@ var _initialiseProps$2 = function _initialiseProps() {
64117
64299
 
64118
64300
  return React__default.createElement(
64119
64301
  Popup,
64120
- _extends$1w({
64302
+ _extends$1x({
64121
64303
  prefixCls: prefixCls,
64122
64304
  destroyPopupOnHide: destroyPopupOnHide,
64123
64305
  visible: popupVisible,
@@ -64196,7 +64378,7 @@ var _typeof3 = _interopRequireDefault(_typeof_1$1);
64196
64378
 
64197
64379
 
64198
64380
 
64199
- var _extends3 = _interopRequireDefault(_extends$1v);
64381
+ var _extends3 = _interopRequireDefault(_extends$1w);
64200
64382
 
64201
64383
 
64202
64384
 
@@ -64361,7 +64543,7 @@ var _defineProperty3 = _interopRequireDefault(defineProperty$6);
64361
64543
 
64362
64544
 
64363
64545
 
64364
- var _extends3 = _interopRequireDefault(_extends$1v);
64546
+ var _extends3 = _interopRequireDefault(_extends$1w);
64365
64547
 
64366
64548
 
64367
64549
 
@@ -64804,7 +64986,7 @@ Object.defineProperty(exports, "__esModule", {
64804
64986
 
64805
64987
 
64806
64988
 
64807
- var _extends3 = _interopRequireDefault(_extends$1v);
64989
+ var _extends3 = _interopRequireDefault(_extends$1w);
64808
64990
 
64809
64991
 
64810
64992
 
@@ -65449,18 +65631,18 @@ var FilmToolVerticalMode = /*#__PURE__*/function (_Component) {
65449
65631
  var css_248z$H = ".paladin-film-print-modal table {\n width: 100%;\n border-collapse: collapse;\n border-spacing: 0;\n border: 1px solid #525253;\n border-bottom: none;\n}\n.paladin-film-print-modal table svg {\n width: 20px;\n}\n.paladin-film-print-modal table tr {\n height: 54px;\n margin-left: 30px;\n border-bottom: 1px solid #525253;\n}\n.paladin-film-print-modal table tr .th-1 {\n width: 3%;\n}\n.paladin-film-print-modal table tr .th-2 {\n width: 18%;\n}\n.paladin-film-print-modal table tr .th-3 {\n width: 13%;\n}\n.paladin-film-print-modal table tr .th-4 {\n width: 19%;\n}\n.paladin-film-print-modal table tr .th-5 {\n width: 15%;\n}\n.paladin-film-print-modal table tr .th-6 {\n width: 12%;\n}\n.paladin-film-print-modal table tr .th-7 {\n width: 16%;\n}\n.paladin-film-print-modal table tr th {\n background: #404041;\n}\n.paladin-film-print-modal table tr th,\n.paladin-film-print-modal table tr td {\n text-align: left;\n font-weight: normal;\n font-size: 14px;\n word-wrap: break-word;\n word-break: break-all;\n}\n.paladin-film-print-modal table tr th button,\n.paladin-film-print-modal table tr td button {\n border: none;\n background: transparent;\n color: #3C7EFF;\n}\n.paladin-film-print-modal .print-modal-top {\n margin-bottom: 24px;\n margin-top: 5px;\n}\n.paladin-film-print-modal .print-modal-top button {\n background: #3C7EFF;\n}\n.paladin-film-print-modal .printer-config-add-title {\n color: #3C7EFF;\n margin-left: 30px;\n}\n.paladin-film-print-modal .printer-config-form {\n margin-top: 20px;\n}\n.paladin-film-print-modal .printer-config-form .paladin-ipt {\n color: #ccc;\n border: 1px solid rgba(255, 255, 255, 0.2);\n}\n.paladin-film-print-modal .printer-config-form .paladin-row {\n margin-bottom: 18px;\n}\n.paladin-film-print-modal .printer-config-form .paladin-col {\n padding-right: 20px;\n}\n.paladin-film-print-modal .printer-config-form .paladin-col-xs-2 {\n justify-content: center;\n align-items: end;\n}\n.paladin-film-print-modal .printer-config-form .printer-config-form-radio .paladin-ipt {\n width: 20px;\n}\n.paladin-film-print-modal .film-box {\n display: flex;\n align-items: center;\n}\n.paladin-film-print-modal .film-box span {\n display: flex;\n flex: none;\n width: 100px;\n}\n.paladin-film-print-modal .film-box .film-select {\n cursor: pointer;\n width: 200px;\n height: 40px;\n display: flex;\n position: relative;\n align-items: center;\n justify-content: center;\n background: #1f1f1f;\n border: 1px solid rgba(255, 255, 255, 0.2);\n}\n.paladin-film-print-modal .film-box button {\n border: none;\n box-sizing: border-box;\n width: 100%;\n height: 100%;\n background: #1f1f1f;\n color: #c0c0c0;\n font-size: 15px;\n}\n.paladin-film-print-modal .film-box svg {\n width: 20px;\n position: absolute;\n right: 5px;\n top: 0;\n}\n.paladin-film-print-modal .film-printer-info {\n margin-left: 100px;\n color: #A4A4A4;\n}\n.paladin-film-print-modal .film-printer-info p {\n margin-top: 15px;\n}\n.paladin-film-print-modal .paladin-menu-custom {\n width: 200px;\n background: #000000;\n color: #c0c0c0;\n padding: 0;\n margin: 0;\n}\n.paladin-film-print-modal .paladin-menu-custom li {\n text-align: center;\n list-style: none;\n border-bottom: 1px solid #4D4D4D;\n padding: 6px 0;\n cursor: pointer;\n}\n.paladin-film-print-modal .paladin-menu-custom li:last-child {\n border-bottom: none;\n}\n.paladin-film-print-modal .film-button-select {\n height: 36px;\n}\n.paladin-film-print-modal .film-button-select .paladin-col {\n justify-content: center;\n}\n.paladin-film-print-modal .film-button-select-item {\n cursor: pointer;\n display: flex;\n flex: 1;\n align-items: center;\n justify-content: center;\n height: 36px;\n border: 1px solid #555555;\n border-right: none;\n}\n.paladin-film-print-modal .film-button-select-item:last-child {\n border-right: 1px solid #555555;\n}\n.paladin-film-print-modal .film-button-select-item-active {\n background: #3C7EFF;\n color: #fff;\n}\n.paladin-film-print-modal .print-modal-bottom {\n margin-top: 30px;\n text-align: right;\n}\n.paladin-film-print-modal .print-modal-bottom .paladin-default {\n background: #454545;\n border: 1px solid #707070;\n color: rgba(255, 255, 255, 0.9);\n}\n.paladin-film-print-modal .print-modal-bottom .paladin-primary {\n background: #3C7EFF;\n}\n";
65450
65632
  styleInject$1(css_248z$H);
65451
65633
 
65452
- function _extends$1y() { _extends$1y = Object.assign || 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$1y.apply(this, arguments); }
65634
+ function _extends$1z() { _extends$1z = Object.assign || 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$1z.apply(this, arguments); }
65453
65635
 
65454
- var _ref$1u = /*#__PURE__*/React__default.createElement("path", {
65636
+ var _ref$1v = /*#__PURE__*/React__default.createElement("path", {
65455
65637
  d: "M29.839 10.107q0 .714-.5 1.214L13.982 26.678q-.5.5-1.214.5t-1.214-.5l-8.893-8.893q-.5-.5-.5-1.214t.5-1.214l2.429-2.429q.5-.5 1.214-.5t1.214.5l5.25 5.268L24.482 6.464q.5-.5 1.214-.5t1.214.5l2.429 2.429q.5.5.5 1.214z"
65456
65638
  });
65457
65639
 
65458
- const SvgOk = props => /*#__PURE__*/React__default.createElement("svg", _extends$1y({
65640
+ const SvgOk = props => /*#__PURE__*/React__default.createElement("svg", _extends$1z({
65459
65641
  width: 32,
65460
65642
  height: 32,
65461
65643
  viewBox: "0 0 32 32",
65462
65644
  fill: "currentColor"
65463
- }, props), _ref$1u);
65645
+ }, props), _ref$1v);
65464
65646
 
65465
65647
  function ownKeys$Y(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
65466
65648
 
@@ -66643,19 +66825,19 @@ var drawRightBottom = function drawRightBottom(dicom, ctx, width, height, viewpo
66643
66825
  ctx.fillText("W: ".concat(windowWidth.toFixed(0)), contentX, contentY);
66644
66826
  };
66645
66827
 
66646
- function _extends$1z() { _extends$1z = Object.assign || 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$1z.apply(this, arguments); }
66828
+ function _extends$1A() { _extends$1A = Object.assign || 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$1A.apply(this, arguments); }
66647
66829
 
66648
- var _ref$1v = /*#__PURE__*/React__default.createElement("path", {
66830
+ var _ref$1w = /*#__PURE__*/React__default.createElement("path", {
66649
66831
  d: "M185.884 327.55L146.3 367.133l365.721 365.646L877.7 367.133l-39.583-39.583-326.12 326.126z"
66650
66832
  });
66651
66833
 
66652
- const SvgDown = props => /*#__PURE__*/React__default.createElement("svg", _extends$1z({
66834
+ const SvgDown = props => /*#__PURE__*/React__default.createElement("svg", _extends$1A({
66653
66835
  className: "down_svg__icon",
66654
66836
  viewBox: "0 0 1024 1024",
66655
66837
  width: 200,
66656
66838
  height: 200,
66657
66839
  fill: "currentColor"
66658
- }, props), _ref$1v);
66840
+ }, props), _ref$1w);
66659
66841
 
66660
66842
  function ownKeys$_(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
66661
66843
 
@@ -67179,7 +67361,7 @@ var mergeProps$v = function mergeProps(propsFromState, propsFromDispatch, ownPro
67179
67361
  reset: function reset() {
67180
67362
  if (propsFromState.filmActiveIndex >= 0) {
67181
67363
  var activeElement = document.getElementById("paladin-film-viewport-".concat(propsFromState.filmActiveIndex));
67182
- resetOnly(activeElement);
67364
+ resetOnlyAndSync(activeElement);
67183
67365
  }
67184
67366
  },
67185
67367
  handleClearFilms: function handleClearFilms() {
@@ -67327,6 +67509,8 @@ var FilmViewport = /*#__PURE__*/function (_Component) {
67327
67509
  if (_this.element) {
67328
67510
  cornerstone.displayImage(_this.element, image);
67329
67511
 
67512
+ _this.initSync();
67513
+
67330
67514
  if (!nextStack) {
67331
67515
  cornerstoneTools.setToolActiveForElement(_this.element, 'OrientationMarkers');
67332
67516
  cornerstoneTools.setToolActiveForElement(_this.element, 'RulerOverlay');
@@ -67345,6 +67529,19 @@ var FilmViewport = /*#__PURE__*/function (_Component) {
67345
67529
  });
67346
67530
  });
67347
67531
 
67532
+ defineProperty(assertThisInitialized(_this), "initSync", function () {
67533
+ var _this$props = _this.props,
67534
+ filmSynchronizer = _this$props.filmSynchronizer,
67535
+ filmRelativeIndexes = _this$props.filmRelativeIndexes,
67536
+ active = _this$props.active,
67537
+ index = _this$props.index;
67538
+ filmSynchronizer.remove(_this.element);
67539
+
67540
+ if (lodash$1.includes(filmRelativeIndexes, index) || active) {
67541
+ filmSynchronizer.add(_this.element);
67542
+ }
67543
+ });
67544
+
67348
67545
  defineProperty(assertThisInitialized(_this), "setActiveTool", function () {
67349
67546
  var activeTool = _this.props.filmActiveTool;
67350
67547
 
@@ -67386,6 +67583,35 @@ var FilmViewport = /*#__PURE__*/function (_Component) {
67386
67583
  });
67387
67584
  });
67388
67585
 
67586
+ defineProperty(assertThisInitialized(_this), "onMouseUp", function (e) {
67587
+ var index = _this.props.index; // 判断是否按住ctrl
67588
+
67589
+ if (e && e.ctrlKey) {
67590
+ _this.props.handleCtrlSelect(_this.element, index);
67591
+ }
67592
+ });
67593
+
67594
+ defineProperty(assertThisInitialized(_this), "onMouseDown", function (e) {
67595
+ if (e && e.ctrlKey) {
67596
+ return;
67597
+ }
67598
+
67599
+ e.stopPropagation();
67600
+ var filmActiveTool = _this.props.filmActiveTool;
67601
+ var commonTools = ['Wwwc', 'Pan', 'Zoom'];
67602
+
67603
+ if (filmActiveTool && lodash$1.includes(commonTools, filmActiveTool)) {
67604
+ window.onmouseup = function (e) {
67605
+ var _this$props2 = _this.props,
67606
+ filmActiveTool = _this$props2.filmActiveTool,
67607
+ filmSynchronizer = _this$props2.filmSynchronizer;
67608
+ var syncElements = filmSynchronizer && filmSynchronizer.getSourceElements();
67609
+ relativeChangeSetViewport(e, _this.element, filmActiveTool, null, null, syncElements);
67610
+ window.onmouseup = null;
67611
+ };
67612
+ }
67613
+ });
67614
+
67389
67615
  defineProperty(assertThisInitialized(_this), "onContextMenu", function (event) {
67390
67616
  event.preventDefault();
67391
67617
  });
@@ -67466,6 +67692,7 @@ var FilmViewport = /*#__PURE__*/function (_Component) {
67466
67692
  if (this.element) {
67467
67693
  this.removeEventListener();
67468
67694
  unusedSynchronizer.remove(this.element);
67695
+ this.props.filmSynchronizer.remove(this.element);
67469
67696
  cornerstone.disable(this.element);
67470
67697
  this.element = null;
67471
67698
  }
@@ -67475,12 +67702,16 @@ var FilmViewport = /*#__PURE__*/function (_Component) {
67475
67702
  value: function addEventListener() {
67476
67703
  this.element.addEventListener(cornerstone.EVENTS.IMAGE_RENDERED, this.onImageRendered);
67477
67704
  this.element.addEventListener(cornerstone.EVENTS.NEW_IMAGE, this.onNewImage);
67705
+ this.element.addEventListener('mouseup', this.onMouseUp);
67706
+ this.element.addEventListener('mousedown', this.onMouseDown);
67478
67707
  }
67479
67708
  }, {
67480
67709
  key: "removeEventListener",
67481
67710
  value: function removeEventListener() {
67482
67711
  this.element.removeEventListener(cornerstone.EVENTS.IMAGE_RENDERED, this.onImageRendered);
67483
67712
  this.element.removeEventListener(cornerstone.EVENTS.NEW_IMAGE, this.onNewImage);
67713
+ this.element.removeEventListener('mouseup', this.onMouseUp);
67714
+ this.element.removeEventListener('mousedown', this.onMouseDown);
67484
67715
  }
67485
67716
  }, {
67486
67717
  key: "componentWillUnmount",
@@ -67495,10 +67726,10 @@ var FilmViewport = /*#__PURE__*/function (_Component) {
67495
67726
  viewport = _this$state.viewport,
67496
67727
  error = _this$state.error,
67497
67728
  loading = _this$state.loading;
67498
- var _this$props = this.props,
67499
- index = _this$props.index,
67500
- onClick = _this$props.onClick,
67501
- overlayFontSize = _this$props.overlayFontSize;
67729
+ var _this$props3 = this.props,
67730
+ index = _this$props3.index,
67731
+ onClick = _this$props3.onClick,
67732
+ overlayFontSize = _this$props3.overlayFontSize;
67502
67733
  var imageId = stack && stack.imageIds[0];
67503
67734
  return /*#__PURE__*/React__default.createElement("div", {
67504
67735
  className: "paladin-film-viewport-wrapper"
@@ -67559,9 +67790,14 @@ defineProperty(FilmViewport, "defaultProps", {
67559
67790
  });
67560
67791
 
67561
67792
  var mapStateToProps$x = function mapStateToProps(state) {
67562
- var filmActiveTool = state.paladin.tools.film.filmActiveTool;
67793
+ var _state$paladin$tools$ = state.paladin.tools.film,
67794
+ filmActiveTool = _state$paladin$tools$.filmActiveTool,
67795
+ filmRelativeIndexes = _state$paladin$tools$.filmRelativeIndexes,
67796
+ filmSynchronizer = _state$paladin$tools$.filmSynchronizer;
67563
67797
  return {
67564
- filmActiveTool: filmActiveTool
67798
+ filmActiveTool: filmActiveTool,
67799
+ filmRelativeIndexes: filmRelativeIndexes,
67800
+ filmSynchronizer: filmSynchronizer
67565
67801
  };
67566
67802
  };
67567
67803
 
@@ -67733,7 +67969,9 @@ var FilmView = /*#__PURE__*/function (_Component) {
67733
67969
  filmActiveIndex = _this$props4.filmActiveIndex,
67734
67970
  _onViewportSave = _this$props4.onViewportSave,
67735
67971
  filmCurrentPage = _this$props4.filmCurrentPage,
67736
- filmActiveTool = _this$props4.filmActiveTool;
67972
+ filmActiveTool = _this$props4.filmActiveTool,
67973
+ handleCtrlSelect = _this$props4.handleCtrlSelect,
67974
+ filmRelativeIndexes = _this$props4.filmRelativeIndexes;
67737
67975
  var _this$state = this.state,
67738
67976
  filmViewWidth = _this$state.filmViewWidth,
67739
67977
  filmViewHeight = _this$state.filmViewHeight,
@@ -67790,12 +68028,16 @@ var FilmView = /*#__PURE__*/function (_Component) {
67790
68028
  }, lodash$1.range(col).map(function (colIndex) {
67791
68029
  var index = rowIndex * col + colIndex;
67792
68030
  var realIndex = filmCurrentPage * (row * col) + index;
68031
+
68032
+ var isRelative = currentPageFilms[index] && lodash$1.includes(filmRelativeIndexes, index);
68033
+
68034
+ var isActive = currentPageFilms[index] && filmActiveIndex === index;
67793
68035
  return /*#__PURE__*/React__default.createElement("div", {
67794
68036
  key: "film-view-".concat(index),
67795
68037
  className: 'paladin-film-view-col',
67796
68038
  style: {
67797
68039
  width: "".concat(100 / col, "%"),
67798
- borderColor: filmActiveIndex === index ? '#00FF83' : '#353535'
68040
+ borderColor: isActive ? '#00FF83' : isRelative ? 'yellow' : '#353535'
67799
68041
  },
67800
68042
  draggable: filmActiveTool === 'Select',
67801
68043
  onDragStart: function onDragStart(ev) {
@@ -67809,9 +68051,10 @@ var FilmView = /*#__PURE__*/function (_Component) {
67809
68051
  key: "film-viewport-".concat(index),
67810
68052
  stack: currentPageFilms[index],
67811
68053
  index: index,
67812
- onClick: function onClick() {
67813
- handleOnClickViewport(index);
68054
+ onClick: function onClick(e) {
68055
+ handleOnClickViewport(e, index);
67814
68056
  },
68057
+ handleCtrlSelect: handleCtrlSelect,
67815
68058
  active: filmActiveIndex === index,
67816
68059
  onViewportSave: function onViewportSave(vp) {
67817
68060
  _onViewportSave && _onViewportSave(realIndex, vp);
@@ -67838,7 +68081,9 @@ var mapStateToProps$y = function mapStateToProps(state) {
67838
68081
  filmSizeType = _state$paladin$tools$.filmSizeType,
67839
68082
  filmActiveIndex = _state$paladin$tools$.filmActiveIndex,
67840
68083
  filmCurrentPage = _state$paladin$tools$.filmCurrentPage,
67841
- filmActiveTool = _state$paladin$tools$.filmActiveTool;
68084
+ filmActiveTool = _state$paladin$tools$.filmActiveTool,
68085
+ filmRelativeIndexes = _state$paladin$tools$.filmRelativeIndexes,
68086
+ filmSynchronizer = _state$paladin$tools$.filmSynchronizer;
67842
68087
  return {
67843
68088
  films: films,
67844
68089
  filmLayoutRow: filmLayoutRow,
@@ -67846,7 +68091,9 @@ var mapStateToProps$y = function mapStateToProps(state) {
67846
68091
  filmSizeType: filmSizeType,
67847
68092
  filmActiveIndex: filmActiveIndex,
67848
68093
  filmCurrentPage: filmCurrentPage,
67849
- filmActiveTool: filmActiveTool
68094
+ filmActiveTool: filmActiveTool,
68095
+ filmRelativeIndexes: filmRelativeIndexes,
68096
+ filmSynchronizer: filmSynchronizer
67850
68097
  };
67851
68098
  };
67852
68099
 
@@ -67857,26 +68104,41 @@ var mergeProps$w = function mergeProps(propsFromState, propsFromDispatch, ownPro
67857
68104
  propsFromDispatch.exchangeFilm(origin, target);
67858
68105
  }
67859
68106
  },
67860
- handleDeleteFilm: function handleDeleteFilm(currentPage) {
67861
- var filmActiveIndex = propsFromState.filmActiveIndex,
67862
- films = propsFromState.films,
67863
- filmLayoutRow = propsFromState.filmLayoutRow,
67864
- filmLayoutCol = propsFromState.filmLayoutCol;
68107
+ handleDeleteFilm: function handleDeleteFilm() {
68108
+ propsFromDispatch.removeFilm();
68109
+ },
68110
+ // 点击胶片的element item
68111
+ handleOnClickViewport: function handleOnClickViewport(e, index) {
68112
+ var filmSynchronizer = propsFromState.filmSynchronizer,
68113
+ filmActiveIndex = propsFromState.filmActiveIndex,
68114
+ filmRelativeIndexes = propsFromState.filmRelativeIndexes;
67865
68115
 
67866
- if (filmActiveIndex < 0) {
67867
- return;
68116
+ if (!e.ctrlKey && e.button === 0) {
68117
+ if (!_.includes(filmRelativeIndexes, filmActiveIndex)) {
68118
+ var oldActiveElement = getFilmElement(filmActiveIndex);
68119
+ filmSynchronizer.remove(oldActiveElement);
68120
+ }
68121
+
68122
+ if (!_.includes(filmRelativeIndexes, index)) {
68123
+ var element = getFilmElement(index);
68124
+ filmSynchronizer.add(element);
68125
+ }
67868
68126
  }
67869
68127
 
67870
- var filmRealIndex = currentPage * (filmLayoutRow * filmLayoutCol) + filmActiveIndex;
68128
+ propsFromDispatch.setFilmActiveIndex(index);
68129
+ },
68130
+ // 多选胶片
68131
+ handleCtrlSelect: function handleCtrlSelect(element, index) {
68132
+ var filmSynchronizer = propsFromState.filmSynchronizer,
68133
+ filmRelativeIndexes = propsFromState.filmRelativeIndexes;
67871
68134
 
67872
- if (!films || !filmRealIndex && filmRealIndex !== 0 || !films[filmRealIndex]) {
67873
- return;
68135
+ if (filmRelativeIndexes && _.includes(filmRelativeIndexes, index)) {
68136
+ filmSynchronizer.remove(element);
68137
+ } else {
68138
+ filmSynchronizer.add(element);
67874
68139
  }
67875
68140
 
67876
- propsFromDispatch.removeFilm(filmRealIndex);
67877
- },
67878
- handleOnClickViewport: function handleOnClickViewport(index) {
67879
- propsFromDispatch.setFilmActiveIndex(index);
68141
+ propsFromDispatch.setFilmRelativeIndex(index);
67880
68142
  },
67881
68143
  onViewportSave: function onViewportSave(index, vp) {
67882
68144
  propsFromDispatch.setFilmViewport(index, vp);
@@ -67889,6 +68151,7 @@ var ConnectedFilmView = reactRedux.connect(mapStateToProps$y, {
67889
68151
  exchangeFilm: exchangeFilm,
67890
68152
  removeFilm: removeFilm,
67891
68153
  setFilmActiveIndex: setFilmActiveIndex,
68154
+ setFilmRelativeIndex: setFilmRelativeIndex,
67892
68155
  setFilmViewport: setFilmViewport,
67893
68156
  setFilmCurrentPage: setFilmCurrentPage
67894
68157
  }, mergeProps$w)(FilmView);
@@ -68619,13 +68882,7 @@ var mapStateToProps$z = function mapStateToProps(state) {
68619
68882
  var _state$paladin$tools$3 = state.paladin.tools.customization,
68620
68883
  toolMode = _state$paladin$tools$3.toolMode,
68621
68884
  globalLoading = _state$paladin$tools$3.globalLoading;
68622
- var _state$paladin$tools$4 = state.paladin.tools.film,
68623
- filmPrinterSettings = _state$paladin$tools$4.filmPrinterSettings,
68624
- filmActiveIndex = _state$paladin$tools$4.filmActiveIndex,
68625
- films = _state$paladin$tools$4.films,
68626
- filmLayoutRow = _state$paladin$tools$4.filmLayoutRow,
68627
- filmLayoutCol = _state$paladin$tools$4.filmLayoutCol,
68628
- filmCurrentPage = _state$paladin$tools$4.filmCurrentPage;
68885
+ var filmPrinterSettings = state.paladin.tools.film.filmPrinterSettings;
68629
68886
  return {
68630
68887
  activeIndex: activeIndex,
68631
68888
  imageActiveIndex: imageActiveIndex,
@@ -68658,12 +68915,7 @@ var mapStateToProps$z = function mapStateToProps(state) {
68658
68915
  globalLoading: globalLoading,
68659
68916
  originStudy: originStudy,
68660
68917
  Film: Film,
68661
- reduxFilmPrinterSettings: filmPrinterSettings,
68662
- filmActiveIndex: filmActiveIndex,
68663
- films: films,
68664
- filmLayoutRow: filmLayoutRow,
68665
- filmLayoutCol: filmLayoutCol,
68666
- filmCurrentPage: filmCurrentPage
68918
+ reduxFilmPrinterSettings: filmPrinterSettings
68667
68919
  };
68668
68920
  };
68669
68921
 
@@ -68973,23 +69225,7 @@ var mergeProps$x = function mergeProps(propsFromState, propsFromDispatch, ownPro
68973
69225
  * 删除激活框的胶片
68974
69226
  */
68975
69227
  if (propsFromState.Film) {
68976
- var filmActiveIndex = propsFromState.filmActiveIndex,
68977
- filmCurrentPage = propsFromState.filmCurrentPage,
68978
- filmLayoutRow = propsFromState.filmLayoutRow,
68979
- filmLayoutCol = propsFromState.filmLayoutCol,
68980
- films = propsFromState.films;
68981
-
68982
- if (filmActiveIndex < 0) {
68983
- return;
68984
- }
68985
-
68986
- var filmRealIndex = filmCurrentPage * (filmLayoutRow * filmLayoutCol) + filmActiveIndex;
68987
-
68988
- if (!films || !filmRealIndex && filmRealIndex !== 0 || !films[filmRealIndex]) {
68989
- return;
68990
- }
68991
-
68992
- propsFromDispatch.removeFilm(filmRealIndex);
69228
+ propsFromDispatch.removeFilm();
68993
69229
  } else {
68994
69230
  var layoutElements = lodash$1.map(Array(row * col), function (v, n) {
68995
69231
  return getElement(n);
@@ -69229,7 +69465,7 @@ var mergeProps$x = function mergeProps(propsFromState, propsFromDispatch, ownPro
69229
69465
  },
69230
69466
  initSeries: function () {
69231
69467
  var _initSeries2 = asyncToGenerator( /*#__PURE__*/regenerator.mark(function _callee(changeStudy, callback) {
69232
- var data, resetToolMergeState, synchronizer, linkSynchronizer, linkImageModeSynchronizer, linkScrollSynchronizer, options, _study, series, needCheckMultiFrame, hasMultiFrame, modalitiesInStudy, i, item, wado, url, dataSet, numFrames, imageIds, _i, imageId, seriesCurrentIndex, firstReady, maxRequest, retry, clearCacheEveryLoad, dicom, frameTime, linkToolLocalDefaultState, realActiveIndex, continuousMeasureLocalDefaultState;
69468
+ var data, resetToolMergeState, synchronizer, linkSynchronizer, linkImageModeSynchronizer, linkScrollSynchronizer, options, _study, series, needCheckMultiFrame, hasMultiFrame, modalitiesInStudy, i, item, wado, url, dataSet, numFrames, imageIds, _i, imageId, seriesCurrentIndex, firstReady, maxRequest, retry, clearCacheEveryLoad, dicom, frameTime, linkToolLocalDefaultState, realActiveIndex, continuousMeasureLocalDefaultState, referenceLineLocalDefaultState;
69233
69469
 
69234
69470
  return regenerator.wrap(function _callee$(_context) {
69235
69471
  while (1) {
@@ -69463,7 +69699,7 @@ var mergeProps$x = function mergeProps(propsFromState, propsFromDispatch, ownPro
69463
69699
  if (dicom && dicom.FrameTime && dicom.FrameTime.value) {
69464
69700
  frameTime = dicom.FrameTime.value;
69465
69701
  propsFromDispatch.setCineFps(lodash$1.round(1000 / frameTime, 3) || 3);
69466
- } // 初始化本地存储的工具初始状态(目前包含:自动联动、连续测量)
69702
+ } // 初始化本地存储的工具初始状态(目前包含:自动联动、连续测量、定位线)
69467
69703
 
69468
69704
 
69469
69705
  linkToolLocalDefaultState = window.localStorage.getItem('hellfire-link-tool-default-state');
@@ -69491,7 +69727,13 @@ var mergeProps$x = function mergeProps(propsFromState, propsFromDispatch, ownPro
69491
69727
  propsFromDispatch.setMeasure(false);
69492
69728
  }
69493
69729
 
69494
- case 68:
69730
+ referenceLineLocalDefaultState = window.localStorage.getItem('hellfire-reference-line-default-state');
69731
+
69732
+ if (referenceLineLocalDefaultState && referenceLineLocalDefaultState === 'open') {
69733
+ propsFromDispatch.activeDicomFunction("ReferenceLines");
69734
+ }
69735
+
69736
+ case 70:
69495
69737
  case "end":
69496
69738
  return _context.stop();
69497
69739
  }