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.
150 lines
3.7 KiB
150 lines
3.7 KiB
<template>
|
|
<v-content>
|
|
<v-container fluid>
|
|
<v-row justify="center">
|
|
<v-col cols="12" md="9">
|
|
<v-card>
|
|
<v-card-text class="title">
|
|
<entity-item-box
|
|
:labels="items"
|
|
:text="currentDoc.text"
|
|
:entities="currentDoc.annotations"
|
|
:delete-annotation="removeEntity"
|
|
:update-entity="updateEntity"
|
|
:add-entity="addEntity"
|
|
/>
|
|
</v-card-text>
|
|
</v-card>
|
|
</v-col>
|
|
<v-col cols="12" md="3">
|
|
<metadata-box :metadata="JSON.parse(currentDoc.meta)" />
|
|
</v-col>
|
|
</v-row>
|
|
</v-container>
|
|
</v-content>
|
|
</template>
|
|
|
|
<script>
|
|
import EntityItemBox from '~/components/organisms/annotation/EntityItemBox'
|
|
import MetadataBox from '@/components/organisms/annotation/MetadataBox'
|
|
|
|
export default {
|
|
layout: 'demo',
|
|
|
|
components: {
|
|
EntityItemBox,
|
|
MetadataBox
|
|
},
|
|
|
|
data() {
|
|
return {
|
|
items: [
|
|
{
|
|
id: 4,
|
|
text: 'LOC',
|
|
prefix_key: null,
|
|
suffix_key: 'l',
|
|
background_color: '#7c20e0',
|
|
text_color: '#ffffff'
|
|
},
|
|
{
|
|
id: 5,
|
|
text: 'MISC',
|
|
prefix_key: null,
|
|
suffix_key: 'm',
|
|
background_color: '#fbb028',
|
|
text_color: '#000000'
|
|
},
|
|
{
|
|
id: 6,
|
|
text: 'ORG',
|
|
prefix_key: null,
|
|
suffix_key: 'o',
|
|
background_color: '#e6d176',
|
|
text_color: '#000000'
|
|
},
|
|
{
|
|
id: 7,
|
|
text: 'PER',
|
|
prefix_key: null,
|
|
suffix_key: 'p',
|
|
background_color: '#6a74b9',
|
|
text_color: '#ffffff'
|
|
}
|
|
],
|
|
currentDoc: {
|
|
id: 8,
|
|
text: 'After bowling Somerset out for 83 on the opening morning at Grace Road , Leicestershire extended their first innings by 94 runs before being bowled out for 296 with England discard Andy Caddick taking three for 83 .',
|
|
annotations: [
|
|
{
|
|
id: 17,
|
|
prob: 0.0,
|
|
label: 4,
|
|
start_offset: 60,
|
|
end_offset: 70,
|
|
user: 1,
|
|
document: 8
|
|
},
|
|
{
|
|
id: 19,
|
|
prob: 0.0,
|
|
label: 4,
|
|
start_offset: 165,
|
|
end_offset: 172,
|
|
user: 1,
|
|
document: 8
|
|
},
|
|
{
|
|
id: 16,
|
|
prob: 0.0,
|
|
label: 6,
|
|
start_offset: 14,
|
|
end_offset: 22,
|
|
user: 1,
|
|
document: 8
|
|
},
|
|
{
|
|
id: 18,
|
|
prob: 0.0,
|
|
label: 6,
|
|
start_offset: 73,
|
|
end_offset: 87,
|
|
user: 1,
|
|
document: 8
|
|
},
|
|
{
|
|
id: 20,
|
|
prob: 0.0,
|
|
label: 7,
|
|
start_offset: 181,
|
|
end_offset: 193,
|
|
user: 1,
|
|
document: 8
|
|
}
|
|
],
|
|
meta: '{"wikiPageId":2}',
|
|
annotation_approver: null
|
|
}
|
|
}
|
|
},
|
|
|
|
methods: {
|
|
removeEntity(annotationId) {
|
|
this.currentDoc.annotations = this.currentDoc.annotations.filter(item => item.id !== annotationId)
|
|
},
|
|
updateEntity(labelId, annotationId) {
|
|
const index = this.currentDoc.annotations.findIndex(item => item.id === annotationId)
|
|
this.currentDoc.annotations[index].label = labelId
|
|
},
|
|
addEntity(startOffset, endOffset, labelId) {
|
|
const payload = {
|
|
id: Math.floor(Math.random() * Math.floor(Number.MAX_SAFE_INTEGER)),
|
|
start_offset: startOffset,
|
|
end_offset: endOffset,
|
|
label: labelId
|
|
}
|
|
this.currentDoc.annotations.push(payload)
|
|
}
|
|
}
|
|
}
|
|
</script>
|