mirror of https://github.com/perkeep/perkeep.git
189 lines
5.1 KiB
JavaScript
189 lines
5.1 KiB
JavaScript
/*
|
|
Copyright 2013 The Camlistore Authors.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
/**
|
|
* @fileoverview Pictures gallery page.
|
|
*
|
|
*/
|
|
goog.provide('camlistore.GalleryPage');
|
|
|
|
goog.require('goog.dom');
|
|
goog.require('goog.events.EventHandler');
|
|
goog.require('goog.events.EventType');
|
|
goog.require('goog.ui.Component');
|
|
goog.require('camlistore.ServerConnection');
|
|
|
|
/**
|
|
* @param {camlistore.ServerType.DiscoveryDocument} config Global config
|
|
* of the current server this page is being rendered for.
|
|
* @param {goog.dom.DomHelper=} opt_domHelper DOM helper to use.
|
|
*
|
|
* @extends {goog.ui.Component}
|
|
* @constructor
|
|
*/
|
|
camlistore.GalleryPage = function(config, opt_domHelper) {
|
|
goog.base(this, opt_domHelper);
|
|
|
|
/**
|
|
* @type {Object}
|
|
* @private
|
|
*/
|
|
this.config_ = config;
|
|
|
|
/**
|
|
* @type {camlistore.ServerConnection}
|
|
* @private
|
|
*/
|
|
this.connection_ = new camlistore.ServerConnection(config);
|
|
};
|
|
goog.inherits(camlistore.GalleryPage, goog.ui.Component);
|
|
|
|
|
|
/**
|
|
* Decorates an existing HTML DIV element.
|
|
* @param {Element} element The DIV element to decorate.
|
|
*/
|
|
camlistore.GalleryPage.prototype.decorateInternal = function(element) {
|
|
camlistore.GalleryPage.superClass_.decorateInternal.call(this, element);
|
|
};
|
|
|
|
|
|
/** @override */
|
|
camlistore.GalleryPage.prototype.disposeInternal = function() {
|
|
camlistore.GalleryPage.superClass_.disposeInternal.call(this);
|
|
};
|
|
|
|
|
|
/**
|
|
* Called when component's element is known to be in the document.
|
|
*/
|
|
camlistore.GalleryPage.prototype.enterDocument = function() {
|
|
camlistore.GalleryPage.superClass_.enterDocument.call(this);
|
|
|
|
var members = goog.dom.getElement('members');
|
|
if (!members) {
|
|
return;
|
|
}
|
|
var children = goog.dom.getChildren(members);
|
|
if (!children || children.length < 1) {
|
|
return;
|
|
}
|
|
goog.array.forEach(children, function(li) {
|
|
li.src = li.src + '&square=1';
|
|
})
|
|
|
|
if (camliViewIsOwner) {
|
|
var el = this.getElement();
|
|
goog.dom.classes.add(el, 'camliadmin');
|
|
|
|
goog.array.forEach(children, function(li) {
|
|
var lichild = goog.dom.getFirstElementChild(li);
|
|
var titleSpan = goog.dom.getLastElementChild(lichild);
|
|
var editLink = goog.dom.createElement('a', {'href': '#'});
|
|
goog.dom.classes.add(editLink, 'hidden');
|
|
goog.dom.setTextContent(editLink, 'edit title');
|
|
|
|
var titleInput = goog.dom.createElement('input');
|
|
goog.dom.classes.add(titleInput, 'hidden');
|
|
|
|
goog.events.listen(editLink,
|
|
goog.events.EventType.CLICK,
|
|
function(e) {
|
|
goog.dom.classes.remove(titleSpan, 'visible');
|
|
goog.dom.classes.add(titleSpan, 'hidden');
|
|
goog.dom.classes.remove(titleInput, 'hidden');
|
|
goog.dom.classes.add(titleInput, 'visible');
|
|
titleInput.focus();
|
|
titleInput.select();
|
|
e.stopPropagation();
|
|
e.preventDefault();
|
|
},
|
|
false, this
|
|
);
|
|
goog.events.listen(li,
|
|
goog.events.EventType.MOUSEOVER,
|
|
function(e) {
|
|
goog.dom.classes.remove(editLink, 'hidden');
|
|
goog.dom.classes.add(editLink, 'title-edit');
|
|
},
|
|
false, this
|
|
);
|
|
goog.events.listen(li,
|
|
goog.events.EventType.MOUSEOUT,
|
|
function(e) {
|
|
goog.dom.classes.remove(editLink, 'title-edit');
|
|
goog.dom.classes.add(editLink, 'hidden');
|
|
goog.dom.classes.remove(titleInput, 'visible');
|
|
goog.dom.classes.add(titleInput, 'hidden');
|
|
goog.dom.classes.remove(titleSpan, 'hidden');
|
|
goog.dom.classes.add(titleSpan, 'visible');
|
|
},
|
|
false, this
|
|
);
|
|
goog.events.listen(titleInput,
|
|
goog.events.EventType.KEYPRESS,
|
|
goog.bind(function(e) {
|
|
if (e.keyCode == 13) {
|
|
this.saveImgTitle_(titleInput, titleSpan);
|
|
}
|
|
}, this),
|
|
false, this
|
|
);
|
|
goog.dom.insertSiblingBefore(editLink, titleSpan);
|
|
goog.dom.insertChildAt(li, titleInput, 1);
|
|
}, this
|
|
)
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param {string} titleInput text field element for title
|
|
* @param {string} titleSpan span element containing the title
|
|
* @private
|
|
*/
|
|
camlistore.GalleryPage.prototype.saveImgTitle_ =
|
|
function (titleInput, titleSpan) {
|
|
var spanText = goog.dom.getTextContent(titleSpan);
|
|
var newVal = titleInput.value;
|
|
if (newVal != "" && newVal != spanText) {
|
|
goog.dom.setTextContent(titleSpan, newVal);
|
|
var blobRef = goog.dom.getParentElement(titleInput).id.replace(/^camli-/, '');
|
|
this.connection_.newSetAttributeClaim(
|
|
blobRef,
|
|
"title",
|
|
newVal,
|
|
function() {
|
|
},
|
|
function(msg) {
|
|
alert(msg);
|
|
}
|
|
);
|
|
}
|
|
goog.dom.classes.remove(titleInput, 'visible');
|
|
goog.dom.classes.add(titleInput, 'hidden');
|
|
goog.dom.classes.remove(titleSpan, 'hidden');
|
|
goog.dom.classes.add(titleSpan, 'visible');
|
|
}
|
|
|
|
/**
|
|
* Called when component's element is known to have been removed from the
|
|
* document.
|
|
*/
|
|
camlistore.GalleryPage.prototype.exitDocument = function() {
|
|
camlistore.GalleryPage.superClass_.exitDocument.call(this);
|
|
};
|
|
|