Commit bf2698d5 authored by Pascal Hartig's avatar Pascal Hartig

Flight: Upgrade to 1.1.1

parent 16adcca6
...@@ -4,16 +4,14 @@ ...@@ -4,16 +4,14 @@
// http://opensource.org/licenses/MIT // http://opensource.org/licenses/MIT
// ========================================== // ==========================================
"use strict";
define( define(
[ [
'./utils',
'./compose' './compose'
], ],
function (util, compose) { function(compose) {
'use strict';
var advice = { var advice = {
...@@ -25,7 +23,7 @@ define( ...@@ -25,7 +23,7 @@ define(
for (; i < l; i++) args[i + 1] = arguments[i]; for (; i < l; i++) args[i + 1] = arguments[i];
return wrapped.apply(this, args); return wrapped.apply(this, args);
} };
}, },
before: function(base, before) { before: function(base, before) {
...@@ -33,7 +31,7 @@ define( ...@@ -33,7 +31,7 @@ define(
return function composedBefore() { return function composedBefore() {
beforeFn.apply(this, arguments); beforeFn.apply(this, arguments);
return base.apply(this, arguments); return base.apply(this, arguments);
} };
}, },
after: function(base, after) { after: function(base, after) {
...@@ -42,7 +40,7 @@ define( ...@@ -42,7 +40,7 @@ define(
var res = (base.unbound || base).apply(this, arguments); var res = (base.unbound || base).apply(this, arguments);
afterFn.apply(this, arguments); afterFn.apply(this, arguments);
return res; return res;
} };
}, },
// a mixin that allows other mixins to augment existing functions by adding additional // a mixin that allows other mixins to augment existing functions by adding additional
...@@ -53,10 +51,12 @@ define( ...@@ -53,10 +51,12 @@ define(
compose.unlockProperty(this, method, function() { compose.unlockProperty(this, method, function() {
if (typeof this[method] == 'function') { if (typeof this[method] == 'function') {
return this[method] = advice[m](this[method], fn); this[method] = advice[m](this[method], fn);
} else { } else {
return this[method] = fn; this[method] = fn;
} }
return this[method];
}); });
}; };
......
// ==========================================
// Copyright 2013 Twitter, Inc
// Licensed under The MIT License
// http://opensource.org/licenses/MIT
// ==========================================
define( define(
[ [
'./utils', './utils',
'./registry', './registry',
'./debug' './debug'
], ],
function(utils, registry, debug) { function(utils, registry, debug) {
//common mixin allocates basic functionality - used by all component prototypes 'use strict';
//callback context is bound to component
var componentId = 0;
function teardownInstance(instanceInfo){ // common mixin allocates basic functionality - used by all component prototypes
instanceInfo.events.slice().forEach(function(event) { // callback context is bound to component
var args = [event.type]; var componentId = 0;
event.element && args.unshift(event.element); function teardownInstance(instanceInfo){
(typeof event.callback == 'function') && args.push(event.callback); instanceInfo.events.slice().forEach(function(event) {
var args = [event.type];
this.off.apply(this, args); event.element && args.unshift(event.element);
}, instanceInfo.instance); (typeof event.callback == 'function') && args.push(event.callback);
}
function checkSerializable(type, data) { this.off.apply(this, args);
try { }, instanceInfo.instance);
window.postMessage(data, '*');
} catch(e) {
console.log('unserializable data for event',type,':',data);
throw new Error(
["The event", type, "on component", this.toString(), "was triggered with non-serializable data"].join(" ")
);
} }
}
function withBase() { function checkSerializable(type, data) {
try {
// delegate trigger, bind and unbind to an element window.postMessage(data, '*');
// if $element not supplied, use component's node } catch(e) {
// other arguments are passed on console.log('unserializable data for event',type,':',data);
// event can be either a string specifying the type throw new Error(
// of the event, or a hash specifying both the type ['The event', type, 'on component', this.toString(), 'was triggered with non-serializable data'].join(' ')
// and a default function to be called. );
this.trigger = function() {
var $element, type, data, event, defaultFn;
var lastIndex = arguments.length - 1, lastArg = arguments[lastIndex];
if (typeof lastArg != "string" && !(lastArg && lastArg.defaultBehavior)) {
lastIndex--;
data = lastArg;
}
if (lastIndex == 1) {
$element = $(arguments[0]);
event = arguments[1];
} else {
$element = this.$node;
event = arguments[0];
}
if (event.defaultBehavior) {
defaultFn = event.defaultBehavior;
event = $.Event(event.type);
} }
}
type = event.type || event; function withBase() {
// delegate trigger, bind and unbind to an element
// if $element not supplied, use component's node
// other arguments are passed on
// event can be either a string specifying the type
// of the event, or a hash specifying both the type
// and a default function to be called.
this.trigger = function() {
var $element, type, data, event, defaultFn;
var lastIndex = arguments.length - 1, lastArg = arguments[lastIndex];
if (typeof lastArg != 'string' && !(lastArg && lastArg.defaultBehavior)) {
lastIndex--;
data = lastArg;
}
if (debug.enabled && window.postMessage) { if (lastIndex == 1) {
checkSerializable.call(this, type, data); $element = $(arguments[0]);
} event = arguments[1];
} else {
$element = this.$node;
event = arguments[0];
}
if (typeof this.attr.eventData === 'object') { if (event.defaultBehavior) {
data = $.extend(true, {}, this.attr.eventData, data); defaultFn = event.defaultBehavior;
} event = $.Event(event.type);
}
$element.trigger((event || type), data); type = event.type || event;
if (defaultFn && !event.isDefaultPrevented()) { if (debug.enabled && window.postMessage) {
(this[defaultFn] || defaultFn).call(this); checkSerializable.call(this, type, data);
} }
return $element; if (typeof this.attr.eventData === 'object') {
}; data = $.extend(true, {}, this.attr.eventData, data);
}
this.on = function() { $element.trigger((event || type), data);
var $element, type, callback, originalCb;
var lastIndex = arguments.length - 1, origin = arguments[lastIndex];
if (typeof origin == "object") { if (defaultFn && !event.isDefaultPrevented()) {
//delegate callback (this[defaultFn] || defaultFn).call(this);
originalCb = utils.delegate( }
this.resolveDelegateRules(origin)
);
} else {
originalCb = origin;
}
if (lastIndex == 2) { return $element;
$element = $(arguments[0]); };
type = arguments[1];
} else {
$element = this.$node;
type = arguments[0];
}
if (typeof originalCb != 'function' && typeof originalCb != 'object') { this.on = function() {
throw new Error("Unable to bind to '" + type + "' because the given callback is not a function or an object"); var $element, type, callback, originalCb;
} var lastIndex = arguments.length - 1, origin = arguments[lastIndex];
callback = originalCb.bind(this); if (typeof origin == 'object') {
callback.target = originalCb; //delegate callback
originalCb = utils.delegate(
this.resolveDelegateRules(origin)
);
} else {
originalCb = origin;
}
// if the original callback is already branded by jQuery's guid, copy it to the context-bound version if (lastIndex == 2) {
if (originalCb.guid) { $element = $(arguments[0]);
callback.guid = originalCb.guid; type = arguments[1];
} } else {
$element = this.$node;
type = arguments[0];
}
$element.on(type, callback); if (typeof originalCb != 'function' && typeof originalCb != 'object') {
throw new Error('Unable to bind to "' + type + '" because the given callback is not a function or an object');
}
// get jquery's guid from our bound fn, so unbinding will work callback = originalCb.bind(this);
originalCb.guid = callback.guid; callback.target = originalCb;
return callback; // if the original callback is already branded by jQuery's guid, copy it to the context-bound version
}; if (originalCb.guid) {
callback.guid = originalCb.guid;
}
this.off = function() { $element.on(type, callback);
var $element, type, callback;
var lastIndex = arguments.length - 1;
if (typeof arguments[lastIndex] == "function") { // get jquery's guid from our bound fn, so unbinding will work
callback = arguments[lastIndex]; originalCb.guid = callback.guid;
lastIndex -= 1;
}
if (lastIndex == 1) { return callback;
$element = $(arguments[0]); };
type = arguments[1];
} else {
$element = this.$node;
type = arguments[0];
}
return $element.off(type, callback); this.off = function() {
}; var $element, type, callback;
var lastIndex = arguments.length - 1;
this.resolveDelegateRules = function(ruleInfo) { if (typeof arguments[lastIndex] == 'function') {
var rules = {}; callback = arguments[lastIndex];
lastIndex -= 1;
}
Object.keys(ruleInfo).forEach(function(r) { if (lastIndex == 1) {
if (!(r in this.attr)) { $element = $(arguments[0]);
throw new Error('Component "' + this.toString() + '" wants to listen on "' + r + '" but no such attribute was defined.'); type = arguments[1];
} else {
$element = this.$node;
type = arguments[0];
} }
rules[this.attr[r]] = ruleInfo[r];
}, this);
return rules; return $element.off(type, callback);
}; };
this.defaultAttrs = function(defaults) { this.resolveDelegateRules = function(ruleInfo) {
utils.push(this.defaults, defaults, true) || (this.defaults = defaults); var rules = {};
};
this.select = function(attributeKey) { Object.keys(ruleInfo).forEach(function(r) {
return this.$node.find(this.attr[attributeKey]); if (!(r in this.attr)) {
}; throw new Error('Component "' + this.toString() + '" wants to listen on "' + r + '" but no such attribute was defined.');
}
rules[this.attr[r]] = ruleInfo[r];
}, this);
this.initialize = function(node, attrs) { return rules;
attrs = attrs || {}; };
this.identity = componentId++;
if (!node) { this.defaultAttrs = function(defaults) {
throw new Error("Component needs a node"); utils.push(this.defaults, defaults, true) || (this.defaults = defaults);
} };
if (node.jquery) { this.select = function(attributeKey) {
this.node = node[0]; return this.$node.find(this.attr[attributeKey]);
this.$node = node; };
} else {
this.node = node;
this.$node = $(node);
}
//merge defaults with supplied options this.initialize = function(node, attrs) {
//put options in attr.__proto__ to avoid merge overhead attrs || (attrs = {});
var attr = Object.create(attrs); //only assign identity if there isn't one (initialize can be called multiple times)
for (var key in this.defaults) { this.identity || (this.identity = componentId++);
if (!attrs.hasOwnProperty(key)) {
attr[key] = this.defaults[key]; if (!node) {
throw new Error('Component needs a node');
} }
}
this.attr = attr; if (node.jquery) {
this.node = node[0];
this.$node = node;
} else {
this.node = node;
this.$node = $(node);
}
Object.keys(this.defaults || {}).forEach(function(key) { // merge defaults with supplied options
if (this.defaults[key] === null && this.attr[key] === null) { // put options in attr.__proto__ to avoid merge overhead
throw new Error('Required attribute "' + key + '" not specified in attachTo for component "' + this.toString() + '".'); var attr = Object.create(attrs);
for (var key in this.defaults) {
if (!attrs.hasOwnProperty(key)) {
attr[key] = this.defaults[key];
}
} }
}, this);
return this; this.attr = attr;
Object.keys(this.defaults || {}).forEach(function(key) {
if (this.defaults[key] === null && this.attr[key] === null) {
throw new Error('Required attribute "' + key + '" not specified in attachTo for component "' + this.toString() + '".');
}
}, this);
return this;
};
this.teardown = function() {
teardownInstance(registry.findInstanceInfo(this));
};
} }
this.teardown = function() { return withBase;
teardownInstance(registry.findInstanceInfo(this));
};
} }
);
return withBase;
});
...@@ -4,8 +4,6 @@ ...@@ -4,8 +4,6 @@
// http://opensource.org/licenses/MIT // http://opensource.org/licenses/MIT
// ========================================== // ==========================================
"use strict";
define( define(
[ [
...@@ -19,10 +17,11 @@ define( ...@@ -19,10 +17,11 @@ define(
], ],
function(advice, utils, compose, withBase, registry, withLogging, debug) { function(advice, utils, compose, withBase, registry, withLogging, debug) {
'use strict';
var functionNameRegEx = /function (.*?)\s?\(/; var functionNameRegEx = /function (.*?)\s?\(/;
//teardown for all instances of this constructor // teardown for all instances of this constructor
function teardownAll() { function teardownAll() {
var componentInfo = registry.findComponentInfo(this); var componentInfo = registry.findComponentInfo(this);
...@@ -38,7 +37,7 @@ define( ...@@ -38,7 +37,7 @@ define(
} catch(e) { } catch(e) {
console.log('unserializable data for event',type,':',data); console.log('unserializable data for event',type,':',data);
throw new Error( throw new Error(
["The event", type, "on component", this.toString(), "was triggered with non-serializable data"].join(" ") ['The event', type, 'on component', this.toString(), 'was triggered with non-serializable data'].join(' ')
); );
} }
} }
...@@ -50,16 +49,15 @@ define( ...@@ -50,16 +49,15 @@ define(
for (var i = 1; i < l; i++) args[i - 1] = arguments[i]; for (var i = 1; i < l; i++) args[i - 1] = arguments[i];
if (!selector) { if (!selector) {
throw new Error("Component needs to be attachTo'd a jQuery object, native node or selector string"); throw new Error('Component needs to be attachTo\'d a jQuery object, native node or selector string');
} }
var options = utils.merge.apply(utils, args); var options = utils.merge.apply(utils, args);
var componentInfo = registry.findComponentInfo(this);
$(selector).each(function(i, node) { $(selector).each(function(i, node) {
var rawNode = node.jQuery ? node[0] : node; if (componentInfo && componentInfo.isAttachedTo(node)) {
var componentInfo = registry.findComponentInfo(this) // already attached
if (componentInfo && componentInfo.isAttachedTo(rawNode)) {
//already attached
return; return;
} }
...@@ -73,7 +71,8 @@ define( ...@@ -73,7 +71,8 @@ define(
function define(/*mixins*/) { function define(/*mixins*/) {
// unpacking arguments by hand benchmarked faster // unpacking arguments by hand benchmarked faster
var l = arguments.length; var l = arguments.length;
var mixins = new Array(l + 3); //add three for common mixins // add three for common mixins
var mixins = new Array(l + 3);
for (var i = 0; i < l; i++) mixins[i] = arguments[i]; for (var i = 0; i < l; i++) mixins[i] = arguments[i];
var Component = function() {}; var Component = function() {};
...@@ -81,11 +80,11 @@ define( ...@@ -81,11 +80,11 @@ define(
Component.toString = Component.prototype.toString = function() { Component.toString = Component.prototype.toString = function() {
var prettyPrintMixins = mixins.map(function(mixin) { var prettyPrintMixins = mixins.map(function(mixin) {
if (mixin.name == null) { if (mixin.name == null) {
//function name property not supported by this browser, use regex // function name property not supported by this browser, use regex
var m = mixin.toString().match(functionNameRegEx); var m = mixin.toString().match(functionNameRegEx);
return (m && m[1]) ? m[1] : ""; return (m && m[1]) ? m[1] : '';
} else { } else {
return (mixin.name != "withBase") ? mixin.name : ""; return (mixin.name != 'withBase') ? mixin.name : '';
} }
}).filter(Boolean).join(', '); }).filter(Boolean).join(', ');
return prettyPrintMixins; return prettyPrintMixins;
...@@ -95,7 +94,7 @@ define( ...@@ -95,7 +94,7 @@ define(
Component.describe = Component.prototype.describe = Component.toString(); Component.describe = Component.prototype.describe = Component.toString();
} }
//'options' is optional hash to be merged with 'defaults' in the component definition // 'options' is optional hash to be merged with 'defaults' in the component definition
Component.attachTo = attachTo; Component.attachTo = attachTo;
Component.teardownAll = teardownAll; Component.teardownAll = teardownAll;
......
...@@ -4,8 +4,6 @@ ...@@ -4,8 +4,6 @@
// http://opensource.org/licenses/MIT // http://opensource.org/licenses/MIT
// ========================================== // ==========================================
"use strict";
define( define(
[ [
...@@ -13,10 +11,11 @@ define( ...@@ -13,10 +11,11 @@ define(
'./debug' './debug'
], ],
function(util, debug) { function(utils, debug) {
'use strict';
//enumerables are shims - getOwnPropertyDescriptor shim doesn't work //enumerables are shims - getOwnPropertyDescriptor shim doesn't work
var canWriteProtect = debug.enabled && !util.isEnumerable(Object, 'getOwnPropertyDescriptor'); var canWriteProtect = debug.enabled && !utils.isEnumerable(Object, 'getOwnPropertyDescriptor');
//whitelist of unlockable property names //whitelist of unlockable property names
var dontLock = ['mixedIn']; var dontLock = ['mixedIn'];
......
"use strict"; // ==========================================
// Copyright 2013 Twitter, Inc
// Licensed under The MIT License
// http://opensource.org/licenses/MIT
// ==========================================
define([], function() { define(
var logFilter; [],
function() {
'use strict';
//****************************************************************************************** //******************************************************************************************
// Search object model // Search object model
//****************************************************************************************** //******************************************************************************************
function traverse(util, searchTerm, options) { function traverse(util, searchTerm, options) {
var options = options || {}; options = options || {};
var obj = options.obj || window; var obj = options.obj || window;
var path = options.path || ((obj==window) ? "window" : ""); var path = options.path || ((obj==window) ? 'window' : '');
var props = Object.keys(obj); var props = Object.keys(obj);
props.forEach(function(prop) { props.forEach(function(prop) {
if ((tests[util] || util)(searchTerm, obj, prop)){ if ((tests[util] || util)(searchTerm, obj, prop)){
console.log([path, ".", prop].join(""), "->",["(", typeof obj[prop], ")"].join(""), obj[prop]); console.log([path, '.', prop].join(''), '->', ['(', typeof obj[prop], ')'].join(''), obj[prop]);
} }
if(Object.prototype.toString.call(obj[prop])=="[object Object]" && (obj[prop] != obj) && path.split(".").indexOf(prop) == -1) { if (Object.prototype.toString.call(obj[prop]) == '[object Object]' && (obj[prop] != obj) && path.split('.').indexOf(prop) == -1) {
traverse(util, searchTerm, {obj: obj[prop], path: [path,prop].join(".")}); traverse(util, searchTerm, {obj: obj[prop], path: [path,prop].join('.')});
} }
}); });
} }
...@@ -27,24 +34,24 @@ define([], function() { ...@@ -27,24 +34,24 @@ define([], function() {
if (!expected || typeof searchTerm == expected) { if (!expected || typeof searchTerm == expected) {
traverse(util, searchTerm, options); traverse(util, searchTerm, options);
} else { } else {
console.error([searchTerm, 'must be', expected].join(' ')) console.error([searchTerm, 'must be', expected].join(' '));
} }
} }
var tests = { var tests = {
'name': function(searchTerm, obj, prop) {return searchTerm == prop}, 'name': function(searchTerm, obj, prop) {return searchTerm == prop;},
'nameContains': function(searchTerm, obj, prop) {return prop.indexOf(searchTerm)>-1}, 'nameContains': function(searchTerm, obj, prop) {return prop.indexOf(searchTerm) > -1;},
'type': function(searchTerm, obj, prop) {return obj[prop] instanceof searchTerm}, 'type': function(searchTerm, obj, prop) {return obj[prop] instanceof searchTerm;},
'value': function(searchTerm, obj, prop) {return obj[prop] === searchTerm}, 'value': function(searchTerm, obj, prop) {return obj[prop] === searchTerm;},
'valueCoerced': function(searchTerm, obj, prop) {return obj[prop] == searchTerm} 'valueCoerced': function(searchTerm, obj, prop) {return obj[prop] == searchTerm;}
} };
function byName(searchTerm, options) {search('name', 'string', searchTerm, options);}; function byName(searchTerm, options) {search('name', 'string', searchTerm, options);}
function byNameContains(searchTerm, options) {search('nameContains', 'string', searchTerm, options);}; function byNameContains(searchTerm, options) {search('nameContains', 'string', searchTerm, options);}
function byType(searchTerm, options) {search('type', 'function', searchTerm, options);}; function byType(searchTerm, options) {search('type', 'function', searchTerm, options);}
function byValue(searchTerm, options) {search('value', null, searchTerm, options);}; function byValue(searchTerm, options) {search('value', null, searchTerm, options);}
function byValueCoerced(searchTerm, options) {search('valueCoerced', null, searchTerm, options);}; function byValueCoerced(searchTerm, options) {search('valueCoerced', null, searchTerm, options);}
function custom(fn, options) {traverse(fn, null, options);}; function custom(fn, options) {traverse(fn, null, options);}
//****************************************************************************************** //******************************************************************************************
// Event logging // Event logging
...@@ -98,7 +105,8 @@ define([], function() { ...@@ -98,7 +105,8 @@ define([], function() {
eventNames: (window.localStorage && localStorage.getItem('logFilter_eventNames')) || defaultEventNamesFilter, eventNames: (window.localStorage && localStorage.getItem('logFilter_eventNames')) || defaultEventNamesFilter,
actions: (window.localStorage && localStorage.getItem('logFilter_actions')) || defaultActionsFilter actions: (window.localStorage && localStorage.getItem('logFilter_actions')) || defaultActionsFilter
}; };
//reconstitute arrays
// reconstitute arrays
Object.keys(result).forEach(function(k) { Object.keys(result).forEach(function(k) {
var thisProp = result[k]; var thisProp = result[k];
if (typeof thisProp == 'string' && thisProp !== ALL) { if (typeof thisProp == 'string' && thisProp !== ALL) {
...@@ -147,4 +155,3 @@ define([], function() { ...@@ -147,4 +155,3 @@ define([], function() {
}; };
} }
); );
...@@ -15,7 +15,8 @@ define( ...@@ -15,7 +15,8 @@ define(
'./utils' './utils'
], ],
function (advice, component, compose, logger, registry, utils) { function(advice, component, compose, logger, registry, utils) {
'use strict';
return { return {
advice: advice, advice: advice,
......
...@@ -4,41 +4,38 @@ ...@@ -4,41 +4,38 @@
// http://opensource.org/licenses/MIT // http://opensource.org/licenses/MIT
// ========================================== // ==========================================
"use strict";
define( define(
[ [
'./compose',
'./utils' './utils'
], ],
function (compose, util) { function(utils) {
'use strict';
var actionSymbols = { var actionSymbols = {
on:'<-', on: '<-',
trigger: '->', trigger: '->',
off: 'x ' off: 'x '
}; };
function elemToString(elem) { function elemToString(elem) {
var tagStr = elem.tagName ? elem.tagName.toLowerCase() : elem.toString(); var tagStr = elem.tagName ? elem.tagName.toLowerCase() : elem.toString();
var classStr = elem.className ? "." + (elem.className) : ""; var classStr = elem.className ? '.' + (elem.className) : '';
var result = tagStr + classStr; var result = tagStr + classStr;
return elem.tagName ? ['\'', '\''].join(result) : result; return elem.tagName ? ['\'', '\''].join(result) : result;
} }
function log(action, component, eventArgs) { function log(action, component, eventArgs) {
var name, elem, fn, logFilter, toRegExp, actionLoggable, nameLoggable;
var name, elem, fn, fnName, logFilter, toRegExp, actionLoggable, nameLoggable;
if (typeof eventArgs[eventArgs.length-1] == 'function') { if (typeof eventArgs[eventArgs.length-1] == 'function') {
fn = eventArgs.pop(); fn = eventArgs.pop();
fn = fn.unbound || fn; //use unbound version if any (better info) fn = fn.unbound || fn; // use unbound version if any (better info)
} }
if (typeof eventArgs[eventArgs.length - 1] == 'object') { if (typeof eventArgs[eventArgs.length - 1] == 'object') {
eventArgs.pop(); //trigger data arg - not logged right now eventArgs.pop(); // trigger data arg - not logged right now
} }
if (eventArgs.length == 2) { if (eventArgs.length == 2) {
...@@ -53,14 +50,14 @@ define( ...@@ -53,14 +50,14 @@ define(
logFilter = DEBUG.events.logFilter; logFilter = DEBUG.events.logFilter;
// no regex for you, actions... // no regex for you, actions...
actionLoggable = logFilter.actions=="all" || (logFilter.actions.indexOf(action) > -1); actionLoggable = logFilter.actions == 'all' || (logFilter.actions.indexOf(action) > -1);
// event name filter allow wildcards or regex... // event name filter allow wildcards or regex...
toRegExp = function(expr) { toRegExp = function(expr) {
return expr.test ? expr : new RegExp("^" + expr.replace(/\*/g, ".*") + "$"); return expr.test ? expr : new RegExp('^' + expr.replace(/\*/g, '.*') + '$');
}; };
nameLoggable = nameLoggable =
logFilter.eventNames=="all" || logFilter.eventNames == 'all' ||
logFilter.eventNames.some(function(e) {return toRegExp(e).test(name)}); logFilter.eventNames.some(function(e) {return toRegExp(e).test(name);});
if (actionLoggable && nameLoggable) { if (actionLoggable && nameLoggable) {
console.info( console.info(
...@@ -68,7 +65,7 @@ define( ...@@ -68,7 +65,7 @@ define(
action, action,
'[' + name + ']', '[' + name + ']',
elemToString(elem), elemToString(elem),
component.constructor.describe.split(' ').slice(0,3).join(' ') //two mixins only component.constructor.describe.split(' ').slice(0,3).join(' ') // two mixins only
); );
} }
} }
...@@ -76,13 +73,13 @@ define( ...@@ -76,13 +73,13 @@ define(
function withLogging() { function withLogging() {
this.before('trigger', function() { this.before('trigger', function() {
log('trigger', this, util.toArray(arguments)); log('trigger', this, utils.toArray(arguments));
}); });
this.before('on', function() { this.before('on', function() {
log('on', this, util.toArray(arguments)); log('on', this, utils.toArray(arguments));
}); });
this.before('off', function(eventArgs) { this.before('off', function() {
log('off', this, util.toArray(arguments)); log('off', this, utils.toArray(arguments));
}); });
} }
......
...@@ -4,15 +4,12 @@ ...@@ -4,15 +4,12 @@
// http://opensource.org/licenses/MIT // http://opensource.org/licenses/MIT
// ========================================== // ==========================================
"use strict";
define( define(
[ [],
'./utils'
],
function (util) { function() {
'use strict';
function parseEventArgs(instance, args) { function parseEventArgs(instance, args) {
var element, type, callback; var element, type, callback;
...@@ -71,7 +68,7 @@ define( ...@@ -71,7 +68,7 @@ define(
this.attachedTo.push(instance.node); this.attachedTo.push(instance.node);
return instanceInfo; return instanceInfo;
} };
this.removeInstance = function(instance) { this.removeInstance = function(instance) {
delete this.instances[instance.identity]; delete this.instances[instance.identity];
...@@ -82,11 +79,11 @@ define( ...@@ -82,11 +79,11 @@ define(
//if I hold no more instances remove me from registry //if I hold no more instances remove me from registry
registry.removeComponentInfo(this); registry.removeComponentInfo(this);
} }
} };
this.isAttachedTo = function(node) { this.isAttachedTo = function(node) {
return this.attachedTo.indexOf(node) > -1; return this.attachedTo.indexOf(node) > -1;
} };
} }
function InstanceInfo(instance) { function InstanceInfo(instance) {
...@@ -104,7 +101,7 @@ define( ...@@ -104,7 +101,7 @@ define(
this.events.splice(i, 1); this.events.splice(i, 1);
} }
} }
} };
} }
this.addInstance = function(instance) { this.addInstance = function(instance) {
...@@ -135,7 +132,7 @@ define( ...@@ -135,7 +132,7 @@ define(
this.removeComponentInfo = function(componentInfo) { this.removeComponentInfo = function(componentInfo) {
var index = this.components.indexOf(componentInfo); var index = this.components.indexOf(componentInfo);
(index > -1) && this.components.splice(index, 1); (index > -1) && this.components.splice(index, 1);
}; };
this.findComponentInfo = function(which) { this.findComponentInfo = function(which) {
...@@ -151,18 +148,18 @@ define( ...@@ -151,18 +148,18 @@ define(
}; };
this.findInstanceInfo = function(instance) { this.findInstanceInfo = function(instance) {
return this.allInstances[instance.identity] || null; return this.allInstances[instance.identity] || null;
}; };
this.findInstanceInfoByNode = function(node) { this.findInstanceInfoByNode = function(node) {
var result = []; var result = [];
Object.keys(this.allInstances).forEach(function(k) { Object.keys(this.allInstances).forEach(function(k) {
var thisInstanceInfo = this.allInstances[k]; var thisInstanceInfo = this.allInstances[k];
if(thisInstanceInfo.instance.node === node) { if (thisInstanceInfo.instance.node === node) {
result.push(thisInstanceInfo); result.push(thisInstanceInfo);
} }
}, this); }, this);
return result; return result;
}; };
this.on = function(componentOn) { this.on = function(componentOn) {
...@@ -183,7 +180,7 @@ define( ...@@ -183,7 +180,7 @@ define(
} }
}; };
this.off = function(el, type, callback) { this.off = function(/*el, type, callback*/) {
var event = parseEventArgs(this, arguments), var event = parseEventArgs(this, arguments),
instance = registry.findInstanceInfo(this); instance = registry.findInstanceInfo(this);
...@@ -199,8 +196,8 @@ define( ...@@ -199,8 +196,8 @@ define(
} }
}; };
//debug tools may want to add advice to trigger // debug tools may want to add advice to trigger
registry.trigger = new Function; registry.trigger = function() {};
this.teardown = function() { this.teardown = function() {
registry.removeInstance(this); registry.removeInstance(this);
...@@ -215,7 +212,7 @@ define( ...@@ -215,7 +212,7 @@ define(
this.after('off', registry.off); this.after('off', registry.off);
//debug tools may want to add advice to trigger //debug tools may want to add advice to trigger
window.DEBUG && DEBUG.enabled && this.after('trigger', registry.trigger); window.DEBUG && DEBUG.enabled && this.after('trigger', registry.trigger);
this.after('teardown', {obj:registry, fnName:'teardown'}); this.after('teardown', {obj: registry, fnName: 'teardown'});
}; };
} }
......
...@@ -4,13 +4,12 @@ ...@@ -4,13 +4,12 @@
// http://opensource.org/licenses/MIT // http://opensource.org/licenses/MIT
// ========================================== // ==========================================
"use strict";
define( define(
[], [],
function () { function() {
'use strict';
var arry = []; var arry = [];
var DEFAULT_INTERVAL = 100; var DEFAULT_INTERVAL = 100;
...@@ -92,14 +91,14 @@ define( ...@@ -92,14 +91,14 @@ define(
if (base) { if (base) {
Object.keys(extra || {}).forEach(function(key) { Object.keys(extra || {}).forEach(function(key) {
if (base[key] && protect) { if (base[key] && protect) {
throw Error("utils.push attempted to overwrite '" + key + "' while running in protected mode"); throw new Error('utils.push attempted to overwrite "' + key + '" while running in protected mode');
} }
if (typeof base[key] == "object" && typeof extra[key] == "object") { if (typeof base[key] == 'object' && typeof extra[key] == 'object') {
//recurse // recurse
this.push(base[key], extra[key]); this.push(base[key], extra[key]);
} else { } else {
//no protect, so extra wins // no protect, so extra wins
base[key] = extra[key]; base[key] = extra[key];
} }
}, this); }, this);
...@@ -112,9 +111,9 @@ define( ...@@ -112,9 +111,9 @@ define(
return Object.keys(obj).indexOf(property) > -1; return Object.keys(obj).indexOf(property) > -1;
}, },
//build a function from other function(s) // build a function from other function(s)
//util.compose(a,b,c) -> a(b(c())); // utils.compose(a,b,c) -> a(b(c()));
//implementation lifted from underscore.js (c) 2009-2012 Jeremy Ashkenas // implementation lifted from underscore.js (c) 2009-2012 Jeremy Ashkenas
compose: function() { compose: function() {
var funcs = arguments; var funcs = arguments;
......
/** vim: et:ts=4:sw=4:sts=4 /** vim: et:ts=4:sw=4:sts=4
* @license RequireJS 2.1.8 Copyright (c) 2010-2012, The Dojo Foundation All Rights Reserved. * @license RequireJS 2.1.9 Copyright (c) 2010-2012, The Dojo Foundation All Rights Reserved.
* Available via the MIT or new BSD license. * Available via the MIT or new BSD license.
* see: http://github.com/jrburke/requirejs for details * see: http://github.com/jrburke/requirejs for details
*/ */
...@@ -12,7 +12,7 @@ var requirejs, require, define; ...@@ -12,7 +12,7 @@ var requirejs, require, define;
(function (global) { (function (global) {
var req, s, head, baseElement, dataMain, src, var req, s, head, baseElement, dataMain, src,
interactiveScript, currentlyAddingScript, mainScript, subPath, interactiveScript, currentlyAddingScript, mainScript, subPath,
version = '2.1.8', version = '2.1.9',
commentRegExp = /(\/\*([\s\S]*?)\*\/|([^:]|^)\/\/(.*)$)/mg, commentRegExp = /(\/\*([\s\S]*?)\*\/|([^:]|^)\/\/(.*)$)/mg,
cjsRequireRegExp = /[^.]\s*require\s*\(\s*["']([^'"\s]+)["']\s*\)/g, cjsRequireRegExp = /[^.]\s*require\s*\(\s*["']([^'"\s]+)["']\s*\)/g,
jsSuffixRegExp = /\.js$/, jsSuffixRegExp = /\.js$/,
...@@ -22,7 +22,7 @@ var requirejs, require, define; ...@@ -22,7 +22,7 @@ var requirejs, require, define;
hasOwn = op.hasOwnProperty, hasOwn = op.hasOwnProperty,
ap = Array.prototype, ap = Array.prototype,
apsp = ap.splice, apsp = ap.splice,
isBrowser = !!(typeof window !== 'undefined' && navigator && window.document), isBrowser = !!(typeof window !== 'undefined' && typeof navigator !== 'undefined' && window.document),
isWebWorker = !isBrowser && typeof importScripts !== 'undefined', isWebWorker = !isBrowser && typeof importScripts !== 'undefined',
//PS3 indicates loaded and complete, but need to wait for complete //PS3 indicates loaded and complete, but need to wait for complete
//specifically. Sequence is 'loading', 'loaded', execution, //specifically. Sequence is 'loading', 'loaded', execution,
...@@ -373,7 +373,6 @@ var requirejs, require, define; ...@@ -373,7 +373,6 @@ var requirejs, require, define;
function hasPathFallback(id) { function hasPathFallback(id) {
var pathConfig = getOwn(config.paths, id); var pathConfig = getOwn(config.paths, id);
if (pathConfig && isArray(pathConfig) && pathConfig.length > 1) { if (pathConfig && isArray(pathConfig) && pathConfig.length > 1) {
removeScript(id);
//Pop off the first array value, since it failed, and //Pop off the first array value, since it failed, and
//retry //retry
pathConfig.shift(); pathConfig.shift();
...@@ -1464,6 +1463,8 @@ var requirejs, require, define; ...@@ -1464,6 +1463,8 @@ var requirejs, require, define;
var map = makeModuleMap(id, relMap, true), var map = makeModuleMap(id, relMap, true),
mod = getOwn(registry, id); mod = getOwn(registry, id);
removeScript(id);
delete defined[id]; delete defined[id];
delete urlFetched[map.url]; delete urlFetched[map.url];
delete undefEvents[id]; delete undefEvents[id];
...@@ -1609,7 +1610,7 @@ var requirejs, require, define; ...@@ -1609,7 +1610,7 @@ var requirejs, require, define;
//Join the path parts together, then figure out if baseUrl is needed. //Join the path parts together, then figure out if baseUrl is needed.
url = syms.join('/'); url = syms.join('/');
url += (ext || (/\?/.test(url) || skipExt ? '' : '.js')); url += (ext || (/^data\:|\?/.test(url) || skipExt ? '' : '.js'));
url = (url.charAt(0) === '/' || url.match(/^[\w\+\.\-]+:/) ? '' : config.baseUrl) + url; url = (url.charAt(0) === '/' || url.match(/^[\w\+\.\-]+:/) ? '' : config.baseUrl) + url;
} }
...@@ -1918,7 +1919,7 @@ var requirejs, require, define; ...@@ -1918,7 +1919,7 @@ var requirejs, require, define;
} }
//Look for a data-main script attribute, which could also adjust the baseUrl. //Look for a data-main script attribute, which could also adjust the baseUrl.
if (isBrowser) { if (isBrowser && !cfg.skipDataMain) {
//Figure out baseUrl. Get it from the script tag with require.js in it. //Figure out baseUrl. Get it from the script tag with require.js in it.
eachReverse(scripts(), function (script) { eachReverse(scripts(), function (script) {
//Set the 'head' where we can append children by //Set the 'head' where we can append children by
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment