document references
This commit is contained in:
parent
0db8ca6c47
commit
e4316c9b44
1 changed files with 38 additions and 9 deletions
|
@ -107,7 +107,7 @@ class Document(models.Model):
|
||||||
q = Q()
|
q = Q()
|
||||||
for v in removed_values:
|
for v in removed_values:
|
||||||
q |= Q(value__iexact=v)
|
q |= Q(value__iexact=v)
|
||||||
Facet.objects.filter(document=self, key=key).filter(q).delete()
|
r = Facet.objects.filter(document=self, key=key).filter(q).delete()
|
||||||
|
|
||||||
for value in current_values:
|
for value in current_values:
|
||||||
if value.lower() not in saved_values:
|
if value.lower() not in saved_values:
|
||||||
|
@ -368,7 +368,10 @@ class Document(models.Model):
|
||||||
elif isinstance(data[key], int) or isinstance(data[key], float):
|
elif isinstance(data[key], int) or isinstance(data[key], float):
|
||||||
self.data[key] = data[key]
|
self.data[key] = data[key]
|
||||||
else:
|
else:
|
||||||
self.data[key] = ox.escape_html(data[key])
|
if data[key]:
|
||||||
|
self.data[key] = ox.escape_html(data[key])
|
||||||
|
else:
|
||||||
|
del self.data[key]
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def dimensions(self):
|
def dimensions(self):
|
||||||
|
@ -413,6 +416,7 @@ class Document(models.Model):
|
||||||
'matches',
|
'matches',
|
||||||
'size',
|
'size',
|
||||||
'user',
|
'user',
|
||||||
|
'referenced',
|
||||||
]
|
]
|
||||||
if self.extension in ('html', 'txt'):
|
if self.extension in ('html', 'txt'):
|
||||||
keys.append('text')
|
keys.append('text')
|
||||||
|
@ -442,8 +446,8 @@ class Document(models.Model):
|
||||||
entity_json = dp.entity.json(['id', 'type', 'name'])
|
entity_json = dp.entity.json(['id', 'type', 'name'])
|
||||||
entity_json['data'] = dp.data
|
entity_json['data'] = dp.data
|
||||||
entity_jsons.append(entity_json)
|
entity_jsons.append(entity_json)
|
||||||
elif key == 'items':
|
elif key == 'referenced':
|
||||||
response[key] = [i['public_id'] for i in self.items.all().values('public_id')]
|
response[key] = self.referenced()
|
||||||
elif key in self.data:
|
elif key in self.data:
|
||||||
response[key] = self.data[key]
|
response[key] = self.data[key]
|
||||||
elif hasattr(self, _map.get(key, key)):
|
elif hasattr(self, _map.get(key, key)):
|
||||||
|
@ -568,19 +572,44 @@ class Document(models.Model):
|
||||||
self.ratio = size[0] / size[1]
|
self.ratio = size[0] / size[1]
|
||||||
return self.ratio
|
return self.ratio
|
||||||
|
|
||||||
def update_matches(self):
|
def urls(self):
|
||||||
import annotation.models
|
|
||||||
import item.models
|
|
||||||
import text.models
|
|
||||||
urls = [self.get_absolute_url()]
|
urls = [self.get_absolute_url()]
|
||||||
url = unquote(urls[0])
|
url = unquote(urls[0])
|
||||||
if url != urls[0]:
|
if url != urls[0]:
|
||||||
urls.append(url)
|
urls.append(url)
|
||||||
|
return urls
|
||||||
|
|
||||||
|
def referenced(self):
|
||||||
|
import annotation.models
|
||||||
|
import item.models
|
||||||
|
result = {}
|
||||||
|
result['items'] = [i.get_json(keys=['id', 'title']) for i in self.items.all().order_by('sort__title')]
|
||||||
|
urls = self.urls()
|
||||||
|
# annotations
|
||||||
|
q = Q()
|
||||||
|
for url in urls:
|
||||||
|
q |= Q(value__contains=url)
|
||||||
|
qs = annotation.models.Annotation.objects.filter(q)
|
||||||
|
result['annotations'] = [a.json(keys=['id', 'title', 'in']) for a in qs]
|
||||||
|
# documents
|
||||||
|
q = Q()
|
||||||
|
for url in urls:
|
||||||
|
q |= Q(data__contains=url)
|
||||||
|
qs = Document.objects.filter(q)
|
||||||
|
result['documents'] = [d.json(keys=['id', 'title']) for d in qs]
|
||||||
|
|
||||||
|
result['entities'] = [e.json(keys=['id', 'name']) for e in self.entities.all()]
|
||||||
|
return result
|
||||||
|
|
||||||
|
def update_matches(self):
|
||||||
|
import annotation.models
|
||||||
|
import item.models
|
||||||
|
urls = self.urls()
|
||||||
matches = self.items.count() + self.entities.count()
|
matches = self.items.count() + self.entities.count()
|
||||||
for url in urls:
|
for url in urls:
|
||||||
matches += annotation.models.Annotation.objects.filter(value__contains=url).count()
|
matches += annotation.models.Annotation.objects.filter(value__contains=url).count()
|
||||||
matches += item.models.Item.objects.filter(data__contains=url).count()
|
matches += item.models.Item.objects.filter(data__contains=url).count()
|
||||||
matches += text.models.Text.objects.filter(text__contains=url).count()
|
matches += Document.objects.filter(extension='html', data__contains=url).count()
|
||||||
if matches != self.matches:
|
if matches != self.matches:
|
||||||
Document.objects.filter(id=self.id).update(matches=matches)
|
Document.objects.filter(id=self.id).update(matches=matches)
|
||||||
self.matches = matches
|
self.matches = matches
|
||||||
|
|
Loading…
Reference in a new issue