@hunterchen/canvas 0.1.0
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/canvas/canvas.d.ts +29 -0
- package/dist/components/canvas/canvas.d.ts.map +1 -0
- package/dist/components/canvas/canvas.js +419 -0
- package/dist/components/canvas/canvas.js.map +1 -0
- package/dist/components/canvas/component.d.ts +47 -0
- package/dist/components/canvas/component.d.ts.map +1 -0
- package/dist/components/canvas/component.js +177 -0
- package/dist/components/canvas/component.js.map +1 -0
- package/dist/components/canvas/cursor.d.ts +8 -0
- package/dist/components/canvas/cursor.d.ts.map +1 -0
- package/dist/components/canvas/cursor.js +32 -0
- package/dist/components/canvas/cursor.js.map +1 -0
- package/dist/components/canvas/draggable.d.ts +21 -0
- package/dist/components/canvas/draggable.d.ts.map +1 -0
- package/dist/components/canvas/draggable.js +163 -0
- package/dist/components/canvas/draggable.js.map +1 -0
- package/dist/components/canvas/navbar/index.d.ts +19 -0
- package/dist/components/canvas/navbar/index.d.ts.map +1 -0
- package/dist/components/canvas/navbar/index.js +106 -0
- package/dist/components/canvas/navbar/index.js.map +1 -0
- package/dist/components/canvas/navbar/single-button.d.ts +17 -0
- package/dist/components/canvas/navbar/single-button.d.ts.map +1 -0
- package/dist/components/canvas/navbar/single-button.js +97 -0
- package/dist/components/canvas/navbar/single-button.js.map +1 -0
- package/dist/components/canvas/offest.d.ts +6 -0
- package/dist/components/canvas/offest.d.ts.map +1 -0
- package/dist/components/canvas/offest.js +12 -0
- package/dist/components/canvas/offest.js.map +1 -0
- package/dist/components/canvas/reset.d.ts +5 -0
- package/dist/components/canvas/reset.d.ts.map +1 -0
- package/dist/components/canvas/reset.js +7 -0
- package/dist/components/canvas/reset.js.map +1 -0
- package/dist/components/canvas/toolbar.d.ts +7 -0
- package/dist/components/canvas/toolbar.d.ts.map +1 -0
- package/dist/components/canvas/toolbar.js +28 -0
- package/dist/components/canvas/toolbar.js.map +1 -0
- package/dist/components/canvas/wrapper.d.ts +26 -0
- package/dist/components/canvas/wrapper.d.ts.map +1 -0
- package/dist/components/canvas/wrapper.js +107 -0
- package/dist/components/canvas/wrapper.js.map +1 -0
- package/dist/components/ui/FolderIcon.d.ts +9 -0
- package/dist/components/ui/FolderIcon.d.ts.map +1 -0
- package/dist/components/ui/FolderIcon.js +25 -0
- package/dist/components/ui/FolderIcon.js.map +1 -0
- package/dist/components/ui/button.d.ts +14 -0
- package/dist/components/ui/button.d.ts.map +1 -0
- package/dist/components/ui/button.js +54 -0
- package/dist/components/ui/button.js.map +1 -0
- package/dist/components/ui/label.d.ts +6 -0
- package/dist/components/ui/label.d.ts.map +1 -0
- package/dist/components/ui/label.js +10 -0
- package/dist/components/ui/label.js.map +1 -0
- package/dist/components/ui/toast.d.ts +16 -0
- package/dist/components/ui/toast.d.ts.map +1 -0
- package/dist/components/ui/toast.js +41 -0
- package/dist/components/ui/toast.js.map +1 -0
- package/dist/components/ui/toaster.d.ts +2 -0
- package/dist/components/ui/toaster.d.ts.map +1 -0
- package/dist/components/ui/toaster.js +10 -0
- package/dist/components/ui/toaster.js.map +1 -0
- package/dist/contexts/CanvasContext.d.ts +26 -0
- package/dist/contexts/CanvasContext.d.ts.map +1 -0
- package/dist/contexts/CanvasContext.js +22 -0
- package/dist/contexts/CanvasContext.js.map +1 -0
- package/dist/contexts/PerformanceContext.d.ts +31 -0
- package/dist/contexts/PerformanceContext.d.ts.map +1 -0
- package/dist/contexts/PerformanceContext.js +56 -0
- package/dist/contexts/PerformanceContext.js.map +1 -0
- package/dist/hooks/use-mobile.d.ts +2 -0
- package/dist/hooks/use-mobile.d.ts.map +1 -0
- package/dist/hooks/use-mobile.js +16 -0
- package/dist/hooks/use-mobile.js.map +1 -0
- package/dist/hooks/use-toast.d.ts +45 -0
- package/dist/hooks/use-toast.d.ts.map +1 -0
- package/dist/hooks/use-toast.js +126 -0
- package/dist/hooks/use-toast.js.map +1 -0
- package/dist/hooks/usePerformanceMode.d.ts +6 -0
- package/dist/hooks/usePerformanceMode.d.ts.map +1 -0
- package/dist/hooks/usePerformanceMode.js +6 -0
- package/dist/hooks/usePerformanceMode.js.map +1 -0
- package/dist/hooks/useWindowDimensions.d.ts +7 -0
- package/dist/hooks/useWindowDimensions.d.ts.map +1 -0
- package/dist/hooks/useWindowDimensions.js +22 -0
- package/dist/hooks/useWindowDimensions.js.map +1 -0
- package/dist/index.d.ts +26 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +28 -0
- package/dist/index.js.map +1 -0
- package/dist/lib/canvas.d.ts +35 -0
- package/dist/lib/canvas.d.ts.map +1 -0
- package/dist/lib/canvas.js +82 -0
- package/dist/lib/canvas.js.map +1 -0
- package/dist/lib/constants.d.ts +78 -0
- package/dist/lib/constants.d.ts.map +1 -0
- package/dist/lib/constants.js +122 -0
- package/dist/lib/constants.js.map +1 -0
- package/dist/lib/copy.d.ts +2 -0
- package/dist/lib/copy.d.ts.map +1 -0
- package/dist/lib/copy.js +20 -0
- package/dist/lib/copy.js.map +1 -0
- package/dist/lib/utils.d.ts +4 -0
- package/dist/lib/utils.d.ts.map +1 -0
- package/dist/lib/utils.js +14 -0
- package/dist/lib/utils.js.map +1 -0
- package/dist/types/index.d.ts +19 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +14 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/performance.d.ts +9 -0
- package/dist/utils/performance.d.ts.map +1 -0
- package/dist/utils/performance.js +29 -0
- package/dist/utils/performance.js.map +1 -0
- package/package.json +55 -0
- package/src/components/canvas/canvas.tsx +728 -0
- package/src/components/canvas/component.tsx +230 -0
- package/src/components/canvas/cursor.tsx +161 -0
- package/src/components/canvas/draggable.tsx +298 -0
- package/src/components/canvas/navbar/index.tsx +213 -0
- package/src/components/canvas/navbar/single-button.tsx +199 -0
- package/src/components/canvas/offest.tsx +23 -0
- package/src/components/canvas/reset.tsx +21 -0
- package/src/components/canvas/toolbar.tsx +67 -0
- package/src/components/canvas/wrapper.tsx +219 -0
- package/src/components/ui/FolderIcon.tsx +116 -0
- package/src/components/ui/button.tsx +162 -0
- package/src/components/ui/label.tsx +24 -0
- package/src/components/ui/toast.tsx +136 -0
- package/src/components/ui/toaster.tsx +33 -0
- package/src/contexts/CanvasContext.tsx +54 -0
- package/src/contexts/PerformanceContext.tsx +81 -0
- package/src/hooks/use-mobile.ts +21 -0
- package/src/hooks/use-toast.ts +186 -0
- package/src/hooks/usePerformanceMode.ts +5 -0
- package/src/hooks/useWindowDimensions.ts +32 -0
- package/src/index.ts +36 -0
- package/src/lib/canvas.ts +132 -0
- package/src/lib/constants.ts +153 -0
- package/src/lib/copy.ts +18 -0
- package/src/lib/utils.ts +18 -0
- package/src/types/index.ts +20 -0
- package/src/utils/performance.ts +37 -0
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { type Transition } from "framer-motion";
|
|
2
|
+
import React, { type FC } from "react";
|
|
3
|
+
import { CanvasSection, type SectionCoordinates } from "../../types";
|
|
4
|
+
import type { ReactNode } from "react";
|
|
5
|
+
interface Props {
|
|
6
|
+
homeCoordinates: SectionCoordinates;
|
|
7
|
+
children: React.ReactNode;
|
|
8
|
+
navbarCoordinates?: Record<CanvasSection, SectionCoordinates>;
|
|
9
|
+
navbarSections?: CanvasSection[];
|
|
10
|
+
navbarHomeSection?: CanvasSection;
|
|
11
|
+
/** Disable intro animation entirely */
|
|
12
|
+
skipIntro?: boolean;
|
|
13
|
+
/** Custom intro content during loading */
|
|
14
|
+
introContent?: ReactNode;
|
|
15
|
+
/** Custom loading text */
|
|
16
|
+
loadingText?: string;
|
|
17
|
+
/** Background gradient for intro */
|
|
18
|
+
introBackgroundGradient?: string;
|
|
19
|
+
/** Canvas box gradient */
|
|
20
|
+
canvasBoxGradient?: string;
|
|
21
|
+
/** Custom grow transition */
|
|
22
|
+
growTransition?: Transition;
|
|
23
|
+
/** Custom blur transition */
|
|
24
|
+
blurTransition?: Transition;
|
|
25
|
+
}
|
|
26
|
+
declare const Canvas: FC<Props>;
|
|
27
|
+
export declare const gradientBgImage = "radial-gradient(ellipse 6000px 4000px at 3000px 4000px, var(--coral) 0%, var(--salmon) 41%, var(--lilac) 59%, var(--beige) 90%)";
|
|
28
|
+
export default Canvas;
|
|
29
|
+
//# sourceMappingURL=canvas.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"canvas.d.ts","sourceRoot":"","sources":["../../../src/components/canvas/canvas.tsx"],"names":[],"mappings":"AAAA,OAAO,EAOL,KAAK,UAAU,EAChB,MAAM,eAAe,CAAC;AACvB,OAAO,KAAK,EAAE,EAIZ,KAAK,EAAE,EAIR,MAAM,OAAO,CAAC;AAyBf,OAAO,EAAE,aAAa,EAAE,KAAK,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAGrE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEvC,UAAU,KAAK;IACb,eAAe,EAAE,kBAAkB,CAAC;IACpC,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAG1B,iBAAiB,CAAC,EAAE,MAAM,CAAC,aAAa,EAAE,kBAAkB,CAAC,CAAC;IAC9D,cAAc,CAAC,EAAE,aAAa,EAAE,CAAC;IACjC,iBAAiB,CAAC,EAAE,aAAa,CAAC;IAGlC,uCAAuC;IACvC,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,0CAA0C;IAC1C,YAAY,CAAC,EAAE,SAAS,CAAC;IACzB,0BAA0B;IAC1B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,oCAAoC;IACpC,uBAAuB,CAAC,EAAE,MAAM,CAAC;IACjC,0BAA0B;IAC1B,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,6BAA6B;IAC7B,cAAc,CAAC,EAAE,UAAU,CAAC;IAC5B,6BAA6B;IAC7B,cAAc,CAAC,EAAE,UAAU,CAAC;CAC7B;AAYD,QAAA,MAAM,MAAM,EAAE,EAAE,CAAC,KAAK,CAymBrB,CAAC;AAEF,eAAO,MAAM,eAAe,oIAAkL,CAAC;AAyB/M,eAAe,MAAM,CAAC"}
|
|
@@ -0,0 +1,419 @@
|
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { motion, useMotionValue, animate, useTransform, } from "framer-motion";
|
|
3
|
+
import React, { useState, useRef, useEffect, useCallback, useMemo, } from "react";
|
|
4
|
+
import { CanvasProvider } from "../../contexts/CanvasContext";
|
|
5
|
+
import { useToast } from "../../hooks/use-toast";
|
|
6
|
+
import { calcInitialBoxWidth, canvasHeight, canvasWidth, getDistance, getMidpoint, getScreenSizeEnum, getSectionPanCoordinates, INTERACTIVE_SELECTOR, MAX_ZOOM, MIN_ZOOMS, panToOffsetScene, ZOOM_BOUND, } from "../../lib/canvas";
|
|
7
|
+
import { STAGE2_TRANSITION, MOUSE_WHEEL_ZOOM_SENSITIVITY, TRACKPAD_ZOOM_SENSITIVITY, } from "../../lib/constants";
|
|
8
|
+
import useWindowDimensions from "../../hooks/useWindowDimensions";
|
|
9
|
+
import Navbar from "./navbar";
|
|
10
|
+
import Toolbar from "./toolbar";
|
|
11
|
+
import { CanvasSection } from "../../types";
|
|
12
|
+
import { CanvasWrapper } from "./wrapper";
|
|
13
|
+
import { usePerformanceMode } from "../../hooks/usePerformanceMode";
|
|
14
|
+
const stopAllMotion = (x, y, scale) => {
|
|
15
|
+
x.stop();
|
|
16
|
+
y.stop();
|
|
17
|
+
scale.stop();
|
|
18
|
+
};
|
|
19
|
+
const Canvas = ({ children, homeCoordinates, navbarCoordinates, navbarSections, navbarHomeSection, skipIntro = false, introContent, loadingText, introBackgroundGradient, canvasBoxGradient, growTransition, blurTransition, }) => {
|
|
20
|
+
const { height: windowHeight, width: windowWidth } = useWindowDimensions();
|
|
21
|
+
const { toast } = useToast();
|
|
22
|
+
const hasToasted = useRef(false);
|
|
23
|
+
useEffect(() => {
|
|
24
|
+
if (windowWidth < 768 && !hasToasted.current) {
|
|
25
|
+
setTimeout(() => {
|
|
26
|
+
toast({
|
|
27
|
+
title: "Please use desktop for the best experience.",
|
|
28
|
+
duration: 6700,
|
|
29
|
+
variant: "cute",
|
|
30
|
+
});
|
|
31
|
+
hasToasted.current = true;
|
|
32
|
+
}, 1200);
|
|
33
|
+
}
|
|
34
|
+
}, [windowWidth, toast]);
|
|
35
|
+
const { mode } = usePerformanceMode();
|
|
36
|
+
const navSections = navbarSections ?? Object.values(CanvasSection);
|
|
37
|
+
const navHomeSection = navbarHomeSection ?? CanvasSection.Home;
|
|
38
|
+
const hasNavbarData = Boolean(navbarCoordinates);
|
|
39
|
+
const sceneWidth = canvasWidth;
|
|
40
|
+
const sceneHeight = canvasHeight;
|
|
41
|
+
const MIN_ZOOM = MIN_ZOOMS[getScreenSizeEnum(windowWidth)];
|
|
42
|
+
// tracks if user is panning the screen
|
|
43
|
+
const [isPanning, setIsPanning] = useState(false);
|
|
44
|
+
// this one is moving from scene control, not from user
|
|
45
|
+
const [isSceneMoving, setIsSceneMoving] = useState(false);
|
|
46
|
+
const [panStartPoint, setPanStartPoint] = useState({ x: 0, y: 0 });
|
|
47
|
+
const [initialPanOffsetOnDrag, setInitialPanOffsetOnDrag] = useState({
|
|
48
|
+
x: 0,
|
|
49
|
+
y: 0,
|
|
50
|
+
});
|
|
51
|
+
const [isResetting, setIsResetting] = useState(false);
|
|
52
|
+
const [maxZIndex, setMaxZIndex] = useState(50);
|
|
53
|
+
const [animationStage, setAnimationStage] = useState(0); // 0: initial, 1: finish grow, 2: pan to home
|
|
54
|
+
const [nextTargetSection, setNextTargetSection] = useState(null);
|
|
55
|
+
// Track if the intro (stage1 + stage2) is still running, to avoid accidental cancellation
|
|
56
|
+
const isIntroAnimatingRef = useRef(true);
|
|
57
|
+
const initialBoxWidth = useMemo(() => calcInitialBoxWidth(windowWidth, windowHeight), [windowWidth, windowHeight]);
|
|
58
|
+
// somewhere near the middle-ish
|
|
59
|
+
const x = useMotionValue(0);
|
|
60
|
+
const y = useMotionValue(0);
|
|
61
|
+
const scale = useMotionValue(initialBoxWidth);
|
|
62
|
+
const offsetHomeCoordinates = useMemo(() => getSectionPanCoordinates({
|
|
63
|
+
windowDimensions: { width: windowWidth, height: windowHeight },
|
|
64
|
+
coords: homeCoordinates,
|
|
65
|
+
targetZoom: 1,
|
|
66
|
+
}), [homeCoordinates, windowWidth, windowHeight]);
|
|
67
|
+
const onResetViewAndItems = useCallback((onComplete) => {
|
|
68
|
+
setIsResetting(true);
|
|
69
|
+
void panToOffsetScene(offsetHomeCoordinates, x, y, scale, 1).then(() => {
|
|
70
|
+
setIsResetting(false);
|
|
71
|
+
if (onComplete)
|
|
72
|
+
onComplete();
|
|
73
|
+
});
|
|
74
|
+
}, [offsetHomeCoordinates, x, y, scale]);
|
|
75
|
+
// Shared intro progress (0->1) driven by CanvasWrapper
|
|
76
|
+
const introProgress = useMotionValue(0);
|
|
77
|
+
// Precompute final stage1 scale and offsets (snapshot dimensions once on mount)
|
|
78
|
+
const stage1Targets = useMemo(() => {
|
|
79
|
+
const finalScale = Math.max((windowWidth || 0) / canvasWidth, (windowHeight || 0) / canvasHeight);
|
|
80
|
+
const endX = (windowWidth - canvasWidth * finalScale) / 2;
|
|
81
|
+
const endY = (windowHeight - canvasHeight * finalScale) / 2;
|
|
82
|
+
return { finalScale, endX, endY };
|
|
83
|
+
}, [windowWidth, windowHeight]);
|
|
84
|
+
// Replace direct motion values with derived transforms during stage1
|
|
85
|
+
const derivedScale = useTransform(introProgress, [0, 1], [initialBoxWidth, stage1Targets.finalScale]);
|
|
86
|
+
const derivedX = useTransform(introProgress, [0, 1], [0, stage1Targets.endX]);
|
|
87
|
+
const derivedY = useTransform(introProgress, [0, 1], [0, stage1Targets.endY]);
|
|
88
|
+
// While intro (stage1) is running, bind x/y/scale to derived versions.
|
|
89
|
+
useEffect(() => {
|
|
90
|
+
const unsubscribeScale = derivedScale.on("change", (v) => {
|
|
91
|
+
if (animationStage === 0)
|
|
92
|
+
scale.set(v);
|
|
93
|
+
});
|
|
94
|
+
const unsubscribeX = derivedX.on("change", (v) => {
|
|
95
|
+
if (animationStage === 0)
|
|
96
|
+
x.set(v);
|
|
97
|
+
});
|
|
98
|
+
const unsubscribeY = derivedY.on("change", (v) => {
|
|
99
|
+
if (animationStage === 0)
|
|
100
|
+
y.set(v);
|
|
101
|
+
});
|
|
102
|
+
return () => {
|
|
103
|
+
unsubscribeScale();
|
|
104
|
+
unsubscribeX();
|
|
105
|
+
unsubscribeY();
|
|
106
|
+
};
|
|
107
|
+
}, [derivedScale, derivedX, derivedY, animationStage, scale, x, y]);
|
|
108
|
+
// Kick off stage2 (pan to home) when grow completes (introProgress hits 1)
|
|
109
|
+
const startStage2 = useCallback(() => {
|
|
110
|
+
setAnimationStage(1);
|
|
111
|
+
Promise.all([
|
|
112
|
+
animate(x, offsetHomeCoordinates.x, STAGE2_TRANSITION),
|
|
113
|
+
animate(y, offsetHomeCoordinates.y, STAGE2_TRANSITION),
|
|
114
|
+
animate(scale, 1, STAGE2_TRANSITION),
|
|
115
|
+
])
|
|
116
|
+
.then(() => {
|
|
117
|
+
setAnimationStage(2);
|
|
118
|
+
isIntroAnimatingRef.current = false;
|
|
119
|
+
})
|
|
120
|
+
.catch(() => {
|
|
121
|
+
isIntroAnimatingRef.current = false;
|
|
122
|
+
});
|
|
123
|
+
}, [offsetHomeCoordinates, x, y, scale]);
|
|
124
|
+
const viewportRef = useRef(null);
|
|
125
|
+
const sceneRef = useRef(null);
|
|
126
|
+
// Stable wheel listener wrapper that always calls the latest handler via ref
|
|
127
|
+
const wheelHandlerRef = useRef(null);
|
|
128
|
+
const wheelWrapper = useCallback((e) => {
|
|
129
|
+
wheelHandlerRef.current?.(e);
|
|
130
|
+
}, []);
|
|
131
|
+
// Ensure wheel listener attaches when the element actually mounts (wrapper delays child mount)
|
|
132
|
+
const setViewportRef = useCallback((node) => {
|
|
133
|
+
// Clean up old listener if ref changes/unmounts
|
|
134
|
+
if (viewportRef.current) {
|
|
135
|
+
viewportRef.current.removeEventListener("wheel", wheelWrapper);
|
|
136
|
+
}
|
|
137
|
+
viewportRef.current = node;
|
|
138
|
+
if (node) {
|
|
139
|
+
node.addEventListener("wheel", wheelWrapper, { passive: false });
|
|
140
|
+
}
|
|
141
|
+
}, [wheelWrapper]);
|
|
142
|
+
const activePointersRef = useRef(new Map());
|
|
143
|
+
const initialPinchStateRef = useRef(null);
|
|
144
|
+
const panToOffset = useCallback((offset, viewportRef, onComplete, zoom) => {
|
|
145
|
+
if (!viewportRef.current)
|
|
146
|
+
return;
|
|
147
|
+
setIsSceneMoving(true);
|
|
148
|
+
// Calculate bounds based on scene and viewport dimensions
|
|
149
|
+
const viewportWidth = viewportRef.current.offsetWidth;
|
|
150
|
+
const viewportHeight = viewportRef.current.offsetHeight;
|
|
151
|
+
const minPanX = viewportWidth - sceneWidth * (zoom ?? 1);
|
|
152
|
+
const maxPanX = 0;
|
|
153
|
+
const minPanY = viewportHeight - sceneHeight * (zoom ?? 1);
|
|
154
|
+
const maxPanY = 0;
|
|
155
|
+
// Clamp the offset to keep the scene within bounds, shouldn't be needed but still implemented
|
|
156
|
+
const clampedX = Math.min(Math.max(offset.x, minPanX), maxPanX);
|
|
157
|
+
const clampedY = Math.min(Math.max(offset.y, minPanY), maxPanY);
|
|
158
|
+
void panToOffsetScene({ x: clampedX, y: clampedY }, x, y, scale, zoom).then(() => {
|
|
159
|
+
setIsSceneMoving(false);
|
|
160
|
+
if (onComplete)
|
|
161
|
+
onComplete();
|
|
162
|
+
});
|
|
163
|
+
}, [sceneWidth, sceneHeight, x, y, scale]);
|
|
164
|
+
// Guarded stop that ignores attempts during intro animations
|
|
165
|
+
const stopAllSceneMotion = useCallback(() => {
|
|
166
|
+
if (isIntroAnimatingRef.current)
|
|
167
|
+
return; // ignore stops while intro runs
|
|
168
|
+
stopAllMotion(x, y, scale);
|
|
169
|
+
}, [x, y, scale]);
|
|
170
|
+
const handlePointerDown = useCallback((event) => {
|
|
171
|
+
if (animationStage < 2)
|
|
172
|
+
return; // ignore during intro animations
|
|
173
|
+
activePointersRef.current.set(event.pointerId, event);
|
|
174
|
+
event.target.setPointerCapture(event.pointerId);
|
|
175
|
+
if (isResetting || isSceneMoving)
|
|
176
|
+
return;
|
|
177
|
+
stopAllSceneMotion();
|
|
178
|
+
// pan with 1 pointer, pinch with 2 pointers
|
|
179
|
+
if (activePointersRef.current.size === 1) {
|
|
180
|
+
// do not pan from interactive elements
|
|
181
|
+
const targetElement = event.target;
|
|
182
|
+
if (targetElement.closest(INTERACTIVE_SELECTOR)) {
|
|
183
|
+
activePointersRef.current.delete(event.pointerId);
|
|
184
|
+
event.target.releasePointerCapture(event.pointerId);
|
|
185
|
+
return;
|
|
186
|
+
}
|
|
187
|
+
setIsPanning(true);
|
|
188
|
+
setPanStartPoint({ x: event.clientX, y: event.clientY });
|
|
189
|
+
setInitialPanOffsetOnDrag({ x: x.get(), y: y.get() });
|
|
190
|
+
if (viewportRef.current)
|
|
191
|
+
viewportRef.current.style.cursor = "grabbing";
|
|
192
|
+
}
|
|
193
|
+
else if (activePointersRef.current.size === 2) {
|
|
194
|
+
setIsPanning(false);
|
|
195
|
+
const pointers = Array.from(activePointersRef.current.values());
|
|
196
|
+
initialPinchStateRef.current = {
|
|
197
|
+
distance: getDistance(pointers[0], pointers[1]),
|
|
198
|
+
midpoint: getMidpoint(pointers[0], pointers[1]),
|
|
199
|
+
zoom: scale.get(),
|
|
200
|
+
panOffset: { x: x.get(), y: y.get() },
|
|
201
|
+
};
|
|
202
|
+
}
|
|
203
|
+
}, [
|
|
204
|
+
isResetting,
|
|
205
|
+
isSceneMoving,
|
|
206
|
+
setIsPanning,
|
|
207
|
+
setPanStartPoint,
|
|
208
|
+
setInitialPanOffsetOnDrag,
|
|
209
|
+
x,
|
|
210
|
+
y,
|
|
211
|
+
scale,
|
|
212
|
+
viewportRef,
|
|
213
|
+
animationStage,
|
|
214
|
+
stopAllSceneMotion,
|
|
215
|
+
]);
|
|
216
|
+
const handlePointerMove = useCallback((event) => {
|
|
217
|
+
if (animationStage < 2)
|
|
218
|
+
return;
|
|
219
|
+
if (isPanning || activePointersRef.current.size >= 2) {
|
|
220
|
+
stopAllSceneMotion();
|
|
221
|
+
}
|
|
222
|
+
if (!activePointersRef.current.has(event.pointerId) || isResetting)
|
|
223
|
+
return;
|
|
224
|
+
activePointersRef.current.set(event.pointerId, event);
|
|
225
|
+
if (isPanning && activePointersRef.current.size === 1) {
|
|
226
|
+
event.preventDefault();
|
|
227
|
+
const deltaX = event.clientX - panStartPoint.x;
|
|
228
|
+
const deltaY = event.clientY - panStartPoint.y;
|
|
229
|
+
// UPDATE to use motion value
|
|
230
|
+
const minPanX = windowWidth - sceneWidth * scale.get();
|
|
231
|
+
const maxPanX = 0;
|
|
232
|
+
const minPanY = windowHeight - sceneHeight * scale.get();
|
|
233
|
+
const maxPanY = 0;
|
|
234
|
+
const newX = Math.min(Math.max(initialPanOffsetOnDrag.x + deltaX, minPanX), maxPanX);
|
|
235
|
+
const newY = Math.min(Math.max(initialPanOffsetOnDrag.y + deltaY, minPanY), maxPanY);
|
|
236
|
+
x.set(newX);
|
|
237
|
+
y.set(newY);
|
|
238
|
+
}
|
|
239
|
+
else if (activePointersRef.current.size >= 2 &&
|
|
240
|
+
initialPinchStateRef.current) {
|
|
241
|
+
event.preventDefault();
|
|
242
|
+
const pointers = Array.from(activePointersRef.current.values());
|
|
243
|
+
const p1 = pointers[0];
|
|
244
|
+
const p2 = pointers[1];
|
|
245
|
+
const currentDistance = getDistance(p1, p2);
|
|
246
|
+
const currentMidpoint = getMidpoint(p1, p2);
|
|
247
|
+
const { distance: initialDistance, zoom: initialZoom, panOffset: initialPanOffsetPinch, } = initialPinchStateRef.current;
|
|
248
|
+
if (initialDistance === 0)
|
|
249
|
+
return;
|
|
250
|
+
let newZoom = initialZoom * (currentDistance / initialDistance);
|
|
251
|
+
newZoom = Math.max((window.innerWidth / canvasWidth) * ZOOM_BOUND, // Ensure zoom is at least the width of the canvas
|
|
252
|
+
(window.innerHeight / canvasHeight) * ZOOM_BOUND, // Ensure zoom is at least the height of the canvas
|
|
253
|
+
Math.min(newZoom, 10), MIN_ZOOM);
|
|
254
|
+
const mx = currentMidpoint.x;
|
|
255
|
+
const my = currentMidpoint.y;
|
|
256
|
+
const minPanX = windowWidth - sceneWidth * newZoom;
|
|
257
|
+
const maxPanX = 0;
|
|
258
|
+
const minPanY = windowHeight - sceneHeight * newZoom;
|
|
259
|
+
const maxPanY = 0;
|
|
260
|
+
let newPanX = mx - ((mx - initialPanOffsetPinch.x) / initialZoom) * newZoom;
|
|
261
|
+
let newPanY = my - ((my - initialPanOffsetPinch.y) / initialZoom) * newZoom;
|
|
262
|
+
// Clamp pan to prevent leaving bounds
|
|
263
|
+
newPanX = Math.min(Math.max(newPanX, minPanX), maxPanX);
|
|
264
|
+
newPanY = Math.min(Math.max(newPanY, minPanY), maxPanY);
|
|
265
|
+
scale.set(newZoom);
|
|
266
|
+
x.set(newPanX);
|
|
267
|
+
y.set(newPanY);
|
|
268
|
+
}
|
|
269
|
+
}, [
|
|
270
|
+
isPanning,
|
|
271
|
+
isResetting,
|
|
272
|
+
x,
|
|
273
|
+
y,
|
|
274
|
+
scale,
|
|
275
|
+
panStartPoint.x,
|
|
276
|
+
panStartPoint.y,
|
|
277
|
+
windowWidth,
|
|
278
|
+
sceneWidth,
|
|
279
|
+
windowHeight,
|
|
280
|
+
sceneHeight,
|
|
281
|
+
initialPanOffsetOnDrag.x,
|
|
282
|
+
initialPanOffsetOnDrag.y,
|
|
283
|
+
MIN_ZOOM,
|
|
284
|
+
animationStage,
|
|
285
|
+
stopAllSceneMotion,
|
|
286
|
+
]);
|
|
287
|
+
const handlePointerUpOrCancel = useCallback((event) => {
|
|
288
|
+
if (animationStage < 2) {
|
|
289
|
+
event.preventDefault();
|
|
290
|
+
return; // ignore pointer up during intro
|
|
291
|
+
}
|
|
292
|
+
stopAllSceneMotion();
|
|
293
|
+
event.preventDefault();
|
|
294
|
+
if (event.target.hasPointerCapture(event.pointerId)) {
|
|
295
|
+
event.target.releasePointerCapture(event.pointerId);
|
|
296
|
+
}
|
|
297
|
+
activePointersRef.current.delete(event.pointerId);
|
|
298
|
+
if (isPanning && activePointersRef.current.size < 1) {
|
|
299
|
+
setIsPanning(false);
|
|
300
|
+
if (viewportRef.current)
|
|
301
|
+
viewportRef.current.style.cursor = "url('/customcursor.svg'), grab";
|
|
302
|
+
}
|
|
303
|
+
if (initialPinchStateRef.current && activePointersRef.current.size < 2) {
|
|
304
|
+
initialPinchStateRef.current = null;
|
|
305
|
+
}
|
|
306
|
+
if (!isPanning &&
|
|
307
|
+
activePointersRef.current.size === 1 &&
|
|
308
|
+
!initialPinchStateRef.current) {
|
|
309
|
+
const lastPointer = Array.from(activePointersRef.current.values())[0];
|
|
310
|
+
setIsPanning(true);
|
|
311
|
+
setPanStartPoint({ x: lastPointer.clientX, y: lastPointer.clientY });
|
|
312
|
+
setInitialPanOffsetOnDrag({ x: x.get(), y: y.get() });
|
|
313
|
+
}
|
|
314
|
+
}, [x, y, isPanning, animationStage, stopAllSceneMotion]);
|
|
315
|
+
const handleWheelZoom = useCallback((event) => {
|
|
316
|
+
if (animationStage < 2) {
|
|
317
|
+
event.preventDefault();
|
|
318
|
+
return; // block wheel interaction during intro animations
|
|
319
|
+
}
|
|
320
|
+
event.preventDefault();
|
|
321
|
+
// pinch gesture on track
|
|
322
|
+
const isPinch = event.ctrlKey || event.metaKey;
|
|
323
|
+
const isMouseWheelZoom = event.deltaMode === WheelEvent.DOM_DELTA_LINE ||
|
|
324
|
+
Math.abs(event.deltaY) >= 100;
|
|
325
|
+
// mouse wheel zoom and track pad zoom have different sensitivities
|
|
326
|
+
const ZOOM_SENSITIVITY = isMouseWheelZoom
|
|
327
|
+
? MOUSE_WHEEL_ZOOM_SENSITIVITY
|
|
328
|
+
: TRACKPAD_ZOOM_SENSITIVITY;
|
|
329
|
+
if (isPinch) {
|
|
330
|
+
const currentZoom = scale.get();
|
|
331
|
+
const nextZoom = Math.max(Math.min(currentZoom * (1 - event.deltaY * ZOOM_SENSITIVITY), MAX_ZOOM), MIN_ZOOM, (window.innerWidth / canvasWidth) * ZOOM_BOUND, // Ensure zoom is at least the width of the canvas
|
|
332
|
+
(window.innerHeight / canvasHeight) * ZOOM_BOUND);
|
|
333
|
+
const rect = viewportRef.current?.getBoundingClientRect();
|
|
334
|
+
if (!rect)
|
|
335
|
+
return;
|
|
336
|
+
const vpLeft = rect.left;
|
|
337
|
+
const vpTop = rect.top;
|
|
338
|
+
const viewportWidth = rect.width;
|
|
339
|
+
const viewportHeight = rect.height;
|
|
340
|
+
const cursorSceneX = (event.clientX - vpLeft - x.get()) / currentZoom;
|
|
341
|
+
const cursorSceneY = (event.clientY - vpTop - y.get()) / currentZoom;
|
|
342
|
+
let newPanX = event.clientX - vpLeft - cursorSceneX * nextZoom;
|
|
343
|
+
let newPanY = event.clientY - vpTop - cursorSceneY * nextZoom;
|
|
344
|
+
const minPanX = viewportWidth - sceneWidth * nextZoom;
|
|
345
|
+
const minPanY = viewportHeight - sceneHeight * nextZoom;
|
|
346
|
+
const maxPanX = 0;
|
|
347
|
+
const maxPanY = 0;
|
|
348
|
+
newPanX = Math.min(maxPanX, Math.max(minPanX, newPanX));
|
|
349
|
+
newPanY = Math.min(maxPanY, Math.max(minPanY, newPanY));
|
|
350
|
+
x.set(newPanX);
|
|
351
|
+
y.set(newPanY);
|
|
352
|
+
scale.set(nextZoom);
|
|
353
|
+
}
|
|
354
|
+
else {
|
|
355
|
+
stopAllSceneMotion();
|
|
356
|
+
const scrollSpeed = 1;
|
|
357
|
+
const newPanX = x.get() - event.deltaX * scrollSpeed;
|
|
358
|
+
const newPanY = y.get() - event.deltaY * scrollSpeed;
|
|
359
|
+
const minPanX = windowWidth - sceneWidth * scale.get();
|
|
360
|
+
const maxPanX = 0;
|
|
361
|
+
const minPanY = windowHeight - sceneHeight * scale.get();
|
|
362
|
+
const maxPanY = 0;
|
|
363
|
+
const clampedPanX = Math.min(Math.max(newPanX, minPanX), maxPanX);
|
|
364
|
+
const clampedPanY = Math.min(Math.max(newPanY, minPanY), maxPanY);
|
|
365
|
+
x.set(clampedPanX);
|
|
366
|
+
y.set(clampedPanY);
|
|
367
|
+
}
|
|
368
|
+
}, [
|
|
369
|
+
scale,
|
|
370
|
+
MIN_ZOOM,
|
|
371
|
+
x,
|
|
372
|
+
y,
|
|
373
|
+
sceneWidth,
|
|
374
|
+
sceneHeight,
|
|
375
|
+
windowWidth,
|
|
376
|
+
windowHeight,
|
|
377
|
+
animationStage,
|
|
378
|
+
stopAllSceneMotion,
|
|
379
|
+
]);
|
|
380
|
+
// Keep the wheel handler ref pointing to the latest implementation
|
|
381
|
+
useEffect(() => {
|
|
382
|
+
wheelHandlerRef.current = handleWheelZoom;
|
|
383
|
+
}, [handleWheelZoom]);
|
|
384
|
+
const handlePanToOffset = useCallback((offset, onComplete, zoom) => {
|
|
385
|
+
panToOffset({
|
|
386
|
+
x: -offset.x,
|
|
387
|
+
y: -offset.y,
|
|
388
|
+
}, viewportRef, onComplete, zoom);
|
|
389
|
+
}, [panToOffset, viewportRef]);
|
|
390
|
+
return (_jsx(CanvasWrapper, { introProgress: introProgress, onIntroGrowComplete: startStage2, skipIntro: skipIntro, introContent: introContent, loadingText: loadingText, introBackgroundGradient: introBackgroundGradient, canvasBoxGradient: canvasBoxGradient, growTransition: growTransition, blurTransition: blurTransition, children: _jsxs(CanvasProvider, { x: x, y: y, scale: scale, isResetting: isResetting, maxZIndex: maxZIndex, setMaxZIndex: setMaxZIndex, animationStage: animationStage, nextTargetSection: nextTargetSection, setNextTargetSection: setNextTargetSection, children: [animationStage >= 2 && (_jsxs(_Fragment, { children: [_jsx(Toolbar, { homeCoordinates: offsetHomeCoordinates }), hasNavbarData && navbarCoordinates ? (_jsx(Navbar, { panToOffset: handlePanToOffset, onReset: onResetViewAndItems, coordinates: navbarCoordinates, sections: navSections, homeSection: navHomeSection })) : null] })), _jsx("div", { ref: setViewportRef, className: "relative h-full w-full touch-none select-none overflow-hidden", style: {
|
|
391
|
+
touchAction: "none",
|
|
392
|
+
pointerEvents: animationStage >= 2 ? "auto" : "none",
|
|
393
|
+
overscrollBehavior: "contain",
|
|
394
|
+
}, onPointerDown: handlePointerDown, onPointerMove: handlePointerMove, onPointerUp: handlePointerUpOrCancel, onPointerLeave: handlePointerUpOrCancel, onPointerCancel: handlePointerUpOrCancel, children: _jsxs(motion.div, { ref: sceneRef, className: "absolute z-20 origin-top-left", initial: { opacity: 0 }, animate: { opacity: 1 }, transition: { duration: 0.3, ease: "easeIn" }, style: {
|
|
395
|
+
width: `${canvasWidth}px`,
|
|
396
|
+
height: `${canvasHeight}px`,
|
|
397
|
+
x,
|
|
398
|
+
y,
|
|
399
|
+
scale,
|
|
400
|
+
willChange: mode !== "high" && (animationStage < 2 || isPanning)
|
|
401
|
+
? "transform"
|
|
402
|
+
: "auto",
|
|
403
|
+
}, children: [_jsx(Gradient, {}), animationStage >= 1 &&
|
|
404
|
+
(mode === "high" ? (_jsxs(motion.div, { initial: { opacity: 0 }, animate: { opacity: 1 }, transition: { duration: 0.5, ease: "easeIn" }, children: [_jsx(Filter, {}), _jsx(Dots, {})] })) : (_jsxs(_Fragment, { children: [_jsx(Filter, {}), _jsx(Dots, {})] }))), children] }) })] }) }));
|
|
405
|
+
};
|
|
406
|
+
export const gradientBgImage = `radial-gradient(ellipse ${canvasWidth}px ${canvasHeight}px at ${canvasWidth / 2}px ${canvasHeight}px, var(--coral) 0%, var(--salmon) 41%, var(--lilac) 59%, var(--beige) 90%)`;
|
|
407
|
+
const Gradient = React.memo(function Gradient() {
|
|
408
|
+
return (_jsx("div", { className: "pointer-events-none absolute inset-0 h-full w-full opacity-100", style: {
|
|
409
|
+
backgroundImage: gradientBgImage,
|
|
410
|
+
} }));
|
|
411
|
+
});
|
|
412
|
+
const Dots = React.memo(function Dots() {
|
|
413
|
+
return (_jsx("div", { className: "pointer-events-none absolute inset-0 h-full w-full bg-[radial-gradient(#776780_1.5px,transparent_1px)] opacity-35 [background-size:22px_22px] " }));
|
|
414
|
+
});
|
|
415
|
+
const Filter = React.memo(function Filter() {
|
|
416
|
+
return (_jsx("div", { className: "contrast-60 md:bg-noise pointer-events-none absolute inset-0 hidden h-full w-full bg-none opacity-60 filter md:inline" }));
|
|
417
|
+
});
|
|
418
|
+
export default Canvas;
|
|
419
|
+
//# sourceMappingURL=canvas.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"canvas.js","sourceRoot":"","sources":["../../../src/components/canvas/canvas.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { type FC } from "react";
|
|
2
|
+
import type { SectionCoordinates } from "../../types";
|
|
3
|
+
interface CanvasProps {
|
|
4
|
+
children: React.ReactNode;
|
|
5
|
+
offset?: SectionCoordinates;
|
|
6
|
+
optimize?: boolean;
|
|
7
|
+
imageFallback?: string;
|
|
8
|
+
coordinatesToSection?: (coords: SectionCoordinates | undefined) => string | null;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Returns true if any portion of the component described by `offset`
|
|
12
|
+
* is currently inside the viewport after applying the canvas pan (x,y) and scale.
|
|
13
|
+
*
|
|
14
|
+
* Coordinate systems:
|
|
15
|
+
* - offset.{x,y} are in "scene" coordinates (unscaled canvas space, origin at canvas top-left).
|
|
16
|
+
* - (sceneX, sceneY) are the current translated position of the scene's top-left
|
|
17
|
+
* in viewport coordinates (these are <= 0; 0 means aligned with the viewport edge).
|
|
18
|
+
* - scale uniformly scales scene coordinates about the scene's origin (top-left) AFTER translation.
|
|
19
|
+
*
|
|
20
|
+
* Mapping a scene-space point (sx, sy) to viewport space:
|
|
21
|
+
* vx = sceneX + sx * scale
|
|
22
|
+
* vy = sceneY + sy * scale
|
|
23
|
+
*
|
|
24
|
+
* The component's axis-aligned bounding box in viewport space is:
|
|
25
|
+
* left = sceneX + offset.x * scale
|
|
26
|
+
* top = sceneY + offset.y * scale
|
|
27
|
+
* right = left + offset.width * scale
|
|
28
|
+
* bottom = top + offset.height * scale
|
|
29
|
+
*
|
|
30
|
+
* It intersects the viewport iff it isn't entirely left, right, above, or below it.
|
|
31
|
+
*
|
|
32
|
+
* Edge handling:
|
|
33
|
+
* - Touching an edge counts as visible (>= / <= comparisons).
|
|
34
|
+
* - If executed during SSR (no window) and no explicit viewport dimensions are provided,
|
|
35
|
+
* it returns true to avoid hydration mismatches.
|
|
36
|
+
*/
|
|
37
|
+
export declare function isComponentInViewport(params: {
|
|
38
|
+
offset: SectionCoordinates;
|
|
39
|
+
sceneX: number;
|
|
40
|
+
sceneY: number;
|
|
41
|
+
scale: number;
|
|
42
|
+
viewportWidth?: number;
|
|
43
|
+
viewportHeight?: number;
|
|
44
|
+
}): boolean;
|
|
45
|
+
export declare const CanvasComponent: FC<CanvasProps>;
|
|
46
|
+
export {};
|
|
47
|
+
//# sourceMappingURL=component.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"component.d.ts","sourceRoot":"","sources":["../../../src/components/canvas/component.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,EAAuB,MAAM,OAAO,CAAC;AACrD,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAUtD,UAAU,WAAW;IACnB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,MAAM,CAAC,EAAE,kBAAkB,CAAC;IAC5B,QAAQ,CAAC,EAAE,OAAO,CAAC;IAGnB,aAAa,CAAC,EAAE,MAAM,CAAC;IAEvB,oBAAoB,CAAC,EAAE,CAAC,MAAM,EAAE,kBAAkB,GAAG,SAAS,KAAK,MAAM,GAAG,IAAI,CAAC;CAClF;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,wBAAgB,qBAAqB,CAAC,MAAM,EAAE;IAC5C,MAAM,EAAE,kBAAkB,CAAC;IAC3B,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB,GAAG,OAAO,CA2BV;AAED,eAAO,MAAM,eAAe,EAAE,EAAE,CAAC,WAAW,CAgJ3C,CAAC"}
|