terra-draw 0.0.1-alpha.6 → 0.0.1-alpha.61

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