code refactored
This commit is contained in:
@@ -23,7 +23,6 @@ const Outline: React.FC = () => {
|
|||||||
// const [buildingsList, setBuildingsList] = useState<{ id: string; name: string }[]>([]);
|
// const [buildingsList, setBuildingsList] = useState<{ id: string; name: string }[]>([]);
|
||||||
// const [isLayersOpen, setIsLayersOpen] = useState(true);
|
// const [isLayersOpen, setIsLayersOpen] = useState(true);
|
||||||
// const [isBuildingsOpen, setIsBuildingsOpen] = useState(false);
|
// const [isBuildingsOpen, setIsBuildingsOpen] = useState(false);
|
||||||
const [isZonesOpen, setIsZonesOpen] = useState(true);
|
|
||||||
const { assetStore, zoneStore } = useSceneContext();
|
const { assetStore, zoneStore } = useSceneContext();
|
||||||
const { assets } = assetStore();
|
const { assets } = assetStore();
|
||||||
const { zones } = zoneStore();
|
const { zones } = zoneStore();
|
||||||
@@ -100,7 +99,7 @@ const Outline: React.FC = () => {
|
|||||||
</section> */}
|
</section> */}
|
||||||
<section className="outline-section overflow">
|
<section className="outline-section overflow">
|
||||||
{/* <DropDownList value="Buildings" items={buildingsList} isOpen={isBuildingsOpen} onToggle={() => setIsBuildingsOpen((prev) => !prev)} showKebabMenu={false} showAddIcon={false} /> */}
|
{/* <DropDownList value="Buildings" items={buildingsList} isOpen={isBuildingsOpen} onToggle={() => setIsBuildingsOpen((prev) => !prev)} showKebabMenu={false} showAddIcon={false} /> */}
|
||||||
<DropDownList value="Zones" items={sceneAssetsDataList} isOpen={isZonesOpen} onToggle={() => setIsZonesOpen((prev) => !prev)} showKebabMenu={false} showAddIcon={false} />
|
<DropDownList header="Zones" type="Zones" items={sceneAssetsDataList} isDefaultOpen={true} showKebabMenu={false} showAddIcon={false} />
|
||||||
</section>
|
</section>
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
|
|||||||
@@ -34,10 +34,7 @@ const SideBarLeft: React.FC = () => {
|
|||||||
};
|
};
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div
|
<div className={`sidebar-left-wrapper ${toggleUILeft && (!isComparing || activeModule !== "simulation") ? "open" : "closed"}`}>
|
||||||
className={`sidebar-left-wrapper ${toggleUILeft && (!isComparing || activeModule !== "simulation") ? "open" : "closed"
|
|
||||||
}`}
|
|
||||||
>
|
|
||||||
<Header />
|
<Header />
|
||||||
{toggleUILeft && (
|
{toggleUILeft && (
|
||||||
<div className={`sidebar-left-container `}>
|
<div className={`sidebar-left-container `}>
|
||||||
@@ -45,15 +42,9 @@ const SideBarLeft: React.FC = () => {
|
|||||||
if (activeModule === "visualization") {
|
if (activeModule === "visualization") {
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<ToggleHeader
|
<ToggleHeader options={["Widgets", "Templates"]} activeOption={activeOption} handleClick={handleToggleClick} />
|
||||||
options={["Widgets", "Templates"]}
|
|
||||||
activeOption={activeOption}
|
|
||||||
handleClick={handleToggleClick}
|
|
||||||
/>
|
|
||||||
<Search onChange={handleSearchChange} />
|
<Search onChange={handleSearchChange} />
|
||||||
<div className="sidebar-left-content-container">
|
<div className="sidebar-left-content-container">{activeOption === "Widgets" ? <Widgets /> : <Templates />}</div>
|
||||||
{activeOption === "Widgets" ? <Widgets /> : <Templates />}
|
|
||||||
</div>
|
|
||||||
</>
|
</>
|
||||||
);
|
);
|
||||||
} else if (activeModule === "market") {
|
} else if (activeModule === "market") {
|
||||||
@@ -61,14 +52,8 @@ const SideBarLeft: React.FC = () => {
|
|||||||
} else if (activeModule === "builder") {
|
} else if (activeModule === "builder") {
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<ToggleHeader
|
<ToggleHeader options={["Outline", "Assets"]} activeOption={activeOption} handleClick={handleToggleClick} />
|
||||||
options={["Outline", "Assets"]}
|
<div className="sidebar-left-content-container">{activeOption === "Outline" ? <Outline /> : <Assets />}</div>
|
||||||
activeOption={activeOption}
|
|
||||||
handleClick={handleToggleClick}
|
|
||||||
/>
|
|
||||||
<div className="sidebar-left-content-container">
|
|
||||||
{activeOption === "Outline" ? <Outline /> : <Assets />}
|
|
||||||
</div>
|
|
||||||
</>
|
</>
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
@@ -76,14 +61,8 @@ const SideBarLeft: React.FC = () => {
|
|||||||
<>
|
<>
|
||||||
{!isComparing && (
|
{!isComparing && (
|
||||||
<>
|
<>
|
||||||
<ToggleHeader
|
<ToggleHeader options={["Outline"]} activeOption={activeOption} handleClick={handleToggleClick} />
|
||||||
options={["Outline"]}
|
<div className="sidebar-left-content-container">{activeOption === "Outline" ? <Outline /> : <Assets />}</div>
|
||||||
activeOption={activeOption}
|
|
||||||
handleClick={handleToggleClick}
|
|
||||||
/>
|
|
||||||
<div className="sidebar-left-content-container">
|
|
||||||
{activeOption === "Outline" ? <Outline /> : <Assets />}
|
|
||||||
</div>
|
|
||||||
</>
|
</>
|
||||||
)}
|
)}
|
||||||
</>
|
</>
|
||||||
|
|||||||
@@ -4,61 +4,69 @@ import KebabMenuListMultiSelect from "./KebebMenuListMultiSelect";
|
|||||||
import List from "./OutlineList/ListNew";
|
import List from "./OutlineList/ListNew";
|
||||||
|
|
||||||
interface DropDownListProps {
|
interface DropDownListProps {
|
||||||
value?: string;
|
header?: string;
|
||||||
|
type?: "Zones" | "Assets";
|
||||||
items?: { id: string; name: string }[];
|
items?: { id: string; name: string }[];
|
||||||
showFocusIcon?: boolean;
|
showFocusIcon?: boolean;
|
||||||
|
onFocusClick?: () => void;
|
||||||
showAddIcon?: boolean;
|
showAddIcon?: boolean;
|
||||||
|
onAddClick?: () => void;
|
||||||
showKebabMenu?: boolean;
|
showKebabMenu?: boolean;
|
||||||
|
onKebabMenuSelect?: (selectedItems: string[]) => void;
|
||||||
kebabMenuItems?: { id: string; name: string }[];
|
kebabMenuItems?: { id: string; name: string }[];
|
||||||
remove?: boolean;
|
removeIcon?: boolean;
|
||||||
isOpen: boolean;
|
isDefaultOpen: boolean;
|
||||||
onToggle: () => void;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const DropDownList: React.FC<DropDownListProps> = ({
|
const DropDownList: React.FC<DropDownListProps> = ({
|
||||||
value = "Dropdown",
|
header = "Dropdown",
|
||||||
items = [],
|
items = [],
|
||||||
|
type = "Assets",
|
||||||
showFocusIcon = false,
|
showFocusIcon = false,
|
||||||
|
onFocusClick,
|
||||||
showAddIcon = true,
|
showAddIcon = true,
|
||||||
|
onAddClick,
|
||||||
showKebabMenu = true,
|
showKebabMenu = true,
|
||||||
|
onKebabMenuSelect,
|
||||||
|
removeIcon = false,
|
||||||
kebabMenuItems = [
|
kebabMenuItems = [
|
||||||
{ id: "Buildings", name: "Buildings" },
|
{ id: "Buildings", name: "Buildings" },
|
||||||
{ id: "Paths", name: "Paths" },
|
{ id: "Paths", name: "Paths" },
|
||||||
{ id: "Zones", name: "Zones" },
|
{ id: "Zones", name: "Zones" },
|
||||||
],
|
],
|
||||||
remove,
|
isDefaultOpen,
|
||||||
isOpen,
|
|
||||||
onToggle,
|
|
||||||
}) => {
|
}) => {
|
||||||
|
const [isOpen, setIsOpen] = React.useState(isDefaultOpen);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="dropdown-list-container">
|
<div className="dropdown-list-container">
|
||||||
<div className="head" onClick={onToggle}>
|
<div className="head" onClick={() => setIsOpen((prev) => !prev)}>
|
||||||
<div className="value">{value}</div>
|
<div className="value">{header}</div>
|
||||||
<div className="options">
|
<div className="options">
|
||||||
{showFocusIcon && (
|
{showFocusIcon && (
|
||||||
<div className="focus option">
|
<div className="focus option" onClick={onFocusClick}>
|
||||||
<FocusIcon />
|
<FocusIcon />
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
{showAddIcon && (
|
{showAddIcon && (
|
||||||
<div className="add option">
|
<div className="add option" onClick={onAddClick}>
|
||||||
<AddIcon />
|
<AddIcon />
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
{showKebabMenu && (
|
{showKebabMenu && (
|
||||||
<div className="kebab-menu option">
|
<div className="kebab-menu option">
|
||||||
<KebabMenuListMultiSelect items={kebabMenuItems} />
|
<KebabMenuListMultiSelect items={kebabMenuItems} onSelectionChange={onKebabMenuSelect} />
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
<button id="collapse-btn" title="collapse-btn" className="collapse-icon option" style={{ transform: isOpen ? "rotate(0deg)" : "rotate(-90deg)" }}>
|
<button id="collapse-btn" title="collapse-btn" className="collapse-icon option" style={{ transform: isDefaultOpen ? "rotate(0deg)" : "rotate(-90deg)" }}>
|
||||||
<ArrowIcon />
|
<ArrowIcon />
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{isOpen && (
|
{isDefaultOpen && isOpen && (
|
||||||
<div className="lists-container">
|
<div className="lists-container">
|
||||||
<List items={items} remove={remove} />
|
<List items={items} remove={removeIcon} />
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
Reference in New Issue
Block a user