- Refactor and resolved an issue on window.opener event.
- Refactor FB_Redactor plugin.
- Support for django-suit
- Support for django-suit-ckeditor
- Support for django-suit-redactor
- Support for custom user model
- Mandatory django version higher 1.5
pip install django-media-manager
or
pip install https://github.com/miguelramos/django-media-manager/archive/master.zip
- Add filebrowser to INSTALLED_APPS.
- Add the following line before the admin URLS:
-
(r'^admin/filebrowser/', include('filebrowser.urls'))
- Collect static files
- Add uploads/ folder to media folder or customize this setting
The application have support for django-suit template. To use it add on your settings files the following config:
FILEBROWSER_SUIT_TEMPLATE = True
Filebrowser will now use templates for django suit.
To use filebrowser on django-suit-ckeditor or django-suit-redactor please follow the example bellow:
#models.py
from django.db import models
from filebrowser.fields import FileBrowseField
class MediaPublication(models.Model):
ckeditor = models.TextField(help_text='Editor CKEditor')
redactor = models.TextField(help_text='Editor Redactor')
image = FileBrowseField("Image", max_length=200, blank=True, null=True)
image_initialdir = FileBrowseField("Image (Initial Directory)", max_length=200, directory="images/", blank=True, null=True)
image_extensions = FileBrowseField("Image (Extensions)", max_length=200, extensions=['.jpg'],
help_text="Only jpg-Images allowed.", blank=True, null=True)
image_format = FileBrowseField("Image (Format)", max_length=200, format='Image', blank=True, null=True)
pdf = FileBrowseField("PDF", max_length=200, directory="documents/", extensions=['.pdf'], format='Document',
blank=True, null=True)
class Meta:
ordering = ['image',]
verbose_name = 'publication'
verbose_name_plural = 'publications'
To use on admin you need to do some litle tweeks:
#admin.py
from django.contrib import admin
from django.forms import ModelForm, Media
from suit_ckeditor.widgets import CKEditorWidget
from suit_redactor.widgets import RedactorWidget
from .models import MediaPublication
class Editor(ModelForm):
class Meta:
widgets = {
'ckeditor': CKEditorWidget(editor_options={'startupFocus': True}),
'redactor': RedactorWidget(editor_options={
'lang': 'en',
'plugins': ['filebrowser']
}),
}
class Media:
js = ('filebrowser/js/FB_CKEditor.js', 'filebrowser/js/FB_Redactor.js')
css = {
'all': ('filebrowser/css/suit-filebrowser.css',)
}
class AdminPublication(admin.ModelAdmin):
form = Editor
fieldsets = (
(None, {
'classes': ('suit-tab suit-tab-media',),
'fields': ['image', 'image_initialdir', 'image_extensions', 'image_format', 'pdf'],
}),
('CKEditor', {
'classes': ('full-width',),
'fields': ('ckeditor',)
}),
('Redactor', {
'classes': ('full-width',),
'fields': ('redactor',)
}),
)
list_display = ('thumbnail', 'image_extensions', 'pdf')
suit_form_tabs = (('media', 'Media'),)
def thumbnail(self, obj):
if obj.image:
return '<img src="%s" />' % obj.image.url_thumbnail
else:
return ""
thumbnail.allow_tags = True
admin.site.register(MediaPublication, AdminPublication)
The most important things are on ModelForm (Media and Widgets). To use browser on CKEditor and have the button to navigate on filebrowser you only need to add the js file to Media
For Redactor you will have to add the plugin option on the widget (plugin name is mandatory - filebrowser ) and add the css and js file to media.
That's it you are now ready to send all kind of files to ckeditor or redactor.
Please this is a work in progress. If you have ideas or want to make it better please fel free to pull requests.
- Better uploader, now using uploadify (some flash elements)
- Add more options on thumbs sizes
You can find the original documentation of django-filebrowser and all settings in Google Code repo.