@jbrowse/plugin-linear-genome-view 2.1.0 → 2.1.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (139) hide show
  1. package/dist/BaseLinearDisplay/components/BaseLinearDisplay.js +27 -54
  2. package/dist/BaseLinearDisplay/components/BaseLinearDisplay.js.map +1 -1
  3. package/dist/BaseLinearDisplay/components/Block.js +17 -28
  4. package/dist/BaseLinearDisplay/components/Block.js.map +1 -1
  5. package/dist/BaseLinearDisplay/components/LinearBlocks.js +19 -21
  6. package/dist/BaseLinearDisplay/components/LinearBlocks.js.map +1 -1
  7. package/dist/BaseLinearDisplay/components/ServerSideRenderedBlockContent.js +27 -48
  8. package/dist/BaseLinearDisplay/components/ServerSideRenderedBlockContent.js.map +1 -1
  9. package/dist/BaseLinearDisplay/components/Tooltip.js +29 -58
  10. package/dist/BaseLinearDisplay/components/Tooltip.js.map +1 -1
  11. package/dist/BaseLinearDisplay/models/BaseLinearDisplayModel.js +242 -363
  12. package/dist/BaseLinearDisplay/models/BaseLinearDisplayModel.js.map +1 -1
  13. package/dist/BaseLinearDisplay/models/baseLinearDisplayConfigSchema.js +1 -1
  14. package/dist/BaseLinearDisplay/models/baseLinearDisplayConfigSchema.js.map +1 -1
  15. package/dist/BaseLinearDisplay/models/serverSideRenderedBlock.js +77 -129
  16. package/dist/BaseLinearDisplay/models/serverSideRenderedBlock.js.map +1 -1
  17. package/dist/LinearBareDisplay/configSchema.js +2 -2
  18. package/dist/LinearBareDisplay/configSchema.js.map +1 -1
  19. package/dist/LinearBareDisplay/model.js +13 -19
  20. package/dist/LinearBareDisplay/model.js.map +1 -1
  21. package/dist/LinearBasicDisplay/components/SetMaxHeight.js +14 -31
  22. package/dist/LinearBasicDisplay/components/SetMaxHeight.js.map +1 -1
  23. package/dist/LinearBasicDisplay/configSchema.js +3 -3
  24. package/dist/LinearBasicDisplay/configSchema.js.map +1 -1
  25. package/dist/LinearBasicDisplay/model.js +119 -147
  26. package/dist/LinearBasicDisplay/model.js.map +1 -1
  27. package/dist/LinearGenomeView/components/CenterLine.js +11 -12
  28. package/dist/LinearGenomeView/components/CenterLine.js.map +1 -1
  29. package/dist/LinearGenomeView/components/ExportSvgDialog.js +30 -96
  30. package/dist/LinearGenomeView/components/ExportSvgDialog.js.map +1 -1
  31. package/dist/LinearGenomeView/components/GetSequenceDialog.d.ts +9 -0
  32. package/dist/LinearGenomeView/components/GetSequenceDialog.js +172 -0
  33. package/dist/LinearGenomeView/components/GetSequenceDialog.js.map +1 -0
  34. package/dist/LinearGenomeView/components/Gridlines.js +18 -20
  35. package/dist/LinearGenomeView/components/Gridlines.js.map +1 -1
  36. package/dist/LinearGenomeView/components/Header.js +26 -31
  37. package/dist/LinearGenomeView/components/Header.js.map +1 -1
  38. package/dist/LinearGenomeView/components/HelpDialog.js +10 -11
  39. package/dist/LinearGenomeView/components/HelpDialog.js.map +1 -1
  40. package/dist/LinearGenomeView/components/ImportForm.js +91 -158
  41. package/dist/LinearGenomeView/components/ImportForm.js.map +1 -1
  42. package/dist/LinearGenomeView/components/LinearGenomeView.js +20 -21
  43. package/dist/LinearGenomeView/components/LinearGenomeView.js.map +1 -1
  44. package/dist/LinearGenomeView/components/LinearGenomeViewSvg.js +87 -157
  45. package/dist/LinearGenomeView/components/LinearGenomeViewSvg.js.map +1 -1
  46. package/dist/LinearGenomeView/components/MiniControls.js +16 -32
  47. package/dist/LinearGenomeView/components/MiniControls.js.map +1 -1
  48. package/dist/LinearGenomeView/components/OverviewRubberBand.d.ts +0 -11
  49. package/dist/LinearGenomeView/components/OverviewRubberBand.js +44 -76
  50. package/dist/LinearGenomeView/components/OverviewRubberBand.js.map +1 -1
  51. package/dist/LinearGenomeView/components/OverviewScaleBar.d.ts +14 -8
  52. package/dist/LinearGenomeView/components/OverviewScaleBar.js +94 -117
  53. package/dist/LinearGenomeView/components/OverviewScaleBar.js.map +1 -1
  54. package/dist/LinearGenomeView/components/RefNameAutocomplete.js +107 -169
  55. package/dist/LinearGenomeView/components/RefNameAutocomplete.js.map +1 -1
  56. package/dist/LinearGenomeView/components/RubberBand.js +51 -71
  57. package/dist/LinearGenomeView/components/RubberBand.js.map +1 -1
  58. package/dist/LinearGenomeView/components/Ruler.js +17 -18
  59. package/dist/LinearGenomeView/components/Ruler.js.map +1 -1
  60. package/dist/LinearGenomeView/components/ScaleBar.js +37 -58
  61. package/dist/LinearGenomeView/components/ScaleBar.js.map +1 -1
  62. package/dist/LinearGenomeView/components/SearchBox.js +73 -133
  63. package/dist/LinearGenomeView/components/SearchBox.js.map +1 -1
  64. package/dist/LinearGenomeView/components/SearchResultsDialog.js +38 -36
  65. package/dist/LinearGenomeView/components/SearchResultsDialog.js.map +1 -1
  66. package/dist/LinearGenomeView/components/{SequenceDialog.d.ts → SequenceSearchDialog.d.ts} +0 -0
  67. package/dist/LinearGenomeView/components/SequenceSearchDialog.js +104 -0
  68. package/dist/LinearGenomeView/components/SequenceSearchDialog.js.map +1 -0
  69. package/dist/LinearGenomeView/components/TrackContainer.js +28 -30
  70. package/dist/LinearGenomeView/components/TrackContainer.js.map +1 -1
  71. package/dist/LinearGenomeView/components/TrackLabel.js +37 -71
  72. package/dist/LinearGenomeView/components/TrackLabel.js.map +1 -1
  73. package/dist/LinearGenomeView/components/TracksContainer.js +32 -49
  74. package/dist/LinearGenomeView/components/TracksContainer.js.map +1 -1
  75. package/dist/LinearGenomeView/components/ZoomControls.js +15 -32
  76. package/dist/LinearGenomeView/components/ZoomControls.js.map +1 -1
  77. package/dist/LinearGenomeView/components/util.d.ts +1 -0
  78. package/dist/LinearGenomeView/components/util.js +28 -88
  79. package/dist/LinearGenomeView/components/util.js.map +1 -1
  80. package/dist/LinearGenomeView/index.d.ts +4 -4
  81. package/dist/LinearGenomeView/index.js +380 -430
  82. package/dist/LinearGenomeView/index.js.map +1 -1
  83. package/dist/LinearGenomeView/util.js +17 -36
  84. package/dist/LinearGenomeView/util.js.map +1 -1
  85. package/dist/index.js +75 -146
  86. package/dist/index.js.map +1 -1
  87. package/esm/LinearGenomeView/components/GetSequenceDialog.d.ts +9 -0
  88. package/esm/LinearGenomeView/components/{SequenceDialog.js → GetSequenceDialog.js} +4 -7
  89. package/esm/LinearGenomeView/components/GetSequenceDialog.js.map +1 -0
  90. package/esm/LinearGenomeView/components/ImportForm.js +39 -42
  91. package/esm/LinearGenomeView/components/ImportForm.js.map +1 -1
  92. package/esm/LinearGenomeView/components/LinearGenomeView.js +2 -2
  93. package/esm/LinearGenomeView/components/LinearGenomeView.js.map +1 -1
  94. package/esm/LinearGenomeView/components/LinearGenomeViewSvg.js +2 -1
  95. package/esm/LinearGenomeView/components/LinearGenomeViewSvg.js.map +1 -1
  96. package/esm/LinearGenomeView/components/OverviewRubberBand.d.ts +0 -11
  97. package/esm/LinearGenomeView/components/OverviewRubberBand.js +4 -12
  98. package/esm/LinearGenomeView/components/OverviewRubberBand.js.map +1 -1
  99. package/esm/LinearGenomeView/components/OverviewScaleBar.d.ts +14 -8
  100. package/esm/LinearGenomeView/components/OverviewScaleBar.js +0 -2
  101. package/esm/LinearGenomeView/components/OverviewScaleBar.js.map +1 -1
  102. package/esm/LinearGenomeView/components/RefNameAutocomplete.js +26 -6
  103. package/esm/LinearGenomeView/components/RefNameAutocomplete.js.map +1 -1
  104. package/esm/LinearGenomeView/components/RubberBand.js +0 -1
  105. package/esm/LinearGenomeView/components/RubberBand.js.map +1 -1
  106. package/esm/LinearGenomeView/components/SearchBox.js +37 -33
  107. package/esm/LinearGenomeView/components/SearchBox.js.map +1 -1
  108. package/esm/LinearGenomeView/components/SearchResultsDialog.js +7 -4
  109. package/esm/LinearGenomeView/components/SearchResultsDialog.js.map +1 -1
  110. package/esm/LinearGenomeView/components/{SequenceDialog.d.ts → SequenceSearchDialog.d.ts} +0 -0
  111. package/esm/LinearGenomeView/components/SequenceSearchDialog.js +76 -0
  112. package/esm/LinearGenomeView/components/SequenceSearchDialog.js.map +1 -0
  113. package/esm/LinearGenomeView/components/TrackLabel.js +1 -1
  114. package/esm/LinearGenomeView/components/TrackLabel.js.map +1 -1
  115. package/esm/LinearGenomeView/components/util.d.ts +1 -0
  116. package/esm/LinearGenomeView/components/util.js +12 -0
  117. package/esm/LinearGenomeView/components/util.js.map +1 -1
  118. package/esm/LinearGenomeView/index.d.ts +4 -4
  119. package/esm/LinearGenomeView/index.js +26 -19
  120. package/esm/LinearGenomeView/index.js.map +1 -1
  121. package/package.json +2 -3
  122. package/src/LinearGenomeView/components/{SequenceDialog.tsx → GetSequenceDialog.tsx} +4 -17
  123. package/src/LinearGenomeView/components/ImportForm.tsx +40 -42
  124. package/src/LinearGenomeView/components/LinearGenomeView.tsx +3 -3
  125. package/src/LinearGenomeView/components/LinearGenomeViewSvg.tsx +4 -4
  126. package/src/LinearGenomeView/components/OverviewRubberBand.tsx +5 -15
  127. package/src/LinearGenomeView/components/OverviewScaleBar.tsx +0 -2
  128. package/src/LinearGenomeView/components/RefNameAutocomplete.tsx +27 -8
  129. package/src/LinearGenomeView/components/RubberBand.tsx +0 -1
  130. package/src/LinearGenomeView/components/SearchBox.tsx +39 -36
  131. package/src/LinearGenomeView/components/SearchResultsDialog.tsx +7 -4
  132. package/src/LinearGenomeView/components/SequenceSearchDialog.tsx +165 -0
  133. package/src/LinearGenomeView/components/TrackLabel.tsx +3 -1
  134. package/src/LinearGenomeView/components/__snapshots__/LinearGenomeView.test.js.snap +16 -16
  135. package/src/LinearGenomeView/components/util.ts +12 -0
  136. package/src/LinearGenomeView/index.tsx +32 -25
  137. package/dist/LinearGenomeView/components/SequenceDialog.js +0 -242
  138. package/dist/LinearGenomeView/components/SequenceDialog.js.map +0 -1
  139. package/esm/LinearGenomeView/components/SequenceDialog.js.map +0 -1
@@ -22,43 +22,22 @@ var __importStar = (this && this.__importStar) || function (mod) {
22
22
  __setModuleDefault(result, mod);
23
23
  return result;
24
24
  };
25
- var __read = (this && this.__read) || function (o, n) {
26
- var m = typeof Symbol === "function" && o[Symbol.iterator];
27
- if (!m) return o;
28
- var i = m.call(o), r, ar = [], e;
29
- try {
30
- while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
31
- }
32
- catch (error) { e = { error: error }; }
33
- finally {
34
- try {
35
- if (r && !r.done && (m = i["return"])) m.call(i);
36
- }
37
- finally { if (e) throw e.error; }
38
- }
39
- return ar;
40
- };
41
- var __importDefault = (this && this.__importDefault) || function (mod) {
42
- return (mod && mod.__esModule) ? mod : { "default": mod };
43
- };
44
25
  Object.defineProperty(exports, "__esModule", { value: true });
45
- var react_1 = __importStar(require("react"));
46
- var material_1 = require("@mui/material");
47
- var mui_1 = require("tss-react/mui");
48
- var util_1 = require("@jbrowse/core/util");
49
- var mobx_react_1 = require("mobx-react");
50
- var prop_types_1 = __importDefault(require("prop-types"));
51
- var __1 = require("..");
52
- var useStyles = (0, mui_1.makeStyles)()(function (theme) {
53
- // @ts-ignore
54
- var _a = theme.palette, tertiary = _a.tertiary, primary = _a.primary;
55
- var background = tertiary
26
+ const react_1 = __importStar(require("react"));
27
+ const material_1 = require("@mui/material");
28
+ const mui_1 = require("tss-react/mui");
29
+ const util_1 = require("@jbrowse/core/util");
30
+ const mobx_react_1 = require("mobx-react");
31
+ const __1 = require("..");
32
+ const useStyles = (0, mui_1.makeStyles)()(theme => {
33
+ const { tertiary, primary } = theme.palette;
34
+ const background = tertiary
56
35
  ? (0, material_1.alpha)(tertiary.main, 0.7)
57
36
  : (0, material_1.alpha)(primary.main, 0.7);
58
37
  return {
59
38
  rubberBand: {
60
39
  height: '100%',
61
- background: background,
40
+ background,
62
41
  position: 'absolute',
63
42
  zIndex: 10,
64
43
  textAlign: 'center',
@@ -89,40 +68,35 @@ var useStyles = (0, mui_1.makeStyles)()(function (theme) {
89
68
  },
90
69
  };
91
70
  });
92
- var HoverTooltip = (0, mobx_react_1.observer)(function (_a) {
93
- var _b;
94
- var model = _a.model, open = _a.open, guideX = _a.guideX, overview = _a.overview;
95
- var classes = useStyles().classes;
96
- var cytobandOffset = model.cytobandOffset;
97
- var assemblyManager = (0, util_1.getSession)(model).assemblyManager;
98
- var px = overview.pxToBp(guideX - cytobandOffset);
99
- var assembly = assemblyManager.get(px.assemblyName);
100
- var cytoband = (_b = assembly === null || assembly === void 0 ? void 0 : assembly.cytobands) === null || _b === void 0 ? void 0 : _b.find(function (f) {
101
- return px.coord > f.get('start') &&
102
- px.coord < f.get('end') &&
103
- px.refName === assembly.getCanonicalRefName(f.get('refName'));
104
- });
71
+ const HoverTooltip = (0, mobx_react_1.observer)(({ model, open, guideX, overview, }) => {
72
+ var _a;
73
+ const { classes } = useStyles();
74
+ const { cytobandOffset } = model;
75
+ const { assemblyManager } = (0, util_1.getSession)(model);
76
+ const px = overview.pxToBp(guideX - cytobandOffset);
77
+ const assembly = assemblyManager.get(px.assemblyName);
78
+ const cytoband = (_a = assembly === null || assembly === void 0 ? void 0 : assembly.cytobands) === null || _a === void 0 ? void 0 : _a.find(f => px.coord > f.get('start') &&
79
+ px.coord < f.get('end') &&
80
+ px.refName === assembly.getCanonicalRefName(f.get('refName')));
105
81
  return (react_1.default.createElement(material_1.Tooltip, { open: open, placement: "top", title: [(0, util_1.stringify)(px), cytoband === null || cytoband === void 0 ? void 0 : cytoband.get('name')].join(' '), arrow: true },
106
82
  react_1.default.createElement("div", { className: classes.guide, style: {
107
83
  left: guideX,
108
84
  } })));
109
85
  });
110
- function OverviewRubberBand(_a) {
111
- var _b;
112
- var model = _a.model, overview = _a.overview, _c = _a.ControlComponent, ControlComponent = _c === void 0 ? react_1.default.createElement("div", null) : _c;
113
- var cytobandOffset = model.cytobandOffset;
114
- var _d = __read((0, react_1.useState)(), 2), startX = _d[0], setStartX = _d[1];
115
- var _e = __read((0, react_1.useState)(), 2), currentX = _e[0], setCurrentX = _e[1];
116
- var _f = __read((0, react_1.useState)(), 2), guideX = _f[0], setGuideX = _f[1];
117
- var controlsRef = (0, react_1.useRef)(null);
118
- var rubberBandRef = (0, react_1.useRef)(null);
119
- var classes = useStyles().classes;
120
- var mouseDragging = startX !== undefined;
121
- (0, react_1.useEffect)(function () {
86
+ function OverviewRubberBand({ model, overview, ControlComponent = react_1.default.createElement("div", null), }) {
87
+ const { cytobandOffset } = model;
88
+ const [startX, setStartX] = (0, react_1.useState)();
89
+ const [currentX, setCurrentX] = (0, react_1.useState)();
90
+ const [guideX, setGuideX] = (0, react_1.useState)();
91
+ const controlsRef = (0, react_1.useRef)(null);
92
+ const rubberBandRef = (0, react_1.useRef)(null);
93
+ const { classes } = useStyles();
94
+ const mouseDragging = startX !== undefined;
95
+ (0, react_1.useEffect)(() => {
122
96
  function globalMouseMove(event) {
123
- var ref = controlsRef.current;
97
+ const ref = controlsRef.current;
124
98
  if (ref && mouseDragging) {
125
- var relativeX = event.clientX - ref.getBoundingClientRect().left;
99
+ const relativeX = event.clientX - ref.getBoundingClientRect().left;
126
100
  setCurrentX(relativeX);
127
101
  }
128
102
  }
@@ -130,12 +104,14 @@ function OverviewRubberBand(_a) {
130
104
  // click and drag
131
105
  if (startX !== undefined && currentX !== undefined) {
132
106
  if (Math.abs(currentX - startX) > 3) {
133
- model.moveTo(overview.pxToBp(startX - cytobandOffset), overview.pxToBp(currentX - cytobandOffset));
107
+ const left = Math.min(startX, currentX);
108
+ const right = Math.max(startX, currentX);
109
+ model.moveTo(overview.pxToBp(left - cytobandOffset), overview.pxToBp(right - cytobandOffset));
134
110
  }
135
111
  }
136
112
  // just a click
137
113
  if (startX !== undefined && currentX === undefined) {
138
- var click = overview.pxToBp(startX - cytobandOffset);
114
+ const click = overview.pxToBp(startX - cytobandOffset);
139
115
  if (!click.refName) {
140
116
  (0, util_1.getSession)(model).notify('unknown position clicked');
141
117
  console.error('unknown position clicked', click);
@@ -160,13 +136,13 @@ function OverviewRubberBand(_a) {
160
136
  window.addEventListener('mousemove', globalMouseMove, true);
161
137
  window.addEventListener('mouseup', globalMouseUp, true);
162
138
  window.addEventListener('keydown', globalKeyDown, true);
163
- return function () {
139
+ return () => {
164
140
  window.removeEventListener('mousemove', globalMouseMove, true);
165
141
  window.removeEventListener('mouseup', globalMouseUp, true);
166
142
  window.removeEventListener('keydown', globalKeyDown, true);
167
143
  };
168
144
  }
169
- return function () { };
145
+ return () => { };
170
146
  }, [mouseDragging, currentX, startX, model, overview, cytobandOffset]);
171
147
  function mouseDown(event) {
172
148
  event.preventDefault();
@@ -188,21 +164,21 @@ function OverviewRubberBand(_a) {
188
164
  guideX !== undefined ? (react_1.default.createElement(HoverTooltip, { model: model, open: !mouseDragging, overview: overview, guideX: guideX })) : null,
189
165
  react_1.default.createElement("div", { className: classes.rubberBandControl, role: "presentation", ref: controlsRef, onMouseDown: mouseDown, onMouseOut: mouseOut, onMouseMove: mouseMove }, ControlComponent)));
190
166
  }
191
- var left = startX || 0;
192
- var width = 0;
167
+ let left = startX || 0;
168
+ let width = 0;
193
169
  if (startX !== undefined && currentX !== undefined) {
194
170
  left = currentX < startX ? currentX : startX;
195
171
  width = currentX - startX;
196
172
  }
197
173
  // calculate the start and end bp of drag
198
- var leftBpOffset;
199
- var rightBpOffset;
174
+ let leftBpOffset;
175
+ let rightBpOffset;
200
176
  if (startX) {
201
177
  leftBpOffset = overview.pxToBp(startX - cytobandOffset);
202
178
  rightBpOffset = overview.pxToBp(startX + width - cytobandOffset);
203
179
  if (currentX && currentX < startX) {
204
180
  ;
205
- _b = __read([rightBpOffset, leftBpOffset], 2), leftBpOffset = _b[0], rightBpOffset = _b[1];
181
+ [leftBpOffset, rightBpOffset] = [rightBpOffset, leftBpOffset];
206
182
  }
207
183
  }
208
184
  return (react_1.default.createElement("div", { style: { position: 'relative' } },
@@ -228,19 +204,11 @@ function OverviewRubberBand(_a) {
228
204
  }, keepMounted: true, disableRestoreFocus: true },
229
205
  react_1.default.createElement(material_1.Typography, null, rightBpOffset ? (0, util_1.stringify)(rightBpOffset) : '')))) : null,
230
206
  react_1.default.createElement("div", { ref: rubberBandRef, className: classes.rubberBand, style: {
231
- left: left,
207
+ left,
232
208
  width: Math.abs(width),
233
209
  height: __1.HEADER_OVERVIEW_HEIGHT,
234
210
  } }),
235
211
  react_1.default.createElement("div", { "data-testid": "rubberBand_controls", className: classes.rubberBandControl, role: "presentation", ref: controlsRef, onMouseDown: mouseDown, onMouseOut: mouseOut, onMouseMove: mouseMove }, ControlComponent)));
236
212
  }
237
- OverviewRubberBand.propTypes = {
238
- model: mobx_react_1.PropTypes.objectOrObservableObject.isRequired,
239
- overview: mobx_react_1.PropTypes.objectOrObservableObject.isRequired,
240
- ControlComponent: prop_types_1.default.node,
241
- };
242
- OverviewRubberBand.defaultProps = {
243
- ControlComponent: react_1.default.createElement("div", null),
244
- };
245
213
  exports.default = (0, mobx_react_1.observer)(OverviewRubberBand);
246
214
  //# sourceMappingURL=OverviewRubberBand.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"OverviewRubberBand.js","sourceRoot":"","sources":["../../../src/LinearGenomeView/components/OverviewRubberBand.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"OverviewRubberBand.js","sourceRoot":"","sources":["../../../src/LinearGenomeView/components/OverviewRubberBand.tsx"],"names":[],"mappings":"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"}
@@ -28,10 +28,13 @@ declare const Cytobands: ({ overview, block, assembly, }: {
28
28
  readonly initialized: boolean;
29
29
  readonly name: string;
30
30
  readonly aliases: string[];
31
+ readonly displayName: string | undefined;
31
32
  hasName(name: string): boolean;
32
33
  readonly allAliases: string[];
33
34
  readonly refNames: string[] | undefined;
34
35
  readonly allRefNames: string[] | undefined;
36
+ readonly lowerCaseRefNames: string[] | undefined;
37
+ readonly allRefNamesWithLowerCase: string[] | undefined;
35
38
  readonly rpcManager: any;
36
39
  readonly refNameColors: string[];
37
40
  } & {
@@ -62,17 +65,17 @@ declare const Cytobands: ({ overview, block, assembly, }: {
62
65
  } & {
63
66
  getAdapterMapEntry(adapterConf: unknown, options: import("@jbrowse/core/assemblyManager/assembly").BaseOptions): Promise<{
64
67
  forwardMap: {
65
- [k: string]: string;
68
+ [key: string]: string;
66
69
  };
67
70
  reverseMap: {
68
- [k: string]: string;
71
+ [key: string]: string;
69
72
  };
70
73
  }>;
71
74
  getRefNameMapForAdapter(adapterConf: unknown, opts: import("@jbrowse/core/assemblyManager/assembly").BaseOptions): Promise<{
72
- [k: string]: string;
75
+ [key: string]: string;
73
76
  }>;
74
77
  getReverseRefNameMapForAdapter(adapterConf: unknown, opts: import("@jbrowse/core/assemblyManager/assembly").BaseOptions): Promise<{
75
- [k: string]: string;
78
+ [key: string]: string;
76
79
  }>;
77
80
  } & import("mobx-state-tree").IStateTreeNode<import("mobx-state-tree").IModelType<{
78
81
  configuration: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IReferenceType<import("mobx-state-tree").IAnyType>>;
@@ -90,10 +93,13 @@ declare const Cytobands: ({ overview, block, assembly, }: {
90
93
  readonly initialized: boolean;
91
94
  readonly name: string;
92
95
  readonly aliases: string[];
96
+ readonly displayName: string | undefined;
93
97
  hasName(name: string): boolean;
94
98
  readonly allAliases: string[];
95
99
  readonly refNames: string[] | undefined;
96
100
  readonly allRefNames: string[] | undefined;
101
+ readonly lowerCaseRefNames: string[] | undefined;
102
+ readonly allRefNamesWithLowerCase: string[] | undefined;
97
103
  readonly rpcManager: any;
98
104
  readonly refNameColors: string[];
99
105
  } & {
@@ -124,17 +130,17 @@ declare const Cytobands: ({ overview, block, assembly, }: {
124
130
  } & {
125
131
  getAdapterMapEntry(adapterConf: unknown, options: import("@jbrowse/core/assemblyManager/assembly").BaseOptions): Promise<{
126
132
  forwardMap: {
127
- [k: string]: string;
133
+ [key: string]: string;
128
134
  };
129
135
  reverseMap: {
130
- [k: string]: string;
136
+ [key: string]: string;
131
137
  };
132
138
  }>;
133
139
  getRefNameMapForAdapter(adapterConf: unknown, opts: import("@jbrowse/core/assemblyManager/assembly").BaseOptions): Promise<{
134
- [k: string]: string;
140
+ [key: string]: string;
135
141
  }>;
136
142
  getReverseRefNameMapForAdapter(adapterConf: unknown, opts: import("@jbrowse/core/assemblyManager/assembly").BaseOptions): Promise<{
137
- [k: string]: string;
143
+ [key: string]: string;
138
144
  }>;
139
145
  }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>) | undefined;
140
146
  block: ContentBlock;
@@ -1,49 +1,22 @@
1
1
  "use strict";
2
- var __assign = (this && this.__assign) || function () {
3
- __assign = Object.assign || function(t) {
4
- for (var s, i = 1, n = arguments.length; i < n; i++) {
5
- s = arguments[i];
6
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
- t[p] = s[p];
8
- }
9
- return t;
10
- };
11
- return __assign.apply(this, arguments);
12
- };
13
- var __read = (this && this.__read) || function (o, n) {
14
- var m = typeof Symbol === "function" && o[Symbol.iterator];
15
- if (!m) return o;
16
- var i = m.call(o), r, ar = [], e;
17
- try {
18
- while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
19
- }
20
- catch (error) { e = { error: error }; }
21
- finally {
22
- try {
23
- if (r && !r.done && (m = i["return"])) m.call(i);
24
- }
25
- finally { if (e) throw e.error; }
26
- }
27
- return ar;
28
- };
29
2
  var __importDefault = (this && this.__importDefault) || function (mod) {
30
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
31
4
  };
32
5
  Object.defineProperty(exports, "__esModule", { value: true });
33
6
  exports.Polygon = exports.Cytobands = void 0;
34
- var react_1 = __importDefault(require("react"));
35
- var material_1 = require("@mui/material");
36
- var mui_1 = require("tss-react/mui");
37
- var mobx_react_1 = require("mobx-react");
38
- var Base1DViewModel_1 = __importDefault(require("@jbrowse/core/util/Base1DViewModel"));
39
- var util_1 = require("@jbrowse/core/util");
40
- var blockTypes_1 = require("@jbrowse/core/util/blockTypes");
7
+ const react_1 = __importDefault(require("react"));
8
+ const material_1 = require("@mui/material");
9
+ const mui_1 = require("tss-react/mui");
10
+ const mobx_react_1 = require("mobx-react");
11
+ const Base1DViewModel_1 = __importDefault(require("@jbrowse/core/util/Base1DViewModel"));
12
+ const util_1 = require("@jbrowse/core/util");
13
+ const blockTypes_1 = require("@jbrowse/core/util/blockTypes");
41
14
  // locals
42
- var __1 = require("..");
43
- var util_2 = require("../util");
44
- var OverviewRubberBand_1 = __importDefault(require("./OverviewRubberBand"));
45
- var wholeSeqSpacer = 2;
46
- var useStyles = (0, mui_1.makeStyles)()(function (theme) { return ({
15
+ const __1 = require("..");
16
+ const util_2 = require("../util");
17
+ const OverviewRubberBand_1 = __importDefault(require("./OverviewRubberBand"));
18
+ const wholeSeqSpacer = 2;
19
+ const useStyles = (0, mui_1.makeStyles)()(theme => ({
47
20
  scaleBar: {
48
21
  height: __1.HEADER_OVERVIEW_HEIGHT,
49
22
  },
@@ -57,11 +30,11 @@ var useStyles = (0, mui_1.makeStyles)()(function (theme) { return ({
57
30
  height: __1.HEADER_OVERVIEW_HEIGHT,
58
31
  },
59
32
  scaleBarContigForward: {
60
- backgroundImage: "url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 15 9'%3E%3Cpath d='M-.1 0L6 4.5L-.1 9' fill='none' stroke='%23ddd'/%3E%3C/svg%3E\")",
33
+ backgroundImage: `url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 15 9'%3E%3Cpath d='M-.1 0L6 4.5L-.1 9' fill='none' stroke='%23ddd'/%3E%3C/svg%3E")`,
61
34
  backgroundRepeat: 'repeat',
62
35
  },
63
36
  scaleBarContigReverse: {
64
- backgroundImage: "url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 15 9'%3E%3Cpath d='M6 0L0 4.5L6 9' fill='none' stroke='%23ddd'/%3E%3C/svg%3E\")",
37
+ backgroundImage: `url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 15 9'%3E%3Cpath d='M6 0L0 4.5L6 9' fill='none' stroke='%23ddd'/%3E%3C/svg%3E")`,
65
38
  backgroundRepeat: 'repeat',
66
39
  },
67
40
  scaleBarRefName: {
@@ -92,30 +65,34 @@ var useStyles = (0, mui_1.makeStyles)()(function (theme) { return ({
92
65
  width: '100%',
93
66
  position: 'absolute',
94
67
  },
95
- }); });
96
- var Polygon = (0, mobx_react_1.observer)(function (_a) {
97
- var model = _a.model, overview = _a.overview, _b = _a.useOffset, useOffset = _b === void 0 ? true : _b;
98
- var theme = (0, material_1.useTheme)();
99
- var multiplier = Number(useOffset);
100
- var interRegionPaddingWidth = model.interRegionPaddingWidth, offsetPx = model.offsetPx, dynamicBlocks = model.dynamicBlocks, cytobandOffset = model.cytobandOffset;
101
- var contentBlocks = dynamicBlocks.contentBlocks, totalWidthPxWithoutBorders = dynamicBlocks.totalWidthPxWithoutBorders;
102
- // @ts-ignore
103
- var _c = theme.palette, tertiary = _c.tertiary, primary = _c.primary;
104
- var polygonColor = tertiary ? tertiary.light : primary.light;
68
+ }));
69
+ const Polygon = (0, mobx_react_1.observer)(({ model, overview, useOffset = true, }) => {
70
+ const theme = (0, material_1.useTheme)();
71
+ const multiplier = Number(useOffset);
72
+ const { interRegionPaddingWidth, offsetPx, dynamicBlocks, cytobandOffset } = model;
73
+ const { contentBlocks, totalWidthPxWithoutBorders } = dynamicBlocks;
74
+ const { tertiary, primary } = theme.palette;
75
+ const polygonColor = tertiary ? tertiary.light : primary.light;
105
76
  if (!contentBlocks.length) {
106
77
  return null;
107
78
  }
108
- var first = contentBlocks[0];
109
- var last = contentBlocks[contentBlocks.length - 1];
110
- var topLeft = (overview.bpToPx(__assign(__assign({}, first), { coord: first.reversed ? first.end : first.start })) || 0) +
79
+ const first = contentBlocks[0];
80
+ const last = contentBlocks[contentBlocks.length - 1];
81
+ const topLeft = (overview.bpToPx({
82
+ ...first,
83
+ coord: first.reversed ? first.end : first.start,
84
+ }) || 0) +
111
85
  cytobandOffset * multiplier;
112
- var topRight = (overview.bpToPx(__assign(__assign({}, last), { coord: last.reversed ? last.start : last.end })) || 0) +
86
+ const topRight = (overview.bpToPx({
87
+ ...last,
88
+ coord: last.reversed ? last.start : last.end,
89
+ }) || 0) +
113
90
  cytobandOffset * multiplier;
114
- var startPx = Math.max(0, -offsetPx);
115
- var endPx = startPx +
91
+ const startPx = Math.max(0, -offsetPx);
92
+ const endPx = startPx +
116
93
  totalWidthPxWithoutBorders +
117
94
  (contentBlocks.length * interRegionPaddingWidth) / 2;
118
- var points = [
95
+ const points = [
119
96
  [startPx, __1.HEADER_BAR_HEIGHT],
120
97
  [endPx, __1.HEADER_BAR_HEIGHT],
121
98
  [topRight, 0],
@@ -146,7 +123,7 @@ function leftRoundedRect(x, y, width, height, radius) {
146
123
  + "a" + radius + "," + radius + " 0 0 1 " + radius + "," + (-radius)
147
124
  + "z";
148
125
  }
149
- var colorMap = {
126
+ const colorMap = {
150
127
  gneg: 'rgb(227,227,227)',
151
128
  gpos25: 'rgb(142,142,142)',
152
129
  gpos50: 'rgb(85,85,85)',
@@ -158,38 +135,36 @@ var colorMap = {
158
135
  };
159
136
  function getCytobands(assembly, refName) {
160
137
  var _a;
161
- return (((_a = assembly === null || assembly === void 0 ? void 0 : assembly.cytobands) === null || _a === void 0 ? void 0 : _a.map(function (f) { return ({
138
+ return (((_a = assembly === null || assembly === void 0 ? void 0 : assembly.cytobands) === null || _a === void 0 ? void 0 : _a.map(f => ({
162
139
  refName: assembly.getCanonicalRefName(f.get('refName')),
163
140
  start: f.get('start'),
164
141
  end: f.get('end'),
165
142
  type: f.get('type'),
166
- }); }).filter(function (f) { return f.refName === refName; })) || []);
143
+ })).filter(f => f.refName === refName)) || []);
167
144
  }
168
- var Cytobands = (0, mobx_react_1.observer)(function (_a) {
169
- var overview = _a.overview, block = _a.block, assembly = _a.assembly;
170
- var offsetPx = block.offsetPx, reversed = block.reversed;
171
- var cytobands = getCytobands(assembly, block.refName);
172
- var coords = cytobands.map(function (f) {
173
- var refName = f.refName, start = f.start, end = f.end, type = f.type;
145
+ const Cytobands = (0, mobx_react_1.observer)(({ overview, block, assembly, }) => {
146
+ const { offsetPx, reversed } = block;
147
+ const cytobands = getCytobands(assembly, block.refName);
148
+ const coords = cytobands.map(f => {
149
+ const { refName, start, end, type } = f;
174
150
  return [
175
151
  overview.bpToPx({
176
- refName: refName,
152
+ refName,
177
153
  coord: start,
178
154
  }),
179
155
  overview.bpToPx({
180
- refName: refName,
156
+ refName,
181
157
  coord: end,
182
158
  }),
183
159
  type,
184
160
  ];
185
161
  });
186
- var arr = cytobands || [];
187
- var lcap = reversed ? arr.length - 1 : 0;
188
- var rcap = reversed ? 0 : arr.length - 1;
189
- var firstCent = true;
190
- return (react_1.default.createElement("g", { transform: "translate(-".concat(offsetPx, ")") }, coords.map(function (_a, index) {
191
- var _b = __read(_a, 3), start = _b[0], end = _b[1], type = _b[2];
192
- var key = "".concat(start, "-").concat(end, "-").concat(type);
162
+ const arr = cytobands || [];
163
+ const lcap = reversed ? arr.length - 1 : 0;
164
+ const rcap = reversed ? 0 : arr.length - 1;
165
+ let firstCent = true;
166
+ return (react_1.default.createElement("g", { transform: `translate(-${offsetPx})` }, coords.map(([start, end, type], index) => {
167
+ const key = `${start}-${end}-${type}`;
193
168
  if (type === 'acen' && firstCent) {
194
169
  firstCent = false;
195
170
  return (react_1.default.createElement("polygon", { key: key, points: [
@@ -217,21 +192,20 @@ var Cytobands = (0, mobx_react_1.observer)(function (_a) {
217
192
  })));
218
193
  });
219
194
  exports.Cytobands = Cytobands;
220
- var OverviewBox = (0, mobx_react_1.observer)(function (_a) {
221
- var scale = _a.scale, model = _a.model, block = _a.block, overview = _a.overview;
222
- var _b = useStyles(), classes = _b.classes, cx = _b.cx;
223
- var cytobandOffset = model.cytobandOffset, bpPerPx = model.bpPerPx, showCytobands = model.showCytobands;
224
- var start = block.start, end = block.end, reversed = block.reversed, refName = block.refName, assemblyName = block.assemblyName;
225
- var majorPitch = (0, util_2.chooseGridPitch)(scale, 120, 15).majorPitch;
226
- var assemblyManager = (0, util_1.getSession)(model).assemblyManager;
227
- var assembly = assemblyManager.get(assemblyName);
228
- var refNameColor = assembly === null || assembly === void 0 ? void 0 : assembly.getRefNameColor(refName);
229
- var tickLabels = [];
230
- for (var i = 0; i < Math.floor((end - start) / majorPitch); i++) {
231
- var offsetLabel = (i + 1) * majorPitch;
195
+ const OverviewBox = (0, mobx_react_1.observer)(({ scale, model, block, overview, }) => {
196
+ const { classes, cx } = useStyles();
197
+ const { cytobandOffset, bpPerPx, showCytobands } = model;
198
+ const { start, end, reversed, refName, assemblyName } = block;
199
+ const { majorPitch } = (0, util_2.chooseGridPitch)(scale, 120, 15);
200
+ const { assemblyManager } = (0, util_1.getSession)(model);
201
+ const assembly = assemblyManager.get(assemblyName);
202
+ const refNameColor = assembly === null || assembly === void 0 ? void 0 : assembly.getRefNameColor(refName);
203
+ const tickLabels = [];
204
+ for (let i = 0; i < Math.floor((end - start) / majorPitch); i++) {
205
+ const offsetLabel = (i + 1) * majorPitch;
232
206
  tickLabels.push(reversed ? end - offsetLabel : start + offsetLabel);
233
207
  }
234
- var canDisplayCytobands = showCytobands && getCytobands(assembly, block.refName).length;
208
+ const canDisplayCytobands = showCytobands && getCytobands(assembly, block.refName).length;
235
209
  return (react_1.default.createElement("div", null,
236
210
  react_1.default.createElement(material_1.Typography, { style: {
237
211
  left: block.offsetPx + 3,
@@ -247,34 +221,38 @@ var OverviewBox = (0, mobx_react_1.observer)(function (_a) {
247
221
  borderColor: refNameColor,
248
222
  } },
249
223
  !canDisplayCytobands
250
- ? tickLabels.map(function (tickLabel, labelIdx) { return (react_1.default.createElement(material_1.Typography, { key: "".concat(JSON.stringify(block), "-").concat(tickLabel, "-").concat(labelIdx), className: classes.scaleBarLabel, variant: "body2", style: {
224
+ ? tickLabels.map((tickLabel, labelIdx) => (react_1.default.createElement(material_1.Typography, { key: `${JSON.stringify(block)}-${tickLabel}-${labelIdx}`, className: classes.scaleBarLabel, variant: "body2", style: {
251
225
  left: ((labelIdx + 1) * majorPitch) / scale,
252
226
  pointerEvents: 'none',
253
227
  color: refNameColor,
254
- } }, (0, util_1.getTickDisplayStr)(tickLabel, bpPerPx))); })
228
+ } }, (0, util_1.getTickDisplayStr)(tickLabel, bpPerPx))))
255
229
  : null,
256
230
  canDisplayCytobands ? (react_1.default.createElement("svg", { style: { width: '100%' } },
257
231
  react_1.default.createElement(Cytobands, { overview: overview, assembly: assembly, block: block }))) : null)));
258
232
  });
259
- var ScaleBar = (0, mobx_react_1.observer)(function (_a) {
260
- var model = _a.model, scale = _a.scale, overview = _a.overview;
261
- var classes = useStyles().classes;
262
- var theme = (0, material_1.useTheme)();
263
- var dynamicBlocks = model.dynamicBlocks, showCytobands = model.showCytobands, cytobandOffset = model.cytobandOffset;
264
- var visibleRegions = dynamicBlocks.contentBlocks;
265
- var overviewVisibleRegions = overview.dynamicBlocks;
266
- // @ts-ignore
267
- var _b = theme.palette, tertiary = _b.tertiary, primary = _b.primary;
268
- var scaleBarColor = tertiary ? tertiary.light : primary.light;
233
+ const ScaleBar = (0, mobx_react_1.observer)(({ model, scale, overview, }) => {
234
+ const { classes } = useStyles();
235
+ const theme = (0, material_1.useTheme)();
236
+ const { dynamicBlocks, showCytobands, cytobandOffset } = model;
237
+ const visibleRegions = dynamicBlocks.contentBlocks;
238
+ const overviewVisibleRegions = overview.dynamicBlocks;
239
+ const { tertiary, primary } = theme.palette;
240
+ const scaleBarColor = tertiary ? tertiary.light : primary.light;
269
241
  if (!visibleRegions.length) {
270
242
  return null;
271
243
  }
272
- var first = visibleRegions[0];
273
- var firstOverviewPx = overview.bpToPx(__assign(__assign({}, first), { coord: first.reversed ? first.end : first.start })) || 0;
274
- var last = visibleRegions[visibleRegions.length - 1];
275
- var lastOverviewPx = overview.bpToPx(__assign(__assign({}, last), { coord: last.reversed ? last.start : last.end })) || 0;
276
- var color = showCytobands ? '#f00' : scaleBarColor;
277
- var transparency = showCytobands ? 0.1 : 0.3;
244
+ const first = visibleRegions[0];
245
+ const firstOverviewPx = overview.bpToPx({
246
+ ...first,
247
+ coord: first.reversed ? first.end : first.start,
248
+ }) || 0;
249
+ const last = visibleRegions[visibleRegions.length - 1];
250
+ const lastOverviewPx = overview.bpToPx({
251
+ ...last,
252
+ coord: last.reversed ? last.start : last.end,
253
+ }) || 0;
254
+ const color = showCytobands ? '#f00' : scaleBarColor;
255
+ const transparency = showCytobands ? 0.1 : 0.3;
278
256
  return (react_1.default.createElement("div", { className: classes.scaleBar },
279
257
  react_1.default.createElement("div", { className: classes.scaleBarVisibleRegion, style: {
280
258
  width: lastOverviewPx - firstOverviewPx,
@@ -282,28 +260,27 @@ var ScaleBar = (0, mobx_react_1.observer)(function (_a) {
282
260
  background: (0, material_1.alpha)(color, transparency),
283
261
  borderColor: color,
284
262
  } }),
285
- overviewVisibleRegions.map(function (block, idx) {
286
- return !(block instanceof blockTypes_1.ContentBlock) ? (react_1.default.createElement("div", { key: "".concat(JSON.stringify(block), "-").concat(idx), className: classes.scaleBarContig, style: {
263
+ overviewVisibleRegions.map((block, idx) => {
264
+ return !(block instanceof blockTypes_1.ContentBlock) ? (react_1.default.createElement("div", { key: `${JSON.stringify(block)}-${idx}`, className: classes.scaleBarContig, style: {
287
265
  width: block.widthPx,
288
266
  left: block.offsetPx,
289
267
  backgroundColor: '#999',
290
268
  backgroundImage: 'repeating-linear-gradient(90deg, transparent, transparent 1px, rgba(255,255,255,.5) 1px, rgba(255,255,255,.5) 3px)',
291
- } })) : (react_1.default.createElement(OverviewBox, { scale: scale, block: block, model: model, overview: overview, key: "".concat(JSON.stringify(block), "-").concat(idx) }));
269
+ } })) : (react_1.default.createElement(OverviewBox, { scale: scale, block: block, model: model, overview: overview, key: `${JSON.stringify(block)}-${idx}` }));
292
270
  })));
293
271
  });
294
- function OverviewScaleBar(_a) {
295
- var model = _a.model, children = _a.children;
296
- var classes = useStyles().classes;
297
- var totalBp = model.totalBp, width = model.width, cytobandOffset = model.cytobandOffset, displayedRegions = model.displayedRegions;
298
- var overview = Base1DViewModel_1.default.create({
272
+ function OverviewScaleBar({ model, children, }) {
273
+ const { classes } = useStyles();
274
+ const { totalBp, width, cytobandOffset, displayedRegions } = model;
275
+ const overview = Base1DViewModel_1.default.create({
299
276
  displayedRegions: JSON.parse(JSON.stringify(displayedRegions)),
300
277
  interRegionPaddingWidth: 0,
301
278
  minimumBlockWidth: model.minimumBlockWidth,
302
279
  });
303
- var modWidth = width - cytobandOffset;
280
+ const modWidth = width - cytobandOffset;
304
281
  overview.setVolatileWidth(modWidth);
305
282
  overview.showAllRegions();
306
- var scale = totalBp / (modWidth - (displayedRegions.length - 1) * wholeSeqSpacer);
283
+ const scale = totalBp / (modWidth - (displayedRegions.length - 1) * wholeSeqSpacer);
307
284
  return (react_1.default.createElement("div", null,
308
285
  react_1.default.createElement(OverviewRubberBand_1.default, { model: model, overview: overview, ControlComponent: react_1.default.createElement(ScaleBar, { model: model, overview: overview, scale: scale }) }),
309
286
  react_1.default.createElement("div", { className: classes.overview },