jbrowse-plugin-mafviewer 1.0.6 → 1.1.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 (154) hide show
  1. package/README.md +71 -22
  2. package/dist/BgzipTaffyAdapter/BgzipTaffyAdapter.d.ts +20 -0
  3. package/dist/BgzipTaffyAdapter/BgzipTaffyAdapter.js +197 -0
  4. package/dist/BgzipTaffyAdapter/BgzipTaffyAdapter.js.map +1 -0
  5. package/dist/BgzipTaffyAdapter/configSchema.d.ts +44 -0
  6. package/dist/BgzipTaffyAdapter/configSchema.js +53 -0
  7. package/dist/BgzipTaffyAdapter/configSchema.js.map +1 -0
  8. package/dist/BgzipTaffyAdapter/index.d.ts +2 -0
  9. package/dist/BgzipTaffyAdapter/index.js +11 -0
  10. package/dist/BgzipTaffyAdapter/index.js.map +1 -0
  11. package/dist/BgzipTaffyAdapter/rowInstructions.d.ts +35 -0
  12. package/dist/BgzipTaffyAdapter/rowInstructions.js +55 -0
  13. package/dist/BgzipTaffyAdapter/rowInstructions.js.map +1 -0
  14. package/dist/BgzipTaffyAdapter/types.d.ts +13 -0
  15. package/dist/BgzipTaffyAdapter/types.js +2 -0
  16. package/dist/BgzipTaffyAdapter/types.js.map +1 -0
  17. package/dist/BgzipTaffyAdapter/virtualOffset.d.ts +8 -0
  18. package/dist/BgzipTaffyAdapter/virtualOffset.js +23 -0
  19. package/dist/BgzipTaffyAdapter/virtualOffset.js.map +1 -0
  20. package/dist/BigMafAdapter/BigMafAdapter.d.ts +17 -0
  21. package/dist/BigMafAdapter/BigMafAdapter.js +92 -0
  22. package/dist/BigMafAdapter/BigMafAdapter.js.map +1 -0
  23. package/dist/BigMafAdapter/configSchema.d.ts +32 -0
  24. package/dist/BigMafAdapter/configSchema.js +39 -0
  25. package/dist/BigMafAdapter/configSchema.js.map +1 -0
  26. package/dist/BigMafAdapter/index.d.ts +2 -0
  27. package/dist/BigMafAdapter/index.js +11 -0
  28. package/dist/BigMafAdapter/index.js.map +1 -0
  29. package/dist/LinearMafDisplay/components/ColorLegend.d.ts +8 -0
  30. package/dist/LinearMafDisplay/components/ColorLegend.js +19 -0
  31. package/dist/LinearMafDisplay/components/ColorLegend.js.map +1 -0
  32. package/dist/LinearMafDisplay/components/ReactComponent.d.ts +6 -0
  33. package/dist/LinearMafDisplay/components/ReactComponent.js +50 -0
  34. package/dist/LinearMafDisplay/components/ReactComponent.js.map +1 -0
  35. package/dist/LinearMafDisplay/components/RectBg.d.ts +9 -0
  36. package/dist/LinearMafDisplay/components/RectBg.js +7 -0
  37. package/dist/LinearMafDisplay/components/RectBg.js.map +1 -0
  38. package/dist/LinearMafDisplay/components/SetRowHeight.d.ts +11 -0
  39. package/dist/LinearMafDisplay/components/SetRowHeight.js +36 -0
  40. package/dist/LinearMafDisplay/components/SetRowHeight.js.map +1 -0
  41. package/dist/LinearMafDisplay/components/SvgWrapper.d.ts +8 -0
  42. package/dist/LinearMafDisplay/components/SvgWrapper.js +21 -0
  43. package/dist/LinearMafDisplay/components/SvgWrapper.js.map +1 -0
  44. package/dist/LinearMafDisplay/components/Tree.d.ts +5 -0
  45. package/dist/LinearMafDisplay/components/Tree.js +22 -0
  46. package/dist/LinearMafDisplay/components/Tree.js.map +1 -0
  47. package/dist/LinearMafDisplay/components/YScaleBars.d.ts +8 -0
  48. package/dist/LinearMafDisplay/components/YScaleBars.js +20 -0
  49. package/dist/LinearMafDisplay/components/YScaleBars.js.map +1 -0
  50. package/dist/LinearMafDisplay/components/util.d.ts +1 -0
  51. package/dist/LinearMafDisplay/components/util.js +8 -0
  52. package/dist/LinearMafDisplay/components/util.js.map +1 -0
  53. package/dist/LinearMafDisplay/configSchema.d.ts +34 -0
  54. package/dist/LinearMafDisplay/configSchema.js +15 -0
  55. package/dist/LinearMafDisplay/configSchema.js.map +1 -0
  56. package/dist/LinearMafDisplay/index.d.ts +2 -0
  57. package/dist/LinearMafDisplay/index.js +20 -0
  58. package/dist/LinearMafDisplay/index.js.map +1 -0
  59. package/dist/LinearMafDisplay/renderSvg.d.ts +4 -0
  60. package/dist/LinearMafDisplay/renderSvg.js +18 -0
  61. package/dist/LinearMafDisplay/renderSvg.js.map +1 -0
  62. package/dist/LinearMafDisplay/stateModel.d.ts +426 -0
  63. package/dist/LinearMafDisplay/stateModel.js +276 -0
  64. package/dist/LinearMafDisplay/stateModel.js.map +1 -0
  65. package/dist/LinearMafDisplay/types.d.ts +17 -0
  66. package/dist/LinearMafDisplay/types.js +16 -0
  67. package/dist/LinearMafDisplay/types.js.map +1 -0
  68. package/dist/LinearMafRenderer/LinearMafRenderer.d.ts +45 -0
  69. package/dist/LinearMafRenderer/LinearMafRenderer.js +183 -0
  70. package/dist/LinearMafRenderer/LinearMafRenderer.js.map +1 -0
  71. package/dist/LinearMafRenderer/components/ReactComponent.d.ts +6 -0
  72. package/dist/LinearMafRenderer/components/ReactComponent.js +8 -0
  73. package/dist/LinearMafRenderer/components/ReactComponent.js.map +1 -0
  74. package/dist/LinearMafRenderer/configSchema.d.ts +2 -0
  75. package/dist/LinearMafRenderer/configSchema.js +13 -0
  76. package/dist/LinearMafRenderer/configSchema.js.map +1 -0
  77. package/dist/LinearMafRenderer/index.d.ts +2 -0
  78. package/dist/LinearMafRenderer/index.js +12 -0
  79. package/dist/LinearMafRenderer/index.js.map +1 -0
  80. package/dist/LinearMafRenderer/util.d.ts +10 -0
  81. package/dist/LinearMafRenderer/util.js +16 -0
  82. package/dist/LinearMafRenderer/util.js.map +1 -0
  83. package/dist/MafAddTrackWorkflow/AddTrackWorkflow.d.ts +5 -0
  84. package/dist/MafAddTrackWorkflow/AddTrackWorkflow.js +128 -0
  85. package/dist/MafAddTrackWorkflow/AddTrackWorkflow.js.map +1 -0
  86. package/dist/MafAddTrackWorkflow/index.d.ts +2 -0
  87. package/dist/MafAddTrackWorkflow/index.js +12 -0
  88. package/dist/MafAddTrackWorkflow/index.js.map +1 -0
  89. package/dist/MafRPC/index.d.ts +16 -0
  90. package/dist/MafRPC/index.js +19 -0
  91. package/dist/MafRPC/index.js.map +1 -0
  92. package/dist/MafTabixAdapter/MafTabixAdapter.d.ts +25 -0
  93. package/dist/MafTabixAdapter/MafTabixAdapter.js +95 -0
  94. package/dist/MafTabixAdapter/MafTabixAdapter.js.map +1 -0
  95. package/dist/MafTabixAdapter/configSchema.d.ts +50 -0
  96. package/dist/MafTabixAdapter/configSchema.js +56 -0
  97. package/dist/MafTabixAdapter/configSchema.js.map +1 -0
  98. package/dist/MafTabixAdapter/index.d.ts +2 -0
  99. package/dist/MafTabixAdapter/index.js +11 -0
  100. package/dist/MafTabixAdapter/index.js.map +1 -0
  101. package/dist/MafTrack/configSchema.d.ts +79 -0
  102. package/dist/MafTrack/configSchema.js +15 -0
  103. package/dist/MafTrack/configSchema.js.map +1 -0
  104. package/dist/MafTrack/index.d.ts +2 -0
  105. package/dist/MafTrack/index.js +14 -0
  106. package/dist/MafTrack/index.js.map +1 -0
  107. package/dist/index.d.ts +8 -0
  108. package/dist/index.js +26 -0
  109. package/dist/index.js.map +1 -0
  110. package/dist/jbrowse-plugin-mafviewer.umd.production.min.js +65 -1
  111. package/dist/jbrowse-plugin-mafviewer.umd.production.min.js.map +7 -1
  112. package/dist/parseNewick.d.ts +60 -0
  113. package/dist/parseNewick.js +95 -0
  114. package/dist/parseNewick.js.map +1 -0
  115. package/dist/util.d.ts +9 -0
  116. package/dist/util.js +9 -0
  117. package/dist/util.js.map +1 -0
  118. package/package.json +37 -41
  119. package/src/BgzipTaffyAdapter/BgzipTaffyAdapter.ts +227 -0
  120. package/src/BgzipTaffyAdapter/configSchema.ts +59 -0
  121. package/src/BgzipTaffyAdapter/index.ts +16 -0
  122. package/src/BgzipTaffyAdapter/rowInstructions.ts +91 -0
  123. package/src/BgzipTaffyAdapter/types.ts +16 -0
  124. package/src/BgzipTaffyAdapter/virtualOffset.ts +29 -0
  125. package/src/BigMafAdapter/BigMafAdapter.ts +12 -13
  126. package/src/BigMafAdapter/configSchema.ts +11 -0
  127. package/src/BigMafAdapter/index.ts +2 -1
  128. package/src/LinearMafDisplay/components/ColorLegend.tsx +38 -27
  129. package/src/LinearMafDisplay/components/ReactComponent.tsx +68 -3
  130. package/src/LinearMafDisplay/components/SetRowHeight.tsx +15 -8
  131. package/src/LinearMafDisplay/components/SvgWrapper.tsx +39 -0
  132. package/src/LinearMafDisplay/components/Tree.tsx +33 -0
  133. package/src/LinearMafDisplay/components/YScaleBars.tsx +11 -38
  134. package/src/LinearMafDisplay/components/util.ts +7 -0
  135. package/src/LinearMafDisplay/index.ts +2 -1
  136. package/src/LinearMafDisplay/renderSvg.tsx +2 -1
  137. package/src/LinearMafDisplay/stateModel.ts +169 -18
  138. package/src/LinearMafDisplay/types.ts +41 -0
  139. package/src/LinearMafRenderer/LinearMafRenderer.ts +51 -44
  140. package/src/LinearMafRenderer/components/ReactComponent.tsx +2 -1
  141. package/src/LinearMafRenderer/index.ts +2 -1
  142. package/src/LinearMafRenderer/util.ts +20 -0
  143. package/src/MafAddTrackWorkflow/AddTrackWorkflow.tsx +133 -51
  144. package/src/MafRPC/index.ts +39 -0
  145. package/src/MafTabixAdapter/MafTabixAdapter.ts +33 -27
  146. package/src/MafTabixAdapter/configSchema.ts +17 -1
  147. package/src/MafTabixAdapter/index.ts +2 -1
  148. package/src/MafTrack/index.ts +1 -0
  149. package/src/index.ts +6 -2
  150. package/src/parseNewick.ts +94 -0
  151. package/src/util.ts +11 -0
  152. package/LICENSE +0 -201
  153. package/dist/jbrowse-plugin-mafviewer.umd.development.js +0 -1439
  154. package/dist/jbrowse-plugin-mafviewer.umd.development.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"virtualOffset.js","sourceRoot":"","sources":["../../src/BgzipTaffyAdapter/virtualOffset.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,OAAO,OAAO,aAAa;IACzB,aAAa,CAAQ;IACrB,YAAY,CAAQ;IAC3B,YAAY,aAAqB,EAAE,YAAoB;QACrD,IAAI,CAAC,aAAa,GAAG,aAAa,CAAA,CAAC,wCAAwC;QAC3E,IAAI,CAAC,YAAY,GAAG,YAAY,CAAA,CAAC,sCAAsC;IACzE,CAAC;IAED,QAAQ;QACN,OAAO,GAAG,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,YAAY,EAAE,CAAA;IACrD,CAAC;IAED,SAAS,CAAC,CAAgB;QACxB,OAAO,CACL,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC,aAAa,IAAI,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,YAAY,CAC3E,CAAA;IACH,CAAC;CACF;AACD,MAAM,UAAU,SAAS,CAAC,KAAiB,EAAE,MAAM,GAAG,CAAC;IACrD,OAAO,IAAI,aAAa,CACtB,KAAK,CAAC,MAAM,GAAG,CAAC,CAAE,GAAG,aAAa;QAChC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAE,GAAG,WAAW;QAChC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAE,GAAG,SAAS;QAC9B,KAAK,CAAC,MAAM,GAAG,CAAC,CAAE,GAAG,OAAO;QAC5B,KAAK,CAAC,MAAM,GAAG,CAAC,CAAE,GAAG,KAAK;QAC1B,KAAK,CAAC,MAAM,GAAG,CAAC,CAAE,EACpB,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAE,IAAI,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAE,CAC3C,CAAA;AACH,CAAC"}
@@ -0,0 +1,17 @@
1
+ import { BaseFeatureDataAdapter } from '@jbrowse/core/data_adapters/BaseAdapter';
2
+ import { Feature, Region } from '@jbrowse/core/util';
3
+ export default class BigMafAdapter extends BaseFeatureDataAdapter {
4
+ setupP?: Promise<{
5
+ adapter: BaseFeatureDataAdapter;
6
+ }>;
7
+ setup(): Promise<{
8
+ adapter: BaseFeatureDataAdapter;
9
+ }>;
10
+ setupPre(): Promise<{
11
+ adapter: BaseFeatureDataAdapter;
12
+ }>;
13
+ getRefNames(): Promise<string[]>;
14
+ getHeader(): Promise<unknown>;
15
+ getFeatures(query: Region): import("rxjs").Observable<Feature>;
16
+ freeResources(): void;
17
+ }
@@ -0,0 +1,92 @@
1
+ import { BaseFeatureDataAdapter } from '@jbrowse/core/data_adapters/BaseAdapter';
2
+ import { SimpleFeature } from '@jbrowse/core/util';
3
+ import { ObservableCreate } from '@jbrowse/core/util/rxjs';
4
+ import { getSnapshot } from 'mobx-state-tree';
5
+ import { firstValueFrom, toArray } from 'rxjs';
6
+ export default class BigMafAdapter extends BaseFeatureDataAdapter {
7
+ setupP;
8
+ async setup() {
9
+ if (!this.getSubAdapter) {
10
+ throw new Error('no getSubAdapter available');
11
+ }
12
+ const adapter = await this.getSubAdapter({
13
+ ...getSnapshot(this.config),
14
+ type: 'BigBedAdapter',
15
+ });
16
+ return {
17
+ adapter: adapter.dataAdapter,
18
+ };
19
+ }
20
+ async setupPre() {
21
+ if (!this.setupP) {
22
+ this.setupP = this.setup().catch((e) => {
23
+ this.setupP = undefined;
24
+ throw e;
25
+ });
26
+ }
27
+ return this.setupP;
28
+ }
29
+ async getRefNames() {
30
+ const { adapter } = await this.setup();
31
+ return adapter.getRefNames();
32
+ }
33
+ async getHeader() {
34
+ const { adapter } = await this.setup();
35
+ return adapter.getHeader();
36
+ }
37
+ getFeatures(query) {
38
+ return ObservableCreate(async (observer) => {
39
+ const { adapter } = await this.setup();
40
+ const features = await firstValueFrom(adapter.getFeatures(query).pipe(toArray()));
41
+ for (const feature of features) {
42
+ const maf = feature.get('mafBlock');
43
+ const blocks = maf.split(';');
44
+ let aln;
45
+ const alns = [];
46
+ const alignments = {};
47
+ const blocks2 = [];
48
+ for (const block of blocks) {
49
+ if (block.startsWith('s')) {
50
+ if (aln) {
51
+ alns.push(block.split(/ +/)[6]);
52
+ blocks2.push(block);
53
+ }
54
+ else {
55
+ aln = block.split(/ +/)[6];
56
+ alns.push(aln);
57
+ blocks2.push(block);
58
+ }
59
+ }
60
+ }
61
+ for (let i = 0; i < blocks2.length; i++) {
62
+ const elt = blocks2[i];
63
+ const ad = elt.split(/ +/);
64
+ const y = ad[1].split('.');
65
+ const org = y[0];
66
+ const chr = y[1];
67
+ alignments[org] = {
68
+ chr: chr,
69
+ start: +ad[1],
70
+ srcSize: +ad[2],
71
+ strand: ad[3] === '+' ? 1 : -1,
72
+ unknown: +ad[4],
73
+ data: alns[i],
74
+ };
75
+ }
76
+ observer.next(new SimpleFeature({
77
+ id: feature.id(),
78
+ data: {
79
+ start: feature.get('start'),
80
+ end: feature.get('end'),
81
+ refName: feature.get('refName'),
82
+ seq: alns[0],
83
+ alignments: alignments,
84
+ },
85
+ }));
86
+ }
87
+ observer.complete();
88
+ });
89
+ }
90
+ freeResources() { }
91
+ }
92
+ //# sourceMappingURL=BigMafAdapter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BigMafAdapter.js","sourceRoot":"","sources":["../../src/BigMafAdapter/BigMafAdapter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,yCAAyC,CAAA;AAChF,OAAO,EAAmB,aAAa,EAAE,MAAM,oBAAoB,CAAA;AACnE,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAA;AAC1D,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAA;AAC7C,OAAO,EAAE,cAAc,EAAE,OAAO,EAAE,MAAM,MAAM,CAAA;AAU9C,MAAM,CAAC,OAAO,OAAO,aAAc,SAAQ,sBAAsB;IACxD,MAAM,CAA+C;IAE5D,KAAK,CAAC,KAAK;QACT,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;YACxB,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAA;QAC/C,CAAC;QACD,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,aAAa,CAAC;YACvC,GAAG,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC;YAC3B,IAAI,EAAE,eAAe;SACtB,CAAC,CAAA;QACF,OAAO;YACL,OAAO,EAAE,OAAO,CAAC,WAAqC;SACvD,CAAA;IACH,CAAC;IACD,KAAK,CAAC,QAAQ;QACZ,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YACjB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC,KAAK,CAAC,CAAC,CAAU,EAAE,EAAE;gBAC9C,IAAI,CAAC,MAAM,GAAG,SAAS,CAAA;gBACvB,MAAM,CAAC,CAAA;YACT,CAAC,CAAC,CAAA;QACJ,CAAC;QACD,OAAO,IAAI,CAAC,MAAM,CAAA;IACpB,CAAC;IAED,KAAK,CAAC,WAAW;QACf,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,EAAE,CAAA;QACtC,OAAO,OAAO,CAAC,WAAW,EAAE,CAAA;IAC9B,CAAC;IAED,KAAK,CAAC,SAAS;QACb,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,EAAE,CAAA;QACtC,OAAO,OAAO,CAAC,SAAS,EAAE,CAAA;IAC5B,CAAC;IAED,WAAW,CAAC,KAAa;QACvB,OAAO,gBAAgB,CAAU,KAAK,EAAC,QAAQ,EAAC,EAAE;YAChD,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,IAAI,CAAC,KAAK,EAAE,CAAA;YACtC,MAAM,QAAQ,GAAG,MAAM,cAAc,CACnC,OAAO,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAC3C,CAAA;YACD,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;gBAC/B,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,UAAU,CAAW,CAAA;gBAC7C,MAAM,MAAM,GAAG,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;gBAC7B,IAAI,GAAuB,CAAA;gBAC3B,MAAM,IAAI,GAAG,EAAc,CAAA;gBAC3B,MAAM,UAAU,GAAG,EAAoC,CAAA;gBACvD,MAAM,OAAO,GAAG,EAAc,CAAA;gBAC9B,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;oBAC3B,IAAI,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;wBAC1B,IAAI,GAAG,EAAE,CAAC;4BACR,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAE,CAAC,CAAA;4BAChC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;wBACrB,CAAC;6BAAM,CAAC;4BACN,GAAG,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAA;4BAC1B,IAAI,CAAC,IAAI,CAAC,GAAI,CAAC,CAAA;4BACf,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;wBACrB,CAAC;oBACH,CAAC;gBACH,CAAC;gBAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;oBACxC,MAAM,GAAG,GAAG,OAAO,CAAC,CAAC,CAAE,CAAA;oBACvB,MAAM,EAAE,GAAG,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;oBAC1B,MAAM,CAAC,GAAG,EAAE,CAAC,CAAC,CAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;oBAC3B,MAAM,GAAG,GAAG,CAAC,CAAC,CAAC,CAAE,CAAA;oBACjB,MAAM,GAAG,GAAG,CAAC,CAAC,CAAC,CAAE,CAAA;oBAEjB,UAAU,CAAC,GAAG,CAAC,GAAG;wBAChB,GAAG,EAAE,GAAG;wBACR,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC,CAAE;wBACd,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAE;wBAChB,MAAM,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;wBAC9B,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAE;wBAChB,IAAI,EAAE,IAAI,CAAC,CAAC,CAAE;qBACf,CAAA;gBACH,CAAC;gBACD,QAAQ,CAAC,IAAI,CACX,IAAI,aAAa,CAAC;oBAChB,EAAE,EAAE,OAAO,CAAC,EAAE,EAAE;oBAChB,IAAI,EAAE;wBACJ,KAAK,EAAE,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC;wBAC3B,GAAG,EAAE,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC;wBACvB,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC;wBAC/B,GAAG,EAAE,IAAI,CAAC,CAAC,CAAC;wBACZ,UAAU,EAAE,UAAU;qBACvB;iBACF,CAAC,CACH,CAAA;YACH,CAAC;YACD,QAAQ,CAAC,QAAQ,EAAE,CAAA;QACrB,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,aAAa,KAAU,CAAC;CACzB"}
@@ -0,0 +1,32 @@
1
+ declare const configSchema: import("@jbrowse/core/configuration/configurationSchema").ConfigurationSchemaType<{
2
+ /**
3
+ * #slot
4
+ */
5
+ samples: {
6
+ type: string;
7
+ description: string;
8
+ defaultValue: never[];
9
+ };
10
+ /**
11
+ * #slot
12
+ */
13
+ bigBedLocation: {
14
+ type: string;
15
+ defaultValue: {
16
+ uri: string;
17
+ locationType: string;
18
+ };
19
+ };
20
+ /**
21
+ * #slot
22
+ */
23
+ nhLocation: {
24
+ type: string;
25
+ description: string;
26
+ defaultValue: {
27
+ uri: string;
28
+ locationType: string;
29
+ };
30
+ };
31
+ }, import("@jbrowse/core/configuration/configurationSchema").ConfigurationSchemaOptions<undefined, undefined>>;
32
+ export default configSchema;
@@ -0,0 +1,39 @@
1
+ import { ConfigurationSchema } from '@jbrowse/core/configuration';
2
+ /**
3
+ * #config BigMafAdapter
4
+ * used to configure BigMaf adapter
5
+ */
6
+ function x() { } // eslint-disable-line @typescript-eslint/no-unused-vars
7
+ const configSchema = ConfigurationSchema('BigMafAdapter', {
8
+ /**
9
+ * #slot
10
+ */
11
+ samples: {
12
+ type: 'frozen',
13
+ description: 'string[] or {id:string,label:string,color?:string}[]',
14
+ defaultValue: [],
15
+ },
16
+ /**
17
+ * #slot
18
+ */
19
+ bigBedLocation: {
20
+ type: 'fileLocation',
21
+ defaultValue: {
22
+ uri: '/path/to/my.bb',
23
+ locationType: 'UriLocation',
24
+ },
25
+ },
26
+ /**
27
+ * #slot
28
+ */
29
+ nhLocation: {
30
+ type: 'fileLocation',
31
+ description: 'newick tree',
32
+ defaultValue: {
33
+ uri: '/path/to/my.nh',
34
+ locationType: 'UriLocation',
35
+ },
36
+ },
37
+ }, { explicitlyTyped: true });
38
+ export default configSchema;
39
+ //# sourceMappingURL=configSchema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"configSchema.js","sourceRoot":"","sources":["../../src/BigMafAdapter/configSchema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAA;AAEjE;;;GAGG;AACH,SAAS,CAAC,KAAI,CAAC,CAAC,wDAAwD;AAExE,MAAM,YAAY,GAAG,mBAAmB,CACtC,eAAe,EACf;IACE;;OAEG;IACH,OAAO,EAAE;QACP,IAAI,EAAE,QAAQ;QACd,WAAW,EAAE,sDAAsD;QACnE,YAAY,EAAE,EAAE;KACjB;IACD;;OAEG;IACH,cAAc,EAAE;QACd,IAAI,EAAE,cAAc;QACpB,YAAY,EAAE;YACZ,GAAG,EAAE,gBAAgB;YACrB,YAAY,EAAE,aAAa;SAC5B;KACF;IACD;;OAEG;IACH,UAAU,EAAE;QACV,IAAI,EAAE,cAAc;QACpB,WAAW,EAAE,aAAa;QAC1B,YAAY,EAAE;YACZ,GAAG,EAAE,gBAAgB;YACrB,YAAY,EAAE,aAAa;SAC5B;KACF;CACF,EACD,EAAE,eAAe,EAAE,IAAI,EAAE,CAC1B,CAAA;AAED,eAAe,YAAY,CAAA"}
@@ -0,0 +1,2 @@
1
+ import PluginManager from '@jbrowse/core/PluginManager';
2
+ export default function BigMafAdapterF(pluginManager: PluginManager): PluginManager;
@@ -0,0 +1,11 @@
1
+ import { AdapterType } from '@jbrowse/core/pluggableElementTypes';
2
+ import BigMafAdapter from './BigMafAdapter';
3
+ import configSchema from './configSchema';
4
+ export default function BigMafAdapterF(pluginManager) {
5
+ return pluginManager.addAdapterType(() => new AdapterType({
6
+ name: 'BigMafAdapter',
7
+ AdapterClass: BigMafAdapter,
8
+ configSchema,
9
+ }));
10
+ }
11
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/BigMafAdapter/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,qCAAqC,CAAA;AAEjE,OAAO,aAAa,MAAM,iBAAiB,CAAA;AAC3C,OAAO,YAAY,MAAM,gBAAgB,CAAA;AAEzC,MAAM,CAAC,OAAO,UAAU,cAAc,CAAC,aAA4B;IACjE,OAAO,aAAa,CAAC,cAAc,CACjC,GAAG,EAAE,CACH,IAAI,WAAW,CAAC;QACd,IAAI,EAAE,eAAe;QACrB,YAAY,EAAE,aAAa;QAC3B,YAAY;KACb,CAAC,CACL,CAAA;AACH,CAAC"}
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+ import { LinearMafDisplayModel } from '../stateModel';
3
+ declare const ColorLegend: ({ model, labelWidth, svgFontSize, }: {
4
+ model: LinearMafDisplayModel;
5
+ svgFontSize: number;
6
+ labelWidth: number;
7
+ }) => React.JSX.Element;
8
+ export default ColorLegend;
@@ -0,0 +1,19 @@
1
+ import React from 'react';
2
+ import { observer } from 'mobx-react';
3
+ import RectBg from './RectBg';
4
+ import Tree from './Tree';
5
+ const ColorLegend = observer(function ({ model, labelWidth, svgFontSize, }) {
6
+ const { totalHeight, treeWidth, samples, rowHeight } = model;
7
+ const canDisplayLabel = rowHeight >= 8;
8
+ const boxHeight = Math.min(20, rowHeight);
9
+ return (React.createElement(React.Fragment, null,
10
+ React.createElement(RectBg, { y: 0, x: 0, width: labelWidth + 5 + treeWidth, height: totalHeight }),
11
+ React.createElement(Tree, { model: model }),
12
+ React.createElement("g", { transform: `translate(${treeWidth + 5},0)` },
13
+ samples.map((sample, idx) => (React.createElement(RectBg, { key: `${sample.id}-${idx}`, y: idx * rowHeight, x: 0, width: labelWidth + 5, height: boxHeight, color: sample.color }))),
14
+ canDisplayLabel
15
+ ? samples.map((sample, idx) => (React.createElement("text", { key: `${sample.id}-${idx}`, y: idx * rowHeight + rowHeight / 2, dominantBaseline: "middle", x: 2, fontSize: svgFontSize }, sample.label)))
16
+ : null)));
17
+ });
18
+ export default ColorLegend;
19
+ //# sourceMappingURL=ColorLegend.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ColorLegend.js","sourceRoot":"","sources":["../../../src/LinearMafDisplay/components/ColorLegend.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAIrC,OAAO,MAAM,MAAM,UAAU,CAAA;AAC7B,OAAO,IAAI,MAAM,QAAQ,CAAA;AAEzB,MAAM,WAAW,GAAG,QAAQ,CAAC,UAAU,EACrC,KAAK,EACL,UAAU,EACV,WAAW,GAKZ;IACC,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,KAAK,CAAA;IAC5D,MAAM,eAAe,GAAG,SAAS,IAAI,CAAC,CAAA;IACtC,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,SAAS,CAAC,CAAA;IAEzC,OAAO,CACL;QACE,oBAAC,MAAM,IACL,CAAC,EAAE,CAAC,EACJ,CAAC,EAAE,CAAC,EACJ,KAAK,EAAE,UAAU,GAAG,CAAC,GAAG,SAAS,EACjC,MAAM,EAAE,WAAW,GACnB;QACF,oBAAC,IAAI,IAAC,KAAK,EAAE,KAAK,GAAI;QACtB,2BAAG,SAAS,EAAE,aAAa,SAAS,GAAG,CAAC,KAAK;YAC1C,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,GAAG,EAAE,EAAE,CAAC,CAC5B,oBAAC,MAAM,IACL,GAAG,EAAE,GAAG,MAAM,CAAC,EAAE,IAAI,GAAG,EAAE,EAC1B,CAAC,EAAE,GAAG,GAAG,SAAS,EAClB,CAAC,EAAE,CAAC,EACJ,KAAK,EAAE,UAAU,GAAG,CAAC,EACrB,MAAM,EAAE,SAAS,EACjB,KAAK,EAAE,MAAM,CAAC,KAAK,GACnB,CACH,CAAC;YACD,eAAe;gBACd,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,GAAG,EAAE,EAAE,CAAC,CAC3B,8BACE,GAAG,EAAE,GAAG,MAAM,CAAC,EAAE,IAAI,GAAG,EAAE,EAC1B,CAAC,EAAE,GAAG,GAAG,SAAS,GAAG,SAAS,GAAG,CAAC,EAClC,gBAAgB,EAAC,QAAQ,EACzB,CAAC,EAAE,CAAC,EACJ,QAAQ,EAAE,WAAW,IAEpB,MAAM,CAAC,KAAK,CACR,CACR,CAAC;gBACJ,CAAC,CAAC,IAAI,CACN,CACH,CACJ,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,eAAe,WAAW,CAAA"}
@@ -0,0 +1,6 @@
1
+ import React from 'react';
2
+ import { LinearMafDisplayModel } from '../stateModel';
3
+ declare const LinearMafDisplay: (props: {
4
+ model: LinearMafDisplayModel;
5
+ }) => React.JSX.Element;
6
+ export default LinearMafDisplay;
@@ -0,0 +1,50 @@
1
+ import React, { useRef, useState } from 'react';
2
+ import BaseTooltip from '@jbrowse/core/ui/BaseTooltip';
3
+ import SanitizedHTML from '@jbrowse/core/ui/SanitizedHTML';
4
+ import { getContainingView, getEnv } from '@jbrowse/core/util';
5
+ import { observer } from 'mobx-react';
6
+ import { makeStyles } from 'tss-react/mui';
7
+ import YScaleBars from './YScaleBars';
8
+ const useStyles = makeStyles()({
9
+ cursor: {
10
+ pointerEvents: 'none',
11
+ },
12
+ });
13
+ const LinearMafDisplay = observer(function (props) {
14
+ const { model } = props;
15
+ const { classes } = useStyles();
16
+ const { pluginManager } = getEnv(model);
17
+ const { rowHeight, height, scrollTop, samples: sources } = model;
18
+ const ref = useRef(null);
19
+ const LinearGenomePlugin = pluginManager.getPlugin('LinearGenomeViewPlugin');
20
+ const { BaseLinearDisplayComponent } = LinearGenomePlugin.exports;
21
+ const [mouseY, setMouseY] = useState();
22
+ const [mouseX, setMouseX] = useState();
23
+ const { width } = getContainingView(model);
24
+ return (React.createElement("div", { ref: ref, onMouseMove: event => {
25
+ const rect = ref.current?.getBoundingClientRect();
26
+ const top = rect?.top || 0;
27
+ const left = rect?.left || 0;
28
+ setMouseY(event.clientY - top);
29
+ setMouseX(event.clientX - left);
30
+ }, onMouseLeave: () => {
31
+ setMouseY(undefined);
32
+ setMouseX(undefined);
33
+ } },
34
+ React.createElement(BaseLinearDisplayComponent, { ...props }),
35
+ React.createElement(YScaleBars, { model: model }),
36
+ mouseY ? (React.createElement("div", { style: { position: 'relative' } },
37
+ React.createElement("svg", { className: classes.cursor, width: width, height: height, style: {
38
+ position: 'absolute',
39
+ top: scrollTop,
40
+ } },
41
+ React.createElement("line", { x1: 0, x2: width, y1: mouseY - scrollTop, y2: mouseY - scrollTop, stroke: "black" }),
42
+ React.createElement("line", { x1: mouseX, x2: mouseX, y1: 0, y2: height, stroke: "black" })),
43
+ React.createElement(BaseTooltip, null,
44
+ React.createElement(SanitizedHTML, { html: Object.entries(sources[Math.floor(mouseY / rowHeight)] || {})
45
+ .filter(([key]) => key !== 'color' && key !== 'id')
46
+ .map(([key, value]) => `${key}:${value}`)
47
+ .join('\n') })))) : null));
48
+ });
49
+ export default LinearMafDisplay;
50
+ //# sourceMappingURL=ReactComponent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ReactComponent.js","sourceRoot":"","sources":["../../../src/LinearMafDisplay/components/ReactComponent.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import React from 'react';
2
+ declare const RectBg: (props: {
3
+ x: number;
4
+ y: number;
5
+ width: number;
6
+ height: number;
7
+ color?: string;
8
+ }) => React.JSX.Element;
9
+ export default RectBg;
@@ -0,0 +1,7 @@
1
+ import React from 'react';
2
+ const RectBg = (props) => {
3
+ const { color = 'rgb(255,255,255,0.8)' } = props;
4
+ return React.createElement("rect", { ...props, fill: color });
5
+ };
6
+ export default RectBg;
7
+ //# sourceMappingURL=RectBg.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RectBg.js","sourceRoot":"","sources":["../../../src/LinearMafDisplay/components/RectBg.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,MAAM,MAAM,GAAG,CAAC,KAMf,EAAE,EAAE;IACH,MAAM,EAAE,KAAK,GAAG,sBAAsB,EAAE,GAAG,KAAK,CAAA;IAChD,OAAO,iCAAU,KAAK,EAAE,IAAI,EAAE,KAAK,GAAI,CAAA;AACzC,CAAC,CAAA;AAED,eAAe,MAAM,CAAA"}
@@ -0,0 +1,11 @@
1
+ import React from 'react';
2
+ declare const SetRowHeightDialog: (props: {
3
+ model: {
4
+ rowHeight?: number;
5
+ rowProportion?: number;
6
+ setRowHeight: (arg: number) => void;
7
+ setRowProportion: (arg: number) => void;
8
+ };
9
+ handleClose: () => void;
10
+ }) => React.JSX.Element;
11
+ export default SetRowHeightDialog;
@@ -0,0 +1,36 @@
1
+ import React, { useState } from 'react';
2
+ import { Dialog } from '@jbrowse/core/ui';
3
+ import { Button, DialogActions, DialogContent, TextField, Typography, } from '@mui/material';
4
+ import { observer } from 'mobx-react';
5
+ import { makeStyles } from 'tss-react/mui';
6
+ const useStyles = makeStyles()({
7
+ root: {
8
+ width: 500,
9
+ },
10
+ });
11
+ const SetRowHeightDialog = observer(function (props) {
12
+ const { model, handleClose } = props;
13
+ const { classes } = useStyles();
14
+ const [rowHeight, setRowHeight] = useState(`${model.rowHeight}`);
15
+ const [rowProportion, setRowProportion] = useState(`${model.rowProportion}`);
16
+ return (React.createElement(Dialog, { open: true, onClose: handleClose, title: "Set row height" },
17
+ React.createElement(DialogContent, { className: classes.root },
18
+ React.createElement(Typography, null, "Set row height and the proportion of the row height to use for drawing each row"),
19
+ React.createElement(TextField, { value: rowHeight, helperText: "Enter row height", onChange: event => {
20
+ setRowHeight(event.target.value);
21
+ } }),
22
+ React.createElement(TextField, { value: rowProportion, helperText: "Enter row proportion", onChange: event => {
23
+ setRowProportion(event.target.value);
24
+ } }),
25
+ React.createElement(DialogActions, null,
26
+ React.createElement(Button, { variant: "contained", color: "primary", type: "submit", autoFocus: true, onClick: () => {
27
+ model.setRowProportion(+rowProportion);
28
+ model.setRowHeight(+rowHeight);
29
+ handleClose();
30
+ } }, "Submit"),
31
+ React.createElement(Button, { variant: "contained", color: "secondary", onClick: () => {
32
+ handleClose();
33
+ } }, "Cancel")))));
34
+ });
35
+ export default SetRowHeightDialog;
36
+ //# sourceMappingURL=SetRowHeight.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SetRowHeight.js","sourceRoot":"","sources":["../../../src/LinearMafDisplay/components/SetRowHeight.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAEvC,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AACzC,OAAO,EACL,MAAM,EACN,aAAa,EACb,aAAa,EACb,SAAS,EACT,UAAU,GACX,MAAM,eAAe,CAAA;AACtB,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AACrC,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAE1C,MAAM,SAAS,GAAG,UAAU,EAAE,CAAC;IAC7B,IAAI,EAAE;QACJ,KAAK,EAAE,GAAG;KACX;CACF,CAAC,CAAA;AAEF,MAAM,kBAAkB,GAAG,QAAQ,CAAC,UAAU,KAQ7C;IACC,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,GAAG,KAAK,CAAA;IACpC,MAAM,EAAE,OAAO,EAAE,GAAG,SAAS,EAAE,CAAA;IAC/B,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,GAAG,KAAK,CAAC,SAAS,EAAE,CAAC,CAAA;IAChE,MAAM,CAAC,aAAa,EAAE,gBAAgB,CAAC,GAAG,QAAQ,CAAC,GAAG,KAAK,CAAC,aAAa,EAAE,CAAC,CAAA;IAE5E,OAAO,CACL,oBAAC,MAAM,IAAC,IAAI,QAAC,OAAO,EAAE,WAAW,EAAE,KAAK,EAAC,gBAAgB;QACvD,oBAAC,aAAa,IAAC,SAAS,EAAE,OAAO,CAAC,IAAI;YACpC,oBAAC,UAAU,0FAGE;YACb,oBAAC,SAAS,IACR,KAAK,EAAE,SAAS,EAChB,UAAU,EAAC,kBAAkB,EAC7B,QAAQ,EAAE,KAAK,CAAC,EAAE;oBAChB,YAAY,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;gBAClC,CAAC,GACD;YACF,oBAAC,SAAS,IACR,KAAK,EAAE,aAAa,EACpB,UAAU,EAAC,sBAAsB,EACjC,QAAQ,EAAE,KAAK,CAAC,EAAE;oBAChB,gBAAgB,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;gBACtC,CAAC,GACD;YACF,oBAAC,aAAa;gBACZ,oBAAC,MAAM,IACL,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,SAAS,EACf,IAAI,EAAC,QAAQ,EACb,SAAS,QACT,OAAO,EAAE,GAAG,EAAE;wBACZ,KAAK,CAAC,gBAAgB,CAAC,CAAC,aAAa,CAAC,CAAA;wBACtC,KAAK,CAAC,YAAY,CAAC,CAAC,SAAS,CAAC,CAAA;wBAC9B,WAAW,EAAE,CAAA;oBACf,CAAC,aAGM;gBACT,oBAAC,MAAM,IACL,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,WAAW,EACjB,OAAO,EAAE,GAAG,EAAE;wBACZ,WAAW,EAAE,CAAA;oBACf,CAAC,aAGM,CACK,CACF,CACT,CACV,CAAA;AACH,CAAC,CAAC,CAAA;AACF,eAAe,kBAAkB,CAAA"}
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+ import { LinearMafDisplayModel } from '../stateModel';
3
+ declare const SvgWrapper: ({ children, model, exportSVG, }: {
4
+ model: LinearMafDisplayModel;
5
+ children: React.ReactNode;
6
+ exportSVG?: boolean;
7
+ }) => React.JSX.Element;
8
+ export default SvgWrapper;
@@ -0,0 +1,21 @@
1
+ import React from 'react';
2
+ import { getContainingView } from '@jbrowse/core/util';
3
+ import { observer } from 'mobx-react';
4
+ const SvgWrapper = observer(function ({ children, model, exportSVG, }) {
5
+ if (exportSVG) {
6
+ return React.createElement(React.Fragment, null, children);
7
+ }
8
+ else {
9
+ const { rowHeight, samples } = model;
10
+ return (React.createElement("svg", { style: {
11
+ position: 'absolute',
12
+ top: 0,
13
+ left: 0,
14
+ pointerEvents: 'none',
15
+ height: samples.length * rowHeight,
16
+ width: getContainingView(model).width,
17
+ } }, children));
18
+ }
19
+ });
20
+ export default SvgWrapper;
21
+ //# sourceMappingURL=SvgWrapper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SvgWrapper.js","sourceRoot":"","sources":["../../../src/LinearMafDisplay/components/SvgWrapper.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAA;AACtD,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAKrC,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,EACpC,QAAQ,EACR,KAAK,EACL,SAAS,GAKV;IACC,IAAI,SAAS,EAAE,CAAC;QACd,OAAO,0CAAG,QAAQ,CAAI,CAAA;IACxB,CAAC;SAAM,CAAC;QACN,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,KAAK,CAAA;QACpC,OAAO,CACL,6BACE,KAAK,EAAE;gBACL,QAAQ,EAAE,UAAU;gBACpB,GAAG,EAAE,CAAC;gBACN,IAAI,EAAE,CAAC;gBACP,aAAa,EAAE,MAAM;gBACrB,MAAM,EAAE,OAAO,CAAC,MAAM,GAAG,SAAS;gBAClC,KAAK,EAAE,iBAAiB,CAAC,KAAK,CAAC,CAAC,KAAK;aACtC,IAEA,QAAQ,CACL,CACP,CAAA;IACH,CAAC;AACH,CAAC,CAAC,CAAA;AAEF,eAAe,UAAU,CAAA"}
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+ declare const Tree: ({ model }: {
3
+ model: any;
4
+ }) => React.JSX.Element;
5
+ export default Tree;
@@ -0,0 +1,22 @@
1
+ import React from 'react';
2
+ import { observer } from 'mobx-react';
3
+ const Tree = observer(function ({ model }) {
4
+ const { hierarchy, showBranchLen } = model;
5
+ return (React.createElement(React.Fragment, null, hierarchy
6
+ ? [...hierarchy.links()].map(link => {
7
+ const { source, target } = link;
8
+ const sy = source.x;
9
+ const ty = target.x;
10
+ const tx = showBranchLen ? target.len : target.y;
11
+ const sx = showBranchLen ? source.len : source.y;
12
+ // 1d line intersection to check if line crosses block at all, this is
13
+ // an optimization that allows us to skip drawing most tree links
14
+ // outside the block
15
+ return (React.createElement(React.Fragment, { key: [sy, ty, tx, sx].join('-') },
16
+ React.createElement("line", { stroke: "black", x1: sx, y1: sy, x2: sx, y2: ty }),
17
+ React.createElement("line", { stroke: "black", x1: sx, y1: ty, x2: tx, y2: ty })));
18
+ })
19
+ : null));
20
+ });
21
+ export default Tree;
22
+ //# sourceMappingURL=Tree.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Tree.js","sourceRoot":"","sources":["../../../src/LinearMafDisplay/components/Tree.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAErC,MAAM,IAAI,GAAG,QAAQ,CAAC,UAAU,EAAE,KAAK,EAAkB;IACvD,MAAM,EAAE,SAAS,EAAE,aAAa,EAAE,GAAG,KAAK,CAAA;IAE1C,OAAO,CACL,0CACG,SAAS;QACR,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;YAChC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,CAAA;YAC/B,MAAM,EAAE,GAAG,MAAM,CAAC,CAAE,CAAA;YACpB,MAAM,EAAE,GAAG,MAAM,CAAC,CAAE,CAAA;YACpB,MAAM,EAAE,GAAG,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAA;YAChD,MAAM,EAAE,GAAG,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAA;YAEhD,sEAAsE;YACtE,iEAAiE;YACjE,oBAAoB;YACpB,OAAO,CACL,oBAAC,KAAK,CAAC,QAAQ,IAAC,GAAG,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;gBAC7C,8BAAM,MAAM,EAAC,OAAO,EAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAI;gBACvD,8BAAM,MAAM,EAAC,OAAO,EAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAI,CACxC,CAClB,CAAA;QACH,CAAC,CAAC;QACJ,CAAC,CAAC,IAAI,CACP,CACJ,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,eAAe,IAAI,CAAA"}
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+ import { LinearMafDisplayModel } from '../stateModel';
3
+ export declare const YScaleBars: (props: {
4
+ model: LinearMafDisplayModel;
5
+ orientation?: string;
6
+ exportSVG?: boolean;
7
+ }) => React.JSX.Element;
8
+ export default YScaleBars;
@@ -0,0 +1,20 @@
1
+ import React from 'react';
2
+ import { measureText } from '@jbrowse/core/util';
3
+ import { observer } from 'mobx-react';
4
+ import ColorLegend from './ColorLegend';
5
+ import SvgWrapper from './SvgWrapper';
6
+ import { max } from './util';
7
+ export const YScaleBars = observer(function (props) {
8
+ const { model } = props;
9
+ const { rowHeight, samples } = model;
10
+ const svgFontSize = Math.min(Math.max(rowHeight, 8), 14);
11
+ const canDisplayLabel = rowHeight >= 8;
12
+ const minWidth = 20;
13
+ const labelWidth = max(samples
14
+ .map(s => measureText(s.label, svgFontSize))
15
+ .map(width => (canDisplayLabel ? width : minWidth)));
16
+ return (React.createElement(SvgWrapper, { ...props },
17
+ React.createElement(ColorLegend, { model: model, labelWidth: labelWidth, svgFontSize: svgFontSize })));
18
+ });
19
+ export default YScaleBars;
20
+ //# sourceMappingURL=YScaleBars.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"YScaleBars.js","sourceRoot":"","sources":["../../../src/LinearMafDisplay/components/YScaleBars.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAA;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAIrC,OAAO,WAAW,MAAM,eAAe,CAAA;AACvC,OAAO,UAAU,MAAM,cAAc,CAAA;AACrC,OAAO,EAAE,GAAG,EAAE,MAAM,QAAQ,CAAA;AAE5B,MAAM,CAAC,MAAM,UAAU,GAAG,QAAQ,CAAC,UAAU,KAI5C;IACC,MAAM,EAAE,KAAK,EAAE,GAAG,KAAK,CAAA;IACvB,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,KAAK,CAAA;IACpC,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAA;IACxD,MAAM,eAAe,GAAG,SAAS,IAAI,CAAC,CAAA;IACtC,MAAM,QAAQ,GAAG,EAAE,CAAA;IAEnB,MAAM,UAAU,GAAG,GAAG,CACpB,OAAO;SACJ,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;SAC3C,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CACtD,CAAA;IAED,OAAO,CACL,oBAAC,UAAU,OAAK,KAAK;QACnB,oBAAC,WAAW,IACV,KAAK,EAAE,KAAK,EACZ,UAAU,EAAE,UAAU,EACtB,WAAW,EAAE,WAAW,GACxB,CACS,CACd,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,eAAe,UAAU,CAAA"}
@@ -0,0 +1 @@
1
+ export declare function max(arr: number[], init?: number): number;
@@ -0,0 +1,8 @@
1
+ export function max(arr, init = Number.NEGATIVE_INFINITY) {
2
+ let max = init;
3
+ for (const entry of arr) {
4
+ max = Math.max(entry, max);
5
+ }
6
+ return max;
7
+ }
8
+ //# sourceMappingURL=util.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"util.js","sourceRoot":"","sources":["../../../src/LinearMafDisplay/components/util.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,GAAG,CAAC,GAAa,EAAE,IAAI,GAAG,MAAM,CAAC,iBAAiB;IAChE,IAAI,GAAG,GAAG,IAAI,CAAA;IACd,KAAK,MAAM,KAAK,IAAI,GAAG,EAAE,CAAC;QACxB,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,GAAG,CAAC,CAAA;IAC5B,CAAC;IACD,OAAO,GAAG,CAAA;AACZ,CAAC"}
@@ -0,0 +1,34 @@
1
+ import PluginManager from '@jbrowse/core/PluginManager';
2
+ export default function configSchemaF(pluginManager: PluginManager): import("@jbrowse/core/configuration/configurationSchema").ConfigurationSchemaType<{
3
+ /**
4
+ * #slot
5
+ */
6
+ renderer: import("mobx-state-tree").IAnyModelType;
7
+ }, import("@jbrowse/core/configuration/configurationSchema").ConfigurationSchemaOptions<import("@jbrowse/core/configuration/configurationSchema").ConfigurationSchemaType<{
8
+ maxFeatureScreenDensity: {
9
+ type: string;
10
+ description: string;
11
+ defaultValue: number;
12
+ };
13
+ fetchSizeLimit: {
14
+ type: string;
15
+ defaultValue: number;
16
+ description: string;
17
+ };
18
+ height: {
19
+ type: string;
20
+ defaultValue: number;
21
+ description: string;
22
+ };
23
+ mouseover: {
24
+ type: string;
25
+ description: string;
26
+ defaultValue: string;
27
+ contextVariable: string[];
28
+ };
29
+ jexlFilters: {
30
+ type: string;
31
+ description: string;
32
+ defaultValue: never[];
33
+ };
34
+ }, import("@jbrowse/core/configuration/configurationSchema").ConfigurationSchemaOptions<undefined, "displayId">>, undefined>>;
@@ -0,0 +1,15 @@
1
+ import { ConfigurationSchema } from '@jbrowse/core/configuration';
2
+ export default function configSchemaF(pluginManager) {
3
+ const LinearGenomePlugin = pluginManager.getPlugin('LinearGenomeViewPlugin');
4
+ const { baseLinearDisplayConfigSchema } = LinearGenomePlugin.exports;
5
+ return ConfigurationSchema('LinearMafDisplay', {
6
+ /**
7
+ * #slot
8
+ */
9
+ renderer: pluginManager.pluggableConfigSchemaType('renderer'),
10
+ }, {
11
+ baseConfiguration: baseLinearDisplayConfigSchema,
12
+ explicitlyTyped: true,
13
+ });
14
+ }
15
+ //# sourceMappingURL=configSchema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"configSchema.js","sourceRoot":"","sources":["../../src/LinearMafDisplay/configSchema.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAA;AAEjE,MAAM,CAAC,OAAO,UAAU,aAAa,CAAC,aAA4B;IAChE,MAAM,kBAAkB,GAAG,aAAa,CAAC,SAAS,CAChD,wBAAwB,CAC+B,CAAA;IACzD,MAAM,EAAE,6BAA6B,EAAE,GAAG,kBAAkB,CAAC,OAAO,CAAA;IACpE,OAAO,mBAAmB,CACxB,kBAAkB,EAClB;QACE;;WAEG;QACH,QAAQ,EAAE,aAAa,CAAC,yBAAyB,CAAC,UAAU,CAAC;KAC9D,EACD;QACE,iBAAiB,EAAE,6BAA6B;QAChD,eAAe,EAAE,IAAI;KACtB,CACF,CAAA;AACH,CAAC"}
@@ -0,0 +1,2 @@
1
+ import PluginManager from '@jbrowse/core/PluginManager';
2
+ export default function LinearMafDisplayF(pluginManager: PluginManager): void;
@@ -0,0 +1,20 @@
1
+ import { DisplayType } from '@jbrowse/core/pluggableElementTypes';
2
+ import ReactComponent from './components/ReactComponent';
3
+ import configSchemaF from './configSchema';
4
+ import stateModelFactory from './stateModel';
5
+ export default function LinearMafDisplayF(pluginManager) {
6
+ pluginManager.addDisplayType(() => {
7
+ const configSchema = configSchemaF(pluginManager);
8
+ const stateModel = stateModelFactory(configSchema, pluginManager);
9
+ return new DisplayType({
10
+ name: 'LinearMafDisplay',
11
+ configSchema,
12
+ stateModel,
13
+ ReactComponent,
14
+ viewType: 'LinearGenomeView',
15
+ trackType: 'MafTrack',
16
+ displayName: 'MAF display',
17
+ });
18
+ });
19
+ }
20
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/LinearMafDisplay/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,qCAAqC,CAAA;AAEjE,OAAO,cAAc,MAAM,6BAA6B,CAAA;AACxD,OAAO,aAAa,MAAM,gBAAgB,CAAA;AAC1C,OAAO,iBAAiB,MAAM,cAAc,CAAA;AAE5C,MAAM,CAAC,OAAO,UAAU,iBAAiB,CAAC,aAA4B;IACpE,aAAa,CAAC,cAAc,CAAC,GAAG,EAAE;QAChC,MAAM,YAAY,GAAG,aAAa,CAAC,aAAa,CAAC,CAAA;QACjD,MAAM,UAAU,GAAG,iBAAiB,CAAC,YAAY,EAAE,aAAa,CAAC,CAAA;QACjE,OAAO,IAAI,WAAW,CAAC;YACrB,IAAI,EAAE,kBAAkB;YACxB,YAAY;YACZ,UAAU;YACV,cAAc;YACd,QAAQ,EAAE,kBAAkB;YAC5B,SAAS,EAAE,UAAU;YACrB,WAAW,EAAE,aAAa;SAC3B,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC"}
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ import { ExportSvgDisplayOptions } from '@jbrowse/plugin-linear-genome-view';
3
+ import { LinearMafDisplayModel } from './stateModel';
4
+ export declare function renderSvg(self: LinearMafDisplayModel, opts: ExportSvgDisplayOptions, superRenderSvg: (opts: ExportSvgDisplayOptions) => Promise<React.ReactNode>): Promise<React.JSX.Element>;