terra-draw 0.0.1-alpha.9 → 1.0.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.
Files changed (119) hide show
  1. package/.devcontainer/Dockerfile +8 -0
  2. package/.devcontainer/devcontainer.json +27 -0
  3. package/.devcontainer/post-create.sh +16 -0
  4. package/README.md +23 -13
  5. package/dist/adapters/arcgis-maps-sdk.adapter.d.ts +106 -0
  6. package/dist/adapters/google-maps.adapter.d.ts +90 -39
  7. package/dist/adapters/leaflet.adapter.d.ts +99 -33
  8. package/dist/adapters/mapbox-gl.adapter.d.ts +91 -37
  9. package/dist/adapters/maplibre-gl.adapter.d.ts +72 -0
  10. package/dist/adapters/openlayers.adapter.d.ts +120 -0
  11. package/dist/common.d.ts +118 -98
  12. package/dist/geometry/boolean/is-valid-coordinate.d.ts +4 -0
  13. package/dist/geometry/boolean/point-in-polygon.d.ts +2 -2
  14. package/dist/geometry/boolean/self-intersects.d.ts +2 -2
  15. package/dist/geometry/centroid.d.ts +2 -2
  16. package/dist/geometry/coordinates-identical.d.ts +2 -2
  17. package/dist/geometry/get-coordinates-as-points.d.ts +6 -6
  18. package/dist/geometry/get-midpoints.d.ts +14 -7
  19. package/dist/geometry/helpers.d.ts +4 -4
  20. package/dist/geometry/limit-decimal-precision.d.ts +1 -1
  21. package/dist/geometry/measure/area.d.ts +2 -0
  22. package/dist/geometry/measure/bearing.d.ts +9 -0
  23. package/dist/geometry/measure/destination.d.ts +2 -0
  24. package/dist/geometry/measure/haversine-distance.d.ts +2 -2
  25. package/dist/geometry/measure/pixel-distance-to-line.d.ts +10 -10
  26. package/dist/geometry/measure/pixel-distance.d.ts +7 -7
  27. package/dist/geometry/measure/rhumb-bearing.d.ts +2 -2
  28. package/dist/geometry/measure/rhumb-destination.d.ts +2 -2
  29. package/dist/geometry/measure/rhumb-distance.d.ts +2 -2
  30. package/dist/geometry/measure/slice-along.d.ts +2 -0
  31. package/dist/geometry/midpoint-coordinate.d.ts +4 -2
  32. package/dist/geometry/project/web-mercator.d.ts +20 -0
  33. package/dist/geometry/shape/create-bbox.d.ts +10 -0
  34. package/dist/geometry/shape/create-circle.d.ts +13 -7
  35. package/dist/geometry/shape/great-circle-coordinates.d.ts +2 -0
  36. package/dist/geometry/shape/web-mercator-distortion.d.ts +2 -0
  37. package/dist/geometry/transform/rotate.d.ts +9 -2
  38. package/dist/geometry/transform/scale.d.ts +9 -2
  39. package/dist/geometry/web-mercator-centroid.d.ts +11 -0
  40. package/dist/modes/base.behavior.d.ts +21 -19
  41. package/dist/modes/base.mode.d.ts +66 -33
  42. package/dist/modes/circle/circle.mode.d.ts +66 -37
  43. package/dist/modes/click-bounding-box.behavior.d.ts +6 -7
  44. package/dist/modes/freehand/freehand.mode.d.ts +63 -43
  45. package/dist/modes/insert-coordinates.behavior.d.ts +9 -0
  46. package/dist/modes/linestring/linestring.mode.d.ts +78 -47
  47. package/dist/modes/pixel-distance.behavior.d.ts +7 -7
  48. package/dist/modes/point/point.mode.d.ts +44 -26
  49. package/dist/modes/polygon/behaviors/closing-points.behavior.d.ts +19 -19
  50. package/dist/modes/polygon/polygon.mode.d.ts +69 -51
  51. package/dist/modes/rectangle/rectangle.mode.d.ts +55 -0
  52. package/dist/modes/render/render.mode.d.ts +52 -23
  53. package/dist/modes/select/behaviors/drag-coordinate-resize.behavior.d.ts +62 -0
  54. package/dist/modes/select/behaviors/drag-coordinate.behavior.d.ts +20 -13
  55. package/dist/modes/select/behaviors/drag-feature.behavior.d.ts +20 -17
  56. package/dist/modes/select/behaviors/{features-at-mouse-event.behavior.d.ts → feature-at-pointer-event.behavior.d.ts} +15 -15
  57. package/dist/modes/select/behaviors/midpoint.behavior.d.ts +19 -18
  58. package/dist/modes/select/behaviors/rotate-feature.behavior.d.ts +14 -13
  59. package/dist/modes/select/behaviors/scale-feature.behavior.d.ts +14 -13
  60. package/dist/modes/select/behaviors/selection-point.behavior.d.ts +19 -18
  61. package/dist/modes/select/select.mode.d.ts +119 -78
  62. package/dist/modes/snapping.behavior.d.ts +16 -13
  63. package/dist/modes/static/static.mode.d.ts +32 -30
  64. package/dist/store/spatial-index/quickselect.d.ts +2 -2
  65. package/dist/store/spatial-index/rbush.d.ts +35 -35
  66. package/dist/store/spatial-index/spatial-index.d.ts +18 -18
  67. package/dist/store/store-feature-validation.d.ts +16 -0
  68. package/dist/store/store.d.ts +59 -48
  69. package/dist/terra-draw.cjs +1 -1
  70. package/dist/terra-draw.cjs.map +1 -1
  71. package/dist/terra-draw.d.ts +222 -48
  72. package/dist/terra-draw.modern.js +1 -1
  73. package/dist/terra-draw.modern.js.map +1 -1
  74. package/dist/terra-draw.module.js +1 -1
  75. package/dist/terra-draw.module.js.map +1 -1
  76. package/dist/terra-draw.umd.js +1 -1
  77. package/dist/terra-draw.umd.js.map +1 -1
  78. package/dist/util/geoms.d.ts +3 -3
  79. package/dist/util/id.d.ts +1 -1
  80. package/dist/util/styling.d.ts +2 -2
  81. package/dist/validations/linestring.validation.d.ts +2 -0
  82. package/dist/validations/max-size.validation.d.ts +2 -0
  83. package/dist/validations/min-size.validation.d.ts +2 -0
  84. package/dist/validations/not-self-intersecting.validation.d.ts +2 -0
  85. package/dist/validations/point.validation.d.ts +2 -0
  86. package/dist/validations/polygon.validation.d.ts +3 -0
  87. package/e2e/README.md +29 -0
  88. package/e2e/package-lock.json +4274 -0
  89. package/e2e/package.json +26 -0
  90. package/e2e/playwright.config.ts +77 -0
  91. package/e2e/public/favicon.ico +0 -0
  92. package/e2e/public/index.html +52 -0
  93. package/e2e/tests/leaflet.spec.ts +657 -0
  94. package/e2e/tests/setup.ts +181 -0
  95. package/e2e/webpack.config.js +36 -0
  96. package/jest.nocheck.config.ts +17 -0
  97. package/package.json +159 -87
  98. package/readme.gif +0 -0
  99. package/tsconfig.json +25 -12
  100. package/CODE_OF_CONDUCT.md +0 -36
  101. package/CONTRIBUTING.md +0 -17
  102. package/DEVELOPMENT.md +0 -77
  103. package/dist/bundle.js +0 -6
  104. package/dist/bundle.js.LICENSE.txt +0 -4
  105. package/dist/geometry/create-circle.d.ts +0 -6
  106. package/dist/geometry/get-pixel-distance-to-line.d.ts +0 -10
  107. package/dist/geometry/get-pixel-distance.d.ts +0 -7
  108. package/dist/geometry/haversine-distance.d.ts +0 -1
  109. package/dist/geometry/point-in-polygon.d.ts +0 -1
  110. package/dist/geometry/self-intersects.d.ts +0 -2
  111. package/dist/modes/circle.mode.d.ts +0 -18
  112. package/dist/modes/freehand.mode.d.ts +0 -20
  113. package/dist/modes/line-string.mode.d.ts +0 -21
  114. package/dist/modes/point.mode.d.ts +0 -14
  115. package/dist/modes/polygon/behaviors/start-end-point.behavior.d.ts +0 -11
  116. package/dist/modes/polygon.mode.d.ts +0 -21
  117. package/dist/modes/select.mode.d.ts +0 -21
  118. package/dist/modes/static.mode.d.ts +0 -10
  119. package/jest.config.ts +0 -27
@@ -1,48 +1,222 @@
1
- import { TerraDrawGoogleMapsAdapter } from "./adapters/google-maps.adapter";
2
- import { TerraDrawLeafletAdapter } from "./adapters/leaflet.adapter";
3
- import { TerraDrawMapboxGLAdapter } from "./adapters/mapbox-gl.adapter";
4
- import { TerraDrawMode, TerraDrawAdapter, TerraDrawAdapterStyling } from "./common";
5
- import { TerraDrawCircleMode } from "./modes/circle/circle.mode";
6
- import { TerraDrawFreehandMode } from "./modes/freehand/freehand.mode";
7
- import { TerraDrawLineStringMode } from "./modes/linestring/linestring.mode";
8
- import { TerraDrawPointMode } from "./modes/point/point.mode";
9
- import { TerraDrawPolygonMode } from "./modes/polygon/polygon.mode";
10
- import { TerraDrawRenderMode } from "./modes/render/render.mode";
11
- import { TerraDrawSelectMode } from "./modes/select/select.mode";
12
- import { GeoJSONStoreFeatures } from "./store/store";
13
- declare type ChangeListener = (ids: string[], type: string) => void;
14
- declare type SelectListener = (id: string) => void;
15
- declare type DeselectListener = () => void;
16
- interface TerraDrawEventListeners {
17
- change: ChangeListener;
18
- select: SelectListener;
19
- deselect: DeselectListener;
20
- }
21
- declare type TerraDrawEvents = keyof TerraDrawEventListeners;
22
- declare class TerraDraw {
23
- private _modes;
24
- private _mode;
25
- private _adapter;
26
- private _enabled;
27
- private _store;
28
- private _eventListeners;
29
- constructor(options: {
30
- adapter: TerraDrawAdapter;
31
- modes: {
32
- [mode: string]: TerraDrawMode;
33
- };
34
- data?: GeoJSONStoreFeatures[];
35
- });
36
- private getModeStyles;
37
- setModeStyles(mode: string, styles: TerraDrawAdapterStyling): void;
38
- getSnapshot(): GeoJSONStoreFeatures[];
39
- get enabled(): boolean;
40
- set enabled(_: boolean);
41
- getCurrentMode(): string;
42
- changeMode(mode: string): void;
43
- start(): void;
44
- stop(): void;
45
- on<T extends TerraDrawEvents>(event: T, callback: TerraDrawEventListeners[T]): void;
46
- off<T extends TerraDrawEvents>(event: TerraDrawEvents, callback: TerraDrawEventListeners[T]): void;
47
- }
48
- export { TerraDraw, TerraDrawSelectMode, TerraDrawPointMode, TerraDrawLineStringMode, TerraDrawPolygonMode, TerraDrawCircleMode, TerraDrawFreehandMode, TerraDrawRenderMode, TerraDrawGoogleMapsAdapter, TerraDrawMapboxGLAdapter, TerraDrawLeafletAdapter, };
1
+ import { TerraDrawGoogleMapsAdapter } from "./adapters/google-maps.adapter";
2
+ import { TerraDrawLeafletAdapter } from "./adapters/leaflet.adapter";
3
+ import { TerraDrawMapboxGLAdapter } from "./adapters/mapbox-gl.adapter";
4
+ import { TerraDrawMapLibreGLAdapter } from "./adapters/maplibre-gl.adapter";
5
+ import { TerraDrawOpenLayersAdapter } from "./adapters/openlayers.adapter";
6
+ import { TerraDrawArcGISMapsSDKAdapter } from "./adapters/arcgis-maps-sdk.adapter";
7
+ import { TerraDrawAdapter, TerraDrawAdapterStyling, GetLngLatFromEvent, Project, SetCursor, TerraDrawChanges, TerraDrawStylingFunction, Unproject, HexColor, TerraDrawKeyboardEvent, TerraDrawMouseEvent, OnFinishContext } from "./common";
8
+ import { TerraDrawBaseAdapter } from "./adapters/common/base.adapter";
9
+ import { TerraDrawBaseDrawMode } from "./modes/base.mode";
10
+ import { TerraDrawCircleMode } from "./modes/circle/circle.mode";
11
+ import { TerraDrawFreehandMode } from "./modes/freehand/freehand.mode";
12
+ import { TerraDrawLineStringMode } from "./modes/linestring/linestring.mode";
13
+ import { TerraDrawPointMode } from "./modes/point/point.mode";
14
+ import { TerraDrawPolygonMode } from "./modes/polygon/polygon.mode";
15
+ import { TerraDrawRectangleMode } from "./modes/rectangle/rectangle.mode";
16
+ import { TerraDrawRenderMode } from "./modes/render/render.mode";
17
+ import { TerraDrawSelectMode } from "./modes/select/select.mode";
18
+ import { FeatureId, GeoJSONStoreFeatures, IdStrategy } from "./store/store";
19
+ import { BehaviorConfig } from "./modes/base.behavior";
20
+ import { ValidateMinAreaSquareMeters } from "./validations/min-size.validation";
21
+ import { ValidateMaxAreaSquareMeters } from "./validations/max-size.validation";
22
+ import { ValidateNotSelfIntersecting } from "./validations/not-self-intersecting.validation";
23
+ type FinishListener = (id: FeatureId, context: OnFinishContext) => void;
24
+ type ChangeListener = (ids: FeatureId[], type: string) => void;
25
+ type SelectListener = (id: FeatureId) => void;
26
+ type DeselectListener = () => void;
27
+ interface TerraDrawEventListeners {
28
+ ready: () => void;
29
+ finish: FinishListener;
30
+ change: ChangeListener;
31
+ select: SelectListener;
32
+ deselect: DeselectListener;
33
+ }
34
+ type TerraDrawEvents = keyof TerraDrawEventListeners;
35
+ declare class TerraDraw {
36
+ private _modes;
37
+ private _mode;
38
+ private _adapter;
39
+ private _enabled;
40
+ private _store;
41
+ private _eventListeners;
42
+ private _instanceSelectMode;
43
+ constructor(options: {
44
+ adapter: TerraDrawAdapter;
45
+ modes: TerraDrawBaseDrawMode<any>[];
46
+ idStrategy?: IdStrategy<FeatureId>;
47
+ tracked?: boolean;
48
+ });
49
+ private checkEnabled;
50
+ private getModeStyles;
51
+ private featuresAtLocation;
52
+ private getSelectMode;
53
+ /**
54
+ * Allows the setting of a style for a given mode
55
+ *
56
+ * @param mode - The mode you wish to set a style for
57
+ * @param styles - The styles you wish to set for the mode - this is
58
+ * the same as the initialisation style schema
59
+ *
60
+ * @beta
61
+ */
62
+ setModeStyles<Styling extends Record<string, number | HexColor>>(mode: string, styles: Styling): void;
63
+ /**
64
+ * Allows the user to get a snapshot (copy) of all given features
65
+ *
66
+ * @returns An array of all given Feature Geometries in the instances store
67
+ *
68
+ * @beta
69
+ */
70
+ getSnapshot(): GeoJSONStoreFeatures[];
71
+ /**
72
+ * Removes all data from the current store and removes any rendered layers
73
+ * via the registering the adapter.
74
+ *
75
+ * @beta
76
+ */
77
+ clear(): void;
78
+ /**
79
+ * A property used to determine whether the instance is active or not. You
80
+ * can use the start method to set this to true, and stop method to set this to false.
81
+ * This is a read only property.
82
+ *
83
+ * @return true or false depending on if the instance is stopped or started
84
+ * @readonly
85
+ * @beta
86
+ */
87
+ get enabled(): boolean;
88
+ /**
89
+ * enabled is a read only property and will throw and error if you try and set it.
90
+ *
91
+ * @beta
92
+ */
93
+ set enabled(_: boolean);
94
+ /**
95
+ * A method for getting the current mode name
96
+ *
97
+ * @return the current mode name
98
+ *
99
+ * @beta
100
+ */
101
+ getMode(): string;
102
+ /**
103
+ * A method for setting the current mode by name. Under the hood this will stop
104
+ * the previous mode and start the new one.
105
+ * @param mode - The mode name you wish to start
106
+ *
107
+ * @beta
108
+ */
109
+ setMode(mode: string): void;
110
+ /**
111
+ * A method for removing features to the store
112
+ * @param ids
113
+ * @returns
114
+ *
115
+ * @beta
116
+ */
117
+ removeFeatures(ids: FeatureId[]): void;
118
+ /**
119
+ * Provides the ability to programmatically select a feature using the instances provided select mode.
120
+ * If not select mode is provided in the instance, an error will be thrown. If the instance is not currently
121
+ * in the select mode, it will switch to it.
122
+ * @param id - the id of the feature to select
123
+ * @beta
124
+ */
125
+ selectFeature(id: FeatureId): void;
126
+ /**
127
+ * Provides the ability to programmatically deselect a feature using the instances provided select mode.
128
+ * If not select mode is provided in the instance, an error will be thrown. If the instance is not currently
129
+ * in the select mode, it will switch to it.
130
+ * @param id - the id of the feature to deselect
131
+ * @beta
132
+ */
133
+ deselectFeature(id: FeatureId): void;
134
+ /**
135
+ * Returns the next feature id from the store - defaults to UUID4 unless you have
136
+ * set a custom idStrategy. This method can be useful if you are needing creating features
137
+ * outside of the Terra Draw instance but want to add them in to the store.
138
+ * @returns a id, either number of string based on whatever the configured idStrategy is
139
+ *
140
+ * @beta
141
+ */
142
+ getFeatureId(): FeatureId;
143
+ /**
144
+ * Returns true or false depending on if the Terra Draw instance has a feature with a given id
145
+ * @returns a boolean determining if the instance has a feature with the given id
146
+ *
147
+ * @beta
148
+ */
149
+ hasFeature(id: FeatureId): boolean;
150
+ /**
151
+ * A method for adding features to the store. This method will validate the features.
152
+ * Features must match one of the modes enabled in the instance.
153
+ * @param mode
154
+ * @param features
155
+ * @returns
156
+ *
157
+ * @beta
158
+ */
159
+ addFeatures(features: GeoJSONStoreFeatures[]): void;
160
+ /**
161
+ * A method starting Terra Draw. It put the instance into a started state, and
162
+ * in registers the passed adapter giving it all the callbacks required to operate.
163
+ *
164
+ * @beta
165
+ */
166
+ start(): void;
167
+ /**
168
+ * Gets the features at a given longitude and latitude.
169
+ * Will return point and linestrings that are a given pixel distance
170
+ * away from the lng/lat and any polygons which contain it.
171
+ *
172
+ * @beta
173
+ */
174
+ getFeaturesAtLngLat(lngLat: {
175
+ lng: number;
176
+ lat: number;
177
+ }, options?: {
178
+ pointerDistance: number;
179
+ ignoreSelectFeatures: boolean;
180
+ }): GeoJSONStoreFeatures[];
181
+ /**
182
+ * Takes a given pointer event and
183
+ * Will return point and linestrings that are a given pixel distance
184
+ * away from the lng/lat and any polygons which contain it.
185
+ *
186
+ * @beta
187
+ */
188
+ getFeaturesAtPointerEvent(event: PointerEvent | MouseEvent, options?: {
189
+ pointerDistance: number;
190
+ ignoreSelectFeatures: boolean;
191
+ }): GeoJSONStoreFeatures[];
192
+ /**
193
+ * A method for stopping Terra Draw. Will clear the store, deregister the adapter and
194
+ * remove any rendered layers in the process.
195
+ *
196
+ * @beta
197
+ */
198
+ stop(): void;
199
+ /**
200
+ * Registers a Terra Draw event
201
+ *
202
+ * @param event - The name of the event you wish to listen for
203
+ * @param callback - The callback with you wish to be called when this event occurs
204
+ *
205
+ * @beta
206
+ */
207
+ on<T extends TerraDrawEvents>(event: T, callback: TerraDrawEventListeners[T]): void;
208
+ /**
209
+ * Unregisters a Terra Draw event
210
+ *
211
+ * @param event - The name of the event you wish to unregister
212
+ * @param callback - The callback you originally provided to the 'on' method
213
+ *
214
+ * @beta
215
+ */
216
+ off<T extends TerraDrawEvents>(event: TerraDrawEvents, callback: TerraDrawEventListeners[T]): void;
217
+ }
218
+ declare const TerraDrawExtend: {
219
+ TerraDrawBaseDrawMode: typeof TerraDrawBaseDrawMode;
220
+ TerraDrawBaseAdapter: typeof TerraDrawBaseAdapter;
221
+ };
222
+ export { TerraDraw, TerraDrawSelectMode, TerraDrawPointMode, TerraDrawLineStringMode, TerraDrawPolygonMode, TerraDrawCircleMode, TerraDrawFreehandMode, TerraDrawRenderMode, TerraDrawRectangleMode, TerraDrawGoogleMapsAdapter, TerraDrawMapboxGLAdapter, TerraDrawLeafletAdapter, TerraDrawMapLibreGLAdapter, TerraDrawOpenLayersAdapter, TerraDrawArcGISMapsSDKAdapter, TerraDrawExtend, BehaviorConfig, GeoJSONStoreFeatures, HexColor, TerraDrawMouseEvent, TerraDrawAdapterStyling, TerraDrawKeyboardEvent, TerraDrawChanges, TerraDrawStylingFunction, Project, Unproject, SetCursor, GetLngLatFromEvent, ValidateMinAreaSquareMeters, ValidateMaxAreaSquareMeters, ValidateNotSelfIntersecting, };