%PDF- %PDF-
| Direktori : /home/lightco1/www/lightingrepublic.com.au/media/com_files/js/ |
| Current File : /home/lightco1/www/lightingrepublic.com.au/media/com_files/js/files.app.js |
/**
* @version $Id$
* @package Nooku_Components
* @subpackage Files
* @copyright Copyright (C) 2011 - 2012 Timble CVBA and Contributors. (http://www.timble.net).
* @license GNU GPLv3 <http://www.gnu.org/licenses/gpl.html>
* @link http://www.nooku.org
*/
if(!Files) var Files = {};
Files.blank_image = '';
Files.App = new Class({
Implements: [Events, Options],
_tmpl_cache: {},
active: null,
title: '',
cookie: null,
options: {
cookie: {
path: '/'
},
persistent: true,
thumbnails: true,
types: null,
container: null,
active: null,
title: 'files-title',
pathway: {
element: 'files-pathway'
},
state: {
defaults: {}
},
tree: {
enabled: true,
div: 'files-tree',
theme: ''
},
grid: {
element: 'files-grid',
batch_delete: '#files-batch-delete',
icon_size: 150
},
paginator: {
element: 'files-paginator'
},
history: {
enabled: true
},
router: {
defaults: {
option: 'com_files',
view: 'files',
format: 'json'
}
},
initial_response: null,
onAfterSetGrid: function(){
window.addEvent('resize', function(){
this.setDimensions(true);
}.bind(this));
this.grid.addEvent('onAfterRenew', function(){
this.setDimensions(true);
}.bind(this));
this.addEvent('onUploadFile', function(){
this.setDimensions(true);
}.bind(this));
},
onAfterNavigate: function(path) {
if (path !== undefined) {
this.setTitle(this.folder.name || this.container.title);
jQuery('#upload-files-to, .upload-files-to').text(this.container.title+(path ? '/'+path : ''));
}
}
},
initialize: function(options) {
this.setOptions(options);
if (this.options.persistent && this.options.container) {
var container = typeof this.options.container === 'string' ? this.options.container : this.options.container.slug;
this.cookie = 'com.files.container.'+container;
}
if(this.options.pathway) {
this.setPathway();
}
this.setState();
this.setHistory();
this.setGrid();
this.setPaginator();
var url = this.getUrl();
if (url.getData('container') && !this.options.container) {
this.options.container = url.getData('container');
}
if (url.getData('folder')) {
this.options.active = url.getData('folder');
}
if (this.options.title) {
this.options.title = document.id(this.options.title);
}
if (this.options.thumbnails) {
this.addEvent('afterSelect', function(resp) {
this.setThumbnails();
});
}
if (this.options.container) {
this.setContainer(this.options.container);
}
},
setState: function() {
this.fireEvent('beforeSetState');
if (this.cookie) {
var state = Cookie.read(this.cookie+'.state'),
obj = JSON.decode(state, true);
if (obj) {
if (!this.getUrl().getData('folder')) {
this.options.active = obj.folder;
}
delete obj.folder;
this.options.state.defaults = Files.utils.merge(this.options.state.defaults, obj);
}
}
var opts = this.options.state;
this.state = new Files.State(opts);
this.fireEvent('afterSetState');
},
setHistory: function() {
this.fireEvent('beforeSetHistory');
if (this.options.history.enabled) {
var that = this;
this.history = History;
window.addEvent('popstate', function(e) {
if (e) { e.stop(); }
var state = History.getState(),
old_state = that.state.getData(),
new_state = state.data,
state_changed = false;
Files.utils.each(old_state, function(value, key) {
if (state_changed === true) {
return;
}
if (new_state && new_state[key] && value !== new_state[key]) {
state_changed = true;
}
});
if (that.container && (state_changed || that.active !== state.data.folder)) {
var set_state = Files.utils.append({}, state.data);
['option', 'view', 'layout', 'folder', 'container'].each(function(key) {
delete set_state[key];
});
that.state.set(set_state);
that.navigate(state.data.folder, 'stateless');
}
});
this.addEvent('afterNavigate', function(path, type) {
if (type !== 'stateless' && that.history) {
var obj = {
folder: that.active,
container: that.container ? that.container.slug : null
};
obj = Files.utils.append(obj, that.state.getData());
var method = type === 'initial' ? 'replaceState' : 'pushState';
var url = that.getUrl().setData(obj, true).set('fragment', '').toString()
that.history[method](obj, null, url);
}
});
}
this.fireEvent('afterSetHistory');
},
/**
* type can be 'stateless' for no state or 'initial' to use replaceState
* response can be set if you want to set the results without an AJAX request.
*/
navigate: function(path, type, revalidate_cache, response) {
this.fireEvent('beforeNavigate', [path, type]);
if (path !== undefined) {
if (this.active) {
// Reset offset if we are changing folders
this.state.set('offset', 0);
}
this.active = path == '/' ? '' : path;
}
this.grid.reset();
var parts = this.active.split('/'),
name = parts[parts.length ? parts.length-1 : 0],
folder = parts.slice(0, parts.length-1).join('/'),
that = this
url_builder = function(url) {
if (revalidate_cache) {
url['revalidate_cache'] = 1;
}
return this.createRoute(url);
}.bind(this),
success = function(resp) {
if (resp.status !== false) {
Files.utils.each(resp.items, function(item) {
if (!item.baseurl) {
item.baseurl = that.baseurl;
}
});
that.response = resp;
that.grid.insertRows(resp.items);
that.fireEvent('afterSelect', resp);
} else {
alert(resp.error);
}
};
this.folder = new Files.Folder({'folder': folder, 'name': name});
if (response) {
success(response);
} else {
this.folder.getChildren(success, null, this.state.getData(), url_builder);
}
if (this.cookie) {
var data = jQuery.extend(true, {}, this.state.data);
data.folder = this.active;
Cookie.write(this.cookie+'.state', JSON.encode(data), this.options.cookie);
}
this.fireEvent('afterNavigate', [path, type]);
},
setContainer: function(container) {
var setter = function(item) {
this.fireEvent('beforeSetContainer', {container: item});
this.container = item;
this.baseurl = Files.sitebase + '/' + item.relative_path;
this.active = '';
if (this.uploader) {
if (this.container.parameters.allowed_extensions) {
this.uploader.settings.filters = [
{title: Files._('All Files'), extensions: this.container.parameters.allowed_extensions.join(',')}
];
}
if (this.container.parameters.maximum_size) {
this.uploader.settings.max_file_size = this.container.parameters.maximum_size;
var max_size = document.id('upload-max-size');
if (max_size) {
max_size.set('html', new Files.Filesize(this.container.parameters.maximum_size).humanize());
}
}
}
if (this.container.parameters.thumbnails !== true) {
this.options.thumbnails = false;
} else {
this.state.set('thumbnails', true);
}
if (this.options.types !== null) {
this.options.grid.types = this.options.types;
this.state.set('types', this.options.types);
}
this.fireEvent('afterSetContainer', {container: item});
this.setTree();
this.active = this.options.active || '';
this.options.active = '';
if (typeof this.options.initial_response === 'string') {
this.options.initial_response = JSON.decode(this.options.initial_response);
}
this.navigate(this.active, 'initial', false, this.options.initial_response);
}.bind(this);
if (typeof container === 'string') {
new Request.JSON({
url: this.createRoute({view: 'container', slug: container, container: false}),
method: 'get',
onSuccess: function(response) {
setter(response.item);
}.bind(this)
}).send();
} else {
setter(container);
}
},
setPaginator: function() {
this.fireEvent('beforeSetPaginator');
var opts = this.options.paginator,
state = this.state;
Files.utils.append(opts, {
'state' : state,
'onClickPage': function(el) {
this.state.set('limit', el.get('data-limit'));
this.state.set('offset', el.get('data-offset'));
this.navigate();
}.bind(this),
'onChangeLimit': function(limit) {
this.state.set('limit', limit);
// Recalculate offset
var total = Files.app.paginator.values.total,
offset = Files.app.paginator.values.offset;
if (total) {
var page_count = Math.ceil(total/limit);
offset = (page_count-1)*limit;
}
this.state.set('offset', offset);
this.navigate();
}.bind(this)
});
this.paginator = new Files.Paginator(opts.element, opts);
var that = this;
that.addEvent('afterSelect', function(response) {
that.paginator.setData({
limit: response.limit,
offset: response.offset,
total: response.total
});
that.paginator.setValues();
});
this.fireEvent('afterSetPaginator');
},
setGrid: function() {
this.fireEvent('beforeSetGrid');
var that = this,
opts = this.options.grid,
key = this.cookie+'.grid.layout';
if (this.cookie && Cookie.read(key)) {
opts.layout = Cookie.read(key);
}
Files.utils.append(opts, {
'onClickFolder': function(e) {
var target = document.id(e.target),
node = target.getParent('.files-node-shadow') || target.getParent('.files-node'),
path = node.retrieve('row').path;
if (path) {
this.navigate(path);
}
}.bind(this),
'onClickImage': function(e) {
var target = document.id(e.target),
node = target.getParent('.files-node-shadow') || target.getParent('.files-node'),
row = node.retrieve('row'),
img = that.createRoute({view: 'file', format: 'raw', name: row.name, folder: row.folder});
if (img) {
SqueezeBox.open(img, {handler: 'image'});
}
},
'onClickFile': function(e) {
var target = document.id(e.target),
node = target.getParent('.files-node-shadow') || target.getParent('.files-node'),
row = node.retrieve('row'),
copy = Files.utils.append({}, row),
trash = new Element('div', {style: 'display: none'}).inject(document.body);
copy.template = 'file_preview';
var template = copy.render().inject(trash), size = template.measure(function(){return this.getDimensions();});
SqueezeBox.open(template, {
handler: 'adopt',
size: {x: size.x, y: size.y}
});
trash.dispose();
},
'onAfterSetLayout': function(context) {
if (key) {
Cookie.write(key, context.layout, this.options.cookie);
}
}.bind(this)
});
this.grid = new Files.Grid(this.options.grid.element, opts);
this.fireEvent('afterSetGrid');
},
setTree: function() {
this.fireEvent('beforeSetTree');
if (this.options.tree.enabled) {
var opts = this.options.tree,
that = this;
Files.utils.append(opts, {
onClick: function(node) {
if (node.id || node.data.url) {
that.navigate(node && node.id ? node.id : '');
}
},
root: {
text: this.container.title,
data: {
url: '#'
}
}
});
this.tree = new Files.Tree(opts);
this.tree.fromUrl(this.createRoute({view: 'folders', 'tree': '1', 'limit': '0'}));
this.addEvent('afterNavigate', function(path) {
that.tree.selectPath(path);
});
if (this.grid) {
this.grid.addEvent('afterDeleteNode', function(context) {
var node = context.node;
if (node.type == 'folder') {
var item = that.tree.get(node.path);
if (item) {
item.remove();
}
}
});
}
}
this.fireEvent('afterSetTree');
},
getUrl: function() {
return new URI(window.location.href);
},
getPath: function() {
return this.active;
},
setThumbnails: function() {
this.setDimensions(true);
var nodes = this.grid.nodes,
that = this;
if (nodes.getLength()) {
nodes.each(function(node) {
if (node.filetype !== 'image') {
return;
}
var name = node.name;
var img = node.element.getElement('img.image-thumbnail');
if (img) {
img.addEvent('load', function(){
this.addClass('loaded');
});
img.set('src', node.thumbnail ? node.thumbnail : Files.blank_image);
(node.element.getElement('.files-node') || node.element).addClass('loaded').removeClass('loading');
if(window.sessionStorage) {
sessionStorage[node.image.toString()] = img.get('src');
}
}
});
}
},
setDimensions: function(force){
if(!this._cached_grid_width) this._cached_grid_width = 0;
//Only fire if the cache have changed
if(this._cached_grid_width != this.grid.root.element.getSize().x || force) {
var width = this.grid.root.element.getSize().x,
factor = width/(this.grid.options.icon_size.toInt()+40),
limit = Math.min(Math.floor(factor), this.grid.nodes.getLength()),
resize = width / limit,
thumbs = [[]],
labels = [[]],
index = 0,
pointer = 0;
this.grid.root.element.getElements('.files-node-shadow').each(function(element, i, elements){
element.setStyle('width', (100/limit)+'%');
}, this);
this._cached_grid_width = this.grid.root.element.getSize().x;
}
},
setPathway: function() {
this.fireEvent('beforeSetPathway');
var pathway = new Files.Pathway(this.options.pathway);
this.addEvent('afterSetTitle', pathway.setPath.bind(pathway, this));
this.fireEvent('afterSetPathway');
},
setTitle: function(title) {
this.fireEvent('beforeSetTitle', {title: title});
this.title = title;
if (this.options.title) {
this.options.title.set('html', title);
}
this.fireEvent('afterSetTitle', {title: title});
},
createRoute: function(query) {
query = Files.utils.merge(this.options.router.defaults, query || {});
if (query.container !== false && !query.container && this.container) {
query.container = this.container.slug;
} else {
delete query.container;
}
if (query.format == 'html') {
delete query.format;
}
return '?'+new Hash(query).filter(function(value, key) {
return typeof value !== 'function';
}).toQueryString();
}
});