terra-draw 1.0.0-beta.0 → 1.0.0-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/geometry/calculate-relative-angle.d.ts +17 -0
- package/dist/geometry/determine-halfplane.d.ts +10 -0
- package/dist/geometry/measure/destination.d.ts +7 -0
- package/dist/geometry/measure/pixel-distance.d.ts +1 -1
- package/dist/modes/angled-rectangle/angled-rectangle.mode.d.ts +62 -0
- package/dist/terra-draw.cjs +1 -1
- package/dist/terra-draw.cjs.map +1 -1
- package/dist/terra-draw.d.ts +2 -1
- package/dist/terra-draw.modern.js +1 -1
- package/dist/terra-draw.modern.js.map +1 -1
- package/dist/terra-draw.module.js +1 -1
- package/dist/terra-draw.module.js.map +1 -1
- package/dist/terra-draw.umd.js +1 -1
- package/dist/terra-draw.umd.js.map +1 -1
- package/e2e/public/index.html +1 -0
- package/e2e/tests/leaflet.spec.ts +82 -0
- package/e2e/tests/setup.ts +19 -2
- package/package.json +2 -3
package/e2e/public/index.html
CHANGED
|
@@ -41,6 +41,7 @@
|
|
|
41
41
|
<button id="linestring">Linestring</button>
|
|
42
42
|
<button id="polygon">Polygon</button>
|
|
43
43
|
<button id="rectangle">Rectangle</button>
|
|
44
|
+
<button id="angled-rectangle">Angled Rectangle</button>
|
|
44
45
|
<button id="circle">Circle</button>
|
|
45
46
|
<button id="clear">Clear</button>
|
|
46
47
|
</div>
|
|
@@ -328,6 +328,88 @@ test.describe("rectangle mode", () => {
|
|
|
328
328
|
});
|
|
329
329
|
});
|
|
330
330
|
|
|
331
|
+
test.describe("angled rectangle mode", () => {
|
|
332
|
+
const mode = "angled-rectangle";
|
|
333
|
+
|
|
334
|
+
test("mode can set and can be used to create an angled rectangle (horizontal up)", async ({
|
|
335
|
+
page,
|
|
336
|
+
}) => {
|
|
337
|
+
const mapDiv = await setupMap({ page });
|
|
338
|
+
await changeMode({ page, mode });
|
|
339
|
+
|
|
340
|
+
await page.mouse.click(mapDiv.width / 2, mapDiv.height / 2);
|
|
341
|
+
await page.mouse.move(mapDiv.width / 3, mapDiv.height / 2, { steps: 30 });
|
|
342
|
+
await page.mouse.click(mapDiv.width / 3, mapDiv.height / 2);
|
|
343
|
+
await page.mouse.move(mapDiv.width / 3 + 50, mapDiv.height / 3 + 50, {
|
|
344
|
+
steps: 30,
|
|
345
|
+
});
|
|
346
|
+
await page.mouse.click(mapDiv.width / 3 + 50, mapDiv.height / 3 + 50);
|
|
347
|
+
|
|
348
|
+
await expectPaths({ page, count: 1 });
|
|
349
|
+
|
|
350
|
+
await expectPathDimensions({ page, width: 217, height: 74 });
|
|
351
|
+
});
|
|
352
|
+
|
|
353
|
+
test("mode can set and can be used to create an angled rectangle (horizontal down)", async ({
|
|
354
|
+
page,
|
|
355
|
+
}) => {
|
|
356
|
+
const mapDiv = await setupMap({ page });
|
|
357
|
+
await changeMode({ page, mode });
|
|
358
|
+
|
|
359
|
+
await page.mouse.click(mapDiv.width / 2, mapDiv.height / 2);
|
|
360
|
+
await page.mouse.move(mapDiv.width / 3, mapDiv.height / 2, { steps: 30 });
|
|
361
|
+
await page.mouse.click(mapDiv.width / 3, mapDiv.height / 2);
|
|
362
|
+
await page.mouse.move(mapDiv.width / 3 + 50, mapDiv.height / 3 + 200, {
|
|
363
|
+
steps: 30,
|
|
364
|
+
});
|
|
365
|
+
await page.mouse.click(mapDiv.width / 3 + 50, mapDiv.height / 3 + 200);
|
|
366
|
+
|
|
367
|
+
await expectPaths({ page, count: 1 });
|
|
368
|
+
|
|
369
|
+
await expectPathDimensions({ page, width: 217, height: 84 });
|
|
370
|
+
});
|
|
371
|
+
|
|
372
|
+
test("mode can set and can be used to create an angled (diagonal)", async ({
|
|
373
|
+
page,
|
|
374
|
+
}) => {
|
|
375
|
+
const mapDiv = await setupMap({ page });
|
|
376
|
+
await changeMode({ page, mode });
|
|
377
|
+
|
|
378
|
+
await page.mouse.click(mapDiv.width / 2, mapDiv.height / 2);
|
|
379
|
+
await page.mouse.move(mapDiv.width / 3, mapDiv.height / 3, { steps: 30 });
|
|
380
|
+
await page.mouse.click(mapDiv.width / 3, mapDiv.height / 3);
|
|
381
|
+
await page.mouse.move(mapDiv.width / 3 + 150, mapDiv.height / 3 + 150, {
|
|
382
|
+
steps: 30,
|
|
383
|
+
});
|
|
384
|
+
await page.mouse.click(mapDiv.width / 3 + 150, mapDiv.height / 3 + 150);
|
|
385
|
+
|
|
386
|
+
await expectPaths({ page, count: 1 });
|
|
387
|
+
|
|
388
|
+
await expectPathDimensions({ page, width: 245, height: 174 });
|
|
389
|
+
});
|
|
390
|
+
|
|
391
|
+
test("mode can set and can be used to create an angled (diagonal 2)", async ({
|
|
392
|
+
page,
|
|
393
|
+
}) => {
|
|
394
|
+
const mapDiv = await setupMap({ page });
|
|
395
|
+
await changeMode({ page, mode });
|
|
396
|
+
|
|
397
|
+
await page.mouse.click(mapDiv.width / 1.8, mapDiv.height / 1.8);
|
|
398
|
+
await page.mouse.move(mapDiv.width / 2.5, mapDiv.height / 1.3, {
|
|
399
|
+
steps: 30,
|
|
400
|
+
});
|
|
401
|
+
await page.mouse.click(mapDiv.width / 2.5, mapDiv.height / 1.3);
|
|
402
|
+
await page.mouse.move(mapDiv.width / 2.5 + 50, mapDiv.height / 1.3 + 50, {
|
|
403
|
+
steps: 30,
|
|
404
|
+
});
|
|
405
|
+
await page.mouse.click(mapDiv.width / 2.5 + 50, mapDiv.height / 1.3 + 50);
|
|
406
|
+
|
|
407
|
+
await expectPaths({ page, count: 1 });
|
|
408
|
+
|
|
409
|
+
await expectPathDimensions({ page, width: 246, height: 213 });
|
|
410
|
+
});
|
|
411
|
+
});
|
|
412
|
+
|
|
331
413
|
test.describe("circle mode", () => {
|
|
332
414
|
const mode = "circle";
|
|
333
415
|
|
package/e2e/tests/setup.ts
CHANGED
|
@@ -53,9 +53,26 @@ export const changeMode = async ({
|
|
|
53
53
|
mode,
|
|
54
54
|
}: {
|
|
55
55
|
page: Page;
|
|
56
|
-
mode:
|
|
56
|
+
mode:
|
|
57
|
+
| "point"
|
|
58
|
+
| "polygon"
|
|
59
|
+
| "linestring"
|
|
60
|
+
| "select"
|
|
61
|
+
| "rectangle"
|
|
62
|
+
| "circle"
|
|
63
|
+
| "angled-rectangle";
|
|
57
64
|
}) => {
|
|
58
|
-
|
|
65
|
+
let modeText = mode.charAt(0).toUpperCase() + mode.slice(1);
|
|
66
|
+
|
|
67
|
+
if (mode.includes("-")) {
|
|
68
|
+
modeText = mode
|
|
69
|
+
.split("-")
|
|
70
|
+
.map((word) => word.charAt(0).toUpperCase() + word.slice(1))
|
|
71
|
+
.join(" ");
|
|
72
|
+
} else {
|
|
73
|
+
modeText = mode.charAt(0).toUpperCase() + mode.slice(1);
|
|
74
|
+
}
|
|
75
|
+
|
|
59
76
|
const buttons = page.getByTestId("buttons");
|
|
60
77
|
const button = buttons.getByText(modeText, { exact: true });
|
|
61
78
|
|
package/package.json
CHANGED
|
@@ -1,11 +1,10 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "terra-draw",
|
|
3
|
-
"version": "1.0.0-beta.
|
|
3
|
+
"version": "1.0.0-beta.1",
|
|
4
4
|
"description": "Frictionless map drawing across mapping provider",
|
|
5
5
|
"scripts": {
|
|
6
6
|
"docs": "typedoc",
|
|
7
7
|
"docs:serve": "serve ./docs",
|
|
8
|
-
"release:beta:major": "standard-version --prerelease beta --release-as major",
|
|
9
8
|
"release:beta:increment": "standard-version --prerelease beta",
|
|
10
9
|
"release:beta:changelog": "tsx ./scripts/changelog-valid.ts",
|
|
11
10
|
"release:beta:next": "tsx ./scripts/next-beta-version.ts",
|
|
@@ -75,7 +74,7 @@
|
|
|
75
74
|
"mapbox-gl": "2.13.0",
|
|
76
75
|
"maplibre-gl": "3.2.0",
|
|
77
76
|
"microbundle": "0.15.0",
|
|
78
|
-
"ol": "
|
|
77
|
+
"ol": "10.0.0",
|
|
79
78
|
"serve": "14.1.2",
|
|
80
79
|
"standard-version": "9.5.0",
|
|
81
80
|
"ts-jest": "29.1.2",
|