@jbrowse/plugin-variants 1.7.9 → 2.0.0

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 (109) hide show
  1. package/dist/ChordVariantDisplay/index.d.ts +2 -1
  2. package/dist/ChordVariantDisplay/index.js +19 -31
  3. package/dist/ChordVariantDisplay/index.js.map +1 -0
  4. package/dist/ChordVariantDisplay/models/ChordVariantDisplay.d.ts +94 -2
  5. package/dist/ChordVariantDisplay/models/ChordVariantDisplay.js +39 -71
  6. package/dist/ChordVariantDisplay/models/ChordVariantDisplay.js.map +1 -0
  7. package/dist/LinearVariantDisplay/configSchema.js +9 -16
  8. package/dist/LinearVariantDisplay/configSchema.js.map +1 -0
  9. package/dist/LinearVariantDisplay/index.js +10 -22
  10. package/dist/LinearVariantDisplay/index.js.map +1 -0
  11. package/dist/LinearVariantDisplay/model.d.ts +18 -13
  12. package/dist/LinearVariantDisplay/model.js +83 -73
  13. package/dist/LinearVariantDisplay/model.js.map +1 -0
  14. package/dist/StructuralVariantChordRenderer/ReactComponent.js +193 -214
  15. package/dist/StructuralVariantChordRenderer/ReactComponent.js.map +1 -0
  16. package/dist/StructuralVariantChordRenderer/index.js +36 -46
  17. package/dist/StructuralVariantChordRenderer/index.js.map +1 -0
  18. package/dist/VariantFeatureWidget/BreakendOptionDialog.d.ts +1 -1
  19. package/dist/VariantFeatureWidget/BreakendOptionDialog.js +95 -119
  20. package/dist/VariantFeatureWidget/BreakendOptionDialog.js.map +1 -0
  21. package/dist/VariantFeatureWidget/VariantFeatureWidget.js +193 -240
  22. package/dist/VariantFeatureWidget/VariantFeatureWidget.js.map +1 -0
  23. package/dist/VariantFeatureWidget/index.d.ts +32 -6
  24. package/dist/VariantFeatureWidget/index.js +14 -33
  25. package/dist/VariantFeatureWidget/index.js.map +1 -0
  26. package/dist/VcfAdapter/VcfAdapter.js +232 -372
  27. package/dist/VcfAdapter/VcfAdapter.js.map +1 -0
  28. package/dist/VcfAdapter/configSchema.js +9 -21
  29. package/dist/VcfAdapter/configSchema.js.map +1 -0
  30. package/dist/VcfAdapter/index.js +8 -14
  31. package/dist/VcfAdapter/index.js.map +1 -0
  32. package/dist/VcfTabixAdapter/VcfFeature.js +203 -246
  33. package/dist/VcfTabixAdapter/VcfFeature.js.map +1 -0
  34. package/dist/VcfTabixAdapter/VcfTabixAdapter.js +237 -374
  35. package/dist/VcfTabixAdapter/VcfTabixAdapter.js.map +1 -0
  36. package/dist/VcfTabixAdapter/configSchema.js +23 -36
  37. package/dist/VcfTabixAdapter/configSchema.js.map +1 -0
  38. package/dist/VcfTabixAdapter/index.js +8 -14
  39. package/dist/VcfTabixAdapter/index.js.map +1 -0
  40. package/dist/index.js +160 -203
  41. package/dist/index.js.map +1 -0
  42. package/esm/ChordVariantDisplay/index.d.ts +4 -0
  43. package/esm/ChordVariantDisplay/index.js +16 -0
  44. package/esm/ChordVariantDisplay/index.js.map +1 -0
  45. package/esm/ChordVariantDisplay/models/ChordVariantDisplay.d.ts +97 -0
  46. package/esm/ChordVariantDisplay/models/ChordVariantDisplay.js +40 -0
  47. package/esm/ChordVariantDisplay/models/ChordVariantDisplay.js.map +1 -0
  48. package/esm/LinearVariantDisplay/configSchema.d.ts +5 -0
  49. package/esm/LinearVariantDisplay/configSchema.js +7 -0
  50. package/esm/LinearVariantDisplay/configSchema.js.map +1 -0
  51. package/esm/LinearVariantDisplay/index.d.ts +2 -0
  52. package/esm/LinearVariantDisplay/index.js +3 -0
  53. package/esm/LinearVariantDisplay/index.js.map +1 -0
  54. package/esm/LinearVariantDisplay/model.d.ts +212 -0
  55. package/esm/LinearVariantDisplay/model.js +34 -0
  56. package/esm/LinearVariantDisplay/model.js.map +1 -0
  57. package/esm/StructuralVariantChordRenderer/ReactComponent.d.ts +24 -0
  58. package/esm/StructuralVariantChordRenderer/ReactComponent.js +133 -0
  59. package/esm/StructuralVariantChordRenderer/ReactComponent.js.map +1 -0
  60. package/esm/StructuralVariantChordRenderer/index.d.ts +3 -0
  61. package/esm/StructuralVariantChordRenderer/index.js +33 -0
  62. package/esm/StructuralVariantChordRenderer/index.js.map +1 -0
  63. package/esm/VariantFeatureWidget/BreakendOptionDialog.d.ts +10 -0
  64. package/esm/VariantFeatureWidget/BreakendOptionDialog.js +58 -0
  65. package/esm/VariantFeatureWidget/BreakendOptionDialog.js.map +1 -0
  66. package/esm/VariantFeatureWidget/VariantFeatureWidget.d.ts +4 -0
  67. package/esm/VariantFeatureWidget/VariantFeatureWidget.js +129 -0
  68. package/esm/VariantFeatureWidget/VariantFeatureWidget.js.map +1 -0
  69. package/esm/VariantFeatureWidget/index.d.ts +37 -0
  70. package/esm/VariantFeatureWidget/index.js +12 -0
  71. package/esm/VariantFeatureWidget/index.js.map +1 -0
  72. package/esm/VcfAdapter/VcfAdapter.d.ts +24 -0
  73. package/esm/VcfAdapter/VcfAdapter.js +99 -0
  74. package/esm/VcfAdapter/VcfAdapter.js.map +1 -0
  75. package/esm/VcfAdapter/configSchema.d.ts +2 -0
  76. package/esm/VcfAdapter/configSchema.js +8 -0
  77. package/esm/VcfAdapter/configSchema.js.map +1 -0
  78. package/esm/VcfAdapter/index.d.ts +1 -0
  79. package/esm/VcfAdapter/index.js +2 -0
  80. package/esm/VcfAdapter/index.js.map +1 -0
  81. package/esm/VcfTabixAdapter/VcfFeature.d.ts +59 -0
  82. package/esm/VcfTabixAdapter/VcfFeature.js +184 -0
  83. package/esm/VcfTabixAdapter/VcfFeature.js.map +1 -0
  84. package/esm/VcfTabixAdapter/VcfTabixAdapter.d.ts +35 -0
  85. package/esm/VcfTabixAdapter/VcfTabixAdapter.js +112 -0
  86. package/esm/VcfTabixAdapter/VcfTabixAdapter.js.map +1 -0
  87. package/esm/VcfTabixAdapter/configSchema.d.ts +2 -0
  88. package/esm/VcfTabixAdapter/configSchema.js +23 -0
  89. package/esm/VcfTabixAdapter/configSchema.js.map +1 -0
  90. package/esm/VcfTabixAdapter/index.d.ts +1 -0
  91. package/esm/VcfTabixAdapter/index.js +2 -0
  92. package/esm/VcfTabixAdapter/index.js.map +1 -0
  93. package/esm/index.d.ts +7 -0
  94. package/esm/index.js +110 -0
  95. package/esm/index.js.map +1 -0
  96. package/package.json +20 -11
  97. package/src/ChordVariantDisplay/index.ts +4 -4
  98. package/src/ChordVariantDisplay/models/ChordVariantDisplay.js +7 -8
  99. package/src/VariantFeatureWidget/BreakendOptionDialog.tsx +8 -9
  100. package/src/VariantFeatureWidget/VariantFeatureWidget.tsx +2 -3
  101. package/src/VariantFeatureWidget/__snapshots__/VariantFeatureWidget.test.js.snap +52 -57
  102. package/src/VariantFeatureWidget/index.ts +17 -0
  103. package/dist/LinearVariantDisplay/configSchema.test.js +0 -92
  104. package/dist/VariantFeatureWidget/VariantFeatureWidget.test.js +0 -56
  105. package/dist/VcfAdapter/VcfAdapter.test.js +0 -55
  106. package/dist/VcfTabixAdapter/VcfFeature.test.js +0 -106
  107. package/dist/VcfTabixAdapter/VcfTabixAdapter.test.js +0 -99
  108. package/dist/index.test.js +0 -37
  109. package/src/VariantFeatureWidget/index.js +0 -26
@@ -0,0 +1,40 @@
1
+ import { baseChordDisplayConfig, BaseChordDisplayModel, } from '@jbrowse/plugin-circular-view';
2
+ import { ConfigurationSchema, ConfigurationReference, } from '@jbrowse/core/configuration';
3
+ import { types } from 'mobx-state-tree';
4
+ import { getContainingView } from '@jbrowse/core/util';
5
+ import { getParentRenderProps } from '@jbrowse/core/util/tracks';
6
+ const ChordVariantDisplayF = pluginManager => {
7
+ const configSchema = ConfigurationSchema('ChordVariantDisplay', {
8
+ renderer: types.optional(pluginManager.pluggableConfigSchemaType('renderer'), { type: 'StructuralVariantChordRenderer' }),
9
+ }, { baseConfiguration: baseChordDisplayConfig, explicitlyTyped: true });
10
+ const stateModel = types
11
+ .compose('ChordVariantDisplay', BaseChordDisplayModel, types.model({
12
+ type: types.literal('ChordVariantDisplay'),
13
+ configuration: ConfigurationReference(configSchema),
14
+ }))
15
+ .views(self => ({
16
+ get rendererTypeName() {
17
+ return self.configuration.renderer.type;
18
+ },
19
+ renderProps() {
20
+ const view = getContainingView(self);
21
+ return {
22
+ ...getParentRenderProps(self),
23
+ rpcDriverName: self.rpcDriverName,
24
+ displayModel: self,
25
+ bezierRadius: view.radiusPx * self.bezierRadiusRatio,
26
+ radius: view.radiusPx,
27
+ blockDefinitions: this.blockDefinitions,
28
+ config: self.configuration.renderer,
29
+ onChordClick: self.onChordClick,
30
+ };
31
+ },
32
+ }));
33
+ return { stateModel, configSchema };
34
+ };
35
+ // http://localhost:3000/test_data/hs37d5.HG002-SequelII-CCS.sv.vcf.gz.tbi
36
+ // render request is for 1.5x the current viewing window
37
+ // tracks all have a height
38
+ //
39
+ export default ChordVariantDisplayF;
40
+ //# sourceMappingURL=ChordVariantDisplay.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ChordVariantDisplay.js","sourceRoot":"","sources":["../../../src/ChordVariantDisplay/models/ChordVariantDisplay.js"],"names":[],"mappings":"AAAA,OAAO,EACL,sBAAsB,EACtB,qBAAqB,GACtB,MAAM,+BAA+B,CAAA;AACtC,OAAO,EACL,mBAAmB,EACnB,sBAAsB,GACvB,MAAM,6BAA6B,CAAA;AACpC,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAA;AACvC,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAA;AACtD,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAA;AAEhE,MAAM,oBAAoB,GAAG,aAAa,CAAC,EAAE;IAC3C,MAAM,YAAY,GAAG,mBAAmB,CACtC,qBAAqB,EACrB;QACE,QAAQ,EAAE,KAAK,CAAC,QAAQ,CACtB,aAAa,CAAC,yBAAyB,CAAC,UAAU,CAAC,EACnD,EAAE,IAAI,EAAE,gCAAgC,EAAE,CAC3C;KACF,EACD,EAAE,iBAAiB,EAAE,sBAAsB,EAAE,eAAe,EAAE,IAAI,EAAE,CACrE,CAAA;IAED,MAAM,UAAU,GAAG,KAAK;SACrB,OAAO,CACN,qBAAqB,EACrB,qBAAqB,EACrB,KAAK,CAAC,KAAK,CAAC;QACV,IAAI,EAAE,KAAK,CAAC,OAAO,CAAC,qBAAqB,CAAC;QAC1C,aAAa,EAAE,sBAAsB,CAAC,YAAY,CAAC;KACpD,CAAC,CACH;SACA,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACd,IAAI,gBAAgB;YAClB,OAAO,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAA;QACzC,CAAC;QAED,WAAW;YACT,MAAM,IAAI,GAAG,iBAAiB,CAAC,IAAI,CAAC,CAAA;YACpC,OAAO;gBACL,GAAG,oBAAoB,CAAC,IAAI,CAAC;gBAC7B,aAAa,EAAE,IAAI,CAAC,aAAa;gBACjC,YAAY,EAAE,IAAI;gBAClB,YAAY,EAAE,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,iBAAiB;gBACpD,MAAM,EAAE,IAAI,CAAC,QAAQ;gBACrB,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;gBACvC,MAAM,EAAE,IAAI,CAAC,aAAa,CAAC,QAAQ;gBACnC,YAAY,EAAE,IAAI,CAAC,YAAY;aAChC,CAAA;QACH,CAAC;KACF,CAAC,CAAC,CAAA;IAEL,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,CAAA;AACrC,CAAC,CAAA;AAED,0EAA0E;AAE1E,wDAAwD;AAExD,2BAA2B;AAC3B,EAAE;AACF,eAAe,oBAAoB,CAAA"}
@@ -0,0 +1,5 @@
1
+ import { Instance } from 'mobx-state-tree';
2
+ import PluginManager from '@jbrowse/core/PluginManager';
3
+ export declare function LinearVariantDisplayConfigFactory(pluginManager: PluginManager): import("@jbrowse/core/configuration").AnyConfigurationSchemaType;
4
+ export declare type LinearVariantDisplayConfigModel = ReturnType<typeof LinearVariantDisplayConfigFactory>;
5
+ export declare type LinearVariantDisplayConfig = Instance<LinearVariantDisplayConfigModel>;
@@ -0,0 +1,7 @@
1
+ import { ConfigurationSchema } from '@jbrowse/core/configuration';
2
+ import { linearBasicDisplayConfigSchemaFactory } from '@jbrowse/plugin-linear-genome-view';
3
+ export function LinearVariantDisplayConfigFactory(pluginManager) {
4
+ const configSchema = linearBasicDisplayConfigSchemaFactory(pluginManager);
5
+ return ConfigurationSchema('LinearVariantDisplay', {}, { baseConfiguration: configSchema, explicitlyTyped: true });
6
+ }
7
+ //# sourceMappingURL=configSchema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"configSchema.js","sourceRoot":"","sources":["../../src/LinearVariantDisplay/configSchema.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAA;AAGjE,OAAO,EAAE,qCAAqC,EAAE,MAAM,oCAAoC,CAAA;AAE1F,MAAM,UAAU,iCAAiC,CAC/C,aAA4B;IAE5B,MAAM,YAAY,GAAG,qCAAqC,CAAC,aAAa,CAAC,CAAA;IAEzE,OAAO,mBAAmB,CACxB,sBAAsB,EACtB,EAAE,EACF,EAAE,iBAAiB,EAAE,YAAY,EAAE,eAAe,EAAE,IAAI,EAAE,CAC3D,CAAA;AACH,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { LinearVariantDisplayConfigFactory as configSchemaFactory } from './configSchema';
2
+ export { default as modelFactory } from './model';
@@ -0,0 +1,3 @@
1
+ export { LinearVariantDisplayConfigFactory as configSchemaFactory } from './configSchema';
2
+ export { default as modelFactory } from './model';
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/LinearVariantDisplay/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iCAAiC,IAAI,mBAAmB,EAAE,MAAM,gBAAgB,CAAA;AACzF,OAAO,EAAE,OAAO,IAAI,YAAY,EAAE,MAAM,SAAS,CAAA"}
@@ -0,0 +1,212 @@
1
+ /// <reference types="react" />
2
+ import { Feature } from '@jbrowse/core/util/simpleFeature';
3
+ import { LinearVariantDisplayConfigModel } from './configSchema';
4
+ export default function (configSchema: LinearVariantDisplayConfigModel): import("mobx-state-tree").IModelType<{
5
+ id: import("mobx-state-tree").IOptionalIType<import("mobx-state-tree").ISimpleType<string>, [undefined]>;
6
+ type: import("mobx-state-tree").ISimpleType<string>;
7
+ rpcDriverName: import("mobx-state-tree").IMaybe<import("mobx-state-tree").ISimpleType<string>>;
8
+ } & {
9
+ height: import("mobx-state-tree").IOptionalIType<import("mobx-state-tree").ISimpleType<number>, [undefined]>;
10
+ blockState: import("mobx-state-tree").IMapType<import("mobx-state-tree").IModelType<{
11
+ key: import("mobx-state-tree").ISimpleType<string>;
12
+ region: import("mobx-state-tree").IModelType<{
13
+ refName: import("mobx-state-tree").ISimpleType<string>;
14
+ start: import("mobx-state-tree").ISimpleType<number>;
15
+ end: import("mobx-state-tree").ISimpleType<number>;
16
+ reversed: import("mobx-state-tree").IOptionalIType<import("mobx-state-tree").ISimpleType<boolean>, [undefined]>;
17
+ } & {
18
+ assemblyName: import("mobx-state-tree").ISimpleType<string>;
19
+ }, {
20
+ setRefName(newRefName: string): void;
21
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>;
22
+ reloadFlag: import("mobx-state-tree").IType<number | undefined, number, number>;
23
+ isLeftEndOfDisplayedRegion: import("mobx-state-tree").IType<boolean | undefined, boolean, boolean>;
24
+ isRightEndOfDisplayedRegion: import("mobx-state-tree").IType<boolean | undefined, boolean, boolean>;
25
+ }, {
26
+ renderInProgress: AbortController | undefined;
27
+ filled: boolean;
28
+ reactElement: import("react").ReactElement<any, string | import("react").JSXElementConstructor<any>> | undefined;
29
+ features: Map<string, Feature> | undefined;
30
+ layout: any;
31
+ status: string;
32
+ error: unknown;
33
+ message: string | undefined;
34
+ maxHeightReached: boolean;
35
+ ReactComponent: ({ model, }: {
36
+ model: any;
37
+ }) => any;
38
+ renderProps: any;
39
+ } & {
40
+ doReload(): void;
41
+ afterAttach(): void;
42
+ setStatus(message: string): void;
43
+ setLoading(abortController: AbortController): void;
44
+ setMessage(messageText: string): void;
45
+ setRendered(props: {
46
+ reactElement: import("react").ReactElement<any, string | import("react").JSXElementConstructor<any>>;
47
+ features: Map<string, Feature>;
48
+ layout: any;
49
+ maxHeightReached: boolean;
50
+ renderProps: any;
51
+ } | undefined): void;
52
+ setError(error: unknown): void;
53
+ reload(): void;
54
+ beforeDestroy(): void;
55
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>;
56
+ userBpPerPxLimit: import("mobx-state-tree").IMaybe<import("mobx-state-tree").ISimpleType<number>>;
57
+ userByteSizeLimit: import("mobx-state-tree").IMaybe<import("mobx-state-tree").ISimpleType<number>>;
58
+ } & {
59
+ type: import("mobx-state-tree").ISimpleType<"LinearBasicDisplay">;
60
+ trackShowLabels: import("mobx-state-tree").IMaybe<import("mobx-state-tree").ISimpleType<boolean>>;
61
+ trackShowDescriptions: import("mobx-state-tree").IMaybe<import("mobx-state-tree").ISimpleType<boolean>>;
62
+ trackDisplayMode: import("mobx-state-tree").IMaybe<import("mobx-state-tree").ISimpleType<string>>;
63
+ trackMaxHeight: import("mobx-state-tree").IMaybe<import("mobx-state-tree").ISimpleType<number>>;
64
+ configuration: import("mobx-state-tree").ITypeUnion<any, any, any>;
65
+ } & {
66
+ type: import("mobx-state-tree").ISimpleType<"LinearVariantDisplay">;
67
+ configuration: import("mobx-state-tree").ITypeUnion<any, any, any>;
68
+ }, {
69
+ rendererTypeName: string;
70
+ error: unknown;
71
+ } & {
72
+ readonly RenderingComponent: import("react").FC<{
73
+ model: {
74
+ id: string;
75
+ type: string;
76
+ rpcDriverName: string | undefined;
77
+ } & import("mobx-state-tree/dist/internal").NonEmptyObject & {
78
+ rendererTypeName: string;
79
+ error: unknown;
80
+ } & import("mobx-state-tree").IStateTreeNode<import("mobx-state-tree").IModelType<{
81
+ id: import("mobx-state-tree").IOptionalIType<import("mobx-state-tree").ISimpleType<string>, [undefined]>;
82
+ type: import("mobx-state-tree").ISimpleType<string>;
83
+ rpcDriverName: import("mobx-state-tree").IMaybe<import("mobx-state-tree").ISimpleType<string>>;
84
+ }, {
85
+ rendererTypeName: string;
86
+ error: unknown;
87
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>;
88
+ onHorizontalScroll?: Function | undefined;
89
+ blockState?: Record<string, any> | undefined;
90
+ }>;
91
+ readonly DisplayBlurb: import("react").FC<{
92
+ model: {
93
+ id: string;
94
+ type: string;
95
+ rpcDriverName: string | undefined;
96
+ } & import("mobx-state-tree/dist/internal").NonEmptyObject & {
97
+ rendererTypeName: string;
98
+ error: unknown;
99
+ } & import("mobx-state-tree").IStateTreeNode<import("mobx-state-tree").IModelType<{
100
+ id: import("mobx-state-tree").IOptionalIType<import("mobx-state-tree").ISimpleType<string>, [undefined]>;
101
+ type: import("mobx-state-tree").ISimpleType<string>;
102
+ rpcDriverName: import("mobx-state-tree").IMaybe<import("mobx-state-tree").ISimpleType<string>>;
103
+ }, {
104
+ rendererTypeName: string;
105
+ error: unknown;
106
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>;
107
+ }> | null;
108
+ readonly adapterConfig: any;
109
+ readonly parentTrack: any;
110
+ renderProps(): any;
111
+ readonly rendererType: any;
112
+ readonly DisplayMessageComponent: import("react").FC<any> | undefined;
113
+ trackMenuItems(): import("@jbrowse/core/ui").MenuItem[];
114
+ readonly viewMenuActions: import("@jbrowse/core/ui").MenuItem[];
115
+ regionCannotBeRendered(): undefined;
116
+ } & {
117
+ setError(error?: unknown): void;
118
+ setRpcDriverName(rpcDriverName: string): void;
119
+ reload(): void;
120
+ } & {
121
+ currBpPerPx: number;
122
+ message: string;
123
+ featureIdUnderMouse: string | undefined;
124
+ contextMenuFeature: Feature | undefined;
125
+ scrollTop: number;
126
+ estimatedRegionStatsP: Promise<import("@jbrowse/core/data_adapters/BaseAdapter").Stats> | undefined;
127
+ estimatedRegionStats: import("@jbrowse/core/data_adapters/BaseAdapter").Stats | undefined;
128
+ } & {
129
+ readonly blockType: "dynamicBlocks" | "staticBlocks";
130
+ readonly blockDefinitions: import("@jbrowse/core/util/blockTypes").BlockSet;
131
+ } & {
132
+ readonly renderDelay: number;
133
+ readonly TooltipComponent: import("react").FC<any>;
134
+ readonly selectedFeatureId: string | undefined;
135
+ readonly DisplayMessageComponent: import("react").FC<any> | undefined;
136
+ } & {
137
+ readonly features: import("@jbrowse/core/util/compositeMap").default<string, Feature>;
138
+ readonly featureUnderMouse: Feature | undefined;
139
+ getFeatureOverlapping(blockKey: string, x: number, y: number): any;
140
+ getFeatureByID(blockKey: string, id: string): [number, number, number, number] | undefined;
141
+ searchFeatureByID(id: string): [number, number, number, number] | undefined;
142
+ readonly currentBytesRequested: number;
143
+ readonly currentFeatureScreenDensity: number;
144
+ readonly maxFeatureScreenDensity: any;
145
+ readonly estimatedStatsReady: boolean;
146
+ readonly maxAllowableBytes: number;
147
+ } & {
148
+ setMessage(message: string): void;
149
+ afterAttach(): void;
150
+ estimateRegionsStats(regions: import("@jbrowse/core/util").Region[], opts: {
151
+ headers?: Record<string, string> | undefined;
152
+ signal?: AbortSignal | undefined;
153
+ filters?: string[] | undefined;
154
+ }): Promise<{}>;
155
+ setRegionStatsP(p?: Promise<import("@jbrowse/core/data_adapters/BaseAdapter").Stats> | undefined): void;
156
+ setRegionStats(estimatedRegionStats?: import("@jbrowse/core/data_adapters/BaseAdapter").Stats | undefined): void;
157
+ clearRegionStats(): void;
158
+ setHeight(displayHeight: number): number;
159
+ resizeHeight(distance: number): number;
160
+ setScrollTop(scrollTop: number): void;
161
+ updateStatsLimit(stats: import("@jbrowse/core/data_adapters/BaseAdapter").Stats): void;
162
+ addBlock(key: string, block: import("@jbrowse/core/util/blockTypes").BaseBlock): void;
163
+ setCurrBpPerPx(n: number): void;
164
+ deleteBlock(key: string): void;
165
+ selectFeature(feature: Feature): void;
166
+ clearFeatureSelection(): void;
167
+ setFeatureIdUnderMouse(feature: string | undefined): void;
168
+ reload(): void;
169
+ setContextMenuFeature(feature?: Feature | undefined): void;
170
+ } & {
171
+ readonly regionTooLarge: boolean;
172
+ readonly regionTooLargeReason: string;
173
+ } & {
174
+ reload(): Promise<void>;
175
+ afterAttach(): void;
176
+ } & {
177
+ regionCannotBeRenderedText(_region: import("@jbrowse/core/util").Region): "" | "Force load to see features";
178
+ regionCannotBeRendered(_region: import("@jbrowse/core/util").Region): JSX.Element | undefined;
179
+ trackMenuItems(): import("@jbrowse/core/ui").MenuItem[];
180
+ contextMenuItems(): {
181
+ label: string;
182
+ icon: import("@mui/material/OverridableComponent").OverridableComponent<import("@mui/material").SvgIconTypeMap<{}, "svg">> & {
183
+ muiName: string;
184
+ };
185
+ onClick: () => void;
186
+ }[];
187
+ renderProps(): any;
188
+ } & {
189
+ renderSvg(opts: import("@jbrowse/plugin-linear-genome-view/src/LinearGenomeView").ExportSvgOptions & {
190
+ overrideHeight: number;
191
+ }): Promise<JSX.Element>;
192
+ } & {
193
+ readonly rendererTypeName: any;
194
+ readonly showLabels: any;
195
+ readonly showDescriptions: any;
196
+ readonly maxHeight: any;
197
+ readonly displayMode: any;
198
+ } & {
199
+ readonly rendererConfig: any;
200
+ } & {
201
+ toggleShowLabels(): void;
202
+ toggleShowDescriptions(): void;
203
+ setDisplayMode(val: string): void;
204
+ setMaxHeight(val: number): void;
205
+ } & {
206
+ renderProps(): {
207
+ config: any;
208
+ };
209
+ trackMenuItems(): import("@jbrowse/core/ui").MenuItem[];
210
+ } & {
211
+ selectFeature(feature: Feature): Promise<void>;
212
+ }, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>;
@@ -0,0 +1,34 @@
1
+ import { getConf, ConfigurationReference } from '@jbrowse/core/configuration';
2
+ import { getRpcSessionId } from '@jbrowse/core/util/tracks';
3
+ import { getContainingTrack, getSession, getContainingView, isSessionModelWithWidgets, } from '@jbrowse/core/util';
4
+ import { linearBasicDisplayModelFactory } from '@jbrowse/plugin-linear-genome-view';
5
+ import { types } from 'mobx-state-tree';
6
+ export default function (configSchema) {
7
+ return types
8
+ .compose('LinearVariantDisplay', linearBasicDisplayModelFactory(configSchema), types.model({
9
+ type: types.literal('LinearVariantDisplay'),
10
+ configuration: ConfigurationReference(configSchema),
11
+ }))
12
+ .actions(self => ({
13
+ async selectFeature(feature) {
14
+ const session = getSession(self);
15
+ if (isSessionModelWithWidgets(session)) {
16
+ const { rpcManager } = session;
17
+ const sessionId = getRpcSessionId(self);
18
+ const track = getContainingTrack(self);
19
+ const adapterConfig = getConf(track, 'adapter');
20
+ const header = await rpcManager.call(sessionId, 'CoreGetMetadata', {
21
+ adapterConfig,
22
+ });
23
+ const featureWidget = session.addWidget('VariantFeatureWidget', 'variantFeature', {
24
+ featureData: feature.toJSON(),
25
+ view: getContainingView(self),
26
+ descriptions: header,
27
+ });
28
+ session.showWidget(featureWidget);
29
+ }
30
+ session.setSelection(feature);
31
+ },
32
+ }));
33
+ }
34
+ //# sourceMappingURL=model.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"model.js","sourceRoot":"","sources":["../../src/LinearVariantDisplay/model.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAA;AAC7E,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAC3D,OAAO,EACL,kBAAkB,EAClB,UAAU,EACV,iBAAiB,EACjB,yBAAyB,GAC1B,MAAM,oBAAoB,CAAA;AAG3B,OAAO,EAAE,8BAA8B,EAAE,MAAM,oCAAoC,CAAA;AACnF,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAA;AAGvC,MAAM,CAAC,OAAO,WAAW,YAA6C;IACpE,OAAO,KAAK;SACT,OAAO,CACN,sBAAsB,EACtB,8BAA8B,CAAC,YAAY,CAAC,EAC5C,KAAK,CAAC,KAAK,CAAC;QACV,IAAI,EAAE,KAAK,CAAC,OAAO,CAAC,sBAAsB,CAAC;QAC3C,aAAa,EAAE,sBAAsB,CAAC,YAAY,CAAC;KACpD,CAAC,CACH;SACA,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAChB,KAAK,CAAC,aAAa,CAAC,OAAgB;YAClC,MAAM,OAAO,GAAG,UAAU,CAAC,IAAI,CAAC,CAAA;YAChC,IAAI,yBAAyB,CAAC,OAAO,CAAC,EAAE;gBACtC,MAAM,EAAE,UAAU,EAAE,GAAG,OAAO,CAAA;gBAC9B,MAAM,SAAS,GAAG,eAAe,CAAC,IAAI,CAAC,CAAA;gBACvC,MAAM,KAAK,GAAG,kBAAkB,CAAC,IAAI,CAAC,CAAA;gBACtC,MAAM,aAAa,GAAG,OAAO,CAAC,KAAK,EAAE,SAAS,CAAC,CAAA;gBAC/C,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,IAAI,CAAC,SAAS,EAAE,iBAAiB,EAAE;oBACjE,aAAa;iBACd,CAAC,CAAA;gBACF,MAAM,aAAa,GAAG,OAAO,CAAC,SAAS,CACrC,sBAAsB,EACtB,gBAAgB,EAChB;oBACE,WAAW,EAAE,OAAO,CAAC,MAAM,EAAE;oBAC7B,IAAI,EAAE,iBAAiB,CAAC,IAAI,CAAC;oBAC7B,YAAY,EAAE,MAAM;iBACrB,CACF,CAAA;gBACD,OAAO,CAAC,UAAU,CAAC,aAAa,CAAC,CAAA;aAClC;YAED,OAAO,CAAC,YAAY,CAAC,OAAO,CAAC,CAAA;QAC/B,CAAC;KACF,CAAC,CAAC,CAAA;AACP,CAAC"}
@@ -0,0 +1,24 @@
1
+ declare function _default(props: any): JSX.Element;
2
+ declare namespace _default {
3
+ namespace propTypes {
4
+ const features: PropTypes.Validator<Map<unknown, unknown>>;
5
+ const config: PropTypes.Validator<any>;
6
+ const displayModel: React.Requireable<any>;
7
+ const blockDefinitions: PropTypes.Validator<any[]>;
8
+ const radius: PropTypes.Validator<number>;
9
+ const bezierRadius: PropTypes.Validator<number>;
10
+ const selectedFeatureId: PropTypes.Requireable<string>;
11
+ const onChordClick: PropTypes.Requireable<string | ((...args: any[]) => any)>;
12
+ }
13
+ namespace defaultProps {
14
+ const displayModel_1: undefined;
15
+ export { displayModel_1 as displayModel };
16
+ const selectedFeatureId_1: string;
17
+ export { selectedFeatureId_1 as selectedFeatureId };
18
+ const onChordClick_1: undefined;
19
+ export { onChordClick_1 as onChordClick };
20
+ }
21
+ }
22
+ export default _default;
23
+ import PropTypes from "prop-types";
24
+ import React from "react";
@@ -0,0 +1,133 @@
1
+ import React, { useMemo } from 'react';
2
+ import { observer, PropTypes as MobxPropTypes } from 'mobx-react';
3
+ import { polarToCartesian } from '@jbrowse/core/util';
4
+ import { readConfObject } from '@jbrowse/core/configuration';
5
+ import { PropTypes as CommonPropTypes } from '@jbrowse/core/util/types/mst';
6
+ import { parseBreakend } from '@gmod/vcf';
7
+ import PropTypes from 'prop-types';
8
+ function bpToRadians(block, pos) {
9
+ const blockStart = block.region.elided ? 0 : block.region.start;
10
+ const blockEnd = block.region.elided ? 0 : block.region.end;
11
+ const bpOffset = block.flipped ? blockEnd - pos : pos - blockStart;
12
+ const radians = bpOffset / block.bpPerRadian + block.startRadians;
13
+ return radians;
14
+ }
15
+ const Chord = observer(function Chord({ feature, blocksForRefs, radius, config, bezierRadius, selected, onClick, }) {
16
+ var _a, _b, _c, _d, _e;
17
+ // find the blocks that our start and end points belong to
18
+ const startBlock = blocksForRefs[feature.get('refName')];
19
+ if (!startBlock) {
20
+ return null;
21
+ }
22
+ let svType;
23
+ if (feature.get('INFO')) {
24
+ ;
25
+ [svType] = feature.get('INFO').SVTYPE || [];
26
+ }
27
+ else if (feature.get('mate')) {
28
+ svType = 'mate';
29
+ }
30
+ let endPosition;
31
+ let endBlock;
32
+ const alt = (_a = feature.get('ALT')) === null || _a === void 0 ? void 0 : _a[0];
33
+ const bnd = alt && parseBreakend(alt);
34
+ if (bnd) {
35
+ // VCF BND
36
+ const matePosition = bnd.MatePosition.split(':');
37
+ endPosition = +matePosition[1];
38
+ endBlock = blocksForRefs[matePosition[0]];
39
+ }
40
+ else if (alt === '<TRA>') {
41
+ // VCF TRA
42
+ const chr2 = (_c = (_b = feature.get('INFO')) === null || _b === void 0 ? void 0 : _b.CHR2) === null || _c === void 0 ? void 0 : _c[0];
43
+ const end = (_e = (_d = feature.get('INFO')) === null || _d === void 0 ? void 0 : _d.END) === null || _e === void 0 ? void 0 : _e[0];
44
+ endPosition = parseInt(end, 10);
45
+ endBlock = blocksForRefs[chr2];
46
+ }
47
+ else if (svType === 'mate') {
48
+ // generic simplefeatures arcs
49
+ const mate = feature.get('mate');
50
+ const chr2 = mate.refName;
51
+ endPosition = mate.start;
52
+ endBlock = blocksForRefs[chr2];
53
+ }
54
+ if (endBlock) {
55
+ const startPos = feature.get('start');
56
+ const startRadians = bpToRadians(startBlock, startPos);
57
+ const endRadians = bpToRadians(endBlock, endPosition);
58
+ const startXY = polarToCartesian(radius, startRadians);
59
+ const endXY = polarToCartesian(radius, endRadians);
60
+ const controlXY = polarToCartesian(bezierRadius, (endRadians + startRadians) / 2);
61
+ const strokeColor = selected
62
+ ? readConfObject(config, 'strokeColorSelected', { feature })
63
+ : readConfObject(config, 'strokeColor', { feature });
64
+ const hoverStrokeColor = readConfObject(config, 'strokeColorHover', {
65
+ feature,
66
+ });
67
+ return (React.createElement("path", { "data-testid": `chord-${feature.id()}`, d: ['M', ...startXY, 'Q', ...controlXY, ...endXY].join(' '), style: { stroke: strokeColor }, onClick: evt => onClick(feature, startBlock.region, endBlock.region, evt), onMouseOver: evt => {
68
+ if (!selected) {
69
+ evt.target.style.stroke = hoverStrokeColor;
70
+ evt.target.style.strokeWidth = 3;
71
+ }
72
+ }, onMouseOut: evt => {
73
+ if (!selected) {
74
+ evt.target.style.stroke = strokeColor;
75
+ evt.target.style.strokeWidth = 1;
76
+ }
77
+ } }));
78
+ }
79
+ return null;
80
+ });
81
+ function StructuralVariantChords(props) {
82
+ const { features, config, displayModel, blockDefinitions, radius, bezierRadius, displayModel: { selectedFeatureId }, onChordClick, } = props;
83
+ // make a map of refName -> blockDefinition
84
+ const blocksForRefsMemo = useMemo(() => {
85
+ const blocksForRefs = {};
86
+ blockDefinitions.forEach(block => {
87
+ const regions = block.region.elided
88
+ ? block.region.regions
89
+ : [block.region];
90
+ regions.forEach(region => {
91
+ blocksForRefs[region.refName] = block;
92
+ });
93
+ });
94
+ return blocksForRefs;
95
+ }, [blockDefinitions]);
96
+ // console.log(blocksForRefs)
97
+ const chords = [];
98
+ for (const [id, feature] of features) {
99
+ const selected = String(selectedFeatureId) === String(feature.id());
100
+ chords.push(React.createElement(Chord, { key: id, feature: feature, config: config, displayModel: displayModel, radius: radius, bezierRadius: bezierRadius, blocksForRefs: blocksForRefsMemo, selected: selected, onClick: onChordClick }));
101
+ }
102
+ const trackStyleId = `chords-${displayModel.id}`;
103
+ return (React.createElement("g", { id: trackStyleId, "data-testid": "structuralVariantChordRenderer" },
104
+ React.createElement("style", {
105
+ // eslint-disable-next-line react/no-danger
106
+ dangerouslySetInnerHTML: {
107
+ __html: `
108
+ #${trackStyleId} > path {
109
+ cursor: crosshair;
110
+ fill: none;
111
+ }
112
+ `,
113
+ } }),
114
+ chords));
115
+ }
116
+ StructuralVariantChords.propTypes = {
117
+ features: PropTypes.instanceOf(Map).isRequired,
118
+ config: CommonPropTypes.ConfigSchema.isRequired,
119
+ displayModel: MobxPropTypes.objectOrObservableObject,
120
+ blockDefinitions: PropTypes.arrayOf(MobxPropTypes.objectOrObservableObject)
121
+ .isRequired,
122
+ radius: PropTypes.number.isRequired,
123
+ bezierRadius: PropTypes.number.isRequired,
124
+ selectedFeatureId: PropTypes.string,
125
+ onChordClick: PropTypes.oneOfType([PropTypes.func, PropTypes.string]),
126
+ };
127
+ StructuralVariantChords.defaultProps = {
128
+ displayModel: undefined,
129
+ selectedFeatureId: '',
130
+ onChordClick: undefined,
131
+ };
132
+ export default observer(StructuralVariantChords);
133
+ //# sourceMappingURL=ReactComponent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ReactComponent.js","sourceRoot":"","sources":["../../src/StructuralVariantChordRenderer/ReactComponent.js"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ export default ChordRendererConfigF;
2
+ declare function ChordRendererConfigF(pluginManager: any): ChordRendererType;
3
+ import ChordRendererType from "@jbrowse/core/pluggableElementTypes/renderers/CircularChordRendererType";
@@ -0,0 +1,33 @@
1
+ import ChordRendererType from '@jbrowse/core/pluggableElementTypes/renderers/CircularChordRendererType';
2
+ import { ConfigurationSchema } from '@jbrowse/core/configuration';
3
+ import ReactComponent from './ReactComponent';
4
+ const ChordRendererConfigF = pluginManager => {
5
+ const configSchema = ConfigurationSchema('StructuralVariantChordRenderer', {
6
+ strokeColor: {
7
+ type: 'color',
8
+ description: 'the line color of each arc',
9
+ defaultValue: 'rgba(255,133,0,0.32)',
10
+ contextVariable: ['feature'],
11
+ },
12
+ strokeColorSelected: {
13
+ type: 'color',
14
+ description: 'the line color of an arc that has been selected',
15
+ defaultValue: 'black',
16
+ contextVariable: ['feature'],
17
+ },
18
+ strokeColorHover: {
19
+ type: 'color',
20
+ description: 'the line color of an arc that is being hovered over with the mouse',
21
+ defaultValue: '#555',
22
+ contextVariable: ['feature'],
23
+ },
24
+ }, { explicitlyTyped: true });
25
+ return new ChordRendererType({
26
+ name: 'StructuralVariantChordRenderer',
27
+ ReactComponent,
28
+ configSchema,
29
+ pluginManager,
30
+ });
31
+ };
32
+ export default ChordRendererConfigF;
33
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/StructuralVariantChordRenderer/index.js"],"names":[],"mappings":"AAAA,OAAO,iBAAiB,MAAM,yEAAyE,CAAA;AACvG,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAA;AACjE,OAAO,cAAc,MAAM,kBAAkB,CAAA;AAE7C,MAAM,oBAAoB,GAAG,aAAa,CAAC,EAAE;IAC3C,MAAM,YAAY,GAAG,mBAAmB,CACtC,gCAAgC,EAChC;QACE,WAAW,EAAE;YACX,IAAI,EAAE,OAAO;YACb,WAAW,EAAE,4BAA4B;YACzC,YAAY,EAAE,sBAAsB;YACpC,eAAe,EAAE,CAAC,SAAS,CAAC;SAC7B;QACD,mBAAmB,EAAE;YACnB,IAAI,EAAE,OAAO;YACb,WAAW,EAAE,iDAAiD;YAC9D,YAAY,EAAE,OAAO;YACrB,eAAe,EAAE,CAAC,SAAS,CAAC;SAC7B;QACD,gBAAgB,EAAE;YAChB,IAAI,EAAE,OAAO;YACb,WAAW,EACT,oEAAoE;YACtE,YAAY,EAAE,MAAM;YACpB,eAAe,EAAE,CAAC,SAAS,CAAC;SAC7B;KACF,EACD,EAAE,eAAe,EAAE,IAAI,EAAE,CAC1B,CAAA;IACD,OAAO,IAAI,iBAAiB,CAAC;QAC3B,IAAI,EAAE,gCAAgC;QACtC,cAAc;QACd,YAAY;QACZ,aAAa;KACd,CAAC,CAAA;AACJ,CAAC,CAAA;AAED,eAAe,oBAAoB,CAAA"}
@@ -0,0 +1,10 @@
1
+ /// <reference types="react" />
2
+ import { Feature } from '@jbrowse/core/util';
3
+ declare function BreakendOptionDialog({ model, handleClose, feature, viewType, }: {
4
+ model: any;
5
+ handleClose: () => void;
6
+ feature: Feature;
7
+ viewType: any;
8
+ }): JSX.Element;
9
+ declare const _default: typeof BreakendOptionDialog;
10
+ export default _default;
@@ -0,0 +1,58 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+ import React, { useState } from 'react';
3
+ import { observer } from 'mobx-react';
4
+ import { Button, Checkbox, Dialog, DialogActions, DialogContent, DialogTitle, Divider, FormControlLabel, IconButton, } from '@mui/material';
5
+ import { makeStyles } from 'tss-react/mui';
6
+ import CloseIcon from '@mui/icons-material/Close';
7
+ import { getSnapshot } from 'mobx-state-tree';
8
+ import { getSession } from '@jbrowse/core/util';
9
+ const useStyles = makeStyles()(theme => ({
10
+ closeButton: {
11
+ position: 'absolute',
12
+ right: theme.spacing(1),
13
+ top: theme.spacing(1),
14
+ color: theme.palette.grey[500],
15
+ },
16
+ block: {
17
+ display: 'block',
18
+ },
19
+ }));
20
+ function BreakendOptionDialog({ model, handleClose, feature, viewType, }) {
21
+ const { classes } = useStyles();
22
+ const [copyTracks, setCopyTracks] = useState(true);
23
+ const [mirrorTracks, setMirrorTracks] = useState(true);
24
+ return (React.createElement(Dialog, { open: true, onClose: handleClose },
25
+ React.createElement(DialogTitle, null,
26
+ "Breakpoint split view options",
27
+ handleClose ? (React.createElement(IconButton, { className: classes.closeButton, onClick: () => handleClose() },
28
+ React.createElement(CloseIcon, null))) : null),
29
+ React.createElement(Divider, null),
30
+ React.createElement(DialogContent, null,
31
+ React.createElement(FormControlLabel, { className: classes.block, control: React.createElement(Checkbox, { checked: copyTracks, onChange: () => setCopyTracks(val => !val) }), label: "Copy tracks into the new view" }),
32
+ React.createElement(FormControlLabel, { className: classes.block, control: React.createElement(Checkbox, { checked: mirrorTracks, onChange: () => setMirrorTracks(val => !val) }), label: "Mirror tracks vertically in vertically stacked view" })),
33
+ React.createElement(DialogActions, null,
34
+ React.createElement(Button, { onClick: () => {
35
+ const { view } = model;
36
+ const session = getSession(model);
37
+ try {
38
+ const viewSnapshot = viewType.snapshotFromBreakendFeature(feature, view);
39
+ viewSnapshot.views[0].offsetPx -= view.width / 2 + 100;
40
+ viewSnapshot.views[1].offsetPx -= view.width / 2 + 100;
41
+ viewSnapshot.featureData = feature;
42
+ const viewTracks = getSnapshot(view.tracks);
43
+ viewSnapshot.views[0].tracks = viewTracks;
44
+ viewSnapshot.views[1].tracks = mirrorTracks
45
+ ? viewTracks.slice().reverse()
46
+ : viewTracks;
47
+ session.addView('BreakpointSplitView', viewSnapshot);
48
+ }
49
+ catch (e) {
50
+ console.error(e);
51
+ session.notify(`${e}`);
52
+ }
53
+ handleClose();
54
+ }, variant: "contained", color: "primary", autoFocus: true }, "OK"),
55
+ React.createElement(Button, { onClick: () => handleClose(), color: "secondary", variant: "contained" }, "Cancel"))));
56
+ }
57
+ export default observer(BreakendOptionDialog);
58
+ //# sourceMappingURL=BreakendOptionDialog.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BreakendOptionDialog.js","sourceRoot":"","sources":["../../src/VariantFeatureWidget/BreakendOptionDialog.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ declare function VariantFeatureDetails(props: any): JSX.Element;
3
+ declare const _default: typeof VariantFeatureDetails;
4
+ export default _default;