2022-08-31 06:33:37 +05:00
|
|
|
/*
|
|
|
|
|
This file is part of the Notesnook project (https://notesnook.com/)
|
|
|
|
|
|
2023-01-16 13:44:52 +05:00
|
|
|
Copyright (C) 2023 Streetwriters (Private) Limited
|
2022-08-31 06:33:37 +05:00
|
|
|
|
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
*/
|
2022-08-30 16:13:11 +05:00
|
|
|
|
2022-06-27 18:37:12 +05:00
|
|
|
import React, { RefObject, useEffect, useRef, useState } from "react";
|
2023-02-14 12:32:25 +05:00
|
|
|
import { getTotalWords, Editor } from "@notesnook/editor";
|
2023-12-21 10:14:53 +05:00
|
|
|
import { useTabContext } from "../hooks/useTabStore";
|
2024-08-15 15:39:53 +05:00
|
|
|
import { strings } from "@notesnook/intl";
|
2022-06-23 19:14:55 +05:00
|
|
|
|
2024-03-14 10:43:25 +05:00
|
|
|
function StatusBar({
|
|
|
|
|
container,
|
|
|
|
|
loading
|
|
|
|
|
}: {
|
|
|
|
|
container: RefObject<HTMLDivElement>;
|
|
|
|
|
loading?: boolean;
|
|
|
|
|
}) {
|
2023-12-21 10:14:53 +05:00
|
|
|
const tab = useTabContext();
|
2025-09-11 15:49:00 +05:00
|
|
|
const [showChars, setShowChars] = useState(false);
|
2024-11-08 10:24:50 +05:00
|
|
|
const [words, setWords] = useState(strings.totalWords(0));
|
2022-07-25 18:38:22 +05:00
|
|
|
const currentWords = useRef(words);
|
2025-09-11 15:49:00 +05:00
|
|
|
const [chars, setChars] = useState(0);
|
2022-06-23 19:14:55 +05:00
|
|
|
const statusBar = useRef({
|
2025-09-11 15:49:00 +05:00
|
|
|
set: () => {},
|
2023-04-01 16:16:52 +05:00
|
|
|
updateWords: () => {
|
2023-12-21 10:14:53 +05:00
|
|
|
const editor = editors[tab.id];
|
2023-12-22 08:23:42 +05:00
|
|
|
if (!editor) return;
|
2024-11-08 10:24:50 +05:00
|
|
|
const words = strings.totalWords(getTotalWords(editor as Editor));
|
2023-04-01 16:16:52 +05:00
|
|
|
if (currentWords.current === words) return;
|
|
|
|
|
setWords(words);
|
2024-02-15 10:30:07 +05:00
|
|
|
},
|
|
|
|
|
resetWords: () => {
|
2024-11-08 10:24:50 +05:00
|
|
|
currentWords.current = strings.totalWords(0);
|
|
|
|
|
setWords(currentWords.current);
|
2023-04-01 16:16:52 +05:00
|
|
|
}
|
2022-06-23 19:14:55 +05:00
|
|
|
});
|
2023-12-21 10:14:53 +05:00
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
|
globalThis.statusBars[tab.id] = statusBar;
|
2025-09-11 15:49:00 +05:00
|
|
|
if (showChars) {
|
|
|
|
|
editors[tab.id]?.on("selectionUpdate", (event) => {
|
|
|
|
|
setChars(event.editor.extensionStorage.characterCount.characters());
|
|
|
|
|
});
|
2022-07-25 12:07:01 +05:00
|
|
|
}
|
2025-09-11 15:49:00 +05:00
|
|
|
if (editors[tab.id]) {
|
|
|
|
|
setChars(
|
|
|
|
|
editors[tab.id]?.extensionStorage.characterCount.characters() || 0
|
|
|
|
|
);
|
2024-11-06 13:14:14 +05:00
|
|
|
}
|
|
|
|
|
|
2025-09-11 15:49:00 +05:00
|
|
|
return () => {
|
|
|
|
|
globalThis.statusBars[tab.id] = undefined;
|
|
|
|
|
};
|
|
|
|
|
}, [tab.id, statusBar, showChars]);
|
2022-06-27 18:37:12 +05:00
|
|
|
|
2022-07-25 18:38:22 +05:00
|
|
|
useEffect(() => {
|
|
|
|
|
currentWords.current = words;
|
|
|
|
|
}, [words]);
|
|
|
|
|
|
2023-01-16 13:44:52 +05:00
|
|
|
const paragraphStyle: React.CSSProperties = {
|
2022-06-23 19:14:55 +05:00
|
|
|
marginTop: 0,
|
|
|
|
|
marginBottom: 0,
|
2025-09-11 15:49:00 +05:00
|
|
|
fontSize: 12,
|
2023-08-01 12:07:21 +05:00
|
|
|
color: "var(--nn_secondary_paragraph)",
|
2022-09-16 16:01:45 +05:00
|
|
|
paddingBottom: 0,
|
2025-10-23 21:58:27 +05:00
|
|
|
fontFamily: "Inter",
|
2025-09-11 15:49:00 +05:00
|
|
|
userSelect: "none"
|
2022-06-23 19:14:55 +05:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
return (
|
2025-10-23 21:58:27 +05:00
|
|
|
<p
|
|
|
|
|
onMouseDown={(e) => {
|
|
|
|
|
setShowChars(!showChars);
|
2022-06-23 19:14:55 +05:00
|
|
|
}}
|
2025-10-23 21:58:27 +05:00
|
|
|
style={paragraphStyle}
|
2022-06-23 19:14:55 +05:00
|
|
|
>
|
2025-10-23 21:58:27 +05:00
|
|
|
{showChars ? strings.charactersCount(chars) : words}
|
|
|
|
|
</p>
|
2022-06-23 19:14:55 +05:00
|
|
|
);
|
|
|
|
|
}
|
2022-07-25 18:38:22 +05:00
|
|
|
|
2024-03-14 10:43:25 +05:00
|
|
|
export default React.memo(
|
|
|
|
|
StatusBar,
|
|
|
|
|
(prev, next) => prev.loading === next.loading
|
|
|
|
|
);
|