@pie-lib/tools 0.9.36 → 0.11.0-beta.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.
- package/CHANGELOG.md +16 -0
- package/NEXT.CHANGELOG.json +1 -0
- package/lib/__tests__/anchor-utils.test.js +228 -0
- package/lib/__tests__/rotatable.test.js +255 -0
- package/lib/__tests__/transform-origin.test.js +63 -0
- package/lib/anchor-utils.js +1 -1
- package/lib/anchor.js +1 -1
- package/lib/index.js +1 -1
- package/lib/protractor/__tests__/graphic.test.js +27 -0
- package/lib/protractor/__tests__/index.test.js +23 -0
- package/lib/protractor/graphic.js +1 -1
- package/lib/protractor/index.js +1 -1
- package/lib/rotatable.js +1 -1
- package/lib/ruler/__tests__/graphic.test.js +31 -0
- package/lib/ruler/__tests__/index.test.js +51 -0
- package/lib/ruler/__tests__/unit-type.test.js +24 -0
- package/lib/ruler/__tests__/unit.test.js +30 -0
- package/lib/ruler/graphic.js +1 -1
- package/lib/ruler/index.js +1 -1
- package/lib/ruler/unit-type.js +1 -1
- package/lib/ruler/unit.js +1 -1
- package/lib/style-utils.js +1 -1
- package/lib/transform-origin.js +1 -1
- package/package.json +3 -3
- package/src/__tests__/__snapshots__/rotatable.test.jsx.snap +37 -0
- package/src/__tests__/anchor-utils.test.js +131 -0
- package/src/__tests__/rotatable.test.jsx +220 -0
- package/src/__tests__/transform-origin.test.jsx +24 -0
- package/src/index.js +1 -0
- package/src/protractor/__tests__/__snapshots__/graphic.test.jsx.snap +1234 -0
- package/src/protractor/__tests__/__snapshots__/index.test.jsx.snap +40 -0
- package/src/protractor/__tests__/graphic.test.jsx +13 -0
- package/src/protractor/__tests__/index.test.jsx +13 -0
- package/src/ruler/__tests__/__snapshots__/graphic.test.jsx.snap +160 -0
- package/src/ruler/__tests__/__snapshots__/index.test.jsx.snap +45 -0
- package/src/ruler/__tests__/__snapshots__/unit-type.test.jsx.snap +12 -0
- package/src/ruler/__tests__/__snapshots__/unit.test.jsx.snap +30 -0
- package/src/ruler/__tests__/graphic.test.jsx +23 -0
- package/src/ruler/__tests__/index.test.jsx +28 -0
- package/src/ruler/__tests__/unit-type.test.jsx +13 -0
- package/src/ruler/__tests__/unit.test.jsx +15 -0
- package/lib/anchor-utils.js.map +0 -1
- package/lib/anchor.js.map +0 -1
- package/lib/index.js.map +0 -1
- package/lib/protractor/graphic.js.map +0 -1
- package/lib/protractor/index.js.map +0 -1
- package/lib/rotatable.js.map +0 -1
- package/lib/ruler/graphic.js.map +0 -1
- package/lib/ruler/index.js.map +0 -1
- package/lib/ruler/unit-type.js.map +0 -1
- package/lib/ruler/unit.js.map +0 -1
- package/lib/style-utils.js.map +0 -1
- package/lib/transform-origin.js.map +0 -1
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,22 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
# [0.11.0-beta.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/tools@0.9.36...@pie-lib/tools@0.11.0-beta.0) (2025-07-15)
|
|
7
|
+
|
|
8
|
+
**Note:** Version bump only for package @pie-lib/tools
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
# [0.10.0-beta.0](https://github.com/pie-framework/pie-lib/compare/@pie-lib/tools@0.9.36...@pie-lib/tools@0.10.0-beta.0) (2025-07-15)
|
|
15
|
+
|
|
16
|
+
**Note:** Version bump only for package @pie-lib/tools
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
|
|
6
22
|
## [0.9.36](https://github.com/pie-framework/pie-lib/compare/@pie-lib/tools@0.9.35...@pie-lib/tools@0.9.36) (2023-06-24)
|
|
7
23
|
|
|
8
24
|
**Note:** Version bump only for package @pie-lib/tools
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
[]
|
|
@@ -0,0 +1,228 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
6
|
+
|
|
7
|
+
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
|
|
8
|
+
|
|
9
|
+
var _anchorUtils = require("../anchor-utils");
|
|
10
|
+
|
|
11
|
+
var _templateObject;
|
|
12
|
+
|
|
13
|
+
var o = function o(strings) {
|
|
14
|
+
for (var _len = arguments.length, exp = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
|
|
15
|
+
exp[_key - 1] = arguments[_key];
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
return strings.reduce(function (acc, v, index) {
|
|
19
|
+
var e = exp[index];
|
|
20
|
+
var s = (0, _typeof2["default"])(e) === 'object' ? JSON.stringify(e) : e;
|
|
21
|
+
return "".concat(acc).concat(v).concat(s || '');
|
|
22
|
+
}, '');
|
|
23
|
+
};
|
|
24
|
+
|
|
25
|
+
var rect = {
|
|
26
|
+
width: 100,
|
|
27
|
+
height: 100
|
|
28
|
+
};
|
|
29
|
+
describe('getAngleAndHypotenuse', function () {
|
|
30
|
+
var assert = function assert(corner, rect, point, expected) {
|
|
31
|
+
it(o(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["", ", ", ", ", " => ", ""])), corner, rect, point, expected), function () {
|
|
32
|
+
var result = (0, _anchorUtils.getAngleAndHypotenuse)(corner, rect, point);
|
|
33
|
+
expect(result).toMatchObject(expected);
|
|
34
|
+
});
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
assert('top-left', rect, {
|
|
38
|
+
x: 50,
|
|
39
|
+
y: 50
|
|
40
|
+
}, {
|
|
41
|
+
degrees: -45
|
|
42
|
+
});
|
|
43
|
+
assert('bottom-left', rect, {
|
|
44
|
+
x: 50,
|
|
45
|
+
y: 50
|
|
46
|
+
}, {
|
|
47
|
+
degrees: -135
|
|
48
|
+
});
|
|
49
|
+
assert('top-right', rect, {
|
|
50
|
+
x: 50,
|
|
51
|
+
y: 50
|
|
52
|
+
}, {
|
|
53
|
+
degrees: 45
|
|
54
|
+
});
|
|
55
|
+
assert('bottom-right', rect, {
|
|
56
|
+
x: 50,
|
|
57
|
+
y: 50
|
|
58
|
+
}, {
|
|
59
|
+
degrees: 135
|
|
60
|
+
});
|
|
61
|
+
});
|
|
62
|
+
describe('getAnchor', function () {
|
|
63
|
+
describe('rect', function () {
|
|
64
|
+
it('does this: ', function () {
|
|
65
|
+
var result = (0, _anchorUtils.getAnchor)({
|
|
66
|
+
width: 400,
|
|
67
|
+
height: 100
|
|
68
|
+
}, {
|
|
69
|
+
x: 0,
|
|
70
|
+
y: 100
|
|
71
|
+
}, 0);
|
|
72
|
+
expect(result.top).not.toBeUndefined();
|
|
73
|
+
expect(result.left).not.toBeUndefined();
|
|
74
|
+
});
|
|
75
|
+
});
|
|
76
|
+
describe('square', function () {
|
|
77
|
+
it('square @ 45', function () {
|
|
78
|
+
var result = (0, _anchorUtils.getAnchor)({
|
|
79
|
+
width: 100,
|
|
80
|
+
height: 100
|
|
81
|
+
}, {
|
|
82
|
+
x: 50,
|
|
83
|
+
y: 50
|
|
84
|
+
}, 45);
|
|
85
|
+
expect(result.top).toBeCloseTo(70.71);
|
|
86
|
+
expect(result.left).toBeCloseTo(70.71);
|
|
87
|
+
});
|
|
88
|
+
it('square @ 90', function () {
|
|
89
|
+
var result = (0, _anchorUtils.getAnchor)({
|
|
90
|
+
width: 100,
|
|
91
|
+
height: 100
|
|
92
|
+
}, {
|
|
93
|
+
x: 50,
|
|
94
|
+
y: 50
|
|
95
|
+
}, 90);
|
|
96
|
+
expect(result.top).toBeCloseTo(50);
|
|
97
|
+
expect(result.left).toBeCloseTo(50);
|
|
98
|
+
});
|
|
99
|
+
it('square @ 180', function () {
|
|
100
|
+
var result = (0, _anchorUtils.getAnchor)({
|
|
101
|
+
width: 100,
|
|
102
|
+
height: 100
|
|
103
|
+
}, {
|
|
104
|
+
x: 50,
|
|
105
|
+
y: 50
|
|
106
|
+
}, 180);
|
|
107
|
+
expect(result.top).toBeCloseTo(50);
|
|
108
|
+
expect(result.left).toBeCloseTo(50);
|
|
109
|
+
});
|
|
110
|
+
it('square @ 270', function () {
|
|
111
|
+
var result = (0, _anchorUtils.getAnchor)({
|
|
112
|
+
width: 100,
|
|
113
|
+
height: 100
|
|
114
|
+
}, {
|
|
115
|
+
x: 50,
|
|
116
|
+
y: 50
|
|
117
|
+
}, 180);
|
|
118
|
+
expect(result.top).toBeCloseTo(50);
|
|
119
|
+
expect(result.left).toBeCloseTo(50);
|
|
120
|
+
});
|
|
121
|
+
it('square @ -45 - bottom right anchor', function () {
|
|
122
|
+
var result = (0, _anchorUtils.getAnchor)({
|
|
123
|
+
width: 100,
|
|
124
|
+
height: 100
|
|
125
|
+
}, {
|
|
126
|
+
x: 100,
|
|
127
|
+
y: 100
|
|
128
|
+
}, -45);
|
|
129
|
+
expect(result.left).toBeCloseTo(141.42);
|
|
130
|
+
expect(result.top).toBeCloseTo(70.71);
|
|
131
|
+
});
|
|
132
|
+
it('square @ 45 - bottom right anchor', function () {
|
|
133
|
+
var result = (0, _anchorUtils.getAnchor)({
|
|
134
|
+
width: 100,
|
|
135
|
+
height: 100
|
|
136
|
+
}, {
|
|
137
|
+
x: 100,
|
|
138
|
+
y: 100
|
|
139
|
+
}, 45);
|
|
140
|
+
expect(result.top).toBeCloseTo(141.42);
|
|
141
|
+
expect(result.left).toBeCloseTo(70.71);
|
|
142
|
+
});
|
|
143
|
+
it('square @ 20 - bottom right anchor', function () {
|
|
144
|
+
var result = (0, _anchorUtils.getAnchor)({
|
|
145
|
+
width: 100,
|
|
146
|
+
height: 100
|
|
147
|
+
}, {
|
|
148
|
+
x: 100,
|
|
149
|
+
y: 100
|
|
150
|
+
}, 20);
|
|
151
|
+
expect(result.top).toBeCloseTo(128.17);
|
|
152
|
+
expect(result.left).toBeCloseTo(93.969);
|
|
153
|
+
});
|
|
154
|
+
it('square @ 45, shifted center', function () {
|
|
155
|
+
var result = (0, _anchorUtils.getAnchor)({
|
|
156
|
+
width: 100,
|
|
157
|
+
height: 100
|
|
158
|
+
}, {
|
|
159
|
+
x: 25,
|
|
160
|
+
y: 25
|
|
161
|
+
}, 45);
|
|
162
|
+
expect(result.top).toBeCloseTo(35.36);
|
|
163
|
+
expect(result.left).toBeCloseTo(70.71);
|
|
164
|
+
});
|
|
165
|
+
it('square @ 20, shifted center', function () {
|
|
166
|
+
var result = (0, _anchorUtils.getAnchor)({
|
|
167
|
+
width: 100,
|
|
168
|
+
height: 100
|
|
169
|
+
}, {
|
|
170
|
+
x: 25,
|
|
171
|
+
y: 25
|
|
172
|
+
}, 20);
|
|
173
|
+
expect(result.top).toBeCloseTo(32.04);
|
|
174
|
+
expect(result.left).toBeCloseTo(49.14);
|
|
175
|
+
});
|
|
176
|
+
it('square @ 20', function () {
|
|
177
|
+
var result = (0, _anchorUtils.getAnchor)({
|
|
178
|
+
width: 100,
|
|
179
|
+
height: 100
|
|
180
|
+
}, {
|
|
181
|
+
x: 50,
|
|
182
|
+
y: 50
|
|
183
|
+
}, 20);
|
|
184
|
+
expect(result.top).toBeCloseTo(64.085);
|
|
185
|
+
expect(result.left).toBeCloseTo(64.085);
|
|
186
|
+
});
|
|
187
|
+
it('square @ 135', function () {
|
|
188
|
+
var result = (0, _anchorUtils.getAnchor)({
|
|
189
|
+
width: 100,
|
|
190
|
+
height: 100
|
|
191
|
+
}, {
|
|
192
|
+
x: 50,
|
|
193
|
+
y: 50
|
|
194
|
+
}, 135);
|
|
195
|
+
expect(result.top).toBeCloseTo(70.71);
|
|
196
|
+
expect(result.left).toBeCloseTo(70.71);
|
|
197
|
+
});
|
|
198
|
+
it('square @ 225', function () {
|
|
199
|
+
var result = (0, _anchorUtils.getAnchor)({
|
|
200
|
+
width: 100,
|
|
201
|
+
height: 100
|
|
202
|
+
}, {
|
|
203
|
+
x: 50,
|
|
204
|
+
y: 50
|
|
205
|
+
}, 135);
|
|
206
|
+
expect(result.top).toBeCloseTo(70.71);
|
|
207
|
+
expect(result.left).toBeCloseTo(70.71);
|
|
208
|
+
});
|
|
209
|
+
});
|
|
210
|
+
});
|
|
211
|
+
describe('normalizeAngle', function () {
|
|
212
|
+
var assert = function assert(a, expected) {
|
|
213
|
+
it("".concat(a, " -> ").concat(expected), function () {
|
|
214
|
+
expect((0, _anchorUtils.normalizeAngle)(a)).toEqual(expected);
|
|
215
|
+
});
|
|
216
|
+
};
|
|
217
|
+
|
|
218
|
+
assert(360, 360);
|
|
219
|
+
assert(0, 0);
|
|
220
|
+
assert(10, 10);
|
|
221
|
+
assert(361, 1);
|
|
222
|
+
assert(450, 90);
|
|
223
|
+
assert(721, 1);
|
|
224
|
+
assert(-1, 359);
|
|
225
|
+
assert(-361, 359);
|
|
226
|
+
assert(-721, 359);
|
|
227
|
+
});
|
|
228
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/__tests__/anchor-utils.test.js"],"names":["o","strings","exp","reduce","acc","v","index","e","s","JSON","stringify","rect","width","height","describe","assert","corner","point","expected","it","result","expect","toMatchObject","x","y","degrees","top","not","toBeUndefined","left","toBeCloseTo","a","toEqual"],"mappings":"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","sourcesContent":["import { getAnchor, normalizeAngle, getAngleAndHypotenuse, getTranslateXY } from '../anchor-utils';\n\nconst o = (strings, ...exp) => {\n  return strings.reduce((acc, v, index) => {\n    const e = exp[index];\n    const s = typeof e === 'object' ? JSON.stringify(e) : e;\n    return `${acc}${v}${s || ''}`;\n  }, '');\n};\n\nconst rect = { width: 100, height: 100 };\n\ndescribe('getAngleAndHypotenuse', () => {\n  const assert = (corner, rect, point, expected) => {\n    it(o`${corner}, ${rect}, ${point} => ${expected}`, () => {\n      const result = getAngleAndHypotenuse(corner, rect, point);\n      expect(result).toMatchObject(expected);\n    });\n  };\n  assert('top-left', rect, { x: 50, y: 50 }, { degrees: -45 });\n  assert('bottom-left', rect, { x: 50, y: 50 }, { degrees: -135 });\n  assert('top-right', rect, { x: 50, y: 50 }, { degrees: 45 });\n  assert('bottom-right', rect, { x: 50, y: 50 }, { degrees: 135 });\n});\n\ndescribe('getAnchor', () => {\n  describe('rect', () => {\n    it('does this: ', () => {\n      const result = getAnchor(\n        {\n          width: 400,\n          height: 100,\n        },\n        { x: 0, y: 100 },\n        0,\n      );\n      expect(result.top).not.toBeUndefined();\n      expect(result.left).not.toBeUndefined();\n    });\n  });\n  describe('square', () => {\n    it('square @ 45', () => {\n      const result = getAnchor({ width: 100, height: 100 }, { x: 50, y: 50 }, 45);\n      expect(result.top).toBeCloseTo(70.71);\n      expect(result.left).toBeCloseTo(70.71);\n    });\n    it('square @ 90', () => {\n      const result = getAnchor({ width: 100, height: 100 }, { x: 50, y: 50 }, 90);\n      expect(result.top).toBeCloseTo(50);\n      expect(result.left).toBeCloseTo(50);\n    });\n\n    it('square @ 180', () => {\n      const result = getAnchor({ width: 100, height: 100 }, { x: 50, y: 50 }, 180);\n      expect(result.top).toBeCloseTo(50);\n      expect(result.left).toBeCloseTo(50);\n    });\n\n    it('square @ 270', () => {\n      const result = getAnchor({ width: 100, height: 100 }, { x: 50, y: 50 }, 180);\n      expect(result.top).toBeCloseTo(50);\n      expect(result.left).toBeCloseTo(50);\n    });\n\n    it('square @ -45 - bottom right anchor', () => {\n      const result = getAnchor({ width: 100, height: 100 }, { x: 100, y: 100 }, -45);\n      expect(result.left).toBeCloseTo(141.42);\n      expect(result.top).toBeCloseTo(70.71);\n    });\n\n    it('square @ 45 - bottom right anchor', () => {\n      const result = getAnchor({ width: 100, height: 100 }, { x: 100, y: 100 }, 45);\n      expect(result.top).toBeCloseTo(141.42);\n      expect(result.left).toBeCloseTo(70.71);\n    });\n\n    it('square @ 20 - bottom right anchor', () => {\n      const result = getAnchor({ width: 100, height: 100 }, { x: 100, y: 100 }, 20);\n\n      expect(result.top).toBeCloseTo(128.17);\n      expect(result.left).toBeCloseTo(93.969);\n    });\n\n    it('square @ 45, shifted center', () => {\n      const result = getAnchor({ width: 100, height: 100 }, { x: 25, y: 25 }, 45);\n      expect(result.top).toBeCloseTo(35.36);\n      expect(result.left).toBeCloseTo(70.71);\n    });\n\n    it('square @ 20, shifted center', () => {\n      const result = getAnchor({ width: 100, height: 100 }, { x: 25, y: 25 }, 20);\n      expect(result.top).toBeCloseTo(32.04);\n      expect(result.left).toBeCloseTo(49.14);\n    });\n\n    it('square @ 20', () => {\n      const result = getAnchor({ width: 100, height: 100 }, { x: 50, y: 50 }, 20);\n      expect(result.top).toBeCloseTo(64.085);\n      expect(result.left).toBeCloseTo(64.085);\n    });\n\n    it('square @ 135', () => {\n      const result = getAnchor({ width: 100, height: 100 }, { x: 50, y: 50 }, 135);\n      expect(result.top).toBeCloseTo(70.71);\n      expect(result.left).toBeCloseTo(70.71);\n    });\n    it('square @ 225', () => {\n      const result = getAnchor({ width: 100, height: 100 }, { x: 50, y: 50 }, 135);\n      expect(result.top).toBeCloseTo(70.71);\n      expect(result.left).toBeCloseTo(70.71);\n    });\n  });\n});\n\ndescribe('normalizeAngle', () => {\n  const assert = (a, expected) => {\n    it(`${a} -> ${expected}`, () => {\n      expect(normalizeAngle(a)).toEqual(expected);\n    });\n  };\n\n  assert(360, 360);\n  assert(0, 0);\n  assert(10, 10);\n  assert(361, 1);\n  assert(450, 90);\n  assert(721, 1);\n  assert(-1, 359);\n  assert(-361, 359);\n  assert(-721, 359);\n});\n"]}
|
|
@@ -0,0 +1,255 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _enzymeToJson = _interopRequireDefault(require("enzyme-to-json"));
|
|
6
|
+
|
|
7
|
+
var _enzyme = require("enzyme");
|
|
8
|
+
|
|
9
|
+
var _rotatable = require("../rotatable");
|
|
10
|
+
|
|
11
|
+
var _react = _interopRequireDefault(require("react"));
|
|
12
|
+
|
|
13
|
+
var _reactTestRenderer = _interopRequireDefault(require("react-test-renderer"));
|
|
14
|
+
|
|
15
|
+
var _anchorUtils = require("../anchor-utils");
|
|
16
|
+
|
|
17
|
+
var _pointGeometry = _interopRequireDefault(require("@mapbox/point-geometry"));
|
|
18
|
+
|
|
19
|
+
/** Note: we use the test renderer because we need to make use of ref mocking. */
|
|
20
|
+
// ES6
|
|
21
|
+
jest.mock('../anchor-utils', function () {
|
|
22
|
+
return {
|
|
23
|
+
distanceBetween: jest.fn(function () {
|
|
24
|
+
return {
|
|
25
|
+
x: 2,
|
|
26
|
+
y: 2
|
|
27
|
+
};
|
|
28
|
+
}),
|
|
29
|
+
toPoint: jest.fn(function () {
|
|
30
|
+
return {
|
|
31
|
+
x: 0,
|
|
32
|
+
y: 0
|
|
33
|
+
};
|
|
34
|
+
}),
|
|
35
|
+
getAnchor: jest.fn(function () {
|
|
36
|
+
return {
|
|
37
|
+
left: 0,
|
|
38
|
+
top: 0
|
|
39
|
+
};
|
|
40
|
+
}),
|
|
41
|
+
toDegrees: jest.fn(function () {
|
|
42
|
+
return 90;
|
|
43
|
+
}),
|
|
44
|
+
arctangent: jest.fn(function () {
|
|
45
|
+
return 90;
|
|
46
|
+
})
|
|
47
|
+
};
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
var event = function event() {
|
|
51
|
+
var x = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
|
|
52
|
+
var y = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
|
|
53
|
+
return {
|
|
54
|
+
pageX: x,
|
|
55
|
+
pageY: y,
|
|
56
|
+
clientX: x,
|
|
57
|
+
clientY: y,
|
|
58
|
+
preventDefault: jest.fn()
|
|
59
|
+
};
|
|
60
|
+
};
|
|
61
|
+
|
|
62
|
+
describe('rotatable', function () {
|
|
63
|
+
describe('snapshot', function () {
|
|
64
|
+
it('renders', function () {
|
|
65
|
+
var wrapper = (0, _enzyme.shallow)( /*#__PURE__*/_react["default"].createElement(_rotatable.Rotatable, {
|
|
66
|
+
classes: {}
|
|
67
|
+
}, "foo"));
|
|
68
|
+
expect((0, _enzymeToJson["default"])(wrapper)).toMatchSnapshot();
|
|
69
|
+
});
|
|
70
|
+
it('renders with transforms', function () {
|
|
71
|
+
var wrapper = (0, _enzyme.shallow)( /*#__PURE__*/_react["default"].createElement(_rotatable.Rotatable, {
|
|
72
|
+
classes: {}
|
|
73
|
+
}, "foo"));
|
|
74
|
+
wrapper.setState({
|
|
75
|
+
translate: {
|
|
76
|
+
x: 10,
|
|
77
|
+
y: 10
|
|
78
|
+
},
|
|
79
|
+
rotation: 10,
|
|
80
|
+
origin: 'bottom left'
|
|
81
|
+
});
|
|
82
|
+
expect((0, _enzymeToJson["default"])(wrapper)).toMatchSnapshot();
|
|
83
|
+
});
|
|
84
|
+
});
|
|
85
|
+
describe('logic', function () {
|
|
86
|
+
var wrapper, el, instance;
|
|
87
|
+
beforeEach(function () {
|
|
88
|
+
el = {
|
|
89
|
+
addEventListener: jest.fn(),
|
|
90
|
+
removeEventListener: jest.fn()
|
|
91
|
+
};
|
|
92
|
+
wrapper = _reactTestRenderer["default"].create( /*#__PURE__*/_react["default"].createElement(_rotatable.Rotatable, {
|
|
93
|
+
handle: [{
|
|
94
|
+
"class": 'foo',
|
|
95
|
+
origin: 'bottom left'
|
|
96
|
+
}],
|
|
97
|
+
classes: {
|
|
98
|
+
rotatable: 'rotatable'
|
|
99
|
+
}
|
|
100
|
+
}, /*#__PURE__*/_react["default"].createElement("div", {
|
|
101
|
+
className: 'foo'
|
|
102
|
+
}, "foo")), {
|
|
103
|
+
createNodeMock: function createNodeMock(e) {
|
|
104
|
+
if (e.props.className === 'rotatable') {
|
|
105
|
+
return {
|
|
106
|
+
querySelector: jest.fn(function () {
|
|
107
|
+
return el;
|
|
108
|
+
}),
|
|
109
|
+
getBoundingClientRect: jest.fn(function () {
|
|
110
|
+
return {
|
|
111
|
+
left: 0,
|
|
112
|
+
top: 0,
|
|
113
|
+
width: 100,
|
|
114
|
+
height: 100
|
|
115
|
+
};
|
|
116
|
+
})
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
});
|
|
121
|
+
document.addEventListener = jest.fn();
|
|
122
|
+
document.removeEventListener = jest.fn();
|
|
123
|
+
instance = wrapper.root.instance;
|
|
124
|
+
});
|
|
125
|
+
describe('rotate', function () {
|
|
126
|
+
describe('init', function () {
|
|
127
|
+
it('call el.addEventListener(mousedown)', function () {
|
|
128
|
+
expect(el.addEventListener).toBeCalledWith('mousedown', expect.anything());
|
|
129
|
+
});
|
|
130
|
+
it('call el.addEventListener(mouseup)', function () {
|
|
131
|
+
expect(el.addEventListener).toBeCalledWith('mouseup', instance.rotateStop);
|
|
132
|
+
});
|
|
133
|
+
});
|
|
134
|
+
describe('rotateStart', function () {
|
|
135
|
+
var e;
|
|
136
|
+
beforeEach(function () {
|
|
137
|
+
e = event();
|
|
138
|
+
|
|
139
|
+
_anchorUtils.distanceBetween.mockReturnValue({
|
|
140
|
+
x: 22,
|
|
141
|
+
y: 4
|
|
142
|
+
});
|
|
143
|
+
|
|
144
|
+
instance.state.origin = 'bottom right';
|
|
145
|
+
instance.state.position = {
|
|
146
|
+
left: 0,
|
|
147
|
+
top: 0
|
|
148
|
+
};
|
|
149
|
+
instance.rotateStart('bottom left')(e);
|
|
150
|
+
});
|
|
151
|
+
it('calls event.preventDefault()', function () {
|
|
152
|
+
instance.rotateStart('bottom left')(e);
|
|
153
|
+
expect(e.preventDefault).toBeCalled();
|
|
154
|
+
});
|
|
155
|
+
it('updates the position if origin has change', function () {
|
|
156
|
+
expect(instance.state.position).toMatchObject({
|
|
157
|
+
left: 22,
|
|
158
|
+
top: 4
|
|
159
|
+
});
|
|
160
|
+
});
|
|
161
|
+
it('updates the startAngle', function () {
|
|
162
|
+
expect(instance.state.startAngle).toEqual(90);
|
|
163
|
+
});
|
|
164
|
+
it('updates the anchor', function () {
|
|
165
|
+
expect(instance.state.anchor).toMatchObject({
|
|
166
|
+
left: 0,
|
|
167
|
+
top: 0
|
|
168
|
+
});
|
|
169
|
+
});
|
|
170
|
+
});
|
|
171
|
+
describe('rotate', function () {
|
|
172
|
+
var e;
|
|
173
|
+
beforeEach(function () {
|
|
174
|
+
e = event();
|
|
175
|
+
instance.state.anchor = {
|
|
176
|
+
left: 0,
|
|
177
|
+
top: 0
|
|
178
|
+
};
|
|
179
|
+
instance.state.isRotating = true;
|
|
180
|
+
instance.rotate(e);
|
|
181
|
+
});
|
|
182
|
+
it('calls event.preventDefault()', function () {
|
|
183
|
+
expect(e.preventDefault).toBeCalled();
|
|
184
|
+
});
|
|
185
|
+
});
|
|
186
|
+
describe('rotateStop', function () {
|
|
187
|
+
var e;
|
|
188
|
+
beforeEach(function () {
|
|
189
|
+
e = event();
|
|
190
|
+
instance.state.isRotating = true;
|
|
191
|
+
instance.rotateStop(e);
|
|
192
|
+
});
|
|
193
|
+
it('unsets the anchor', function () {
|
|
194
|
+
expect(instance.state.anchor).toEqual(null);
|
|
195
|
+
});
|
|
196
|
+
it('unsets the anchor', function () {
|
|
197
|
+
expect(instance.state.anchor).toEqual(null);
|
|
198
|
+
});
|
|
199
|
+
it('sets the isRotating to false', function () {
|
|
200
|
+
expect(instance.state.isRotating).toEqual(false);
|
|
201
|
+
});
|
|
202
|
+
it('calls document.removeEventListener(mousemove, rotate)', function () {
|
|
203
|
+
expect(document.removeEventListener).toBeCalledWith('mousemove', instance.rotate);
|
|
204
|
+
});
|
|
205
|
+
it('calls document.removeEventListener(mousemove), drag', function () {
|
|
206
|
+
expect(document.removeEventListener).toBeCalledWith('mousemove', instance.drag);
|
|
207
|
+
});
|
|
208
|
+
});
|
|
209
|
+
});
|
|
210
|
+
describe('drag', function () {
|
|
211
|
+
describe('mouseDown', function () {
|
|
212
|
+
it('calls document.addEventListener(mousemove)', function () {
|
|
213
|
+
instance.mouseDown(event());
|
|
214
|
+
expect(document.addEventListener).toBeCalledWith('mousemove', instance.drag);
|
|
215
|
+
});
|
|
216
|
+
});
|
|
217
|
+
describe('mouseup', function () {
|
|
218
|
+
it('calls document.removeEventListener(mousemove)', function () {
|
|
219
|
+
instance.state.translate = {
|
|
220
|
+
x: 10,
|
|
221
|
+
y: 10
|
|
222
|
+
};
|
|
223
|
+
instance.mouseUp({});
|
|
224
|
+
expect(document.removeEventListener).toBeCalledWith('mousemove', instance.drag);
|
|
225
|
+
});
|
|
226
|
+
it('updates the state', function () {
|
|
227
|
+
instance.state.translate = {
|
|
228
|
+
x: 10,
|
|
229
|
+
y: 10
|
|
230
|
+
};
|
|
231
|
+
instance.state.position = {
|
|
232
|
+
left: 0,
|
|
233
|
+
top: 0
|
|
234
|
+
};
|
|
235
|
+
instance.mouseUp({});
|
|
236
|
+
expect(instance.state.position).toEqual({
|
|
237
|
+
left: 10,
|
|
238
|
+
top: 10
|
|
239
|
+
});
|
|
240
|
+
});
|
|
241
|
+
});
|
|
242
|
+
describe('drag', function () {
|
|
243
|
+
it('updates translate', function () {
|
|
244
|
+
instance.state.dragPoint = new _pointGeometry["default"](100, 100);
|
|
245
|
+
instance.drag(event(101, 101));
|
|
246
|
+
expect(instance.state.translate).toEqual({
|
|
247
|
+
x: 1,
|
|
248
|
+
y: 1
|
|
249
|
+
});
|
|
250
|
+
});
|
|
251
|
+
});
|
|
252
|
+
});
|
|
253
|
+
});
|
|
254
|
+
});
|
|
255
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/__tests__/rotatable.test.jsx"],"names":["jest","mock","distanceBetween","fn","x","y","toPoint","getAnchor","left","top","toDegrees","arctangent","event","pageX","pageY","clientX","clientY","preventDefault","describe","it","wrapper","expect","toMatchSnapshot","setState","translate","rotation","origin","el","instance","beforeEach","addEventListener","removeEventListener","TestRenderer","create","rotatable","createNodeMock","e","props","className","querySelector","getBoundingClientRect","width","height","document","root","toBeCalledWith","anything","rotateStop","mockReturnValue","state","position","rotateStart","toBeCalled","toMatchObject","startAngle","toEqual","anchor","isRotating","rotate","drag","mouseDown","mouseUp","dragPoint","Point"],"mappings":"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","sourcesContent":["import toJson from 'enzyme-to-json';\nimport { shallow } from 'enzyme';\nimport { Rotatable } from '../rotatable';\nimport React from 'react';\n/** Note: we use the test renderer because we need to make use of ref mocking. */\nimport TestRenderer from 'react-test-renderer'; // ES6\nimport { distanceBetween } from '../anchor-utils';\n\nimport Point from '@mapbox/point-geometry';\n\njest.mock('../anchor-utils', () => ({\n  distanceBetween: jest.fn(() => ({ x: 2, y: 2 })),\n  toPoint: jest.fn(() => ({ x: 0, y: 0 })),\n  getAnchor: jest.fn(() => ({ left: 0, top: 0 })),\n  toDegrees: jest.fn(() => 90),\n  arctangent: jest.fn(() => 90),\n}));\n\nconst event = (x = 0, y = 0) => ({\n  pageX: x,\n  pageY: y,\n  clientX: x,\n  clientY: y,\n  preventDefault: jest.fn(),\n});\n\ndescribe('rotatable', () => {\n  describe('snapshot', () => {\n    it('renders', () => {\n      const wrapper = shallow(<Rotatable classes={{}}>foo</Rotatable>);\n      expect(toJson(wrapper)).toMatchSnapshot();\n    });\n\n    it('renders with transforms', () => {\n      const wrapper = shallow(<Rotatable classes={{}}>foo</Rotatable>);\n\n      wrapper.setState({\n        translate: {\n          x: 10,\n          y: 10,\n        },\n        rotation: 10,\n        origin: 'bottom left',\n      });\n      expect(toJson(wrapper)).toMatchSnapshot();\n    });\n  });\n\n  describe('logic', () => {\n    let wrapper, el, instance;\n\n    beforeEach(() => {\n      el = {\n        addEventListener: jest.fn(),\n        removeEventListener: jest.fn(),\n      };\n      wrapper = TestRenderer.create(\n        <Rotatable handle={[{ class: 'foo', origin: 'bottom left' }]} classes={{ rotatable: 'rotatable' }}>\n          <div className={'foo'}>foo</div>\n        </Rotatable>,\n        {\n          createNodeMock: (e) => {\n            if (e.props.className === 'rotatable') {\n              return {\n                querySelector: jest.fn(() => el),\n                getBoundingClientRect: jest.fn(() => ({\n                  left: 0,\n                  top: 0,\n                  width: 100,\n                  height: 100,\n                })),\n              };\n            }\n          },\n        },\n      );\n\n      document.addEventListener = jest.fn();\n      document.removeEventListener = jest.fn();\n      instance = wrapper.root.instance;\n    });\n\n    describe('rotate', () => {\n      describe('init', () => {\n        it('call el.addEventListener(mousedown)', () => {\n          expect(el.addEventListener).toBeCalledWith('mousedown', expect.anything());\n        });\n        it('call el.addEventListener(mouseup)', () => {\n          expect(el.addEventListener).toBeCalledWith('mouseup', instance.rotateStop);\n        });\n      });\n\n      describe('rotateStart', () => {\n        let e;\n        beforeEach(() => {\n          e = event();\n\n          distanceBetween.mockReturnValue({\n            x: 22,\n            y: 4,\n          });\n          instance.state.origin = 'bottom right';\n\n          instance.state.position = {\n            left: 0,\n            top: 0,\n          };\n\n          instance.rotateStart('bottom left')(e);\n        });\n\n        it('calls event.preventDefault()', () => {\n          instance.rotateStart('bottom left')(e);\n          expect(e.preventDefault).toBeCalled();\n        });\n\n        it('updates the position if origin has change', () => {\n          expect(instance.state.position).toMatchObject({\n            left: 22,\n            top: 4,\n          });\n        });\n\n        it('updates the startAngle', () => {\n          expect(instance.state.startAngle).toEqual(90);\n        });\n\n        it('updates the anchor', () => {\n          expect(instance.state.anchor).toMatchObject({\n            left: 0,\n            top: 0,\n          });\n        });\n      });\n\n      describe('rotate', () => {\n        let e;\n        beforeEach(() => {\n          e = event();\n\n          instance.state.anchor = {\n            left: 0,\n            top: 0,\n          };\n\n          instance.state.isRotating = true;\n          instance.rotate(e);\n        });\n        it('calls event.preventDefault()', () => {\n          expect(e.preventDefault).toBeCalled();\n        });\n      });\n\n      describe('rotateStop', () => {\n        let e;\n\n        beforeEach(() => {\n          e = event();\n          instance.state.isRotating = true;\n          instance.rotateStop(e);\n        });\n\n        it('unsets the anchor', () => {\n          expect(instance.state.anchor).toEqual(null);\n        });\n        it('unsets the anchor', () => {\n          expect(instance.state.anchor).toEqual(null);\n        });\n        it('sets the isRotating to false', () => {\n          expect(instance.state.isRotating).toEqual(false);\n        });\n\n        it('calls document.removeEventListener(mousemove, rotate)', () => {\n          expect(document.removeEventListener).toBeCalledWith('mousemove', instance.rotate);\n        });\n        it('calls document.removeEventListener(mousemove), drag', () => {\n          expect(document.removeEventListener).toBeCalledWith('mousemove', instance.drag);\n        });\n      });\n    });\n\n    describe('drag', () => {\n      describe('mouseDown', () => {\n        it('calls document.addEventListener(mousemove)', () => {\n          instance.mouseDown(event());\n\n          expect(document.addEventListener).toBeCalledWith('mousemove', instance.drag);\n        });\n      });\n\n      describe('mouseup', () => {\n        it('calls document.removeEventListener(mousemove)', () => {\n          instance.state.translate = { x: 10, y: 10 };\n          instance.mouseUp({});\n\n          expect(document.removeEventListener).toBeCalledWith('mousemove', instance.drag);\n        });\n\n        it('updates the state', () => {\n          instance.state.translate = { x: 10, y: 10 };\n          instance.state.position = { left: 0, top: 0 };\n          instance.mouseUp({});\n\n          expect(instance.state.position).toEqual({\n            left: 10,\n            top: 10,\n          });\n        });\n      });\n\n      describe('drag', () => {\n        it('updates translate', () => {\n          instance.state.dragPoint = new Point(100, 100);\n          instance.drag(event(101, 101));\n          expect(instance.state.translate).toEqual({ x: 1, y: 1 });\n        });\n      });\n    });\n  });\n});\n"]}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _transformOrigin = require("../transform-origin");
|
|
4
|
+
|
|
5
|
+
describe('transform-origin', function () {
|
|
6
|
+
describe('parse', function () {
|
|
7
|
+
var assert = function assert(origin, expected) {
|
|
8
|
+
it("".concat(origin, " => ").concat(JSON.stringify(expected)), function () {
|
|
9
|
+
var out = (0, _transformOrigin.parse)({
|
|
10
|
+
width: 100,
|
|
11
|
+
height: 100
|
|
12
|
+
}, origin);
|
|
13
|
+
expect(out).toEqual(expected);
|
|
14
|
+
});
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
assert(undefined, {
|
|
18
|
+
x: 50,
|
|
19
|
+
y: 50
|
|
20
|
+
});
|
|
21
|
+
assert('right', {
|
|
22
|
+
x: 100,
|
|
23
|
+
y: 50
|
|
24
|
+
});
|
|
25
|
+
assert('20%', {
|
|
26
|
+
x: 20,
|
|
27
|
+
y: 50
|
|
28
|
+
});
|
|
29
|
+
assert('left', {
|
|
30
|
+
x: 0,
|
|
31
|
+
y: 50
|
|
32
|
+
});
|
|
33
|
+
assert('top right', {
|
|
34
|
+
x: 100,
|
|
35
|
+
y: 0
|
|
36
|
+
});
|
|
37
|
+
assert('right top', {
|
|
38
|
+
x: 100,
|
|
39
|
+
y: 0
|
|
40
|
+
});
|
|
41
|
+
assert('bottom left', {
|
|
42
|
+
x: 0,
|
|
43
|
+
y: 100
|
|
44
|
+
});
|
|
45
|
+
assert('left bottom', {
|
|
46
|
+
x: 0,
|
|
47
|
+
y: 100
|
|
48
|
+
});
|
|
49
|
+
assert('0% 100%', {
|
|
50
|
+
x: 0,
|
|
51
|
+
y: 100
|
|
52
|
+
});
|
|
53
|
+
assert('100% 0%', {
|
|
54
|
+
x: 100,
|
|
55
|
+
y: 0
|
|
56
|
+
});
|
|
57
|
+
assert('10px 43px', {
|
|
58
|
+
x: 10,
|
|
59
|
+
y: 43
|
|
60
|
+
});
|
|
61
|
+
});
|
|
62
|
+
});
|
|
63
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9fX3Rlc3RzX18vdHJhbnNmb3JtLW9yaWdpbi50ZXN0LmpzeCJdLCJuYW1lcyI6WyJkZXNjcmliZSIsImFzc2VydCIsIm9yaWdpbiIsImV4cGVjdGVkIiwiaXQiLCJKU09OIiwic3RyaW5naWZ5Iiwib3V0Iiwid2lkdGgiLCJoZWlnaHQiLCJleHBlY3QiLCJ0b0VxdWFsIiwidW5kZWZpbmVkIiwieCIsInkiXSwibWFwcGluZ3MiOiI7O0FBQUE7O0FBRUFBLFFBQVEsQ0FBQyxrQkFBRCxFQUFxQixZQUFNO0FBQ2pDQSxFQUFBQSxRQUFRLENBQUMsT0FBRCxFQUFVLFlBQU07QUFDdEIsUUFBTUMsTUFBTSxHQUFHLFNBQVRBLE1BQVMsQ0FBQ0MsTUFBRCxFQUFTQyxRQUFULEVBQXNCO0FBQ25DQyxNQUFBQSxFQUFFLFdBQUlGLE1BQUosaUJBQWlCRyxJQUFJLENBQUNDLFNBQUwsQ0FBZUgsUUFBZixDQUFqQixHQUE2QyxZQUFNO0FBQ25ELFlBQU1JLEdBQUcsR0FBRyw0QkFBTTtBQUFFQyxVQUFBQSxLQUFLLEVBQUUsR0FBVDtBQUFjQyxVQUFBQSxNQUFNLEVBQUU7QUFBdEIsU0FBTixFQUFtQ1AsTUFBbkMsQ0FBWjtBQUNBUSxRQUFBQSxNQUFNLENBQUNILEdBQUQsQ0FBTixDQUFZSSxPQUFaLENBQW9CUixRQUFwQjtBQUNELE9BSEMsQ0FBRjtBQUlELEtBTEQ7O0FBT0FGLElBQUFBLE1BQU0sQ0FBQ1csU0FBRCxFQUFZO0FBQUVDLE1BQUFBLENBQUMsRUFBRSxFQUFMO0FBQVNDLE1BQUFBLENBQUMsRUFBRTtBQUFaLEtBQVosQ0FBTjtBQUNBYixJQUFBQSxNQUFNLENBQUMsT0FBRCxFQUFVO0FBQUVZLE1BQUFBLENBQUMsRUFBRSxHQUFMO0FBQVVDLE1BQUFBLENBQUMsRUFBRTtBQUFiLEtBQVYsQ0FBTjtBQUNBYixJQUFBQSxNQUFNLENBQUMsS0FBRCxFQUFRO0FBQUVZLE1BQUFBLENBQUMsRUFBRSxFQUFMO0FBQVNDLE1BQUFBLENBQUMsRUFBRTtBQUFaLEtBQVIsQ0FBTjtBQUNBYixJQUFBQSxNQUFNLENBQUMsTUFBRCxFQUFTO0FBQUVZLE1BQUFBLENBQUMsRUFBRSxDQUFMO0FBQVFDLE1BQUFBLENBQUMsRUFBRTtBQUFYLEtBQVQsQ0FBTjtBQUNBYixJQUFBQSxNQUFNLENBQUMsV0FBRCxFQUFjO0FBQUVZLE1BQUFBLENBQUMsRUFBRSxHQUFMO0FBQVVDLE1BQUFBLENBQUMsRUFBRTtBQUFiLEtBQWQsQ0FBTjtBQUNBYixJQUFBQSxNQUFNLENBQUMsV0FBRCxFQUFjO0FBQUVZLE1BQUFBLENBQUMsRUFBRSxHQUFMO0FBQVVDLE1BQUFBLENBQUMsRUFBRTtBQUFiLEtBQWQsQ0FBTjtBQUNBYixJQUFBQSxNQUFNLENBQUMsYUFBRCxFQUFnQjtBQUFFWSxNQUFBQSxDQUFDLEVBQUUsQ0FBTDtBQUFRQyxNQUFBQSxDQUFDLEVBQUU7QUFBWCxLQUFoQixDQUFOO0FBQ0FiLElBQUFBLE1BQU0sQ0FBQyxhQUFELEVBQWdCO0FBQUVZLE1BQUFBLENBQUMsRUFBRSxDQUFMO0FBQVFDLE1BQUFBLENBQUMsRUFBRTtBQUFYLEtBQWhCLENBQU47QUFDQWIsSUFBQUEsTUFBTSxDQUFDLFNBQUQsRUFBWTtBQUFFWSxNQUFBQSxDQUFDLEVBQUUsQ0FBTDtBQUFRQyxNQUFBQSxDQUFDLEVBQUU7QUFBWCxLQUFaLENBQU47QUFDQWIsSUFBQUEsTUFBTSxDQUFDLFNBQUQsRUFBWTtBQUFFWSxNQUFBQSxDQUFDLEVBQUUsR0FBTDtBQUFVQyxNQUFBQSxDQUFDLEVBQUU7QUFBYixLQUFaLENBQU47QUFDQWIsSUFBQUEsTUFBTSxDQUFDLFdBQUQsRUFBYztBQUFFWSxNQUFBQSxDQUFDLEVBQUUsRUFBTDtBQUFTQyxNQUFBQSxDQUFDLEVBQUU7QUFBWixLQUFkLENBQU47QUFDRCxHQW5CTyxDQUFSO0FBb0JELENBckJPLENBQVIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBwYXJzZSB9IGZyb20gJy4uL3RyYW5zZm9ybS1vcmlnaW4nO1xuXG5kZXNjcmliZSgndHJhbnNmb3JtLW9yaWdpbicsICgpID0+IHtcbiAgZGVzY3JpYmUoJ3BhcnNlJywgKCkgPT4ge1xuICAgIGNvbnN0IGFzc2VydCA9IChvcmlnaW4sIGV4cGVjdGVkKSA9PiB7XG4gICAgICBpdChgJHtvcmlnaW59ID0+ICR7SlNPTi5zdHJpbmdpZnkoZXhwZWN0ZWQpfWAsICgpID0+IHtcbiAgICAgICAgY29uc3Qgb3V0ID0gcGFyc2UoeyB3aWR0aDogMTAwLCBoZWlnaHQ6IDEwMCB9LCBvcmlnaW4pO1xuICAgICAgICBleHBlY3Qob3V0KS50b0VxdWFsKGV4cGVjdGVkKTtcbiAgICAgIH0pO1xuICAgIH07XG5cbiAgICBhc3NlcnQodW5kZWZpbmVkLCB7IHg6IDUwLCB5OiA1MCB9KTtcbiAgICBhc3NlcnQoJ3JpZ2h0JywgeyB4OiAxMDAsIHk6IDUwIH0pO1xuICAgIGFzc2VydCgnMjAlJywgeyB4OiAyMCwgeTogNTAgfSk7XG4gICAgYXNzZXJ0KCdsZWZ0JywgeyB4OiAwLCB5OiA1MCB9KTtcbiAgICBhc3NlcnQoJ3RvcCByaWdodCcsIHsgeDogMTAwLCB5OiAwIH0pO1xuICAgIGFzc2VydCgncmlnaHQgdG9wJywgeyB4OiAxMDAsIHk6IDAgfSk7XG4gICAgYXNzZXJ0KCdib3R0b20gbGVmdCcsIHsgeDogMCwgeTogMTAwIH0pO1xuICAgIGFzc2VydCgnbGVmdCBib3R0b20nLCB7IHg6IDAsIHk6IDEwMCB9KTtcbiAgICBhc3NlcnQoJzAlIDEwMCUnLCB7IHg6IDAsIHk6IDEwMCB9KTtcbiAgICBhc3NlcnQoJzEwMCUgMCUnLCB7IHg6IDEwMCwgeTogMCB9KTtcbiAgICBhc3NlcnQoJzEwcHggNDNweCcsIHsgeDogMTAsIHk6IDQzIH0pO1xuICB9KTtcbn0pO1xuIl19
|