Fixed setting of wrong position (#16148)

tokarchuk/v1.17
KN4CK3R 3 years ago committed by GitHub
parent 15fbf23d13
commit 68503bfae6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 16
      web_src/js/markup/tasklist.js

@ -14,7 +14,10 @@ export function initMarkupTasklist() {
const checkboxes = el.querySelectorAll(`.task-list-item input[type=checkbox]`); const checkboxes = el.querySelectorAll(`.task-list-item input[type=checkbox]`);
for (const checkbox of checkboxes) { for (const checkbox of checkboxes) {
if (checkbox.dataset.editable) return; if (checkbox.dataset.editable) {
return;
}
checkbox.dataset.editable = 'true'; checkbox.dataset.editable = 'true';
checkbox.addEventListener('input', async () => { checkbox.addEventListener('input', async () => {
const checkboxCharacter = checkbox.checked ? 'x' : ' '; const checkboxCharacter = checkbox.checked ? 'x' : ' ';
@ -22,8 +25,15 @@ export function initMarkupTasklist() {
const rawContent = container.querySelector('.raw-content'); const rawContent = container.querySelector('.raw-content');
const oldContent = rawContent.textContent; const oldContent = rawContent.textContent;
const newContent = oldContent.substring(0, position) + checkboxCharacter + oldContent.substring(position + 1);
if (newContent === oldContent) return; const encoder = new TextEncoder();
const buffer = encoder.encode(oldContent);
buffer.set(encoder.encode(checkboxCharacter), position);
const newContent = new TextDecoder().decode(buffer);
if (newContent === oldContent) {
return;
}
// Prevent further inputs until the request is done. This does not use the // Prevent further inputs until the request is done. This does not use the
// `disabled` attribute because it causes the border to flash on click. // `disabled` attribute because it causes the border to flash on click.

Loading…
Cancel
Save