diff --git a/src/App.js b/src/App.js
index 1967262..31972e7 100644
--- a/src/App.js
+++ b/src/App.js
@@ -1,4 +1,4 @@
-import React, { useState, Suspense } from "react";
+import React, { useState, Suspense, useEffect } from "react";
import { Button, Table, Empty, Tabs, Image } from "antd";
import "highlight.js/styles/github.css";
@@ -109,8 +109,8 @@ function App() {
// setHasSolution(!!problems[problemId]);
// }, 1000);
- // 开发环境不需要依赖 chrome 插件 query 函数
- const [langReady, setLangReady] = useState(isDev);
+ // 开发环境和直接进入网站的方式不需要依赖 chrome 插件 query 函数
+ const [langReady, setLangReady] = useState(isDev||!isInExtension());
const [problemId, setProblemId] = useState("");
const [hasSolution, setHasSolution] = useState(false);
@@ -243,7 +243,7 @@ function App() {
diff --git a/src/codeTemplates/codeTemplate.jsx b/src/codeTemplates/codeTemplate.jsx
index a5233ab..aa894a3 100644
--- a/src/codeTemplates/codeTemplate.jsx
+++ b/src/codeTemplates/codeTemplate.jsx
@@ -28,7 +28,7 @@ export default function CodeTemplate({ templates }) {
return (
+
-
- 暂不支持编辑功能。如果需要编辑,可通过先“使用”再“保存”,最后“删除”原有的数据,从而间接实现。
+ {/* 暂不支持编辑功能。如果需要编辑,可通过先“使用”再“保存”,最后“删除”原有的数据,从而间接实现。 */}
+ {t("Locale.dataStructureVisualization.explain1")}
-
- 模板可以增量使用。点击”去使用“的下拉三角,并选择增量使用即可。
+ {/* 模板可以增量使用。点击”去使用“的下拉三角,并选择增量使用即可。 */}
+
+ {t("Locale.dataStructureVisualization.explain2")}
-
- 使用的模板会根据你鼠标的位置生成。比如你的鼠标在点(100,
+ {/* 使用的模板会根据你鼠标的位置生成。比如你的鼠标在点(100,
100),那么模板会整体偏移 (100, 100)个单位
。如果此时模板并不是正好以(100,
- 100)为左上顶点,说明模板本身制作的时候就不是以(0,0)为左上顶点制作的。大家制作自定义模板的话需要注意这一点。
+ 100)为左上顶点,说明模板本身制作的时候就不是以(0,0)为左上顶点制作的。大家制作自定义模板的话需要注意这一点。 */}
+ {t("Locale.dataStructureVisualization.explain3")}
+
+ -
+ {/* 你也可以选择直接使用原生 excalidraw */}
+ {t("Locale.dataStructureVisualization.explain4")}
+
+ Website
- - 你也可以选择直接使用原生 excalidraw 地址
{/*
-
-
+
{
setPointer(pointer);
}}
- name="力扣加加"
- // user={{ name: "力扣加加" }}
- // onPointerUpdate={(payload) => console.log(payload)}
+ name={t("app.name")}
+ // user={{ name: "力扣加加" }}
+ // onPointerUpdate={(payload) => console.log(payload)}
/>
diff --git a/src/locales/en.js b/src/locales/en.js
index 12db0b7..804fdd2 100644
--- a/src/locales/en.js
+++ b/src/locales/en.js
@@ -1,12 +1,26 @@
-export const en = {
+const en = {
app: {
+ name: "LeetCode Cheatsheet",
+ preview: "Preview",
+ copyMdOrigin: "Click to copy MarkDown origin",
+ fullScreen: "Full Screen (Press ESC to exit)",
+ toUse: "To Use",
+ custom: "Custom",
+ presets: "Presets",
setLang: "Set Language",
changeLang: "中文",
copy: "copy",
+ save: "save",
+ yes: "yes",
+ no: "no",
+ delete: "delete",
+ delTitle: "Are you sure you want to delete it?",
+ deleteSuccess: "Delete successfully~",
+ saveSuccess: "Save successfully~",
copySuccess: "Copy successfully~",
article: "article",
recommendedQuestions: "Recommended Questions:",
- toWriteSilently: "To write silently",
+ goForDictation: "go for dictation",
contribution: "Correction or contribution to other languages",
back: "Back to Home page",
viewSolution: "View solution",
@@ -43,6 +57,7 @@ export const en = {
savingProblem: "Saving problem information, please wait~",
githubAPIError:
"Failed to use Github API, has been switched to normal mode, normal mode can only automatically bring in the problem name, problem address and solution language.",
+ notYet: "Not yet",
},
problem: {
743: "743. Network Delay Time",
@@ -78,13 +93,47 @@ export const en = {
},
dataStructureVisualization: {
name: "Data Structure Visualization",
+ incrementalUsage: "Incremental Usage",
+ explain1:
+ "The editing function is not supported. If you need to edit, you can do so indirectly by first \"use\", then \"save\", and finally \"delete\" the original data.",
+ explain2:
+ "Templates can be used incrementally. Click the drop-down triangle of 'to use' and select Incremental Usage.",
+ explain3:
+ "The template will be generated according to the position of your mouse. For example, if your mouse is at point (100, 100), the template will be offset by (100, 100) units as a whole. If the template is not exactly at (100, 100), it means that the template itself was not created with (0, 0) as the top-left corner. When creating custom templates, it's important to keep this in mind.",
+ explain4: "You can also choose to use the native excalidraw directly ",
},
explanationTemplate: {
name: "Explanation Template",
+ goToTheWebsiteToUse: "Go to the website to use",
+ problemAddress: "Problem Address",
+ problemDesc: "Problem Description",
+ preKnowledge: "Pre Knowledge",
+ company: "Company",
+ thinking: "Thinking",
+ keyPoints: "Key Points",
+ languageSupport: "Language Support",
+ complexityAnalysis: "Complexity Analysis",
+ complexityDeclare: "Let n be the length of the array.",
+ timeComplexity: "Time Complexity",
+ spaceComplexity: "Space Complexity",
+ howToUse: "How to use it?",
+ programmingLanguage: "Programming Language:",
+ commonFormulas: "Common formulas (click to copy):",
+ noBackup: "No backup file found",
+ restore: "Restore last edit content",
+ backupTips:
+ "The explanation is backed up every five seconds. If you accidentally refresh the browser, you can click the restore button below to restore it. Since it is an overwrite backup, only the last edited content will be saved.",
+ afterUpdateTemplateTips:
+ "More explanation templates will be provided later.",
+ afterUpdateThemeTips:
+ "More themes and user-defined themes will be supported later.",
},
complexityQuickCheck: {
name: "Complexity Quick Check",
+ tips: "Don't understand why? Click here",
+ dataScale: "Data Scale",
+ timeComplexity: "Algorithm acceptable time complexity",
},
learningRoute: {
name: "Learning Route",
@@ -96,4 +145,5 @@ export const en = {
name: "About Me",
},
};
-export default en;
+// export default en;
+module.exports = en;
diff --git a/src/locales/zh.js b/src/locales/zh.js
index 4dee4a9..615d071 100644
--- a/src/locales/zh.js
+++ b/src/locales/zh.js
@@ -1,14 +1,27 @@
-export const cn = {
-
+const zh = {
app: {
+ name: "力扣加加",
+ preview: "预览",
+ copyMdOrigin: "点击复制 MarkDown 原文",
+ fullScreen: "全屏模式(退出请按 ESC)",
+ toUse: "去使用",
+ custom: "自定义",
+ presets: "预设",
setLang: "设置语言",
changeLang: "English",
copy: "复制",
+ save: "保存",
+ yes: "是",
+ no: "否",
+ delete: "删除",
+ delTitle: "确认要删除么?",
+ deleteSuccess: "删除成功~",
+ saveSuccess: "保存成功~",
copySuccess: "复制成功~",
article: "文章",
recommendedQuestions: "推荐题目:",
- toWriteSilently: "去默写",
- contribution:"纠错 or 贡献其他语言",
+ goForDictation: "去默写",
+ contribution: "纠错 or 贡献其他语言",
back: "返回主页",
viewSolution: "查看本题题解",
viewInHandpickCollection: "该题已被收录到精选合集《{slotText}》点击查看",
@@ -27,7 +40,7 @@ export const cn = {
tag: "标签",
},
},
- initializeContentScriptFailed:"初始化 chrome 插件 content script 失败",
+ initializeContentScriptFailed: "初始化 chrome 插件 content script 失败",
run: "运行",
submit: "提交",
wirteSolution: "写题解",
@@ -41,15 +54,16 @@ export const cn = {
savingProblem: "正在存储题目信息,请稍后~",
githubAPIError:
"使用 Github API 失败,已为您切换为普通模式,普通模式仅可自动带入题目名称,题目地址以及题解语言。",
+ notYet: "暂无",
},
problem: {
- "743": "743. 网络延迟时间",
- "1109": "1109. 航班预订统计",
- "1314": "1314. 矩阵区域和",
- "1462":"1462. 课程表 IV",
- "1480": "1480. 一维数组的动态和",
- "1584":"1584. 连接所有点的最小费用",
- "2536": "2536. 子矩阵元素加 1",
+ 743: "743. 网络延迟时间",
+ 1109: "1109. 航班预订统计",
+ 1314: "1314. 矩阵区域和",
+ 1462: "1462. 课程表 IV",
+ 1480: "1480. 一维数组的动态和",
+ 1584: "1584. 连接所有点的最小费用",
+ 2536: "2536. 子矩阵元素加 1",
},
codeTemplate: {
name: "代码模板",
@@ -69,20 +83,50 @@ export const cn = {
item4: "Kruskal(又称加边法,是一种最小生成树算法)",
item5: "Prim(又称加点法,是一种最小生成树算法)",
item6: "Kahn(基于BFS的拓扑排序)",
-
},
- moreTemplate:"更多模板后续陆续更新~"
+ moreTemplate: "更多模板后续陆续更新~",
},
dataStructureVisualization: {
name: "数据结构可视化",
+ incrementalUsage: "增量使用",
+ explain1:
+ "暂不支持编辑功能。如果需要编辑,可通过先“使用”再“保存”,最后“删除”原有的数据,从而间接实现。",
+ explain2: "模板可以增量使用。点击”去使用“的下拉三角,并选择增量使用即可。",
+ explain3:
+ "使用的模板会根据你鼠标的位置生成。比如你的鼠标在点(100, 100),那么模板会整体偏移 (100, 100)个单位。如果此时模板并不是正好以(100, 100)为左上顶点,说明模板本身制作的时候就不是以(0,0)为左上顶点制作的。大家制作自定义模板的话需要注意这一点。",
+ explain4: "你也可以选择直接使用原生 excalidraw ",
},
explanationTemplate: {
name: "题解模板",
+ goToTheWebsiteToUse: "去网站使用",
+ problemAddress: "题目地址",
+ problemDesc: "题目描述",
+ preKnowledge: "前置知识",
+ company: "公司",
+ thinking: "思路",
+ keyPoints: "关键点",
+ languageSupport: "语言支持",
+ complexityAnalysis: "复杂度分析",
+ complexityDeclare: "令 n 为数组长度。",
+ timeComplexity: "时间复杂度",
+ spaceComplexity: "空间复杂度",
+ howToUse: "如何使用?",
+ programmingLanguage: "编程语言:1",
+ commonFormulas: "常用公式(点击可复制):",
+ noBackup: "没有找到任何备份文件",
+ restore: "恢复上次编辑内容",
+ backupTips:
+ "题解每五秒备份一次,如果你不小心刷新了浏览器可以点击下方的恢复按钮还原。由于是覆盖式备份,因此仅会保存最后一次编辑的内容。",
+ afterUpdateTemplateTips: "后续考虑提供更多题解模板。",
+ afterUpdateThemeTips: "后续考虑支持更多主题,以及用户自定义主题。",
},
complexityQuickCheck: {
name: "复杂度速查",
+ tips: "不懂为什么?点这里",
+ dataScale: "数据规模",
+ timeComplexity: "算法可接受时间复杂度",
},
learningRoute: {
name: "学习路线",
@@ -94,4 +138,5 @@ export const cn = {
name: "关于我",
},
};
-export default cn;
+// export default zh;
+module.exports = zh;
diff --git a/src/roadmap/roadmap.jsx b/src/roadmap/roadmap.jsx
index 28ad061..d8deaa1 100644
--- a/src/roadmap/roadmap.jsx
+++ b/src/roadmap/roadmap.jsx
@@ -79,7 +79,7 @@ const roadmaps = {
],
code: {
language: "py",
- text: `代码参考:代码模板 - 二分法`,
+ text: "代码参考:代码模板 - 二分法",
},
keys: [
`
diff --git a/src/solutionTemplate/index.jsx b/src/solutionTemplate/index.jsx
index 61cb401..231cc36 100644
--- a/src/solutionTemplate/index.jsx
+++ b/src/solutionTemplate/index.jsx
@@ -20,6 +20,7 @@ import {
debounce,
getCloundStorage,
} from "../utils.js";
+import { t, lang } from "../locales";
import MarkdownRender from "../components/MarkdownRender";
// import AccessToken from "../components/AccessToken";
@@ -39,6 +40,22 @@ const slogan = `
![](https://p.ipic.vip/h9nm77.jpg)`;
+const sloganEn = `
+
+> This solution template is generated by the [LeetCode Solution Template](https://leetcode-pp.github.io/leetcode-cheat/?tab=solution-template) plugin.
+
+LeetCode friends can [follow me](https://leetcode-cn.com/u/fe-lucifer/) to receive my updates in real-time~
+
+That's all for the content of this article. If you have any thoughts or comments, feel free to leave a message, and I will check and respond to them when I have time. For more algorithm techniques, you can visit my LeetCode solution repository: https://github.com/azl397985856/leetcode. It has already gained 40K stars. You can also follow my WeChat official account "LeetCode Plus Plus" to tackle the hard bone of algorithms with clear and straightforward explanations, abundant illustrations, and step-by-step guidance.
+
+Follow the WeChat official account "LeetCode Plus Plus" and strive to present the solution approach in a clear and concise language, along with numerous illustrations, to help you recognize patterns and efficiently solve problems.
+
+![](https://p.ipic.vip/h9nm77.jpg)`;
+
+const getSlogan = () => {
+ return lang === "en" ? sloganEn : slogan;
+};
+
function displayLanguage(language) {
const m = {
python: "Python",
@@ -66,7 +83,7 @@ function getTemplate({
link = "",
desc = "",
pre = "",
- company = "暂无",
+ company = t("app.notYet"),
language = "python3",
code = "",
keyword = "",
@@ -75,52 +92,55 @@ function getTemplate({
isLucifer = false,
}) {
return `
-## 题目地址(${title})
+## ${t("Locale.explanationTemplate.problemAddress")}(${title})
${link}
-## 题目描述
+## ${t("Locale.explanationTemplate.problemDesc")}
${desc}
-## 前置知识
+## ${t("Locale.explanationTemplate.preKnowledge")}
- ${pre}
-## 公司
+## ${t("Locale.explanationTemplate.company")}
- ${company}
-## 思路
+## ${t("Locale.explanationTemplate.thinking")}
-## 关键点
+## ${t("Locale.explanationTemplate.keyPoints")}
- ${keyword}
-## 代码
+## Code
-- 语言支持:${displayLanguage(language)}
+- ${t("Locale.explanationTemplate.languageSupport")}:${displayLanguage(
+ language
+ )}
${displayLanguage(language)} Code:
-\`\`\`${language.toLocaleLowerCase() === "python3"
+\`\`\`${
+ language.toLocaleLowerCase() == "python3"
? "python"
: language.toLocaleLowerCase()
- }
+ }
${code}
\`\`\`
-**复杂度分析**
+**${t("Locale.explanationTemplate.complexityAnalysis")}**
-令 n 为数组长度。
+${t("Locale.explanationTemplate.complexityDeclare")}
-- 时间复杂度:$O(${time})$
-- 空间复杂度:$O(${space})$
+- ${t("Locale.explanationTemplate.timeComplexity")}:$O(${time})$
+- ${t("Locale.explanationTemplate.spaceComplexity")}:$O(${space})$
-${isLucifer ? slogan : ""}
+${isLucifer ? getSlogan() : ""}
`;
}
function Template({ onChange, template }) {
@@ -149,35 +169,36 @@ function Complexities({ value, onChange }) {
);
}
-const formulas = [
+const getFormulas = (lang) => [
{
formula: "$sum_{i=1}^{n}{a_i}$",
- name: "求和",
+ name: lang === "zh" ? "求和" : "sum",
logo: require("../imgs/formula/sum.svg"),
},
{
formula: "$a\\times b$",
- name: "乘法",
+ name: lang === "zh" ? "乘法" : "times",
logo: require("../imgs/formula/times.svg"),
},
{
formula: "$a\\div b$",
- name: "除法",
+ name: lang === "zh" ? "除法" : "div",
logo: require("../imgs/formula/div.svg"),
},
{
formula: "$\\frac{a}{b}$",
- name: "分数",
+ name: lang === "zh" ? "分数" : "frac",
+
logo: require("../imgs/formula/frac.svg"),
},
{
formula: "$a\\approx b$",
- name: "约等于",
+ name: lang === "zh" ? "约等于" : "approx",
logo: require("../imgs/formula/approx.svg"),
},
{
formula: "$\\sqrt a$",
- name: "根号",
+ name: lang === "zh" ? "根号" : "sqrt",
logo: require("../imgs/formula/sqrt.svg"),
},
{
@@ -191,7 +212,7 @@ $$
\right.
$$
`,
- name: "动态规划选择方程",
+ name: lang === "zh" ? "动态规划选择方程" : "Dynamic programming selection equation",
logo: require("../imgs/formula/choice.svg"),
},
];
@@ -309,14 +330,8 @@ export default class SolutionTemplate extends PureComponent {
});
}
render() {
- const {
- language,
- time,
- space,
- isLucifer,
- template,
- isloading,
- } = this.state;
+ const { language, time, space, isLucifer, template, isloading } =
+ this.state;
return (
<>
{/*
- 如何使用?
+ {t("Locale.explanationTemplate.howToUse")}
{!isInExtension() ? (
<>
- 编程语言:
+ {t("Locale.explanationTemplate.programmingLanguage")}:
- 常用公式(点击可复制):
- {formulas.map(({ formula, name, logo }) => {
+ {t("Locale.explanationTemplate.commonFormulas")}
+ {getFormulas(lang).map(({ formula, name, logo }) => {
return (
{
copyToClipboard(formula);
message.success({
- content: "复制成功~",
+ content: t("app.copySuccess"),
});
}}
alt={name}
@@ -390,7 +412,7 @@ export default class SolutionTemplate extends PureComponent {
})}
- 时间复杂度:
+ {t("Locale.explanationTemplate.timeComplexity")}:
{
@@ -398,15 +420,20 @@ export default class SolutionTemplate extends PureComponent {
this.setTime(v);
this.setTemplate(
template.replace(
- new RegExp(`时间复杂度:.+`, "mg"),
- `时间复杂度:$O(${v})$`
+ new RegExp(
+ `${t("Locale.explanationTemplate.timeComplexity")}:.+`,
+ "mg"
+ ),
+ `${t(
+ "Locale.explanationTemplate.timeComplexity"
+ )}:$O(${v})$`
)
);
}}
/>
- 空间复杂度:
+ {t("Locale.explanationTemplate.spaceComplexity")}:
{
@@ -414,8 +441,15 @@ export default class SolutionTemplate extends PureComponent {
this.setSpace(v);
this.setTemplate(
template.replace(
- new RegExp(`空间复杂度:.+`, "mg"),
- `空间复杂度:$O(${v})$`
+ new RegExp(
+ `${t(
+ "Locale.explanationTemplate.spaceComplexity"
+ )}:.+`,
+ "mg"
+ ),
+ `${t(
+ "Locale.explanationTemplate.spaceComplexity"
+ )}:$O(${v})$`
)
);
}}
@@ -429,15 +463,15 @@ export default class SolutionTemplate extends PureComponent {
const v = e.target.checked;
this.setIsLucifer(v);
if (v) {
- if (template.includes(slogan)) return;
- this.setTemplate(template + slogan);
+ if (template.includes(getSlogan())) return;
+ this.setTemplate(template + getSlogan());
} else {
- if (!template.includes(slogan)) return;
- this.setTemplate(template.replace(slogan, ""));
+ if (!template.includes(getSlogan())) return;
+ this.setTemplate(template.replace(getSlogan(), ""));
}
}}
>
- 是否是 lucifer
+ is lucifer
@@ -452,11 +486,11 @@ export default class SolutionTemplate extends PureComponent {
onClick={() => {
copyToClipboard(template);
message.success({
- content: "复制成功~",
+ content: t("app.copySuccess"),
});
}}
>
- 点击复制 MarkDown 原文
+ {t("app.copyMdOrigin")}
message.error({
- content: "没有找到任何备份文件",
+ content: t("Locale.explanationTemplate.noBackup"),
})
);
}}
>
- 恢复上次编辑内容
+ {t("Locale.explanationTemplate.restore")}