mirror of
https://github.com/upscayl/upscayl.git
synced 2025-01-19 01:24:09 +01:00
96 lines
3.1 KiB
TypeScript
96 lines
3.1 KiB
TypeScript
import React, { useEffect } from "react";
|
|
|
|
const ImageOptions = ({
|
|
zoomAmount,
|
|
setZoomAmount,
|
|
resetImagePaths,
|
|
hideZoomOptions,
|
|
}: {
|
|
zoomAmount: string;
|
|
setZoomAmount: (arg: any) => void;
|
|
resetImagePaths: () => void;
|
|
hideZoomOptions?: boolean;
|
|
}) => {
|
|
useEffect(() => {
|
|
if (!localStorage.getItem("zoomAmount")) {
|
|
localStorage.setItem("zoomAmount", zoomAmount);
|
|
} else {
|
|
setZoomAmount(localStorage.getItem("zoomAmount"));
|
|
}
|
|
}, []);
|
|
|
|
return (
|
|
<div className="animate rounded-btn collapse absolute top-1 z-50 m-2 opacity-25 hover:opacity-100">
|
|
<input type="checkbox" className="peer" />
|
|
<div className="collapse-title bg-base-100 text-center text-sm font-semibold uppercase text-primary-content peer-checked:bg-base-300 peer-checked:text-base-content">
|
|
Show/Hide Image Settings
|
|
</div>
|
|
|
|
<div className="collapse-content bg-base-100 text-base-content">
|
|
<div className="flex max-h-96 flex-col justify-center gap-5 overflow-auto p-5">
|
|
<button className="btn-primary btn" onClick={resetImagePaths}>
|
|
Reset Image
|
|
</button>
|
|
{!hideZoomOptions && (
|
|
<div className="flex flex-row items-center gap-2">
|
|
<p className="w-20">Zoom:</p>
|
|
<button
|
|
className={`btn-primary btn ${
|
|
zoomAmount === "100%" ? "btn-secondary" : "btn-primary"
|
|
}`}
|
|
onClick={() => {
|
|
setZoomAmount("100%");
|
|
localStorage.setItem("zoomAmount", "100%");
|
|
}}>
|
|
100%
|
|
</button>
|
|
<button
|
|
className={`btn-primary btn ${
|
|
zoomAmount === "125%" ? "btn-secondary" : "btn-primary"
|
|
}`}
|
|
onClick={() => {
|
|
setZoomAmount("125%");
|
|
localStorage.setItem("zoomAmount", "125%");
|
|
}}>
|
|
125%
|
|
</button>
|
|
<button
|
|
className={`btn-primary btn ${
|
|
zoomAmount === "150%" ? "btn-secondary" : "btn-primary"
|
|
}`}
|
|
onClick={() => {
|
|
setZoomAmount("150%");
|
|
localStorage.setItem("zoomAmount", "150%");
|
|
}}>
|
|
150%
|
|
</button>
|
|
<button
|
|
className={`btn-primary btn ${
|
|
zoomAmount === "175%" ? "btn-secondary" : "btn-primary"
|
|
}`}
|
|
onClick={() => {
|
|
setZoomAmount("175%");
|
|
localStorage.setItem("zoomAmount", "175%");
|
|
}}>
|
|
175%
|
|
</button>
|
|
<button
|
|
className={`btn-primary btn ${
|
|
zoomAmount === "200%" ? "btn-secondary" : "btn-primary"
|
|
}`}
|
|
onClick={() => {
|
|
setZoomAmount("200%");
|
|
localStorage.setItem("zoomAmount", "200%");
|
|
}}>
|
|
200%
|
|
</button>
|
|
</div>
|
|
)}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default ImageOptions;
|