media gallery: delete item, edit item, edit gallery title
This commit is contained in:
parent
26677493ee
commit
675f418b13
|
@ -3,6 +3,9 @@ from django.conf.urls.defaults import *
|
||||||
urlpatterns = patterns('mediagallery.views',
|
urlpatterns = patterns('mediagallery.views',
|
||||||
(r'^add/(?P<ctype_id>\d+)/(?P<object_id>\d+)', 'add'),
|
(r'^add/(?P<ctype_id>\d+)/(?P<object_id>\d+)', 'add'),
|
||||||
(r'^edit/(?P<id>\d+)', 'edit'),
|
(r'^edit/(?P<id>\d+)', 'edit'),
|
||||||
|
(r'^edit_title/(?P<id>\d+)', 'edit_title'),
|
||||||
|
(r'^delete_photo/(?P<id>\d+)', 'delete_photo'),
|
||||||
|
(r'^edit_photo/(?P<id>\d+)', 'edit_photo'),
|
||||||
(r'^upload/', 'upload'),
|
(r'^upload/', 'upload'),
|
||||||
(r'^(?P<id>\d+)/chunk', 'chunk'),
|
(r'^(?P<id>\d+)/chunk', 'chunk'),
|
||||||
|
|
||||||
|
|
|
@ -2,11 +2,12 @@
|
||||||
from django.shortcuts import render_to_response, get_object_or_404
|
from django.shortcuts import render_to_response, get_object_or_404
|
||||||
from django.template import RequestContext
|
from django.template import RequestContext
|
||||||
from django.http import HttpResponse, HttpResponseRedirect
|
from django.http import HttpResponse, HttpResponseRedirect
|
||||||
from models import GalleryAlbum, Photo
|
from models import GalleryAlbum, GalleryItem, Photo
|
||||||
from django.contrib.contenttypes.models import ContentType
|
from django.contrib.contenttypes.models import ContentType
|
||||||
from django.views.decorators.csrf import csrf_exempt
|
from django.views.decorators.csrf import csrf_exempt
|
||||||
from django import forms
|
from django import forms
|
||||||
from ox.django.shortcuts import render_to_json_response
|
from ox.django.shortcuts import render_to_json_response
|
||||||
|
from sorl.thumbnail import get_thumbnail
|
||||||
|
|
||||||
def add(request, ctype_id, object_id):
|
def add(request, ctype_id, object_id):
|
||||||
ctype = get_object_or_404(ContentType, pk=ctype_id)
|
ctype = get_object_or_404(ContentType, pk=ctype_id)
|
||||||
|
@ -33,6 +34,33 @@ def edit(request, id):
|
||||||
return render_to_response("mediagallery/upload.html", context)
|
return render_to_response("mediagallery/upload.html", context)
|
||||||
|
|
||||||
|
|
||||||
|
def edit_title(request, id):
|
||||||
|
gallery = get_object_or_404(GalleryAlbum, pk=id)
|
||||||
|
title = request.GET.get("title", "")
|
||||||
|
if title.strip() == '':
|
||||||
|
return render_to_json_response({'error': 'Title is empty!'})
|
||||||
|
gallery.title = title
|
||||||
|
gallery.save()
|
||||||
|
return render_to_json_response({'success': 'true'})
|
||||||
|
|
||||||
|
|
||||||
|
def edit_photo(request, id):
|
||||||
|
item = get_object_or_404(Photo, pk=id)
|
||||||
|
title = request.GET.get("title", "")
|
||||||
|
if title.strip() == '':
|
||||||
|
return render_to_json_response({'error': 'Title is empty!'})
|
||||||
|
item.title = title
|
||||||
|
item.save()
|
||||||
|
return render_to_json_response({'success': 'true'})
|
||||||
|
|
||||||
|
|
||||||
|
#FIXME: check permissions
|
||||||
|
def delete_photo(request, id):
|
||||||
|
item = get_object_or_404(Photo, pk=id)
|
||||||
|
item.delete()
|
||||||
|
return render_to_json_response({'success': 'true'})
|
||||||
|
|
||||||
|
|
||||||
@csrf_exempt
|
@csrf_exempt
|
||||||
def upload(request):
|
def upload(request):
|
||||||
if request.method == 'POST':
|
if request.method == 'POST':
|
||||||
|
@ -78,10 +106,10 @@ def chunk(request, id):
|
||||||
item.save()
|
item.save()
|
||||||
response = {
|
response = {
|
||||||
'resultUrl': '/files/' + str(item.id),
|
'resultUrl': '/files/' + str(item.id),
|
||||||
'fileId': item.id,
|
'id': item.id,
|
||||||
'title': name,
|
'title': name,
|
||||||
#'type': item.type,
|
#'type': item.type,
|
||||||
#'thumbnail': item.get_thumb("100x100")
|
'thumbnail': get_thumbnail(item.image, "100x100", crop="center").url
|
||||||
}
|
}
|
||||||
|
|
||||||
response['done'] = 1
|
response['done'] = 1
|
||||||
|
|
|
@ -32,6 +32,7 @@ function ChunkUploader(options) {
|
||||||
retries = 0,
|
retries = 0,
|
||||||
request,
|
request,
|
||||||
that = {};
|
that = {};
|
||||||
|
that.extra_data = options.extra_data;
|
||||||
|
|
||||||
initUpload();
|
initUpload();
|
||||||
|
|
||||||
|
@ -39,7 +40,8 @@ function ChunkUploader(options) {
|
||||||
options.callback({
|
options.callback({
|
||||||
status: that.status,
|
status: that.status,
|
||||||
progress: that.progress,
|
progress: that.progress,
|
||||||
responseText: that.responseText
|
responseText: that.responseText,
|
||||||
|
extra: that.extra_data
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -101,7 +103,8 @@ function ChunkUploader(options) {
|
||||||
that.progress = p;
|
that.progress = p;
|
||||||
options.progress({
|
options.progress({
|
||||||
progress: that.progress,
|
progress: that.progress,
|
||||||
status: that.status
|
status: that.status,
|
||||||
|
extra: that.extra_data
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,20 +1,21 @@
|
||||||
(function($) {
|
(function($) {
|
||||||
|
|
||||||
ItfFileUpload = function(file, Q) {
|
ItfFileUpload = function(file, Q) {
|
||||||
|
this.uploaded = false;
|
||||||
this.file = file;
|
this.file = file;
|
||||||
this.Q = Q;
|
this.Q = Q;
|
||||||
|
this.$li = this.getLi().prependTo('#photosContainer');
|
||||||
this.$li = this.getLi().appendTo(Q.$ul);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
ItfFileUpload.prototype.upload = function() {
|
ItfFileUpload.prototype.upload = function() {
|
||||||
var that = this;
|
var that = this;
|
||||||
var Q = that.Q;
|
var Q = that.Q;
|
||||||
var fil = this.file;
|
var fil = this.file;
|
||||||
// console.log("uploading", fil);
|
// console.log("uploading", fil);
|
||||||
var data = Q.getData(fil);
|
var data = Q.getData(fil);
|
||||||
// var $li = this.getLi(no);
|
// this.$li = this.getLi().appendTo(that.Q.$elem);
|
||||||
Q.isUploading = true;
|
this.Q.isUploading = true;
|
||||||
var url = Q.options.addURL;
|
var url = Q.options.addURL;
|
||||||
this.showProgress();
|
this.showProgress();
|
||||||
// $('#progressbar').show();
|
// $('#progressbar').show();
|
||||||
|
@ -23,26 +24,50 @@ ItfFileUpload.prototype.upload = function() {
|
||||||
'file': fil,
|
'file': fil,
|
||||||
'url': url,
|
'url': url,
|
||||||
'data': data,
|
'data': data,
|
||||||
|
'extra_data': that,
|
||||||
'callback': function(response) {
|
'callback': function(response) {
|
||||||
var data = JSON.parse(response.responseText);
|
var data = JSON.parse(response.responseText);
|
||||||
//console.log("data", data);
|
//console.log("data", data);
|
||||||
if (data.resultUrl) {
|
if (data.resultUrl) {
|
||||||
that.markDone(data);
|
that.markDone(data);
|
||||||
} else {
|
} else {
|
||||||
that.$elem.find("progressStatus").html(response.status);
|
that.$li.find(".progressStatus").html(response.status);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
'progress': that.doProgress
|
'progress': that.doProgress
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
ItfFileUpload.prototype.markDone = function(data) {
|
||||||
|
var that = this;
|
||||||
|
//console.log(data);
|
||||||
|
//alert("hi");
|
||||||
|
this.uploaded = true;
|
||||||
|
//var d = JSON.parse(data.responseText);
|
||||||
|
this.$li.removeClass("uploadFileItem").addClass("photoContainer").empty();
|
||||||
|
var $img = $('<img />').attr("src", data.thumbnail).appendTo(that.$li);
|
||||||
|
var $title = $('<input />').addClass("photoTitle").val(data.title).appendTo(that.$li);
|
||||||
|
var $delete = $('<span />').addClass("deleteItem").text("X").appendTo(that.$li);
|
||||||
|
var $id = $('<input />').attr("hidden", "hidden").addClass("photoId").val(data.id).appendTo(that.$li);
|
||||||
|
this.Q.uploadNext();
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
ItfFileUpload.prototype.showProgress = function() {
|
ItfFileUpload.prototype.showProgress = function() {
|
||||||
this.Q.$elem.find(".fileProgress").show();
|
var that = this;
|
||||||
|
//console.log(that);
|
||||||
|
this.$li.find(".fileProgress").show();
|
||||||
};
|
};
|
||||||
|
|
||||||
ItfFileUpload.prototype.doProgress = function(progress) {
|
ItfFileUpload.prototype.doProgress = function(progress) {
|
||||||
console.log(progress);
|
// console.log(progress);
|
||||||
|
// var that = this;
|
||||||
|
// console.log(that);
|
||||||
|
// console.log(progress);
|
||||||
|
// GLOB = progress;
|
||||||
|
var widthPercent = progress.progress * 100;
|
||||||
|
progress.extra.$li.find(".progressBar").css({'width': widthPercent + "%"});
|
||||||
|
//progress.extra.$li.find(".progressBar").text(progress.progress);
|
||||||
};
|
};
|
||||||
|
|
||||||
ItfFileUpload.prototype.getLi = function() {
|
ItfFileUpload.prototype.getLi = function() {
|
||||||
|
@ -67,11 +92,24 @@ ItfUploadQueue = function(options, $elem) {
|
||||||
this.$ul = $("<ul />").addClass("uploadFileList").appendTo($elem);
|
this.$ul = $("<ul />").addClass("uploadFileList").appendTo($elem);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
ItfUploadQueue.prototype.uploadNext = function() {
|
||||||
|
for (var i=0; i<this.files.length; i++) {
|
||||||
|
if (this.files[i].uploaded === false) {
|
||||||
|
this.files[i].upload();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
this.isUploading = false;
|
||||||
|
return;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
ItfUploadQueue.prototype.addFile = function(f) {
|
ItfUploadQueue.prototype.addFile = function(f) {
|
||||||
var that = this;
|
var that = this;
|
||||||
var fileUpload = new ItfFileUpload(f, that);
|
var fileUpload = new ItfFileUpload(f, that);
|
||||||
this.files.push(fileUpload);
|
this.files.push(fileUpload);
|
||||||
// this.addToList(f);
|
// this.addToList(f);
|
||||||
|
// var no = this.len() - 1;
|
||||||
if (!this.isUploading) {
|
if (!this.isUploading) {
|
||||||
fileUpload.upload();
|
fileUpload.upload();
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,18 +6,67 @@
|
||||||
<script src="/static/js/upload/chunkupload.js"></script>
|
<script src="/static/js/upload/chunkupload.js"></script>
|
||||||
<script src="/static/js/upload/itfUpload.js"></script>
|
<script src="/static/js/upload/itfUpload.js"></script>
|
||||||
<script>
|
<script>
|
||||||
|
GALLERY_ID = {{ gallery.id }};
|
||||||
$(function() {
|
$(function() {
|
||||||
$('#uploadImages').uploadQueue({'addURL': '/mediagallery/upload/', 'id': {{ gallery.id }} });
|
$('#uploadImages').uploadQueue({'addURL': '/mediagallery/upload/', 'id': GALLERY_ID });
|
||||||
//var itfQ = ItfUploadQueue({'addURL': '/mediagallery/upload/'}, $('#uploadImages'));
|
//var itfQ = ItfUploadQueue({'addURL': '/mediagallery/upload/'}, $('#uploadImages'));
|
||||||
|
|
||||||
|
$('#uploadImages').delegate(".deleteItem", "click", function(e) {
|
||||||
|
if (!confirm("Are you sure you wish to delete this image?")) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
var $this = $(e.target);
|
||||||
|
//console.log($this);
|
||||||
|
var id = $this.parents('.photoContainer').find('.photoId').val();
|
||||||
|
var url = "/mediagallery/delete_photo/" + id;
|
||||||
|
|
||||||
|
$.get(url, {}, function(response) {
|
||||||
|
//alert("hi");
|
||||||
});
|
});
|
||||||
|
$this.parents('.photoContainer').fadeOut();
|
||||||
|
});
|
||||||
|
|
||||||
|
$('#uploadImages').delegate(".photoTitle", "blur", function(e) {
|
||||||
|
var $this = $(e.target);
|
||||||
|
//alert($this.val());
|
||||||
|
var title = $this.val();
|
||||||
|
var id = $this.parents('.photoContainer').find('.photoId').val();
|
||||||
|
var url = "/mediagallery/edit_photo/" + id;
|
||||||
|
$.get(url, {'title': title}, function(response) {
|
||||||
|
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
$('.galleryTitle').blur(function() {
|
||||||
|
var title = $(this).val();
|
||||||
|
var url = "/mediagallery/edit_title/" + GALLERY_ID;
|
||||||
|
$.get(url, {'title': title}, function(response) {
|
||||||
|
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
<style>
|
<style>
|
||||||
#uploadImages {
|
#uploadImages {
|
||||||
min-width: 400px;
|
min-width: 400px;
|
||||||
min-height: 300px;
|
min-height: 300px;
|
||||||
|
max-width: 50%;
|
||||||
background: #f00;
|
background: #f00;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.progressBar {
|
||||||
|
height: 10px;
|
||||||
|
background: #00f;
|
||||||
|
}
|
||||||
|
|
||||||
|
.deleteItem {
|
||||||
|
font-weight: bold;
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
</style>
|
</style>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
||||||
|
@ -27,19 +76,20 @@ $(function() {
|
||||||
<div id="uploadImages">
|
<div id="uploadImages">
|
||||||
<input type="file" id="uploadImageFiles" multiple />
|
<input type="file" id="uploadImageFiles" multiple />
|
||||||
|
|
||||||
<div id="photosContainer">
|
<ul id="photosContainer">
|
||||||
{% for photo in photos %}
|
{% for photo in photos %}
|
||||||
<div class="photoContainer">
|
<li class="photoContainer">
|
||||||
{% if photo.image %}
|
{% if photo.image %}
|
||||||
{% thumbnail photo.image "100x100" crop="center" as thumb %}
|
{% thumbnail photo.image "100x100" crop="center" as thumb %}
|
||||||
<img src="{{ thumb.url }}" />
|
<img src="{{ thumb.url }}" />
|
||||||
{% endthumbnail %}
|
{% endthumbnail %}
|
||||||
{% endif %}
|
{% endif %}
|
||||||
<input class="photoTitle" value="{{ photo.title }}" />
|
<input class="photoTitle" value="{{ photo.title }}" />
|
||||||
|
<span class="deleteItem">X</span>
|
||||||
<input type="hidden" class="photoId" value="{{ photo.id }}" />
|
<input type="hidden" class="photoId" value="{{ photo.id }}" />
|
||||||
</div>
|
</li>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</div>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user