- 323da77: feat: upgrade TerraDraw tp v1.0.0 from beta. Drop support of maplibre v2 and v3 since it is no longer supported by TerraDraw.
- 4ade13a: refactor: moved getDistanceUnitName to MeasureControl class
- c561a3d: fix: add distanceUnit, distancePrecision and areaPrecision properties to able to change measure unit and precision value in MeasureControl.
- 4e4f037: chore: updated dependencies.
- d8b3ca2: feat: add areaUnit property to switch unit in area either metric or imperial.
- f397f4b: - fix: fixed a bug of layer ordering of MeasureControl when addFeatures is used to restore data.
- fix: added recalc public method to re-measure area/distance of features.
- fix: delete text-font from default measure label style
- fix: adjusted text-size and text-letter-spacing to look better
- fix: adjusted measure label and layer style to avoid using true black and white.
- fix: use
$type
to filter feature for measuring label layers.
- 8375993: feat: add
computeElevation
option in MeasureControl to enable querying elevation from raster-dem source.
- fab72bc: fix: use TerraDrawExtend.BaseAdapterConfig type for adapterOptions.
-
a348105: feat: exposed TerraDraw adapter options from the plugin constructor.
Default adapter options can be changed like the below code. Please refer to more detailed default adapter options at here
const drawControl = new MaplibreTerradrawControl.MaplibreTerradrawControl({ adapterOptions: { coordinatePrecision: 9 } }); map.addControl(drawControl, 'top-left');
-
cb56751: chore: updated dependencies in package.json as follows:
- support
maplibre-gl
to v5 aspeerDependencies
- delete turfjs from
peerDependencies
since they are bundled in the package. - add
terradraw
marked as optional inpeerDependencies
meta because TerraDraw is included in the plugin package. Terradraw is only required when users want to do their own customization.
- support
- dd174c9: chore: updated teraddraw to beta.11
- 0addc97: fix: update properties to include measured distance/area in getFeatures function.
- 29b7a4b: feat: add download button to fetch geojson feature collection. Furtheremore, select, delete and download button are disabled when no feature is drawn.
- 29b7a4b: feat: update TerraDraw to 1.0.0-beta.10
- db9b16f: fix: fixed bug of polygon validation.
- b46c62b: feat: add maplibre v5 pre to peerDependencies, and added GlobeControl to the demo.
- 1ac5ce8: fix: delete unfinished geojson features if measured feature is cancelled. Furtheremore, deleted polygon validation from MeasureControl.
- 9d35b87: fix: add select and delete-selection for default mode of MeasureControl
- e7b1a5f: refactor: restructure folder structure to make sure each constant and interface is in a file. Also, upadated dependencies.
- 5a285ce: fix: support select and delete-selection mode for MeasureControl. Use change event to compute distance and area instead of finished.
- 42e6ef0: fix: changed TerraDraw mode style for MeasureControl to differentiate from normal control. Also, circle layer for line label is added to visualize node of distance.
- af6beaf: fix: only add relevant source for user specified modes. For example, only line layer and source is added if no modes of polygon are used.
-
36861d2: This release has a breaking change of the plugin interface. Please read carefully this changelog.
added MaplibreMeasureControl to provide measure line and area control easily.
Usage of
MaplibreMeasureControl
is like the below code.const drawControl = new MaplibreMeasureControl({ modes: [ 'linestring', 'polygon', 'rectangle', 'angled-rectangle', 'circle', 'sector', 'sensor', 'freehand', 'delete' ], open: true }); map.addControl(drawControl, 'top-left');
Due to adding new plugin control,
default
export was removed.New usage of
MaplibreTerradrawControl
will be like below.- NPM
- import MaplibreTerradrawControl from '$lib/index.js'; + import { MaplibreTerradrawControl } from '$lib/index.js';
- CDN
for CDN, library name of
MaplibreTerradrawControl
needs to be added.- const draw = new MaplibreTerradrawControl(); + const draw = new MaplibreTerradrawControl.MaplibreTerradrawControl();
Furthermore, all interfaces and constants are now exported from index.js.
- 9358be9: chore: updated vite and other dependencies. Moved exports.types before import and require in package.json
- 853a8a1: feat: add on/off function to the control for subscribing some events (currently only two modes - mode-changed and feature-deleted are supported)
- fc1c04f: fix: in some timing, TerraDraw throw error of 'Can not register unless mode is unregistered'. Hence, it resets _state in modes as unregistered before adding.
- 5529521: chore: updated devDependencies.
- cdf5c1d: fix: fixed bug of angled-rectangle, sensor and sector SVG icons which were not rotated with transform in some browser.
- 37a9836: fix: fixed bug when render button is removed. add default hidden mode if no render buttom.
- fa9ec0f: call this.deactivate() when calling map.removeControl(drawControl)
-
2e23ac1: feat: add
delete-selection
mode to allow users to delete only selected feature. Newdelete-selection
mode is enabled whenselect
mode is chosen. As default, it appears right afterselect
mode, but you can change it in constructor.const drawControl = new MaplibreTerradrawControl({ modes: [ 'render', 'select', 'delete-selection', // place `delete-selection` after select mode. Or you can delete it if this feature is not needed. 'point', 'delete' ], open: true }); map.addControl(drawControl, 'top-left');
- ec05a90: call TerraDraw.stop() when calling onRemove()
- c8742be: feat: added Sensor mode and Sector mode to the plugin.
- c4e42ff: remove controlContrainer on map.removeControl(drawControl)
-
bc8d9c3: feat: add 'delete' mode to arrow users to show/hide delete button in prefered order.
const drawControl = new MaplibreTerradrawControl({ modes: [ 'render', 'select', 'point', 'delete' // delete mode must be specified to show delete button in the tool ], open: true }); map.addControl(drawControl, 'top-left');
-
bf466fb: feat: add 'render' mode in default control options in constructor. Now, the position of render toggle mode button can be changed, or completely remove it from control to keep tool always open.
const drawControl = new MaplibreTerradrawControl({ modes: [ 'render', // delete this if you want the tool to be always opened. 'select', 'point' ], open: true // if you remove 'render' mode, make sure setting open as true. }); map.addControl(drawControl, 'top-left');
- aac04eb: fix: show tooltip for each button.
- 0a6130e: fix: fixed bug of angled-rectangle icon in active state. Rotate 45 degree of SVG itself.
- d1633d4: fix: added rotateable and scalable for linestring.
-
1935d2c: refactor: removed unused variable from the code
-
5c56e28: fix: merge modeOptions param into the first argument of constructor to make the interface simple.
In v0.1.0, it used the second argument of constructor to customise drawing options for each Terra Draw mode. The second argment was now merged into the first argument as shown in the below sample code.
const drawControl = new MaplibreTerradrawControl({ // only show polgyon, line and select mode. modes: ['polygon', 'linestring', 'select'], modeOptions: { select: new TerraDrawSelectMode({ flags: { // only update polygon settings for select mode. // default settings will be used for other geometry types // in this case, line uses default options of the plugin. polygon: { feature: { draggable: false, // users cannot drag to move polygon rotateable: true, scaleable: true, coordinates: { midpoints: false, // users cannot add a node on the middle of edge. draggable: true, deletable: false // users cannot delete a node. } } } } }) } }); map.addControl(drawControl, 'top-left');
-
4d9a435: feat: allows to overwrite default Terra Draw mode instances by using the second argument of constructor.
For example, if you only want to use polygon control, and you want to disable draggable option and node insertion/deletion on an edge of a polygon, the setting can be as follows.
const drawControl = new MaplibreTerradrawControl( { modes: ['polygon', 'select'] }, { select: new TerraDrawSelectMode({ flags: { polygon: { feature: { draggable: false, // users cannot drag to move polygon rotateable: true, scaleable: true, coordinates: { midpoints: false, // users cannot add a node on the middle of edge. draggable: true, deletable: false // users cannot delete a node. } } } } }) } ); map.addControl(drawControl, 'top-left');
-
4d9a435: feat: allows to change the order of Terra Draw modes on the plugin.
Now, an array of modes can be passed to the constructor of the plugin, and the mode controls will be added exactly the same order. You can also remove unnecessary modes from the array when you initialize the plugin.
For instance, you can only add point and select control on the plugin like the below code.
const drawControl = new MaplibreTerradrawControl({ modes: ['point', 'select'] }); map.addControl(drawControl, 'top-left');
- 0d9c15e: fix: updated peerDependencies in package.json to support maplibre v2 to v4 since terra-draw is supporting maplibre from v2
-
8ec1f8c: feat: added
open
option in the control constructor. Default is false. If true is set toopen
option, editor controller will be expaned as default.To expand control as default, create control instance like below.
const drawControl = new MaplibreTerradrawControl({ open: true });
- 069bd2e: fix: moved maplibre-gl and terra-draw to peerDependencies. and updated all other dependencies.
- bfe061e: fix: added TerraDrawRenderMode control as 'render' mode, and it will be used as default state.
- bbd65a7: fix: added index.d.ts and fixed package.json