layerchart 0.32.0 → 0.32.1
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/dist/components/Circle.svelte +1 -1
- package/dist/components/Circle.svelte.d.ts +1 -1
- package/dist/components/GeoEdgeFade.svelte +22 -0
- package/dist/components/GeoEdgeFade.svelte.d.ts +21 -0
- package/dist/components/GeoPoint.svelte +8 -3
- package/dist/components/GeoPoint.svelte.d.ts +4 -3
- package/dist/components/GeoSpline.svelte +37 -0
- package/dist/components/GeoSpline.svelte.d.ts +23 -0
- package/dist/components/Highlight.svelte.d.ts +1 -1
- package/dist/components/Zoom.svelte +1 -1
- package/dist/components/Zoom.svelte.d.ts +1 -1
- package/dist/components/index.d.ts +2 -0
- package/dist/components/index.js +2 -0
- package/package.json +2 -2
|
@@ -7,7 +7,7 @@ declare const __propDef: {
|
|
|
7
7
|
initialCx?: number | undefined;
|
|
8
8
|
cy?: number | undefined;
|
|
9
9
|
initialCy?: number | undefined;
|
|
10
|
-
r
|
|
10
|
+
r?: number | undefined;
|
|
11
11
|
initialR?: number | undefined;
|
|
12
12
|
spring?: boolean | Parameters<typeof springStore>[1];
|
|
13
13
|
tweened?: boolean | Parameters<typeof tweenedStore>[1];
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
<script>import { getContext } from 'svelte';
|
|
2
|
+
import { scaleLinear } from 'd3-scale';
|
|
3
|
+
import { geoDistance } from 'd3-geo';
|
|
4
|
+
import { geoContext } from './GeoContext.svelte';
|
|
5
|
+
export let link;
|
|
6
|
+
const { width, height } = getContext('LayerCake');
|
|
7
|
+
const geo = geoContext();
|
|
8
|
+
const fade = scaleLinear().domain([-0.1, 0]).range([0, 0.1]);
|
|
9
|
+
const clamper = scaleLinear().domain([0, 1]).range([0, 1]).clamp(true);
|
|
10
|
+
// $: center = $geo.invert([$width / 2, $height / 2]);
|
|
11
|
+
$: center = $geo.invert($geo.translate());
|
|
12
|
+
$: source = link.source;
|
|
13
|
+
$: target = link.target;
|
|
14
|
+
$: startDistance = 1.57 - geoDistance(source, center);
|
|
15
|
+
$: endDistance = 1.57 - geoDistance(target, center);
|
|
16
|
+
$: distance = startDistance < endDistance ? startDistance : endDistance;
|
|
17
|
+
$: opacity = clamper(fade(distance));
|
|
18
|
+
</script>
|
|
19
|
+
|
|
20
|
+
<g {opacity}>
|
|
21
|
+
<slot />
|
|
22
|
+
</g>
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { SvelteComponentTyped } from "svelte";
|
|
2
|
+
declare const __propDef: {
|
|
3
|
+
props: {
|
|
4
|
+
link: {
|
|
5
|
+
source: [number, number];
|
|
6
|
+
target: [number, number];
|
|
7
|
+
};
|
|
8
|
+
};
|
|
9
|
+
events: {
|
|
10
|
+
[evt: string]: CustomEvent<any>;
|
|
11
|
+
};
|
|
12
|
+
slots: {
|
|
13
|
+
default: {};
|
|
14
|
+
};
|
|
15
|
+
};
|
|
16
|
+
export type GeoEdgeFadeProps = typeof __propDef.props;
|
|
17
|
+
export type GeoEdgeFadeEvents = typeof __propDef.events;
|
|
18
|
+
export type GeoEdgeFadeSlots = typeof __propDef.slots;
|
|
19
|
+
export default class GeoEdgeFade extends SvelteComponentTyped<GeoEdgeFadeProps, GeoEdgeFadeEvents, GeoEdgeFadeSlots> {
|
|
20
|
+
}
|
|
21
|
+
export {};
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
<script>import { getContext } from 'svelte';
|
|
2
2
|
import { scaleCanvas } from 'layercake';
|
|
3
3
|
import { geoContext } from './GeoContext.svelte';
|
|
4
|
+
import Circle from './Circle.svelte';
|
|
4
5
|
/** Latitude */
|
|
5
6
|
export let lat;
|
|
6
7
|
/** Longitude */
|
|
@@ -22,7 +23,11 @@ $: if (renderContext === 'canvas' && $ctx) {
|
|
|
22
23
|
</script>
|
|
23
24
|
|
|
24
25
|
{#if renderContext === 'svg'}
|
|
25
|
-
|
|
26
|
-
<
|
|
27
|
-
|
|
26
|
+
{#if $$slots.default}
|
|
27
|
+
<g transform="translate({x},{y})">
|
|
28
|
+
<slot />
|
|
29
|
+
</g>
|
|
30
|
+
{:else}
|
|
31
|
+
<Circle cx={x} cy={y} {...$$restProps} />
|
|
32
|
+
{/if}
|
|
28
33
|
{/if}
|
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import { SvelteComponentTyped } from "svelte";
|
|
2
2
|
declare const __propDef: {
|
|
3
3
|
props: {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
4
|
+
[x: string]: any;
|
|
5
|
+
lat: number;
|
|
6
|
+
long: number;
|
|
7
|
+
render?: ((ctx: CanvasRenderingContext2D, coords: {
|
|
7
8
|
x: number;
|
|
8
9
|
y: number;
|
|
9
10
|
}) => any) | undefined;
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
<script>import { getContext } from 'svelte';
|
|
2
|
+
import { geoOrthographic, geoInterpolate } from 'd3-geo';
|
|
3
|
+
import { curveNatural } from 'd3-shape';
|
|
4
|
+
import { geoContext } from './GeoContext.svelte';
|
|
5
|
+
import Spline from './Spline.svelte';
|
|
6
|
+
export let link;
|
|
7
|
+
/** Amount of loft to apply to the midle of the curve */
|
|
8
|
+
export let loft = 1.0;
|
|
9
|
+
/**
|
|
10
|
+
* Curve of spline drawn. Imported via d3-shape.
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* import { curveNatural } from 'd3-shape';
|
|
14
|
+
* <GeoSpline curve={curveNatrual} />
|
|
15
|
+
*
|
|
16
|
+
* @type {CurveFactory | CurveFactoryLineOnly | undefined}
|
|
17
|
+
*/
|
|
18
|
+
export let curve = curveNatural;
|
|
19
|
+
const { width, height } = getContext('LayerCake');
|
|
20
|
+
const geo = geoContext();
|
|
21
|
+
$: loftedProjection = geoOrthographic()
|
|
22
|
+
.translate($geo.translate())
|
|
23
|
+
.rotate($geo.rotate())
|
|
24
|
+
.scale($geo.scale() * loft);
|
|
25
|
+
$: source = $geo(link.source);
|
|
26
|
+
$: target = $geo(link.target);
|
|
27
|
+
$: middle = loftedProjection(geoInterpolate(link.source, link.target)(0.5));
|
|
28
|
+
</script>
|
|
29
|
+
|
|
30
|
+
<Spline
|
|
31
|
+
data={[source, middle, target]}
|
|
32
|
+
x={(d) => d[0]}
|
|
33
|
+
y={(d) => d[1]}
|
|
34
|
+
defined={(d) => $geo.invert(d)}
|
|
35
|
+
{curve}
|
|
36
|
+
{...$$restProps}
|
|
37
|
+
/>
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { SvelteComponentTyped } from "svelte";
|
|
2
|
+
import type { CurveFactory, CurveFactoryLineOnly } from 'd3-shape';
|
|
3
|
+
declare const __propDef: {
|
|
4
|
+
props: {
|
|
5
|
+
[x: string]: any;
|
|
6
|
+
link: {
|
|
7
|
+
source: [number, number];
|
|
8
|
+
target: [number, number];
|
|
9
|
+
};
|
|
10
|
+
loft?: number | undefined;
|
|
11
|
+
curve?: CurveFactory | CurveFactoryLineOnly | undefined;
|
|
12
|
+
};
|
|
13
|
+
events: {
|
|
14
|
+
[evt: string]: CustomEvent<any>;
|
|
15
|
+
};
|
|
16
|
+
slots: {};
|
|
17
|
+
};
|
|
18
|
+
export type GeoSplineProps = typeof __propDef.props;
|
|
19
|
+
export type GeoSplineEvents = typeof __propDef.events;
|
|
20
|
+
export type GeoSplineSlots = typeof __propDef.slots;
|
|
21
|
+
export default class GeoSpline extends SvelteComponentTyped<GeoSplineProps, GeoSplineEvents, GeoSplineSlots> {
|
|
22
|
+
}
|
|
23
|
+
export {};
|
|
@@ -8,7 +8,7 @@ declare const __propDef: {
|
|
|
8
8
|
initialCx?: number | undefined;
|
|
9
9
|
cy?: number | undefined;
|
|
10
10
|
initialCy?: number | undefined;
|
|
11
|
-
r
|
|
11
|
+
r?: number | undefined;
|
|
12
12
|
initialR?: number | undefined;
|
|
13
13
|
spring?: boolean | import("svelte/motion").SpringOpts | undefined;
|
|
14
14
|
tweened?: boolean | import("svelte/motion").TweenedOptions<unknown> | undefined;
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
import { motionStore } from '../stores/motionStore.js';
|
|
3
3
|
const { width, height, padding } = getContext('LayerCake');
|
|
4
4
|
export let mode = 'svg';
|
|
5
|
-
export let translateOnScale;
|
|
5
|
+
export let translateOnScale = false;
|
|
6
6
|
export let spring = undefined;
|
|
7
7
|
export let tweened = undefined;
|
|
8
8
|
export let disablePointer = false;
|
|
@@ -3,7 +3,7 @@ import { motionStore } from '../stores/motionStore.js';
|
|
|
3
3
|
declare const __propDef: {
|
|
4
4
|
props: {
|
|
5
5
|
mode?: "svg" | "manual" | undefined;
|
|
6
|
-
translateOnScale
|
|
6
|
+
translateOnScale?: boolean | undefined;
|
|
7
7
|
spring?: boolean | Parameters<typeof motionStore>[1]['spring'];
|
|
8
8
|
tweened?: boolean | Parameters<typeof motionStore>[1]['tweened'];
|
|
9
9
|
disablePointer?: boolean | undefined;
|
|
@@ -15,8 +15,10 @@ export { default as ColorRamp } from './ColorRamp.svelte';
|
|
|
15
15
|
export { default as Frame } from './Frame.svelte';
|
|
16
16
|
export { default as GeoCircle } from './GeoCircle.svelte';
|
|
17
17
|
export { default as GeoContext, geoContext } from './GeoContext.svelte';
|
|
18
|
+
export { default as GeoEdgeFade } from './GeoEdgeFade.svelte';
|
|
18
19
|
export { default as GeoPath } from './GeoPath.svelte';
|
|
19
20
|
export { default as GeoPoint } from './GeoPoint.svelte';
|
|
21
|
+
export { default as GeoSpline } from './GeoSpline.svelte';
|
|
20
22
|
export { default as GeoTile } from './GeoTile.svelte';
|
|
21
23
|
export { default as Graticule } from './Graticule.svelte';
|
|
22
24
|
export { default as Group } from './Group.svelte';
|
package/dist/components/index.js
CHANGED
|
@@ -15,8 +15,10 @@ export { default as ColorRamp } from './ColorRamp.svelte';
|
|
|
15
15
|
export { default as Frame } from './Frame.svelte';
|
|
16
16
|
export { default as GeoCircle } from './GeoCircle.svelte';
|
|
17
17
|
export { default as GeoContext, geoContext } from './GeoContext.svelte';
|
|
18
|
+
export { default as GeoEdgeFade } from './GeoEdgeFade.svelte';
|
|
18
19
|
export { default as GeoPath } from './GeoPath.svelte';
|
|
19
20
|
export { default as GeoPoint } from './GeoPoint.svelte';
|
|
21
|
+
export { default as GeoSpline } from './GeoSpline.svelte';
|
|
20
22
|
export { default as GeoTile } from './GeoTile.svelte';
|
|
21
23
|
export { default as Graticule } from './Graticule.svelte';
|
|
22
24
|
export { default as Group } from './Group.svelte';
|
package/package.json
CHANGED
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
"author": "Sean Lynch <techniq35@gmail.com>",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"repository": "techniq/layerchart",
|
|
7
|
-
"version": "0.32.
|
|
7
|
+
"version": "0.32.1",
|
|
8
8
|
"devDependencies": {
|
|
9
9
|
"@changesets/cli": "^2.27.1",
|
|
10
10
|
"@mdi/js": "^7.4.47",
|
|
@@ -83,7 +83,7 @@
|
|
|
83
83
|
"lodash-es": "^4.17.21",
|
|
84
84
|
"posthog-js": "^1.108.3",
|
|
85
85
|
"shapefile": "^0.6.6",
|
|
86
|
-
"svelte-ux": "^0.61.
|
|
86
|
+
"svelte-ux": "^0.61.2",
|
|
87
87
|
"topojson-client": "^3.1.0"
|
|
88
88
|
},
|
|
89
89
|
"peerDependencies": {
|