mirror of https://github.com/doccano/doccano.git
pythondatasetsactive-learningtext-annotationdatasetnatural-language-processingdata-labelingmachine-learningannotation-tool
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
75 lines
1.7 KiB
75 lines
1.7 KiB
import Vue from 'vue';
|
|
import annotationMixin from './mixin';
|
|
import HTTP from './http';
|
|
|
|
Vue.use(require('vue-shortkey'));
|
|
|
|
|
|
const vm = new Vue({
|
|
el: '#mail-app',
|
|
delimiters: ['[[', ']]'],
|
|
data: {
|
|
newTodo: '',
|
|
editedTodo: null,
|
|
},
|
|
mixins: [annotationMixin],
|
|
directives: {
|
|
'todo-focus': function(el, binding) {
|
|
if (binding.value) {
|
|
el.focus();
|
|
}
|
|
},
|
|
},
|
|
|
|
methods: {
|
|
addTodo() {
|
|
const value = this.newTodo && this.newTodo.trim();
|
|
if (!value) {
|
|
return;
|
|
}
|
|
|
|
const docId = this.docs[this.pageNumber].id;
|
|
const payload = {
|
|
text: value,
|
|
};
|
|
HTTP.post(`docs/${docId}/annotations/`, payload).then((response) => {
|
|
this.annotations[this.pageNumber].push(response.data);
|
|
});
|
|
|
|
this.newTodo = '';
|
|
},
|
|
|
|
removeTodo(todo) {
|
|
const docId = this.docs[this.pageNumber].id;
|
|
HTTP.delete(`docs/${docId}/annotations/${todo.id}`).then((response) => {
|
|
const index = this.annotations[this.pageNumber].indexOf(todo);
|
|
this.annotations[this.pageNumber].splice(index, 1);
|
|
});
|
|
},
|
|
|
|
editTodo(todo) {
|
|
this.beforeEditCache = todo.text;
|
|
this.editedTodo = todo;
|
|
},
|
|
|
|
doneEdit(todo) {
|
|
if (!this.editedTodo) {
|
|
return;
|
|
}
|
|
this.editedTodo = null;
|
|
todo.text = todo.text.trim();
|
|
if (!todo.text) {
|
|
this.removeTodo(todo);
|
|
}
|
|
const docId = this.docs[this.pageNumber].id;
|
|
HTTP.put(`docs/${docId}/annotations/${todo.id}`, todo).then((response) => {
|
|
console.log(response);
|
|
});
|
|
},
|
|
|
|
cancelEdit(todo) {
|
|
this.editedTodo = null;
|
|
todo.text = this.beforeEditCache;
|
|
},
|
|
},
|
|
});
|