2021-06-03 01:31:18 -04:00
|
|
|
import React, { ReactChild, useContext } from "react";
|
2021-03-11 19:02:58 -05:00
|
|
|
import useDebounce from "../hooks/useDebounce";
|
2020-04-29 04:21:44 -04:00
|
|
|
|
2021-06-03 01:31:18 -04:00
|
|
|
export const StageScaleContext = React.createContext(undefined) as any;
|
|
|
|
export const DebouncedStageScaleContext = React.createContext(undefined) as any;
|
|
|
|
export const StageWidthContext = React.createContext(undefined) as any;
|
|
|
|
export const StageHeightContext = React.createContext(undefined) as any;
|
|
|
|
export const SetPreventMapInteractionContext = React.createContext(undefined) as any;
|
|
|
|
export const MapWidthContext = React.createContext(undefined) as any;
|
|
|
|
export const MapHeightContext = React.createContext(undefined) as any;
|
|
|
|
export const InteractionEmitterContext = React.createContext(undefined) as any;
|
2020-04-29 04:21:44 -04:00
|
|
|
|
2021-06-03 01:31:18 -04:00
|
|
|
export function MapInteractionProvider({ value, children }: { value: any, children: ReactChild[]}) {
|
2021-03-11 19:02:58 -05:00
|
|
|
const {
|
|
|
|
stageScale,
|
|
|
|
stageWidth,
|
|
|
|
stageHeight,
|
|
|
|
setPreventMapInteraction,
|
|
|
|
mapWidth,
|
|
|
|
mapHeight,
|
|
|
|
interactionEmitter,
|
|
|
|
} = value;
|
|
|
|
const debouncedStageScale = useDebounce(stageScale, 200);
|
|
|
|
return (
|
|
|
|
<InteractionEmitterContext.Provider value={interactionEmitter}>
|
|
|
|
<SetPreventMapInteractionContext.Provider
|
|
|
|
value={setPreventMapInteraction}
|
|
|
|
>
|
|
|
|
<StageWidthContext.Provider value={stageWidth}>
|
|
|
|
<StageHeightContext.Provider value={stageHeight}>
|
|
|
|
<MapWidthContext.Provider value={mapWidth}>
|
|
|
|
<MapHeightContext.Provider value={mapHeight}>
|
|
|
|
<StageScaleContext.Provider value={stageScale}>
|
|
|
|
<DebouncedStageScaleContext.Provider
|
2021-03-12 22:23:37 -05:00
|
|
|
value={debouncedStageScale || 1}
|
2021-03-11 19:02:58 -05:00
|
|
|
>
|
|
|
|
{children}
|
|
|
|
</DebouncedStageScaleContext.Provider>
|
|
|
|
</StageScaleContext.Provider>
|
|
|
|
</MapHeightContext.Provider>
|
|
|
|
</MapWidthContext.Provider>
|
|
|
|
</StageHeightContext.Provider>
|
|
|
|
</StageWidthContext.Provider>
|
|
|
|
</SetPreventMapInteractionContext.Provider>
|
|
|
|
</InteractionEmitterContext.Provider>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
export function useInteractionEmitter() {
|
|
|
|
const context = useContext(InteractionEmitterContext);
|
|
|
|
if (context === undefined) {
|
|
|
|
throw new Error(
|
|
|
|
"useInteractionEmitter must be used within a MapInteractionProvider"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
return context;
|
|
|
|
}
|
|
|
|
|
|
|
|
export function useSetPreventMapInteraction() {
|
|
|
|
const context = useContext(SetPreventMapInteractionContext);
|
|
|
|
if (context === undefined) {
|
|
|
|
throw new Error(
|
|
|
|
"useSetPreventMapInteraction must be used within a MapInteractionProvider"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
return context;
|
|
|
|
}
|
|
|
|
|
|
|
|
export function useStageWidth() {
|
|
|
|
const context = useContext(StageWidthContext);
|
|
|
|
if (context === undefined) {
|
|
|
|
throw new Error(
|
|
|
|
"useStageWidth must be used within a MapInteractionProvider"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
return context;
|
|
|
|
}
|
|
|
|
|
|
|
|
export function useStageHeight() {
|
|
|
|
const context = useContext(StageHeightContext);
|
|
|
|
if (context === undefined) {
|
|
|
|
throw new Error(
|
|
|
|
"useStageHeight must be used within a MapInteractionProvider"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
return context;
|
|
|
|
}
|
|
|
|
|
|
|
|
export function useMapWidth() {
|
|
|
|
const context = useContext(MapWidthContext);
|
|
|
|
if (context === undefined) {
|
|
|
|
throw new Error("useMapWidth must be used within a MapInteractionProvider");
|
|
|
|
}
|
|
|
|
return context;
|
|
|
|
}
|
|
|
|
|
|
|
|
export function useMapHeight() {
|
|
|
|
const context = useContext(MapHeightContext);
|
|
|
|
if (context === undefined) {
|
|
|
|
throw new Error(
|
|
|
|
"useMapHeight must be used within a MapInteractionProvider"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
return context;
|
|
|
|
}
|
|
|
|
|
|
|
|
export function useStageScale() {
|
|
|
|
const context = useContext(StageScaleContext);
|
2021-02-05 21:32:38 -05:00
|
|
|
if (context === undefined) {
|
|
|
|
throw new Error(
|
2021-03-11 19:02:58 -05:00
|
|
|
"useStageScale must be used within a MapInteractionProvider"
|
2021-02-05 21:32:38 -05:00
|
|
|
);
|
|
|
|
}
|
|
|
|
return context;
|
|
|
|
}
|
|
|
|
|
2021-03-11 19:02:58 -05:00
|
|
|
export function useDebouncedStageScale() {
|
|
|
|
const context = useContext(DebouncedStageScaleContext);
|
|
|
|
if (context === undefined) {
|
|
|
|
throw new Error(
|
|
|
|
"useDebouncedStageScale must be used within a MapInteractionProvider"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
return context;
|
|
|
|
}
|