updated marionette

pull/6/head
kay.one 12 years ago
parent 5ad5307a7b
commit 84cc7eaa68

@ -19,7 +19,6 @@ module.exports = function (grunt) {
'UI/JsLibraries/jquery.js' : 'http://code.jquery.com/jquery.js', 'UI/JsLibraries/jquery.js' : 'http://code.jquery.com/jquery.js',
'UI/JsLibraries/jquery.backstretch.js' : 'http://raw.github.com/srobbin/jquery-backstretch/master/jquery.backstretch.js', 'UI/JsLibraries/jquery.backstretch.js' : 'http://raw.github.com/srobbin/jquery-backstretch/master/jquery.backstretch.js',
'UI/JsLibraries/jquery.cookie.js' : 'http://raw.github.com/carhartl/jquery-cookie/master/jquery.cookie.js',
'UI/JsLibraries/jquery.signalR.js' : 'https://raw.github.com/SignalR/SignalR/master/samples/Microsoft.AspNet.SignalR.Hosting.AspNet.Samples/Scripts/jquery.signalR.js', 'UI/JsLibraries/jquery.signalR.js' : 'https://raw.github.com/SignalR/SignalR/master/samples/Microsoft.AspNet.SignalR.Hosting.AspNet.Samples/Scripts/jquery.signalR.js',

@ -1,6 +1,6 @@
// MarionetteJS (Backbone.Marionette) // MarionetteJS (Backbone.Marionette)
// ---------------------------------- // ----------------------------------
// v1.0.2 // v1.0.3
// //
// Copyright (c)2013 Derick Bailey, Muted Solutions, LLC. // Copyright (c)2013 Derick Bailey, Muted Solutions, LLC.
// Distributed under MIT license // Distributed under MIT license
@ -518,7 +518,7 @@ Marionette.extend = Backbone.Model.extend;
// -------------------- // --------------------
// Retrieve an object, function or other value from a target // Retrieve an object, function or other value from a target
// object or it's `options`, with `options` taking precedence. // object or its `options`, with `options` taking precedence.
Marionette.getOption = function(target, optionName){ Marionette.getOption = function(target, optionName){
if (!target || !optionName){ return; } if (!target || !optionName){ return; }
var value; var value;
@ -658,7 +658,7 @@ Marionette.MonitorDOMRefresh = (function(){
var methodNames = methods.split(/\s+/); var methodNames = methods.split(/\s+/);
_.each(methodNames,function(methodName) { _.each(methodNames,function(methodName) {
var method = target[method]; var method = target[methodName];
target.stopListening(entity, evt, method, target); target.stopListening(entity, evt, method, target);
}); });
} }
@ -899,18 +899,24 @@ _.extend(Marionette.Region.prototype, Backbone.Events, {
this.ensureEl(); this.ensureEl();
if (view !== this.currentView) { var isViewClosed = view.isClosed || _.isUndefined(view.$el);
var isDifferentView = view !== this.currentView;
if (isDifferentView) {
this.close(); this.close();
}
view.render(); view.render();
if (isDifferentView || isViewClosed) {
this.open(view); this.open(view);
} else {
view.render();
} }
Marionette.triggerMethod.call(view, "show");
Marionette.triggerMethod.call(this, "show", view);
this.currentView = view; this.currentView = view;
Marionette.triggerMethod.call(this, "show", view);
Marionette.triggerMethod.call(view, "show");
}, },
ensureEl: function(){ ensureEl: function(){
@ -1061,14 +1067,20 @@ Marionette.RegionManager = (function(Marionette){
// internal method to store regions // internal method to store regions
_store: function(name, region){ _store: function(name, region){
this._regions[name] = region; this._regions[name] = region;
this.length = _.size(this._regions); this._setLength();
}, },
// internal method to remove a region // internal method to remove a region
_remove: function(name, region){ _remove: function(name, region){
region.close(); region.close();
delete this._regions[name]; delete this._regions[name];
this._setLength();
this.triggerMethod("region:remove", name, region); this.triggerMethod("region:remove", name, region);
},
// set the number of regions current held
_setLength: function(){
this.length = _.size(this._regions);
} }
}); });
@ -1147,7 +1159,7 @@ _.extend(Marionette.TemplateCache, {
}); });
// TemplateCache instance methods, allowing each // TemplateCache instance methods, allowing each
// template cache object to manage it's own state // template cache object to manage its own state
// and know whether or not it has been loaded // and know whether or not it has been loaded
_.extend(Marionette.TemplateCache.prototype, { _.extend(Marionette.TemplateCache.prototype, {
@ -1202,7 +1214,20 @@ Marionette.Renderer = {
// template function. Override this method to provide your own // template function. Override this method to provide your own
// custom rendering and template handling for all of Marionette. // custom rendering and template handling for all of Marionette.
render: function(template, data){ render: function(template, data){
var templateFunc = typeof template === 'function' ? template : Marionette.TemplateCache.get(template);
if (!template) {
var error = new Error("Cannot render the template since it's false, null or undefined.");
error.name = "TemplateNotFoundError";
throw error;
}
var templateFunc;
if (typeof template === "function"){
templateFunc = template;
} else {
templateFunc = Marionette.TemplateCache.get(template);
}
return templateFunc(data); return templateFunc(data);
} }
}; };
@ -1268,7 +1293,7 @@ Marionette.View = Backbone.View.extend({
// build the event handler function for the DOM event // build the event handler function for the DOM event
triggerEvents[key] = function(e){ triggerEvents[key] = function(e){
// stop the event in it's tracks // stop the event in its tracks
if (e && e.preventDefault){ e.preventDefault(); } if (e && e.preventDefault){ e.preventDefault(); }
if (e && e.stopPropagation){ e.stopPropagation(); } if (e && e.stopPropagation){ e.stopPropagation(); }
@ -1394,9 +1419,6 @@ Marionette.View = Backbone.View.extend({
// with underscore.js templates, serializing the view's model or collection, // with underscore.js templates, serializing the view's model or collection,
// and calling several methods on extended views, such as `onRender`. // and calling several methods on extended views, such as `onRender`.
Marionette.ItemView = Marionette.View.extend({ Marionette.ItemView = Marionette.View.extend({
constructor: function(){
Marionette.View.prototype.constructor.apply(this, slice(arguments));
},
// Serialize the model or collection for the view. If a model is // Serialize the model or collection for the view. If a model is
// found, `.toJSON()` is called. If a collection is found, `.toJSON()` // found, `.toJSON()` is called. If a collection is found, `.toJSON()`
@ -1433,6 +1455,7 @@ Marionette.ItemView = Marionette.View.extend({
var template = this.getTemplate(); var template = this.getTemplate();
var html = Marionette.Renderer.render(template, data); var html = Marionette.Renderer.render(template, data);
this.$el.html(html); this.$el.html(html);
this.bindUIElements(); this.bindUIElements();
@ -1726,11 +1749,6 @@ Marionette.CollectionView = Marionette.View.extend({
// Extends directly from CollectionView and also renders an // Extends directly from CollectionView and also renders an
// an item view as `modelView`, for the top leaf // an item view as `modelView`, for the top leaf
Marionette.CompositeView = Marionette.CollectionView.extend({ Marionette.CompositeView = Marionette.CollectionView.extend({
constructor: function(options){
Marionette.CollectionView.apply(this, slice(arguments));
this.itemView = this.getItemView();
},
// Configured the initial events that the composite view // Configured the initial events that the composite view
// binds to. Override this method to prevent the initial // binds to. Override this method to prevent the initial
@ -1817,7 +1835,7 @@ Marionette.CompositeView = Marionette.CollectionView.extend({
// `itemViewContainer` (a jQuery selector). Override this method to // `itemViewContainer` (a jQuery selector). Override this method to
// provide custom logic of how the child item view instances have their // provide custom logic of how the child item view instances have their
// HTML appended to the composite view instance. // HTML appended to the composite view instance.
appendHtml: function(cv, iv){ appendHtml: function(cv, iv, index){
var $container = this.getItemViewContainer(cv); var $container = this.getItemViewContainer(cv);
$container.append(iv.el); $container.append(iv.el);
}, },

@ -152,19 +152,19 @@ Handlebars.registerHelper('each', function(context, options) {
return ret; return ret;
}); });
Handlebars.registerHelper('if', function(context, options) { Handlebars.registerHelper('if', function(conditional, options) {
var type = toString.call(context); var type = toString.call(conditional);
if(type === functionType) { context = context.call(this); } if(type === functionType) { conditional = conditional.call(this); }
if(!context || Handlebars.Utils.isEmpty(context)) { if(!conditional || Handlebars.Utils.isEmpty(conditional)) {
return options.inverse(this); return options.inverse(this);
} else { } else {
return options.fn(this); return options.fn(this);
} }
}); });
Handlebars.registerHelper('unless', function(context, options) { Handlebars.registerHelper('unless', function(conditional, options) {
return Handlebars.helpers['if'].call(this, context, {fn: options.inverse, inverse: options.fn}); return Handlebars.helpers['if'].call(this, conditional, {fn: options.inverse, inverse: options.fn});
}); });
Handlebars.registerHelper('with', function(context, options) { Handlebars.registerHelper('with', function(context, options) {

@ -1,7 +1,7 @@
/* jquery.signalR.core.js */ /* jquery.signalR.core.js */
/*global window:false */ /*global window:false */
/*! /*!
* ASP.NET SignalR JavaScript Library v1.1.0 * ASP.NET SignalR JavaScript Library v1.1.1
* http://signalr.net/ * http://signalr.net/
* *
* Copyright Microsoft Open Technologies, Inc. All rights reserved. * Copyright Microsoft Open Technologies, Inc. All rights reserved.
@ -2119,5 +2119,5 @@
/*global window:false */ /*global window:false */
/// <reference path="jquery.signalR.core.js" /> /// <reference path="jquery.signalR.core.js" />
(function ($) { (function ($) {
$.signalR.version = "1.1.0"; $.signalR.version = "1.1.1";
}(window.jQuery)); }(window.jQuery));

Loading…
Cancel
Save