@jbrowse/plugin-linear-genome-view 2.3.4 → 2.4.1

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 (271) hide show
  1. package/dist/BaseLinearDisplay/components/BaseLinearDisplay.d.ts +2 -3
  2. package/dist/BaseLinearDisplay/components/BaseLinearDisplay.js +4 -4
  3. package/dist/BaseLinearDisplay/components/BaseLinearDisplay.js.map +1 -1
  4. package/dist/BaseLinearDisplay/components/Block.js +1 -1
  5. package/dist/BaseLinearDisplay/components/Block.js.map +1 -1
  6. package/dist/BaseLinearDisplay/components/ServerSideRenderedBlockContent.js +11 -11
  7. package/dist/BaseLinearDisplay/components/ServerSideRenderedBlockContent.js.map +1 -1
  8. package/dist/BaseLinearDisplay/models/BaseLinearDisplayModel.d.ts +82 -7
  9. package/dist/BaseLinearDisplay/models/BaseLinearDisplayModel.js +43 -28
  10. package/dist/BaseLinearDisplay/models/BaseLinearDisplayModel.js.map +1 -1
  11. package/dist/BaseLinearDisplay/models/configSchema.js +8 -0
  12. package/dist/BaseLinearDisplay/models/configSchema.js.map +1 -1
  13. package/dist/BaseLinearDisplay/models/serverSideRenderedBlock.d.ts +1 -1
  14. package/dist/BaseLinearDisplay/models/serverSideRenderedBlock.js +9 -5
  15. package/dist/BaseLinearDisplay/models/serverSideRenderedBlock.js.map +1 -1
  16. package/dist/BaseLinearDisplay/models/util.js +2 -2
  17. package/dist/BaseLinearDisplay/models/util.js.map +1 -1
  18. package/dist/LaunchLinearGenomeView/index.js +1 -1
  19. package/dist/LaunchLinearGenomeView/index.js.map +1 -1
  20. package/dist/LinearBareDisplay/index.d.ts +2 -3
  21. package/dist/LinearBareDisplay/index.js +4 -2
  22. package/dist/LinearBareDisplay/index.js.map +1 -1
  23. package/dist/LinearBareDisplay/model.d.ts +61 -3
  24. package/dist/LinearBasicDisplay/index.d.ts +2 -3
  25. package/dist/LinearBasicDisplay/index.js +4 -2
  26. package/dist/LinearBasicDisplay/index.js.map +1 -1
  27. package/dist/LinearBasicDisplay/model.d.ts +82 -14
  28. package/dist/LinearGenomeView/components/CenterLine.js +2 -2
  29. package/dist/LinearGenomeView/components/CenterLine.js.map +1 -1
  30. package/dist/LinearGenomeView/components/Cytobands.d.ts +118 -0
  31. package/dist/LinearGenomeView/components/Cytobands.js +92 -0
  32. package/dist/LinearGenomeView/components/Cytobands.js.map +1 -0
  33. package/dist/LinearGenomeView/components/ExportSvgDialog.d.ts +1 -1
  34. package/dist/LinearGenomeView/components/ExportSvgDialog.js +24 -3
  35. package/dist/LinearGenomeView/components/ExportSvgDialog.js.map +1 -1
  36. package/dist/LinearGenomeView/components/Gridlines.js +1 -1
  37. package/dist/LinearGenomeView/components/Gridlines.js.map +1 -1
  38. package/dist/LinearGenomeView/components/Header.js +3 -4
  39. package/dist/LinearGenomeView/components/Header.js.map +1 -1
  40. package/dist/LinearGenomeView/components/ImportForm.d.ts +2 -2
  41. package/dist/LinearGenomeView/components/ImportForm.js +15 -19
  42. package/dist/LinearGenomeView/components/ImportForm.js.map +1 -1
  43. package/dist/LinearGenomeView/components/LinearGenomeView.js +1 -1
  44. package/dist/LinearGenomeView/components/MiniControls.js +5 -4
  45. package/dist/LinearGenomeView/components/MiniControls.js.map +1 -1
  46. package/dist/LinearGenomeView/components/OverviewRubberband.d.ts +3 -4
  47. package/dist/LinearGenomeView/components/OverviewRubberband.js +8 -11
  48. package/dist/LinearGenomeView/components/OverviewRubberband.js.map +1 -1
  49. package/dist/LinearGenomeView/components/OverviewScalebar.d.ts +4 -119
  50. package/dist/LinearGenomeView/components/OverviewScalebar.js +19 -103
  51. package/dist/LinearGenomeView/components/OverviewScalebar.js.map +1 -1
  52. package/dist/LinearGenomeView/components/RefNameAutocomplete.d.ts +2 -1
  53. package/dist/LinearGenomeView/components/RefNameAutocomplete.js +35 -31
  54. package/dist/LinearGenomeView/components/RefNameAutocomplete.js.map +1 -1
  55. package/dist/LinearGenomeView/components/RubberbandSpan.d.ts +2 -2
  56. package/dist/LinearGenomeView/components/RubberbandSpan.js +4 -18
  57. package/dist/LinearGenomeView/components/RubberbandSpan.js.map +1 -1
  58. package/dist/LinearGenomeView/components/SearchBox.js +3 -3
  59. package/dist/LinearGenomeView/components/SearchBox.js.map +1 -1
  60. package/dist/LinearGenomeView/components/TrackLabel.js +6 -7
  61. package/dist/LinearGenomeView/components/TrackLabel.js.map +1 -1
  62. package/dist/LinearGenomeView/components/TracksContainer.d.ts +2 -3
  63. package/dist/LinearGenomeView/components/TracksContainer.js +9 -8
  64. package/dist/LinearGenomeView/components/TracksContainer.js.map +1 -1
  65. package/dist/LinearGenomeView/components/ZoomControls.js +5 -4
  66. package/dist/LinearGenomeView/components/ZoomControls.js.map +1 -1
  67. package/dist/LinearGenomeView/components/hooks.d.ts +6 -1
  68. package/dist/LinearGenomeView/components/hooks.js +1 -1
  69. package/dist/LinearGenomeView/components/hooks.js.map +1 -1
  70. package/dist/LinearGenomeView/components/util.d.ts +6 -0
  71. package/dist/LinearGenomeView/components/util.js +11 -1
  72. package/dist/LinearGenomeView/components/util.js.map +1 -1
  73. package/dist/LinearGenomeView/index.js +8 -6
  74. package/dist/LinearGenomeView/index.js.map +1 -1
  75. package/dist/LinearGenomeView/model.d.ts +18 -12
  76. package/dist/LinearGenomeView/model.js +31 -34
  77. package/dist/LinearGenomeView/model.js.map +1 -1
  78. package/dist/LinearGenomeView/svgcomponents/SVGBackground.d.ts +6 -0
  79. package/dist/LinearGenomeView/svgcomponents/SVGBackground.js +13 -0
  80. package/dist/LinearGenomeView/svgcomponents/SVGBackground.js.map +1 -0
  81. package/dist/LinearGenomeView/svgcomponents/SVGHeader.d.ts +10 -0
  82. package/dist/LinearGenomeView/svgcomponents/SVGHeader.js +55 -0
  83. package/dist/LinearGenomeView/svgcomponents/SVGHeader.js.map +1 -0
  84. package/dist/LinearGenomeView/svgcomponents/SVGLinearGenomeView.d.ts +12 -0
  85. package/dist/LinearGenomeView/svgcomponents/SVGLinearGenomeView.js +57 -0
  86. package/dist/LinearGenomeView/svgcomponents/SVGLinearGenomeView.js.map +1 -0
  87. package/dist/LinearGenomeView/svgcomponents/SVGRegionSeparators.d.ts +8 -0
  88. package/dist/LinearGenomeView/svgcomponents/SVGRegionSeparators.js +13 -0
  89. package/dist/LinearGenomeView/svgcomponents/SVGRegionSeparators.js.map +1 -0
  90. package/dist/LinearGenomeView/svgcomponents/SVGRuler.d.ts +8 -0
  91. package/dist/LinearGenomeView/svgcomponents/SVGRuler.js +51 -0
  92. package/dist/LinearGenomeView/svgcomponents/SVGRuler.js.map +1 -0
  93. package/dist/LinearGenomeView/svgcomponents/SVGScalebar.d.ts +8 -0
  94. package/dist/LinearGenomeView/svgcomponents/SVGScalebar.js +22 -0
  95. package/dist/LinearGenomeView/svgcomponents/SVGScalebar.js.map +1 -0
  96. package/dist/LinearGenomeView/svgcomponents/SVGTrackLabel.d.ts +8 -0
  97. package/dist/LinearGenomeView/svgcomponents/SVGTrackLabel.js +16 -0
  98. package/dist/LinearGenomeView/svgcomponents/SVGTrackLabel.js.map +1 -0
  99. package/dist/LinearGenomeView/svgcomponents/SVGTracks.d.ts +23 -0
  100. package/dist/LinearGenomeView/svgcomponents/SVGTracks.js +30 -0
  101. package/dist/LinearGenomeView/svgcomponents/SVGTracks.js.map +1 -0
  102. package/dist/LinearGenomeView/util.js +2 -2
  103. package/dist/LinearGenomeView/util.js.map +1 -1
  104. package/dist/index.d.ts +157 -44
  105. package/dist/index.js +21 -13
  106. package/dist/index.js.map +1 -1
  107. package/esm/BaseLinearDisplay/components/BaseLinearDisplay.d.ts +2 -3
  108. package/esm/BaseLinearDisplay/components/BaseLinearDisplay.js +2 -3
  109. package/esm/BaseLinearDisplay/components/BaseLinearDisplay.js.map +1 -1
  110. package/esm/BaseLinearDisplay/components/Block.js +1 -1
  111. package/esm/BaseLinearDisplay/components/Block.js.map +1 -1
  112. package/esm/BaseLinearDisplay/components/ServerSideRenderedBlockContent.js +11 -11
  113. package/esm/BaseLinearDisplay/components/ServerSideRenderedBlockContent.js.map +1 -1
  114. package/esm/BaseLinearDisplay/models/BaseLinearDisplayModel.d.ts +82 -7
  115. package/esm/BaseLinearDisplay/models/BaseLinearDisplayModel.js +44 -29
  116. package/esm/BaseLinearDisplay/models/BaseLinearDisplayModel.js.map +1 -1
  117. package/esm/BaseLinearDisplay/models/configSchema.js +8 -0
  118. package/esm/BaseLinearDisplay/models/configSchema.js.map +1 -1
  119. package/esm/BaseLinearDisplay/models/serverSideRenderedBlock.d.ts +1 -1
  120. package/esm/BaseLinearDisplay/models/serverSideRenderedBlock.js +9 -5
  121. package/esm/BaseLinearDisplay/models/serverSideRenderedBlock.js.map +1 -1
  122. package/esm/BaseLinearDisplay/models/util.js +2 -2
  123. package/esm/BaseLinearDisplay/models/util.js.map +1 -1
  124. package/esm/LaunchLinearGenomeView/index.js +1 -1
  125. package/esm/LaunchLinearGenomeView/index.js.map +1 -1
  126. package/esm/LinearBareDisplay/index.d.ts +2 -3
  127. package/esm/LinearBareDisplay/index.js +2 -1
  128. package/esm/LinearBareDisplay/index.js.map +1 -1
  129. package/esm/LinearBareDisplay/model.d.ts +61 -3
  130. package/esm/LinearBasicDisplay/index.d.ts +2 -3
  131. package/esm/LinearBasicDisplay/index.js +2 -1
  132. package/esm/LinearBasicDisplay/index.js.map +1 -1
  133. package/esm/LinearBasicDisplay/model.d.ts +82 -14
  134. package/esm/LinearGenomeView/components/CenterLine.js +2 -2
  135. package/esm/LinearGenomeView/components/CenterLine.js.map +1 -1
  136. package/esm/LinearGenomeView/components/Cytobands.d.ts +118 -0
  137. package/esm/LinearGenomeView/components/Cytobands.js +87 -0
  138. package/esm/LinearGenomeView/components/Cytobands.js.map +1 -0
  139. package/esm/LinearGenomeView/components/ExportSvgDialog.d.ts +1 -1
  140. package/esm/LinearGenomeView/components/ExportSvgDialog.js +25 -4
  141. package/esm/LinearGenomeView/components/ExportSvgDialog.js.map +1 -1
  142. package/esm/LinearGenomeView/components/Gridlines.js +1 -1
  143. package/esm/LinearGenomeView/components/Gridlines.js.map +1 -1
  144. package/esm/LinearGenomeView/components/Header.js +5 -6
  145. package/esm/LinearGenomeView/components/Header.js.map +1 -1
  146. package/esm/LinearGenomeView/components/ImportForm.d.ts +2 -2
  147. package/esm/LinearGenomeView/components/ImportForm.js +16 -20
  148. package/esm/LinearGenomeView/components/ImportForm.js.map +1 -1
  149. package/esm/LinearGenomeView/components/LinearGenomeView.js +1 -1
  150. package/esm/LinearGenomeView/components/MiniControls.js +5 -4
  151. package/esm/LinearGenomeView/components/MiniControls.js.map +1 -1
  152. package/esm/LinearGenomeView/components/OverviewRubberband.d.ts +3 -4
  153. package/esm/LinearGenomeView/components/OverviewRubberband.js +8 -11
  154. package/esm/LinearGenomeView/components/OverviewRubberband.js.map +1 -1
  155. package/esm/LinearGenomeView/components/OverviewScalebar.d.ts +4 -119
  156. package/esm/LinearGenomeView/components/OverviewScalebar.js +16 -100
  157. package/esm/LinearGenomeView/components/OverviewScalebar.js.map +1 -1
  158. package/esm/LinearGenomeView/components/RefNameAutocomplete.d.ts +2 -1
  159. package/esm/LinearGenomeView/components/RefNameAutocomplete.js +36 -32
  160. package/esm/LinearGenomeView/components/RefNameAutocomplete.js.map +1 -1
  161. package/esm/LinearGenomeView/components/RubberbandSpan.d.ts +2 -2
  162. package/esm/LinearGenomeView/components/RubberbandSpan.js +5 -20
  163. package/esm/LinearGenomeView/components/RubberbandSpan.js.map +1 -1
  164. package/esm/LinearGenomeView/components/SearchBox.js +3 -3
  165. package/esm/LinearGenomeView/components/SearchBox.js.map +1 -1
  166. package/esm/LinearGenomeView/components/TrackLabel.js +6 -7
  167. package/esm/LinearGenomeView/components/TrackLabel.js.map +1 -1
  168. package/esm/LinearGenomeView/components/TracksContainer.d.ts +2 -3
  169. package/esm/LinearGenomeView/components/TracksContainer.js +9 -8
  170. package/esm/LinearGenomeView/components/TracksContainer.js.map +1 -1
  171. package/esm/LinearGenomeView/components/ZoomControls.js +5 -4
  172. package/esm/LinearGenomeView/components/ZoomControls.js.map +1 -1
  173. package/esm/LinearGenomeView/components/hooks.d.ts +6 -1
  174. package/esm/LinearGenomeView/components/hooks.js +1 -1
  175. package/esm/LinearGenomeView/components/hooks.js.map +1 -1
  176. package/esm/LinearGenomeView/components/util.d.ts +6 -0
  177. package/esm/LinearGenomeView/components/util.js +9 -0
  178. package/esm/LinearGenomeView/components/util.js.map +1 -1
  179. package/esm/LinearGenomeView/index.js +8 -6
  180. package/esm/LinearGenomeView/index.js.map +1 -1
  181. package/esm/LinearGenomeView/model.d.ts +18 -12
  182. package/esm/LinearGenomeView/model.js +24 -28
  183. package/esm/LinearGenomeView/model.js.map +1 -1
  184. package/esm/LinearGenomeView/svgcomponents/SVGBackground.d.ts +6 -0
  185. package/esm/LinearGenomeView/svgcomponents/SVGBackground.js +7 -0
  186. package/esm/LinearGenomeView/svgcomponents/SVGBackground.js.map +1 -0
  187. package/esm/LinearGenomeView/svgcomponents/SVGHeader.d.ts +10 -0
  188. package/esm/LinearGenomeView/svgcomponents/SVGHeader.js +49 -0
  189. package/esm/LinearGenomeView/svgcomponents/SVGHeader.js.map +1 -0
  190. package/esm/LinearGenomeView/svgcomponents/SVGLinearGenomeView.d.ts +12 -0
  191. package/esm/LinearGenomeView/svgcomponents/SVGLinearGenomeView.js +47 -0
  192. package/esm/LinearGenomeView/svgcomponents/SVGLinearGenomeView.js.map +1 -0
  193. package/esm/LinearGenomeView/svgcomponents/SVGRegionSeparators.d.ts +8 -0
  194. package/esm/LinearGenomeView/svgcomponents/SVGRegionSeparators.js +7 -0
  195. package/esm/LinearGenomeView/svgcomponents/SVGRegionSeparators.js.map +1 -0
  196. package/esm/LinearGenomeView/svgcomponents/SVGRuler.d.ts +8 -0
  197. package/esm/LinearGenomeView/svgcomponents/SVGRuler.js +45 -0
  198. package/esm/LinearGenomeView/svgcomponents/SVGRuler.js.map +1 -0
  199. package/esm/LinearGenomeView/svgcomponents/SVGScalebar.d.ts +8 -0
  200. package/esm/LinearGenomeView/svgcomponents/SVGScalebar.js +16 -0
  201. package/esm/LinearGenomeView/svgcomponents/SVGScalebar.js.map +1 -0
  202. package/esm/LinearGenomeView/svgcomponents/SVGTrackLabel.d.ts +8 -0
  203. package/esm/LinearGenomeView/svgcomponents/SVGTrackLabel.js +10 -0
  204. package/esm/LinearGenomeView/svgcomponents/SVGTrackLabel.js.map +1 -0
  205. package/esm/LinearGenomeView/svgcomponents/SVGTracks.d.ts +23 -0
  206. package/esm/LinearGenomeView/svgcomponents/SVGTracks.js +24 -0
  207. package/esm/LinearGenomeView/svgcomponents/SVGTracks.js.map +1 -0
  208. package/esm/LinearGenomeView/util.js +2 -2
  209. package/esm/LinearGenomeView/util.js.map +1 -1
  210. package/esm/index.d.ts +157 -44
  211. package/esm/index.js +9 -5
  212. package/esm/index.js.map +1 -1
  213. package/package.json +3 -3
  214. package/src/BaseLinearDisplay/components/BaseLinearDisplay.tsx +4 -3
  215. package/src/BaseLinearDisplay/components/Block.tsx +1 -1
  216. package/src/BaseLinearDisplay/components/ServerSideRenderedBlockContent.tsx +11 -12
  217. package/src/BaseLinearDisplay/models/BaseLinearDisplayModel.tsx +55 -40
  218. package/src/BaseLinearDisplay/models/configSchema.ts +8 -0
  219. package/src/BaseLinearDisplay/models/serverSideRenderedBlock.ts +15 -22
  220. package/src/BaseLinearDisplay/models/util.ts +2 -2
  221. package/src/LaunchLinearGenomeView/index.ts +1 -1
  222. package/src/LinearBareDisplay/index.ts +2 -1
  223. package/src/LinearBasicDisplay/index.ts +2 -1
  224. package/src/LinearGenomeView/components/CenterLine.tsx +2 -2
  225. package/src/LinearGenomeView/components/Cytobands.tsx +154 -0
  226. package/src/LinearGenomeView/components/ExportSvgDialog.tsx +56 -4
  227. package/src/LinearGenomeView/components/Gridlines.tsx +1 -1
  228. package/src/LinearGenomeView/components/Header.tsx +6 -13
  229. package/src/LinearGenomeView/components/ImportForm.tsx +17 -26
  230. package/src/LinearGenomeView/components/LinearGenomeView.test.tsx +8 -11
  231. package/src/LinearGenomeView/components/LinearGenomeView.tsx +1 -1
  232. package/src/LinearGenomeView/components/MiniControls.tsx +6 -7
  233. package/src/LinearGenomeView/components/OverviewRubberband.tsx +40 -49
  234. package/src/LinearGenomeView/components/OverviewScalebar.tsx +222 -385
  235. package/src/LinearGenomeView/components/RefNameAutocomplete.tsx +50 -48
  236. package/src/LinearGenomeView/components/RubberbandSpan.tsx +8 -25
  237. package/src/LinearGenomeView/components/SearchBox.tsx +3 -2
  238. package/src/LinearGenomeView/components/TrackLabel.tsx +76 -76
  239. package/src/LinearGenomeView/components/TracksContainer.tsx +8 -8
  240. package/src/LinearGenomeView/components/ZoomControls.tsx +3 -4
  241. package/src/LinearGenomeView/components/__snapshots__/LinearGenomeView.test.tsx.snap +1230 -1200
  242. package/src/LinearGenomeView/components/hooks.ts +7 -1
  243. package/src/LinearGenomeView/components/util.ts +13 -0
  244. package/src/LinearGenomeView/index.test.ts +12 -13
  245. package/src/LinearGenomeView/index.ts +8 -9
  246. package/src/LinearGenomeView/model.ts +41 -36
  247. package/src/LinearGenomeView/svgcomponents/SVGBackground.tsx +21 -0
  248. package/src/LinearGenomeView/svgcomponents/SVGHeader.tsx +93 -0
  249. package/src/LinearGenomeView/svgcomponents/SVGLinearGenomeView.tsx +114 -0
  250. package/src/LinearGenomeView/svgcomponents/SVGRegionSeparators.tsx +31 -0
  251. package/src/LinearGenomeView/svgcomponents/SVGRuler.tsx +125 -0
  252. package/src/LinearGenomeView/svgcomponents/SVGScalebar.tsx +57 -0
  253. package/src/LinearGenomeView/svgcomponents/SVGTrackLabel.tsx +47 -0
  254. package/src/LinearGenomeView/svgcomponents/SVGTracks.tsx +67 -0
  255. package/src/LinearGenomeView/util.test.ts +7 -4
  256. package/src/LinearGenomeView/util.ts +3 -3
  257. package/src/index.ts +22 -23
  258. package/dist/LinearGenomeView/components/LinearGenomeViewSvg.d.ts +0 -4
  259. package/dist/LinearGenomeView/components/LinearGenomeViewSvg.js +0 -141
  260. package/dist/LinearGenomeView/components/LinearGenomeViewSvg.js.map +0 -1
  261. package/dist/LinearGenomeView/components/Ruler.d.ts +0 -11
  262. package/dist/LinearGenomeView/components/Ruler.js +0 -39
  263. package/dist/LinearGenomeView/components/Ruler.js.map +0 -1
  264. package/esm/LinearGenomeView/components/LinearGenomeViewSvg.d.ts +0 -4
  265. package/esm/LinearGenomeView/components/LinearGenomeViewSvg.js +0 -134
  266. package/esm/LinearGenomeView/components/LinearGenomeViewSvg.js.map +0 -1
  267. package/esm/LinearGenomeView/components/Ruler.d.ts +0 -11
  268. package/esm/LinearGenomeView/components/Ruler.js +0 -34
  269. package/esm/LinearGenomeView/components/Ruler.js.map +0 -1
  270. package/src/LinearGenomeView/components/LinearGenomeViewSvg.tsx +0 -307
  271. package/src/LinearGenomeView/components/Ruler.tsx +0 -78
@@ -1,134 +0,0 @@
1
- import React from 'react';
2
- import { renderToStaticMarkup } from 'react-dom/server';
3
- import { when } from 'mobx';
4
- import { getParent } from 'mobx-state-tree';
5
- import { getConf, readConfObject } from '@jbrowse/core/configuration';
6
- import { getSession, getBpDisplayStr } from '@jbrowse/core/util';
7
- import Base1DView from '@jbrowse/core/util/Base1DViewModel';
8
- // locals
9
- import Ruler from './Ruler';
10
- import { HEADER_OVERVIEW_HEIGHT, } from '..';
11
- import { Polygon, Cytobands } from './OverviewScalebar';
12
- function Scalebar({ model, fontSize }) {
13
- const { offsetPx, dynamicBlocks: { totalWidthPxWithoutBorders: totalWidthPx, totalBp }, } = model;
14
- const displayBp = getBpDisplayStr(totalBp);
15
- const x0 = Math.max(-offsetPx, 0);
16
- const x1 = x0 + totalWidthPx;
17
- return (React.createElement(React.Fragment, null,
18
- React.createElement("line", { x1: x0, x2: x1, y1: 10, y2: 10, stroke: "black" }),
19
- React.createElement("line", { x1: x0, x2: x0, y1: 5, y2: 15, stroke: "black" }),
20
- React.createElement("line", { x1: x1, x2: x1, y1: 5, y2: 15, stroke: "black" }),
21
- React.createElement("text", { x: x0 + (x1 - x0) / 2, y: fontSize * 2, textAnchor: "middle", fontSize: fontSize }, displayBp)));
22
- }
23
- function SVGRuler({ model, fontSize, width, }) {
24
- const { dynamicBlocks: { contentBlocks }, offsetPx: viewOffsetPx, bpPerPx, } = model;
25
- const renderRuler = contentBlocks.length < 5;
26
- return (React.createElement(React.Fragment, null,
27
- React.createElement("defs", null,
28
- React.createElement("clipPath", { id: "clip-ruler" },
29
- React.createElement("rect", { x: 0, y: 0, width: width, height: 20 }))),
30
- contentBlocks.map(block => {
31
- const { key, start, end, reversed, offsetPx, refName } = block;
32
- const offsetLeft = offsetPx - viewOffsetPx;
33
- return (React.createElement("g", { key: `${key}`, transform: `translate(${offsetLeft} 0)` },
34
- React.createElement("text", { x: offsetLeft / bpPerPx, y: fontSize, fontSize: fontSize }, refName),
35
- renderRuler ? (React.createElement("g", { transform: "translate(0 20)", clipPath: "url(#clip-ruler)" },
36
- React.createElement(Ruler, { start: start, end: end, bpPerPx: bpPerPx, reversed: reversed }))) : (React.createElement("line", { strokeWidth: 1, stroke: "black", x1: start / bpPerPx, x2: end / bpPerPx, y1: 20, y2: 20 }))));
37
- })));
38
- }
39
- const fontSize = 15;
40
- const rulerHeight = 50;
41
- const textHeight = fontSize + 5;
42
- const paddingHeight = 20;
43
- const headerHeight = textHeight + 20;
44
- const cytobandHeightIfExists = 100;
45
- const totalHeight = (tracks) => {
46
- return tracks.reduce((accum, track) => {
47
- const display = track.displays[0];
48
- return accum + display.height + paddingHeight + textHeight;
49
- }, 0);
50
- };
51
- // SVG component, ruler and assembly name
52
- const SVGHeader = ({ model }) => {
53
- const { width, assemblyNames, showCytobands, displayedRegions } = model;
54
- const { assemblyManager } = getSession(model);
55
- const assemblyName = assemblyNames.length > 1 ? '' : assemblyNames[0];
56
- const assembly = assemblyManager.get(assemblyName);
57
- const overview = Base1DView.create({
58
- displayedRegions: JSON.parse(JSON.stringify(displayedRegions)),
59
- interRegionPaddingWidth: 0,
60
- minimumBlockWidth: model.minimumBlockWidth,
61
- });
62
- const visibleRegions = model.dynamicBlocks.contentBlocks;
63
- overview.setVolatileWidth(width);
64
- overview.showAllRegions();
65
- const block = overview.dynamicBlocks.contentBlocks[0];
66
- const first = visibleRegions[0];
67
- const firstOverviewPx = overview.bpToPx({
68
- ...first,
69
- coord: first.reversed ? first.end : first.start,
70
- }) || 0;
71
- const last = visibleRegions[visibleRegions.length - 1];
72
- const lastOverviewPx = overview.bpToPx({
73
- ...last,
74
- coord: last.reversed ? last.start : last.end,
75
- }) || 0;
76
- const cytobandHeight = showCytobands ? cytobandHeightIfExists : 0;
77
- return (React.createElement("g", { id: "header" },
78
- React.createElement("text", { x: 0, y: fontSize, fontSize: fontSize }, assemblyName),
79
- showCytobands ? (React.createElement("g", { transform: `translate(0 ${rulerHeight})` },
80
- React.createElement(Cytobands, { overview: overview, assembly: assembly, block: block }),
81
- React.createElement("rect", { stroke: "red", fill: "rgb(255,0,0,0.1)", width: Math.max(lastOverviewPx - firstOverviewPx, 0.5), height: HEADER_OVERVIEW_HEIGHT - 1, x: firstOverviewPx, y: 0.5 }),
82
- React.createElement("g", { transform: `translate(0,${HEADER_OVERVIEW_HEIGHT})` },
83
- React.createElement(Polygon, { overview: overview, model: model, useOffset: false })))) : null,
84
- React.createElement("g", { transform: `translate(0 ${fontSize + cytobandHeight})` },
85
- React.createElement(Scalebar, { model: model, fontSize: fontSize })),
86
- React.createElement("g", { transform: `translate(0 ${rulerHeight + cytobandHeight})` },
87
- React.createElement(SVGRuler, { model: model, fontSize: fontSize, width: width }))));
88
- };
89
- // SVG component, region separator
90
- const SVGRegionSeparators = ({ model, height, }) => {
91
- const { dynamicBlocks, offsetPx, interRegionPaddingWidth } = model;
92
- return (React.createElement(React.Fragment, null, dynamicBlocks.contentBlocks.slice(1).map(block => (React.createElement("rect", { key: block.key, x: block.offsetPx - offsetPx - interRegionPaddingWidth, width: interRegionPaddingWidth, y: 0, height: height, stroke: "none", fill: "grey" })))));
93
- };
94
- // SVG component, tracks
95
- function SVGTracks({ displayResults, model, offset, }) {
96
- return (React.createElement(React.Fragment, null, displayResults.map(({ track, result }) => {
97
- const current = offset;
98
- const trackName = getConf(track, 'name') ||
99
- `Reference sequence (${readConfObject(getParent(track.configuration), 'displayName') ||
100
- readConfObject(getParent(track.configuration), 'name')})`;
101
- const display = track.displays[0];
102
- offset += display.height + paddingHeight + textHeight;
103
- return (React.createElement("g", { key: track.configuration.trackId, transform: `translate(0 ${current})` },
104
- React.createElement("text", { fontSize: fontSize, x: Math.max(-model.offsetPx, 0) }, trackName),
105
- React.createElement("g", { transform: `translate(0 ${textHeight})` },
106
- result,
107
- React.createElement(SVGRegionSeparators, { model: model, height: display.height }))));
108
- })));
109
- }
110
- // render LGV to SVG
111
- export async function renderToSvg(model, opts) {
112
- await when(() => model.initialized);
113
- const { Wrapper = ({ children }) => React.createElement(React.Fragment, null, children) } = opts;
114
- const { width, tracks, showCytobands } = model;
115
- const shift = 50;
116
- const offset = headerHeight +
117
- rulerHeight +
118
- (showCytobands ? cytobandHeightIfExists : 0) +
119
- 20;
120
- const height = totalHeight(tracks) + offset;
121
- const displayResults = await Promise.all(tracks.map(async (track) => {
122
- const display = track.displays[0];
123
- await when(() => (display.ready !== undefined ? display.ready : true));
124
- return { track, result: await display.renderSvg(opts) };
125
- }));
126
- // the xlink namespace is used for rendering <image> tag
127
- return renderToStaticMarkup(React.createElement(Wrapper, null,
128
- React.createElement("svg", { width: width, height: height, xmlns: "http://www.w3.org/2000/svg", xmlnsXlink: "http://www.w3.org/1999/xlink", viewBox: [0, 0, width + shift * 2, height].toString() },
129
- React.createElement("rect", { width: width + shift * 2, height: height, fill: "white" }),
130
- React.createElement("g", { stroke: "none", transform: `translate(${shift} ${fontSize})` },
131
- React.createElement(SVGHeader, { model: model }),
132
- React.createElement(SVGTracks, { model: model, displayResults: displayResults, offset: offset })))));
133
- }
134
- //# sourceMappingURL=LinearGenomeViewSvg.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"LinearGenomeViewSvg.js","sourceRoot":"","sources":["../../../src/LinearGenomeView/components/LinearGenomeViewSvg.tsx"],"names":[],"mappings":"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"}
@@ -1,11 +0,0 @@
1
- /// <reference types="react" />
2
- declare function Ruler({ start, end, bpPerPx, reversed, major, minor, }: {
3
- start: number;
4
- end: number;
5
- bpPerPx: number;
6
- reversed?: boolean;
7
- major?: boolean;
8
- minor?: boolean;
9
- }): JSX.Element;
10
- declare const _default: typeof Ruler;
11
- export default _default;
@@ -1,34 +0,0 @@
1
- import React from 'react';
2
- import { makeStyles } from 'tss-react/mui';
3
- import { observer } from 'mobx-react';
4
- import { getTickDisplayStr } from '@jbrowse/core/util';
5
- // locals
6
- import { makeTicks } from '../util';
7
- const useStyles = makeStyles()({
8
- majorTickLabel: {
9
- fontSize: '11px',
10
- },
11
- majorTick: {
12
- stroke: '#555',
13
- },
14
- minorTick: {
15
- stroke: '#999',
16
- },
17
- });
18
- function Ruler({ start, end, bpPerPx, reversed = false, major = true, minor = true, }) {
19
- const { classes } = useStyles();
20
- const ticks = makeTicks(start, end, bpPerPx, major, minor);
21
- return (React.createElement(React.Fragment, null,
22
- ticks.map(tick => {
23
- const x = (reversed ? end - tick.base : tick.base - start) / bpPerPx;
24
- return (React.createElement("line", { key: tick.base, x1: x, x2: x, y1: 0, y2: tick.type === 'major' ? 6 : 4, strokeWidth: 1, stroke: tick.type === 'major' ? '#555' : '#999', className: tick.type === 'major' ? classes.majorTick : classes.minorTick, "data-bp": tick.base }));
25
- }),
26
- ticks
27
- .filter(tick => tick.type === 'major')
28
- .map(tick => {
29
- const x = (reversed ? end - tick.base : tick.base - start) / bpPerPx;
30
- return (React.createElement("text", { x: x - 3, y: 7 + 11, key: `label-${tick.base}`, style: { fontSize: '11px' }, className: classes.majorTickLabel }, getTickDisplayStr(tick.base + 1, bpPerPx)));
31
- })));
32
- }
33
- export default observer(Ruler);
34
- //# sourceMappingURL=Ruler.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Ruler.js","sourceRoot":"","sources":["../../../src/LinearGenomeView/components/Ruler.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAC1C,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AACrC,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAA;AAEtD,SAAS;AACT,OAAO,EAAE,SAAS,EAAE,MAAM,SAAS,CAAA;AAEnC,MAAM,SAAS,GAAG,UAAU,EAAE,CAAC;IAC7B,cAAc,EAAE;QACd,QAAQ,EAAE,MAAM;KACjB;IACD,SAAS,EAAE;QACT,MAAM,EAAE,MAAM;KACf;IACD,SAAS,EAAE;QACT,MAAM,EAAE,MAAM;KACf;CACF,CAAC,CAAA;AAEF,SAAS,KAAK,CAAC,EACb,KAAK,EACL,GAAG,EACH,OAAO,EACP,QAAQ,GAAG,KAAK,EAChB,KAAK,GAAG,IAAI,EACZ,KAAK,GAAG,IAAI,GAQb;IACC,MAAM,EAAE,OAAO,EAAE,GAAG,SAAS,EAAE,CAAA;IAC/B,MAAM,KAAK,GAAG,SAAS,CAAC,KAAK,EAAE,GAAG,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,CAAC,CAAA;IAC1D,OAAO,CACL;QACG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;YAChB,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,GAAG,OAAO,CAAA;YACpE,OAAO,CACL,8BACE,GAAG,EAAE,IAAI,CAAC,IAAI,EACd,EAAE,EAAE,CAAC,EACL,EAAE,EAAE,CAAC,EACL,EAAE,EAAE,CAAC,EACL,EAAE,EAAE,IAAI,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EACjC,WAAW,EAAE,CAAC,EACd,MAAM,EAAE,IAAI,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,EAC/C,SAAS,EACP,IAAI,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,SAAS,aAEtD,IAAI,CAAC,IAAI,GAClB,CACH,CAAA;QACH,CAAC,CAAC;QACD,KAAK;aACH,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,OAAO,CAAC;aACrC,GAAG,CAAC,IAAI,CAAC,EAAE;YACV,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,GAAG,OAAO,CAAA;YACpE,OAAO,CACL,8BACE,CAAC,EAAE,CAAC,GAAG,CAAC,EACR,CAAC,EAAE,CAAC,GAAG,EAAE,EACT,GAAG,EAAE,SAAS,IAAI,CAAC,IAAI,EAAE,EACzB,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,EAC3B,SAAS,EAAE,OAAO,CAAC,cAAc,IAEhC,iBAAiB,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,EAAE,OAAO,CAAC,CACrC,CACR,CAAA;QACH,CAAC,CAAC,CACH,CACJ,CAAA;AACH,CAAC;AAED,eAAe,QAAQ,CAAC,KAAK,CAAC,CAAA"}
@@ -1,307 +0,0 @@
1
- import React from 'react'
2
- import { renderToStaticMarkup } from 'react-dom/server'
3
- import { when } from 'mobx'
4
- import { getParent } from 'mobx-state-tree'
5
- import { getConf, readConfObject } from '@jbrowse/core/configuration'
6
- import { getSession, getBpDisplayStr } from '@jbrowse/core/util'
7
- import { AnyConfigurationModel } from '@jbrowse/core/configuration/configurationSchema'
8
- import Base1DView from '@jbrowse/core/util/Base1DViewModel'
9
-
10
- // locals
11
- import Ruler from './Ruler'
12
- import {
13
- LinearGenomeViewModel,
14
- ExportSvgOptions,
15
- HEADER_OVERVIEW_HEIGHT,
16
- } from '..'
17
- import { Polygon, Cytobands } from './OverviewScalebar'
18
-
19
- type LGV = LinearGenomeViewModel
20
-
21
- function Scalebar({ model, fontSize }: { model: LGV; fontSize: number }) {
22
- const {
23
- offsetPx,
24
- dynamicBlocks: { totalWidthPxWithoutBorders: totalWidthPx, totalBp },
25
- } = model
26
- const displayBp = getBpDisplayStr(totalBp)
27
- const x0 = Math.max(-offsetPx, 0)
28
- const x1 = x0 + totalWidthPx
29
- return (
30
- <>
31
- <line x1={x0} x2={x1} y1={10} y2={10} stroke="black" />
32
- <line x1={x0} x2={x0} y1={5} y2={15} stroke="black" />
33
- <line x1={x1} x2={x1} y1={5} y2={15} stroke="black" />
34
- <text
35
- x={x0 + (x1 - x0) / 2}
36
- y={fontSize * 2}
37
- textAnchor="middle"
38
- fontSize={fontSize}
39
- >
40
- {displayBp}
41
- </text>
42
- </>
43
- )
44
- }
45
-
46
- function SVGRuler({
47
- model,
48
- fontSize,
49
- width,
50
- }: {
51
- model: LGV
52
- fontSize: number
53
- width: number
54
- }) {
55
- const {
56
- dynamicBlocks: { contentBlocks },
57
- offsetPx: viewOffsetPx,
58
- bpPerPx,
59
- } = model
60
- const renderRuler = contentBlocks.length < 5
61
- return (
62
- <>
63
- <defs>
64
- <clipPath id="clip-ruler">
65
- <rect x={0} y={0} width={width} height={20} />
66
- </clipPath>
67
- </defs>
68
- {contentBlocks.map(block => {
69
- const { key, start, end, reversed, offsetPx, refName } = block
70
- const offsetLeft = offsetPx - viewOffsetPx
71
- return (
72
- <g key={`${key}`} transform={`translate(${offsetLeft} 0)`}>
73
- <text x={offsetLeft / bpPerPx} y={fontSize} fontSize={fontSize}>
74
- {refName}
75
- </text>
76
- {renderRuler ? (
77
- <g transform="translate(0 20)" clipPath="url(#clip-ruler)">
78
- <Ruler
79
- start={start}
80
- end={end}
81
- bpPerPx={bpPerPx}
82
- reversed={reversed}
83
- />
84
- </g>
85
- ) : (
86
- <line
87
- strokeWidth={1}
88
- stroke="black"
89
- x1={start / bpPerPx}
90
- x2={end / bpPerPx}
91
- y1={20}
92
- y2={20}
93
- />
94
- )}
95
- </g>
96
- )
97
- })}
98
- </>
99
- )
100
- }
101
-
102
- const fontSize = 15
103
- const rulerHeight = 50
104
- const textHeight = fontSize + 5
105
- const paddingHeight = 20
106
- const headerHeight = textHeight + 20
107
- const cytobandHeightIfExists = 100
108
-
109
- interface Display {
110
- height: number
111
- }
112
- interface Track {
113
- displays: Display[]
114
- }
115
-
116
- const totalHeight = (tracks: Track[]) => {
117
- return tracks.reduce((accum, track) => {
118
- const display = track.displays[0]
119
- return accum + display.height + paddingHeight + textHeight
120
- }, 0)
121
- }
122
-
123
- // SVG component, ruler and assembly name
124
- const SVGHeader = ({ model }: { model: LGV }) => {
125
- const { width, assemblyNames, showCytobands, displayedRegions } = model
126
- const { assemblyManager } = getSession(model)
127
- const assemblyName = assemblyNames.length > 1 ? '' : assemblyNames[0]
128
- const assembly = assemblyManager.get(assemblyName)
129
-
130
- const overview = Base1DView.create({
131
- displayedRegions: JSON.parse(JSON.stringify(displayedRegions)),
132
- interRegionPaddingWidth: 0,
133
- minimumBlockWidth: model.minimumBlockWidth,
134
- })
135
- const visibleRegions = model.dynamicBlocks.contentBlocks
136
-
137
- overview.setVolatileWidth(width)
138
- overview.showAllRegions()
139
- const block = overview.dynamicBlocks.contentBlocks[0]
140
-
141
- const first = visibleRegions[0]
142
- const firstOverviewPx =
143
- overview.bpToPx({
144
- ...first,
145
- coord: first.reversed ? first.end : first.start,
146
- }) || 0
147
-
148
- const last = visibleRegions[visibleRegions.length - 1]
149
- const lastOverviewPx =
150
- overview.bpToPx({
151
- ...last,
152
- coord: last.reversed ? last.start : last.end,
153
- }) || 0
154
-
155
- const cytobandHeight = showCytobands ? cytobandHeightIfExists : 0
156
-
157
- return (
158
- <g id="header">
159
- <text x={0} y={fontSize} fontSize={fontSize}>
160
- {assemblyName}
161
- </text>
162
-
163
- {showCytobands ? (
164
- <g transform={`translate(0 ${rulerHeight})`}>
165
- <Cytobands overview={overview} assembly={assembly} block={block} />
166
- <rect
167
- stroke="red"
168
- fill="rgb(255,0,0,0.1)"
169
- width={Math.max(lastOverviewPx - firstOverviewPx, 0.5)}
170
- height={HEADER_OVERVIEW_HEIGHT - 1}
171
- x={firstOverviewPx}
172
- y={0.5}
173
- />
174
- <g transform={`translate(0,${HEADER_OVERVIEW_HEIGHT})`}>
175
- <Polygon overview={overview} model={model} useOffset={false} />
176
- </g>
177
- </g>
178
- ) : null}
179
-
180
- <g transform={`translate(0 ${fontSize + cytobandHeight})`}>
181
- <Scalebar model={model} fontSize={fontSize} />
182
- </g>
183
- <g transform={`translate(0 ${rulerHeight + cytobandHeight})`}>
184
- <SVGRuler model={model} fontSize={fontSize} width={width} />
185
- </g>
186
- </g>
187
- )
188
- }
189
-
190
- // SVG component, region separator
191
- const SVGRegionSeparators = ({
192
- model,
193
- height,
194
- }: {
195
- height: number
196
- model: LGV
197
- }) => {
198
- const { dynamicBlocks, offsetPx, interRegionPaddingWidth } = model
199
- return (
200
- <>
201
- {dynamicBlocks.contentBlocks.slice(1).map(block => (
202
- <rect
203
- key={block.key}
204
- x={block.offsetPx - offsetPx - interRegionPaddingWidth}
205
- width={interRegionPaddingWidth}
206
- y={0}
207
- height={height}
208
- stroke="none"
209
- fill="grey"
210
- />
211
- ))}
212
- </>
213
- )
214
- }
215
-
216
- // SVG component, tracks
217
- function SVGTracks({
218
- displayResults,
219
- model,
220
- offset,
221
- }: {
222
- displayResults: {
223
- track: {
224
- configuration: AnyConfigurationModel
225
- displays: { height: number }[]
226
- }
227
- result: string
228
- }[]
229
- model: LGV
230
- offset: number
231
- }) {
232
- return (
233
- <>
234
- {displayResults.map(({ track, result }) => {
235
- const current = offset
236
- const trackName =
237
- getConf(track, 'name') ||
238
- `Reference sequence (${
239
- readConfObject(getParent(track.configuration), 'displayName') ||
240
- readConfObject(getParent(track.configuration), 'name')
241
- })`
242
- const display = track.displays[0]
243
- offset += display.height + paddingHeight + textHeight
244
- return (
245
- <g
246
- key={track.configuration.trackId}
247
- transform={`translate(0 ${current})`}
248
- >
249
- <text fontSize={fontSize} x={Math.max(-model.offsetPx, 0)}>
250
- {trackName}
251
- </text>
252
- <g transform={`translate(0 ${textHeight})`}>
253
- {result}
254
- <SVGRegionSeparators model={model} height={display.height} />
255
- </g>
256
- </g>
257
- )
258
- })}
259
- </>
260
- )
261
- }
262
-
263
- // render LGV to SVG
264
- export async function renderToSvg(model: LGV, opts: ExportSvgOptions) {
265
- await when(() => model.initialized)
266
- const { Wrapper = ({ children }) => <>{children}</> } = opts
267
- const { width, tracks, showCytobands } = model
268
- const shift = 50
269
- const offset =
270
- headerHeight +
271
- rulerHeight +
272
- (showCytobands ? cytobandHeightIfExists : 0) +
273
- 20
274
- const height = totalHeight(tracks) + offset
275
- const displayResults = await Promise.all(
276
- tracks.map(async track => {
277
- const display = track.displays[0]
278
- await when(() => (display.ready !== undefined ? display.ready : true))
279
- return { track, result: await display.renderSvg(opts) }
280
- }),
281
- )
282
-
283
- // the xlink namespace is used for rendering <image> tag
284
- return renderToStaticMarkup(
285
- <Wrapper>
286
- <svg
287
- width={width}
288
- height={height}
289
- xmlns="http://www.w3.org/2000/svg"
290
- xmlnsXlink="http://www.w3.org/1999/xlink"
291
- viewBox={[0, 0, width + shift * 2, height].toString()}
292
- >
293
- {/* background white */}
294
- <rect width={width + shift * 2} height={height} fill="white" />
295
-
296
- <g stroke="none" transform={`translate(${shift} ${fontSize})`}>
297
- <SVGHeader model={model} />
298
- <SVGTracks
299
- model={model}
300
- displayResults={displayResults}
301
- offset={offset}
302
- />
303
- </g>
304
- </svg>
305
- </Wrapper>,
306
- )
307
- }
@@ -1,78 +0,0 @@
1
- import React from 'react'
2
- import { makeStyles } from 'tss-react/mui'
3
- import { observer } from 'mobx-react'
4
- import { getTickDisplayStr } from '@jbrowse/core/util'
5
-
6
- // locals
7
- import { makeTicks } from '../util'
8
-
9
- const useStyles = makeStyles()({
10
- majorTickLabel: {
11
- fontSize: '11px',
12
- },
13
- majorTick: {
14
- stroke: '#555',
15
- },
16
- minorTick: {
17
- stroke: '#999',
18
- },
19
- })
20
-
21
- function Ruler({
22
- start,
23
- end,
24
- bpPerPx,
25
- reversed = false,
26
- major = true,
27
- minor = true,
28
- }: {
29
- start: number
30
- end: number
31
- bpPerPx: number
32
- reversed?: boolean
33
- major?: boolean
34
- minor?: boolean
35
- }) {
36
- const { classes } = useStyles()
37
- const ticks = makeTicks(start, end, bpPerPx, major, minor)
38
- return (
39
- <>
40
- {ticks.map(tick => {
41
- const x = (reversed ? end - tick.base : tick.base - start) / bpPerPx
42
- return (
43
- <line
44
- key={tick.base}
45
- x1={x}
46
- x2={x}
47
- y1={0}
48
- y2={tick.type === 'major' ? 6 : 4}
49
- strokeWidth={1}
50
- stroke={tick.type === 'major' ? '#555' : '#999'}
51
- className={
52
- tick.type === 'major' ? classes.majorTick : classes.minorTick
53
- }
54
- data-bp={tick.base}
55
- />
56
- )
57
- })}
58
- {ticks
59
- .filter(tick => tick.type === 'major')
60
- .map(tick => {
61
- const x = (reversed ? end - tick.base : tick.base - start) / bpPerPx
62
- return (
63
- <text
64
- x={x - 3}
65
- y={7 + 11}
66
- key={`label-${tick.base}`}
67
- style={{ fontSize: '11px' }}
68
- className={classes.majorTickLabel}
69
- >
70
- {getTickDisplayStr(tick.base + 1, bpPerPx)}
71
- </text>
72
- )
73
- })}
74
- </>
75
- )
76
- }
77
-
78
- export default observer(Ruler)