mirror of
https://github.com/monkeytypegame/monkeytype.git
synced 2025-09-22 14:37:59 +08:00
added caret module. part of #495
This commit is contained in:
parent
63558bef5d
commit
aa10658ae5
3 changed files with 130 additions and 0 deletions
|
@ -103,6 +103,7 @@ const refactoredSrc = [
|
|||
"./src/js/test/out-of-focus.js",
|
||||
"./src/js/chart-controller.js",
|
||||
"./src/js/theme-controller.js",
|
||||
"./src/js/test/caret.js",
|
||||
];
|
||||
|
||||
//legacy files
|
||||
|
|
|
@ -31,3 +31,4 @@ import * as ThemeColors from "./theme-colors";
|
|||
import * as OutOfFocus from "./out-of-focus";
|
||||
import * as ChartController from "./chart-controller";
|
||||
import * as ThemeController from "./theme-controller";
|
||||
import * as Caret from "./caret";
|
||||
|
|
128
src/js/test/caret.js
Normal file
128
src/js/test/caret.js
Normal file
|
@ -0,0 +1,128 @@
|
|||
import * as Misc from "./misc";
|
||||
|
||||
export let caretAnimating = true;
|
||||
|
||||
export function stopAnimation() {
|
||||
if (caretAnimating === true) {
|
||||
$("#caret").css("animation-name", "none");
|
||||
$("#caret").css("opacity", "1");
|
||||
caretAnimating = false;
|
||||
}
|
||||
}
|
||||
|
||||
//TODO remove config when module
|
||||
export function startAnimation(config) {
|
||||
if (caretAnimating === false) {
|
||||
if (config.smoothCaret) {
|
||||
$("#caret").css("animation-name", "caretFlashSmooth");
|
||||
} else {
|
||||
$("#caret").css("animation-name", "caretFlashHard");
|
||||
}
|
||||
caretAnimating = true;
|
||||
}
|
||||
}
|
||||
|
||||
export function hide() {
|
||||
$("#caret").addClass("hidden");
|
||||
}
|
||||
|
||||
export function show(config) {
|
||||
if ($("#result").hasClass("hidden")) {
|
||||
updatePosition("", config);
|
||||
$("#caret").removeClass("hidden");
|
||||
startAnimation(config);
|
||||
}
|
||||
}
|
||||
|
||||
//TODO remove this after test logic is a module
|
||||
//TODO remove config when module
|
||||
export function updatePosition(currentInput, config) {
|
||||
if ($("#wordsWrapper").hasClass("hidden")) return;
|
||||
if ($("#caret").hasClass("off")) {
|
||||
return;
|
||||
}
|
||||
|
||||
let caret = $("#caret");
|
||||
|
||||
let inputLen = currentInput.length;
|
||||
let currentLetterIndex = inputLen - 1;
|
||||
if (currentLetterIndex == -1) {
|
||||
currentLetterIndex = 0;
|
||||
}
|
||||
try {
|
||||
//insert temporary character so the caret will work in zen mode
|
||||
let activeWordEmpty = $("#words .active").children().length == 0;
|
||||
if (activeWordEmpty) {
|
||||
$("#words .active").append('<letter style="opacity: 0;">_</letter>');
|
||||
}
|
||||
|
||||
let currentWordNodeList = document
|
||||
.querySelector("#words .active")
|
||||
.querySelectorAll("letter");
|
||||
let currentLetter = currentWordNodeList[currentLetterIndex];
|
||||
if (inputLen > currentWordNodeList.length) {
|
||||
currentLetter = currentWordNodeList[currentWordNodeList.length - 1];
|
||||
}
|
||||
|
||||
if (config.mode != "zen" && $(currentLetter).length == 0) return;
|
||||
const isLanguageLeftToRight = Misc.getCurrentLanguage().leftToRight;
|
||||
let currentLetterPosLeft = isLanguageLeftToRight
|
||||
? currentLetter.offsetLeft
|
||||
: currentLetter.offsetLeft + $(currentLetter).width();
|
||||
let currentLetterPosTop = currentLetter.offsetTop;
|
||||
let letterHeight = $(currentLetter).height();
|
||||
let newTop = 0;
|
||||
let newLeft = 0;
|
||||
|
||||
newTop = currentLetterPosTop - Math.round(letterHeight / 5);
|
||||
if (inputLen == 0) {
|
||||
newLeft = isLanguageLeftToRight
|
||||
? currentLetterPosLeft - caret.width() / 2
|
||||
: currentLetterPosLeft + caret.width() / 2;
|
||||
} else {
|
||||
newLeft = isLanguageLeftToRight
|
||||
? currentLetterPosLeft + $(currentLetter).width() - caret.width() / 2
|
||||
: currentLetterPosLeft - $(currentLetter).width() + caret.width() / 2;
|
||||
}
|
||||
|
||||
let smoothlinescroll = $("#words .smoothScroller").height();
|
||||
if (smoothlinescroll === undefined) smoothlinescroll = 0;
|
||||
|
||||
if (config.smoothCaret) {
|
||||
caret.stop(true, false).animate(
|
||||
{
|
||||
top: newTop - smoothlinescroll,
|
||||
left: newLeft,
|
||||
},
|
||||
100
|
||||
);
|
||||
} else {
|
||||
caret.stop(true, true).animate(
|
||||
{
|
||||
top: newTop - smoothlinescroll,
|
||||
left: newLeft,
|
||||
},
|
||||
0
|
||||
);
|
||||
}
|
||||
|
||||
if (config.showAllLines) {
|
||||
let browserHeight = window.innerHeight;
|
||||
let middlePos = browserHeight / 2 - $("#caret").outerHeight() / 2;
|
||||
let contentHeight = document.body.scrollHeight;
|
||||
|
||||
if (newTop >= middlePos && contentHeight > browserHeight) {
|
||||
window.scrollTo({
|
||||
left: 0,
|
||||
top: newTop - middlePos,
|
||||
behavior: "smooth",
|
||||
});
|
||||
}
|
||||
}
|
||||
if (activeWordEmpty) {
|
||||
$("#words .active").children().remove();
|
||||
}
|
||||
} catch (e) {
|
||||
console.log("could not move caret: " + e.message);
|
||||
}
|
||||
}
|
Loading…
Add table
Reference in a new issue