Files
Dwinzo_Demo/app/src/store/builder/useBuilderStore.ts

300 lines
8.3 KiB
TypeScript
Raw Normal View History

2025-06-10 15:28:23 +05:30
import { Object3D } from 'three';
import { create } from 'zustand';
import { immer } from 'zustand/middleware/immer';
interface BuilderState {
// Point & Line Interaction
2025-06-10 15:28:23 +05:30
hoveredPoint: Point | null;
snappedPoint: Point | null;
snappedPosition: [number, number, number] | null;
hoveredLine: [Point, Point] | null;
// Wall Settings
selectedWall: Object3D | null;
2025-06-10 15:28:23 +05:30
wallThickness: number;
wallHeight: number;
2025-06-23 09:37:53 +05:30
outsideMaterial: string;
insideMaterial: string;
2025-06-10 15:28:23 +05:30
// Floor Settings
selectedFloor: Object3D | null;
floorDepth: number;
isBeveled: boolean;
bevelStrength: number;
sideMaterial: string;
topMaterial: string;
// Decal Settings
selectedDecal: Object3D | null;
// Aisle General
2025-06-10 15:28:23 +05:30
selectedAisle: Object3D | null;
aisleType: AisleTypes;
aisleWidth: number;
aisleColor: AisleColors;
// Aisle Specific Styles
2025-06-10 15:28:23 +05:30
dashLength: number;
gapLength: number;
dotRadius: number;
aisleLength: number;
isFlipped: boolean;
// Setters - Point/Line
2025-06-10 15:28:23 +05:30
setHoveredPoint: (point: Point | null) => void;
setSnappedPoint: (point: Point | null) => void;
setSnappedPosition: (position: [number, number, number] | null) => void;
setHoveredLine: (line: [Point, Point] | null) => void;
// Setters - Wall
setSelectedWall: (wall: Object3D | null) => void;
setWallThickness: (thickness: number) => void;
setWallHeight: (height: number) => void;
setWallMaterial: (material: string, side: 'inside' | 'outside') => void;
2025-06-10 15:28:23 +05:30
// Setters - Floor
setSelectedFloor: (floor: Object3D | null) => void;
setFloorDepth: (depth: number) => void;
setBeveled: (isBeveled: boolean) => void;
setBevelStrength: (strength: number) => void;
setFloorMaterial: (material: string, side: 'side' | 'top') => void;
// Setters - Decal
setSelectedDecal: (decal: Object3D | null) => void;
// Setters - Aisle General
setSelectedAisle: (aisle: Object3D | null) => void;
2025-06-10 15:28:23 +05:30
setAisleType: (type: AisleTypes) => void;
setAisleWidth: (width: number) => void;
setAisleColor: (color: AisleColors) => void;
// Setters - Aisle Specific
2025-06-10 15:28:23 +05:30
setDashLength: (length: number) => void;
setGapLength: (length: number) => void;
setDotRadius: (radius: number) => void;
setAisleLength: (length: number) => void;
setIsFlipped: (isFlipped: boolean) => void;
// Batch Setters
2025-06-10 15:28:23 +05:30
setDashedAisleProperties: (width: number, dashLength: number, gapLength: number) => void;
setDottedAisleProperties: (width: number, dotRadius: number, gapLength: number) => void;
setArrowsAisleProperties: (width: number, aisleLength: number, gapLength: number) => void;
setAisleProperties: (type: AisleTypes, width: number, color: AisleColors) => void;
}
export const useBuilderStore = create<BuilderState>()(
immer((set) => ({
// === Defaults ===
2025-06-10 15:28:23 +05:30
hoveredPoint: null,
snappedPoint: null,
snappedPosition: null,
hoveredLine: null,
selectedWall: null,
wallThickness: 0.5,
2025-06-10 15:28:23 +05:30
wallHeight: 7,
2025-06-23 09:37:53 +05:30
outsideMaterial: 'Default Material',
insideMaterial: 'Material 1',
2025-06-10 15:28:23 +05:30
selectedFloor: null,
floorDepth: 0.1,
isBeveled: false,
bevelStrength: 0.05,
sideMaterial: 'Material 1',
topMaterial: 'Default Material',
selectedDecal: null,
2025-06-10 15:28:23 +05:30
selectedAisle: null,
aisleType: 'solid-aisle',
aisleWidth: 0.1,
aisleColor: 'yellow',
2025-06-10 15:28:23 +05:30
dashLength: 0.5,
gapLength: 0.3,
dotRadius: 0.1,
aisleLength: 0.6,
isFlipped: false,
// === Setters: Point/Line ===
2025-06-10 15:28:23 +05:30
setHoveredPoint: (point: Point | null) => {
set((state) => {
state.hoveredPoint = point;
});
},
setSnappedPoint: (point: Point | null) => {
set((state) => {
state.snappedPoint = point;
});
},
setSnappedPosition: (position: [number, number, number] | null) => {
set((state) => {
state.snappedPosition = position;
});
},
setHoveredLine: (line: [Point, Point] | null) => {
set((state) => {
state.hoveredLine = line;
})
},
// === Setters: Wall ===
setSelectedWall: (wall: Object3D | null) => {
2025-06-10 15:28:23 +05:30
set((state) => {
state.selectedWall = wall;
})
2025-06-10 15:28:23 +05:30
},
setWallThickness: (thickness: number) => {
2025-06-10 15:28:23 +05:30
set((state) => {
state.wallThickness = thickness;
})
},
setWallHeight: (height: number) => {
set((state) => {
state.wallHeight = height;
})
},
setWallMaterial: (material: string, side: 'inside' | 'outside') => {
set((state) => {
if (side === 'outside') state.outsideMaterial = material;
else state.insideMaterial = material;
2025-06-10 15:28:23 +05:30
});
},
// === Setters: Floor ===
setSelectedFloor: (floor: Object3D | null) => {
set((state) => {
state.selectedFloor = floor;
});
},
setFloorDepth: (depth: number) => {
set((state) => {
state.floorDepth = depth;
});
},
setBeveled: (isBeveled: boolean) => {
set((state) => {
state.isBeveled = isBeveled;
});
},
setBevelStrength: (strength: number) => {
set((state) => {
state.bevelStrength = strength;
});
},
setFloorMaterial: (material: string, side: 'side' | 'top') => {
set((state) => {
if (side === 'side') state.sideMaterial = material;
else state.topMaterial = material;
});
},
// === Setters: Decal ===
setSelectedDecal: (decal: Object3D | null) => {
set((state) => {
state.selectedDecal = decal;
})
},
// === Setters: Aisle General ===
2025-06-10 15:28:23 +05:30
setSelectedAisle: (aisle: Object3D | null) => {
set((state) => {
state.selectedAisle = aisle;
});
},
setAisleType: (type) => {
set((state) => {
state.aisleType = type;
});
},
2025-06-10 15:28:23 +05:30
setAisleWidth: (width) => {
set((state) => {
state.aisleWidth = width;
});
},
2025-06-10 15:28:23 +05:30
setAisleColor: (color) => {
set((state) => {
state.aisleColor = color;
});
},
// === Setters: Aisle Specific ===
2025-06-10 15:28:23 +05:30
setDashLength: (length) => {
set((state) => {
state.dashLength = length;
});
},
2025-06-10 15:28:23 +05:30
setGapLength: (length) => {
set((state) => {
state.gapLength = length;
});
},
2025-06-10 15:28:23 +05:30
setDotRadius: (radius) => {
set((state) => {
state.dotRadius = radius;
});
},
2025-06-10 15:28:23 +05:30
setAisleLength: (length) => {
set((state) => {
state.aisleLength = length;
});
},
2025-06-10 15:28:23 +05:30
setIsFlipped: (isFlipped) => {
set((state) => {
state.isFlipped = isFlipped;
});
},
// === Batch Setters ===
setDashedAisleProperties: (width, dashLength, gapLength) => set((state) => {
state.aisleType = 'dashed-aisle';
state.aisleWidth = width;
state.dashLength = dashLength;
state.gapLength = gapLength;
}),
setDottedAisleProperties: (width, dotRadius, gapLength) => set((state) => {
state.aisleType = 'dotted-aisle';
state.aisleWidth = width;
state.dotRadius = dotRadius;
state.gapLength = gapLength;
}),
setArrowsAisleProperties: (width, aisleLength, gapLength) => set((state) => {
state.aisleType = 'arrows-aisle';
state.aisleWidth = width;
state.aisleLength = aisleLength;
state.gapLength = gapLength;
}),
setAisleProperties: (type, width, color) => set((state) => {
state.aisleType = type;
state.aisleWidth = width;
state.aisleColor = color;
})
2025-06-10 15:28:23 +05:30
}))
);