@jbrowse/plugin-spreadsheet-view 2.6.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 (279) hide show
  1. package/LICENSE +201 -0
  2. package/dist/LaunchSpreadsheetView/index.d.ts +3 -0
  3. package/dist/LaunchSpreadsheetView/index.js +26 -0
  4. package/dist/LaunchSpreadsheetView/index.js.map +1 -0
  5. package/dist/SpreadsheetView/components/CellData.d.ts +9 -0
  6. package/dist/SpreadsheetView/components/CellData.js +16 -0
  7. package/dist/SpreadsheetView/components/CellData.js.map +1 -0
  8. package/dist/SpreadsheetView/components/ColumnFilterControls.d.ts +3 -0
  9. package/dist/SpreadsheetView/components/ColumnFilterControls.js +62 -0
  10. package/dist/SpreadsheetView/components/ColumnFilterControls.js.map +1 -0
  11. package/dist/SpreadsheetView/components/ColumnMenu.d.ts +16 -0
  12. package/dist/SpreadsheetView/components/ColumnMenu.js +127 -0
  13. package/dist/SpreadsheetView/components/ColumnMenu.js.map +1 -0
  14. package/dist/SpreadsheetView/components/DataRow.d.ts +12 -0
  15. package/dist/SpreadsheetView/components/DataRow.js +82 -0
  16. package/dist/SpreadsheetView/components/DataRow.js.map +1 -0
  17. package/dist/SpreadsheetView/components/DataTable.d.ts +10 -0
  18. package/dist/SpreadsheetView/components/DataTable.js +43 -0
  19. package/dist/SpreadsheetView/components/DataTable.js.map +1 -0
  20. package/dist/SpreadsheetView/components/DataTableHeader.d.ts +6 -0
  21. package/dist/SpreadsheetView/components/DataTableHeader.js +102 -0
  22. package/dist/SpreadsheetView/components/DataTableHeader.js.map +1 -0
  23. package/dist/SpreadsheetView/components/GlobalFilterControls.d.ts +5 -0
  24. package/dist/SpreadsheetView/components/GlobalFilterControls.js +64 -0
  25. package/dist/SpreadsheetView/components/GlobalFilterControls.js.map +1 -0
  26. package/dist/SpreadsheetView/components/ImportWizard.d.ts +6 -0
  27. package/dist/SpreadsheetView/components/ImportWizard.js +81 -0
  28. package/dist/SpreadsheetView/components/ImportWizard.js.map +1 -0
  29. package/dist/SpreadsheetView/components/NumberEditor.d.ts +9 -0
  30. package/dist/SpreadsheetView/components/NumberEditor.js +54 -0
  31. package/dist/SpreadsheetView/components/NumberEditor.js.map +1 -0
  32. package/dist/SpreadsheetView/components/RowCountMessage.d.ts +8 -0
  33. package/dist/SpreadsheetView/components/RowCountMessage.js +33 -0
  34. package/dist/SpreadsheetView/components/RowCountMessage.js.map +1 -0
  35. package/dist/SpreadsheetView/components/RowMenu.d.ts +9 -0
  36. package/dist/SpreadsheetView/components/RowMenu.js +39 -0
  37. package/dist/SpreadsheetView/components/RowMenu.js.map +1 -0
  38. package/dist/SpreadsheetView/components/SortIndicator.d.ts +6 -0
  39. package/dist/SpreadsheetView/components/SortIndicator.js +28 -0
  40. package/dist/SpreadsheetView/components/SortIndicator.js.map +1 -0
  41. package/dist/SpreadsheetView/components/Spreadsheet.d.ts +11 -0
  42. package/dist/SpreadsheetView/components/Spreadsheet.js +25 -0
  43. package/dist/SpreadsheetView/components/Spreadsheet.js.map +1 -0
  44. package/dist/SpreadsheetView/components/SpreadsheetView.d.ts +6 -0
  45. package/dist/SpreadsheetView/components/SpreadsheetView.js +86 -0
  46. package/dist/SpreadsheetView/components/SpreadsheetView.js.map +1 -0
  47. package/dist/SpreadsheetView/components/StatusBar.d.ts +11 -0
  48. package/dist/SpreadsheetView/components/StatusBar.js +42 -0
  49. package/dist/SpreadsheetView/components/StatusBar.js.map +1 -0
  50. package/dist/SpreadsheetView/components/util.d.ts +1 -0
  51. package/dist/SpreadsheetView/components/util.js +19 -0
  52. package/dist/SpreadsheetView/components/util.js.map +1 -0
  53. package/dist/SpreadsheetView/importAdapters/BedImport.d.ts +17 -0
  54. package/dist/SpreadsheetView/importAdapters/BedImport.js +147 -0
  55. package/dist/SpreadsheetView/importAdapters/BedImport.js.map +1 -0
  56. package/dist/SpreadsheetView/importAdapters/ImportUtils.d.ts +42 -0
  57. package/dist/SpreadsheetView/importAdapters/ImportUtils.js +124 -0
  58. package/dist/SpreadsheetView/importAdapters/ImportUtils.js.map +1 -0
  59. package/dist/SpreadsheetView/importAdapters/STARFusionImport.d.ts +9 -0
  60. package/dist/SpreadsheetView/importAdapters/STARFusionImport.js +73 -0
  61. package/dist/SpreadsheetView/importAdapters/STARFusionImport.js.map +1 -0
  62. package/dist/SpreadsheetView/importAdapters/VcfImport.d.ts +13 -0
  63. package/dist/SpreadsheetView/importAdapters/VcfImport.js +111 -0
  64. package/dist/SpreadsheetView/importAdapters/VcfImport.js.map +1 -0
  65. package/dist/SpreadsheetView/index.d.ts +4 -0
  66. package/dist/SpreadsheetView/index.js +42 -0
  67. package/dist/SpreadsheetView/index.js.map +1 -0
  68. package/dist/SpreadsheetView/models/ColumnDataTypes/LocEnd.d.ts +13 -0
  69. package/dist/SpreadsheetView/models/ColumnDataTypes/LocEnd.js +21 -0
  70. package/dist/SpreadsheetView/models/ColumnDataTypes/LocEnd.js.map +1 -0
  71. package/dist/SpreadsheetView/models/ColumnDataTypes/LocRef.d.ts +13 -0
  72. package/dist/SpreadsheetView/models/ColumnDataTypes/LocRef.js +21 -0
  73. package/dist/SpreadsheetView/models/ColumnDataTypes/LocRef.js.map +1 -0
  74. package/dist/SpreadsheetView/models/ColumnDataTypes/LocStart.d.ts +13 -0
  75. package/dist/SpreadsheetView/models/ColumnDataTypes/LocStart.js +21 -0
  76. package/dist/SpreadsheetView/models/ColumnDataTypes/LocStart.js.map +1 -0
  77. package/dist/SpreadsheetView/models/ColumnDataTypes/LocString.d.ts +13 -0
  78. package/dist/SpreadsheetView/models/ColumnDataTypes/LocString.js +190 -0
  79. package/dist/SpreadsheetView/models/ColumnDataTypes/LocString.js.map +1 -0
  80. package/dist/SpreadsheetView/models/ColumnDataTypes/MakeSpreadsheetColumnType.d.ts +19 -0
  81. package/dist/SpreadsheetView/models/ColumnDataTypes/MakeSpreadsheetColumnType.js +24 -0
  82. package/dist/SpreadsheetView/models/ColumnDataTypes/MakeSpreadsheetColumnType.js.map +1 -0
  83. package/dist/SpreadsheetView/models/ColumnDataTypes/Number.d.ts +30 -0
  84. package/dist/SpreadsheetView/models/ColumnDataTypes/Number.js +130 -0
  85. package/dist/SpreadsheetView/models/ColumnDataTypes/Number.js.map +1 -0
  86. package/dist/SpreadsheetView/models/ColumnDataTypes/Text.d.ts +28 -0
  87. package/dist/SpreadsheetView/models/ColumnDataTypes/Text.js +131 -0
  88. package/dist/SpreadsheetView/models/ColumnDataTypes/Text.js.map +1 -0
  89. package/dist/SpreadsheetView/models/ColumnDataTypes/index.d.ts +72 -0
  90. package/dist/SpreadsheetView/models/ColumnDataTypes/index.js +38 -0
  91. package/dist/SpreadsheetView/models/ColumnDataTypes/index.js.map +1 -0
  92. package/dist/SpreadsheetView/models/FilterControls.d.ts +26 -0
  93. package/dist/SpreadsheetView/models/FilterControls.js +88 -0
  94. package/dist/SpreadsheetView/models/FilterControls.js.map +1 -0
  95. package/dist/SpreadsheetView/models/ImportWizard.d.ts +31 -0
  96. package/dist/SpreadsheetView/models/ImportWizard.js +193 -0
  97. package/dist/SpreadsheetView/models/ImportWizard.js.map +1 -0
  98. package/dist/SpreadsheetView/models/Row.d.ts +17 -0
  99. package/dist/SpreadsheetView/models/Row.js +46 -0
  100. package/dist/SpreadsheetView/models/Row.js.map +1 -0
  101. package/dist/SpreadsheetView/models/Spreadsheet.d.ts +256 -0
  102. package/dist/SpreadsheetView/models/Spreadsheet.js +176 -0
  103. package/dist/SpreadsheetView/models/Spreadsheet.js.map +1 -0
  104. package/dist/SpreadsheetView/models/SpreadsheetView.d.ts +485 -0
  105. package/dist/SpreadsheetView/models/SpreadsheetView.js +204 -0
  106. package/dist/SpreadsheetView/models/SpreadsheetView.js.map +1 -0
  107. package/dist/SpreadsheetView/models/StaticRowSet.d.ts +163 -0
  108. package/dist/SpreadsheetView/models/StaticRowSet.js +60 -0
  109. package/dist/SpreadsheetView/models/StaticRowSet.js.map +1 -0
  110. package/dist/index.d.ts +8 -0
  111. package/dist/index.js +36 -0
  112. package/dist/index.js.map +1 -0
  113. package/esm/LaunchSpreadsheetView/index.d.ts +3 -0
  114. package/esm/LaunchSpreadsheetView/index.js +24 -0
  115. package/esm/LaunchSpreadsheetView/index.js.map +1 -0
  116. package/esm/SpreadsheetView/components/CellData.d.ts +9 -0
  117. package/esm/SpreadsheetView/components/CellData.js +11 -0
  118. package/esm/SpreadsheetView/components/CellData.js.map +1 -0
  119. package/esm/SpreadsheetView/components/ColumnFilterControls.d.ts +3 -0
  120. package/esm/SpreadsheetView/components/ColumnFilterControls.js +57 -0
  121. package/esm/SpreadsheetView/components/ColumnFilterControls.js.map +1 -0
  122. package/esm/SpreadsheetView/components/ColumnMenu.d.ts +16 -0
  123. package/esm/SpreadsheetView/components/ColumnMenu.js +122 -0
  124. package/esm/SpreadsheetView/components/ColumnMenu.js.map +1 -0
  125. package/esm/SpreadsheetView/components/DataRow.d.ts +12 -0
  126. package/esm/SpreadsheetView/components/DataRow.js +77 -0
  127. package/esm/SpreadsheetView/components/DataRow.js.map +1 -0
  128. package/esm/SpreadsheetView/components/DataTable.d.ts +10 -0
  129. package/esm/SpreadsheetView/components/DataTable.js +38 -0
  130. package/esm/SpreadsheetView/components/DataTable.js.map +1 -0
  131. package/esm/SpreadsheetView/components/DataTableHeader.d.ts +6 -0
  132. package/esm/SpreadsheetView/components/DataTableHeader.js +74 -0
  133. package/esm/SpreadsheetView/components/DataTableHeader.js.map +1 -0
  134. package/esm/SpreadsheetView/components/GlobalFilterControls.d.ts +5 -0
  135. package/esm/SpreadsheetView/components/GlobalFilterControls.js +36 -0
  136. package/esm/SpreadsheetView/components/GlobalFilterControls.js.map +1 -0
  137. package/esm/SpreadsheetView/components/ImportWizard.d.ts +6 -0
  138. package/esm/SpreadsheetView/components/ImportWizard.js +53 -0
  139. package/esm/SpreadsheetView/components/ImportWizard.js.map +1 -0
  140. package/esm/SpreadsheetView/components/NumberEditor.d.ts +9 -0
  141. package/esm/SpreadsheetView/components/NumberEditor.js +29 -0
  142. package/esm/SpreadsheetView/components/NumberEditor.js.map +1 -0
  143. package/esm/SpreadsheetView/components/RowCountMessage.d.ts +8 -0
  144. package/esm/SpreadsheetView/components/RowCountMessage.js +28 -0
  145. package/esm/SpreadsheetView/components/RowCountMessage.js.map +1 -0
  146. package/esm/SpreadsheetView/components/RowMenu.d.ts +9 -0
  147. package/esm/SpreadsheetView/components/RowMenu.js +34 -0
  148. package/esm/SpreadsheetView/components/RowMenu.js.map +1 -0
  149. package/esm/SpreadsheetView/components/SortIndicator.d.ts +6 -0
  150. package/esm/SpreadsheetView/components/SortIndicator.js +22 -0
  151. package/esm/SpreadsheetView/components/SortIndicator.js.map +1 -0
  152. package/esm/SpreadsheetView/components/Spreadsheet.d.ts +11 -0
  153. package/esm/SpreadsheetView/components/Spreadsheet.js +20 -0
  154. package/esm/SpreadsheetView/components/Spreadsheet.js.map +1 -0
  155. package/esm/SpreadsheetView/components/SpreadsheetView.d.ts +6 -0
  156. package/esm/SpreadsheetView/components/SpreadsheetView.js +58 -0
  157. package/esm/SpreadsheetView/components/SpreadsheetView.js.map +1 -0
  158. package/esm/SpreadsheetView/components/StatusBar.d.ts +11 -0
  159. package/esm/SpreadsheetView/components/StatusBar.js +37 -0
  160. package/esm/SpreadsheetView/components/StatusBar.js.map +1 -0
  161. package/esm/SpreadsheetView/components/util.d.ts +1 -0
  162. package/esm/SpreadsheetView/components/util.js +15 -0
  163. package/esm/SpreadsheetView/components/util.js.map +1 -0
  164. package/esm/SpreadsheetView/importAdapters/BedImport.d.ts +17 -0
  165. package/esm/SpreadsheetView/importAdapters/BedImport.js +141 -0
  166. package/esm/SpreadsheetView/importAdapters/BedImport.js.map +1 -0
  167. package/esm/SpreadsheetView/importAdapters/ImportUtils.d.ts +42 -0
  168. package/esm/SpreadsheetView/importAdapters/ImportUtils.js +95 -0
  169. package/esm/SpreadsheetView/importAdapters/ImportUtils.js.map +1 -0
  170. package/esm/SpreadsheetView/importAdapters/STARFusionImport.d.ts +9 -0
  171. package/esm/SpreadsheetView/importAdapters/STARFusionImport.js +69 -0
  172. package/esm/SpreadsheetView/importAdapters/STARFusionImport.js.map +1 -0
  173. package/esm/SpreadsheetView/importAdapters/VcfImport.d.ts +13 -0
  174. package/esm/SpreadsheetView/importAdapters/VcfImport.js +103 -0
  175. package/esm/SpreadsheetView/importAdapters/VcfImport.js.map +1 -0
  176. package/esm/SpreadsheetView/index.d.ts +4 -0
  177. package/esm/SpreadsheetView/index.js +14 -0
  178. package/esm/SpreadsheetView/index.js.map +1 -0
  179. package/esm/SpreadsheetView/models/ColumnDataTypes/LocEnd.d.ts +13 -0
  180. package/esm/SpreadsheetView/models/ColumnDataTypes/LocEnd.js +16 -0
  181. package/esm/SpreadsheetView/models/ColumnDataTypes/LocEnd.js.map +1 -0
  182. package/esm/SpreadsheetView/models/ColumnDataTypes/LocRef.d.ts +13 -0
  183. package/esm/SpreadsheetView/models/ColumnDataTypes/LocRef.js +16 -0
  184. package/esm/SpreadsheetView/models/ColumnDataTypes/LocRef.js.map +1 -0
  185. package/esm/SpreadsheetView/models/ColumnDataTypes/LocStart.d.ts +13 -0
  186. package/esm/SpreadsheetView/models/ColumnDataTypes/LocStart.js +16 -0
  187. package/esm/SpreadsheetView/models/ColumnDataTypes/LocStart.js.map +1 -0
  188. package/esm/SpreadsheetView/models/ColumnDataTypes/LocString.d.ts +13 -0
  189. package/esm/SpreadsheetView/models/ColumnDataTypes/LocString.js +185 -0
  190. package/esm/SpreadsheetView/models/ColumnDataTypes/LocString.js.map +1 -0
  191. package/esm/SpreadsheetView/models/ColumnDataTypes/MakeSpreadsheetColumnType.d.ts +19 -0
  192. package/esm/SpreadsheetView/models/ColumnDataTypes/MakeSpreadsheetColumnType.js +21 -0
  193. package/esm/SpreadsheetView/models/ColumnDataTypes/MakeSpreadsheetColumnType.js.map +1 -0
  194. package/esm/SpreadsheetView/models/ColumnDataTypes/Number.d.ts +30 -0
  195. package/esm/SpreadsheetView/models/ColumnDataTypes/Number.js +123 -0
  196. package/esm/SpreadsheetView/models/ColumnDataTypes/Number.js.map +1 -0
  197. package/esm/SpreadsheetView/models/ColumnDataTypes/Text.d.ts +28 -0
  198. package/esm/SpreadsheetView/models/ColumnDataTypes/Text.js +124 -0
  199. package/esm/SpreadsheetView/models/ColumnDataTypes/Text.js.map +1 -0
  200. package/esm/SpreadsheetView/models/ColumnDataTypes/index.d.ts +72 -0
  201. package/esm/SpreadsheetView/models/ColumnDataTypes/index.js +30 -0
  202. package/esm/SpreadsheetView/models/ColumnDataTypes/index.js.map +1 -0
  203. package/esm/SpreadsheetView/models/FilterControls.d.ts +26 -0
  204. package/esm/SpreadsheetView/models/FilterControls.js +86 -0
  205. package/esm/SpreadsheetView/models/FilterControls.js.map +1 -0
  206. package/esm/SpreadsheetView/models/ImportWizard.d.ts +31 -0
  207. package/esm/SpreadsheetView/models/ImportWizard.js +168 -0
  208. package/esm/SpreadsheetView/models/ImportWizard.js.map +1 -0
  209. package/esm/SpreadsheetView/models/Row.d.ts +17 -0
  210. package/esm/SpreadsheetView/models/Row.js +44 -0
  211. package/esm/SpreadsheetView/models/Row.js.map +1 -0
  212. package/esm/SpreadsheetView/models/Spreadsheet.d.ts +256 -0
  213. package/esm/SpreadsheetView/models/Spreadsheet.js +171 -0
  214. package/esm/SpreadsheetView/models/Spreadsheet.js.map +1 -0
  215. package/esm/SpreadsheetView/models/SpreadsheetView.d.ts +485 -0
  216. package/esm/SpreadsheetView/models/SpreadsheetView.js +199 -0
  217. package/esm/SpreadsheetView/models/SpreadsheetView.js.map +1 -0
  218. package/esm/SpreadsheetView/models/StaticRowSet.d.ts +163 -0
  219. package/esm/SpreadsheetView/models/StaticRowSet.js +55 -0
  220. package/esm/SpreadsheetView/models/StaticRowSet.js.map +1 -0
  221. package/esm/index.d.ts +8 -0
  222. package/esm/index.js +30 -0
  223. package/esm/index.js.map +1 -0
  224. package/package.json +65 -0
  225. package/src/LaunchSpreadsheetView/index.ts +40 -0
  226. package/src/SpreadsheetView/components/CellData.tsx +35 -0
  227. package/src/SpreadsheetView/components/ColumnFilterControls.tsx +84 -0
  228. package/src/SpreadsheetView/components/ColumnMenu.tsx +166 -0
  229. package/src/SpreadsheetView/components/DataRow.tsx +126 -0
  230. package/src/SpreadsheetView/components/DataTable.tsx +91 -0
  231. package/src/SpreadsheetView/components/DataTableHeader.tsx +122 -0
  232. package/src/SpreadsheetView/components/GlobalFilterControls.tsx +70 -0
  233. package/src/SpreadsheetView/components/ImportWizard.tsx +139 -0
  234. package/src/SpreadsheetView/components/NumberEditor.tsx +50 -0
  235. package/src/SpreadsheetView/components/RowCountMessage.tsx +44 -0
  236. package/src/SpreadsheetView/components/RowMenu.tsx +65 -0
  237. package/src/SpreadsheetView/components/SortIndicator.tsx +36 -0
  238. package/src/SpreadsheetView/components/Spreadsheet.test.ts +17 -0
  239. package/src/SpreadsheetView/components/Spreadsheet.tsx +46 -0
  240. package/src/SpreadsheetView/components/SpreadsheetView.tsx +119 -0
  241. package/src/SpreadsheetView/components/StatusBar.tsx +75 -0
  242. package/src/SpreadsheetView/components/util.ts +16 -0
  243. package/src/SpreadsheetView/importAdapters/BedImport.test.ts +14 -0
  244. package/src/SpreadsheetView/importAdapters/BedImport.ts +155 -0
  245. package/src/SpreadsheetView/importAdapters/ImportUtils.test.ts +25 -0
  246. package/src/SpreadsheetView/importAdapters/ImportUtils.ts +152 -0
  247. package/src/SpreadsheetView/importAdapters/STARFusionImport.test.ts +27 -0
  248. package/src/SpreadsheetView/importAdapters/STARFusionImport.ts +74 -0
  249. package/src/SpreadsheetView/importAdapters/VcfImport.test.ts +42 -0
  250. package/src/SpreadsheetView/importAdapters/VcfImport.ts +118 -0
  251. package/src/SpreadsheetView/importAdapters/__snapshots__/ImportUtils.test.ts.snap +6555 -0
  252. package/src/SpreadsheetView/importAdapters/__snapshots__/STARFusionImport.test.ts.snap +2354 -0
  253. package/src/SpreadsheetView/importAdapters/__snapshots__/VcfImport.test.ts.snap +16329 -0
  254. package/src/SpreadsheetView/index.ts +20 -0
  255. package/src/SpreadsheetView/models/ColumnDataTypes/LocEnd.ts +21 -0
  256. package/src/SpreadsheetView/models/ColumnDataTypes/LocRef.ts +21 -0
  257. package/src/SpreadsheetView/models/ColumnDataTypes/LocStart.ts +21 -0
  258. package/src/SpreadsheetView/models/ColumnDataTypes/LocString.tsx +328 -0
  259. package/src/SpreadsheetView/models/ColumnDataTypes/MakeSpreadsheetColumnType.tsx +38 -0
  260. package/src/SpreadsheetView/models/ColumnDataTypes/Number.tsx +177 -0
  261. package/src/SpreadsheetView/models/ColumnDataTypes/Text.tsx +173 -0
  262. package/src/SpreadsheetView/models/ColumnDataTypes/index.ts +34 -0
  263. package/src/SpreadsheetView/models/FilterControls.ts +95 -0
  264. package/src/SpreadsheetView/models/ImportWizard.ts +203 -0
  265. package/src/SpreadsheetView/models/Row.ts +46 -0
  266. package/src/SpreadsheetView/models/Spreadsheet.ts +209 -0
  267. package/src/SpreadsheetView/models/SpreadsheetView.test.ts +8 -0
  268. package/src/SpreadsheetView/models/SpreadsheetView.ts +243 -0
  269. package/src/SpreadsheetView/models/StaticRowSet.ts +65 -0
  270. package/src/SpreadsheetView/test_data/1801160099-N32519_26611_S51_56704.hard-filtered.vcf +174 -0
  271. package/src/SpreadsheetView/test_data/breast_cancer.subset.csv +50 -0
  272. package/src/SpreadsheetView/test_data/diabetes_target.csv.gz +0 -0
  273. package/src/SpreadsheetView/test_data/foo.bed +11 -0
  274. package/src/SpreadsheetView/test_data/location_test.csv +3 -0
  275. package/src/SpreadsheetView/test_data/location_test_2.csv +3 -0
  276. package/src/SpreadsheetView/test_data/reads_lr_skbr3.fa_ngmlr-0.2.3_mapped.bam.sniffles1kb_auto_l8_s5_noalt.bedpe +1405 -0
  277. package/src/SpreadsheetView/test_data/starfusion_example.fusion_predictions.tsv +25 -0
  278. package/src/SpreadsheetView/test_data/volvox.sort.bed +109 -0
  279. package/src/index.ts +38 -0
@@ -0,0 +1,13 @@
1
+ /// <reference types="node" />
2
+ import { RowSet, Column, ParseOptions } from './ImportUtils';
3
+ export declare function parseVcfBuffer(buffer: Buffer, options?: ParseOptions): {
4
+ rowSet: RowSet;
5
+ columnDisplayOrder: number[];
6
+ hasColumnNames: boolean;
7
+ columns: Column[];
8
+ assemblyName: string | undefined;
9
+ };
10
+ export declare function splitVcfFileHeaderAndBody(wholeFile: string): {
11
+ header: string;
12
+ body: string;
13
+ };
@@ -0,0 +1,103 @@
1
+ import VCF from '@gmod/vcf';
2
+ import { VcfFeature } from '@jbrowse/plugin-variants';
3
+ import { bufferToString, } from './ImportUtils';
4
+ const vcfCoreColumns = [
5
+ { name: 'CHROM', type: 'Text' },
6
+ { name: 'POS', type: 'Number' },
7
+ { name: 'ID', type: 'Text' },
8
+ { name: 'REF', type: 'Text' },
9
+ { name: 'ALT', type: 'Text' },
10
+ { name: 'QUAL', type: 'Number' },
11
+ { name: 'FILTER', type: 'Text' },
12
+ { name: 'INFO', type: 'Text' },
13
+ { name: 'FORMAT', type: 'Text' }, // 8
14
+ ];
15
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
16
+ function vcfRecordToRow(vcfParser, line, lineNumber) {
17
+ const vcfVariant = vcfParser.parseLine(line);
18
+ const vcfFeature = new VcfFeature({
19
+ variant: vcfVariant,
20
+ parser: vcfParser,
21
+ id: `vcf-${lineNumber}`,
22
+ });
23
+ const data = line.split('\t').map(d => (d === '.' ? '' : d));
24
+ // no format column, add blank
25
+ if (data.length === 8) {
26
+ data.push('');
27
+ }
28
+ const row = {
29
+ id: String(lineNumber + 1),
30
+ extendedData: { vcfFeature: vcfFeature.toJSON() },
31
+ cells: data.map((text, columnNumber) => {
32
+ return {
33
+ columnNumber,
34
+ text,
35
+ };
36
+ }),
37
+ };
38
+ return row;
39
+ }
40
+ export function parseVcfBuffer(buffer, options = {}) {
41
+ const { selectedAssemblyName } = options;
42
+ let { header, body } = splitVcfFileHeaderAndBody(bufferToString(buffer));
43
+ const rows = [];
44
+ const vcfParser = new VCF({ header });
45
+ header = ''; // garbage collect
46
+ body.split(/\n|\r\n|\r/).forEach((line, lineNumber) => {
47
+ if (/\S/.test(line)) {
48
+ rows.push(vcfRecordToRow(vcfParser, line, lineNumber));
49
+ }
50
+ });
51
+ body = ''; // garbage collect
52
+ const rowSet = {
53
+ isLoaded: true,
54
+ rows,
55
+ };
56
+ const columnDisplayOrder = [];
57
+ const columns = [];
58
+ for (let i = 0; i < vcfCoreColumns.length; i += 1) {
59
+ columnDisplayOrder.push(i);
60
+ columns[i] = {
61
+ name: vcfCoreColumns[i].name,
62
+ dataType: { type: vcfCoreColumns[i].type },
63
+ };
64
+ }
65
+ for (let i = 0; i < vcfParser.samples.length; i += 1) {
66
+ const oi = vcfCoreColumns.length + i;
67
+ columnDisplayOrder.push(oi);
68
+ columns[oi] = { name: vcfParser.samples[i], dataType: { type: 'Text' } };
69
+ }
70
+ columnDisplayOrder.push(columnDisplayOrder.length);
71
+ columns.unshift({
72
+ name: 'Location',
73
+ dataType: { type: 'LocString' },
74
+ isDerived: true,
75
+ derivationFunctionText: `jexl:{text:row.extendedData.vcfFeature.refName+':'\n
76
+ +row.extendedData.vcfFeature.start+'..'+row.extendedData.vcfFeature.end, extendedData:\n
77
+ {refName:row.extendedData.vcfFeature.refName,start:row.extendedData.vcfFeature.start,end:row.extendedData.vcfFeature.end}}`,
78
+ });
79
+ return {
80
+ rowSet,
81
+ columnDisplayOrder,
82
+ hasColumnNames: true,
83
+ columns,
84
+ assemblyName: selectedAssemblyName,
85
+ };
86
+ }
87
+ export function splitVcfFileHeaderAndBody(wholeFile) {
88
+ // split into header and the rest of the file
89
+ let headerEndIndex = 0;
90
+ let prevChar;
91
+ for (; headerEndIndex < wholeFile.length; headerEndIndex += 1) {
92
+ const c = wholeFile[headerEndIndex];
93
+ if (prevChar === '\n' && c !== '#') {
94
+ break;
95
+ }
96
+ prevChar = c;
97
+ }
98
+ return {
99
+ header: wholeFile.slice(0, Math.max(0, headerEndIndex)),
100
+ body: wholeFile.slice(headerEndIndex),
101
+ };
102
+ }
103
+ //# sourceMappingURL=VcfImport.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"VcfImport.js","sourceRoot":"","sources":["../../../src/SpreadsheetView/importAdapters/VcfImport.ts"],"names":[],"mappings":"AAAA,OAAO,GAAG,MAAM,WAAW,CAAA;AAC3B,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAA;AACrD,OAAO,EACL,cAAc,GAKf,MAAM,eAAe,CAAA;AAEtB,MAAM,cAAc,GAAqC;IACvD,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE;IAC/B,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE;IAC/B,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE;IAC5B,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE;IAC7B,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE;IAC7B,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE;IAChC,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE;IAChC,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE;IAC9B,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,IAAI;CACvC,CAAA;AAED,8DAA8D;AAC9D,SAAS,cAAc,CAAC,SAAc,EAAE,IAAY,EAAE,UAAkB;IACtE,MAAM,UAAU,GAAG,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,CAAA;IAC5C,MAAM,UAAU,GAAG,IAAI,UAAU,CAAC;QAChC,OAAO,EAAE,UAAU;QACnB,MAAM,EAAE,SAAS;QACjB,EAAE,EAAE,OAAO,UAAU,EAAE;KACxB,CAAC,CAAA;IAEF,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;IAC5D,8BAA8B;IAC9B,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE;QACrB,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;KACd;IACD,MAAM,GAAG,GAAQ;QACf,EAAE,EAAE,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC;QAC1B,YAAY,EAAE,EAAE,UAAU,EAAE,UAAU,CAAC,MAAM,EAAE,EAAE;QACjD,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,YAAY,EAAE,EAAE;YACrC,OAAO;gBACL,YAAY;gBACZ,IAAI;aACL,CAAA;QACH,CAAC,CAAC;KACH,CAAA;IACD,OAAO,GAAG,CAAA;AACZ,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,MAAc,EAAE,UAAwB,EAAE;IACvE,MAAM,EAAE,oBAAoB,EAAE,GAAG,OAAO,CAAA;IACxC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,yBAAyB,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAA;IACxE,MAAM,IAAI,GAAU,EAAE,CAAA;IACtB,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC,CAAA;IACrC,MAAM,GAAG,EAAE,CAAA,CAAC,kBAAkB;IAC9B,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,CAAC,IAAY,EAAE,UAAU,EAAE,EAAE;QAC5D,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;YACnB,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,SAAS,EAAE,IAAI,EAAE,UAAU,CAAC,CAAC,CAAA;SACvD;IACH,CAAC,CAAC,CAAA;IACF,IAAI,GAAG,EAAE,CAAA,CAAC,kBAAkB;IAE5B,MAAM,MAAM,GAAW;QACrB,QAAQ,EAAE,IAAI;QACd,IAAI;KACL,CAAA;IAED,MAAM,kBAAkB,GAAa,EAAE,CAAA;IACvC,MAAM,OAAO,GAAa,EAAE,CAAA;IAC5B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,cAAc,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE;QACjD,kBAAkB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QAC1B,OAAO,CAAC,CAAC,CAAC,GAAG;YACX,IAAI,EAAE,cAAc,CAAC,CAAC,CAAC,CAAC,IAAI;YAC5B,QAAQ,EAAE,EAAE,IAAI,EAAE,cAAc,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE;SAC3C,CAAA;KACF;IACD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE;QACpD,MAAM,EAAE,GAAG,cAAc,CAAC,MAAM,GAAG,CAAC,CAAA;QACpC,kBAAkB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QAC3B,OAAO,CAAC,EAAE,CAAC,GAAG,EAAE,IAAI,EAAE,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,CAAA;KACzE;IAED,kBAAkB,CAAC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAA;IAClD,OAAO,CAAC,OAAO,CAAC;QACd,IAAI,EAAE,UAAU;QAChB,QAAQ,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE;QAC/B,SAAS,EAAE,IAAI;QACf,sBAAsB,EAAE;;+HAEmG;KAC5H,CAAC,CAAA;IAEF,OAAO;QACL,MAAM;QACN,kBAAkB;QAClB,cAAc,EAAE,IAAI;QACpB,OAAO;QACP,YAAY,EAAE,oBAAoB;KACnC,CAAA;AACH,CAAC;AAED,MAAM,UAAU,yBAAyB,CAAC,SAAiB;IACzD,6CAA6C;IAC7C,IAAI,cAAc,GAAG,CAAC,CAAA;IACtB,IAAI,QAAQ,CAAA;IACZ,OAAO,cAAc,GAAG,SAAS,CAAC,MAAM,EAAE,cAAc,IAAI,CAAC,EAAE;QAC7D,MAAM,CAAC,GAAG,SAAS,CAAC,cAAc,CAAC,CAAA;QACnC,IAAI,QAAQ,KAAK,IAAI,IAAI,CAAC,KAAK,GAAG,EAAE;YAClC,MAAK;SACN;QACD,QAAQ,GAAG,CAAC,CAAA;KACb;IAED,OAAO;QACL,MAAM,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,cAAc,CAAC,CAAC;QACvD,IAAI,EAAE,SAAS,CAAC,KAAK,CAAC,cAAc,CAAC;KACtC,CAAA;AACH,CAAC"}
@@ -0,0 +1,4 @@
1
+ import PluginManager from '@jbrowse/core/PluginManager';
2
+ declare const _default: (pluginManager: PluginManager) => void;
3
+ export default _default;
4
+ export { type SpreadsheetViewModel, type SpreadsheetViewStateModel, } from './models/SpreadsheetView';
@@ -0,0 +1,14 @@
1
+ import { lazy } from 'react';
2
+ import { ViewType } from '@jbrowse/core/pluggableElementTypes';
3
+ import stateModel from './models/SpreadsheetView';
4
+ export default (pluginManager) => {
5
+ pluginManager.addViewType(() => {
6
+ return new ViewType({
7
+ name: 'SpreadsheetView',
8
+ displayName: 'Spreadsheet view',
9
+ stateModel,
10
+ ReactComponent: lazy(() => import('./components/SpreadsheetView')),
11
+ });
12
+ });
13
+ };
14
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/SpreadsheetView/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,OAAO,CAAA;AAC5B,OAAO,EAAE,QAAQ,EAAE,MAAM,qCAAqC,CAAA;AAE9D,OAAO,UAAU,MAAM,0BAA0B,CAAA;AAEjD,eAAe,CAAC,aAA4B,EAAE,EAAE;IAC9C,aAAa,CAAC,WAAW,CAAC,GAAG,EAAE;QAC7B,OAAO,IAAI,QAAQ,CAAC;YAClB,IAAI,EAAE,iBAAiB;YACvB,WAAW,EAAE,kBAAkB;YAC/B,UAAU;YACV,cAAc,EAAE,IAAI,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,8BAA8B,CAAC,CAAC;SACnE,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAA"}
@@ -0,0 +1,13 @@
1
+ /// <reference types="react" />
2
+ declare const LocEnd: import("mobx-state-tree").IModelType<{
3
+ type: import("mobx-state-tree").ISimpleType<string>;
4
+ }, {
5
+ DataCellReactComponent: import("react").FC<any> | null;
6
+ FilterModelType: any;
7
+ displayName: string;
8
+ categoryName: string | undefined;
9
+ } & {
10
+ compare: any;
11
+ readonly hasFilter: boolean;
12
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>;
13
+ export default LocEnd;
@@ -0,0 +1,16 @@
1
+ import MakeSpreadsheetColumnType from './MakeSpreadsheetColumnType';
2
+ import { FilterModelType as NumberFilterModel } from './Number';
3
+ import { types } from 'mobx-state-tree';
4
+ const FilterModelType = types.compose(NumberFilterModel, types.model({
5
+ type: types.literal('LocEnd'),
6
+ }));
7
+ const LocEnd = MakeSpreadsheetColumnType('LocEnd', {
8
+ categoryName: 'Location',
9
+ displayName: 'End',
10
+ compare(cellA, cellB) {
11
+ return parseFloat(cellA.text) - parseFloat(cellB.text);
12
+ },
13
+ FilterModelType,
14
+ });
15
+ export default LocEnd;
16
+ //# sourceMappingURL=LocEnd.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LocEnd.js","sourceRoot":"","sources":["../../../../src/SpreadsheetView/models/ColumnDataTypes/LocEnd.ts"],"names":[],"mappings":"AAAA,OAAO,yBAAyB,MAAM,6BAA6B,CAAA;AACnE,OAAO,EAAE,eAAe,IAAI,iBAAiB,EAAE,MAAM,UAAU,CAAA;AAC/D,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAA;AAEvC,MAAM,eAAe,GAAG,KAAK,CAAC,OAAO,CACnC,iBAAiB,EACjB,KAAK,CAAC,KAAK,CAAC;IACV,IAAI,EAAE,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC;CAC9B,CAAC,CACH,CAAA;AAED,MAAM,MAAM,GAAG,yBAAyB,CAAC,QAAQ,EAAE;IACjD,YAAY,EAAE,UAAU;IACxB,WAAW,EAAE,KAAK;IAClB,OAAO,CAAC,KAAuB,EAAE,KAAuB;QACtD,OAAO,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;IACxD,CAAC;IACD,eAAe;CAChB,CAAC,CAAA;AAEF,eAAe,MAAM,CAAA"}
@@ -0,0 +1,13 @@
1
+ /// <reference types="react" />
2
+ declare const LocRef: import("mobx-state-tree").IModelType<{
3
+ type: import("mobx-state-tree").ISimpleType<string>;
4
+ }, {
5
+ DataCellReactComponent: import("react").FC<any> | null;
6
+ FilterModelType: any;
7
+ displayName: string;
8
+ categoryName: string | undefined;
9
+ } & {
10
+ compare: any;
11
+ readonly hasFilter: boolean;
12
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>;
13
+ export default LocRef;
@@ -0,0 +1,16 @@
1
+ import MakeSpreadsheetColumnType from './MakeSpreadsheetColumnType';
2
+ import { FilterModelType as NumberFilterModel } from './Text';
3
+ import { types } from 'mobx-state-tree';
4
+ const FilterModelType = types.compose(NumberFilterModel, types.model({
5
+ type: types.literal('LocRef'),
6
+ }));
7
+ const LocRef = MakeSpreadsheetColumnType('LocRef', {
8
+ categoryName: 'Location',
9
+ displayName: 'Reference seq',
10
+ compare(cellA, cellB) {
11
+ return cellA.text.localeCompare(cellB.text);
12
+ },
13
+ FilterModelType,
14
+ });
15
+ export default LocRef;
16
+ //# sourceMappingURL=LocRef.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LocRef.js","sourceRoot":"","sources":["../../../../src/SpreadsheetView/models/ColumnDataTypes/LocRef.ts"],"names":[],"mappings":"AAAA,OAAO,yBAAyB,MAAM,6BAA6B,CAAA;AACnE,OAAO,EAAE,eAAe,IAAI,iBAAiB,EAAE,MAAM,QAAQ,CAAA;AAC7D,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAA;AAEvC,MAAM,eAAe,GAAG,KAAK,CAAC,OAAO,CACnC,iBAAiB,EACjB,KAAK,CAAC,KAAK,CAAC;IACV,IAAI,EAAE,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC;CAC9B,CAAC,CACH,CAAA;AAED,MAAM,MAAM,GAAG,yBAAyB,CAAC,QAAQ,EAAE;IACjD,YAAY,EAAE,UAAU;IACxB,WAAW,EAAE,eAAe;IAC5B,OAAO,CAAC,KAAuB,EAAE,KAAuB;QACtD,OAAO,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;IAC7C,CAAC;IACD,eAAe;CAChB,CAAC,CAAA;AAEF,eAAe,MAAM,CAAA"}
@@ -0,0 +1,13 @@
1
+ /// <reference types="react" />
2
+ declare const LocStart: import("mobx-state-tree").IModelType<{
3
+ type: import("mobx-state-tree").ISimpleType<string>;
4
+ }, {
5
+ DataCellReactComponent: import("react").FC<any> | null;
6
+ FilterModelType: any;
7
+ displayName: string;
8
+ categoryName: string | undefined;
9
+ } & {
10
+ compare: any;
11
+ readonly hasFilter: boolean;
12
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>;
13
+ export default LocStart;
@@ -0,0 +1,16 @@
1
+ import MakeSpreadsheetColumnType from './MakeSpreadsheetColumnType';
2
+ import { types } from 'mobx-state-tree';
3
+ import { FilterModelType as NumberFilterModel } from './Number';
4
+ const FilterModelType = types.compose(NumberFilterModel, types.model({
5
+ type: types.literal('LocStart'),
6
+ }));
7
+ const LocStart = MakeSpreadsheetColumnType('LocStart', {
8
+ categoryName: 'Location',
9
+ displayName: 'Start',
10
+ compare(cellA, cellB) {
11
+ return parseFloat(cellA.text) - parseFloat(cellB.text);
12
+ },
13
+ FilterModelType,
14
+ });
15
+ export default LocStart;
16
+ //# sourceMappingURL=LocStart.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LocStart.js","sourceRoot":"","sources":["../../../../src/SpreadsheetView/models/ColumnDataTypes/LocStart.ts"],"names":[],"mappings":"AAAA,OAAO,yBAAyB,MAAM,6BAA6B,CAAA;AACnE,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAA;AACvC,OAAO,EAAE,eAAe,IAAI,iBAAiB,EAAE,MAAM,UAAU,CAAA;AAE/D,MAAM,eAAe,GAAG,KAAK,CAAC,OAAO,CACnC,iBAAiB,EACjB,KAAK,CAAC,KAAK,CAAC;IACV,IAAI,EAAE,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC;CAChC,CAAC,CACH,CAAA;AAED,MAAM,QAAQ,GAAG,yBAAyB,CAAC,UAAU,EAAE;IACrD,YAAY,EAAE,UAAU;IACxB,WAAW,EAAE,OAAO;IACpB,OAAO,CAAC,KAAuB,EAAE,KAAuB;QACtD,OAAO,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;IACxD,CAAC;IACD,eAAe;CAChB,CAAC,CAAA;AAEF,eAAe,QAAQ,CAAA"}
@@ -0,0 +1,13 @@
1
+ import React from 'react';
2
+ declare const LocStringColumnType: import("mobx-state-tree").IModelType<{
3
+ type: import("mobx-state-tree").ISimpleType<string>;
4
+ }, {
5
+ DataCellReactComponent: React.FC<any> | null;
6
+ FilterModelType: any;
7
+ displayName: string;
8
+ categoryName: string | undefined;
9
+ } & {
10
+ compare: any;
11
+ readonly hasFilter: boolean;
12
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>;
13
+ export default LocStringColumnType;
@@ -0,0 +1,185 @@
1
+ import React from 'react';
2
+ import { IconButton, TextField, MenuItem, InputAdornment, Select, } from '@mui/material';
3
+ import { makeStyles } from 'tss-react/mui';
4
+ import { observer } from 'mobx-react';
5
+ import { types, getParent, getPropertyMembers } from 'mobx-state-tree';
6
+ // jbrowse imports
7
+ import { getPropertyType, getEnumerationValues, getSubType, } from '@jbrowse/core/util/mst-reflection';
8
+ import { doesIntersect2, isContainedWithin, compareLocs, getSession, parseLocString, } from '@jbrowse/core/util';
9
+ // icons
10
+ import ClearIcon from '@mui/icons-material/Clear';
11
+ // locals
12
+ import MakeSpreadsheetColumnType from './MakeSpreadsheetColumnType';
13
+ const useStyles = makeStyles()({
14
+ textFilterControlAdornment: { marginRight: '-18px' },
15
+ textFilterControl: {
16
+ '& .MuiInput-formControl': {
17
+ marginTop: 8,
18
+ },
19
+ '& .MuiInputLabel-formControl': {
20
+ top: '-7px',
21
+ '&.MuiInputLabel-shrink': {
22
+ top: '-3px',
23
+ },
24
+ },
25
+ },
26
+ });
27
+ // React component for the column filter control
28
+ const FilterReactComponent = observer(function ({ filterModel, }) {
29
+ const { classes } = useStyles();
30
+ const operationChoices = getEnumerationValues(getSubType(getPropertyType(getPropertyMembers(filterModel), 'operation')));
31
+ return (React.createElement(React.Fragment, null,
32
+ React.createElement(Select, { value: filterModel.operation, onChange: event => filterModel.setOperation(String(event.target.value)) }, operationChoices.map(name => (React.createElement(MenuItem, { key: name, value: name }, name)))),
33
+ ' ',
34
+ React.createElement(TextField, { label: "range", placeholder: "chr1:100-200", error: filterModel.locStringIsInvalid, value: filterModel.locString, onChange: evt => filterModel.setLocString(evt.target.value), className: classes.textFilterControl, InputProps: {
35
+ endAdornment: (React.createElement(InputAdornment, { className: classes.textFilterControlAdornment, position: "end" },
36
+ React.createElement(IconButton, { "aria-label": "clear filter", onClick: () => filterModel.setLocString('') },
37
+ React.createElement(ClearIcon, null)))),
38
+ } })));
39
+ });
40
+ const OPERATIONS = [
41
+ 'overlaps with',
42
+ 'contained within',
43
+ 'fully contains',
44
+ 'does not overlap',
45
+ 'not contained within',
46
+ 'does not contain',
47
+ ];
48
+ // NOTE: assembly names, if present, are ignored in all of these predicates
49
+ const OPERATION_PREDICATES = {
50
+ 'overlaps with': (cellLocation, specifiedLocation) => {
51
+ return (cellLocation.refName === specifiedLocation.refName &&
52
+ doesIntersect2(cellLocation.start, cellLocation.end, specifiedLocation.start, specifiedLocation.end));
53
+ },
54
+ 'contained within': (cellLocation, specifiedLocation) => {
55
+ return (cellLocation.refName === specifiedLocation.refName &&
56
+ isContainedWithin(cellLocation.start, cellLocation.end, specifiedLocation.start, specifiedLocation.end));
57
+ },
58
+ 'fully contains': (cellLocation, specifiedLocation) => {
59
+ return (cellLocation.refName === specifiedLocation.refName &&
60
+ isContainedWithin(specifiedLocation.start, specifiedLocation.end, cellLocation.start, cellLocation.end));
61
+ },
62
+ };
63
+ OPERATION_PREDICATES['does not overlap'] = (cellLocation, specifiedLocation) => {
64
+ return !OPERATION_PREDICATES['overlaps with'](cellLocation, specifiedLocation);
65
+ };
66
+ OPERATION_PREDICATES['not contained within'] = (cellLocation, specifiedLocation) => {
67
+ return !OPERATION_PREDICATES['contained within'](cellLocation, specifiedLocation);
68
+ };
69
+ OPERATION_PREDICATES['does not contain'] = (cellLocation, specifiedLocation) => {
70
+ return !OPERATION_PREDICATES['fully contains'](cellLocation, specifiedLocation);
71
+ };
72
+ // MST model for the column filter control
73
+ const FilterModelType = types
74
+ .model('ColumnLocStringFilter', {
75
+ type: types.literal('LocString'),
76
+ columnNumber: types.integer,
77
+ locString: '',
78
+ operation: types.optional(types.enumeration(OPERATIONS), OPERATIONS[0]),
79
+ })
80
+ .views(self => ({
81
+ get locStringIsInvalid() {
82
+ if (self.locString) {
83
+ const parsed = this.parsedLocString;
84
+ return (!parsed ||
85
+ parsed.refName === '' ||
86
+ typeof parsed.start !== 'number' ||
87
+ typeof parsed.end !== 'number' ||
88
+ parsed.start > parsed.end);
89
+ }
90
+ return false;
91
+ },
92
+ get parsedLocString() {
93
+ const session = getSession(self);
94
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
95
+ const model = getParent(self, 3).spreadsheet;
96
+ const { assemblyName } = model;
97
+ try {
98
+ return parseLocString(self.locString, refName => session.assemblyManager.isValidRefName(refName, assemblyName));
99
+ }
100
+ catch (e) {
101
+ return undefined;
102
+ }
103
+ },
104
+ }))
105
+ .views(self => ({
106
+ // returns a function that tests the given row
107
+ get predicate() {
108
+ const { locString, locStringIsInvalid, parsedLocString, operation, columnNumber, } = self; // avoid closing over self
109
+ if (!locString || locStringIsInvalid || !parsedLocString) {
110
+ return function alwaysTrue() {
111
+ return true;
112
+ };
113
+ }
114
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
115
+ return function stringPredicate(_sheet, row) {
116
+ const { cellsWithDerived: cells } = row;
117
+ const cell = cells[columnNumber];
118
+ if (!cell || !cell.text || !cell.extendedData) {
119
+ return false;
120
+ }
121
+ const parsedCellText = cell.extendedData;
122
+ if (!parsedCellText.refName) {
123
+ return false;
124
+ }
125
+ const predicate = OPERATION_PREDICATES[operation];
126
+ if (!predicate) {
127
+ throw new Error(`"${operation}" not implemented in location filter`);
128
+ }
129
+ return predicate(parsedCellText, parsedLocString);
130
+ };
131
+ },
132
+ }))
133
+ .actions(self => ({
134
+ setLocString(s) {
135
+ self.locString = s;
136
+ },
137
+ setOperation(op) {
138
+ self.operation = op;
139
+ },
140
+ }))
141
+ .volatile(() => ({ ReactComponent: FilterReactComponent }));
142
+ // opens a new LGV at the location described in the locString in the cell text
143
+ async function locationLinkClick(
144
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
145
+ spreadsheet, _columnNumber,
146
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
147
+ cell) {
148
+ const session = getSession(spreadsheet);
149
+ const { assemblyName } = spreadsheet;
150
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
151
+ const { id } = getParent(spreadsheet);
152
+ const newViewId = `${id}_${assemblyName}`;
153
+ let view = session.views.find(v => v.id === newViewId);
154
+ if (!view) {
155
+ view = session.addView('LinearGenomeView', {
156
+ id: newViewId,
157
+ });
158
+ }
159
+ await view.navToLocString(cell.text, assemblyName);
160
+ }
161
+ const DataCellReactComponent = observer(function ({ cell, columnNumber, spreadsheet, }) {
162
+ return (React.createElement("a", { onClick: async (evt) => {
163
+ evt.preventDefault();
164
+ const session = getSession(spreadsheet);
165
+ try {
166
+ await locationLinkClick(spreadsheet, columnNumber, cell);
167
+ }
168
+ catch (e) {
169
+ console.error(e);
170
+ session.notify(`${e}`, 'error');
171
+ }
172
+ }, title: "open a new linear genome view here", href: "#link" }, cell.text));
173
+ });
174
+ const LocStringColumnType = MakeSpreadsheetColumnType('LocString', {
175
+ categoryName: 'Location',
176
+ displayName: 'Full location',
177
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
178
+ compare(cellA, cellB) {
179
+ return compareLocs(cellA.extendedData, cellB.extendedData);
180
+ },
181
+ FilterModelType,
182
+ DataCellReactComponent,
183
+ });
184
+ export default LocStringColumnType;
185
+ //# sourceMappingURL=LocString.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LocString.js","sourceRoot":"","sources":["../../../../src/SpreadsheetView/models/ColumnDataTypes/LocString.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ import React from 'react';
2
+ /** utility function for assembling the MST model of a column data type */
3
+ export default function MakeSpreadsheetColumnType(name: string, { DataCellReactComponent, FilterModelType, compare, displayName, categoryName, }: {
4
+ compare?: any;
5
+ DataCellReactComponent?: React.FC<any> | null;
6
+ FilterModelType?: any;
7
+ displayName?: string;
8
+ categoryName?: string;
9
+ }): import("mobx-state-tree").IModelType<{
10
+ type: import("mobx-state-tree").ISimpleType<string>;
11
+ }, {
12
+ DataCellReactComponent: React.FC<any> | null;
13
+ FilterModelType: any;
14
+ displayName: string;
15
+ categoryName: string | undefined;
16
+ } & {
17
+ compare: any;
18
+ readonly hasFilter: boolean;
19
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>;
@@ -0,0 +1,21 @@
1
+ import { types } from 'mobx-state-tree';
2
+ /** utility function for assembling the MST model of a column data type */
3
+ export default function MakeSpreadsheetColumnType(name, { DataCellReactComponent = null, FilterModelType = null, compare, displayName = undefined, categoryName = undefined, }) {
4
+ return types
5
+ .model(`ColumnDataType${name}`, {
6
+ type: types.literal(name),
7
+ })
8
+ .volatile(() => ({
9
+ DataCellReactComponent,
10
+ FilterModelType: FilterModelType,
11
+ displayName: displayName || name,
12
+ categoryName,
13
+ }))
14
+ .views(() => ({
15
+ compare,
16
+ get hasFilter() {
17
+ return !!FilterModelType;
18
+ },
19
+ }));
20
+ }
21
+ //# sourceMappingURL=MakeSpreadsheetColumnType.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MakeSpreadsheetColumnType.js","sourceRoot":"","sources":["../../../../src/SpreadsheetView/models/ColumnDataTypes/MakeSpreadsheetColumnType.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAA;AAEvC,0EAA0E;AAC1E,MAAM,CAAC,OAAO,UAAU,yBAAyB,CAC/C,IAAY,EACZ,EACE,sBAAsB,GAAG,IAAI,EAC7B,eAAe,GAAG,IAAI,EACtB,OAAO,EACP,WAAW,GAAG,SAAS,EACvB,YAAY,GAAG,SAAS,GAOzB;IAED,OAAO,KAAK;SACT,KAAK,CAAC,iBAAiB,IAAI,EAAE,EAAE;QAC9B,IAAI,EAAE,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC;KAC1B,CAAC;SACD,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC;QACf,sBAAsB;QACtB,eAAe,EAAE,eAAe;QAChC,WAAW,EAAE,WAAW,IAAI,IAAI;QAChC,YAAY;KACb,CAAC,CAAC;SACF,KAAK,CAAC,GAAG,EAAE,CAAC,CAAC;QACZ,OAAO;QACP,IAAI,SAAS;YACX,OAAO,CAAC,CAAC,eAAe,CAAA;QAC1B,CAAC;KACF,CAAC,CAAC,CAAA;AACP,CAAC"}
@@ -0,0 +1,30 @@
1
+ import React from 'react';
2
+ declare const FilterModelType: import("mobx-state-tree").IModelType<{
3
+ type: import("mobx-state-tree").ISimpleType<"Number">;
4
+ columnNumber: import("mobx-state-tree").ISimpleType<number>;
5
+ firstNumber: import("mobx-state-tree").IMaybe<import("mobx-state-tree").ISimpleType<number>>;
6
+ secondNumber: import("mobx-state-tree").IMaybe<import("mobx-state-tree").ISimpleType<number>>;
7
+ operation: import("mobx-state-tree").IOptionalIType<import("mobx-state-tree").ISimpleType<string>, [undefined]>;
8
+ }, {
9
+ readonly predicate: (_sheet: any, row: any) => boolean;
10
+ } & {
11
+ setFirstNumber(n: number): void;
12
+ setSecondNumber(n: number): void;
13
+ setOperation(op: string): void;
14
+ } & {
15
+ ReactComponent: ({ filterModel }: {
16
+ filterModel: any;
17
+ }) => React.JSX.Element;
18
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>;
19
+ declare const NumberColumn: import("mobx-state-tree").IModelType<{
20
+ type: import("mobx-state-tree").ISimpleType<string>;
21
+ }, {
22
+ DataCellReactComponent: React.FC<any> | null;
23
+ FilterModelType: any;
24
+ displayName: string;
25
+ categoryName: string | undefined;
26
+ } & {
27
+ compare: any;
28
+ readonly hasFilter: boolean;
29
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>;
30
+ export { NumberColumn, FilterModelType };