terra-draw 0.0.1-alpha.6 → 0.0.1-alpha.60
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/.devcontainer/Dockerfile +8 -0
- package/.devcontainer/devcontainer.json +21 -0
- package/.devcontainer/post-create.sh +16 -0
- package/README.md +30 -6
- package/dist/adapters/arcgis-maps-sdk.adapter.d.ts +105 -0
- package/dist/adapters/common/adapter-listener.d.ts +22 -0
- package/dist/adapters/common/base.adapter.d.ts +59 -0
- package/dist/adapters/google-maps.adapter.d.ts +90 -39
- package/dist/adapters/leaflet.adapter.d.ts +97 -33
- package/dist/adapters/mapbox-gl.adapter.d.ts +89 -37
- package/dist/adapters/maplibre-gl.adapter.d.ts +71 -0
- package/dist/adapters/openlayers.adapter.d.ts +118 -0
- package/dist/common.d.ts +103 -98
- package/dist/geometry/boolean/is-valid-coordinate.d.ts +4 -0
- package/dist/geometry/boolean/is-valid-linestring-feature.d.ts +2 -0
- package/dist/geometry/boolean/is-valid-point.d.ts +2 -0
- package/dist/geometry/boolean/is-valid-polygon-feature.d.ts +3 -0
- package/dist/geometry/boolean/point-in-polygon.d.ts +2 -2
- package/dist/geometry/boolean/self-intersects.d.ts +2 -2
- package/dist/geometry/centroid.d.ts +2 -2
- package/dist/geometry/coordinates-identical.d.ts +2 -2
- package/dist/geometry/get-coordinates-as-points.d.ts +6 -6
- package/dist/geometry/get-midpoints.d.ts +8 -7
- package/dist/geometry/helpers.d.ts +4 -4
- package/dist/geometry/limit-decimal-precision.d.ts +1 -1
- package/dist/geometry/measure/haversine-distance.d.ts +2 -2
- package/dist/geometry/measure/pixel-distance-to-line.d.ts +10 -10
- package/dist/geometry/measure/pixel-distance.d.ts +7 -7
- package/dist/geometry/measure/rhumb-bearing.d.ts +2 -2
- package/dist/geometry/measure/rhumb-destination.d.ts +2 -2
- package/dist/geometry/measure/rhumb-distance.d.ts +2 -2
- package/dist/geometry/midpoint-coordinate.d.ts +3 -2
- package/dist/geometry/shape/create-bbox.d.ts +10 -0
- package/dist/geometry/shape/create-circle.d.ts +7 -7
- package/dist/geometry/shape/great-circle-line.d.ts +12 -0
- package/dist/geometry/transform/rotate.d.ts +2 -2
- package/dist/geometry/transform/scale.d.ts +2 -2
- package/dist/modes/base.behavior.d.ts +19 -19
- package/dist/modes/base.mode.d.ts +62 -33
- package/dist/modes/circle/circle.mode.d.ts +55 -35
- package/dist/modes/click-bounding-box.behavior.d.ts +6 -7
- package/dist/modes/freehand/freehand.mode.d.ts +63 -37
- package/dist/modes/great-circle-snapping.behavior.d.ts +14 -0
- package/dist/modes/greatcircle/great-circle.mode.d.ts +64 -0
- package/dist/modes/linestring/linestring.mode.d.ts +67 -40
- package/dist/modes/pixel-distance.behavior.d.ts +7 -7
- package/dist/modes/point/point.mode.d.ts +44 -26
- package/dist/modes/polygon/behaviors/closing-points.behavior.d.ts +19 -19
- package/dist/modes/polygon/polygon.mode.d.ts +70 -49
- package/dist/modes/rectangle/rectangle.mode.d.ts +55 -0
- package/dist/modes/render/render.mode.d.ts +52 -23
- package/dist/modes/select/behaviors/drag-coordinate-resize.behavior.d.ts +31 -0
- package/dist/modes/select/behaviors/drag-coordinate.behavior.d.ts +20 -13
- package/dist/modes/select/behaviors/drag-feature.behavior.d.ts +20 -17
- package/dist/modes/select/behaviors/{features-at-mouse-event.behavior.d.ts → feature-at-pointer-event.behavior.d.ts} +15 -15
- package/dist/modes/select/behaviors/midpoint.behavior.d.ts +19 -18
- package/dist/modes/select/behaviors/rotate-feature.behavior.d.ts +14 -13
- package/dist/modes/select/behaviors/scale-feature.behavior.d.ts +14 -13
- package/dist/modes/select/behaviors/selection-point.behavior.d.ts +19 -18
- package/dist/modes/select/select.mode.d.ts +117 -78
- package/dist/modes/snapping.behavior.d.ts +16 -13
- package/dist/modes/static/static.mode.d.ts +32 -30
- package/dist/store/spatial-index/quickselect.d.ts +2 -2
- package/dist/store/spatial-index/rbush.d.ts +35 -35
- package/dist/store/spatial-index/spatial-index.d.ts +18 -18
- package/dist/store/store-feature-validation.d.ts +16 -0
- package/dist/store/store.d.ts +59 -48
- package/dist/terra-draw.cjs +1 -1
- package/dist/terra-draw.cjs.map +1 -1
- package/dist/terra-draw.d.ts +220 -48
- 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/dist/util/geoms.d.ts +3 -3
- package/dist/util/id.d.ts +1 -1
- package/dist/util/styling.d.ts +2 -2
- package/e2e/README.md +29 -0
- package/e2e/package-lock.json +4249 -0
- package/e2e/package.json +26 -0
- package/e2e/playwright.config.ts +77 -0
- package/e2e/public/index.html +53 -0
- package/e2e/src/index.ts +165 -0
- package/e2e/tests/leaflet.spec.ts +413 -0
- package/e2e/tests/setup.ts +164 -0
- package/e2e/webpack.config.js +36 -0
- package/jest.nocheck.config.ts +17 -0
- package/package.json +157 -87
- package/readme.gif +0 -0
- package/tsconfig.json +17 -12
- package/CODE_OF_CONDUCT.md +0 -36
- package/CONTRIBUTING.md +0 -17
- package/DEVELOPMENT.md +0 -77
- package/dist/bundle.js +0 -6
- package/dist/bundle.js.LICENSE.txt +0 -4
- package/dist/geometry/create-circle.d.ts +0 -6
- package/dist/geometry/get-pixel-distance-to-line.d.ts +0 -10
- package/dist/geometry/get-pixel-distance.d.ts +0 -7
- package/dist/geometry/haversine-distance.d.ts +0 -1
- package/dist/geometry/point-in-polygon.d.ts +0 -1
- package/dist/geometry/self-intersects.d.ts +0 -2
- package/dist/modes/circle.mode.d.ts +0 -18
- package/dist/modes/freehand.mode.d.ts +0 -20
- package/dist/modes/line-string.mode.d.ts +0 -21
- package/dist/modes/point.mode.d.ts +0 -14
- package/dist/modes/polygon/behaviors/start-end-point.behavior.d.ts +0 -11
- package/dist/modes/polygon.mode.d.ts +0 -21
- package/dist/modes/select.mode.d.ts +0 -21
- package/dist/modes/static.mode.d.ts +0 -10
- package/jest.config.ts +0 -27
package/dist/terra-draw.d.ts
CHANGED
|
@@ -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 {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
10
|
-
import {
|
|
11
|
-
import {
|
|
12
|
-
import {
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
private
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
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, };
|