import os from django import forms from django.contrib import admin from django.contrib.admin.widgets import AdminFileWidget from django.contrib.gis.admin import OSMGeoAdmin from django.utils.safestring import mark_safe from django.utils.translation import ugettext_lazy as _ from django.conf import settings import markdown def markdown_to_html(txt): md = markdown.Markdown( extensions=[ 'markdown.extensions.fenced_code', 'markdown.extensions.codehilite(css_class=highlight,linenums=False)', 'markdown.extensions.attr_list', 'footnotes', 'extra' ], output_format='html5', safe_mode=False ) return md.convert(txt) class TagListFilter(admin.SimpleListFilter): # Human-readable title which will be displayed in the # right admin sidebar just above the filter options. title = _('tag') # Parameter for the filter that will be used in the URL query. parameter_name = 'tag' def lookups(self, request, model_admin): """ Returns a list of tuples. The first element in each tuple is the coded value for the option that will appear in the URL query. The second element is the human-readable name for the option that will appear in the right sidebar. """ tl = [] self.model_to_use = model_admin.model for t in self.model_to_use.tags.all().order_by('name'): tl += (t.name, t.name), return tl def queryset(self, request, queryset): """ Returns the filtered queryset based on the value provided in the query string and retrievable via `self.value()`. """ qs = self.model_to_use.objects.all() try: request.GET['tag'] return qs.filter(tags__name=self.value()) except: return qs def thumbnail(image_path): absolute_url = os.path.join(settings.IMAGES_URL, image_path[7:]) print(absolute_url) return '%s' % (absolute_url, image_path) class AdminImageWidget(AdminFileWidget): """ A FileField Widget that displays an image instead of a file path if the current file is an image. """ def render(self, name, value, attrs=None): output = [] file_name = str(value) help_text = '' if file_name: file_path = '%s' % (file_name) if attrs['id'] == 'id_thumbnail': help_text = '160 wide' if attrs['id'] == 'id_image': help_text = '205px high' output.append('%s%s' % (help_text, file_path, thumbnail(file_name))) output.append(super(AdminFileWidget, self).render(name, value, attrs)) return mark_safe(''.join(output)) class LGEntryForm(forms.ModelForm): class Meta: widgets = { 'body_markdown': forms.Textarea(attrs={'rows': 40, 'cols': 100}), } class LGEntryFormSmall(forms.ModelForm): class Meta: widgets = { 'body_markdown': forms.Textarea(attrs={'rows': 12, 'cols': 100}), } class OLAdminBase(OSMGeoAdmin): default_lon = -9285175 default_lat = 4025046 default_zoom = 15 units = True scrollable = False map_width = 700 map_height = 425 map_template = 'gis/admin/osm.html' openlayers_url = '/static/admin/js/OpenLayers.js' from bs4 import BeautifulSoup from photos.models import LuxImage from django.template.loader import render_to_string from django.template import Context def parse_image(s): soup = BeautifulSoup(s.group(), "lxml") for img in soup.find_all('img'): image_id = img['id'].split("image-")[1] i = LuxImage.objects.get(pk=image_id) cl = img['class'] caption = False exif = False cluster_class = None extra = None if cl[0] == 'cluster': css_class = cl[0] cluster_class = cl[1] try: if cl[2] == 'caption': caption = True elif cl[2] == 'exif': exif = True else: extra = cl[2] if len(cl) > 3: if cl[3] == 'exif': exif = True except: pass elif cl[0] != 'cluster' and len(cl) > 1: css_class = cl[0] if cl[1] == 'caption': caption = True if cl[1] == 'exif': exif = True elif cl[0] != 'cluster' and len(cl) > 2: css_class = cl[0] if cl[1] == 'caption': caption = True if cl[2] == 'exif': exif = True print('caption'+str(caption)) else: css_class = cl[0] c = Context({'image': i, 'caption': caption, 'exif': exif, 'cluster_class': cluster_class, 'extra':extra}) return render_to_string("lib/img_%s.html" % css_class, c) def parse_video(s): soup = BeautifulSoup(s.group(), "lxml") for vid in soup.find_all('video'): return True return False