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.
@@ -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
 
@@ -53,9 +53,26 @@ export const changeMode = async ({
53
53
  mode,
54
54
  }: {
55
55
  page: Page;
56
- mode: "point" | "polygon" | "linestring" | "select" | "rectangle" | "circle";
56
+ mode:
57
+ | "point"
58
+ | "polygon"
59
+ | "linestring"
60
+ | "select"
61
+ | "rectangle"
62
+ | "circle"
63
+ | "angled-rectangle";
57
64
  }) => {
58
- const modeText = mode.charAt(0).toUpperCase() + mode.slice(1);
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.0",
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": "7.1.0",
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",