Port list membership actions from CoffeeScript to TypeScript

This commit is contained in:
Andreas Nedbal 2021-12-28 21:13:01 +01:00
parent 542cdd8b9a
commit d3d4644776
1 changed files with 37 additions and 0 deletions

View File

@ -0,0 +1,37 @@
import Rails from '@rails/ujs';
import I18n from '../../../legacy/i18n';
export function listMembershipHandler(event: Event): void {
const checkbox = event.target as HTMLInputElement;
const list = checkbox.dataset.list;
let memberCount = Number(document.querySelector(`span#${list}-members`).innerHTML);
checkbox.setAttribute('disabled', 'disabled');
memberCount += checkbox.checked ? 1 : -1;
Rails.ajax({
url: '/ajax/list_membership',
type: 'POST',
data: new URLSearchParams({
list: list,
user: checkbox.dataset.user,
add: String(checkbox.checked)
}).toString(),
success: (data) => {
if (data.success) {
checkbox.checked = data.checked;
document.querySelector(`span#${list}-members`).innerHTML = memberCount.toString();
}
window['showNotification'](data.message, data.success);
},
error: (data, status, xhr) => {
console.log(data, status, xhr);
window['showNotification'](I18n.translate('frontend.error.message'), false);
},
complete: () => {
checkbox.removeAttribute('disabled');
}
});
}