@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,168 @@
1
+ import { types, getParent } from 'mobx-state-tree';
2
+ import { openLocation } from '@jbrowse/core/util/io';
3
+ import { getSession, getEnv } from '@jbrowse/core/util';
4
+ // 30MB
5
+ const IMPORT_SIZE_LIMIT = 30000000;
6
+ const fileTypes = ['CSV', 'TSV', 'VCF', 'BED', 'BEDPE', 'STAR-Fusion'];
7
+ const fileTypeParsers = {
8
+ CSV: () => import('../importAdapters/ImportUtils').then(r => r.parseCsvBuffer),
9
+ TSV: () => import('../importAdapters/ImportUtils').then(r => r.parseTsvBuffer),
10
+ VCF: () => import('../importAdapters/VcfImport').then(r => r.parseVcfBuffer),
11
+ BED: () => import('../importAdapters/BedImport').then(r => r.parseBedBuffer),
12
+ BEDPE: () => import('../importAdapters/BedImport').then(r => r.parseBedPEBuffer),
13
+ 'STAR-Fusion': () => import('../importAdapters/STARFusionImport').then(r => r.parseSTARFusionBuffer),
14
+ };
15
+ // regexp used to guess the type of a file or URL from its file extension
16
+ const fileTypesRegexp = new RegExp(`\\.(${fileTypes.join('|')})(\\.gz)?$`, 'i');
17
+ /**
18
+ * #stateModel SpreadsheetImportWizard
19
+ * #category view
20
+ */
21
+ function x() { } // eslint-disable-line @typescript-eslint/no-unused-vars
22
+ const ImportWizard = types
23
+ .model('SpreadsheetImportWizard', {
24
+ /**
25
+ * #property
26
+ */
27
+ fileType: types.optional(types.enumeration(fileTypes), 'CSV'),
28
+ /**
29
+ * #property
30
+ */
31
+ hasColumnNameLine: true,
32
+ /**
33
+ * #property
34
+ */
35
+ columnNameLineNumber: 1,
36
+ /**
37
+ * #property
38
+ */
39
+ selectedAssemblyName: types.maybe(types.string),
40
+ })
41
+ .volatile(() => ({
42
+ fileTypes,
43
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
44
+ fileSource: undefined,
45
+ error: undefined,
46
+ loading: false,
47
+ }))
48
+ .views(self => ({
49
+ get isReadyToOpen() {
50
+ return (!self.error &&
51
+ self.fileSource &&
52
+ (self.fileSource.blobId ||
53
+ self.fileSource.localPath ||
54
+ self.fileSource.uri));
55
+ },
56
+ get canCancel() {
57
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
58
+ return getParent(self).readyToDisplay;
59
+ },
60
+ get fileName() {
61
+ return (self.fileSource.uri ||
62
+ self.fileSource.localPath ||
63
+ (self.fileSource.blobId && self.fileSource.name));
64
+ },
65
+ get requiresUnzip() {
66
+ return this.fileName.endsWith('gz');
67
+ },
68
+ isValidRefName(refName, assemblyName) {
69
+ const { assemblyManager } = getSession(self);
70
+ if (!assemblyName) {
71
+ return false;
72
+ }
73
+ return assemblyManager.isValidRefName(refName, assemblyName);
74
+ },
75
+ }))
76
+ .actions(self => ({
77
+ setSelectedAssemblyName(s) {
78
+ self.selectedAssemblyName = s;
79
+ },
80
+ setFileSource(newSource) {
81
+ self.fileSource = newSource;
82
+ self.error = undefined;
83
+ if (self.fileSource) {
84
+ // try to autodetect the file type, ignore errors
85
+ const name = self.fileName;
86
+ if (name) {
87
+ const match = fileTypesRegexp.exec(name);
88
+ if (match && match[1]) {
89
+ self.fileType =
90
+ match[1] === 'tsv' && name.includes('star-fusion')
91
+ ? 'STAR-Fusion'
92
+ : match[1].toUpperCase();
93
+ }
94
+ }
95
+ }
96
+ },
97
+ toggleHasColumnNameLine() {
98
+ self.hasColumnNameLine = !self.hasColumnNameLine;
99
+ },
100
+ setColumnNameLineNumber(newnumber) {
101
+ if (newnumber > 0) {
102
+ self.columnNameLineNumber = newnumber;
103
+ }
104
+ },
105
+ setFileType(typeName) {
106
+ self.fileType = typeName;
107
+ },
108
+ setError(error) {
109
+ console.error(error);
110
+ self.loading = false;
111
+ self.error = error;
112
+ },
113
+ setLoaded() {
114
+ self.loading = false;
115
+ self.error = undefined;
116
+ },
117
+ cancelButton() {
118
+ self.error = undefined;
119
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
120
+ getParent(self).setDisplayMode();
121
+ },
122
+ // fetch and parse the file, make a new Spreadsheet model for it,
123
+ // then set the parent to display it
124
+ async import(assemblyName) {
125
+ if (!self.fileSource) {
126
+ return;
127
+ }
128
+ if (self.loading) {
129
+ throw new Error('Cannot import, load already in progress');
130
+ }
131
+ self.selectedAssemblyName = assemblyName;
132
+ self.loading = true;
133
+ const type = self.fileType;
134
+ const typeParser = await fileTypeParsers[type]();
135
+ if (!typeParser) {
136
+ throw new Error(`cannot open files of type '${self.fileType}'`);
137
+ }
138
+ const { unzip } = await import('@gmod/bgzf-filehandle');
139
+ const { pluginManager } = getEnv(self);
140
+ const filehandle = openLocation(self.fileSource, pluginManager);
141
+ try {
142
+ const stat = await filehandle.stat();
143
+ if (stat.size > IMPORT_SIZE_LIMIT) {
144
+ throw new Error(`File is too big. Tabular files are limited to at most ${(IMPORT_SIZE_LIMIT / 1000).toLocaleString()}kb.`);
145
+ }
146
+ }
147
+ catch (e) {
148
+ // not required for stat to succeed to proceed, but it is helpful
149
+ console.warn(e);
150
+ }
151
+ try {
152
+ await filehandle
153
+ .readFile()
154
+ .then(buffer => (self.requiresUnzip ? unzip(buffer) : buffer))
155
+ .then(buffer => typeParser(buffer, self))
156
+ .then(spreadsheet => {
157
+ this.setLoaded();
158
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
159
+ getParent(self).displaySpreadsheet(spreadsheet);
160
+ });
161
+ }
162
+ catch (e) {
163
+ this.setError(e);
164
+ }
165
+ },
166
+ }));
167
+ export default ImportWizard;
168
+ //# sourceMappingURL=ImportWizard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ImportWizard.js","sourceRoot":"","sources":["../../../src/SpreadsheetView/models/ImportWizard.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,SAAS,EAAY,MAAM,iBAAiB,CAAA;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAA;AACpD,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAA;AAEvD,OAAO;AACP,MAAM,iBAAiB,GAAG,QAAU,CAAA;AAEpC,MAAM,SAAS,GAAG,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,aAAa,CAAC,CAAA;AACtE,MAAM,eAAe,GAAG;IACtB,GAAG,EAAE,GAAG,EAAE,CACR,MAAM,CAAC,+BAA+B,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,cAAc,CAAC;IACrE,GAAG,EAAE,GAAG,EAAE,CACR,MAAM,CAAC,+BAA+B,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,cAAc,CAAC;IACrE,GAAG,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,6BAA6B,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,cAAc,CAAC;IAC5E,GAAG,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,6BAA6B,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,cAAc,CAAC;IAC5E,KAAK,EAAE,GAAG,EAAE,CACV,MAAM,CAAC,6BAA6B,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,gBAAgB,CAAC;IACrE,aAAa,EAAE,GAAG,EAAE,CAClB,MAAM,CAAC,oCAAoC,CAAC,CAAC,IAAI,CAC/C,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,qBAAqB,CAC7B;CACJ,CAAA;AACD,yEAAyE;AACzE,MAAM,eAAe,GAAG,IAAI,MAAM,CAAC,OAAO,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,GAAG,CAAC,CAAA;AAE/E;;;GAGG;AACH,SAAS,CAAC,KAAI,CAAC,CAAC,wDAAwD;AAExE,MAAM,YAAY,GAAG,KAAK;KACvB,KAAK,CAAC,yBAAyB,EAAE;IAChC;;OAEG;IACH,QAAQ,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,WAAW,CAAC,SAAS,CAAC,EAAE,KAAK,CAAC;IAC7D;;OAEG;IACH,iBAAiB,EAAE,IAAI;IACvB;;OAEG;IACH,oBAAoB,EAAE,CAAC;IACvB;;OAEG;IACH,oBAAoB,EAAE,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC;CAChD,CAAC;KACD,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC;IACf,SAAS;IACT,8DAA8D;IAC9D,UAAU,EAAE,SAAgB;IAC5B,KAAK,EAAE,SAAoB;IAC3B,OAAO,EAAE,KAAK;CACf,CAAC,CAAC;KACF,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACd,IAAI,aAAa;QACf,OAAO,CACL,CAAC,IAAI,CAAC,KAAK;YACX,IAAI,CAAC,UAAU;YACf,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM;gBACrB,IAAI,CAAC,UAAU,CAAC,SAAS;gBACzB,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CACvB,CAAA;IACH,CAAC;IACD,IAAI,SAAS;QACX,8DAA8D;QAC9D,OAAO,SAAS,CAAM,IAAI,CAAC,CAAC,cAAc,CAAA;IAC5C,CAAC;IAED,IAAI,QAAQ;QACV,OAAO,CACL,IAAI,CAAC,UAAU,CAAC,GAAG;YACnB,IAAI,CAAC,UAAU,CAAC,SAAS;YACzB,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CACjD,CAAA;IACH,CAAC;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAA;IACrC,CAAC;IAED,cAAc,CAAC,OAAe,EAAE,YAAqB;QACnD,MAAM,EAAE,eAAe,EAAE,GAAG,UAAU,CAAC,IAAI,CAAC,CAAA;QAC5C,IAAI,CAAC,YAAY,EAAE;YACjB,OAAO,KAAK,CAAA;SACb;QACD,OAAO,eAAe,CAAC,cAAc,CAAC,OAAO,EAAE,YAAY,CAAC,CAAA;IAC9D,CAAC;CACF,CAAC,CAAC;KACF,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAChB,uBAAuB,CAAC,CAAS;QAC/B,IAAI,CAAC,oBAAoB,GAAG,CAAC,CAAA;IAC/B,CAAC;IACD,aAAa,CAAC,SAAkB;QAC9B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAA;QAC3B,IAAI,CAAC,KAAK,GAAG,SAAS,CAAA;QAEtB,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,iDAAiD;YACjD,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAA;YAE1B,IAAI,IAAI,EAAE;gBACR,MAAM,KAAK,GAAG,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;gBACxC,IAAI,KAAK,IAAI,KAAK,CAAC,CAAC,CAAC,EAAE;oBACrB,IAAI,CAAC,QAAQ;wBACX,KAAK,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC;4BAChD,CAAC,CAAC,aAAa;4BACf,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAA;iBAC7B;aACF;SACF;IACH,CAAC;IAED,uBAAuB;QACrB,IAAI,CAAC,iBAAiB,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAA;IAClD,CAAC;IAED,uBAAuB,CAAC,SAAiB;QACvC,IAAI,SAAS,GAAG,CAAC,EAAE;YACjB,IAAI,CAAC,oBAAoB,GAAG,SAAS,CAAA;SACtC;IACH,CAAC;IAED,WAAW,CAAC,QAAgB;QAC1B,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAA;IAC1B,CAAC;IAED,QAAQ,CAAC,KAAc;QACrB,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;QACpB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAA;QACpB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;IACpB,CAAC;IAED,SAAS;QACP,IAAI,CAAC,OAAO,GAAG,KAAK,CAAA;QACpB,IAAI,CAAC,KAAK,GAAG,SAAS,CAAA;IACxB,CAAC;IAED,YAAY;QACV,IAAI,CAAC,KAAK,GAAG,SAAS,CAAA;QACtB,8DAA8D;QAC9D,SAAS,CAAM,IAAI,CAAC,CAAC,cAAc,EAAE,CAAA;IACvC,CAAC;IAED,iEAAiE;IACjE,oCAAoC;IACpC,KAAK,CAAC,MAAM,CAAC,YAAoB;QAC/B,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YACpB,OAAM;SACP;QAED,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAA;SAC3D;QAED,IAAI,CAAC,oBAAoB,GAAG,YAAY,CAAA;QACxC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAA;QACnB,MAAM,IAAI,GAAG,IAAI,CAAC,QAAwC,CAAA;QAC1D,MAAM,UAAU,GAAG,MAAM,eAAe,CAAC,IAAI,CAAC,EAAE,CAAA;QAChD,IAAI,CAAC,UAAU,EAAE;YACf,MAAM,IAAI,KAAK,CAAC,8BAA8B,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAA;SAChE;QAED,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,MAAM,CAAC,uBAAuB,CAAC,CAAA;QACvD,MAAM,EAAE,aAAa,EAAE,GAAG,MAAM,CAAC,IAAI,CAAC,CAAA;QACtC,MAAM,UAAU,GAAG,YAAY,CAAC,IAAI,CAAC,UAAU,EAAE,aAAa,CAAC,CAAA;QAC/D,IAAI;YACF,MAAM,IAAI,GAAG,MAAM,UAAU,CAAC,IAAI,EAAE,CAAA;YACpC,IAAI,IAAI,CAAC,IAAI,GAAG,iBAAiB,EAAE;gBACjC,MAAM,IAAI,KAAK,CACb,yDAAyD,CACvD,iBAAiB,GAAG,IAAI,CACzB,CAAC,cAAc,EAAE,KAAK,CACxB,CAAA;aACF;SACF;QAAC,OAAO,CAAC,EAAE;YACV,iEAAiE;YACjE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;SAChB;QAED,IAAI;YACF,MAAM,UAAU;iBACb,QAAQ,EAAE;iBACV,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;iBAC7D,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,UAAU,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;iBACxC,IAAI,CAAC,WAAW,CAAC,EAAE;gBAClB,IAAI,CAAC,SAAS,EAAE,CAAA;gBAChB,8DAA8D;gBAC9D,SAAS,CAAM,IAAI,CAAC,CAAC,kBAAkB,CAAC,WAAW,CAAC,CAAA;YACtD,CAAC,CAAC,CAAA;SACL;QAAC,OAAO,CAAC,EAAE;YACV,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAA;SACjB;IACH,CAAC;CACF,CAAC,CAAC,CAAA;AAKL,eAAe,YAAY,CAAA"}
@@ -0,0 +1,17 @@
1
+ declare const RowModel: import("mobx-state-tree").IModelType<{
2
+ id: import("mobx-state-tree").ISimpleType<string>;
3
+ cells: import("mobx-state-tree").IArrayType<import("mobx-state-tree").IModelType<{
4
+ text: import("mobx-state-tree").ISimpleType<string>;
5
+ extendedData: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IType<any, any, any>>;
6
+ }, {}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>;
7
+ extendedData: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IType<any, any, any>>;
8
+ isSelected: import("mobx-state-tree").IType<boolean | undefined, boolean, boolean>;
9
+ }, {
10
+ toggleSelect(): void;
11
+ unSelect(): void;
12
+ select(): void;
13
+ setExtendedData(data: unknown): void;
14
+ } & {
15
+ readonly cellsWithDerived: any;
16
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>;
17
+ export default RowModel;
@@ -0,0 +1,44 @@
1
+ import { types, getParent } from 'mobx-state-tree';
2
+ const CellModel = types.model('SpreadsheetCell', {
3
+ text: types.string,
4
+ extendedData: types.maybe(types.frozen()),
5
+ });
6
+ const RowModel = types
7
+ .model('SpreadsheetRow', {
8
+ id: types.identifier,
9
+ cells: types.array(CellModel),
10
+ extendedData: types.maybe(types.frozen()),
11
+ isSelected: false,
12
+ })
13
+ .actions(self => ({
14
+ toggleSelect() {
15
+ self.isSelected = !self.isSelected;
16
+ },
17
+ unSelect() {
18
+ self.isSelected = false;
19
+ },
20
+ select() {
21
+ self.isSelected = true;
22
+ },
23
+ setExtendedData(data) {
24
+ self.extendedData = data;
25
+ },
26
+ }))
27
+ .views(self => ({
28
+ get cellsWithDerived() {
29
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
30
+ const { columns } = getParent(self, 3);
31
+ let i = 0;
32
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
33
+ return columns.map((column) => {
34
+ if (column.isDerived) {
35
+ return column.expr.evalSync({
36
+ row: self,
37
+ });
38
+ }
39
+ return self.cells[i++];
40
+ });
41
+ },
42
+ }));
43
+ export default RowModel;
44
+ //# sourceMappingURL=Row.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Row.js","sourceRoot":"","sources":["../../../src/SpreadsheetView/models/Row.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAA;AAElD,MAAM,SAAS,GAAG,KAAK,CAAC,KAAK,CAAC,iBAAiB,EAAE;IAC/C,IAAI,EAAE,KAAK,CAAC,MAAM;IAClB,YAAY,EAAE,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;CAC1C,CAAC,CAAA;AAEF,MAAM,QAAQ,GAAG,KAAK;KACnB,KAAK,CAAC,gBAAgB,EAAE;IACvB,EAAE,EAAE,KAAK,CAAC,UAAU;IACpB,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC;IAC7B,YAAY,EAAE,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;IACzC,UAAU,EAAE,KAAK;CAClB,CAAC;KACD,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAChB,YAAY;QACV,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,UAAU,CAAA;IACpC,CAAC;IACD,QAAQ;QACN,IAAI,CAAC,UAAU,GAAG,KAAK,CAAA;IACzB,CAAC;IACD,MAAM;QACJ,IAAI,CAAC,UAAU,GAAG,IAAI,CAAA;IACxB,CAAC;IACD,eAAe,CAAC,IAAa;QAC3B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAA;IAC1B,CAAC;CACF,CAAC,CAAC;KACF,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACd,IAAI,gBAAgB;QAClB,8DAA8D;QAC9D,MAAM,EAAE,OAAO,EAAE,GAAG,SAAS,CAAM,IAAI,EAAE,CAAC,CAAC,CAAA;QAC3C,IAAI,CAAC,GAAG,CAAC,CAAA;QACT,8DAA8D;QAC9D,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,MAAyC,EAAE,EAAE;YAC/D,IAAI,MAAM,CAAC,SAAS,EAAE;gBACpB,OAAO,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC;oBAC1B,GAAG,EAAE,IAAI;iBACV,CAAC,CAAA;aACH;YACD,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAA;QACxB,CAAC,CAAC,CAAA;IACJ,CAAC;CACF,CAAC,CAAC,CAAA;AAEL,eAAe,QAAQ,CAAA"}
@@ -0,0 +1,256 @@
1
+ /// <reference types="react" />
2
+ import { SnapshotIn, Instance } from 'mobx-state-tree';
3
+ import RowModel from './Row';
4
+ type Row = Instance<typeof RowModel>;
5
+ type RowMenuPosition = {
6
+ anchorEl: Element;
7
+ rowNumber: string;
8
+ } | null;
9
+ declare const Spreadsheet: import("mobx-state-tree").IModelType<{
10
+ rowSet: import("mobx-state-tree").IOptionalIType<import("mobx-state-tree").IModelType<{
11
+ isLoaded: import("mobx-state-tree").ISimpleType<true>;
12
+ rows: import("mobx-state-tree").IArrayType<import("mobx-state-tree").IModelType<{
13
+ id: import("mobx-state-tree").ISimpleType<string>;
14
+ cells: import("mobx-state-tree").IArrayType<import("mobx-state-tree").IModelType<{
15
+ text: import("mobx-state-tree").ISimpleType<string>;
16
+ extendedData: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IType<any, any, any>>;
17
+ }, {}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>;
18
+ extendedData: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IType<any, any, any>>;
19
+ isSelected: import("mobx-state-tree").IType<boolean | undefined, boolean, boolean>;
20
+ }, {
21
+ toggleSelect(): void;
22
+ unSelect(): void;
23
+ select(): void;
24
+ setExtendedData(data: unknown): void;
25
+ } & {
26
+ readonly cellsWithDerived: any;
27
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>;
28
+ }, {
29
+ readonly count: number;
30
+ readonly passingFiltersCount: number;
31
+ readonly selectedCount: number;
32
+ readonly selectedAndPassingFiltersCount: number;
33
+ readonly sortedRows: ({
34
+ id: string;
35
+ cells: import("mobx-state-tree").IMSTArray<import("mobx-state-tree").IModelType<{
36
+ text: import("mobx-state-tree").ISimpleType<string>;
37
+ extendedData: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IType<any, any, any>>;
38
+ }, {}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>> & import("mobx-state-tree").IStateTreeNode<import("mobx-state-tree").IArrayType<import("mobx-state-tree").IModelType<{
39
+ text: import("mobx-state-tree").ISimpleType<string>;
40
+ extendedData: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IType<any, any, any>>;
41
+ }, {}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>>;
42
+ extendedData: any;
43
+ isSelected: boolean;
44
+ } & import("mobx-state-tree/dist/internal").NonEmptyObject & {
45
+ toggleSelect(): void;
46
+ unSelect(): void;
47
+ select(): void;
48
+ setExtendedData(data: unknown): void;
49
+ } & {
50
+ readonly cellsWithDerived: any;
51
+ } & import("mobx-state-tree").IStateTreeNode<import("mobx-state-tree").IModelType<{
52
+ id: import("mobx-state-tree").ISimpleType<string>;
53
+ cells: import("mobx-state-tree").IArrayType<import("mobx-state-tree").IModelType<{
54
+ text: import("mobx-state-tree").ISimpleType<string>;
55
+ extendedData: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IType<any, any, any>>;
56
+ }, {}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>;
57
+ extendedData: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IType<any, any, any>>;
58
+ isSelected: import("mobx-state-tree").IType<boolean | undefined, boolean, boolean>;
59
+ }, {
60
+ toggleSelect(): void;
61
+ unSelect(): void;
62
+ select(): void;
63
+ setExtendedData(data: unknown): void;
64
+ } & {
65
+ readonly cellsWithDerived: any;
66
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>)[];
67
+ readonly selectedRows: ({
68
+ id: string;
69
+ cells: import("mobx-state-tree").IMSTArray<import("mobx-state-tree").IModelType<{
70
+ text: import("mobx-state-tree").ISimpleType<string>;
71
+ extendedData: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IType<any, any, any>>;
72
+ }, {}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>> & import("mobx-state-tree").IStateTreeNode<import("mobx-state-tree").IArrayType<import("mobx-state-tree").IModelType<{
73
+ text: import("mobx-state-tree").ISimpleType<string>;
74
+ extendedData: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IType<any, any, any>>;
75
+ }, {}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>>;
76
+ extendedData: any;
77
+ isSelected: boolean;
78
+ } & import("mobx-state-tree/dist/internal").NonEmptyObject & {
79
+ toggleSelect(): void;
80
+ unSelect(): void;
81
+ select(): void;
82
+ setExtendedData(data: unknown): void;
83
+ } & {
84
+ readonly cellsWithDerived: any;
85
+ } & import("mobx-state-tree").IStateTreeNode<import("mobx-state-tree").IModelType<{
86
+ id: import("mobx-state-tree").ISimpleType<string>;
87
+ cells: import("mobx-state-tree").IArrayType<import("mobx-state-tree").IModelType<{
88
+ text: import("mobx-state-tree").ISimpleType<string>;
89
+ extendedData: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IType<any, any, any>>;
90
+ }, {}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>;
91
+ extendedData: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IType<any, any, any>>;
92
+ isSelected: import("mobx-state-tree").IType<boolean | undefined, boolean, boolean>;
93
+ }, {
94
+ toggleSelect(): void;
95
+ unSelect(): void;
96
+ select(): void;
97
+ setExtendedData(data: unknown): void;
98
+ } & {
99
+ readonly cellsWithDerived: any;
100
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>)[];
101
+ readonly selectedFilteredRows: ({
102
+ id: string;
103
+ cells: import("mobx-state-tree").IMSTArray<import("mobx-state-tree").IModelType<{
104
+ text: import("mobx-state-tree").ISimpleType<string>;
105
+ extendedData: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IType<any, any, any>>;
106
+ }, {}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>> & import("mobx-state-tree").IStateTreeNode<import("mobx-state-tree").IArrayType<import("mobx-state-tree").IModelType<{
107
+ text: import("mobx-state-tree").ISimpleType<string>;
108
+ extendedData: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IType<any, any, any>>;
109
+ }, {}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>>;
110
+ extendedData: any;
111
+ isSelected: boolean;
112
+ } & import("mobx-state-tree/dist/internal").NonEmptyObject & {
113
+ toggleSelect(): void;
114
+ unSelect(): void;
115
+ select(): void;
116
+ setExtendedData(data: unknown): void;
117
+ } & {
118
+ readonly cellsWithDerived: any;
119
+ } & import("mobx-state-tree").IStateTreeNode<import("mobx-state-tree").IModelType<{
120
+ id: import("mobx-state-tree").ISimpleType<string>;
121
+ cells: import("mobx-state-tree").IArrayType<import("mobx-state-tree").IModelType<{
122
+ text: import("mobx-state-tree").ISimpleType<string>;
123
+ extendedData: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IType<any, any, any>>;
124
+ }, {}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>;
125
+ extendedData: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IType<any, any, any>>;
126
+ isSelected: import("mobx-state-tree").IType<boolean | undefined, boolean, boolean>;
127
+ }, {
128
+ toggleSelect(): void;
129
+ unSelect(): void;
130
+ select(): void;
131
+ setExtendedData(data: unknown): void;
132
+ } & {
133
+ readonly cellsWithDerived: any;
134
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>)[];
135
+ readonly sortedFilteredRows: ({
136
+ id: string;
137
+ cells: import("mobx-state-tree").IMSTArray<import("mobx-state-tree").IModelType<{
138
+ text: import("mobx-state-tree").ISimpleType<string>;
139
+ extendedData: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IType<any, any, any>>;
140
+ }, {}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>> & import("mobx-state-tree").IStateTreeNode<import("mobx-state-tree").IArrayType<import("mobx-state-tree").IModelType<{
141
+ text: import("mobx-state-tree").ISimpleType<string>;
142
+ extendedData: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IType<any, any, any>>;
143
+ }, {}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>>;
144
+ extendedData: any;
145
+ isSelected: boolean;
146
+ } & import("mobx-state-tree/dist/internal").NonEmptyObject & {
147
+ toggleSelect(): void;
148
+ unSelect(): void;
149
+ select(): void;
150
+ setExtendedData(data: unknown): void;
151
+ } & {
152
+ readonly cellsWithDerived: any;
153
+ } & import("mobx-state-tree").IStateTreeNode<import("mobx-state-tree").IModelType<{
154
+ id: import("mobx-state-tree").ISimpleType<string>;
155
+ cells: import("mobx-state-tree").IArrayType<import("mobx-state-tree").IModelType<{
156
+ text: import("mobx-state-tree").ISimpleType<string>;
157
+ extendedData: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IType<any, any, any>>;
158
+ }, {}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>;
159
+ extendedData: import("mobx-state-tree").IMaybe<import("mobx-state-tree").IType<any, any, any>>;
160
+ isSelected: import("mobx-state-tree").IType<boolean | undefined, boolean, boolean>;
161
+ }, {
162
+ toggleSelect(): void;
163
+ unSelect(): void;
164
+ select(): void;
165
+ setExtendedData(data: unknown): void;
166
+ } & {
167
+ readonly cellsWithDerived: any;
168
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>)[]; /**
169
+ * #property
170
+ */
171
+ } & {
172
+ unselectAll(): void;
173
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>, [undefined]>;
174
+ columns: import("mobx-state-tree").IArrayType<import("mobx-state-tree").IModelType<{
175
+ name: import("mobx-state-tree").IMaybe<import("mobx-state-tree").ISimpleType<string>>;
176
+ dataType: import("mobx-state-tree").IOptionalIType<import("mobx-state-tree").IAnyType, [undefined]>;
177
+ isDerived: import("mobx-state-tree").IType<boolean | undefined, boolean, boolean>;
178
+ derivationFunctionText: import("mobx-state-tree").IMaybe<import("mobx-state-tree").ISimpleType<string>>;
179
+ }, {
180
+ readonly expr: any;
181
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>;
182
+ columnDisplayOrder: import("mobx-state-tree").IArrayType<import("mobx-state-tree").ISimpleType<number>>;
183
+ hasColumnNames: import("mobx-state-tree").IType<boolean | undefined, boolean, boolean>;
184
+ sortColumns: import("mobx-state-tree").IArrayType<import("mobx-state-tree").IModelType<{
185
+ columnNumber: import("mobx-state-tree").ISimpleType<number>;
186
+ descending: import("mobx-state-tree").IType<boolean | undefined, boolean, boolean>;
187
+ }, {
188
+ switchDirection(): void;
189
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>;
190
+ assemblyName: import("mobx-state-tree").IMaybe<import("mobx-state-tree").ISimpleType<string>>;
191
+ }, {
192
+ defaultDataType: import("mobx-state-tree").IModelType<{
193
+ type: import("mobx-state-tree").ISimpleType<string>;
194
+ }, {
195
+ DataCellReactComponent: import("react").FC<any> | null;
196
+ FilterModelType: any;
197
+ displayName: string;
198
+ categoryName: string | undefined;
199
+ } & {
200
+ compare: any;
201
+ readonly hasFilter: boolean;
202
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>;
203
+ rowMenuPosition: RowMenuPosition;
204
+ isLoaded: boolean;
205
+ } & {
206
+ /**
207
+ * #getter
208
+ */
209
+ readonly initialized: boolean | undefined;
210
+ /**
211
+ * #getter
212
+ */
213
+ readonly hideRowSelection: any;
214
+ /**
215
+ * #getter
216
+ * list of data type names to be made available in the column
217
+ * dropdown menu
218
+ */
219
+ readonly dataTypeChoices: {
220
+ typeName: "LocString" | "Text" | "LocRef" | "Number" | "LocStart" | "LocEnd";
221
+ displayName: string;
222
+ categoryName: string | undefined;
223
+ }[];
224
+ /**
225
+ * #method
226
+ */
227
+ rowSortingComparisonFunction(rowA: Row, rowB: Row): any;
228
+ } & {
229
+ afterAttach(): void;
230
+ /**
231
+ * #action
232
+ */
233
+ setLoaded(flag: boolean): void;
234
+ /**
235
+ * #action
236
+ */
237
+ setRowMenuPosition(newPosition: RowMenuPosition): void;
238
+ /**
239
+ * #action
240
+ */
241
+ setSortColumns(newSort: readonly import("mobx-state-tree").ModelCreationType<import("mobx-state-tree/dist/internal").ExtractCFromProps<{
242
+ columnNumber: import("mobx-state-tree").ISimpleType<number>;
243
+ descending: import("mobx-state-tree").IType<boolean | undefined, boolean, boolean>;
244
+ }>>[]): void;
245
+ /**
246
+ * #action
247
+ */
248
+ setColumnType(columnNumber: number, newTypeName: string): void;
249
+ /**
250
+ * #action
251
+ */
252
+ unselectAll(): void;
253
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>;
254
+ export type SpreadsheetStateModel = typeof Spreadsheet;
255
+ export type SpreadsheetModel = Instance<SpreadsheetStateModel>;
256
+ export default Spreadsheet;
@@ -0,0 +1,171 @@
1
+ import { stringToJexlExpression } from '@jbrowse/core/util/jexlStrings';
2
+ import { getSession, getEnv } from '@jbrowse/core/util';
3
+ import { autorun } from 'mobx';
4
+ import { addDisposer, types, getParent, } from 'mobx-state-tree';
5
+ // locals
6
+ import { ColumnTypes, AnyColumnType } from './ColumnDataTypes';
7
+ import StaticRowSetModel from './StaticRowSet';
8
+ const ColumnDefinition = types
9
+ .model('ColumnDefinition', {
10
+ name: types.maybe(types.string),
11
+ dataType: types.optional(AnyColumnType, () => ({
12
+ type: 'Text',
13
+ })),
14
+ // set to true if column is derived from other columns
15
+ // if the column is derived, each cell will have a
16
+ // `derivationFunction` that is called to get its value
17
+ isDerived: false,
18
+ // if this cell is derived from other cells, execute this function to get
19
+ // the value
20
+ derivationFunctionText: types.maybe(types.string),
21
+ })
22
+ .views(self => ({
23
+ get expr() {
24
+ if (self.isDerived) {
25
+ // compile this as a jexl expression
26
+ return stringToJexlExpression(String(self.derivationFunctionText), getEnv(self).pluginManager.jexl);
27
+ }
28
+ return undefined;
29
+ },
30
+ }));
31
+ /**
32
+ * #stateModel SpreadsheetViewSpreadsheet
33
+ * #category view
34
+ */
35
+ function x() { } // eslint-disable-line @typescript-eslint/no-unused-vars
36
+ const Spreadsheet = types
37
+ .model('Spreadsheet', {
38
+ /**
39
+ * #property
40
+ */
41
+ rowSet: types.optional(StaticRowSetModel, () => StaticRowSetModel.create()),
42
+ /**
43
+ * #property
44
+ */
45
+ columns: types.array(ColumnDefinition),
46
+ /**
47
+ * #property
48
+ */
49
+ columnDisplayOrder: types.array(types.number),
50
+ /**
51
+ * #property
52
+ */
53
+ hasColumnNames: false,
54
+ /**
55
+ * #property
56
+ */
57
+ sortColumns: types.array(types
58
+ .model('SortColumns', {
59
+ columnNumber: types.number,
60
+ descending: false,
61
+ })
62
+ .actions(self => ({
63
+ switchDirection() {
64
+ self.descending = !self.descending;
65
+ },
66
+ }))),
67
+ assemblyName: types.maybe(types.string),
68
+ })
69
+ .volatile(() => ({
70
+ defaultDataType: ColumnTypes.Text,
71
+ rowMenuPosition: null,
72
+ isLoaded: false,
73
+ }))
74
+ .views(self => ({
75
+ /**
76
+ * #getter
77
+ */
78
+ get initialized() {
79
+ var _a;
80
+ const session = getSession(self);
81
+ const name = self.assemblyName;
82
+ return name ? (_a = session.assemblyManager.get(name)) === null || _a === void 0 ? void 0 : _a.initialized : false;
83
+ },
84
+ /**
85
+ * #getter
86
+ */
87
+ get hideRowSelection() {
88
+ // just delegates to parent
89
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
90
+ return getParent(self).hideRowSelection;
91
+ },
92
+ /**
93
+ * #getter
94
+ * list of data type names to be made available in the column
95
+ * dropdown menu
96
+ */
97
+ get dataTypeChoices() {
98
+ const typeNames = Object.keys(ColumnTypes);
99
+ return typeNames.map(typeName => {
100
+ const dataType = ColumnTypes[typeName].create({ type: typeName });
101
+ const { displayName, categoryName } = dataType;
102
+ return { typeName, displayName, categoryName };
103
+ });
104
+ },
105
+ /**
106
+ * #method
107
+ */
108
+ rowSortingComparisonFunction(rowA, rowB) {
109
+ for (let i = 0; i < self.sortColumns.length; i += 1) {
110
+ const { columnNumber, descending } = self.sortColumns[i];
111
+ const { dataType } = self.columns[columnNumber];
112
+ const result = dataType.compare(rowA.cellsWithDerived[columnNumber], rowB.cellsWithDerived[columnNumber]);
113
+ if (result) {
114
+ return descending ? -result : result;
115
+ }
116
+ }
117
+ return 0;
118
+ },
119
+ }))
120
+ .actions(self => ({
121
+ afterAttach() {
122
+ addDisposer(self, autorun(async () => {
123
+ const session = getSession(self);
124
+ const { assemblyManager } = session;
125
+ try {
126
+ if (self.assemblyName) {
127
+ await assemblyManager.waitForAssembly(self.assemblyName);
128
+ this.setLoaded(true);
129
+ }
130
+ }
131
+ catch (error) {
132
+ session.notify(`failed to load assembly ${self.assemblyName} ${error}`, 'error');
133
+ }
134
+ }));
135
+ },
136
+ /**
137
+ * #action
138
+ */
139
+ setLoaded(flag) {
140
+ self.isLoaded = flag;
141
+ },
142
+ /**
143
+ * #action
144
+ */
145
+ setRowMenuPosition(newPosition) {
146
+ self.rowMenuPosition = newPosition;
147
+ },
148
+ /**
149
+ * #action
150
+ */
151
+ setSortColumns(newSort) {
152
+ if (newSort) {
153
+ // @ts-expect-error
154
+ self.sortColumns = newSort;
155
+ }
156
+ },
157
+ /**
158
+ * #action
159
+ */
160
+ setColumnType(columnNumber, newTypeName) {
161
+ self.columns[columnNumber].dataType = { type: newTypeName };
162
+ },
163
+ /**
164
+ * #action
165
+ */
166
+ unselectAll() {
167
+ return self.rowSet.unselectAll();
168
+ },
169
+ }));
170
+ export default Spreadsheet;
171
+ //# sourceMappingURL=Spreadsheet.js.map