2023-10-23 13:35:57 +08:00
|
|
|
import React from "react";
|
|
|
|
|
import ReactDOM from "react-dom/client";
|
|
|
|
|
import Action from "./views/Action";
|
|
|
|
|
import createCache from "@emotion/cache";
|
|
|
|
|
import { CacheProvider } from "@emotion/react";
|
|
|
|
|
import {
|
|
|
|
|
MSG_TRANS_TOGGLE,
|
|
|
|
|
MSG_TRANS_TOGGLE_STYLE,
|
|
|
|
|
MSG_TRANS_GETRULE,
|
|
|
|
|
MSG_TRANS_PUTRULE,
|
|
|
|
|
APP_LCNAME,
|
2023-10-23 18:02:42 +08:00
|
|
|
DEFAULT_TRANBOX_SETTING,
|
2023-10-23 13:35:57 +08:00
|
|
|
} from "./config";
|
|
|
|
|
import { getRulesWithDefault, getFabWithDefault } from "./libs/storage";
|
|
|
|
|
import { Translator } from "./libs/translator";
|
|
|
|
|
import { sendIframeMsg, sendParentMsg } from "./libs/iframe";
|
|
|
|
|
import { matchRule } from "./libs/rules";
|
2023-10-23 18:02:42 +08:00
|
|
|
import Slection from "./views/Selection";
|
2023-11-11 16:59:38 +08:00
|
|
|
import { touchTapListener } from "./libs/touch";
|
|
|
|
|
import { debounce } from "./libs/utils";
|
2023-10-23 13:35:57 +08:00
|
|
|
|
|
|
|
|
export async function runTranslator(setting) {
|
|
|
|
|
const href = document.location.href;
|
|
|
|
|
const rules = await getRulesWithDefault();
|
|
|
|
|
const rule = await matchRule(rules, href, setting);
|
|
|
|
|
const translator = new Translator(rule, setting);
|
|
|
|
|
|
|
|
|
|
return { translator, rule };
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function runIframe(setting) {
|
|
|
|
|
let translator;
|
|
|
|
|
window.addEventListener("message", (e) => {
|
|
|
|
|
const { action, args } = e.data || {};
|
|
|
|
|
switch (action) {
|
|
|
|
|
case MSG_TRANS_TOGGLE:
|
|
|
|
|
translator?.toggle();
|
|
|
|
|
break;
|
|
|
|
|
case MSG_TRANS_TOGGLE_STYLE:
|
|
|
|
|
translator?.toggleStyle();
|
|
|
|
|
break;
|
|
|
|
|
case MSG_TRANS_PUTRULE:
|
|
|
|
|
if (!translator) {
|
|
|
|
|
translator = new Translator(args, setting);
|
|
|
|
|
} else {
|
|
|
|
|
translator.updateRule(args || {});
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
sendParentMsg(MSG_TRANS_GETRULE);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export async function showFab(translator) {
|
|
|
|
|
const fab = await getFabWithDefault();
|
2023-10-23 18:02:42 +08:00
|
|
|
if (fab.isHide) {
|
|
|
|
|
return;
|
2023-10-23 13:35:57 +08:00
|
|
|
}
|
2023-10-23 18:02:42 +08:00
|
|
|
|
|
|
|
|
const $action = document.createElement("div");
|
|
|
|
|
$action.setAttribute("id", APP_LCNAME);
|
|
|
|
|
document.body.parentElement.appendChild($action);
|
|
|
|
|
const shadowContainer = $action.attachShadow({ mode: "closed" });
|
|
|
|
|
const emotionRoot = document.createElement("style");
|
|
|
|
|
const shadowRootElement = document.createElement("div");
|
|
|
|
|
shadowContainer.appendChild(emotionRoot);
|
|
|
|
|
shadowContainer.appendChild(shadowRootElement);
|
|
|
|
|
const cache = createCache({
|
|
|
|
|
key: APP_LCNAME,
|
|
|
|
|
prepend: true,
|
|
|
|
|
container: emotionRoot,
|
|
|
|
|
});
|
|
|
|
|
ReactDOM.createRoot(shadowRootElement).render(
|
|
|
|
|
<React.StrictMode>
|
|
|
|
|
<CacheProvider value={cache}>
|
|
|
|
|
<Action translator={translator} fab={fab} />
|
|
|
|
|
</CacheProvider>
|
|
|
|
|
</React.StrictMode>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
2023-10-24 17:58:37 +08:00
|
|
|
export function showTransbox({
|
|
|
|
|
tranboxSetting = DEFAULT_TRANBOX_SETTING,
|
|
|
|
|
transApis,
|
|
|
|
|
}) {
|
2023-10-23 18:02:42 +08:00
|
|
|
if (!tranboxSetting?.transOpen) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const $tranbox = document.createElement("div");
|
|
|
|
|
$tranbox.setAttribute("id", "kiss-transbox");
|
|
|
|
|
document.body.parentElement.appendChild($tranbox);
|
|
|
|
|
const shadowContainer = $tranbox.attachShadow({ mode: "closed" });
|
|
|
|
|
const emotionRoot = document.createElement("style");
|
|
|
|
|
const shadowRootElement = document.createElement("div");
|
|
|
|
|
shadowContainer.appendChild(emotionRoot);
|
|
|
|
|
shadowContainer.appendChild(shadowRootElement);
|
|
|
|
|
const cache = createCache({
|
|
|
|
|
key: "kiss-transbox",
|
|
|
|
|
prepend: true,
|
|
|
|
|
container: emotionRoot,
|
|
|
|
|
});
|
|
|
|
|
ReactDOM.createRoot(shadowRootElement).render(
|
|
|
|
|
<React.StrictMode>
|
|
|
|
|
<CacheProvider value={cache}>
|
2023-10-24 17:58:37 +08:00
|
|
|
<Slection tranboxSetting={tranboxSetting} transApis={transApis} />
|
2023-10-23 18:02:42 +08:00
|
|
|
</CacheProvider>
|
|
|
|
|
</React.StrictMode>
|
|
|
|
|
);
|
2023-10-23 13:35:57 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export function windowListener(rule) {
|
|
|
|
|
window.addEventListener("message", (e) => {
|
|
|
|
|
const { action } = e.data || {};
|
|
|
|
|
switch (action) {
|
|
|
|
|
case MSG_TRANS_GETRULE:
|
|
|
|
|
sendIframeMsg(MSG_TRANS_PUTRULE, rule);
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
2023-11-11 16:59:38 +08:00
|
|
|
export function showErr(message) {
|
2023-10-23 13:35:57 +08:00
|
|
|
const $err = document.createElement("div");
|
2023-11-11 16:59:38 +08:00
|
|
|
$err.innerText = `KISS-Translator: ${message}`;
|
2023-10-23 13:35:57 +08:00
|
|
|
$err.style.cssText = "background:red; color:#fff;";
|
|
|
|
|
document.body.prepend($err);
|
|
|
|
|
}
|
2023-11-11 16:59:38 +08:00
|
|
|
|
|
|
|
|
export function touchOperation(translator) {
|
|
|
|
|
const { touchTranslate = 2 } = translator.setting;
|
|
|
|
|
if (touchTranslate === 0) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const handleTap = debounce(() => {
|
|
|
|
|
translator.toggle();
|
|
|
|
|
sendIframeMsg(MSG_TRANS_TOGGLE);
|
|
|
|
|
});
|
|
|
|
|
touchTapListener(handleTap, touchTranslate);
|
|
|
|
|
}
|