mirror of
https://github.com/Steffo99/festa.git
synced 2024-12-23 07:04:22 +00:00
36 lines
1.2 KiB
TypeScript
36 lines
1.2 KiB
TypeScript
import { faEye, faEyeSlash } from "@fortawesome/free-solid-svg-icons"
|
|
import { useTranslation } from "next-i18next"
|
|
import { useDefinedContext } from "../../../utils/definedContext"
|
|
import { FestaIcon } from "../../generic/renderers/fontawesome"
|
|
import { Tool } from "../../generic/toolbar/tool"
|
|
import { PostcardContext, PostcardVisibility } from "../base"
|
|
|
|
|
|
/**
|
|
* Toolbar tool which toggles the {@link PostcardVisibility} state of its wrapping context.
|
|
*/
|
|
export function ToolToggleVisibility() {
|
|
const { t } = useTranslation()
|
|
const { visibility, setVisibility } = useDefinedContext(PostcardContext)
|
|
|
|
if (visibility === PostcardVisibility.BACKGROUND) {
|
|
return (
|
|
<Tool
|
|
aria-label={t("toggleVisibleShow")}
|
|
onClick={() => setVisibility(PostcardVisibility.FOREGROUND)}
|
|
>
|
|
<FestaIcon icon={faEye} />
|
|
</Tool>
|
|
)
|
|
}
|
|
else {
|
|
return (
|
|
<Tool
|
|
aria-label={t("toggleVisibleHide")}
|
|
onClick={() => setVisibility(PostcardVisibility.BACKGROUND)}
|
|
>
|
|
<FestaIcon icon={faEyeSlash} />
|
|
</Tool>
|
|
)
|
|
}
|
|
}
|