@jbrowse/core 1.7.7 → 1.7.10

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 (53) hide show
  1. package/BaseFeatureWidget/BaseFeatureDetail.d.ts +3 -6
  2. package/BaseFeatureWidget/BaseFeatureDetail.js +158 -103
  3. package/BaseFeatureWidget/index.d.ts +23 -2
  4. package/BaseFeatureWidget/index.js +98 -3
  5. package/assemblyManager/assemblyManager.d.ts +1 -1
  6. package/assemblyManager/assemblyManager.js +21 -27
  7. package/package.json +6 -2
  8. package/pluggableElementTypes/models/InternetAccountModel.d.ts +2 -2
  9. package/pluggableElementTypes/models/baseTrackConfig.js +20 -13
  10. package/pluggableElementTypes/renderers/ComparativeServerSideRendererType.js +6 -14
  11. package/pluggableElementTypes/renderers/ServerSideRendererType.d.ts +6 -0
  12. package/pluggableElementTypes/renderers/ServerSideRendererType.js +44 -2
  13. package/pluggableElementTypes/renderers/declare.d.js +1 -0
  14. package/tsconfig.build.tsbuildinfo +1 -1
  15. package/ui/AboutDialog.d.ts +1 -1
  16. package/ui/AboutDialog.js +24 -7
  17. package/ui/CascadingMenu.d.ts +9 -0
  18. package/ui/CascadingMenu.js +211 -0
  19. package/ui/Menu.d.ts +10 -0
  20. package/ui/Menu.js +9 -14
  21. package/ui/SanitizedHTML.js +26 -4
  22. package/ui/SnackbarModel.d.ts +2 -2
  23. package/ui/index.d.ts +1 -0
  24. package/ui/index.js +9 -0
  25. package/util/declare.d.js +1 -0
  26. package/util/index.d.ts +3 -0
  27. package/util/index.js +35 -1
  28. package/util/jexl.js +42 -43
  29. package/util/offscreenCanvasPonyfill.d.ts +8 -1
  30. package/util/offscreenCanvasPonyfill.js +140 -12
  31. package/util/offscreenCanvasUtils.d.ts +19 -1
  32. package/util/offscreenCanvasUtils.js +146 -12
  33. package/util/types/index.d.ts +1 -1
  34. package/util/types/mst.d.ts +9 -9
  35. package/util/offscreenCanvas/Canvas2DContextShim/Canvas2DContextShim.test.js +0 -15
  36. package/util/offscreenCanvas/Canvas2DContextShim/context.d.ts +0 -56
  37. package/util/offscreenCanvas/Canvas2DContextShim/context.js +0 -356
  38. package/util/offscreenCanvas/Canvas2DContextShim/index.d.ts +0 -2
  39. package/util/offscreenCanvas/Canvas2DContextShim/index.js +0 -13
  40. package/util/offscreenCanvas/Canvas2DContextShim/svg.d.ts +0 -3
  41. package/util/offscreenCanvas/Canvas2DContextShim/svg.js +0 -210
  42. package/util/offscreenCanvas/Canvas2DContextShim/types.d.ts +0 -50
  43. package/util/offscreenCanvas/Canvas2DContextShim/types.js +0 -59
  44. package/util/offscreenCanvas/Canvas2DContextShim/util.d.ts +0 -12
  45. package/util/offscreenCanvas/Canvas2DContextShim/util.js +0 -91
  46. package/util/offscreenCanvas/CanvasShim.d.ts +0 -11
  47. package/util/offscreenCanvas/CanvasShim.js +0 -54
  48. package/util/offscreenCanvas/index.d.ts +0 -14
  49. package/util/offscreenCanvas/index.js +0 -170
  50. package/util/offscreenCanvas/ponyfill.d.ts +0 -6
  51. package/util/offscreenCanvas/ponyfill.js +0 -145
  52. package/util/offscreenCanvas/types.d.ts +0 -16
  53. package/util/offscreenCanvas/types.js +0 -14
package/util/jexl.js CHANGED
@@ -25,15 +25,14 @@ _default() {
25
25
  j.addFunction('id', function (feature) {
26
26
  return feature.id();
27
27
  }); // let user cast a jexl type into a javascript type
28
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
29
28
 
30
29
  j.addFunction('cast', function (arg) {
31
30
  return arg;
32
31
  }); // logging
33
32
 
34
33
  j.addFunction('log', function (thing) {
35
- // eslint-disable-next-line no-console
36
- console.log(thing);
34
+ console.log(thing); // eslint-disable-line no-console
35
+
37
36
  return thing;
38
37
  }); // math
39
38
  // addfunction added in jexl 2.3 but types/jexl still on 2.2
@@ -49,66 +48,66 @@ _default() {
49
48
  j.addFunction('parseInt', Number.parseInt);
50
49
  j.addFunction('parseFloat', Number.parseFloat); // string
51
50
 
52
- j.addFunction('split', function (str, char) {
53
- return str.split(char);
51
+ j.addFunction('split', function (s, char) {
52
+ return s.split(char);
54
53
  });
55
- j.addFunction('charAt', function (str, index) {
56
- return str.charAt(index);
54
+ j.addFunction('charAt', function (s, index) {
55
+ return s.charAt(index);
57
56
  });
58
- j.addFunction('charCodeAt', function (str, index) {
59
- return str.charCodeAt(index);
57
+ j.addFunction('charCodeAt', function (s, index) {
58
+ return s.charCodeAt(index);
60
59
  });
61
- j.addFunction('codePointAt', function (str, pos) {
62
- return str.codePointAt(pos);
60
+ j.addFunction('codePointAt', function (s, pos) {
61
+ return s.codePointAt(pos);
63
62
  });
64
- j.addFunction('startsWith', function (str, searchStr, length) {
65
- return str.startsWith(searchStr, length);
63
+ j.addFunction('startsWith', function (s, search, len) {
64
+ return s.startsWith(search, len);
66
65
  });
67
- j.addFunction('endsWith', function (str, searchStr, length) {
68
- return str.endsWith(searchStr, length);
66
+ j.addFunction('endsWith', function (s, search, len) {
67
+ return s.endsWith(search, len);
69
68
  });
70
- j.addFunction('padEnd', function (str, targetLength, padString) {
71
- return str.padEnd(targetLength, padString);
69
+ j.addFunction('padEnd', function (s, len, pad) {
70
+ return s.padEnd(len, pad);
72
71
  });
73
- j.addFunction('padStart', function (str, targetLength, fillString) {
74
- return str.padStart(targetLength, fillString);
72
+ j.addFunction('padStart', function (s, len, fill) {
73
+ return s.padStart(len, fill);
75
74
  });
76
- j.addFunction('repeat', function (str, count) {
77
- return str.repeat(count);
75
+ j.addFunction('repeat', function (s, count) {
76
+ return s.repeat(count);
78
77
  });
79
- j.addFunction('replace', function (str, match, newSubStr) {
80
- return str.replace(match, newSubStr);
78
+ j.addFunction('replace', function (s, match, sub) {
79
+ return s.replace(match, sub);
81
80
  });
82
- j.addFunction('replaceAll', function (str, match, newSubStr) {
83
- return str.replaceAll(match, newSubStr);
81
+ j.addFunction('replaceAll', function (s, match, sub) {
82
+ return s.replaceAll(match, sub);
84
83
  });
85
- j.addFunction('slice', function (str, start, end) {
86
- return str.slice(start, end);
84
+ j.addFunction('slice', function (s, start, end) {
85
+ return s.slice(start, end);
87
86
  });
88
- j.addFunction('startsWith', function (str, searchStr, position) {
89
- return str.startsWith(searchStr, position);
87
+ j.addFunction('startsWith', function (s, search, pos) {
88
+ return s.startsWith(search, pos);
90
89
  });
91
- j.addFunction('substring', function (str, start, end) {
92
- return str.substring(start, end);
90
+ j.addFunction('substring', function (s, start, end) {
91
+ return s.substring(start, end);
93
92
  });
94
- j.addFunction('toLowerCase', function (str) {
95
- return str.toLowerCase();
93
+ j.addFunction('toLowerCase', function (s) {
94
+ return s.toLowerCase();
96
95
  });
97
- j.addFunction('toUpperCase', function (str) {
98
- return str.toUpperCase();
96
+ j.addFunction('toUpperCase', function (s) {
97
+ return s.toUpperCase();
99
98
  });
100
- j.addFunction('trim', function (str) {
101
- str.trim();
99
+ j.addFunction('trim', function (s) {
100
+ return s.trim();
102
101
  });
103
- j.addFunction('trimEnd', function (str) {
104
- return str.trimEnd();
102
+ j.addFunction('trimEnd', function (s) {
103
+ return s.trimEnd();
105
104
  });
106
- j.addFunction('trimStart', function (str) {
107
- return str.trimStart();
105
+ j.addFunction('trimStart', function (s) {
106
+ return s.trimStart();
108
107
  });
109
- j.addFunction('getTag', function (feature, str) {
108
+ j.addFunction('getTag', function (feature, s) {
110
109
  var tags = feature.get('tags');
111
- return tags ? tags[str] : feature.get(str);
110
+ return tags ? tags[s] : feature.get(s);
112
111
  });
113
112
  j.addBinaryOp('&', 15, function (a, b) {
114
113
  return a & b;
@@ -1 +1,8 @@
1
- export * from "./offscreenCanvas/ponyfill";
1
+ declare type AbstractCanvas = any;
2
+ declare type AbstractImageBitmap = any;
3
+ export declare let createCanvas: (width: number, height: number) => AbstractCanvas;
4
+ export declare let createImageBitmap: (canvas: AbstractCanvas) => Promise<AbstractImageBitmap>;
5
+ /** the JS class (constructor) for offscreen-generated image bitmap data */
6
+ export declare let ImageBitmapType: Function;
7
+ export declare function drawImageOntoCanvasContext(imageData: any, context: CanvasRenderingContext2D): void;
8
+ export {};
@@ -1,18 +1,146 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
3
5
  Object.defineProperty(exports, "__esModule", {
4
6
  value: true
5
7
  });
8
+ exports.createImageBitmap = exports.createCanvas = exports.ImageBitmapType = void 0;
9
+ exports.drawImageOntoCanvasContext = drawImageOntoCanvasContext;
10
+
11
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
12
+
13
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
14
+
15
+ var _detectNode = _interopRequireDefault(require("detect-node"));
16
+
17
+ var _canvasSequencer = require("canvas-sequencer");
18
+
19
+ // This file is a ponyfill for the HTML5 OffscreenCanvas API.
20
+ var createCanvas;
21
+ exports.createCanvas = createCanvas;
22
+ var createImageBitmap;
23
+ /** the JS class (constructor) for offscreen-generated image bitmap data */
24
+
25
+ exports.createImageBitmap = createImageBitmap;
26
+ var ImageBitmapType;
27
+ exports.ImageBitmapType = ImageBitmapType;
28
+
29
+ function drawImageOntoCanvasContext( // eslint-disable-next-line @typescript-eslint/no-explicit-any
30
+ imageData, context) {
31
+ if (imageData.serializedCommands) {
32
+ var seq = new _canvasSequencer.CanvasSequence(imageData.serializedCommands);
33
+ seq.execute(context);
34
+ } else if (imageData instanceof ImageBitmapType) {
35
+ context.drawImage(imageData, 0, 0);
36
+ } else if (imageData.dataURL) {
37
+ throw new Error('dataURL deserialization no longer supported');
38
+ }
39
+ }
40
+
41
+ var weHave = {
42
+ realOffscreenCanvas: typeof OffscreenCanvas === 'function',
43
+ node: _detectNode.default
44
+ };
45
+
46
+ if (weHave.realOffscreenCanvas) {
47
+ exports.createCanvas = createCanvas = function createCanvas(width, height) {
48
+ return new OffscreenCanvas(width, height);
49
+ }; // eslint-disable-next-line no-restricted-globals
50
+
51
+
52
+ exports.createImageBitmap = createImageBitmap = window.createImageBitmap || self.createImageBitmap; // eslint-disable-next-line no-restricted-globals
53
+
54
+ exports.ImageBitmapType = ImageBitmapType = window.ImageBitmap || self.ImageBitmap;
55
+ } else if (weHave.node) {
56
+ // use node-canvas if we are running in node (i.e. automated tests)
57
+ var _require = require('canvas'),
58
+ nodeCreateCanvas = _require.createCanvas,
59
+ Image = _require.Image;
60
+
61
+ exports.createCanvas = createCanvas = nodeCreateCanvas;
62
+
63
+ exports.createImageBitmap = createImageBitmap = /*#__PURE__*/function () {
64
+ var _ref = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(canvas) {
65
+ var dataUri,
66
+ img,
67
+ _args = arguments;
68
+ return _regenerator.default.wrap(function _callee$(_context) {
69
+ while (1) {
70
+ switch (_context.prev = _context.next) {
71
+ case 0:
72
+ if (!(_args.length <= 1 ? 0 : _args.length - 1)) {
73
+ _context.next = 2;
74
+ break;
75
+ }
76
+
77
+ throw new Error('only one-argument uses of createImageBitmap are supported by the node offscreencanvas ponyfill');
78
+
79
+ case 2:
80
+ dataUri = canvas.toDataURL();
81
+ img = new Image();
82
+ return _context.abrupt("return", new Promise(function (resolve, reject) {
83
+ img.onload = function () {
84
+ return resolve(img);
85
+ };
86
+
87
+ img.onerror = reject;
88
+ img.src = dataUri;
89
+ }));
90
+
91
+ case 5:
92
+ case "end":
93
+ return _context.stop();
94
+ }
95
+ }
96
+ }, _callee);
97
+ }));
98
+
99
+ return function createImageBitmap(_x) {
100
+ return _ref.apply(this, arguments);
101
+ };
102
+ }();
103
+
104
+ exports.ImageBitmapType = ImageBitmapType = Image;
105
+ } else {
106
+ exports.createCanvas = createCanvas = function createCanvas(width, height) {
107
+ var context = new _canvasSequencer.CanvasSequence();
108
+ return {
109
+ width: width,
110
+ height: height,
111
+ getContext: function getContext() {
112
+ return context;
113
+ }
114
+ };
115
+ };
116
+
117
+ exports.createImageBitmap = createImageBitmap = /*#__PURE__*/function () {
118
+ var _ref2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2(canvas) {
119
+ var ctx;
120
+ return _regenerator.default.wrap(function _callee2$(_context2) {
121
+ while (1) {
122
+ switch (_context2.prev = _context2.next) {
123
+ case 0:
124
+ ctx = canvas.getContext('2d');
125
+ return _context2.abrupt("return", {
126
+ height: canvas.height,
127
+ width: canvas.width,
128
+ serializedCommands: ctx.toJSON(),
129
+ containsNoTransferables: true
130
+ });
131
+
132
+ case 2:
133
+ case "end":
134
+ return _context2.stop();
135
+ }
136
+ }
137
+ }, _callee2);
138
+ }));
139
+
140
+ return function createImageBitmap(_x2) {
141
+ return _ref2.apply(this, arguments);
142
+ };
143
+ }();
6
144
 
7
- var _ponyfill = require("./offscreenCanvas/ponyfill");
8
-
9
- Object.keys(_ponyfill).forEach(function (key) {
10
- if (key === "default" || key === "__esModule") return;
11
- if (key in exports && exports[key] === _ponyfill[key]) return;
12
- Object.defineProperty(exports, key, {
13
- enumerable: true,
14
- get: function get() {
15
- return _ponyfill[key];
16
- }
17
- });
18
- });
145
+ exports.ImageBitmapType = ImageBitmapType = String;
146
+ }
@@ -1 +1,19 @@
1
- export * from './offscreenCanvas';
1
+ /// <reference types="react" />
2
+ export declare function renderToAbstractCanvas(width: number, height: number, opts: {
3
+ exportSVG?: {
4
+ rasterizeLayers?: boolean;
5
+ };
6
+ highResolutionScaling: number;
7
+ }, cb: Function): Promise<{
8
+ canvasRecordedData: any;
9
+ reactElement?: undefined;
10
+ imageData?: undefined;
11
+ } | {
12
+ reactElement: JSX.Element;
13
+ canvasRecordedData?: undefined;
14
+ imageData?: undefined;
15
+ } | {
16
+ imageData: any;
17
+ canvasRecordedData?: undefined;
18
+ reactElement?: undefined;
19
+ }>;
@@ -1,18 +1,152 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
3
5
  Object.defineProperty(exports, "__esModule", {
4
6
  value: true
5
7
  });
8
+ exports.renderToAbstractCanvas = renderToAbstractCanvas;
9
+
10
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
11
+
12
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
13
+
14
+ var _react = _interopRequireDefault(require("react"));
15
+
16
+ var _offscreenCanvasPonyfill = require("./offscreenCanvasPonyfill");
17
+
18
+ var _canvasSequencer = require("canvas-sequencer");
19
+
20
+ var _index = require("./index");
21
+
22
+ function renderToAbstractCanvas(_x, _x2, _x3, _x4) {
23
+ return _renderToAbstractCanvas.apply(this, arguments);
24
+ }
25
+
26
+ function _renderToAbstractCanvas() {
27
+ _renderToAbstractCanvas = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(width, height, opts, cb) {
28
+ var exportSVG, _opts$highResolutionS, highResolutionScaling, fakeCtx, scale, canvas, ctx, _canvas, _ctx;
29
+
30
+ return _regenerator.default.wrap(function _callee$(_context) {
31
+ while (1) {
32
+ switch (_context.prev = _context.next) {
33
+ case 0:
34
+ exportSVG = opts.exportSVG, _opts$highResolutionS = opts.highResolutionScaling, highResolutionScaling = _opts$highResolutionS === void 0 ? 1 : _opts$highResolutionS;
35
+
36
+ if (!exportSVG) {
37
+ _context.next = 37;
38
+ break;
39
+ }
40
+
41
+ if (exportSVG.rasterizeLayers) {
42
+ _context.next = 9;
43
+ break;
44
+ }
45
+
46
+ fakeCtx = new _canvasSequencer.CanvasSequence();
47
+ _context.next = 6;
48
+ return cb(fakeCtx);
49
+
50
+ case 6:
51
+ return _context.abrupt("return", {
52
+ canvasRecordedData: fakeCtx.toJSON()
53
+ });
54
+
55
+ case 9:
56
+ scale = 4;
57
+ canvas = (0, _offscreenCanvasPonyfill.createCanvas)(Math.ceil(width * scale), height * scale);
58
+ ctx = canvas.getContext('2d');
59
+
60
+ if (ctx) {
61
+ _context.next = 14;
62
+ break;
63
+ }
64
+
65
+ throw new Error('2d canvas rendering not supported on this platform');
66
+
67
+ case 14:
68
+ ctx.scale(scale, scale);
69
+ _context.next = 17;
70
+ return cb(ctx);
71
+
72
+ case 17:
73
+ _context.t0 = _react.default;
74
+ _context.t1 = width;
75
+ _context.t2 = height;
76
+
77
+ if (!('convertToBlob' in canvas)) {
78
+ _context.next = 30;
79
+ break;
80
+ }
81
+
82
+ _context.t4 = _index.blobToDataURL;
83
+ _context.next = 24;
84
+ return canvas.convertToBlob({
85
+ type: 'image/png'
86
+ });
87
+
88
+ case 24:
89
+ _context.t5 = _context.sent;
90
+ _context.next = 27;
91
+ return (0, _context.t4)(_context.t5);
92
+
93
+ case 27:
94
+ _context.t3 = _context.sent;
95
+ _context.next = 31;
96
+ break;
97
+
98
+ case 30:
99
+ _context.t3 = canvas.toDataURL();
100
+
101
+ case 31:
102
+ _context.t6 = _context.t3;
103
+ _context.t7 = {
104
+ width: _context.t1,
105
+ height: _context.t2,
106
+ xlinkHref: _context.t6
107
+ };
108
+ _context.t8 = _context.t0.createElement.call(_context.t0, "image", _context.t7);
109
+ return _context.abrupt("return", {
110
+ reactElement: _context.t8
111
+ });
112
+
113
+ case 35:
114
+ _context.next = 48;
115
+ break;
116
+
117
+ case 37:
118
+ _canvas = (0, _offscreenCanvasPonyfill.createCanvas)(Math.ceil(width * highResolutionScaling), height * highResolutionScaling);
119
+ _ctx = _canvas.getContext('2d');
120
+
121
+ if (_ctx) {
122
+ _context.next = 41;
123
+ break;
124
+ }
125
+
126
+ throw new Error('2d canvas rendering not supported on this platform');
127
+
128
+ case 41:
129
+ _ctx.scale(highResolutionScaling, highResolutionScaling);
130
+
131
+ _context.next = 44;
132
+ return cb(_ctx);
133
+
134
+ case 44:
135
+ _context.next = 46;
136
+ return (0, _offscreenCanvasPonyfill.createImageBitmap)(_canvas);
137
+
138
+ case 46:
139
+ _context.t9 = _context.sent;
140
+ return _context.abrupt("return", {
141
+ imageData: _context.t9
142
+ });
6
143
 
7
- var _offscreenCanvas = require("./offscreenCanvas");
8
-
9
- Object.keys(_offscreenCanvas).forEach(function (key) {
10
- if (key === "default" || key === "__esModule") return;
11
- if (key in exports && exports[key] === _offscreenCanvas[key]) return;
12
- Object.defineProperty(exports, key, {
13
- enumerable: true,
14
- get: function get() {
15
- return _offscreenCanvas[key];
16
- }
17
- });
18
- });
144
+ case 48:
145
+ case "end":
146
+ return _context.stop();
147
+ }
148
+ }
149
+ }, _callee);
150
+ }));
151
+ return _renderToAbstractCanvas.apply(this, arguments);
152
+ }
@@ -13,7 +13,7 @@ export * from './util';
13
13
  export interface AbstractViewContainer extends IAnyStateTreeNode {
14
14
  views: AbstractViewModel[];
15
15
  removeView(view: AbstractViewModel): void;
16
- addView(typeName: string, initialState: Record<string, unknown>): void | AbstractViewModel;
16
+ addView(typeName: string, initialState?: Record<string, unknown>): void | AbstractViewModel;
17
17
  }
18
18
  export declare function isViewContainer(thing: unknown): thing is AbstractViewContainer;
19
19
  export declare type NotificationLevel = 'error' | 'info' | 'warning' | 'success';
@@ -77,13 +77,13 @@ export declare const FileLocation: import("mobx-state-tree").ISnapshotProcessor<
77
77
  internetAccountType: import("mobx-state-tree").ISimpleType<string>;
78
78
  authInfo: import("mobx-state-tree").IType<any, any, any>;
79
79
  }, {}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>;
80
- }>> | import("mobx-state-tree").ModelCreationType<import("mobx-state-tree/dist/internal").ExtractCFromProps<{
81
- locationType: import("mobx-state-tree").ISimpleType<"LocalPathLocation">;
82
- localPath: import("mobx-state-tree").ISimpleType<string>;
83
80
  }>> | import("mobx-state-tree").ModelCreationType<import("mobx-state-tree/dist/internal").ExtractCFromProps<{
84
81
  locationType: import("mobx-state-tree").ISimpleType<"BlobLocation">;
85
82
  name: import("mobx-state-tree").ISimpleType<string>;
86
83
  blobId: import("mobx-state-tree").ISimpleType<string>;
84
+ }>> | import("mobx-state-tree").ModelCreationType<import("mobx-state-tree/dist/internal").ExtractCFromProps<{
85
+ locationType: import("mobx-state-tree").ISimpleType<"LocalPathLocation">;
86
+ localPath: import("mobx-state-tree").ISimpleType<string>;
87
87
  }>>, {
88
88
  locationType: "UriLocation";
89
89
  uri: string;
@@ -93,12 +93,12 @@ export declare const FileLocation: import("mobx-state-tree").ISnapshotProcessor<
93
93
  authInfo: import("mobx-state-tree").IType<any, any, any>;
94
94
  }> | undefined;
95
95
  } | import("mobx-state-tree").ModelSnapshotType<{
96
- locationType: import("mobx-state-tree").ISimpleType<"LocalPathLocation">;
97
- localPath: import("mobx-state-tree").ISimpleType<string>;
98
- }> | import("mobx-state-tree").ModelSnapshotType<{
99
96
  locationType: import("mobx-state-tree").ISimpleType<"BlobLocation">;
100
97
  name: import("mobx-state-tree").ISimpleType<string>;
101
98
  blobId: import("mobx-state-tree").ISimpleType<string>;
99
+ }> | import("mobx-state-tree").ModelSnapshotType<{
100
+ locationType: import("mobx-state-tree").ISimpleType<"LocalPathLocation">;
101
+ localPath: import("mobx-state-tree").ISimpleType<string>;
102
102
  }>, import("mobx-state-tree").ModelCreationType<import("mobx-state-tree/dist/internal").ExtractCFromProps<{
103
103
  locationType: import("mobx-state-tree").ISimpleType<"UriLocation">;
104
104
  uri: import("mobx-state-tree").ISimpleType<string>;
@@ -109,10 +109,10 @@ export declare const FileLocation: import("mobx-state-tree").ISnapshotProcessor<
109
109
  authInfo: import("mobx-state-tree").IType<any, any, any>;
110
110
  }, {}, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>>;
111
111
  }>> | import("mobx-state-tree").ModelInstanceTypeProps<{
112
- locationType: import("mobx-state-tree").ISimpleType<"LocalPathLocation">;
113
- localPath: import("mobx-state-tree").ISimpleType<string>;
114
- }> | import("mobx-state-tree").ModelInstanceTypeProps<{
115
112
  locationType: import("mobx-state-tree").ISimpleType<"BlobLocation">;
116
113
  name: import("mobx-state-tree").ISimpleType<string>;
117
114
  blobId: import("mobx-state-tree").ISimpleType<string>;
115
+ }> | import("mobx-state-tree").ModelInstanceTypeProps<{
116
+ locationType: import("mobx-state-tree").ISimpleType<"LocalPathLocation">;
117
+ localPath: import("mobx-state-tree").ISimpleType<string>;
118
118
  }>>, import("mobx-state-tree")._NotCustomized, import("mobx-state-tree")._NotCustomized>;
@@ -1,15 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
5
- var _ = _interopRequireDefault(require("."));
6
-
7
- test('serialize a single command and read back out', function () {
8
- var ctx = new _.default(100, 100);
9
- ctx.arc(20, 21, 22, 23, 24);
10
- var cmds = Array.from(ctx.getCommands());
11
- expect(cmds).toEqual([{
12
- name: 'arc',
13
- args: [20, 21, 22, 23, 24]
14
- }]);
15
- });
@@ -1,56 +0,0 @@
1
- /// <reference types="react" />
2
- /// <reference types="offscreencanvas" />
3
- import { Command } from './types';
4
- /** get the params type of real method in OffscreenCanvasRenderingContext2D */
5
- declare type RealP<METHODNAME extends keyof OffscreenCanvasRenderingContext2D> = OffscreenCanvasRenderingContext2D[METHODNAME] extends (...arg0: any[]) => any ? Parameters<OffscreenCanvasRenderingContext2D[METHODNAME]> : never;
6
- /** get the return type of real method in OffscreenCanvasRenderingContext2D */
7
- declare type RealRet<METHODNAME extends keyof OffscreenCanvasRenderingContext2D> = OffscreenCanvasRenderingContext2D[METHODNAME] extends (...arg0: any[]) => any ? ReturnType<OffscreenCanvasRenderingContext2D[METHODNAME]> : never;
8
- /** get the type of the params of a method of the canvas shim */
9
- export declare type ShimP<METHODNAME extends keyof OffscreenCanvasRenderingContext2DShim> = OffscreenCanvasRenderingContext2DShim[METHODNAME] extends (...arg0: any[]) => any ? Parameters<OffscreenCanvasRenderingContext2DShim[METHODNAME]> : never;
10
- /** decode all the commands in the given buffer and replay them onto the given context */
11
- export declare function replayCommandsOntoContext(targetContext: CanvasRenderingContext2D, encodedCommands: Iterable<Command>): void;
12
- export default class OffscreenCanvasRenderingContext2DShim {
13
- width: number;
14
- height: number;
15
- currentFont: string;
16
- currentStrokeStyle: string;
17
- currentFillStyle: string;
18
- recordedCommands: Command[];
19
- constructor(width: number, height: number);
20
- private pushMethodCall;
21
- private pushSetterCall;
22
- getSerializedCommands(): Command[];
23
- getSerializedSvg(): JSX.Element;
24
- getCommands(): Command[];
25
- set strokeStyle(style: string);
26
- set fillStyle(style: string);
27
- set font(style: string);
28
- arc(...args: RealP<'arc'>): RealRet<'arc'>;
29
- arcTo(...args: RealP<'arcTo'>): RealRet<'arcTo'>;
30
- beginPath(...args: RealP<'beginPath'>): RealRet<'beginPath'>;
31
- clearRect(...args: RealP<'clearRect'>): RealRet<'clearRect'>;
32
- closePath(...args: RealP<'closePath'>): RealRet<'closePath'>;
33
- ellipse(...args: RealP<'ellipse'>): RealRet<'ellipse'>;
34
- fill(...args: RealP<'fill'>): RealRet<'fill'>;
35
- fillRect(...args: RealP<'fillRect'>): RealRet<'fillRect'>;
36
- fillText(...args: RealP<'fillText'>): RealRet<'fillText'>;
37
- lineTo(...args: RealP<'lineTo'>): RealRet<'lineTo'>;
38
- measureText(...args: RealP<'measureText'>): {
39
- width: number;
40
- height: number;
41
- };
42
- moveTo(...args: RealP<'moveTo'>): RealRet<'moveTo'>;
43
- quadraticCurveTo(...args: RealP<'quadraticCurveTo'>): RealRet<'quadraticCurveTo'>;
44
- rect(...args: RealP<'rect'>): RealRet<'rect'>;
45
- restore(...args: RealP<'restore'>): RealRet<'restore'>;
46
- rotate(...args: RealP<'rotate'>): RealRet<'rotate'>;
47
- save(...args: RealP<'save'>): RealRet<'save'>;
48
- setTransform(...args: RealP<'setTransform'>): RealRet<'setTransform'>;
49
- scale(...args: RealP<'scale'>): RealRet<'scale'>;
50
- stroke(): RealRet<'stroke'>;
51
- strokeRect(...args: RealP<'strokeRect'>): RealRet<'strokeRect'>;
52
- strokeText(...args: RealP<'strokeText'>): RealRet<'strokeText'>;
53
- transform(...args: RealP<'transform'>): RealRet<'transform'>;
54
- translate(...args: RealP<'translate'>): RealRet<'translate'>;
55
- }
56
- export {};