Files
code-box/component/options/csdn.tsx
2025-01-07 11:30:41 +08:00

155 lines
4.9 KiB
TypeScript

import { useImperativeHandle } from "react"
import { useStorage } from "@plasmohq/storage/hook"
import CssCode from "~component/items/cssCode"
import DownloadHtml from "~component/items/downloadHtml"
import DownloadMarkdown from "~component/items/downloadMarkdown"
import DownloadPdf from "~component/items/downloadPdf"
import EditMarkdown from "~component/items/editMarkdown"
import ShowTag from "~component/items/showTag"
import { i18n } from "~tools"
export default function Csdn({ forwardRef }) {
const [closeAds, setCloseAds] = useStorage("csdn-closeAds", (v) =>
v === undefined ? true : v
)
const [copyCode, setCopyCode] = useStorage("csdn-copyCode", (v) =>
v === undefined ? true : v
)
const [closeFollow, setCloseFollow] = useStorage("csdn-closeFollow", (v) =>
v === undefined ? true : v
)
const [closeVip, setCloseVip] = useStorage("csdn-closeVip", (v) =>
v === undefined ? true : v
)
const [autoOpenCode, setAutoOpenCode] = useStorage(
"csdn-autoOpenCode",
(v) => (v === undefined ? true : v)
)
const [closeLoginModal, setCloseLoginModal] = useStorage(
"csdn-closeLoginModal",
(v) => (v === undefined ? true : v)
)
const [closeRedirectModal, setCloseRedirectModal] = useStorage(
"csdn-closeRedirectModal",
(v) => (v === undefined ? true : v)
)
function handleReset() {
setCloseAds(true)
setCopyCode(true)
setCloseFollow(true)
setCloseVip(true)
setAutoOpenCode(true)
setCloseLoginModal(true)
setCloseRedirectModal(true)
}
useImperativeHandle(forwardRef, () => ({
handleReset
}))
return (
<fieldset>
<legend>{i18n("csdnConfig")}</legend>
<div className="item">
<span>{i18n("csdnCloseAds")}</span>
<input
type="checkbox"
id="csdn-closeAds"
name="csdn-closeAds"
className="codebox-offscreen"
checked={closeAds}
onChange={(e) => setCloseAds(e.target.checked)}
/>
<label htmlFor="csdn-closeAds" className="codebox-switch"></label>
</div>
<div className="item">
<span>{i18n("csdnCopyCode")}</span>
<input
type="checkbox"
id="csdn-copyCode"
name="csdn-copyCode"
className="codebox-offscreen"
checked={copyCode}
onChange={(e) => setCopyCode(e.target.checked)}
/>
<label htmlFor="csdn-copyCode" className="codebox-switch"></label>
</div>
<div className="item">
<span>{i18n("csdnCloseFollow")}</span>
<input
type="checkbox"
id="csdn-closeFollow"
name="csdn-closeFollow"
className="codebox-offscreen"
checked={closeFollow}
onChange={(e) => setCloseFollow(e.target.checked)}
/>
<label htmlFor="csdn-closeFollow" className="codebox-switch"></label>
</div>
<div className="item">
<span>{i18n("csdnCloseVip")}</span>
<input
type="checkbox"
id="csdn-closeVip"
name="csdn-closeVip"
className="codebox-offscreen"
checked={closeVip}
onChange={(e) => setCloseVip(e.target.checked)}
/>
<label htmlFor="csdn-closeVip" className="codebox-switch"></label>
</div>
<div className="item">
<span>{i18n("csdnAutoOpenCode")}</span>
<input
type="checkbox"
id="csdn-autoOpenCode"
name="csdn-autoOpenCode"
className="codebox-offscreen"
checked={autoOpenCode}
onChange={(e) => setAutoOpenCode(e.target.checked)}
/>
<label htmlFor="csdn-autoOpenCode" className="codebox-switch"></label>
</div>
<div className="item">
<span>{i18n("csdnCloseLoginModal")}</span>
<input
type="checkbox"
id="csdn-closeLoginModal"
name="csdn-closeLoginModal"
className="codebox-offscreen"
checked={closeLoginModal}
onChange={(e) => setCloseLoginModal(e.target.checked)}
/>
<label
htmlFor="csdn-closeLoginModal"
className="codebox-switch"></label>
</div>
<div className="item">
<span>{i18n("csdnCloseRedirectModal")}</span>
<input
type="checkbox"
id="csdn-closeRedirectModal"
name="csdn-closeRedirectModal"
className="codebox-offscreen"
checked={closeRedirectModal}
onChange={(e) => setCloseRedirectModal(e.target.checked)}
/>
<label
htmlFor="csdn-closeRedirectModal"
className="codebox-switch"></label>
</div>
<ShowTag name="csdn"></ShowTag>
<CssCode name="csdn"></CssCode>
<ShowTag name="csdn"></ShowTag>
<EditMarkdown name="csdn"></EditMarkdown>
<DownloadMarkdown name="csdn"></DownloadMarkdown>
<DownloadHtml name="csdn"></DownloadHtml>
<DownloadPdf name="csdn"></DownloadPdf>
</fieldset>
)
}