gitlab-org--gitlab-foss/app/assets/javascripts/task_list.js

82 lines
2.1 KiB
JavaScript
Raw Normal View History

import $ from 'jquery';
import 'deckar01-task_list';
2018-02-02 11:26:08 +00:00
import axios from './lib/utils/axios_utils';
import Flash from './flash';
export default class TaskList {
constructor(options = {}) {
this.selector = options.selector;
this.dataType = options.dataType;
this.fieldName = options.fieldName;
this.lockVersion = options.lockVersion;
2017-02-08 10:54:33 +00:00
this.onSuccess = options.onSuccess || (() => {});
this.onError = options.onError || function showFlash(e) {
let errorMessages = '';
if (e.response.data && typeof e.response.data === 'object') {
errorMessages = e.response.data.errors.join(' ');
}
return new Flash(errorMessages || 'Update failed', 'alert');
};
this.init();
}
init() {
// Prevent duplicate event bindings
this.disable();
2017-02-08 08:10:04 +00:00
$(`${this.selector} .js-task-list-container`).taskList('enable');
$(document).on(
'tasklist:changed',
`${this.selector} .js-task-list-container`,
this.update.bind(this),
);
}
disableTaskListItems() {
2017-02-08 08:10:04 +00:00
$(`${this.selector} .js-task-list-container`).taskList('disable');
}
enableTaskListItems() {
$(`${this.selector} .js-task-list-container`).taskList('enable');
}
disable() {
this.disableTaskListItems();
2017-02-09 22:14:21 +00:00
$(document).off('tasklist:changed', `${this.selector} .js-task-list-container`);
}
update(e) {
const $target = $(e.target);
const { lineNumber, lineSource, checked } = e.detail;
2017-02-08 08:10:04 +00:00
const patchData = {};
2019-01-18 00:52:22 +00:00
patchData[this.dataType] = {
[this.fieldName]: $target.val(),
lock_version: this.lockVersion,
2019-01-18 00:52:22 +00:00
update_task: {
line_number: lineNumber,
line_source: lineSource,
checked: checked,
2019-01-18 00:52:22 +00:00
},
};
2018-02-02 11:26:08 +00:00
this.disableTaskListItems();
return axios
.patch($target.data('updateUrl') || $('form.js-issuable-update').attr('action'), patchData)
2019-01-16 00:33:58 +00:00
.then(({ data }) => {
this.lockVersion = data.lock_version;
this.enableTaskListItems();
2019-01-16 00:33:58 +00:00
return this.onSuccess(data);
})
.catch(({ response }) => {
this.enableTaskListItems();
return this.onError(response.data);
});
}
}