X-Git-Url: https://git.mdrn.pl/redakcja.git/blobdiff_plain/b0773e2054ab6bc6305142fdd28799e0f41616c9..39d26aa0f2cb893f19282657b2fddd2a494f2263:/project/static/js/views/gallery.js
diff --git a/project/static/js/views/gallery.js b/project/static/js/views/gallery.js
index 95736565..74493444 100644
--- a/project/static/js/views/gallery.js
+++ b/project/static/js/views/gallery.js
@@ -3,22 +3,25 @@ var ImageGalleryView = View.extend({
_className: 'ImageGalleryView',
element: null,
model: null,
+ currentPage: -1,
+ pageZoom: 1.0,
template: 'image-gallery-view-template',
init: function(element, model, parent, template)
- {
- this.currentPage = -1;
-
+ {
+ console.log("init for gallery");
this._super(element, model, template);
this.parent = parent;
+
+ console.log("galley model", this.model);
this.model
.addObserver(this, 'data', this.modelDataChanged.bind(this))
.addObserver(this, 'state', this.modelStateChanged.bind(this));
-
+
//$('.image-gallery-view', this.element).html(this.model.get('data'));
this.modelStateChanged('state', this.model.get('state'));
- this.model.load();
+ this.model.load();
},
modelDataChanged: function(property, value)
@@ -26,7 +29,7 @@ var ImageGalleryView = View.extend({
if( property == 'data')
{
this.render();
- this.gotoPage(this.currentPage);
+ this.gotoPage(this.currentPage);
}
},
@@ -51,7 +54,7 @@ var ImageGalleryView = View.extend({
this.currentPage = index;
cpage = this.$currentPage()
- this.renderImage(cpage, cpage.attr('ui:model'));
+ this.renderImage(cpage);
if(offset) {
cpage.css({top: offset.y, left: offset.x});
@@ -78,15 +81,13 @@ var ImageGalleryView = View.extend({
this.$pageInput.val( (this.currentPage+1) );
},
- modelStateChanged: function(property, value) {
- if (value == 'synced' || value == 'dirty') {
- this.parent.unfreeze();
- } else if (value == 'unsynced') {
- this.parent.freeze('Niezsynchronizowany...');
- } else if (value == 'loading') {
+ reload: function() {},
+
+ modelStateChanged: function(property, value) {
+ if (value == 'loading') {
this.parent.freeze('Åadowanie...');
- } else if (value == 'saving') {
- this.parent.freeze('Zapisywanie...');
+ } else {
+ this.parent.unfreeze();
}
},
@@ -156,12 +157,14 @@ var ImageGalleryView = View.extend({
// and correct
var MARGIN = 30;
+
var vp_width = this.$pageListRoot.width();
var vp_height = this.$pageListRoot.height();
var width = $page.outerWidth();
- var height = $page.outerHeight();
+ var height = $page.outerHeight();
+ // console.log(offset, vp_width, vp_height, width, height);
if( offset.x+width-MARGIN < 0 ) {
// console.log('too much on the left', offset.x, -width)
offset.x = -width+MARGIN;
@@ -172,7 +175,6 @@ var ImageGalleryView = View.extend({
offset.x = vp_width-MARGIN;
// console.log('too much on the right', offset.x, vp_width, width)
}
-
if( offset.y+height-MARGIN < 0)
offset.y = -height+MARGIN;
@@ -183,29 +185,44 @@ var ImageGalleryView = View.extend({
$page.css({left: offset.x, top: offset.y});
},
- renderImage: function(target, source) {
- target.html('');
+ renderImage: function(target)
+ {
+ var source = target.attr('ui:model');
+ var orig_width = parseInt(target.attr('ui:width'));
+ var orig_height = parseInt(target.attr('ui:height'));
+
+ target.html('');
+
$('img', target).
css({
'user-select': 'none',
'-webkit-user-select': 'none',
'-khtml-user-select': 'none',
- '-moz-user-select': 'none',
+ '-moz-user-select': 'none'
}).
attr('unselectable', 'on').
- mousedown(this.pageDragStart.bind(this));
+ mousedown(this.pageDragStart.bind(this));
},
- render: function() {
- /* first unbind all */
+ render: function()
+ {
+ if(!this.model) return;
- // this.pageListElement
+ /* first unbind all */
if(this.$nextButton) this.$nextButton.unbind();
if(this.$prevButton) this.$prevButton.unbind();
if(this.$jumpButton) this.$jumpButton.unbind();
+ if(this.$pageInput) this.$pageInput.unbind();
+
+ if(this.$zoomInButton) this.$zoomInButton.unbind();
+ if(this.$zoomOutButton) this.$zoomOutButton.unbind();
+ if(this.$zoomResetButton) this.$zoomResetButton.unbind();
/* render */
- this.element.html(render_template(this.template, this));
+ this._super();
/* fetch important parts */
this.$pageListRoot = $('.image-gallery-page-list', this.element);
@@ -215,11 +232,23 @@ var ImageGalleryView = View.extend({
this.$prevButton = $('.image-gallery-prev-button', this.element);
this.$pageInput = $('.image-gallery-current-page', this.element);
+ // this.$zoomSelect = $('.image-gallery-current-zoom', this.element);
+ this.$zoomInButton = $('.image-gallery-zoom-in', this.element);
+ this.$zoomOutButton = $('.image-gallery-zoom-out', this.element);
+ this.$zoomResetButton = $('.image-gallery-zoom-reset', this.element);
+
/* re-bind events */
this.$nextButton.click( this.nextPage.bind(this) );
this.$prevButton.click( this.prevPage.bind(this) );
-
this.$pageInput.change( this.jumpToPage.bind(this) );
+
+ // this.$zoomSelect.change( this.zoomChanged.bind(this) );
+ this.$zoomInButton.click( this.zoomInOneStep.bind(this) );
+ this.$zoomOutButton.click( this.zoomOutOneStep.bind(this) );
+ this.$zoomResetButton.click( this.zoomReset.bind(this) );
+
+ this.gotoPage(this.currentPage);
+ this.changePageZoom(this.pageZoom);
},
jumpToPage: function() {
@@ -233,10 +262,58 @@ var ImageGalleryView = View.extend({
prevPage: function() {
this.gotoPage(this.currentPage - 1);
},
+
+ zoomReset: function() {
+ this.changePageZoom(1.0);
+ },
+
+ zoomInOneStep: function() {
+ var zoom = this.pageZoom + 0.1;
+ if(zoom > 3.0) zoom = 3.0;
+ this.changePageZoom(zoom);
+ },
+
+ zoomOutOneStep: function() {
+ var zoom = this.pageZoom - 0.1;
+ if(zoom < 0.3) zoom = 0.3;
+ this.changePageZoom(zoom);
+ },
+
+ changePageZoom: function(value) {
+ var current = this.$currentPage();
+
+ if(!current) return;
+
+ var alpha = value/this.pageZoom;
+ this.pageZoom = value;
+
+ var nwidth = current.attr('ui:width') * this.pageZoom;
+ var nheight = current.attr('ui:height') * this.pageZoom;
+ var off_top = parseInt(current.css('top'));
+ var off_left = parseInt(current.css('left'));
+
+ var vpx = this.$pageListRoot.width() * 0.5;
+ var vpy = this.$pageListRoot.height() * 0.5;
+
+ var new_off_left = vpx - alpha*(vpx-off_left);
+ var new_off_top = vpy - alpha*(vpy-off_top);
+
+ $('img', current).attr('width', nwidth);
+ $('img', current).attr('height', nheight);
+
+ this.setPageViewOffset(current, {
+ y: new_off_top, x: new_off_left
+ });
+
+ // this.$zoomSelect.val(this.pageZoom);
+ // console.log('Zoom is now', this.pageZoom);
+ },
- dispose: function() {
- this.model.removeObserver(this);
- this._super();
+ dispose: function()
+ {
+ console.log("Disposing gallery.");
+ this.model.removeObserver(this);
+ this._super();
}
});