@jbrowse/plugin-grid-bookmark 2.1.0 → 2.1.2
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.
- package/dist/GridBookmarkWidget/components/AssemblySelector.js +13 -14
- package/dist/GridBookmarkWidget/components/AssemblySelector.js.map +1 -1
- package/dist/GridBookmarkWidget/components/ClearBookmarks.js +17 -34
- package/dist/GridBookmarkWidget/components/ClearBookmarks.js.map +1 -1
- package/dist/GridBookmarkWidget/components/DeleteBookmark.js +13 -14
- package/dist/GridBookmarkWidget/components/DeleteBookmark.js.map +1 -1
- package/dist/GridBookmarkWidget/components/DownloadBookmarks.js +20 -37
- package/dist/GridBookmarkWidget/components/DownloadBookmarks.js.map +1 -1
- package/dist/GridBookmarkWidget/components/GridBookmarkWidget.js +45 -91
- package/dist/GridBookmarkWidget/components/GridBookmarkWidget.js.map +1 -1
- package/dist/GridBookmarkWidget/components/ImportBookmarks.js +55 -121
- package/dist/GridBookmarkWidget/components/ImportBookmarks.js.map +1 -1
- package/dist/GridBookmarkWidget/index.js +1 -1
- package/dist/GridBookmarkWidget/index.js.map +1 -1
- package/dist/GridBookmarkWidget/model.js +19 -42
- package/dist/GridBookmarkWidget/model.js.map +1 -1
- package/dist/GridBookmarkWidget/utils.js +50 -104
- package/dist/GridBookmarkWidget/utils.js.map +1 -1
- package/dist/index.js +46 -87
- package/dist/index.js.map +1 -1
- package/package.json +2 -3
|
@@ -3,11 +3,11 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
6
|
+
const react_1 = __importDefault(require("react"));
|
|
7
|
+
const mobx_react_1 = require("mobx-react");
|
|
8
|
+
const material_1 = require("@mui/material");
|
|
9
|
+
const mui_1 = require("tss-react/mui");
|
|
10
|
+
const useStyles = (0, mui_1.makeStyles)()(() => ({
|
|
11
11
|
container: {
|
|
12
12
|
display: 'flex',
|
|
13
13
|
flexDirection: 'row',
|
|
@@ -20,13 +20,12 @@ var useStyles = (0, mui_1.makeStyles)()(function () { return ({
|
|
|
20
20
|
flexItem: {
|
|
21
21
|
marginRight: 8,
|
|
22
22
|
},
|
|
23
|
-
})
|
|
24
|
-
function AssemblySelector(
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
var determineCurrentValue = function (selectedAssembly) {
|
|
23
|
+
}));
|
|
24
|
+
function AssemblySelector({ model }) {
|
|
25
|
+
const { classes } = useStyles();
|
|
26
|
+
const { assemblies, selectedAssembly, setSelectedAssembly } = model;
|
|
27
|
+
const noAssemblies = assemblies.length === 0 ? true : false;
|
|
28
|
+
const determineCurrentValue = (selectedAssembly) => {
|
|
30
29
|
if (selectedAssembly === 'all') {
|
|
31
30
|
return 'all';
|
|
32
31
|
}
|
|
@@ -38,10 +37,10 @@ function AssemblySelector(_a) {
|
|
|
38
37
|
return (react_1.default.createElement("div", { className: classes.container },
|
|
39
38
|
react_1.default.createElement(material_1.Typography, { className: classes.selectText }, "Select assembly:"),
|
|
40
39
|
react_1.default.createElement(material_1.FormControl, { className: classes.flexItem, disabled: noAssemblies },
|
|
41
|
-
react_1.default.createElement(material_1.Select, { value: determineCurrentValue(selectedAssembly), onChange:
|
|
40
|
+
react_1.default.createElement(material_1.Select, { value: determineCurrentValue(selectedAssembly), onChange: event => setSelectedAssembly(event.target.value) },
|
|
42
41
|
react_1.default.createElement(material_1.MenuItem, { value: "none" }, "none"),
|
|
43
42
|
react_1.default.createElement(material_1.MenuItem, { value: "all" }, "all"),
|
|
44
|
-
assemblies.map(
|
|
43
|
+
assemblies.map(assembly => (react_1.default.createElement(material_1.MenuItem, { value: assembly, key: assembly }, assembly)))))));
|
|
45
44
|
}
|
|
46
45
|
exports.default = (0, mobx_react_1.observer)(AssemblySelector);
|
|
47
46
|
//# sourceMappingURL=AssemblySelector.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AssemblySelector.js","sourceRoot":"","sources":["../../../src/GridBookmarkWidget/components/AssemblySelector.tsx"],"names":[],"mappings":";;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"AssemblySelector.js","sourceRoot":"","sources":["../../../src/GridBookmarkWidget/components/AssemblySelector.tsx"],"names":[],"mappings":";;;;;AAAA,kDAAyB;AACzB,2CAAqC;AAErC,4CAAyE;AACzE,uCAA0C;AAI1C,MAAM,SAAS,GAAG,IAAA,gBAAU,GAAE,CAAC,GAAG,EAAE,CAAC,CAAC;IACpC,SAAS,EAAE;QACT,OAAO,EAAE,MAAM;QACf,aAAa,EAAE,KAAK;QACpB,MAAM,EAAE,CAAC;KACV;IACD,UAAU,EAAE;QACV,WAAW,EAAE,CAAC;QACd,SAAS,EAAE,EAAE;KACd;IACD,QAAQ,EAAE;QACR,WAAW,EAAE,CAAC;KACf;CACF,CAAC,CAAC,CAAA;AAEH,SAAS,gBAAgB,CAAC,EAAE,KAAK,EAAgC;IAC/D,MAAM,EAAE,OAAO,EAAE,GAAG,SAAS,EAAE,CAAA;IAC/B,MAAM,EAAE,UAAU,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,GAAG,KAAK,CAAA;IACnE,MAAM,YAAY,GAAG,UAAU,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAA;IAE3D,MAAM,qBAAqB,GAAG,CAAC,gBAAwB,EAAE,EAAE;QACzD,IAAI,gBAAgB,KAAK,KAAK,EAAE;YAC9B,OAAO,KAAK,CAAA;SACb;aAAM,IAAI,UAAU,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE;YAChD,OAAO,gBAAgB,CAAA;SACxB;QAED,OAAO,MAAM,CAAA;IACf,CAAC,CAAA;IAED,OAAO,CACL,uCAAK,SAAS,EAAE,OAAO,CAAC,SAAS;QAC/B,8BAAC,qBAAU,IAAC,SAAS,EAAE,OAAO,CAAC,UAAU,uBAA+B;QACxE,8BAAC,sBAAW,IAAC,SAAS,EAAE,OAAO,CAAC,QAAQ,EAAE,QAAQ,EAAE,YAAY;YAC9D,8BAAC,iBAAM,IACL,KAAK,EAAE,qBAAqB,CAAC,gBAAgB,CAAC,EAC9C,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,mBAAmB,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;gBAE1D,8BAAC,mBAAQ,IAAC,KAAK,EAAC,MAAM,WAAgB;gBACtC,8BAAC,mBAAQ,IAAC,KAAK,EAAC,KAAK,UAAe;gBACnC,UAAU,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,CAC1B,8BAAC,mBAAQ,IAAC,KAAK,EAAE,QAAQ,EAAE,GAAG,EAAE,QAAQ,IACrC,QAAQ,CACA,CACZ,CAAC,CACK,CACG,CACV,CACP,CAAA;AACH,CAAC;AAED,kBAAe,IAAA,qBAAQ,EAAC,gBAAgB,CAAC,CAAA"}
|
|
@@ -22,33 +22,17 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
22
22
|
__setModuleDefault(result, mod);
|
|
23
23
|
return result;
|
|
24
24
|
};
|
|
25
|
-
var __read = (this && this.__read) || function (o, n) {
|
|
26
|
-
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
27
|
-
if (!m) return o;
|
|
28
|
-
var i = m.call(o), r, ar = [], e;
|
|
29
|
-
try {
|
|
30
|
-
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
31
|
-
}
|
|
32
|
-
catch (error) { e = { error: error }; }
|
|
33
|
-
finally {
|
|
34
|
-
try {
|
|
35
|
-
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
36
|
-
}
|
|
37
|
-
finally { if (e) throw e.error; }
|
|
38
|
-
}
|
|
39
|
-
return ar;
|
|
40
|
-
};
|
|
41
25
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
42
26
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
43
27
|
};
|
|
44
28
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
29
|
+
const react_1 = __importStar(require("react"));
|
|
30
|
+
const mobx_react_1 = require("mobx-react");
|
|
31
|
+
const material_1 = require("@mui/material");
|
|
32
|
+
const mui_1 = require("tss-react/mui");
|
|
33
|
+
const ClearAll_1 = __importDefault(require("@mui/icons-material/ClearAll"));
|
|
34
|
+
const Close_1 = __importDefault(require("@mui/icons-material/Close"));
|
|
35
|
+
const useStyles = (0, mui_1.makeStyles)()(() => ({
|
|
52
36
|
closeDialog: {
|
|
53
37
|
position: 'absolute',
|
|
54
38
|
right: 0,
|
|
@@ -57,26 +41,25 @@ var useStyles = (0, mui_1.makeStyles)()(function () { return ({
|
|
|
57
41
|
dialogContainer: {
|
|
58
42
|
margin: 15,
|
|
59
43
|
},
|
|
60
|
-
})
|
|
61
|
-
function ClearBookmarks(
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
var clearAllBookmarks = model.clearAllBookmarks;
|
|
44
|
+
}));
|
|
45
|
+
function ClearBookmarks({ model }) {
|
|
46
|
+
const { classes } = useStyles();
|
|
47
|
+
const [dialogOpen, setDialogOpen] = (0, react_1.useState)(false);
|
|
48
|
+
const { clearAllBookmarks } = model;
|
|
66
49
|
return (react_1.default.createElement(react_1.default.Fragment, null,
|
|
67
|
-
react_1.default.createElement(material_1.Button, { startIcon: react_1.default.createElement(ClearAll_1.default, null), "aria-label": "clear bookmarks", onClick:
|
|
68
|
-
react_1.default.createElement(material_1.Dialog, { open: dialogOpen, onClose:
|
|
50
|
+
react_1.default.createElement(material_1.Button, { startIcon: react_1.default.createElement(ClearAll_1.default, null), "aria-label": "clear bookmarks", onClick: () => setDialogOpen(true) }, "Clear"),
|
|
51
|
+
react_1.default.createElement(material_1.Dialog, { open: dialogOpen, onClose: () => setDialogOpen(false) },
|
|
69
52
|
react_1.default.createElement(material_1.DialogTitle, null,
|
|
70
53
|
"Clear bookmarks",
|
|
71
|
-
react_1.default.createElement(material_1.IconButton, { className: classes.closeDialog, "aria-label": "close-dialog", onClick:
|
|
54
|
+
react_1.default.createElement(material_1.IconButton, { className: classes.closeDialog, "aria-label": "close-dialog", onClick: () => setDialogOpen(false) },
|
|
72
55
|
react_1.default.createElement(Close_1.default, null))),
|
|
73
56
|
react_1.default.createElement(material_1.DialogContent, null,
|
|
74
57
|
react_1.default.createElement(material_1.Typography, null, "Clear all bookmarks? Note this will clear bookmarks for all assemblies")),
|
|
75
58
|
react_1.default.createElement(material_1.DialogActions, null,
|
|
76
|
-
react_1.default.createElement(material_1.Button, { variant: "contained", color: "secondary", onClick:
|
|
59
|
+
react_1.default.createElement(material_1.Button, { variant: "contained", color: "secondary", onClick: () => {
|
|
77
60
|
setDialogOpen(false);
|
|
78
61
|
} }, "Cancel"),
|
|
79
|
-
react_1.default.createElement(material_1.Button, { variant: "contained", color: "primary", onClick:
|
|
62
|
+
react_1.default.createElement(material_1.Button, { variant: "contained", color: "primary", onClick: () => {
|
|
80
63
|
clearAllBookmarks();
|
|
81
64
|
setDialogOpen(false);
|
|
82
65
|
} }, "Confirm")))));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ClearBookmarks.js","sourceRoot":"","sources":["../../../src/GridBookmarkWidget/components/ClearBookmarks.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"ClearBookmarks.js","sourceRoot":"","sources":["../../../src/GridBookmarkWidget/components/ClearBookmarks.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAuC;AACvC,2CAAqC;AAErC,4CAQsB;AACtB,uCAA0C;AAC1C,4EAAuD;AACvD,sEAAiD;AAIjD,MAAM,SAAS,GAAG,IAAA,gBAAU,GAAE,CAAC,GAAG,EAAE,CAAC,CAAC;IACpC,WAAW,EAAE;QACX,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,CAAC;QACR,GAAG,EAAE,CAAC;KACP;IACD,eAAe,EAAE;QACf,MAAM,EAAE,EAAE;KACX;CACF,CAAC,CAAC,CAAA;AAEH,SAAS,cAAc,CAAC,EAAE,KAAK,EAAgC;IAC7D,MAAM,EAAE,OAAO,EAAE,GAAG,SAAS,EAAE,CAAA;IAC/B,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,IAAA,gBAAQ,EAAC,KAAK,CAAC,CAAA;IAEnD,MAAM,EAAE,iBAAiB,EAAE,GAAG,KAAK,CAAA;IAEnC,OAAO,CACL;QACE,8BAAC,iBAAM,IACL,SAAS,EAAE,8BAAC,kBAAY,OAAG,gBAChB,iBAAiB,EAC5B,OAAO,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,YAG3B;QACT,8BAAC,iBAAM,IAAC,IAAI,EAAE,UAAU,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC;YAC3D,8BAAC,sBAAW;;gBAEV,8BAAC,qBAAU,IACT,SAAS,EAAE,OAAO,CAAC,WAAW,gBACnB,cAAc,EACzB,OAAO,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC;oBAEnC,8BAAC,eAAS,OAAG,CACF,CACD;YACd,8BAAC,wBAAa;gBACZ,8BAAC,qBAAU,iFAGE,CACC;YAChB,8BAAC,wBAAa;gBACZ,8BAAC,iBAAM,IACL,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,WAAW,EACjB,OAAO,EAAE,GAAG,EAAE;wBACZ,aAAa,CAAC,KAAK,CAAC,CAAA;oBACtB,CAAC,aAGM;gBACT,8BAAC,iBAAM,IACL,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,SAAS,EACf,OAAO,EAAE,GAAG,EAAE;wBACZ,iBAAiB,EAAE,CAAA;wBACnB,aAAa,CAAC,KAAK,CAAC,CAAA;oBACtB,CAAC,cAGM,CACK,CACT,CACR,CACJ,CAAA;AACH,CAAC;AAED,kBAAe,IAAA,qBAAQ,EAAC,cAAc,CAAC,CAAA"}
|
|
@@ -3,13 +3,13 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
3
3
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
6
|
+
const react_1 = __importDefault(require("react"));
|
|
7
|
+
const mobx_react_1 = require("mobx-react");
|
|
8
|
+
const util_1 = require("@jbrowse/core/util");
|
|
9
|
+
const material_1 = require("@mui/material");
|
|
10
|
+
const mui_1 = require("tss-react/mui");
|
|
11
|
+
const Close_1 = __importDefault(require("@mui/icons-material/Close"));
|
|
12
|
+
const useStyles = (0, mui_1.makeStyles)()(() => ({
|
|
13
13
|
closeDialog: {
|
|
14
14
|
position: 'absolute',
|
|
15
15
|
right: 0,
|
|
@@ -18,11 +18,10 @@ var useStyles = (0, mui_1.makeStyles)()(function () { return ({
|
|
|
18
18
|
dialogContainer: {
|
|
19
19
|
margin: 15,
|
|
20
20
|
},
|
|
21
|
-
})
|
|
22
|
-
function DeleteBookmarkDialog(
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
var removeBookmark = model.removeBookmark;
|
|
21
|
+
}));
|
|
22
|
+
function DeleteBookmarkDialog({ rowNumber, model, onClose, }) {
|
|
23
|
+
const { classes } = useStyles();
|
|
24
|
+
const { removeBookmark } = model;
|
|
26
25
|
return (react_1.default.createElement(material_1.Dialog, { open: rowNumber !== undefined, onClose: onClose },
|
|
27
26
|
react_1.default.createElement(material_1.DialogTitle, null,
|
|
28
27
|
"Delete bookmark",
|
|
@@ -38,10 +37,10 @@ function DeleteBookmarkDialog(_a) {
|
|
|
38
37
|
' ',
|
|
39
38
|
"?")),
|
|
40
39
|
react_1.default.createElement(material_1.DialogActions, null,
|
|
41
|
-
react_1.default.createElement(material_1.Button, { variant: "contained", color: "secondary", onClick:
|
|
40
|
+
react_1.default.createElement(material_1.Button, { variant: "contained", color: "secondary", onClick: () => {
|
|
42
41
|
onClose();
|
|
43
42
|
} }, "Cancel"),
|
|
44
|
-
react_1.default.createElement(material_1.Button, { variant: "contained", color: "primary", onClick:
|
|
43
|
+
react_1.default.createElement(material_1.Button, { variant: "contained", color: "primary", onClick: () => {
|
|
45
44
|
if (rowNumber !== undefined) {
|
|
46
45
|
removeBookmark(rowNumber);
|
|
47
46
|
onClose();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DeleteBookmark.js","sourceRoot":"","sources":["../../../src/GridBookmarkWidget/components/DeleteBookmark.tsx"],"names":[],"mappings":";;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"DeleteBookmark.js","sourceRoot":"","sources":["../../../src/GridBookmarkWidget/components/DeleteBookmark.tsx"],"names":[],"mappings":";;;;;AAAA,kDAAyB;AACzB,2CAAqC;AAErC,6CAAsD;AAEtD,4CAQsB;AACtB,uCAA0C;AAC1C,sEAAiD;AAIjD,MAAM,SAAS,GAAG,IAAA,gBAAU,GAAE,CAAC,GAAG,EAAE,CAAC,CAAC;IACpC,WAAW,EAAE;QACX,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,CAAC;QACR,GAAG,EAAE,CAAC;KACP;IACD,eAAe,EAAE;QACf,MAAM,EAAE,EAAE;KACX;CACF,CAAC,CAAC,CAAA;AAEH,SAAS,oBAAoB,CAAC,EAC5B,SAAS,EACT,KAAK,EACL,OAAO,GAKR;IACC,MAAM,EAAE,OAAO,EAAE,GAAG,SAAS,EAAE,CAAA;IAE/B,MAAM,EAAE,cAAc,EAAE,GAAG,KAAK,CAAA;IAEhC,OAAO,CACL,8BAAC,iBAAM,IAAC,IAAI,EAAE,SAAS,KAAK,SAAS,EAAE,OAAO,EAAE,OAAO;QACrD,8BAAC,sBAAW;;YAEV,8BAAC,qBAAU,IACT,SAAS,EAAE,OAAO,CAAC,WAAW,gBACnB,cAAc,EACzB,OAAO,EAAE,OAAO;gBAEhB,8BAAC,eAAS,OAAG,CACF,CACD;QACd,8BAAC,wBAAa;YACZ,8BAAC,qBAAU;;gBACF,GAAG;gBACV,4CACG,SAAS,KAAK,SAAS;oBACtB,CAAC,CAAC,IAAA,wBAAiB,EAAC,KAAK,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;oBACvD,CAAC,CAAC,EAAE,CACD;gBAAC,GAAG;oBAEA,CACC;QAChB,8BAAC,wBAAa;YACZ,8BAAC,iBAAM,IACL,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,WAAW,EACjB,OAAO,EAAE,GAAG,EAAE;oBACZ,OAAO,EAAE,CAAA;gBACX,CAAC,aAGM;YAET,8BAAC,iBAAM,IACL,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,SAAS,EACf,OAAO,EAAE,GAAG,EAAE;oBACZ,IAAI,SAAS,KAAK,SAAS,EAAE;wBAC3B,cAAc,CAAC,SAAS,CAAC,CAAA;wBACzB,OAAO,EAAE,CAAA;qBACV;gBACH,CAAC,cAGM,CACK,CACT,CACV,CAAA;AACH,CAAC;AAED,kBAAe,IAAA,qBAAQ,EAAC,oBAAoB,CAAC,CAAA"}
|
|
@@ -22,34 +22,18 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
22
22
|
__setModuleDefault(result, mod);
|
|
23
23
|
return result;
|
|
24
24
|
};
|
|
25
|
-
var __read = (this && this.__read) || function (o, n) {
|
|
26
|
-
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
27
|
-
if (!m) return o;
|
|
28
|
-
var i = m.call(o), r, ar = [], e;
|
|
29
|
-
try {
|
|
30
|
-
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
31
|
-
}
|
|
32
|
-
catch (error) { e = { error: error }; }
|
|
33
|
-
finally {
|
|
34
|
-
try {
|
|
35
|
-
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
36
|
-
}
|
|
37
|
-
finally { if (e) throw e.error; }
|
|
38
|
-
}
|
|
39
|
-
return ar;
|
|
40
|
-
};
|
|
41
25
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
42
26
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
43
27
|
};
|
|
44
28
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
29
|
+
const react_1 = __importStar(require("react"));
|
|
30
|
+
const mobx_react_1 = require("mobx-react");
|
|
31
|
+
const material_1 = require("@mui/material");
|
|
32
|
+
const mui_1 = require("tss-react/mui");
|
|
33
|
+
const Close_1 = __importDefault(require("@mui/icons-material/Close"));
|
|
34
|
+
const GetApp_1 = __importDefault(require("@mui/icons-material/GetApp"));
|
|
35
|
+
const utils_1 = require("../utils");
|
|
36
|
+
const useStyles = (0, mui_1.makeStyles)()(() => ({
|
|
53
37
|
closeDialog: {
|
|
54
38
|
position: 'absolute',
|
|
55
39
|
right: 0,
|
|
@@ -66,27 +50,26 @@ var useStyles = (0, mui_1.makeStyles)()(function () { return ({
|
|
|
66
50
|
justifyContent: 'space-evenly',
|
|
67
51
|
width: 200,
|
|
68
52
|
},
|
|
69
|
-
})
|
|
70
|
-
function DownloadBookmarks(
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
var bookmarkedRegions = model.bookmarkedRegions;
|
|
53
|
+
}));
|
|
54
|
+
function DownloadBookmarks({ model }) {
|
|
55
|
+
const { classes } = useStyles();
|
|
56
|
+
const [dialogOpen, setDialogOpen] = (0, react_1.useState)(false);
|
|
57
|
+
const [fileType, setFileType] = (0, react_1.useState)('BED');
|
|
58
|
+
const { bookmarkedRegions } = model;
|
|
76
59
|
return (react_1.default.createElement(react_1.default.Fragment, null,
|
|
77
|
-
react_1.default.createElement(material_1.Button, { startIcon: react_1.default.createElement(GetApp_1.default, null), onClick:
|
|
78
|
-
react_1.default.createElement(material_1.Dialog, { open: dialogOpen, onClose:
|
|
60
|
+
react_1.default.createElement(material_1.Button, { startIcon: react_1.default.createElement(GetApp_1.default, null), onClick: () => setDialogOpen(true) }, "Download"),
|
|
61
|
+
react_1.default.createElement(material_1.Dialog, { open: dialogOpen, onClose: () => setDialogOpen(false) },
|
|
79
62
|
react_1.default.createElement(material_1.DialogTitle, null,
|
|
80
|
-
react_1.default.createElement(material_1.IconButton, { className: classes.closeDialog, "aria-label": "close-dialog", onClick:
|
|
63
|
+
react_1.default.createElement(material_1.IconButton, { className: classes.closeDialog, "aria-label": "close-dialog", onClick: () => setDialogOpen(false) },
|
|
81
64
|
react_1.default.createElement(Close_1.default, null))),
|
|
82
65
|
react_1.default.createElement(material_1.DialogContent, null,
|
|
83
66
|
react_1.default.createElement(material_1.Typography, null, "Format to download"),
|
|
84
|
-
react_1.default.createElement(material_1.Select, { className: classes.flexItem, "data-testid": "selectFileType", value: fileType, onChange:
|
|
67
|
+
react_1.default.createElement(material_1.Select, { className: classes.flexItem, "data-testid": "selectFileType", value: fileType, onChange: event => setFileType(event.target.value) },
|
|
85
68
|
react_1.default.createElement(material_1.MenuItem, { value: "BED" }, "BED"),
|
|
86
69
|
react_1.default.createElement(material_1.MenuItem, { value: "TSV" }, "TSV"))),
|
|
87
70
|
react_1.default.createElement(material_1.DialogActions, null,
|
|
88
|
-
react_1.default.createElement(material_1.Button, { variant: "contained", color: "secondary", onClick:
|
|
89
|
-
react_1.default.createElement(material_1.Button, { className: classes.flexItem, "data-testid": "dialogDownload", variant: "contained", color: "primary", startIcon: react_1.default.createElement(GetApp_1.default, null), onClick:
|
|
71
|
+
react_1.default.createElement(material_1.Button, { variant: "contained", color: "secondary", onClick: () => setDialogOpen(false) }, "Cancel"),
|
|
72
|
+
react_1.default.createElement(material_1.Button, { className: classes.flexItem, "data-testid": "dialogDownload", variant: "contained", color: "primary", startIcon: react_1.default.createElement(GetApp_1.default, null), onClick: () => {
|
|
90
73
|
(0, utils_1.downloadBookmarkFile)(bookmarkedRegions, fileType, model);
|
|
91
74
|
setDialogOpen(false);
|
|
92
75
|
} }, "Download")))));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DownloadBookmarks.js","sourceRoot":"","sources":["../../../src/GridBookmarkWidget/components/DownloadBookmarks.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"DownloadBookmarks.js","sourceRoot":"","sources":["../../../src/GridBookmarkWidget/components/DownloadBookmarks.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,+CAAuC;AACvC,2CAAqC;AAErC,4CAUsB;AACtB,uCAA0C;AAC1C,sEAAiD;AACjD,wEAAmD;AAGnD,oCAA+C;AAE/C,MAAM,SAAS,GAAG,IAAA,gBAAU,GAAE,CAAC,GAAG,EAAE,CAAC,CAAC;IACpC,WAAW,EAAE;QACX,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,CAAC;QACR,GAAG,EAAE,CAAC;KACP;IACD,eAAe,EAAE;QACf,MAAM,EAAE,EAAE;KACX;IACD,QAAQ,EAAE;QACR,MAAM,EAAE,CAAC;KACV;IACD,aAAa,EAAE;QACb,OAAO,EAAE,MAAM;QACf,cAAc,EAAE,cAAc;QAC9B,KAAK,EAAE,GAAG;KACX;CACF,CAAC,CAAC,CAAA;AAEH,SAAS,iBAAiB,CAAC,EAAE,KAAK,EAAgC;IAChE,MAAM,EAAE,OAAO,EAAE,GAAG,SAAS,EAAE,CAAA;IAC/B,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,IAAA,gBAAQ,EAAC,KAAK,CAAC,CAAA;IACnD,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,IAAA,gBAAQ,EAAC,KAAK,CAAC,CAAA;IAC/C,MAAM,EAAE,iBAAiB,EAAE,GAAG,KAAK,CAAA;IAEnC,OAAO,CACL;QACE,8BAAC,iBAAM,IAAC,SAAS,EAAE,8BAAC,gBAAU,OAAG,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,eAE5D;QACT,8BAAC,iBAAM,IAAC,IAAI,EAAE,UAAU,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC;YAC3D,8BAAC,sBAAW;gBACV,8BAAC,qBAAU,IACT,SAAS,EAAE,OAAO,CAAC,WAAW,gBACnB,cAAc,EACzB,OAAO,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC;oBAEnC,8BAAC,eAAS,OAAG,CACF,CACD;YACd,8BAAC,wBAAa;gBACZ,8BAAC,qBAAU,6BAAgC;gBAC3C,8BAAC,iBAAM,IACL,SAAS,EAAE,OAAO,CAAC,QAAQ,iBACf,gBAAgB,EAC5B,KAAK,EAAE,QAAQ,EACf,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,WAAW,CAAC,KAAK,CAAC,MAAM,CAAC,KAAe,CAAC;oBAE5D,8BAAC,mBAAQ,IAAC,KAAK,EAAC,KAAK,UAAe;oBACpC,8BAAC,mBAAQ,IAAC,KAAK,EAAC,KAAK,UAAe,CAC7B,CACK;YAChB,8BAAC,wBAAa;gBACZ,8BAAC,iBAAM,IACL,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,WAAW,EACjB,OAAO,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC,aAG5B;gBACT,8BAAC,iBAAM,IACL,SAAS,EAAE,OAAO,CAAC,QAAQ,iBACf,gBAAgB,EAC5B,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,SAAS,EACf,SAAS,EAAE,8BAAC,gBAAU,OAAG,EACzB,OAAO,EAAE,GAAG,EAAE;wBACZ,IAAA,4BAAoB,EAAC,iBAAiB,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAA;wBACxD,aAAa,CAAC,KAAK,CAAC,CAAA;oBACtB,CAAC,eAGM,CACK,CACT,CACR,CACJ,CAAA;AACH,CAAC;AAED,kBAAe,IAAA,qBAAQ,EAAC,iBAAiB,CAAC,CAAA"}
|
|
@@ -1,15 +1,4 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __assign = (this && this.__assign) || function () {
|
|
3
|
-
__assign = Object.assign || function(t) {
|
|
4
|
-
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
-
s = arguments[i];
|
|
6
|
-
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
-
t[p] = s[p];
|
|
8
|
-
}
|
|
9
|
-
return t;
|
|
10
|
-
};
|
|
11
|
-
return __assign.apply(this, arguments);
|
|
12
|
-
};
|
|
13
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
14
3
|
if (k2 === undefined) k2 = k;
|
|
15
4
|
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
@@ -33,91 +22,57 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
33
22
|
__setModuleDefault(result, mod);
|
|
34
23
|
return result;
|
|
35
24
|
};
|
|
36
|
-
var __rest = (this && this.__rest) || function (s, e) {
|
|
37
|
-
var t = {};
|
|
38
|
-
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
39
|
-
t[p] = s[p];
|
|
40
|
-
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
41
|
-
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
42
|
-
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
43
|
-
t[p[i]] = s[p[i]];
|
|
44
|
-
}
|
|
45
|
-
return t;
|
|
46
|
-
};
|
|
47
|
-
var __read = (this && this.__read) || function (o, n) {
|
|
48
|
-
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
49
|
-
if (!m) return o;
|
|
50
|
-
var i = m.call(o), r, ar = [], e;
|
|
51
|
-
try {
|
|
52
|
-
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
53
|
-
}
|
|
54
|
-
catch (error) { e = { error: error }; }
|
|
55
|
-
finally {
|
|
56
|
-
try {
|
|
57
|
-
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
58
|
-
}
|
|
59
|
-
finally { if (e) throw e.error; }
|
|
60
|
-
}
|
|
61
|
-
return ar;
|
|
62
|
-
};
|
|
63
|
-
var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
64
|
-
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
|
|
65
|
-
if (ar || !(i in from)) {
|
|
66
|
-
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
|
|
67
|
-
ar[i] = from[i];
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
return to.concat(ar || Array.prototype.slice.call(from));
|
|
71
|
-
};
|
|
72
25
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
73
26
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
74
27
|
};
|
|
75
28
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
29
|
+
const react_1 = __importStar(require("react"));
|
|
30
|
+
const mobx_react_1 = require("mobx-react");
|
|
31
|
+
const material_1 = require("@mui/material");
|
|
32
|
+
const mui_1 = require("tss-react/mui");
|
|
33
|
+
const x_data_grid_1 = require("@mui/x-data-grid");
|
|
34
|
+
const util_1 = require("@jbrowse/core/util");
|
|
35
|
+
const Delete_1 = __importDefault(require("@mui/icons-material/Delete"));
|
|
83
36
|
// locals
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
37
|
+
const AssemblySelector_1 = __importDefault(require("./AssemblySelector"));
|
|
38
|
+
const DeleteBookmark_1 = __importDefault(require("./DeleteBookmark"));
|
|
39
|
+
const DownloadBookmarks_1 = __importDefault(require("./DownloadBookmarks"));
|
|
40
|
+
const ImportBookmarks_1 = __importDefault(require("./ImportBookmarks"));
|
|
41
|
+
const ClearBookmarks_1 = __importDefault(require("./ClearBookmarks"));
|
|
42
|
+
const utils_1 = require("../utils");
|
|
43
|
+
const useStyles = (0, mui_1.makeStyles)()(() => ({
|
|
91
44
|
link: {
|
|
92
45
|
cursor: 'pointer',
|
|
93
46
|
},
|
|
94
|
-
})
|
|
47
|
+
}));
|
|
95
48
|
// creates a coarse measurement of column width, similar to code in
|
|
96
49
|
// BaseFeatureDetails
|
|
97
50
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
};
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
51
|
+
const measure = (row, col) => Math.min(Math.max((0, util_1.measureText)(String(row[col]), 14) + 20, 80), 1000);
|
|
52
|
+
const BookmarkGrid = (0, mobx_react_1.observer)(({ model }) => {
|
|
53
|
+
const { classes } = useStyles();
|
|
54
|
+
const [dialogRowNumber, setDialogRowNumber] = (0, react_1.useState)();
|
|
55
|
+
const { bookmarkedRegions, selectedAssembly } = model;
|
|
56
|
+
const { views } = (0, util_1.getSession)(model);
|
|
57
|
+
const bookmarkRows = bookmarkedRegions
|
|
58
|
+
.filter(r => selectedAssembly === 'all' || r.assemblyName === selectedAssembly)
|
|
59
|
+
.map((region, index) => {
|
|
60
|
+
const { assemblyName, ...rest } = region;
|
|
61
|
+
return {
|
|
62
|
+
...region,
|
|
63
|
+
id: index,
|
|
64
|
+
delete: index,
|
|
65
|
+
locString: (0, util_1.assembleLocString)(selectedAssembly === 'all' ? region : rest),
|
|
66
|
+
};
|
|
112
67
|
});
|
|
113
|
-
|
|
68
|
+
const columns = [
|
|
114
69
|
{
|
|
115
70
|
field: 'locString',
|
|
116
71
|
headerName: 'bookmark link',
|
|
117
|
-
width: Math.max
|
|
118
|
-
renderCell:
|
|
119
|
-
|
|
120
|
-
return (react_1.default.createElement(material_1.Link, { className: classes.link, onClick:
|
|
72
|
+
width: Math.max(...bookmarkRows.map(row => measure(row, 'locString'))),
|
|
73
|
+
renderCell: (params) => {
|
|
74
|
+
const { value } = params;
|
|
75
|
+
return (react_1.default.createElement(material_1.Link, { className: classes.link, onClick: (event) => {
|
|
121
76
|
(0, utils_1.navToBookmark)(value, views, model);
|
|
122
77
|
event.preventDefault();
|
|
123
78
|
} }, value));
|
|
@@ -125,15 +80,15 @@ var BookmarkGrid = (0, mobx_react_1.observer)(function (_a) {
|
|
|
125
80
|
},
|
|
126
81
|
{
|
|
127
82
|
field: 'label',
|
|
128
|
-
width: Math.max(100, Math.max
|
|
83
|
+
width: Math.max(100, Math.max(...bookmarkRows.map(row => measure(row, 'label')))),
|
|
129
84
|
editable: true,
|
|
130
85
|
},
|
|
131
86
|
{
|
|
132
87
|
field: 'delete',
|
|
133
88
|
width: 30,
|
|
134
|
-
renderCell:
|
|
135
|
-
|
|
136
|
-
return (react_1.default.createElement(material_1.IconButton, { "data-testid": "deleteBookmark", "aria-label": "delete", onClick:
|
|
89
|
+
renderCell: (params) => {
|
|
90
|
+
const { value } = params;
|
|
91
|
+
return (react_1.default.createElement(material_1.IconButton, { "data-testid": "deleteBookmark", "aria-label": "delete", onClick: () => {
|
|
137
92
|
if (value !== null && value !== undefined) {
|
|
138
93
|
setDialogRowNumber(+value);
|
|
139
94
|
}
|
|
@@ -143,15 +98,14 @@ var BookmarkGrid = (0, mobx_react_1.observer)(function (_a) {
|
|
|
143
98
|
},
|
|
144
99
|
];
|
|
145
100
|
return (react_1.default.createElement(react_1.default.Fragment, null,
|
|
146
|
-
react_1.default.createElement(x_data_grid_1.DataGrid, { density: "compact", rows: bookmarkRows, columns: columns, onCellEditCommit:
|
|
147
|
-
|
|
101
|
+
react_1.default.createElement(x_data_grid_1.DataGrid, { density: "compact", rows: bookmarkRows, columns: columns, onCellEditCommit: args => {
|
|
102
|
+
const { value, id } = args;
|
|
148
103
|
model.updateBookmarkLabel(id, value);
|
|
149
104
|
}, disableSelectionOnClick: true }),
|
|
150
|
-
react_1.default.createElement(DeleteBookmark_1.default, { rowNumber: dialogRowNumber, model: model, onClose:
|
|
105
|
+
react_1.default.createElement(DeleteBookmark_1.default, { rowNumber: dialogRowNumber, model: model, onClose: () => setDialogRowNumber(undefined) })));
|
|
151
106
|
});
|
|
152
|
-
function GridBookmarkWidget(
|
|
153
|
-
|
|
154
|
-
var selectedAssembly = model.selectedAssembly;
|
|
107
|
+
function GridBookmarkWidget({ model }) {
|
|
108
|
+
const { selectedAssembly } = model;
|
|
155
109
|
return (react_1.default.createElement(react_1.default.Fragment, null,
|
|
156
110
|
react_1.default.createElement(AssemblySelector_1.default, { model: model }),
|
|
157
111
|
react_1.default.createElement(DownloadBookmarks_1.default, { model: model }),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"GridBookmarkWidget.js","sourceRoot":"","sources":["../../../src/GridBookmarkWidget/components/GridBookmarkWidget.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"GridBookmarkWidget.js","sourceRoot":"","sources":["../../../src/GridBookmarkWidget/components/GridBookmarkWidget.tsx"],"names":[],"mappings":"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"}
|