diff options
| -rw-r--r-- | chimere/admin.py | 7 | ||||
| -rw-r--r-- | chimere/fixtures/initial_data.json | 91 | ||||
| -rw-r--r-- | chimere/forms.py | 30 | ||||
| -rw-r--r-- | chimere/migrations/0030_auto__add_multimediaextension.py | 237 | ||||
| -rw-r--r-- | chimere/models.py | 19 | ||||
| -rw-r--r-- | chimere/templates/chimere/blocks/alternate_multimedia.html | 29 | ||||
| -rw-r--r-- | chimere/templatetags/chimere_tags.py | 5 | 
7 files changed, 397 insertions, 21 deletions
| diff --git a/chimere/admin.py b/chimere/admin.py index fe1912c..92e971d 100644 --- a/chimere/admin.py +++ b/chimere/admin.py @@ -39,7 +39,7 @@ from chimere.forms import MarkerAdminForm, RouteAdminForm, AreaAdminForm,\  from chimere.models import Category, Icon, SubCategory, Marker, \       PropertyModel, News, Route, Area, ColorTheme, Color, RouteFile,\       MultimediaType, MultimediaFile, PictureFile, Importer, Layer, AreaLayers,\ -     PropertyModelChoice +     PropertyModelChoice, MultimediaExtension  from chimere.utils import unicode_normalize, ShapefileManager, KMLManager  from chimere.widgets import TextareaWidget @@ -226,6 +226,10 @@ class IconAdmin(admin.ModelAdmin):  class RouteFileAdmin(admin.ModelAdmin):      list_display = ['name', 'file_type'] +class MultimediaExtensionAdmin(admin.ModelAdmin): +    list_display = ('name', 'multimedia_type') +    list_filter = ('multimedia_type',) +  class MultimediaTypeAdmin(admin.ModelAdmin):      search_fields = ("name",)      list_display = ('name', 'media_type', 'mime_type', 'iframe', 'available') @@ -258,6 +262,7 @@ admin.site.register(Route, RouteAdmin)  admin.site.register(PropertyModel, PropertyModelAdmin)  admin.site.register(Area, AreaAdmin)  admin.site.register(ColorTheme, ColorThemeAdmin) +admin.site.register(MultimediaExtension, MultimediaExtensionAdmin)  admin.site.register(MultimediaType, MultimediaTypeAdmin)  admin.site.register(MultimediaFile, MultimediaFileAdmin)  admin.site.register(PictureFile, PictureFileAdmin) diff --git a/chimere/fixtures/initial_data.json b/chimere/fixtures/initial_data.json index 4a987db..c0b118f 100644 --- a/chimere/fixtures/initial_data.json +++ b/chimere/fixtures/initial_data.json @@ -199,6 +199,97 @@          }      },      { +        "pk": 16, +        "model": "chimere.multimediatype", +        "fields": { +            "available": false, +            "media_type": "O", +            "iframe": false, +            "name": "auto", +            "mime_type": "" +        } +    }, +    { +        "pk": 1, +        "model": "chimere.multimediaextension", +        "fields": { +            "multimedia_type": 7, +            "name": "mkv" +        } +    }, +    { +        "pk": 3, +        "model": "chimere.multimediaextension", +        "fields": { +            "multimedia_type": 2, +            "name": "mp3" +        } +    }, +    { +        "pk": 4, +        "model": "chimere.multimediaextension", +        "fields": { +            "multimedia_type": 3, +            "name": "ogg" +        } +    }, +    { +        "pk": 5, +        "model": "chimere.multimediaextension", +        "fields": { +            "multimedia_type": 5, +            "name": "mp4" +        } +    }, +    { +        "pk": 6, +        "model": "chimere.multimediaextension", +        "fields": { +            "multimedia_type": 4, +            "name": "mpg" +        } +    }, +    { +        "pk": 7, +        "model": "chimere.multimediaextension", +        "fields": { +            "multimedia_type": 4, +            "name": "mpeg" +        } +    }, +    { +        "pk": 8, +        "model": "chimere.multimediaextension", +        "fields": { +            "multimedia_type": 8, +            "name": "avi" +        } +    }, +    { +        "pk": 9, +        "model": "chimere.multimediaextension", +        "fields": { +            "multimedia_type": 6, +            "name": "ogm" +        } +    }, +    { +        "pk": 10, +        "model": "chimere.multimediaextension", +        "fields": { +            "multimedia_type": 6, +            "name": "ogv" +        } +    }, +    { +        "pk": 11, +        "model": "chimere.multimediaextension", +        "fields": { +            "multimedia_type": 13, +            "name": "webm" +        } +    } +    {          "pk": 1,          "model": "chimere.layer",          "fields": { diff --git a/chimere/forms.py b/chimere/forms.py index 985e2ca..db1719a 100644 --- a/chimere/forms.py +++ b/chimere/forms.py @@ -32,8 +32,8 @@ from django.contrib.admin.widgets import AdminDateWidget  from django.core.mail import EmailMessage, BadHeaderError  from chimere.models import Marker, Route, PropertyModel, Property, Area,\ -     News, Category, SubCategory, RouteFile, MultimediaFile, MultimediaType, \ -     PictureFile, Importer, PropertyModelChoice +   News, Category, SubCategory, RouteFile, MultimediaFile, MultimediaType, \ +   PictureFile, Importer, PropertyModelChoice, IFRAME_LINKS, MultimediaExtension  from chimere.widgets import AreaField, PointField, TextareaWidget, \                              DatePickerWidget, ButtonSelectWidget, NominatimWidget @@ -386,7 +386,31 @@ class MultimediaFileForm(BaseFileForm):      def __init__(self, *args, **kwargs):          super(MultimediaFileForm, self).__init__(*args, **kwargs)          self.fields['multimedia_type'].widget.choices = \ -                                              MultimediaType.get_tuples() +                                                MultimediaType.get_tuples() + +    def clean(self): +        if not self.cleaned_data.get('multimedia_type') or\ +           not self.cleaned_data.get('url'): +            return self.cleaned_data +        if self.cleaned_data['multimedia_type'].name != 'auto': +            return self.cleaned_data +        url = self.cleaned_data['url'] +        for mm_type in IFRAME_LINKS: +            res, embeded_url = IFRAME_LINKS[mm_type] +            if [r for r in res if r.search(url)]: +                multimedia_type = MultimediaType.objects.get( +                                    name__iexact=mm_type) +                self.cleaned_data['multimedia_type'] = multimedia_type +                return self.cleaned_data +        ext = url.split(".")[-1] +        q = MultimediaExtension.objects.filter(name__iendswith=ext) +        if q.count(): +            self.cleaned_data['multimedia_type'] = q.all()[0].multimedia_type +        else: +            # default to an iframe +            self.cleaned_data['multimedia_type'] = \ +                MultimediaType.objects.filter(name__iexact='iframe').all()[0] +        return self.cleaned_data  MultimediaFileFormSet = formset_factory(MultimediaFileForm, can_delete=True) diff --git a/chimere/migrations/0030_auto__add_multimediaextension.py b/chimere/migrations/0030_auto__add_multimediaextension.py new file mode 100644 index 0000000..47888c4 --- /dev/null +++ b/chimere/migrations/0030_auto__add_multimediaextension.py @@ -0,0 +1,237 @@ +# -*- coding: utf-8 -*- +import datetime +from south.db import db +from south.v2 import SchemaMigration +from django.db import models + + +class Migration(SchemaMigration): + +    def forwards(self, orm): +        # Adding model 'MultimediaExtension' +        db.create_table('chimere_multimediaextension', ( +            ('id', self.gf('django.db.models.fields.AutoField')(primary_key=True)), +            ('name', self.gf('django.db.models.fields.CharField')(max_length=6)), +            ('multimedia_type', self.gf('django.db.models.fields.related.ForeignKey')(related_name='extensions', to=orm['chimere.MultimediaType'])), +        )) +        db.send_create_signal('chimere', ['MultimediaExtension']) + + +    def backwards(self, orm): +        # Deleting model 'MultimediaExtension' +        db.delete_table('chimere_multimediaextension') + + +    models = { +        'chimere.area': { +            'Meta': {'ordering': "('order', 'name')", 'object_name': 'Area'}, +            'available': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), +            'default': ('django.db.models.fields.NullBooleanField', [], {'null': 'True', 'blank': 'True'}), +            'default_subcategories': ('chimere.widgets.SelectMultipleField', [], {'to': "orm['chimere.SubCategory']", 'symmetrical': 'False', 'blank': 'True'}), +            'dynamic_categories': ('django.db.models.fields.NullBooleanField', [], {'null': 'True', 'blank': 'True'}), +            'external_css': ('django.db.models.fields.URLField', [], {'max_length': '200', 'null': 'True', 'blank': 'True'}), +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'layers': ('chimere.widgets.SelectMultipleField', [], {'symmetrical': 'False', 'related_name': "'areas'", 'blank': 'True', 'through': "orm['chimere.AreaLayers']", 'to': "orm['chimere.Layer']"}), +            'lower_right_corner': ('django.contrib.gis.db.models.fields.PointField', [], {'default': "'POINT(0 0)'"}), +            'name': ('django.db.models.fields.CharField', [], {'max_length': '150'}), +            'order': ('django.db.models.fields.IntegerField', [], {}), +            'restrict_to_extent': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), +            'subcategories': ('chimere.widgets.SelectMultipleField', [], {'symmetrical': 'False', 'related_name': "'areas'", 'blank': 'True', 'db_table': "'chimere_subcategory_areas'", 'to': "orm['chimere.SubCategory']"}), +            'upper_left_corner': ('django.contrib.gis.db.models.fields.PointField', [], {'default': "'POINT(0 0)'"}), +            'urn': ('django.db.models.fields.SlugField', [], {'unique': 'True', 'max_length': '50', 'blank': 'True'}), +            'welcome_message': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}) +        }, +        'chimere.arealayers': { +            'Meta': {'ordering': "('order',)", 'object_name': 'AreaLayers'}, +            'area': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['chimere.Area']"}), +            'default': ('django.db.models.fields.NullBooleanField', [], {'null': 'True', 'blank': 'True'}), +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'layer': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['chimere.Layer']"}), +            'order': ('django.db.models.fields.IntegerField', [], {}) +        }, +        'chimere.category': { +            'Meta': {'ordering': "['order']", 'object_name': 'Category'}, +            'available': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), +            'description': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}), +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'name': ('django.db.models.fields.CharField', [], {'max_length': '150'}), +            'order': ('django.db.models.fields.IntegerField', [], {}) +        }, +        'chimere.color': { +            'Meta': {'ordering': "['order']", 'object_name': 'Color'}, +            'code': ('django.db.models.fields.CharField', [], {'max_length': '6'}), +            'color_theme': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['chimere.ColorTheme']"}), +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'order': ('django.db.models.fields.IntegerField', [], {}) +        }, +        'chimere.colortheme': { +            'Meta': {'object_name': 'ColorTheme'}, +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'name': ('django.db.models.fields.CharField', [], {'max_length': '150'}) +        }, +        'chimere.icon': { +            'Meta': {'object_name': 'Icon'}, +            'height': ('django.db.models.fields.IntegerField', [], {}), +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'image': ('django.db.models.fields.files.ImageField', [], {'max_length': '100'}), +            'name': ('django.db.models.fields.CharField', [], {'max_length': '150'}), +            'width': ('django.db.models.fields.IntegerField', [], {}) +        }, +        'chimere.importer': { +            'Meta': {'object_name': 'Importer'}, +            'categories': ('chimere.widgets.SelectMultipleField', [], {'to': "orm['chimere.SubCategory']", 'symmetrical': 'False'}), +            'filtr': ('django.db.models.fields.CharField', [], {'max_length': '200', 'null': 'True', 'blank': 'True'}), +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'importer_type': ('django.db.models.fields.CharField', [], {'max_length': '4'}), +            'source': ('django.db.models.fields.CharField', [], {'max_length': '200', 'null': 'True', 'blank': 'True'}), +            'srid': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}), +            'state': ('django.db.models.fields.CharField', [], {'max_length': '200', 'null': 'True', 'blank': 'True'}), +            'zipped': ('django.db.models.fields.BooleanField', [], {'default': 'False'}) +        }, +        'chimere.layer': { +            'Meta': {'object_name': 'Layer'}, +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'layer_code': ('django.db.models.fields.TextField', [], {'max_length': '300'}), +            'name': ('django.db.models.fields.CharField', [], {'max_length': '150'}) +        }, +        'chimere.marker': { +            'Meta': {'ordering': "('status', 'name')", 'object_name': 'Marker'}, +            'available_date': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}), +            'categories': ('chimere.widgets.SelectMultipleField', [], {'to': "orm['chimere.SubCategory']", 'symmetrical': 'False'}), +            'description': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}), +            'end_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}), +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'import_key': ('django.db.models.fields.CharField', [], {'max_length': '200', 'null': 'True', 'blank': 'True'}), +            'import_source': ('django.db.models.fields.CharField', [], {'max_length': '200', 'null': 'True', 'blank': 'True'}), +            'import_version': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}), +            'name': ('django.db.models.fields.CharField', [], {'max_length': '150'}), +            'point': ('chimere.widgets.PointField', [], {}), +            'ref_item': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'submited_marker'", 'null': 'True', 'to': "orm['chimere.Marker']"}), +            'route': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'associated_marker'", 'null': 'True', 'to': "orm['chimere.Route']"}), +            'start_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}), +            'status': ('django.db.models.fields.CharField', [], {'max_length': '1'}), +            'submiter_comment': ('django.db.models.fields.TextField', [], {'max_length': '200', 'null': 'True', 'blank': 'True'}), +            'submiter_email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'null': 'True', 'blank': 'True'}), +            'submiter_name': ('django.db.models.fields.CharField', [], {'max_length': '40', 'null': 'True', 'blank': 'True'}), +            'submiter_session_key': ('django.db.models.fields.CharField', [], {'max_length': '40', 'null': 'True', 'blank': 'True'}) +        }, +        'chimere.multimediaextension': { +            'Meta': {'object_name': 'MultimediaExtension'}, +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'multimedia_type': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'extensions'", 'to': "orm['chimere.MultimediaType']"}), +            'name': ('django.db.models.fields.CharField', [], {'max_length': '6'}) +        }, +        'chimere.multimediafile': { +            'Meta': {'object_name': 'MultimediaFile'}, +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'marker': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'multimedia_files'", 'to': "orm['chimere.Marker']"}), +            'miniature': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), +            'multimedia_type': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['chimere.MultimediaType']"}), +            'name': ('django.db.models.fields.CharField', [], {'max_length': '150'}), +            'order': ('django.db.models.fields.IntegerField', [], {'default': '1'}), +            'url': ('django.db.models.fields.URLField', [], {'max_length': '200'}) +        }, +        'chimere.multimediatype': { +            'Meta': {'object_name': 'MultimediaType'}, +            'available': ('django.db.models.fields.BooleanField', [], {'default': 'True'}), +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'iframe': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), +            'media_type': ('django.db.models.fields.CharField', [], {'max_length': '1'}), +            'mime_type': ('django.db.models.fields.CharField', [], {'max_length': '50', 'null': 'True', 'blank': 'True'}), +            'name': ('django.db.models.fields.CharField', [], {'max_length': '150'}) +        }, +        'chimere.news': { +            'Meta': {'object_name': 'News'}, +            'available': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), +            'content': ('django.db.models.fields.TextField', [], {}), +            'date': ('django.db.models.fields.DateField', [], {'auto_now_add': 'True', 'blank': 'True'}), +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'title': ('django.db.models.fields.CharField', [], {'max_length': '150'}) +        }, +        'chimere.picturefile': { +            'Meta': {'object_name': 'PictureFile'}, +            'height': ('django.db.models.fields.IntegerField', [], {}), +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'marker': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'pictures'", 'to': "orm['chimere.Marker']"}), +            'miniature': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), +            'name': ('django.db.models.fields.CharField', [], {'max_length': '150'}), +            'order': ('django.db.models.fields.IntegerField', [], {'default': '1'}), +            'picture': ('django.db.models.fields.files.ImageField', [], {'max_length': '100'}), +            'thumbnailfile': ('django.db.models.fields.files.ImageField', [], {'max_length': '100', 'null': 'True', 'blank': 'True'}), +            'thumbnailfile_height': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}), +            'thumbnailfile_width': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}), +            'width': ('django.db.models.fields.IntegerField', [], {}) +        }, +        'chimere.property': { +            'Meta': {'object_name': 'Property'}, +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'marker': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['chimere.Marker']"}), +            'propertymodel': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['chimere.PropertyModel']"}), +            'value': ('django.db.models.fields.TextField', [], {}) +        }, +        'chimere.propertymodel': { +            'Meta': {'ordering': "('order',)", 'object_name': 'PropertyModel'}, +            'available': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'mandatory': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), +            'name': ('django.db.models.fields.CharField', [], {'max_length': '150'}), +            'order': ('django.db.models.fields.IntegerField', [], {}), +            'subcategories': ('chimere.widgets.SelectMultipleField', [], {'symmetrical': 'False', 'related_name': "'properties'", 'blank': 'True', 'to': "orm['chimere.SubCategory']"}), +            'type': ('django.db.models.fields.CharField', [], {'max_length': '1'}) +        }, +        'chimere.propertymodelchoice': { +            'Meta': {'object_name': 'PropertyModelChoice'}, +            'available': ('django.db.models.fields.BooleanField', [], {'default': 'True'}), +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'propertymodel': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'choices'", 'to': "orm['chimere.PropertyModel']"}), +            'value': ('django.db.models.fields.CharField', [], {'max_length': '150'}) +        }, +        'chimere.route': { +            'Meta': {'ordering': "('status', 'name')", 'object_name': 'Route'}, +            'associated_file': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['chimere.RouteFile']", 'null': 'True', 'blank': 'True'}), +            'categories': ('chimere.widgets.SelectMultipleField', [], {'to': "orm['chimere.SubCategory']", 'symmetrical': 'False'}), +            'end_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}), +            'height': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}), +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'import_key': ('django.db.models.fields.CharField', [], {'max_length': '200', 'null': 'True', 'blank': 'True'}), +            'import_source': ('django.db.models.fields.CharField', [], {'max_length': '200', 'null': 'True', 'blank': 'True'}), +            'import_version': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}), +            'name': ('django.db.models.fields.CharField', [], {'max_length': '150'}), +            'picture': ('django.db.models.fields.files.ImageField', [], {'max_length': '100', 'null': 'True', 'blank': 'True'}), +            'ref_item': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'submited_route'", 'null': 'True', 'to': "orm['chimere.Route']"}), +            'route': ('chimere.widgets.RouteField', [], {}), +            'start_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}), +            'status': ('django.db.models.fields.CharField', [], {'max_length': '1'}), +            'submiter_comment': ('django.db.models.fields.TextField', [], {'max_length': '200', 'null': 'True', 'blank': 'True'}), +            'submiter_email': ('django.db.models.fields.EmailField', [], {'max_length': '75', 'null': 'True', 'blank': 'True'}), +            'submiter_name': ('django.db.models.fields.CharField', [], {'max_length': '40', 'null': 'True', 'blank': 'True'}), +            'submiter_session_key': ('django.db.models.fields.CharField', [], {'max_length': '40', 'null': 'True', 'blank': 'True'}), +            'width': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}) +        }, +        'chimere.routefile': { +            'Meta': {'ordering': "('name',)", 'object_name': 'RouteFile'}, +            'file_type': ('django.db.models.fields.CharField', [], {'max_length': '1'}), +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'name': ('django.db.models.fields.CharField', [], {'max_length': '150'}), +            'raw_file': ('django.db.models.fields.files.FileField', [], {'max_length': '100'}), +            'simplified_file': ('django.db.models.fields.files.FileField', [], {'max_length': '100', 'null': 'True', 'blank': 'True'}) +        }, +        'chimere.subcategory': { +            'Meta': {'ordering': "['category', 'order']", 'object_name': 'SubCategory'}, +            'available': ('django.db.models.fields.BooleanField', [], {'default': 'False'}), +            'category': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['chimere.Category']"}), +            'color_theme': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['chimere.ColorTheme']", 'null': 'True', 'blank': 'True'}), +            'icon': ('django.db.models.fields.related.ForeignKey', [], {'to': "orm['chimere.Icon']"}), +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'item_type': ('django.db.models.fields.CharField', [], {'max_length': '1'}), +            'name': ('django.db.models.fields.CharField', [], {'max_length': '150'}), +            'order': ('django.db.models.fields.IntegerField', [], {}) +        }, +        'chimere.tinyurl': { +            'Meta': {'object_name': 'TinyUrl'}, +            'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}), +            'parameters': ('django.db.models.fields.CharField', [], {'max_length': '500'}) +        } +    } + +    complete_apps = ['chimere']
\ No newline at end of file diff --git a/chimere/models.py b/chimere/models.py index 8f07576..8098ade 100644 --- a/chimere/models.py +++ b/chimere/models.py @@ -509,17 +509,30 @@ IFRAME_LINKS = {      'youtube':((re.compile(r'youtube.com\/watch\?v=([A-Za-z0-9_-]*)'),                  re.compile(r'youtu.be\/([A-Za-z0-9_-]*)'),                  re.compile(r'youtube.com\/embed\/([A-Za-z0-9_-]*)')), -                "http://www.youtube.com/embed/%s"), +                 "http://www.youtube.com/embed/%s"),      'dailymotion':(          (re.compile(r'dailymotion.com/video/([A-Za-z0-9]*)_[A-Za-z0-9_-]*'),           re.compile(r'dailymotion.com/embed/video/([A-Za-z0-9]*)'),           re.compile("http://www.dailymotion.com/embed/video/%s")), -         'http://www.dailymotion.com/embed/video/%s'), +          'http://www.dailymotion.com/embed/video/%s'),      'vimeo':((re.compile(r'vimeo.com/([A-Za-z0-9]*)'),                re.compile(r'vimeo.com/video/([A-Za-z0-9]*)')), -              "http://player.vimeo.com/video/%s") +               "http://player.vimeo.com/video/%s")  } +class MultimediaExtension(models.Model): +    name = models.CharField(_(u"Extension name"), max_length=6) +    multimedia_type = models.ForeignKey(MultimediaType, +                        verbose_name=_(u"Associated multimedia type"), +                        related_name='extensions') + +    class Meta: +        verbose_name = _(u"Multimedia extension") +        verbose_name_plural = _(u"Multimedia extensions") + +    def __unicode__(self): +        return self.name +  class MultimediaFile(models.Model):      name = models.CharField(_(u"Name"), max_length=150)      url = models.URLField(_(u"Url"), max_length=200) diff --git a/chimere/templates/chimere/blocks/alternate_multimedia.html b/chimere/templates/chimere/blocks/alternate_multimedia.html index 0a63c1b..0662750 100644 --- a/chimere/templates/chimere/blocks/alternate_multimedia.html +++ b/chimere/templates/chimere/blocks/alternate_multimedia.html @@ -3,7 +3,11 @@      {% for formset in formsets %}          {{ formset.management_form }}          {% if formset.errors %}<div class='errors'> -            {{formset.errors}} +        {% for dict in formset.errors %} +            {% for error in dict.values %} +                {{ error }} +            {% endfor %} +        {% endfor %}          </div>{% endif %}      {% endfor %}          <ul id='multimedia_list_content'> @@ -39,7 +43,7 @@          <input type='radio' value='other' id='media_type_other' name="multimedia_type"> {% trans "Audio, video, other..." %}          </div>          <div class="fieldWrapper"> -        <label id="multimedia_file_label">{% trans "Download"%}</label> <input type='file' name='picture-0-picture' class='multimedia_file'> +        <label id="multimedia_file_label">{% trans "Download"%}</label> <input type='file' name='picture-0-picture' id='picture-0-picture' class='multimedia_file'>          <p class='notice'>{% trans "Or" %}</p>          <label for='multimedia_url'>{% trans "Web address"%}</label> <input type='text' name='multimedia_url' id='multimedia_url'>          </div> @@ -78,7 +82,7 @@                      return false;                  }                  if ($('#media_type_image:checked').val() -                        && !$("#multimedia_file").val() +                        && !$("#picture-"+current_image_number+"-picture").val()                          && !$("#multimedia_url").val()){                      alert("{% trans "You must provide a file or a web address." %}")                      return false; @@ -92,14 +96,13 @@                  var prefix = '';                  var contener = $("#multimedia_list_content")                  content = '<li'; -                if ($('#media_type_image:checked').val() -                        && !$("#multimedia_file").val()){ +                if ($('#media_type_image:checked').val()){                      content += ' class="picture">';                      prefix = 'picture-' + current_image_number;                  } else {                      content += ' class="multimedia">';                      prefix = 'multimedia-' + current_multi_number; -                    content += '<input type="hidden" name="'+prefix+'-multimedia_type" value="auto" />\n'; +                    content += '<input type="hidden" name="'+prefix+'-multimedia_type" value="{{auto_type_id}}" />\n';                      content += '<input type="hidden" name="'+prefix+'-url" value="'+$("#multimedia_url").val()+'" />\n';                  }                  content += '<input type="hidden" name="'+prefix+'-id"/>\n'; @@ -111,12 +114,14 @@                  content += '</li>';                  contener.append(content);                  if ($('#media_type_image:checked').val() -                        && !$("#multimedia_file").val()){ -                    // clone the file item -                    var file_item = $('picture-'+current_image_number+'-picture'); -                    var cloned = file_item.clone(true); -                    file_item.hide(); -                    cloned.insertAfter(file_item); +                        && $("#picture-"+current_image_number+"-picture").val()){ +                    // the file item cannot be recopied - security issue +                    // so it is hiden then a new one is added +                    //$('#picture-'+current_image_number+'-picture').hide(); +                    var file_item = $('#picture-'+current_image_number+'-picture'); +                    //var cloned = file_item.clone(true); +                    //file_item.hide(); +                    //cloned.insertAfter(file_item);                      file_item.appendTo($("#multimedia_list_content li").last());                  }                  $("#multimedia_form").dialog("close"); diff --git a/chimere/templatetags/chimere_tags.py b/chimere/templatetags/chimere_tags.py index b2f045f..99ee0aa 100644 --- a/chimere/templatetags/chimere_tags.py +++ b/chimere/templatetags/chimere_tags.py @@ -10,7 +10,7 @@ from django.conf import settings  from django.core.exceptions import ObjectDoesNotExist  from django.core.urlresolvers import reverse -from chimere.models import Marker, Area, News, SubCategory +from chimere.models import Marker, Area, News, SubCategory, MultimediaType  from chimere.widgets import get_map_layers  log = getLogger(__name__) @@ -220,7 +220,8 @@ def multimedia_render(context, multimedia_file):  @register.inclusion_tag('chimere/blocks/alternate_multimedia.html')  def alternate_multimedia(formset_multi, formset_picture):      return {'formsets':[formset_multi, formset_picture], -            "STATIC_URL": settings.STATIC_URL} +            "STATIC_URL": settings.STATIC_URL, +            'auto_type_id':MultimediaType.objects.get(name='auto').pk}  @register.simple_tag  def get_tinyfied_url(marker, area_name=''): | 
