terra-draw 0.0.1-alpha.41 → 0.0.1-alpha.42

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/CHANGELOG.md CHANGED
@@ -2,6 +2,8 @@
2
2
 
3
3
  All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
4
4
 
5
+ ### 0.0.1-alpha.42 (2023-07-24)
6
+
5
7
  ### 0.0.1-alpha.41 (2023-07-16)
6
8
 
7
9
 
package/dist/common.d.ts CHANGED
@@ -1,5 +1,7 @@
1
1
  import { StoreChangeHandler, GeoJSONStore, GeoJSONStoreFeatures } from "./store/store";
2
2
  export type HexColor = `#${string}`;
3
+ export type HexColorStyling = HexColor | ((feature: GeoJSONStoreFeatures) => HexColor);
4
+ export type NumericStyling = number | ((feature: GeoJSONStoreFeatures) => number);
3
5
  export interface TerraDrawAdapterStyling {
4
6
  pointColor: HexColor;
5
7
  pointWidth: number;
@@ -1,7 +1,7 @@
1
1
  import { BehaviorConfig, TerraDrawModeBehavior } from "./base.behavior";
2
- import { TerraDrawAdapterStyling, TerraDrawKeyboardEvent, TerraDrawModeRegisterConfig, TerraDrawModeState, TerraDrawMouseEvent } from "../common";
2
+ import { HexColor, TerraDrawAdapterStyling, TerraDrawKeyboardEvent, TerraDrawModeRegisterConfig, TerraDrawModeState, TerraDrawMouseEvent } from "../common";
3
3
  import { GeoJSONStore, GeoJSONStoreFeatures, StoreChangeHandler } from "../store/store";
4
- type CustomStyling = Record<string, string | number>;
4
+ type CustomStyling = Record<string, string | number | ((feature: GeoJSONStoreFeatures) => HexColor) | ((feature: GeoJSONStoreFeatures) => number)>;
5
5
  export declare enum ModeTypes {
6
6
  Drawing = "drawing",
7
7
  Select = "select",
@@ -51,5 +51,8 @@ export declare abstract class TerraDrawBaseDrawMode<T extends CustomStyling> {
51
51
  onDragStart(event: TerraDrawMouseEvent, setMapDraggability: (enabled: boolean) => void): void;
52
52
  onDrag(event: TerraDrawMouseEvent, setMapDraggability: (enabled: boolean) => void): void;
53
53
  onDragEnd(event: TerraDrawMouseEvent, setMapDraggability: (enabled: boolean) => void): void;
54
+ protected getHexColorStylingValue(value: HexColor | ((feature: GeoJSONStoreFeatures) => HexColor) | undefined, defaultValue: HexColor, feature: GeoJSONStoreFeatures): HexColor;
55
+ protected getNumericStylingValue(value: number | ((feature: GeoJSONStoreFeatures) => number) | undefined, defaultValue: number, feature: GeoJSONStoreFeatures): number;
56
+ private getStylingValue;
54
57
  }
55
58
  export {};
@@ -1,4 +1,4 @@
1
- import { TerraDrawMouseEvent, TerraDrawAdapterStyling, TerraDrawKeyboardEvent, HexColor } from "../../common";
1
+ import { TerraDrawMouseEvent, TerraDrawAdapterStyling, TerraDrawKeyboardEvent, HexColorStyling, NumericStyling } from "../../common";
2
2
  import { GeoJSONStoreFeatures } from "../../store/store";
3
3
  import { TerraDrawBaseDrawMode } from "../base.mode";
4
4
  type TerraDrawCircleModeKeyEvents = {
@@ -6,10 +6,10 @@ type TerraDrawCircleModeKeyEvents = {
6
6
  finish: KeyboardEvent["key"] | null;
7
7
  };
8
8
  type FreehandPolygonStyling = {
9
- fillColor: HexColor;
10
- outlineColor: HexColor;
11
- outlineWidth: number;
12
- fillOpacity: number;
9
+ fillColor: HexColorStyling;
10
+ outlineColor: HexColorStyling;
11
+ outlineWidth: NumericStyling;
12
+ fillOpacity: NumericStyling;
13
13
  };
14
14
  export declare class TerraDrawCircleMode extends TerraDrawBaseDrawMode<FreehandPolygonStyling> {
15
15
  mode: string;
@@ -1,4 +1,4 @@
1
- import { TerraDrawMouseEvent, TerraDrawAdapterStyling, TerraDrawKeyboardEvent, HexColor } from "../../common";
1
+ import { TerraDrawMouseEvent, TerraDrawAdapterStyling, TerraDrawKeyboardEvent, HexColorStyling, NumericStyling } from "../../common";
2
2
  import { TerraDrawBaseDrawMode } from "../base.mode";
3
3
  import { GeoJSONStoreFeatures } from "../../store/store";
4
4
  type TerraDrawFreehandModeKeyEvents = {
@@ -6,14 +6,14 @@ type TerraDrawFreehandModeKeyEvents = {
6
6
  finish: KeyboardEvent["key"] | null;
7
7
  };
8
8
  type FreehandPolygonStyling = {
9
- fillColor: HexColor;
10
- outlineColor: HexColor;
11
- outlineWidth: number;
12
- fillOpacity: number;
13
- closingPointColor: HexColor;
14
- closingPointWidth: number;
15
- closingPointOutlineColor: HexColor;
16
- closingPointOutlineWidth: number;
9
+ fillColor: HexColorStyling;
10
+ outlineColor: HexColorStyling;
11
+ outlineWidth: NumericStyling;
12
+ fillOpacity: NumericStyling;
13
+ closingPointColor: HexColorStyling;
14
+ closingPointWidth: NumericStyling;
15
+ closingPointOutlineColor: HexColorStyling;
16
+ closingPointOutlineWidth: NumericStyling;
17
17
  };
18
18
  export declare class TerraDrawFreehandMode extends TerraDrawBaseDrawMode<FreehandPolygonStyling> {
19
19
  mode: string;
@@ -1,4 +1,4 @@
1
- import { TerraDrawMouseEvent, TerraDrawAdapterStyling, TerraDrawKeyboardEvent, HexColor } from "../../common";
1
+ import { TerraDrawMouseEvent, TerraDrawAdapterStyling, TerraDrawKeyboardEvent, HexColorStyling, NumericStyling } from "../../common";
2
2
  import { TerraDrawBaseDrawMode } from "../base.mode";
3
3
  import { BehaviorConfig } from "../base.behavior";
4
4
  import { GeoJSONStoreFeatures } from "../../store/store";
@@ -7,12 +7,12 @@ type TerraDrawGreateCircleModeKeyEvents = {
7
7
  finish: KeyboardEvent["key"] | null;
8
8
  };
9
9
  type GreateCircleStyling = {
10
- lineStringWidth: number;
11
- lineStringColor: HexColor;
12
- closingPointColor: HexColor;
13
- closingPointWidth: number;
14
- closingPointOutlineColor: HexColor;
15
- closingPointOutlineWidth: number;
10
+ lineStringWidth: NumericStyling;
11
+ lineStringColor: HexColorStyling;
12
+ closingPointColor: HexColorStyling;
13
+ closingPointWidth: NumericStyling;
14
+ closingPointOutlineColor: HexColorStyling;
15
+ closingPointOutlineWidth: NumericStyling;
16
16
  };
17
17
  export declare class TerraDrawGreatCircleMode extends TerraDrawBaseDrawMode<GreateCircleStyling> {
18
18
  mode: string;
@@ -1,4 +1,4 @@
1
- import { TerraDrawMouseEvent, TerraDrawAdapterStyling, TerraDrawKeyboardEvent, HexColor } from "../../common";
1
+ import { TerraDrawMouseEvent, TerraDrawAdapterStyling, TerraDrawKeyboardEvent, HexColorStyling, NumericStyling } from "../../common";
2
2
  import { TerraDrawBaseDrawMode } from "../base.mode";
3
3
  import { BehaviorConfig } from "../base.behavior";
4
4
  import { GeoJSONStoreFeatures } from "../../store/store";
@@ -7,12 +7,12 @@ type TerraDrawLineStringModeKeyEvents = {
7
7
  finish: KeyboardEvent["key"] | null;
8
8
  };
9
9
  type LineStringStyling = {
10
- lineStringWidth: number;
11
- lineStringColor: HexColor;
12
- closingPointColor: HexColor;
13
- closingPointWidth: number;
14
- closingPointOutlineColor: HexColor;
15
- closingPointOutlineWidth: number;
10
+ lineStringWidth: NumericStyling;
11
+ lineStringColor: HexColorStyling;
12
+ closingPointColor: HexColorStyling;
13
+ closingPointWidth: NumericStyling;
14
+ closingPointOutlineColor: HexColorStyling;
15
+ closingPointOutlineWidth: NumericStyling;
16
16
  };
17
17
  export declare class TerraDrawLineStringMode extends TerraDrawBaseDrawMode<LineStringStyling> {
18
18
  mode: string;
@@ -1,11 +1,11 @@
1
- import { TerraDrawMouseEvent, TerraDrawAdapterStyling, HexColor } from "../../common";
1
+ import { TerraDrawMouseEvent, TerraDrawAdapterStyling, NumericStyling, HexColorStyling } from "../../common";
2
2
  import { GeoJSONStoreFeatures } from "../../store/store";
3
3
  import { TerraDrawBaseDrawMode } from "../base.mode";
4
4
  type PointModeStyling = {
5
- pointWidth: number;
6
- pointColor: HexColor;
7
- pointOutlineColor: HexColor;
8
- pointOutlineWidth: number;
5
+ pointWidth: NumericStyling;
6
+ pointColor: HexColorStyling;
7
+ pointOutlineColor: HexColorStyling;
8
+ pointOutlineWidth: NumericStyling;
9
9
  };
10
10
  export declare class TerraDrawPointMode extends TerraDrawBaseDrawMode<PointModeStyling> {
11
11
  mode: string;
@@ -1,4 +1,4 @@
1
- import { TerraDrawMouseEvent, TerraDrawAdapterStyling, TerraDrawKeyboardEvent, HexColor } from "../../common";
1
+ import { TerraDrawMouseEvent, TerraDrawAdapterStyling, TerraDrawKeyboardEvent, HexColorStyling, NumericStyling } from "../../common";
2
2
  import { TerraDrawBaseDrawMode } from "../base.mode";
3
3
  import { BehaviorConfig } from "../base.behavior";
4
4
  import { GeoJSONStoreFeatures } from "../../store/store";
@@ -7,14 +7,14 @@ type TerraDrawPolygonModeKeyEvents = {
7
7
  finish?: KeyboardEvent["key"] | null;
8
8
  };
9
9
  type PolygonStyling = {
10
- fillColor: HexColor;
11
- outlineColor: HexColor;
12
- outlineWidth: number;
13
- fillOpacity: number;
14
- closingPointWidth: number;
15
- closingPointColor: HexColor;
16
- closingPointOutlineWidth: number;
17
- closingPointOutlineColor: HexColor;
10
+ fillColor: HexColorStyling;
11
+ outlineColor: HexColorStyling;
12
+ outlineWidth: NumericStyling;
13
+ fillOpacity: NumericStyling;
14
+ closingPointWidth: NumericStyling;
15
+ closingPointColor: HexColorStyling;
16
+ closingPointOutlineWidth: NumericStyling;
17
+ closingPointOutlineColor: HexColorStyling;
18
18
  };
19
19
  export declare class TerraDrawPolygonMode extends TerraDrawBaseDrawMode<PolygonStyling> {
20
20
  mode: string;
@@ -1,4 +1,4 @@
1
- import { TerraDrawMouseEvent, TerraDrawAdapterStyling, TerraDrawKeyboardEvent, HexColor } from "../../common";
1
+ import { TerraDrawMouseEvent, TerraDrawAdapterStyling, TerraDrawKeyboardEvent, HexColorStyling, NumericStyling } from "../../common";
2
2
  import { GeoJSONStoreFeatures } from "../../store/store";
3
3
  import { TerraDrawBaseDrawMode } from "../base.mode";
4
4
  type TerraDrawRectangleModeKeyEvents = {
@@ -6,10 +6,10 @@ type TerraDrawRectangleModeKeyEvents = {
6
6
  finish: KeyboardEvent["key"] | null;
7
7
  };
8
8
  type RectanglePolygonStyling = {
9
- fillColor: HexColor;
10
- outlineColor: HexColor;
11
- outlineWidth: number;
12
- fillOpacity: number;
9
+ fillColor: HexColorStyling;
10
+ outlineColor: HexColorStyling;
11
+ outlineWidth: NumericStyling;
12
+ fillOpacity: NumericStyling;
13
13
  };
14
14
  export declare class TerraDrawRectangleMode extends TerraDrawBaseDrawMode<RectanglePolygonStyling> {
15
15
  mode: string;
@@ -1,14 +1,25 @@
1
- import { TerraDrawAdapterStyling } from "../../common";
1
+ import { HexColorStyling, NumericStyling, TerraDrawAdapterStyling } from "../../common";
2
2
  import { ModeTypes, TerraDrawBaseDrawMode } from "../base.mode";
3
3
  import { BehaviorConfig } from "../base.behavior";
4
4
  import { GeoJSONStoreFeatures } from "../../terra-draw";
5
- type RenderModeStylingExt<T extends TerraDrawAdapterStyling> = {};
6
- type RenderModeStyling = RenderModeStylingExt<TerraDrawAdapterStyling>;
5
+ type RenderModeStyling = {
6
+ pointColor: HexColorStyling;
7
+ pointWidth: NumericStyling;
8
+ pointOutlineColor: HexColorStyling;
9
+ pointOutlineWidth: NumericStyling;
10
+ polygonFillColor: HexColorStyling;
11
+ polygonFillOpacity: NumericStyling;
12
+ polygonOutlineColor: HexColorStyling;
13
+ polygonOutlineWidth: NumericStyling;
14
+ lineStringWidth: NumericStyling;
15
+ lineStringColor: HexColorStyling;
16
+ zIndex: NumericStyling;
17
+ };
7
18
  export declare class TerraDrawRenderMode extends TerraDrawBaseDrawMode<RenderModeStyling> {
8
19
  type: ModeTypes;
9
20
  mode: string;
10
21
  constructor(options: {
11
- styles: Partial<TerraDrawAdapterStyling>;
22
+ styles: Partial<RenderModeStyling>;
12
23
  });
13
24
  /** @internal */
14
25
  registerBehaviors(behaviorConfig: BehaviorConfig): void;
@@ -33,7 +44,7 @@ export declare class TerraDrawRenderMode extends TerraDrawBaseDrawMode<RenderMod
33
44
  /** @internal */
34
45
  cleanUp(): void;
35
46
  /** @internal */
36
- styleFeature(): TerraDrawAdapterStyling;
47
+ styleFeature(feature: GeoJSONStoreFeatures): TerraDrawAdapterStyling;
37
48
  validateFeature(feature: unknown): feature is GeoJSONStoreFeatures;
38
49
  }
39
50
  export {};
@@ -1,4 +1,4 @@
1
- import { TerraDrawMouseEvent, TerraDrawKeyboardEvent, HexColor, TerraDrawAdapterStyling } from "../../common";
1
+ import { TerraDrawMouseEvent, TerraDrawKeyboardEvent, TerraDrawAdapterStyling, HexColorStyling, NumericStyling } from "../../common";
2
2
  import { ModeTypes, TerraDrawBaseDrawMode } from "../base.mode";
3
3
  import { BehaviorConfig } from "../base.behavior";
4
4
  import { GeoJSONStoreFeatures } from "../../store/store";
@@ -21,24 +21,24 @@ type ModeFlags = {
21
21
  };
22
22
  };
23
23
  type SelectionStyling = {
24
- selectedPointColor: HexColor;
25
- selectedPointWidth: number;
26
- selectedPointOutlineColor: HexColor;
27
- selectedPointOutlineWidth: number;
28
- selectedLineStringColor: HexColor;
29
- selectedLineStringWidth: number;
30
- selectedPolygonColor: HexColor;
31
- selectedPolygonFillOpacity: number;
32
- selectedPolygonOutlineColor: HexColor;
33
- selectedPolygonOutlineWidth: number;
34
- selectionPointWidth: number;
35
- selectionPointColor: HexColor;
36
- selectionPointOutlineColor: HexColor;
37
- selectionPointOutlineWidth: number;
38
- midPointColor: HexColor;
39
- midPointOutlineColor: HexColor;
40
- midPointWidth: number;
41
- midPointOutlineWidth: number;
24
+ selectedPointColor: HexColorStyling;
25
+ selectedPointWidth: NumericStyling;
26
+ selectedPointOutlineColor: HexColorStyling;
27
+ selectedPointOutlineWidth: NumericStyling;
28
+ selectedLineStringColor: HexColorStyling;
29
+ selectedLineStringWidth: NumericStyling;
30
+ selectedPolygonColor: HexColorStyling;
31
+ selectedPolygonFillOpacity: NumericStyling;
32
+ selectedPolygonOutlineColor: HexColorStyling;
33
+ selectedPolygonOutlineWidth: NumericStyling;
34
+ selectionPointWidth: NumericStyling;
35
+ selectionPointColor: HexColorStyling;
36
+ selectionPointOutlineColor: HexColorStyling;
37
+ selectionPointOutlineWidth: NumericStyling;
38
+ midPointColor: HexColorStyling;
39
+ midPointOutlineColor: HexColorStyling;
40
+ midPointWidth: NumericStyling;
41
+ midPointOutlineWidth: NumericStyling;
42
42
  };
43
43
  export declare class TerraDrawSelectMode extends TerraDrawBaseDrawMode<SelectionStyling> {
44
44
  type: ModeTypes;