Skip to content

Commit

Permalink
Mark changed words
Browse files Browse the repository at this point in the history
  • Loading branch information
danny0838 committed Apr 20, 2024
1 parent 36740c5 commit d96ff57
Show file tree
Hide file tree
Showing 4 changed files with 59 additions and 8 deletions.
26 changes: 25 additions & 1 deletion sts/data/htmlpage.tpl.html
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
#viewer a { border: thin dotted #AAA; color: unset; text-decoration: none; }
#viewer a:focus { outline: medium solid blue; }
#viewer a.single, .single { background-color: #DDDDDD; } /* 單選字 */
#viewer a.changed, .changed { background-color: #DDDDFF; } /* 異動字 */
#viewer a.unchecked, .unchecked { background-color: #FFFF99; } /* 未審字 */
#viewer a.checked, .checked { background-color: #CCFFFF; } /* 已審字 */
#viewer a.picked, .picked { background-color: #CCFFCC; } /* 選定字 */
Expand Down Expand Up @@ -272,6 +273,16 @@
anchorNew.focus();
}

function moveToChanged(anchor, offset) {
const anchorNew = moveAnchor(anchor, offset, a => {
return a.matches('.changed');
});
if (!anchorNew) {
return;
}
anchorNew.focus();
}

function moveToAny(anchor, offset) {
const anchorNew = moveAnchor(anchor, offset);
if (!anchorNew) {
Expand Down Expand Up @@ -365,6 +376,8 @@
"moveToCheckworthyForward": "移至下一個待校字",
"moveToSameBackward": "移至上一個相同字",
"moveToSameForward": "移至下一個相同字",
"moveToChangedBackward": "移至上一個異動字",
"moveToChangedForward": "移至下一個異動字",
"moveToAnyBackward": "移至上一個字",
"moveToAnyForward": "移至下一個字",

Expand Down Expand Up @@ -447,6 +460,12 @@
case "moveToSameForward":
moveToSame(anchor, 1);
break;
case "moveToChangedBackward":
moveToChanged(anchor, -1);
break;
case "moveToChangedForward":
moveToChanged(anchor, 1);
break;
case "moveToAnyBackward":
moveToAny(anchor, -1);
break;
Expand Down Expand Up @@ -648,8 +667,12 @@
elem.removeAttribute('atomic');
elem.classList.add('atomic');
}
const cls = (atomic && elem.querySelectorAll('ins').length <= 1) ? 'single' : 'unchecked';
const insElems = elem.querySelectorAll('ins');
const cls = (atomic && insElems.length <= 1) ? 'single' : 'unchecked';
elem.classList.add(cls);
if (insElems[0] && elem.querySelector('del').textContent !== insElems[0].textContent) {
elem.classList.add('changed');
}
}

const target = viewer.querySelector('a.unchecked');
Expand Down Expand Up @@ -678,6 +701,7 @@
<h3>上色標示說明</h3>
<ul>
<li><span class="single">灰色</span>:單選字。只有單一選項的字。</li>
<li><span class="changed">紫色</span>:異動字。轉換後與轉換前不同的字。</li>
<li><span class="unchecked">黃色</span>:未審字。未檢查的字。</li>
<li><span class="checked">藍色</span>:已審字。已檢查的字(未修改)。</li>
<li><span class="picked">綠色</span>:已選字。已修改的字。</li>
Expand Down
1 change: 1 addition & 0 deletions sts/data/htmlpage/index.css
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ body > footer { margin-top: 1em; text-align: center; font-size: small; }
#viewer a { border: thin dotted #AAA; color: unset; text-decoration: none; }
#viewer a:focus { outline: medium solid blue; }
#viewer a.single, .single { background-color: #DDDDDD; } /* 單選字 */
#viewer a.changed, .changed { background-color: #DDDDFF; } /* 異動字 */
#viewer a.unchecked, .unchecked { background-color: #FFFF99; } /* 未審字 */
#viewer a.checked, .checked { background-color: #CCFFFF; } /* 已審字 */
#viewer a.picked, .picked { background-color: #CCFFCC; } /* 選定字 */
Expand Down
1 change: 1 addition & 0 deletions sts/data/htmlpage/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -128,6 +128,7 @@
<h3>上色標示說明</h3>
<ul>
<li><span class="single">灰色</span>:單選字。只有單一選項的字。</li>
<li><span class="changed">紫色</span>:異動字。轉換後與轉換前不同的字。</li>
<li><span class="unchecked">黃色</span>:未審字。未檢查的字。</li>
<li><span class="checked">藍色</span>:已審字。已檢查的字(未修改)。</li>
<li><span class="picked">綠色</span>:已選字。已修改的字。</li>
Expand Down
39 changes: 32 additions & 7 deletions sts/data/htmlpage/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -230,6 +230,16 @@ function moveToSame(anchor, offset) {
anchorNew.focus();
}

function moveToChanged(anchor, offset) {
const anchorNew = moveAnchor(anchor, offset, a => {
return a.matches('.changed');
});
if (!anchorNew) {
return;
}
anchorNew.focus();
}

function moveToAny(anchor, offset) {
const anchorNew = moveAnchor(anchor, offset);
if (!anchorNew) {
Expand Down Expand Up @@ -323,6 +333,8 @@ async function runCommand(anchor, cmd) {
"moveToCheckworthyForward": "移至下一個待校字",
"moveToSameBackward": "移至上一個相同字",
"moveToSameForward": "移至下一個相同字",
"moveToChangedBackward": "移至上一個異動字",
"moveToChangedForward": "移至下一個異動字",
"moveToAnyBackward": "移至上一個字",
"moveToAnyForward": "移至下一個字",

Expand Down Expand Up @@ -405,6 +417,12 @@ async function runCommand(anchor, cmd) {
case "moveToSameForward":
moveToSame(anchor, 1);
break;
case "moveToChangedBackward":
moveToChanged(anchor, -1);
break;
case "moveToChangedForward":
moveToChanged(anchor, 1);
break;
case "moveToAnyBackward":
moveToAny(anchor, -1);
break;
Expand Down Expand Up @@ -606,8 +624,12 @@ document.addEventListener('DOMContentLoaded', (event) => {
elem.removeAttribute('atomic');
elem.classList.add('atomic');
}
const cls = (atomic && elem.querySelectorAll('ins').length <= 1) ? 'single' : 'unchecked';
const insElems = elem.querySelectorAll('ins');
const cls = (atomic && insElems.length <= 1) ? 'single' : 'unchecked';
elem.classList.add(cls);
if (insElems[0] && elem.querySelector('del').textContent !== insElems[0].textContent) {
elem.classList.add('changed');
}
}

const target = viewer.querySelector('a.unchecked');
Expand Down Expand Up @@ -681,12 +703,15 @@ async function convertHtml(text, mode, exclude) {
}

const atomic = part.key.length === 1;
const cls = (atomic && part.values.length <= 1) ? 'single' : 'unchecked';

result.push(`<a tabindex=0 class=${cls}>`);
result.push(`<del hidden>${escapeHtml(part.key.join(''))}</del>`);
for (let i = 0, I = part.values.length; i < I; i++) {
const value = part.values[i];
const cls = [(atomic && part.values.length <= 1) ? 'single' : 'unchecked'];
const key = part.key.join('');
const values = part.values;
if (values.length && key !== values[0]) { cls.push('changed'); }

result.push(`<a tabindex=0 class="${cls.join(' ')}">`);
result.push(`<del hidden>${escapeHtml(key)}</del>`);
for (let i = 0, I = values.length; i < I; i++) {
const value = values[i];
result.push(`<ins${i === 0 ? '' : ' hidden'}>${escapeHtml(value)}</ins>`);
}
result.push(`</a>`);
Expand Down

0 comments on commit d96ff57

Please sign in to comment.