Commit 28bd694f authored by Eric Bidelman's avatar Eric Bidelman Committed by Sam Saccone

Update polymer 1.2.2

parent 2291ad9a
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
"dependencies": { "dependencies": {
"todomvc-common": "^1.0.1", "todomvc-common": "^1.0.1",
"todomvc-app-css": "^1.0.0", "todomvc-app-css": "^1.0.0",
"polymer": "Polymer/polymer#^1.1.4", "polymer": "Polymer/polymer#^1.2.2",
"iron-selector": "PolymerElements/iron-selector#^1.0.5", "iron-selector": "PolymerElements/iron-selector#^1.0.5",
"flatiron-director": "PolymerLabs/flatiron-director#^1.0.0", "flatiron-director": "PolymerLabs/flatiron-director#^1.0.0",
"iron-localstorage": "PolymerElements/iron-localstorage#^1.0.4" "iron-localstorage": "PolymerElements/iron-localstorage#^1.0.4"
......
...@@ -72,6 +72,11 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN ...@@ -72,6 +72,11 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN
this._selection.multi = multi; this._selection.multi = multi;
}, },
get _shouldUpdateSelection() {
return this.selected != null ||
(this.selectedValues != null && this.selectedValues.length);
},
_updateSelected: function() { _updateSelected: function() {
if (this.multi) { if (this.multi) {
this._selectMulti(this.selectedValues); this._selectMulti(this.selectedValues);
......
...@@ -64,6 +64,8 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN ...@@ -64,6 +64,8 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN
/** /**
* Returns the currently selected item. * Returns the currently selected item.
*
* @type {?Object}
*/ */
selectedItem: { selectedItem: {
type: Object, type: Object,
...@@ -104,14 +106,24 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN ...@@ -104,14 +106,24 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN
value: null value: null
}, },
/**
* The list of items from which a selection can be made.
*/
items: {
type: Array,
readOnly: true,
value: function() {
return [];
}
},
/** /**
* The set of excluded elements where the key is the `localName` * The set of excluded elements where the key is the `localName`
* of the element that will be ignored from the item list. * of the element that will be ignored from the item list.
* *
* @type {object}
* @default {template: 1} * @default {template: 1}
*/ */
excludedLocalNames: { _excludedLocalNames: {
type: Object, type: Object,
value: function() { value: function() {
return { return {
...@@ -132,33 +144,20 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN ...@@ -132,33 +144,20 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN
attached: function() { attached: function() {
this._observer = this._observeItems(this); this._observer = this._observeItems(this);
this._contentObserver = this._observeContent(this); this._updateItems();
if (!this.selectedItem && this.selected) { if (!this._shouldUpdateSelection) {
this._updateSelected(this.attrForSelected,this.selected) this._updateSelected(this.attrForSelected,this.selected)
} }
this._addListener(this.activateEvent);
}, },
detached: function() { detached: function() {
if (this._observer) { if (this._observer) {
this._observer.disconnect(); Polymer.dom(this).unobserveNodes(this._observer);
}
if (this._contentObserver) {
this._contentObserver.disconnect();
} }
this._removeListener(this.activateEvent); this._removeListener(this.activateEvent);
}, },
/**
* Returns an array of selectable items.
*
* @property items
* @type Array
*/
get items() {
var nodes = Polymer.dom(this).queryDistributedElements(this.selectable || '*');
return Array.prototype.filter.call(nodes, this._bindFilterItem);
},
/** /**
* Returns the index of the given item. * Returns the index of the given item.
* *
...@@ -201,6 +200,10 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN ...@@ -201,6 +200,10 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN
this.selected = this._indexToValue(index); this.selected = this._indexToValue(index);
}, },
get _shouldUpdateSelection() {
return this.selected != null;
},
_addListener: function(eventName) { _addListener: function(eventName) {
this.listen(this, eventName, '_activateHandler'); this.listen(this, eventName, '_activateHandler');
}, },
...@@ -214,6 +217,12 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN ...@@ -214,6 +217,12 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN
this._addListener(eventName); this._addListener(eventName);
}, },
_updateItems: function() {
var nodes = Polymer.dom(this).queryDistributedElements(this.selectable || '*');
nodes = Array.prototype.filter.call(nodes, this._bindFilterItem);
this._setItems(nodes);
},
_updateSelected: function() { _updateSelected: function() {
this._selectSelected(this.selected); this._selectSelected(this.selected);
}, },
...@@ -223,7 +232,7 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN ...@@ -223,7 +232,7 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN
}, },
_filterItem: function(node) { _filterItem: function(node) {
return !this.excludedLocalNames[node.localName]; return !this._excludedLocalNames[node.localName];
}, },
_valueToItem: function(value) { _valueToItem: function(value) {
...@@ -272,18 +281,9 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN ...@@ -272,18 +281,9 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN
this._setSelectedItem(this._selection.get()); this._setSelectedItem(this._selection.get());
}, },
// observe content changes under the given node.
_observeContent: function(node) {
var content = node.querySelector('content');
if (content && content.parentElement === node) {
return this._observeItems(node.domHost);
}
},
// observe items change under the given node. // observe items change under the given node.
_observeItems: function(node) { _observeItems: function(node) {
// TODO(cdata): Update this when we get distributed children changed. return Polymer.dom(node).observeNodes(function(mutations) {
var observer = new MutationObserver(function(mutations) {
// Let other interested parties know about the change so that // Let other interested parties know about the change so that
// we don't have to recreate mutation observers everywher. // we don't have to recreate mutation observers everywher.
this.fire('iron-items-changed', mutations, { this.fire('iron-items-changed', mutations, {
...@@ -291,15 +291,12 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN ...@@ -291,15 +291,12 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN
cancelable: false cancelable: false
}); });
if (this.selected != null) { this._updateItems();
if (this._shouldUpdateSelection) {
this._updateSelected(); this._updateSelected();
} }
}.bind(this));
observer.observe(node, {
childList: true,
subtree: true
}); });
return observer;
}, },
_activateHandler: function(e) { _activateHandler: function(e) {
......
...@@ -23,10 +23,11 @@ addEventListener('DOMContentLoaded', resolve); ...@@ -23,10 +23,11 @@ addEventListener('DOMContentLoaded', resolve);
window.Polymer = { window.Polymer = {
Settings: function () { Settings: function () {
var user = window.Polymer || {}; var user = window.Polymer || {};
location.search.slice(1).split('&').forEach(function (o) { var parts = location.search.slice(1).split('&');
for (var i = 0, o; i < parts.length && (o = parts[i]); i++) {
o = o.split('='); o = o.split('=');
o[0] && (user[o[0]] = o[1] || true); o[0] && (user[o[0]] = o[1] || true);
}); }
var wantShadow = user.dom === 'shadow'; var wantShadow = user.dom === 'shadow';
var hasShadow = Boolean(Element.prototype.createShadowRoot); var hasShadow = Boolean(Element.prototype.createShadowRoot);
var nativeShadow = hasShadow && !window.ShadowDOMPolyfill; var nativeShadow = hasShadow && !window.ShadowDOMPolyfill;
...@@ -113,15 +114,43 @@ this._callbacks.push(cb); ...@@ -113,15 +114,43 @@ this._callbacks.push(cb);
}, },
_makeReady: function () { _makeReady: function () {
this._ready = true; this._ready = true;
this._callbacks.forEach(function (cb) { for (var i = 0; i < this._callbacks.length; i++) {
cb(); this._callbacks[i]();
}); }
this._callbacks = []; this._callbacks = [];
}, },
_catchFirstRender: function () { _catchFirstRender: function () {
requestAnimationFrame(function () { requestAnimationFrame(function () {
Polymer.RenderStatus._makeReady(); Polymer.RenderStatus._makeReady();
}); });
},
_afterNextRenderQueue: [],
_waitingNextRender: false,
afterNextRender: function (element, fn, args) {
if (!this._waitingNextRender) {
this._waitingNextRender = true;
this.whenReady(this._flushAfterNextRender);
}
this._afterNextRenderQueue.push([
element,
fn,
args
]);
},
_flushAfterNextRender: function () {
requestAnimationFrame(function () {
setTimeout(Polymer.RenderStatus.__flushAfterNextRender);
});
},
__flushAfterNextRender: function () {
var self = Polymer.RenderStatus;
self._waitingNextRender = false;
for (var i = 0, h; i < self._afterNextRenderQueue.length; i++) {
h = self._afterNextRenderQueue[i];
h[1].apply(h[0], h[2] || Polymer.nar);
}
;
self._afterNextRenderQueue = [];
} }
}; };
if (window.HTMLImports) { if (window.HTMLImports) {
...@@ -151,27 +180,33 @@ this._doBehavior('created'); ...@@ -151,27 +180,33 @@ this._doBehavior('created');
this._initFeatures(); this._initFeatures();
}, },
attachedCallback: function () { attachedCallback: function () {
var self = this;
Polymer.RenderStatus.whenReady(function () { Polymer.RenderStatus.whenReady(function () {
this.isAttached = true; self.isAttached = true;
this._doBehavior('attached'); self._doBehavior('attached');
}.bind(this)); });
}, },
detachedCallback: function () { detachedCallback: function () {
this.isAttached = false; this.isAttached = false;
this._doBehavior('detached'); this._doBehavior('detached');
}, },
attributeChangedCallback: function (name) { attributeChangedCallback: function (name, oldValue, newValue) {
this._attributeChangedImpl(name); this._attributeChangedImpl(name);
this._doBehavior('attributeChanged', arguments); this._doBehavior('attributeChanged', [
name,
oldValue,
newValue
]);
}, },
_attributeChangedImpl: function (name) { _attributeChangedImpl: function (name) {
this._setAttributeToProperty(this, name); this._setAttributeToProperty(this, name);
}, },
extend: function (prototype, api) { extend: function (prototype, api) {
if (prototype && api) { if (prototype && api) {
Object.getOwnPropertyNames(api).forEach(function (n) { var n$ = Object.getOwnPropertyNames(api);
for (var i = 0, n; i < n$.length && (n = n$[i]); i++) {
this.copyOwnProperty(n, api, prototype); this.copyOwnProperty(n, api, prototype);
}, this); }
} }
return prototype || api; return prototype || api;
}, },
...@@ -264,7 +299,7 @@ document.registerElement('dom-module', DomModule); ...@@ -264,7 +299,7 @@ document.registerElement('dom-module', DomModule);
function forceDocumentUpgrade() { function forceDocumentUpgrade() {
if (cePolyfill) { if (cePolyfill) {
var script = document._currentScript || document.currentScript; var script = document._currentScript || document.currentScript;
var doc = script && script.ownerDocument; var doc = script && script.ownerDocument || document;
if (doc) { if (doc) {
CustomElements.upgradeAll(doc); CustomElements.upgradeAll(doc);
} }
...@@ -301,7 +336,8 @@ return behaviors; ...@@ -301,7 +336,8 @@ return behaviors;
}, },
_flattenBehaviorsList: function (behaviors) { _flattenBehaviorsList: function (behaviors) {
var flat = []; var flat = [];
behaviors.forEach(function (b) { for (var i = 0; i < behaviors.length; i++) {
var b = behaviors[i];
if (b instanceof Array) { if (b instanceof Array) {
flat = flat.concat(this._flattenBehaviorsList(b)); flat = flat.concat(this._flattenBehaviorsList(b));
} else if (b) { } else if (b) {
...@@ -309,31 +345,16 @@ flat.push(b); ...@@ -309,31 +345,16 @@ flat.push(b);
} else { } else {
this._warn(this._logf('_flattenBehaviorsList', 'behavior is null, check for missing or 404 import')); this._warn(this._logf('_flattenBehaviorsList', 'behavior is null, check for missing or 404 import'));
} }
}, this); }
return flat; return flat;
}, },
_mixinBehavior: function (b) { _mixinBehavior: function (b) {
Object.getOwnPropertyNames(b).forEach(function (n) { var n$ = Object.getOwnPropertyNames(b);
switch (n) { for (var i = 0, n; i < n$.length && (n = n$[i]); i++) {
case 'hostAttributes': if (!Polymer.Base._behaviorProperties[n] && !this.hasOwnProperty(n)) {
case 'registered':
case 'properties':
case 'observers':
case 'listeners':
case 'created':
case 'attached':
case 'detached':
case 'attributeChanged':
case 'configure':
case 'ready':
break;
default:
if (!this.hasOwnProperty(n)) {
this.copyOwnProperty(n, b, this); this.copyOwnProperty(n, b, this);
} }
break;
} }
}, this);
}, },
_prepBehaviors: function () { _prepBehaviors: function () {
this._prepFlattenedBehaviors(this.behaviors); this._prepFlattenedBehaviors(this.behaviors);
...@@ -345,9 +366,9 @@ this._prepBehavior(behaviors[i]); ...@@ -345,9 +366,9 @@ this._prepBehavior(behaviors[i]);
this._prepBehavior(this); this._prepBehavior(this);
}, },
_doBehavior: function (name, args) { _doBehavior: function (name, args) {
this.behaviors.forEach(function (b) { for (var i = 0; i < this.behaviors.length; i++) {
this._invokeBehavior(b, name, args); this._invokeBehavior(this.behaviors[i], name, args);
}, this); }
this._invokeBehavior(this, name, args); this._invokeBehavior(this, name, args);
}, },
_invokeBehavior: function (b, name, args) { _invokeBehavior: function (b, name, args) {
...@@ -357,12 +378,24 @@ fn.apply(this, args || Polymer.nar); ...@@ -357,12 +378,24 @@ fn.apply(this, args || Polymer.nar);
} }
}, },
_marshalBehaviors: function () { _marshalBehaviors: function () {
this.behaviors.forEach(function (b) { for (var i = 0; i < this.behaviors.length; i++) {
this._marshalBehavior(b); this._marshalBehavior(this.behaviors[i]);
}, this); }
this._marshalBehavior(this); this._marshalBehavior(this);
} }
}); });
Polymer.Base._behaviorProperties = {
hostAttributes: true,
registered: true,
properties: true,
observers: true,
listeners: true,
created: true,
attached: true,
detached: true,
attributeChanged: true,
ready: true
};
Polymer.Base._addFeature({ Polymer.Base._addFeature({
_getExtendedPrototype: function (tag) { _getExtendedPrototype: function (tag) {
return this._getExtendedNativePrototype(tag); return this._getExtendedNativePrototype(tag);
...@@ -414,9 +447,13 @@ properties: {}, ...@@ -414,9 +447,13 @@ properties: {},
getPropertyInfo: function (property) { getPropertyInfo: function (property) {
var info = this._getPropertyInfo(property, this.properties); var info = this._getPropertyInfo(property, this.properties);
if (!info) { if (!info) {
this.behaviors.some(function (b) { for (var i = 0; i < this.behaviors.length; i++) {
return info = this._getPropertyInfo(property, b.properties); info = this._getPropertyInfo(property, this.behaviors[i].properties);
}, this); if (info) {
return info;
}
}
;
} }
return info || Polymer.nob; return info || Polymer.nob;
}, },
...@@ -429,6 +466,40 @@ if (p) { ...@@ -429,6 +466,40 @@ if (p) {
p.defined = true; p.defined = true;
} }
return p; return p;
},
_prepPropertyInfo: function () {
this._propertyInfo = {};
for (var i = 0, p; i < this.behaviors.length; i++) {
this._addPropertyInfo(this._propertyInfo, this.behaviors[i].properties);
}
this._addPropertyInfo(this._propertyInfo, this.properties);
this._addPropertyInfo(this._propertyInfo, this._propertyEffects);
},
_addPropertyInfo: function (target, source) {
if (source) {
var t, s;
for (var i in source) {
t = target[i];
s = source[i];
if (i[0] === '_' && !s.readOnly) {
continue;
}
if (!target[i]) {
target[i] = {
type: typeof s === 'function' ? s : s.type,
readOnly: s.readOnly,
attribute: Polymer.CaseMap.camelToDashCase(i)
};
} else {
if (!t.type) {
t.type = s.type;
}
if (!t.readOnly) {
t.readOnly = s.readOnly;
}
}
}
}
} }
}); });
Polymer.CaseMap = { Polymer.CaseMap = {
...@@ -456,21 +527,24 @@ return g[0] + '-' + g[1].toLowerCase(); ...@@ -456,21 +527,24 @@ return g[0] + '-' + g[1].toLowerCase();
} }
}; };
Polymer.Base._addFeature({ Polymer.Base._addFeature({
_prepAttributes: function () {
this._aggregatedAttributes = {};
},
_addHostAttributes: function (attributes) { _addHostAttributes: function (attributes) {
if (!this._aggregatedAttributes) {
this._aggregatedAttributes = {};
}
if (attributes) { if (attributes) {
this.mixin(this._aggregatedAttributes, attributes); this.mixin(this._aggregatedAttributes, attributes);
} }
}, },
_marshalHostAttributes: function () { _marshalHostAttributes: function () {
if (this._aggregatedAttributes) {
this._applyAttributes(this, this._aggregatedAttributes); this._applyAttributes(this, this._aggregatedAttributes);
}
}, },
_applyAttributes: function (node, attr$) { _applyAttributes: function (node, attr$) {
for (var n in attr$) { for (var n in attr$) {
if (!this.hasAttribute(n) && n !== 'class') { if (!this.hasAttribute(n) && n !== 'class') {
this.serializeValueToAttribute(attr$[n], n, this); var v = attr$[n];
this.serializeValueToAttribute(v, n, this);
} }
} }
}, },
...@@ -478,29 +552,40 @@ _marshalAttributes: function () { ...@@ -478,29 +552,40 @@ _marshalAttributes: function () {
this._takeAttributesToModel(this); this._takeAttributesToModel(this);
}, },
_takeAttributesToModel: function (model) { _takeAttributesToModel: function (model) {
for (var i = 0, l = this.attributes.length; i < l; i++) { if (this.hasAttributes()) {
this._setAttributeToProperty(model, this.attributes[i].name); for (var i in this._propertyInfo) {
var info = this._propertyInfo[i];
if (this.hasAttribute(info.attribute)) {
this._setAttributeToProperty(model, info.attribute, i, info);
}
}
} }
}, },
_setAttributeToProperty: function (model, attrName) { _setAttributeToProperty: function (model, attribute, property, info) {
if (!this._serializing) { if (!this._serializing) {
var propName = Polymer.CaseMap.dashToCamelCase(attrName); var property = property || Polymer.CaseMap.dashToCamelCase(attribute);
var info = this.getPropertyInfo(propName); info = info || this._propertyInfo && this._propertyInfo[property];
if (info.defined || this._propertyEffects && this._propertyEffects[propName]) { if (info && !info.readOnly) {
var val = this.getAttribute(attrName); var v = this.getAttribute(attribute);
model[propName] = this.deserialize(val, info.type); model[property] = this.deserialize(v, info.type);
} }
} }
}, },
_serializing: false, _serializing: false,
reflectPropertyToAttribute: function (name) { reflectPropertyToAttribute: function (property, attribute, value) {
this._serializing = true; this._serializing = true;
this.serializeValueToAttribute(this[name], Polymer.CaseMap.camelToDashCase(name)); value = value === undefined ? this[property] : value;
this.serializeValueToAttribute(value, attribute || Polymer.CaseMap.camelToDashCase(property));
this._serializing = false; this._serializing = false;
}, },
serializeValueToAttribute: function (value, attribute, node) { serializeValueToAttribute: function (value, attribute, node) {
var str = this.serialize(value); var str = this.serialize(value);
(node || this)[str === undefined ? 'removeAttribute' : 'setAttribute'](attribute, str); node = node || this;
if (str === undefined) {
node.removeAttribute(attribute);
} else {
node.setAttribute(attribute, str);
}
}, },
deserialize: function (value, type) { deserialize: function (value, type) {
switch (type) { switch (type) {
...@@ -576,13 +661,13 @@ debouncer.stop(); ...@@ -576,13 +661,13 @@ debouncer.stop();
} }
} }
}); });
Polymer.version = '1.1.4'; Polymer.version = '1.2.2';
Polymer.Base._addFeature({ Polymer.Base._addFeature({
_registerFeatures: function () { _registerFeatures: function () {
this._prepIs(); this._prepIs();
this._prepAttributes();
this._prepBehaviors(); this._prepBehaviors();
this._prepConstructor(); this._prepConstructor();
this._prepPropertyInfo();
}, },
_prepBehavior: function (b) { _prepBehavior: function (b) {
this._addHostAttributes(b.hostAttributes); this._addHostAttributes(b.hostAttributes);
......
...@@ -10,7 +10,9 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN ...@@ -10,7 +10,9 @@ subject to an additional IP rights grant found at http://polymer.github.io/PATEN
<script>Polymer.Base._addFeature({ <script>Polymer.Base._addFeature({
_prepTemplate: function () { _prepTemplate: function () {
this._template = this._template || Polymer.DomModule.import(this.is, 'template'); if (this._template === undefined) {
this._template = Polymer.DomModule.import(this.is, 'template');
}
if (this._template && this._template.hasAttribute('is')) { if (this._template && this._template.hasAttribute('is')) {
this._warn(this._logf('_prepTemplate', 'top-level Polymer template ' + 'must not be a type-extension, found', this._template, 'Move inside simple <template>.')); this._warn(this._logf('_prepTemplate', 'top-level Polymer template ' + 'must not be a type-extension, found', this._template, 'Move inside simple <template>.'));
} }
...@@ -35,20 +37,19 @@ Polymer.Base._addFeature({ ...@@ -35,20 +37,19 @@ Polymer.Base._addFeature({
_hostStack: [], _hostStack: [],
ready: function () { ready: function () {
}, },
_pushHost: function (host) { _registerHost: function (host) {
this.dataHost = host = host || Polymer.Base._hostStack[Polymer.Base._hostStack.length - 1]; this.dataHost = host = host || Polymer.Base._hostStack[Polymer.Base._hostStack.length - 1];
if (host && host._clients) { if (host && host._clients) {
host._clients.push(this); host._clients.push(this);
} }
this._beginHost();
}, },
_beginHost: function () { _beginHosting: function () {
Polymer.Base._hostStack.push(this); Polymer.Base._hostStack.push(this);
if (!this._clients) { if (!this._clients) {
this._clients = []; this._clients = [];
} }
}, },
_popHost: function () { _endHosting: function () {
Polymer.Base._hostStack.pop(); Polymer.Base._hostStack.pop();
}, },
_tryReady: function () { _tryReady: function () {
...@@ -61,20 +62,24 @@ return !this.dataHost || this.dataHost._clientsReadied; ...@@ -61,20 +62,24 @@ return !this.dataHost || this.dataHost._clientsReadied;
}, },
_ready: function () { _ready: function () {
this._beforeClientsReady(); this._beforeClientsReady();
if (this._template) {
this._setupRoot(); this._setupRoot();
this._readyClients(); this._readyClients();
}
this._clientsReadied = true;
this._clients = null;
this._afterClientsReady(); this._afterClientsReady();
this._readySelf(); this._readySelf();
}, },
_readyClients: function () { _readyClients: function () {
this._beginDistribute(); this._beginDistribute();
var c$ = this._clients; var c$ = this._clients;
if (c$) {
for (var i = 0, l = c$.length, c; i < l && (c = c$[i]); i++) { for (var i = 0, l = c$.length, c; i < l && (c = c$[i]); i++) {
c._ready(); c._ready();
} }
}
this._finishDistribute(); this._finishDistribute();
this._clientsReadied = true;
this._clients = null;
}, },
_readySelf: function () { _readySelf: function () {
this._doBehavior('ready'); this._doBehavior('ready');
...@@ -270,61 +275,6 @@ return currentValue === previousValue; ...@@ -270,61 +275,6 @@ return currentValue === previousValue;
}; };
return new ArraySplice(); return new ArraySplice();
}(); }();
Polymer.EventApi = function () {
var Settings = Polymer.Settings;
var EventApi = function (event) {
this.event = event;
};
if (Settings.useShadow) {
EventApi.prototype = {
get rootTarget() {
return this.event.path[0];
},
get localTarget() {
return this.event.target;
},
get path() {
return this.event.path;
}
};
} else {
EventApi.prototype = {
get rootTarget() {
return this.event.target;
},
get localTarget() {
var current = this.event.currentTarget;
var currentRoot = current && Polymer.dom(current).getOwnerRoot();
var p$ = this.path;
for (var i = 0; i < p$.length; i++) {
if (Polymer.dom(p$[i]).getOwnerRoot() === currentRoot) {
return p$[i];
}
}
},
get path() {
if (!this.event._path) {
var path = [];
var o = this.rootTarget;
while (o) {
path.push(o);
o = Polymer.dom(o).parentNode || o.host;
}
path.push(window);
this.event._path = path;
}
return this.event._path;
}
};
}
var factory = function (event) {
if (!event.__eventApi) {
event.__eventApi = new EventApi(event);
}
return event.__eventApi;
};
return { factory: factory };
}();
Polymer.domInnerHTML = function () { Polymer.domInnerHTML = function () {
var escapeAttrRegExp = /[&\u00A0"]/g; var escapeAttrRegExp = /[&\u00A0"]/g;
var escapeDataRegExp = /[&\u00A0<>]/g; var escapeDataRegExp = /[&\u00A0<>]/g;
...@@ -432,24 +382,31 @@ var nativeRemoveChild = Element.prototype.removeChild; ...@@ -432,24 +382,31 @@ var nativeRemoveChild = Element.prototype.removeChild;
var nativeAppendChild = Element.prototype.appendChild; var nativeAppendChild = Element.prototype.appendChild;
var nativeCloneNode = Element.prototype.cloneNode; var nativeCloneNode = Element.prototype.cloneNode;
var nativeImportNode = Document.prototype.importNode; var nativeImportNode = Document.prototype.importNode;
var DomApi = function (node) { var needsToWrap = Settings.hasShadow && !Settings.nativeShadow;
this.node = node; var wrap = window.wrap ? window.wrap : function (node) {
if (this.patch) { return node;
this.patch();
}
}; };
if (window.wrap && Settings.useShadow && !Settings.useNativeShadow) { var DomApi = function (node) {
DomApi = function (node) { this.node = needsToWrap ? wrap(node) : node;
this.node = wrap(node);
if (this.patch) { if (this.patch) {
this.patch(); this.patch();
} }
}; };
}
DomApi.prototype = { DomApi.prototype = {
flush: function () { flush: function () {
Polymer.dom.flush(); Polymer.dom.flush();
}, },
deepContains: function (node) {
if (this.node.contains(node)) {
return true;
}
var n = node;
var wrappedDocument = wrap(document);
while (n && n !== wrappedDocument && n !== this.node) {
n = Polymer.dom(n).parentNode || n.host;
}
return n === this.node;
},
_lazyDistribute: function (host) { _lazyDistribute: function (host) {
if (host.shadyRoot && host.shadyRoot._distributionClean) { if (host.shadyRoot && host.shadyRoot._distributionClean) {
host.shadyRoot._distributionClean = false; host.shadyRoot._distributionClean = false;
...@@ -463,7 +420,7 @@ insertBefore: function (node, ref_node) { ...@@ -463,7 +420,7 @@ insertBefore: function (node, ref_node) {
return this._addNode(node, ref_node); return this._addNode(node, ref_node);
}, },
_addNode: function (node, ref_node) { _addNode: function (node, ref_node) {
this._removeNodeFromHost(node, true); this._removeNodeFromParent(node);
var addedInsertionPoint; var addedInsertionPoint;
var root = this.getOwnerRoot(); var root = this.getOwnerRoot();
if (root) { if (root) {
...@@ -495,6 +452,7 @@ nativeAppendChild.call(container, node); ...@@ -495,6 +452,7 @@ nativeAppendChild.call(container, node);
if (addedInsertionPoint) { if (addedInsertionPoint) {
this._updateInsertionPoints(root.host); this._updateInsertionPoints(root.host);
} }
this.notifyObserver();
return node; return node;
}, },
removeChild: function (node) { removeChild: function (node) {
...@@ -509,6 +467,7 @@ removeFromComposedParent(container, node); ...@@ -509,6 +467,7 @@ removeFromComposedParent(container, node);
nativeRemoveChild.call(container, node); nativeRemoveChild.call(container, node);
} }
} }
this.notifyObserver();
return node; return node;
}, },
replaceChild: function (node, ref_node) { replaceChild: function (node, ref_node) {
...@@ -601,6 +560,13 @@ return Boolean(node._lightChildren !== undefined); ...@@ -601,6 +560,13 @@ return Boolean(node._lightChildren !== undefined);
_parentNeedsDistribution: function (parent) { _parentNeedsDistribution: function (parent) {
return parent && parent.shadyRoot && hasInsertionPoint(parent.shadyRoot); return parent && parent.shadyRoot && hasInsertionPoint(parent.shadyRoot);
}, },
_removeNodeFromParent: function (node) {
var parent = node._lightParent || node.parentNode;
if (parent && hasDomApi(parent)) {
factory(parent).notifyObserver();
}
this._removeNodeFromHost(node, true);
},
_removeNodeFromHost: function (node, ensureComposedRemoval) { _removeNodeFromHost: function (node, ensureComposedRemoval) {
var hostNeedsDist; var hostNeedsDist;
var root; var root;
...@@ -612,7 +578,7 @@ if (root) { ...@@ -612,7 +578,7 @@ if (root) {
root.host._elementRemove(node); root.host._elementRemove(node);
hostNeedsDist = this._removeDistributedChildren(root, node); hostNeedsDist = this._removeDistributedChildren(root, node);
} }
this._removeLogicalInfo(node, node._lightParent); this._removeLogicalInfo(node, parent);
} }
this._removeOwnerShadyRoot(node); this._removeOwnerShadyRoot(node);
if (root && hostNeedsDist) { if (root && hostNeedsDist) {
...@@ -660,7 +626,7 @@ _addLogicalInfo: function (node, container, index) { ...@@ -660,7 +626,7 @@ _addLogicalInfo: function (node, container, index) {
var children = factory(container).childNodes; var children = factory(container).childNodes;
index = index === undefined ? children.length : index; index = index === undefined ? children.length : index;
if (node.nodeType === Node.DOCUMENT_FRAGMENT_NODE) { if (node.nodeType === Node.DOCUMENT_FRAGMENT_NODE) {
var c$ = Array.prototype.slice.call(node.childNodes); var c$ = arrayCopyChildNodes(node);
for (var i = 0, n; i < c$.length && (n = c$[i]); i++) { for (var i = 0, n; i < c$.length && (n = c$[i]); i++) {
children.splice(index++, 0, n); children.splice(index++, 0, n);
n._lightParent = container; n._lightParent = container;
...@@ -731,24 +697,29 @@ getDistributedNodes: function () { ...@@ -731,24 +697,29 @@ getDistributedNodes: function () {
return this.node._distributedNodes || []; return this.node._distributedNodes || [];
}, },
queryDistributedElements: function (selector) { queryDistributedElements: function (selector) {
var c$ = this.childNodes; var c$ = this.getEffectiveChildNodes();
var list = []; var list = [];
this._distributedFilter(selector, c$, list);
for (var i = 0, l = c$.length, c; i < l && (c = c$[i]); i++) { for (var i = 0, l = c$.length, c; i < l && (c = c$[i]); i++) {
if (c.localName === CONTENT) { if (c.nodeType === Node.ELEMENT_NODE && matchesSelector.call(c, selector)) {
this._distributedFilter(selector, factory(c).getDistributedNodes(), list); list.push(c);
} }
} }
return list; return list;
}, },
_distributedFilter: function (selector, list, results) { getEffectiveChildNodes: function () {
results = results || []; var list = [];
for (var i = 0, l = list.length, d; i < l && (d = list[i]); i++) { var c$ = this.childNodes;
if (d.nodeType === Node.ELEMENT_NODE && d.localName !== CONTENT && matchesSelector.call(d, selector)) { for (var i = 0, l = c$.length, c; i < l && (c = c$[i]); i++) {
results.push(d); if (c.localName === CONTENT) {
var d$ = factory(c).getDistributedNodes();
for (var j = 0; j < d$.length; j++) {
list.push(d$[j]);
}
} else {
list.push(c);
} }
} }
return results; return list;
}, },
_clear: function () { _clear: function () {
while (this.childNodes.length) { while (this.childNodes.length) {
...@@ -792,36 +763,24 @@ d.appendChild(nc); ...@@ -792,36 +763,24 @@ d.appendChild(nc);
} }
} }
return n; return n;
},
observeNodes: function (callback) {
if (callback) {
if (!this.observer) {
this.observer = this.node.localName === CONTENT ? new DomApi.DistributedNodesObserver(this) : new DomApi.EffectiveNodesObserver(this);
} }
}; return this.observer.addListener(callback);
Object.defineProperty(DomApi.prototype, 'classList', {
get: function () {
if (!this._classList) {
this._classList = new DomApi.ClassList(this);
} }
return this._classList;
},
configurable: true
});
DomApi.ClassList = function (host) {
this.domApi = host;
this.node = host.node;
};
DomApi.ClassList.prototype = {
add: function () {
this.node.classList.add.apply(this.node.classList, arguments);
this.domApi._distributeParent();
}, },
remove: function () { unobserveNodes: function (handle) {
this.node.classList.remove.apply(this.node.classList, arguments); if (this.observer) {
this.domApi._distributeParent(); this.observer.removeListener(handle);
}, }
toggle: function () {
this.node.classList.toggle.apply(this.node.classList, arguments);
this.domApi._distributeParent();
}, },
contains: function () { notifyObserver: function () {
return this.node.classList.contains.apply(this.node.classList, arguments); if (this.observer) {
this.observer.notify();
}
} }
}; };
if (!Settings.useShadow) { if (!Settings.useShadow) {
...@@ -829,7 +788,7 @@ Object.defineProperties(DomApi.prototype, { ...@@ -829,7 +788,7 @@ Object.defineProperties(DomApi.prototype, {
childNodes: { childNodes: {
get: function () { get: function () {
var c$ = getLightChildren(this.node); var c$ = getLightChildren(this.node);
return Array.isArray(c$) ? c$ : Array.prototype.slice.call(c$); return Array.isArray(c$) ? c$ : arrayCopyChildNodes(this.node);
}, },
configurable: true configurable: true
}, },
...@@ -952,7 +911,7 @@ if (nt !== Node.TEXT_NODE || nt !== Node.COMMENT_NODE) { ...@@ -952,7 +911,7 @@ if (nt !== Node.TEXT_NODE || nt !== Node.COMMENT_NODE) {
this._clear(); this._clear();
var d = document.createElement('div'); var d = document.createElement('div');
d.innerHTML = text; d.innerHTML = text;
var c$ = Array.prototype.slice.call(d.childNodes); var c$ = arrayCopyChildNodes(d);
for (var i = 0; i < c$.length; i++) { for (var i = 0; i < c$.length; i++) {
this.appendChild(c$[i]); this.appendChild(c$[i]);
} }
...@@ -965,20 +924,25 @@ DomApi.prototype._getComposedInnerHTML = function () { ...@@ -965,20 +924,25 @@ DomApi.prototype._getComposedInnerHTML = function () {
return getInnerHTML(this.node, true); return getInnerHTML(this.node, true);
}; };
} else { } else {
var forwardMethods = [ var forwardMethods = function (m$) {
for (var i = 0; i < m$.length; i++) {
forwardMethod(m$[i]);
}
};
var forwardMethod = function (method) {
DomApi.prototype[method] = function () {
return this.node[method].apply(this.node, arguments);
};
};
forwardMethods([
'cloneNode', 'cloneNode',
'appendChild', 'appendChild',
'insertBefore', 'insertBefore',
'removeChild', 'removeChild',
'replaceChild' 'replaceChild'
]; ]);
forwardMethods.forEach(function (name) {
DomApi.prototype[name] = function () {
return this.node[name].apply(this.node, arguments);
};
});
DomApi.prototype.querySelectorAll = function (selector) { DomApi.prototype.querySelectorAll = function (selector) {
return Array.prototype.slice.call(this.node.querySelectorAll(selector)); return arrayCopy(this.node.querySelectorAll(selector));
}; };
DomApi.prototype.getOwnerRoot = function () { DomApi.prototype.getOwnerRoot = function () {
var n = this.node; var n = this.node;
...@@ -995,24 +959,24 @@ return doc.importNode(externalNode, deep); ...@@ -995,24 +959,24 @@ return doc.importNode(externalNode, deep);
}; };
DomApi.prototype.getDestinationInsertionPoints = function () { DomApi.prototype.getDestinationInsertionPoints = function () {
var n$ = this.node.getDestinationInsertionPoints && this.node.getDestinationInsertionPoints(); var n$ = this.node.getDestinationInsertionPoints && this.node.getDestinationInsertionPoints();
return n$ ? Array.prototype.slice.call(n$) : []; return n$ ? arrayCopy(n$) : [];
}; };
DomApi.prototype.getDistributedNodes = function () { DomApi.prototype.getDistributedNodes = function () {
var n$ = this.node.getDistributedNodes && this.node.getDistributedNodes(); var n$ = this.node.getDistributedNodes && this.node.getDistributedNodes();
return n$ ? Array.prototype.slice.call(n$) : []; return n$ ? arrayCopy(n$) : [];
}; };
DomApi.prototype._distributeParent = function () { DomApi.prototype._distributeParent = function () {
}; };
Object.defineProperties(DomApi.prototype, { Object.defineProperties(DomApi.prototype, {
childNodes: { childNodes: {
get: function () { get: function () {
return Array.prototype.slice.call(this.node.childNodes); return arrayCopyChildNodes(this.node);
}, },
configurable: true configurable: true
}, },
children: { children: {
get: function () { get: function () {
return Array.prototype.slice.call(this.node.children); return arrayCopyChildren(this.node);
}, },
configurable: true configurable: true
}, },
...@@ -1035,7 +999,20 @@ return this.node.innerHTML = value; ...@@ -1035,7 +999,20 @@ return this.node.innerHTML = value;
configurable: true configurable: true
} }
}); });
var forwardProperties = [ var forwardProperties = function (f$) {
for (var i = 0; i < f$.length; i++) {
forwardProperty(f$[i]);
}
};
var forwardProperty = function (name) {
Object.defineProperty(DomApi.prototype, name, {
get: function () {
return this.node[name];
},
configurable: true
});
};
forwardProperties([
'parentNode', 'parentNode',
'firstChild', 'firstChild',
'lastChild', 'lastChild',
...@@ -1045,24 +1022,21 @@ var forwardProperties = [ ...@@ -1045,24 +1022,21 @@ var forwardProperties = [
'lastElementChild', 'lastElementChild',
'nextElementSibling', 'nextElementSibling',
'previousElementSibling' 'previousElementSibling'
]; ]);
forwardProperties.forEach(function (name) {
Object.defineProperty(DomApi.prototype, name, {
get: function () {
return this.node[name];
},
configurable: true
});
});
} }
var CONTENT = 'content'; var CONTENT = 'content';
var factory = function (node, patch) { function factory(node, patch) {
node = node || document; node = node || document;
if (!node.__domApi) { if (!node.__domApi) {
node.__domApi = new DomApi(node, patch); node.__domApi = new DomApi(node, patch);
} }
return node.__domApi; return node.__domApi;
}; }
;
function hasDomApi(node) {
return Boolean(node.__domApi);
}
;
Polymer.dom = function (obj, patch) { Polymer.dom = function (obj, patch) {
if (obj instanceof Event) { if (obj instanceof Event) {
return Polymer.EventApi.factory(obj); return Polymer.EventApi.factory(obj);
...@@ -1070,50 +1044,13 @@ return Polymer.EventApi.factory(obj); ...@@ -1070,50 +1044,13 @@ return Polymer.EventApi.factory(obj);
return factory(obj, patch); return factory(obj, patch);
} }
}; };
Polymer.Base.extend(Polymer.dom, {
_flushGuard: 0,
_FLUSH_MAX: 100,
_needsTakeRecords: !Polymer.Settings.useNativeCustomElements,
_debouncers: [],
_finishDebouncer: null,
flush: function () {
for (var i = 0; i < this._debouncers.length; i++) {
this._debouncers[i].complete();
}
if (this._finishDebouncer) {
this._finishDebouncer.complete();
}
this._flushPolyfills();
if (this._debouncers.length && this._flushGuard < this._FLUSH_MAX) {
this._flushGuard++;
this.flush();
} else {
if (this._flushGuard >= this._FLUSH_MAX) {
console.warn('Polymer.dom.flush aborted. Flush may not be complete.');
}
this._flushGuard = 0;
}
},
_flushPolyfills: function () {
if (this._needsTakeRecords) {
CustomElements.takeRecords();
}
},
addDebouncer: function (debouncer) {
this._debouncers.push(debouncer);
this._finishDebouncer = Polymer.Debounce(this._finishDebouncer, this._finishFlush);
},
_finishFlush: function () {
Polymer.dom._debouncers = [];
}
});
function getLightChildren(node) { function getLightChildren(node) {
var children = node._lightChildren; var children = node._lightChildren;
return children ? children : node.childNodes; return children ? children : node.childNodes;
} }
function getComposedChildren(node) { function getComposedChildren(node) {
if (!node._composedChildren) { if (!node._composedChildren) {
node._composedChildren = Array.prototype.slice.call(node.childNodes); node._composedChildren = arrayCopyChildNodes(node);
} }
return node._composedChildren; return node._composedChildren;
} }
...@@ -1149,13 +1086,35 @@ children.splice(i, 1); ...@@ -1149,13 +1086,35 @@ children.splice(i, 1);
} }
function saveLightChildrenIfNeeded(node) { function saveLightChildrenIfNeeded(node) {
if (!node._lightChildren) { if (!node._lightChildren) {
var c$ = Array.prototype.slice.call(node.childNodes); var c$ = arrayCopyChildNodes(node);
for (var i = 0, l = c$.length, child; i < l && (child = c$[i]); i++) { for (var i = 0, l = c$.length, child; i < l && (child = c$[i]); i++) {
child._lightParent = child._lightParent || node; child._lightParent = child._lightParent || node;
} }
node._lightChildren = c$; node._lightChildren = c$;
} }
} }
function arrayCopyChildNodes(parent) {
var copy = [], i = 0;
for (var n = parent.firstChild; n; n = n.nextSibling) {
copy[i++] = n;
}
return copy;
}
function arrayCopyChildren(parent) {
var copy = [], i = 0;
for (var n = parent.firstElementChild; n; n = n.nextElementSibling) {
copy[i++] = n;
}
return copy;
}
function arrayCopy(a$) {
var l = a$.length;
var copy = new Array(l);
for (var i = 0; i < l; i++) {
copy[i] = a$[i];
}
return copy;
}
function hasInsertionPoint(root) { function hasInsertionPoint(root) {
return Boolean(root && root._insertionPoints.length); return Boolean(root && root._insertionPoints.length);
} }
...@@ -1170,10 +1129,411 @@ saveLightChildrenIfNeeded: saveLightChildrenIfNeeded, ...@@ -1170,10 +1129,411 @@ saveLightChildrenIfNeeded: saveLightChildrenIfNeeded,
matchesSelector: matchesSelector, matchesSelector: matchesSelector,
hasInsertionPoint: hasInsertionPoint, hasInsertionPoint: hasInsertionPoint,
ctor: DomApi, ctor: DomApi,
factory: factory factory: factory,
hasDomApi: hasDomApi,
arrayCopy: arrayCopy,
arrayCopyChildNodes: arrayCopyChildNodes,
arrayCopyChildren: arrayCopyChildren,
wrap: wrap
};
}();
Polymer.Base.extend(Polymer.dom, {
_flushGuard: 0,
_FLUSH_MAX: 100,
_needsTakeRecords: !Polymer.Settings.useNativeCustomElements,
_debouncers: [],
_staticFlushList: [],
_finishDebouncer: null,
flush: function () {
this._flushGuard = 0;
this._prepareFlush();
while (this._debouncers.length && this._flushGuard < this._FLUSH_MAX) {
for (var i = 0; i < this._debouncers.length; i++) {
this._debouncers[i].complete();
}
if (this._finishDebouncer) {
this._finishDebouncer.complete();
}
this._prepareFlush();
this._flushGuard++;
}
if (this._flushGuard >= this._FLUSH_MAX) {
console.warn('Polymer.dom.flush aborted. Flush may not be complete.');
}
},
_prepareFlush: function () {
if (this._needsTakeRecords) {
CustomElements.takeRecords();
}
for (var i = 0; i < this._staticFlushList.length; i++) {
this._staticFlushList[i]();
}
},
addStaticFlush: function (fn) {
this._staticFlushList.push(fn);
},
removeStaticFlush: function (fn) {
var i = this._staticFlushList.indexOf(fn);
if (i >= 0) {
this._staticFlushList.splice(i, 1);
}
},
addDebouncer: function (debouncer) {
this._debouncers.push(debouncer);
this._finishDebouncer = Polymer.Debounce(this._finishDebouncer, this._finishFlush);
},
_finishFlush: function () {
Polymer.dom._debouncers = [];
}
});
Polymer.EventApi = function () {
'use strict';
var DomApi = Polymer.DomApi.ctor;
var Settings = Polymer.Settings;
DomApi.Event = function (event) {
this.event = event;
};
if (Settings.useShadow) {
DomApi.Event.prototype = {
get rootTarget() {
return this.event.path[0];
},
get localTarget() {
return this.event.target;
},
get path() {
return this.event.path;
}
};
} else {
DomApi.Event.prototype = {
get rootTarget() {
return this.event.target;
},
get localTarget() {
var current = this.event.currentTarget;
var currentRoot = current && Polymer.dom(current).getOwnerRoot();
var p$ = this.path;
for (var i = 0; i < p$.length; i++) {
if (Polymer.dom(p$[i]).getOwnerRoot() === currentRoot) {
return p$[i];
}
}
},
get path() {
if (!this.event._path) {
var path = [];
var o = this.rootTarget;
while (o) {
path.push(o);
o = Polymer.dom(o).parentNode || o.host;
}
path.push(window);
this.event._path = path;
}
return this.event._path;
}
};
}
var factory = function (event) {
if (!event.__eventApi) {
event.__eventApi = new DomApi.Event(event);
}
return event.__eventApi;
}; };
return { factory: factory };
}(); }();
(function () { (function () {
'use strict';
var DomApi = Polymer.DomApi.ctor;
Object.defineProperty(DomApi.prototype, 'classList', {
get: function () {
if (!this._classList) {
this._classList = new DomApi.ClassList(this);
}
return this._classList;
},
configurable: true
});
DomApi.ClassList = function (host) {
this.domApi = host;
this.node = host.node;
};
DomApi.ClassList.prototype = {
add: function () {
this.node.classList.add.apply(this.node.classList, arguments);
this.domApi._distributeParent();
},
remove: function () {
this.node.classList.remove.apply(this.node.classList, arguments);
this.domApi._distributeParent();
},
toggle: function () {
this.node.classList.toggle.apply(this.node.classList, arguments);
this.domApi._distributeParent();
},
contains: function () {
return this.node.classList.contains.apply(this.node.classList, arguments);
}
};
}());
(function () {
'use strict';
var DomApi = Polymer.DomApi.ctor;
var Settings = Polymer.Settings;
var hasDomApi = Polymer.DomApi.hasDomApi;
DomApi.EffectiveNodesObserver = function (domApi) {
this.domApi = domApi;
this.node = this.domApi.node;
this._listeners = [];
};
DomApi.EffectiveNodesObserver.prototype = {
addListener: function (callback) {
if (!this._isSetup) {
this._setup();
this._isSetup = true;
}
var listener = {
fn: callback,
_nodes: []
};
this._listeners.push(listener);
this._scheduleNotify();
return listener;
},
removeListener: function (handle) {
var i = this._listeners.indexOf(handle);
if (i >= 0) {
this._listeners.splice(i, 1);
handle._nodes = [];
}
if (!this._hasListeners()) {
this._cleanup();
this._isSetup = false;
}
},
_setup: function () {
this._observeContentElements(this.domApi.childNodes);
},
_cleanup: function () {
this._unobserveContentElements(this.domApi.childNodes);
},
_hasListeners: function () {
return Boolean(this._listeners.length);
},
_scheduleNotify: function () {
if (this._debouncer) {
this._debouncer.stop();
}
this._debouncer = Polymer.Debounce(this._debouncer, this._notify);
this._debouncer.context = this;
Polymer.dom.addDebouncer(this._debouncer);
},
notify: function () {
if (this._hasListeners()) {
this._scheduleNotify();
}
},
_notify: function (mxns) {
this._beforeCallListeners();
this._callListeners();
},
_beforeCallListeners: function () {
this._updateContentElements();
},
_updateContentElements: function () {
this._observeContentElements(this.domApi.childNodes);
},
_observeContentElements: function (elements) {
for (var i = 0, n; i < elements.length && (n = elements[i]); i++) {
if (this._isContent(n)) {
n.__observeNodesMap = n.__observeNodesMap || new WeakMap();
if (!n.__observeNodesMap.has(this)) {
n.__observeNodesMap.set(this, this._observeContent(n));
}
}
}
},
_observeContent: function (content) {
var self = this;
var h = Polymer.dom(content).observeNodes(function () {
self._scheduleNotify();
});
h._avoidChangeCalculation = true;
return h;
},
_unobserveContentElements: function (elements) {
for (var i = 0, n, h; i < elements.length && (n = elements[i]); i++) {
if (this._isContent(n)) {
h = n.__observeNodesMap.get(this);
if (h) {
Polymer.dom(n).unobserveNodes(h);
n.__observeNodesMap.delete(this);
}
}
}
},
_isContent: function (node) {
return node.localName === 'content';
},
_callListeners: function () {
var o$ = this._listeners;
var nodes = this._getEffectiveNodes();
for (var i = 0, o; i < o$.length && (o = o$[i]); i++) {
var info = this._generateListenerInfo(o, nodes);
if (info || o._alwaysNotify) {
this._callListener(o, info);
}
}
},
_getEffectiveNodes: function () {
return this.domApi.getEffectiveChildNodes();
},
_generateListenerInfo: function (listener, newNodes) {
if (listener._avoidChangeCalculation) {
return true;
}
var oldNodes = listener._nodes;
var info = {
target: this.node,
addedNodes: [],
removedNodes: []
};
var splices = Polymer.ArraySplice.calculateSplices(newNodes, oldNodes);
for (var i = 0, s; i < splices.length && (s = splices[i]); i++) {
for (var j = 0, n; j < s.removed.length && (n = s.removed[j]); j++) {
info.removedNodes.push(n);
}
}
for (var i = 0, s; i < splices.length && (s = splices[i]); i++) {
for (var j = s.index; j < s.index + s.addedCount; j++) {
info.addedNodes.push(newNodes[j]);
}
}
listener._nodes = newNodes;
if (info.addedNodes.length || info.removedNodes.length) {
return info;
}
},
_callListener: function (listener, info) {
return listener.fn.call(this.node, info);
},
enableShadowAttributeTracking: function () {
}
};
if (Settings.useShadow) {
var baseSetup = DomApi.EffectiveNodesObserver.prototype._setup;
var baseCleanup = DomApi.EffectiveNodesObserver.prototype._cleanup;
var beforeCallListeners = DomApi.EffectiveNodesObserver.prototype._beforeCallListeners;
Polymer.Base.extend(DomApi.EffectiveNodesObserver.prototype, {
_setup: function () {
if (!this._observer) {
var self = this;
this._mutationHandler = function (mxns) {
if (mxns && mxns.length) {
self._scheduleNotify();
}
};
this._observer = new MutationObserver(this._mutationHandler);
this._boundFlush = function () {
self._flush();
};
Polymer.dom.addStaticFlush(this._boundFlush);
this._observer.observe(this.node, { childList: true });
}
baseSetup.call(this);
},
_cleanup: function () {
this._observer.disconnect();
this._observer = null;
this._mutationHandler = null;
Polymer.dom.removeStaticFlush(this._boundFlush);
baseCleanup.call(this);
},
_flush: function () {
if (this._observer) {
this._mutationHandler(this._observer.takeRecords());
}
},
enableShadowAttributeTracking: function () {
if (this._observer) {
this._makeContentListenersAlwaysNotify();
this._observer.disconnect();
this._observer.observe(this.node, {
childList: true,
attributes: true,
subtree: true
});
var root = this.domApi.getOwnerRoot();
var host = root && root.host;
if (host && Polymer.dom(host).observer) {
Polymer.dom(host).observer.enableShadowAttributeTracking();
}
}
},
_makeContentListenersAlwaysNotify: function () {
for (var i = 0, h; i < this._listeners.length; i++) {
h = this._listeners[i];
h._alwaysNotify = h._isContentListener;
}
}
});
}
}());
(function () {
'use strict';
var DomApi = Polymer.DomApi.ctor;
var Settings = Polymer.Settings;
DomApi.DistributedNodesObserver = function (domApi) {
DomApi.EffectiveNodesObserver.call(this, domApi);
};
DomApi.DistributedNodesObserver.prototype = Object.create(DomApi.EffectiveNodesObserver.prototype);
Polymer.Base.extend(DomApi.DistributedNodesObserver.prototype, {
_setup: function () {
},
_cleanup: function () {
},
_beforeCallListeners: function () {
},
_getEffectiveNodes: function () {
return this.domApi.getDistributedNodes();
}
});
if (Settings.useShadow) {
Polymer.Base.extend(DomApi.DistributedNodesObserver.prototype, {
_setup: function () {
if (!this._observer) {
var root = this.domApi.getOwnerRoot();
var host = root && root.host;
if (host) {
var self = this;
this._observer = Polymer.dom(host).observeNodes(function () {
self._scheduleNotify();
});
this._observer._isContentListener = true;
if (this._hasAttrSelect()) {
Polymer.dom(host).observer.enableShadowAttributeTracking();
}
}
}
},
_hasAttrSelect: function () {
var select = this.node.getAttribute('select');
return select && select.match(/[[.]+/);
},
_cleanup: function () {
var root = this.domApi.getOwnerRoot();
var host = root && root.host;
if (host) {
Polymer.dom(host).unobserveNodes(this._observer);
}
this._observer = null;
}
});
}
}());
(function () {
var hasDomApi = Polymer.DomApi.hasDomApi;
Polymer.Base._addFeature({ Polymer.Base._addFeature({
_prepShady: function () { _prepShady: function () {
this._useContent = this._useContent || Boolean(this._template); this._useContent = this._useContent || Boolean(this._template);
...@@ -1194,6 +1554,7 @@ upgradeLightChildren(this._lightChildren); ...@@ -1194,6 +1554,7 @@ upgradeLightChildren(this._lightChildren);
_createLocalRoot: function () { _createLocalRoot: function () {
this.shadyRoot = this.root; this.shadyRoot = this.root;
this.shadyRoot._distributionClean = false; this.shadyRoot._distributionClean = false;
this.shadyRoot._hasDistributed = false;
this.shadyRoot._isShadyRoot = true; this.shadyRoot._isShadyRoot = true;
this.shadyRoot._dirtyRoots = []; this.shadyRoot._dirtyRoots = [];
var i$ = this.shadyRoot._insertionPoints = !this._notes || this._notes._hasContent ? this.shadyRoot.querySelectorAll('content') : []; var i$ = this.shadyRoot._insertionPoints = !this._notes || this._notes._hasContent ? this.shadyRoot.querySelectorAll('content') : [];
...@@ -1244,6 +1605,7 @@ if (this._useContent) { ...@@ -1244,6 +1605,7 @@ if (this._useContent) {
this.shadyRoot._distributionClean = true; this.shadyRoot._distributionClean = true;
if (hasInsertionPoint(this.shadyRoot)) { if (hasInsertionPoint(this.shadyRoot)) {
this._composeTree(); this._composeTree();
notifyContentObservers(this.shadyRoot);
} else { } else {
if (!this.shadyRoot._hasDistributed) { if (!this.shadyRoot._hasDistributed) {
this.textContent = ''; this.textContent = '';
...@@ -1254,6 +1616,9 @@ var children = this._composeNode(this); ...@@ -1254,6 +1616,9 @@ var children = this._composeNode(this);
this._updateChildNodes(this, children); this._updateChildNodes(this, children);
} }
} }
if (!this.shadyRoot._hasDistributed) {
notifyInitialDistribution(this);
}
this.shadyRoot._hasDistributed = true; this.shadyRoot._hasDistributed = true;
} }
}, },
...@@ -1471,6 +1836,19 @@ return host.domHost; ...@@ -1471,6 +1836,19 @@ return host.domHost;
} }
} }
} }
function notifyContentObservers(root) {
for (var i = 0, c; i < root._insertionPoints.length; i++) {
c = root._insertionPoints[i];
if (hasDomApi(c)) {
Polymer.dom(c).notifyObserver();
}
}
}
function notifyInitialDistribution(host) {
if (hasDomApi(host)) {
Polymer.dom(host).notifyObserver();
}
}
var needsUpgrade = window.CustomElements && !CustomElements.useNative; var needsUpgrade = window.CustomElements && !CustomElements.useNative;
function upgradeLightChildren(children) { function upgradeLightChildren(children) {
if (needsUpgrade && children) { if (needsUpgrade && children) {
...@@ -1503,20 +1881,23 @@ Polymer.DomModule = document.createElement('dom-module'); ...@@ -1503,20 +1881,23 @@ Polymer.DomModule = document.createElement('dom-module');
Polymer.Base._addFeature({ Polymer.Base._addFeature({
_registerFeatures: function () { _registerFeatures: function () {
this._prepIs(); this._prepIs();
this._prepAttributes();
this._prepBehaviors(); this._prepBehaviors();
this._prepConstructor(); this._prepConstructor();
this._prepTemplate(); this._prepTemplate();
this._prepShady(); this._prepShady();
this._prepPropertyInfo();
}, },
_prepBehavior: function (b) { _prepBehavior: function (b) {
this._addHostAttributes(b.hostAttributes); this._addHostAttributes(b.hostAttributes);
}, },
_initFeatures: function () { _initFeatures: function () {
this._registerHost();
if (this._template) {
this._poolContent(); this._poolContent();
this._pushHost(); this._beginHosting();
this._stampTemplate(); this._stampTemplate();
this._popHost(); this._endHosting();
}
this._marshalHostAttributes(); this._marshalHostAttributes();
this._setupDebouncers(); this._setupDebouncers();
this._marshalBehaviors(); this._marshalBehaviors();
......
...@@ -21,35 +21,79 @@ Polymer.Annotations = { ...@@ -21,35 +21,79 @@ Polymer.Annotations = {
parseAnnotations: function (template) { parseAnnotations: function (template) {
var list = []; var list = [];
var content = template._content || template.content; var content = template._content || template.content;
this._parseNodeAnnotations(content, list); this._parseNodeAnnotations(content, list, template.hasAttribute('strip-whitespace'));
return list; return list;
}, },
_parseNodeAnnotations: function (node, list) { _parseNodeAnnotations: function (node, list, stripWhiteSpace) {
return node.nodeType === Node.TEXT_NODE ? this._parseTextNodeAnnotation(node, list) : this._parseElementAnnotations(node, list); return node.nodeType === Node.TEXT_NODE ? this._parseTextNodeAnnotation(node, list) : this._parseElementAnnotations(node, list, stripWhiteSpace);
}, },
_testEscape: function (value) { _bindingRegex: /([^{[]*)(\{\{|\[\[)(?!\}\}|\]\])(.+?)(?:\]\]|\}\})/g,
var escape = value.slice(0, 2); _parseBindings: function (text) {
if (escape === '{{' || escape === '[[') { var re = this._bindingRegex;
return escape; var parts = [];
var m, lastIndex;
while ((m = re.exec(text)) !== null) {
if (m[1]) {
parts.push({ literal: m[1] });
}
var mode = m[2][0];
var value = m[3].trim();
var negate = false;
if (value[0] == '!') {
negate = true;
value = value.substring(1).trim();
}
var customEvent, notifyEvent, colon;
if (mode == '{' && (colon = value.indexOf('::')) > 0) {
notifyEvent = value.substring(colon + 2);
value = value.substring(0, colon);
customEvent = true;
}
parts.push({
compoundIndex: parts.length,
value: value,
mode: mode,
negate: negate,
event: notifyEvent,
customEvent: customEvent
});
lastIndex = re.lastIndex;
}
if (lastIndex && lastIndex < text.length) {
var literal = text.substring(lastIndex);
if (literal) {
parts.push({ literal: literal });
} }
}
if (parts.length) {
return parts;
}
},
_literalFromParts: function (parts) {
var s = '';
for (var i = 0; i < parts.length; i++) {
var literal = parts[i].literal;
s += literal || '';
}
return s;
}, },
_parseTextNodeAnnotation: function (node, list) { _parseTextNodeAnnotation: function (node, list) {
var v = node.textContent; var parts = this._parseBindings(node.textContent);
var escape = this._testEscape(v); if (parts) {
if (escape) { node.textContent = this._literalFromParts(parts) || ' ';
node.textContent = ' ';
var annote = { var annote = {
bindings: [{ bindings: [{
kind: 'text', kind: 'text',
mode: escape[0], name: 'textContent',
value: v.slice(2, -2).trim() parts: parts,
isCompound: parts.length !== 1
}] }]
}; };
list.push(annote); list.push(annote);
return annote; return annote;
} }
}, },
_parseElementAnnotations: function (element, list) { _parseElementAnnotations: function (element, list, stripWhiteSpace) {
var annote = { var annote = {
bindings: [], bindings: [],
events: [] events: []
...@@ -57,7 +101,7 @@ events: [] ...@@ -57,7 +101,7 @@ events: []
if (element.localName === 'content') { if (element.localName === 'content') {
list._hasContent = true; list._hasContent = true;
} }
this._parseChildNodesAnnotations(element, annote, list); this._parseChildNodesAnnotations(element, annote, list, stripWhiteSpace);
if (element.attributes) { if (element.attributes) {
this._parseNodeAttributeAnnotations(element, annote, list); this._parseNodeAttributeAnnotations(element, annote, list);
if (this.prepElement) { if (this.prepElement) {
...@@ -69,26 +113,38 @@ list.push(annote); ...@@ -69,26 +113,38 @@ list.push(annote);
} }
return annote; return annote;
}, },
_parseChildNodesAnnotations: function (root, annote, list, callback) { _parseChildNodesAnnotations: function (root, annote, list, stripWhiteSpace) {
if (root.firstChild) { if (root.firstChild) {
for (var i = 0, node = root.firstChild; node; node = node.nextSibling, i++) { var node = root.firstChild;
var i = 0;
while (node) {
var next = node.nextSibling;
if (node.localName === 'template' && !node.hasAttribute('preserve-content')) { if (node.localName === 'template' && !node.hasAttribute('preserve-content')) {
this._parseTemplate(node, i, list, annote); this._parseTemplate(node, i, list, annote);
} }
if (node.nodeType === Node.TEXT_NODE) { if (node.nodeType === Node.TEXT_NODE) {
var n = node.nextSibling; var n = next;
while (n && n.nodeType === Node.TEXT_NODE) { while (n && n.nodeType === Node.TEXT_NODE) {
node.textContent += n.textContent; node.textContent += n.textContent;
next = n.nextSibling;
root.removeChild(n); root.removeChild(n);
n = n.nextSibling; n = next;
} }
if (stripWhiteSpace && !node.textContent.trim()) {
root.removeChild(node);
i--;
} }
var childAnnotation = this._parseNodeAnnotations(node, list, callback); }
if (node.parentNode) {
var childAnnotation = this._parseNodeAnnotations(node, list, stripWhiteSpace);
if (childAnnotation) { if (childAnnotation) {
childAnnotation.parent = annote; childAnnotation.parent = annote;
childAnnotation.index = i; childAnnotation.index = i;
} }
} }
node = next;
i++;
}
} }
}, },
_parseTemplate: function (node, index, list, parent) { _parseTemplate: function (node, index, list, parent) {
...@@ -104,62 +160,50 @@ index: index ...@@ -104,62 +160,50 @@ index: index
}); });
}, },
_parseNodeAttributeAnnotations: function (node, annotation) { _parseNodeAttributeAnnotations: function (node, annotation) {
for (var i = node.attributes.length - 1, a; a = node.attributes[i]; i--) { var attrs = Array.prototype.slice.call(node.attributes);
var n = a.name, v = a.value; for (var i = attrs.length - 1, a; a = attrs[i]; i--) {
if (n === 'id' && !this._testEscape(v)) { var n = a.name;
annotation.id = v; var v = a.value;
} else if (n.slice(0, 3) === 'on-') { var b;
if (n.slice(0, 3) === 'on-') {
node.removeAttribute(n); node.removeAttribute(n);
annotation.events.push({ annotation.events.push({
name: n.slice(3), name: n.slice(3),
value: v value: v
}); });
} else { } else if (b = this._parseNodeAttributeAnnotation(node, n, v)) {
var b = this._parseNodeAttributeAnnotation(node, n, v);
if (b) {
annotation.bindings.push(b); annotation.bindings.push(b);
} } else if (n === 'id') {
annotation.id = v;
} }
} }
}, },
_parseNodeAttributeAnnotation: function (node, n, v) { _parseNodeAttributeAnnotation: function (node, name, value) {
var escape = this._testEscape(v); var parts = this._parseBindings(value);
if (escape) { if (parts) {
var customEvent; var origName = name;
var name = n;
var mode = escape[0];
v = v.slice(2, -2).trim();
var not = false;
if (v[0] == '!') {
v = v.substring(1);
not = true;
}
var kind = 'property'; var kind = 'property';
if (n[n.length - 1] == '$') { if (name[name.length - 1] == '$') {
name = n.slice(0, -1); name = name.slice(0, -1);
kind = 'attribute'; kind = 'attribute';
} }
var notifyEvent, colon; var literal = this._literalFromParts(parts);
if (mode == '{' && (colon = v.indexOf('::')) > 0) { if (literal && kind == 'attribute') {
notifyEvent = v.substring(colon + 2); node.setAttribute(name, literal);
v = v.substring(0, colon);
customEvent = true;
} }
if (node.localName == 'input' && n == 'value') { if (node.localName == 'input' && name == 'value') {
node.setAttribute(n, ''); node.setAttribute(origName, '');
} }
node.removeAttribute(n); node.removeAttribute(origName);
if (kind === 'property') { if (kind === 'property') {
name = Polymer.CaseMap.dashToCamelCase(name); name = Polymer.CaseMap.dashToCamelCase(name);
} }
return { return {
kind: kind, kind: kind,
mode: mode,
name: name, name: name,
value: v, parts: parts,
negate: not, literal: literal,
event: notifyEvent, isCompound: parts.length !== 1
customEvent: customEvent
}; };
} }
}, },
...@@ -235,7 +279,10 @@ _prepAnnotations: function () { ...@@ -235,7 +279,10 @@ _prepAnnotations: function () {
if (!this._template) { if (!this._template) {
this._notes = []; this._notes = [];
} else { } else {
Polymer.Annotations.prepElement = this._prepElement.bind(this); var self = this;
Polymer.Annotations.prepElement = function (element) {
self._prepElement(element);
};
if (this._template._content && this._template._content._notes) { if (this._template._content && this._template._content._notes) {
this._notes = this._template._content._notes; this._notes = this._template._content._notes;
} else { } else {
...@@ -250,9 +297,14 @@ for (var i = 0; i < notes.length; i++) { ...@@ -250,9 +297,14 @@ for (var i = 0; i < notes.length; i++) {
var note = notes[i]; var note = notes[i];
for (var j = 0; j < note.bindings.length; j++) { for (var j = 0; j < note.bindings.length; j++) {
var b = note.bindings[j]; var b = note.bindings[j];
b.signature = this._parseMethod(b.value); for (var k = 0; k < b.parts.length; k++) {
if (!b.signature) { var p = b.parts[k];
b.model = this._modelForPath(b.value); if (!p.literal) {
p.signature = this._parseMethod(p.value);
if (!p.signature) {
p.model = this._modelForPath(p.value);
}
}
} }
} }
if (note.templateContent) { if (note.templateContent) {
...@@ -263,10 +315,12 @@ for (var prop in pp) { ...@@ -263,10 +315,12 @@ for (var prop in pp) {
bindings.push({ bindings.push({
index: note.index, index: note.index,
kind: 'property', kind: 'property',
mode: '{',
name: '_parent_' + prop, name: '_parent_' + prop,
parts: [{
mode: '{',
model: prop, model: prop,
value: prop value: prop
}]
}); });
} }
note.bindings = note.bindings.concat(bindings); note.bindings = note.bindings.concat(bindings);
...@@ -275,22 +329,24 @@ note.bindings = note.bindings.concat(bindings); ...@@ -275,22 +329,24 @@ note.bindings = note.bindings.concat(bindings);
}, },
_discoverTemplateParentProps: function (notes) { _discoverTemplateParentProps: function (notes) {
var pp = {}; var pp = {};
notes.forEach(function (n) { for (var i = 0, n; i < notes.length && (n = notes[i]); i++) {
n.bindings.forEach(function (b) { for (var j = 0, b$ = n.bindings, b; j < b$.length && (b = b$[j]); j++) {
if (b.signature) { for (var k = 0, p$ = b.parts, p; k < p$.length && (p = p$[k]); k++) {
var args = b.signature.args; if (p.signature) {
for (var k = 0; k < args.length; k++) { var args = p.signature.args;
pp[args[k].model] = true; for (var kk = 0; kk < args.length; kk++) {
pp[args[kk].model] = true;
} }
} else { } else {
pp[b.model] = true; pp[p.model] = true;
}
}
} }
});
if (n.templateContent) { if (n.templateContent) {
var tpp = n.templateContent._parentProps; var tpp = n.templateContent._parentProps;
Polymer.Base.mixin(pp, tpp); Polymer.Base.mixin(pp, tpp);
} }
}); }
return pp; return pp;
}, },
_prepElement: function (element) { _prepElement: function (element) {
...@@ -304,60 +360,98 @@ this._marshalAnnotatedNodes(); ...@@ -304,60 +360,98 @@ this._marshalAnnotatedNodes();
this._marshalAnnotatedListeners(); this._marshalAnnotatedListeners();
} }
}, },
_configureAnnotationReferences: function () { _configureAnnotationReferences: function (config) {
this._configureTemplateContent(); var notes = this._notes;
var nodes = this._nodes;
for (var i = 0; i < notes.length; i++) {
var note = notes[i];
var node = nodes[i];
this._configureTemplateContent(note, node);
this._configureCompoundBindings(note, node);
}
}, },
_configureTemplateContent: function () { _configureTemplateContent: function (note, node) {
this._notes.forEach(function (note, i) {
if (note.templateContent) { if (note.templateContent) {
this._nodes[i]._content = note.templateContent; node._content = note.templateContent;
}
},
_configureCompoundBindings: function (note, node) {
var bindings = note.bindings;
for (var i = 0; i < bindings.length; i++) {
var binding = bindings[i];
if (binding.isCompound) {
var storage = node.__compoundStorage__ || (node.__compoundStorage__ = {});
var parts = binding.parts;
var literals = new Array(parts.length);
for (var j = 0; j < parts.length; j++) {
literals[j] = parts[j].literal;
}
var name = binding.name;
storage[name] = literals;
if (binding.literal && binding.kind == 'property') {
if (node._configValue) {
node._configValue(name, binding.literal);
} else {
node[name] = binding.literal;
}
}
}
} }
}, this);
}, },
_marshalIdNodes: function () { _marshalIdNodes: function () {
this.$ = {}; this.$ = {};
this._notes.forEach(function (a) { for (var i = 0, l = this._notes.length, a; i < l && (a = this._notes[i]); i++) {
if (a.id) { if (a.id) {
this.$[a.id] = this._findAnnotatedNode(this.root, a); this.$[a.id] = this._findAnnotatedNode(this.root, a);
} }
}, this); }
}, },
_marshalAnnotatedNodes: function () { _marshalAnnotatedNodes: function () {
if (this._nodes) { if (this._notes && this._notes.length) {
this._nodes = this._nodes.map(function (a) { var r = new Array(this._notes.length);
return this._findAnnotatedNode(this.root, a); for (var i = 0; i < this._notes.length; i++) {
}, this); r[i] = this._findAnnotatedNode(this.root, this._notes[i]);
}
this._nodes = r;
} }
}, },
_marshalAnnotatedListeners: function () { _marshalAnnotatedListeners: function () {
this._notes.forEach(function (a) { for (var i = 0, l = this._notes.length, a; i < l && (a = this._notes[i]); i++) {
if (a.events && a.events.length) { if (a.events && a.events.length) {
var node = this._findAnnotatedNode(this.root, a); var node = this._findAnnotatedNode(this.root, a);
a.events.forEach(function (e) { for (var j = 0, e$ = a.events, e; j < e$.length && (e = e$[j]); j++) {
this.listen(node, e.name, e.value); this.listen(node, e.name, e.value);
}, this);
} }
}, this); }
}
} }
}); });
Polymer.Base._addFeature({ Polymer.Base._addFeature({
listeners: {}, listeners: {},
_listenListeners: function (listeners) { _listenListeners: function (listeners) {
var node, name, key; var node, name, eventName;
for (key in listeners) { for (eventName in listeners) {
if (key.indexOf('.') < 0) { if (eventName.indexOf('.') < 0) {
node = this; node = this;
name = key; name = eventName;
} else { } else {
name = key.split('.'); name = eventName.split('.');
node = this.$[name[0]]; node = this.$[name[0]];
name = name[1]; name = name[1];
} }
this.listen(node, name, listeners[key]); this.listen(node, name, listeners[eventName]);
} }
}, },
listen: function (node, eventName, methodName) { listen: function (node, eventName, methodName) {
this._listen(node, eventName, this._createEventHandler(node, eventName, methodName)); var handler = this._recallEventHandler(this, eventName, node, methodName);
if (!handler) {
handler = this._createEventHandler(node, eventName, methodName);
}
if (handler._listening) {
return;
}
this._listen(node, eventName, handler);
handler._listening = true;
}, },
_boundListenerKey: function (eventName, methodName) { _boundListenerKey: function (eventName, methodName) {
return eventName + ':' + methodName; return eventName + ':' + methodName;
...@@ -396,6 +490,7 @@ host[methodName](e, e.detail); ...@@ -396,6 +490,7 @@ host[methodName](e, e.detail);
host._warn(host._logf('_createEventHandler', 'listener method `' + methodName + '` not defined')); host._warn(host._logf('_createEventHandler', 'listener method `' + methodName + '` not defined'));
} }
}; };
handler._listening = false;
this._recordEventHandler(host, eventName, node, methodName, handler); this._recordEventHandler(host, eventName, node, methodName, handler);
return handler; return handler;
}, },
...@@ -403,6 +498,7 @@ unlisten: function (node, eventName, methodName) { ...@@ -403,6 +498,7 @@ unlisten: function (node, eventName, methodName) {
var handler = this._recallEventHandler(this, eventName, node, methodName); var handler = this._recallEventHandler(this, eventName, node, methodName);
if (handler) { if (handler) {
this._unlisten(node, eventName, handler); this._unlisten(node, eventName, handler);
handler._listening = false;
} }
}, },
_listen: function (node, eventName, handler) { _listen: function (node, eventName, handler) {
...@@ -414,6 +510,7 @@ node.removeEventListener(eventName, handler); ...@@ -414,6 +510,7 @@ node.removeEventListener(eventName, handler);
}); });
(function () { (function () {
'use strict'; 'use strict';
var wrap = Polymer.DomApi.wrap;
var HAS_NATIVE_TA = typeof document.head.style.touchAction === 'string'; var HAS_NATIVE_TA = typeof document.head.style.touchAction === 'string';
var GESTURE_KEY = '__polymerGestures'; var GESTURE_KEY = '__polymerGestures';
var HANDLED_OBJ = '__polymerGesturesHandled'; var HANDLED_OBJ = '__polymerGesturesHandled';
...@@ -564,8 +661,11 @@ return ev.target; ...@@ -564,8 +661,11 @@ return ev.target;
handleNative: function (ev) { handleNative: function (ev) {
var handled; var handled;
var type = ev.type; var type = ev.type;
var node = ev.currentTarget; var node = wrap(ev.currentTarget);
var gobj = node[GESTURE_KEY]; var gobj = node[GESTURE_KEY];
if (!gobj) {
return;
}
var gs = gobj[type]; var gs = gobj[type];
if (!gs) { if (!gs) {
return; return;
...@@ -648,6 +748,7 @@ Gestures.prevent('track'); ...@@ -648,6 +748,7 @@ Gestures.prevent('track');
} }
}, },
add: function (node, evType, handler) { add: function (node, evType, handler) {
node = wrap(node);
var recognizer = this.gestures[evType]; var recognizer = this.gestures[evType];
var deps = recognizer.deps; var deps = recognizer.deps;
var name = recognizer.name; var name = recognizer.name;
...@@ -676,6 +777,7 @@ this.setTouchAction(node, recognizer.touchAction); ...@@ -676,6 +777,7 @@ this.setTouchAction(node, recognizer.touchAction);
} }
}, },
remove: function (node, evType, handler) { remove: function (node, evType, handler) {
node = wrap(node);
var recognizer = this.gestures[evType]; var recognizer = this.gestures[evType];
var deps = recognizer.deps; var deps = recognizer.deps;
var name = recognizer.name; var name = recognizer.name;
...@@ -802,7 +904,9 @@ Gestures.fire(target, type, { ...@@ -802,7 +904,9 @@ Gestures.fire(target, type, {
x: event.clientX, x: event.clientX,
y: event.clientY, y: event.clientY,
sourceEvent: event, sourceEvent: event,
prevent: Gestures.prevent.bind(Gestures) prevent: function (e) {
return Gestures.prevent(e);
}
}); });
} }
}); });
...@@ -1094,12 +1198,17 @@ this._callbacks.splice(0, len); ...@@ -1094,12 +1198,17 @@ this._callbacks.splice(0, len);
this._lastVal += len; this._lastVal += len;
} }
}; };
new (window.MutationObserver || JsMutationObserver)(Polymer.Async._atEndOfMicrotask.bind(Polymer.Async)).observe(Polymer.Async._twiddle, { characterData: true }); new window.MutationObserver(function () {
Polymer.Async._atEndOfMicrotask();
}).observe(Polymer.Async._twiddle, { characterData: true });
Polymer.Debounce = function () { Polymer.Debounce = function () {
var Async = Polymer.Async; var Async = Polymer.Async;
var Debouncer = function (context) { var Debouncer = function (context) {
this.context = context; this.context = context;
this.boundComplete = this.complete.bind(this); var self = this;
this.boundComplete = function () {
self.complete();
};
}; };
Debouncer.prototype = { Debouncer.prototype = {
go: function (callback, wait) { go: function (callback, wait) {
...@@ -1176,6 +1285,32 @@ if (toElement) { ...@@ -1176,6 +1285,32 @@ if (toElement) {
Polymer.dom(toElement).setAttribute(name, ''); Polymer.dom(toElement).setAttribute(name, '');
} }
}, },
getEffectiveChildNodes: function () {
return Polymer.dom(this).getEffectiveChildNodes();
},
getEffectiveChildren: function () {
var list = Polymer.dom(this).getEffectiveChildNodes();
return list.filter(function (n) {
return n.nodeType === Node.ELEMENT_NODE;
});
},
getEffectiveTextContent: function () {
var cn = this.getEffectiveChildNodes();
var tc = [];
for (var i = 0, c; c = cn[i]; i++) {
if (c.nodeType !== Node.COMMENT_NODE) {
tc.push(Polymer.dom(c).textContent);
}
}
return tc.join('');
},
queryEffectiveChildren: function (slctr) {
var e$ = Polymer.dom(this).queryDistributedElements(slctr);
return e$ && e$[0];
},
queryAllEffectiveChildren: function (slctr) {
return Polymer.dom(this).queryDistributedElements(slctr);
},
getContentChildNodes: function (slctr) { getContentChildNodes: function (slctr) {
var content = Polymer.dom(this.root).querySelector(slctr || 'content'); var content = Polymer.dom(this.root).querySelector(slctr || 'content');
return content ? Polymer.dom(content).getDistributedNodes() : []; return content ? Polymer.dom(content).getDistributedNodes() : [];
...@@ -1188,19 +1323,37 @@ return n.nodeType === Node.ELEMENT_NODE; ...@@ -1188,19 +1323,37 @@ return n.nodeType === Node.ELEMENT_NODE;
fire: function (type, detail, options) { fire: function (type, detail, options) {
options = options || Polymer.nob; options = options || Polymer.nob;
var node = options.node || this; var node = options.node || this;
var detail = detail === null || detail === undefined ? Polymer.nob : detail; var detail = detail === null || detail === undefined ? {} : detail;
var bubbles = options.bubbles === undefined ? true : options.bubbles; var bubbles = options.bubbles === undefined ? true : options.bubbles;
var cancelable = Boolean(options.cancelable); var cancelable = Boolean(options.cancelable);
var event = new CustomEvent(type, { var useCache = options._useCache;
var event = this._getEvent(type, bubbles, cancelable, useCache);
event.detail = detail;
if (useCache) {
this.__eventCache[type] = null;
}
node.dispatchEvent(event);
if (useCache) {
this.__eventCache[type] = event;
}
return event;
},
__eventCache: {},
_getEvent: function (type, bubbles, cancelable, useCache) {
var event = useCache && this.__eventCache[type];
if (!event || (event.bubbles != bubbles || event.cancelable != cancelable)) {
event = new Event(type, {
bubbles: Boolean(bubbles), bubbles: Boolean(bubbles),
cancelable: cancelable, cancelable: cancelable
detail: detail
}); });
node.dispatchEvent(event); }
return event; return event;
}, },
async: function (callback, waitTime) { async: function (callback, waitTime) {
return Polymer.Async.run(callback.bind(this), waitTime); var self = this;
return Polymer.Async.run(function () {
callback.call(self);
}, waitTime);
}, },
cancelAsync: function (handle) { cancelAsync: function (handle) {
Polymer.Async.cancel(handle); Polymer.Async.cancel(handle);
...@@ -1213,7 +1366,7 @@ if (index >= 0) { ...@@ -1213,7 +1366,7 @@ if (index >= 0) {
return path.splice(index, 1); return path.splice(index, 1);
} }
} else { } else {
var arr = this.get(path); var arr = this._get(path);
index = arr.indexOf(item); index = arr.indexOf(item);
if (index >= 0) { if (index >= 0) {
return this.splice(path, index, 1); return this.splice(path, index, 1);
...@@ -1233,11 +1386,16 @@ importHref: function (href, onload, onerror) { ...@@ -1233,11 +1386,16 @@ importHref: function (href, onload, onerror) {
var l = document.createElement('link'); var l = document.createElement('link');
l.rel = 'import'; l.rel = 'import';
l.href = href; l.href = href;
var self = this;
if (onload) { if (onload) {
l.onload = onload.bind(this); l.onload = function (e) {
return onload.call(self, e);
};
} }
if (onerror) { if (onerror) {
l.onerror = onerror.bind(this); l.onerror = function (e) {
return onerror.call(self, e);
};
} }
document.head.appendChild(l); document.head.appendChild(l);
return l; return l;
...@@ -1250,20 +1408,27 @@ elt[n] = props[n]; ...@@ -1250,20 +1408,27 @@ elt[n] = props[n];
} }
} }
return elt; return elt;
},
isLightDescendant: function (node) {
return this !== node && this.contains(node) && Polymer.dom(this).getOwnerRoot() === Polymer.dom(node).getOwnerRoot();
},
isLocalDescendant: function (node) {
return this.root === Polymer.dom(node).getOwnerRoot();
} }
}); });
Polymer.Bind = { Polymer.Bind = {
_dataEventCache: {},
prepareModel: function (model) { prepareModel: function (model) {
model._propertyEffects = {};
model._bindListeners = [];
Polymer.Base.mixin(model, this._modelApi); Polymer.Base.mixin(model, this._modelApi);
}, },
_modelApi: { _modelApi: {
_notifyChange: function (property) { _notifyChange: function (source, event, value) {
var eventName = Polymer.CaseMap.camelToDashCase(property) + '-changed'; value = value === undefined ? this[source] : value;
Polymer.Base.fire(eventName, { value: this[property] }, { event = event || Polymer.CaseMap.camelToDashCase(source) + '-changed';
this.fire(event, { value: value }, {
bubbles: false, bubbles: false,
node: this cancelable: false,
_useCache: true
}); });
}, },
_propertySetter: function (property, value, effects, fromAbove) { _propertySetter: function (property, value, effects, fromAbove) {
...@@ -1292,12 +1457,9 @@ node[property] = value; ...@@ -1292,12 +1457,9 @@ node[property] = value;
} }
}, },
_effectEffects: function (property, value, effects, old, fromAbove) { _effectEffects: function (property, value, effects, old, fromAbove) {
effects.forEach(function (fx) { for (var i = 0, l = effects.length, fx; i < l && (fx = effects[i]); i++) {
var fn = Polymer.Bind['_' + fx.kind + 'Effect']; fx.fn.call(this, property, value, fx.effect, old, fromAbove);
if (fn) {
fn.call(this, property, value, fx.effect, old, fromAbove);
} }
}, this);
}, },
_clearPath: function (path) { _clearPath: function (path) {
for (var prop in this.__data__) { for (var prop in this.__data__) {
...@@ -1308,6 +1470,9 @@ this.__data__[prop] = undefined; ...@@ -1308,6 +1470,9 @@ this.__data__[prop] = undefined;
} }
}, },
ensurePropertyEffects: function (model, property) { ensurePropertyEffects: function (model, property) {
if (!model._propertyEffects) {
model._propertyEffects = {};
}
var fx = model._propertyEffects[property]; var fx = model._propertyEffects[property];
if (!fx) { if (!fx) {
fx = model._propertyEffects[property] = []; fx = model._propertyEffects[property] = [];
...@@ -1316,10 +1481,13 @@ return fx; ...@@ -1316,10 +1481,13 @@ return fx;
}, },
addPropertyEffect: function (model, property, kind, effect) { addPropertyEffect: function (model, property, kind, effect) {
var fx = this.ensurePropertyEffects(model, property); var fx = this.ensurePropertyEffects(model, property);
fx.push({ var propEffect = {
kind: kind, kind: kind,
effect: effect effect: effect,
}); fn: Polymer.Bind['_' + kind + 'Effect']
};
fx.push(propEffect);
return propEffect;
}, },
createBindings: function (model) { createBindings: function (model) {
var fx$ = model._propertyEffects; var fx$ = model._propertyEffects;
...@@ -1369,7 +1537,10 @@ upper: function (name) { ...@@ -1369,7 +1537,10 @@ upper: function (name) {
return name[0].toUpperCase() + name.substring(1); return name[0].toUpperCase() + name.substring(1);
}, },
_addAnnotatedListener: function (model, index, property, path, event) { _addAnnotatedListener: function (model, index, property, path, event) {
var fn = this._notedListenerFactory(property, path, this._isStructured(path), this._isEventBogus); if (!model._bindListeners) {
model._bindListeners = [];
}
var fn = this._notedListenerFactory(property, path, this._isStructured(path));
var eventName = event || Polymer.CaseMap.camelToDashCase(property) + '-changed'; var eventName = event || Polymer.CaseMap.camelToDashCase(property) + '-changed';
model._bindListeners.push({ model._bindListeners.push({
index: index, index: index,
...@@ -1385,54 +1556,59 @@ return path.indexOf('.') > 0; ...@@ -1385,54 +1556,59 @@ return path.indexOf('.') > 0;
_isEventBogus: function (e, target) { _isEventBogus: function (e, target) {
return e.path && e.path[0] !== target; return e.path && e.path[0] !== target;
}, },
_notedListenerFactory: function (property, path, isStructured, bogusTest) { _notedListenerFactory: function (property, path, isStructured) {
return function (e, target) { return function (target, value, targetPath) {
if (!bogusTest(e, target)) { if (targetPath) {
if (e.detail && e.detail.path) { this._notifyPath(this._fixPath(path, property, targetPath), value);
this.notifyPath(this._fixPath(path, property, e.detail.path), e.detail.value);
} else { } else {
var value = target[property]; value = target[property];
if (!isStructured) { if (!isStructured) {
this[path] = target[property]; this[path] = value;
} else { } else {
if (this.__data__[path] != value) { if (this.__data__[path] != value) {
this.set(path, value); this.set(path, value);
} }
} }
} }
}
}; };
}, },
prepareInstance: function (inst) { prepareInstance: function (inst) {
inst.__data__ = Object.create(null); inst.__data__ = Object.create(null);
}, },
setupBindListeners: function (inst) { setupBindListeners: function (inst) {
inst._bindListeners.forEach(function (info) { var b$ = inst._bindListeners;
for (var i = 0, l = b$.length, info; i < l && (info = b$[i]); i++) {
var node = inst._nodes[info.index]; var node = inst._nodes[info.index];
node.addEventListener(info.event, inst._notifyListener.bind(inst, info.changedFn)); this._addNotifyListener(node, inst, info.event, info.changedFn);
}
;
},
_addNotifyListener: function (element, context, event, changedFn) {
element.addEventListener(event, function (e) {
return context._notifyListener(changedFn, e);
}); });
} }
}; };
Polymer.Base.extend(Polymer.Bind, { Polymer.Base.extend(Polymer.Bind, {
_shouldAddListener: function (effect) { _shouldAddListener: function (effect) {
return effect.name && effect.mode === '{' && !effect.negate && effect.kind != 'attribute'; return effect.name && effect.kind != 'attribute' && effect.kind != 'text' && !effect.isCompound && effect.parts[0].mode === '{' && !effect.parts[0].negate;
}, },
_annotationEffect: function (source, value, effect) { _annotationEffect: function (source, value, effect) {
if (source != effect.value) { if (source != effect.value) {
value = this.get(effect.value); value = this._get(effect.value);
this.__data__[effect.value] = value; this.__data__[effect.value] = value;
} }
var calc = effect.negate ? !value : value; var calc = effect.negate ? !value : value;
if (!effect.customEvent || this._nodes[effect.index][effect.name] !== calc) { if (!effect.customEvent || this._nodes[effect.index][effect.name] !== calc) {
return this._applyEffectValue(calc, effect); return this._applyEffectValue(effect, calc);
} }
}, },
_reflectEffect: function (source) { _reflectEffect: function (source, value, effect) {
this.reflectPropertyToAttribute(source); this.reflectPropertyToAttribute(source, effect.attribute, value);
}, },
_notifyEffect: function (source, value, effect, old, fromAbove) { _notifyEffect: function (source, value, effect, old, fromAbove) {
if (!fromAbove) { if (!fromAbove) {
this._notifyChange(source); this._notifyChange(source, effect.event, value);
} }
}, },
_functionEffect: function (source, value, fn, old, fromAbove) { _functionEffect: function (source, value, fn, old, fromAbove) {
...@@ -1462,7 +1638,7 @@ var args = Polymer.Bind._marshalArgs(this.__data__, effect, source, value); ...@@ -1462,7 +1638,7 @@ var args = Polymer.Bind._marshalArgs(this.__data__, effect, source, value);
if (args) { if (args) {
var fn = this[effect.method]; var fn = this[effect.method];
if (fn) { if (fn) {
this.__setProperty(effect.property, fn.apply(this, args)); this.__setProperty(effect.name, fn.apply(this, args));
} else { } else {
this._warn(this._logf('_computeEffect', 'compute method `' + effect.method + '` not defined')); this._warn(this._logf('_computeEffect', 'compute method `' + effect.method + '` not defined'));
} }
...@@ -1478,7 +1654,7 @@ var computedvalue = fn.apply(computedHost, args); ...@@ -1478,7 +1654,7 @@ var computedvalue = fn.apply(computedHost, args);
if (effect.negate) { if (effect.negate) {
computedvalue = !computedvalue; computedvalue = !computedvalue;
} }
this._applyEffectValue(computedvalue, effect); this._applyEffectValue(effect, computedvalue);
} }
} else { } else {
computedHost._warn(computedHost._logf('_annotatedComputationEffect', 'compute method `' + effect.method + '` not defined')); computedHost._warn(computedHost._logf('_annotatedComputationEffect', 'compute method `' + effect.method + '` not defined'));
...@@ -1494,7 +1670,7 @@ var v; ...@@ -1494,7 +1670,7 @@ var v;
if (arg.literal) { if (arg.literal) {
v = arg.value; v = arg.value;
} else if (arg.structured) { } else if (arg.structured) {
v = Polymer.Base.get(name, model); v = Polymer.Base._get(name, model);
} else { } else {
v = model[name]; v = model[name];
} }
...@@ -1518,7 +1694,8 @@ return values; ...@@ -1518,7 +1694,8 @@ return values;
}); });
Polymer.Base._addFeature({ Polymer.Base._addFeature({
_addPropertyEffect: function (property, kind, effect) { _addPropertyEffect: function (property, kind, effect) {
Polymer.Bind.addPropertyEffect(this, property, kind, effect); var prop = Polymer.Bind.addPropertyEffect(this, property, kind, effect);
prop.pathFn = this['_' + prop.kind + 'PathEffect'];
}, },
_prepEffects: function () { _prepEffects: function () {
Polymer.Bind.prepareModel(this); Polymer.Bind.prepareModel(this);
...@@ -1539,10 +1716,10 @@ prop.readOnly = true; ...@@ -1539,10 +1716,10 @@ prop.readOnly = true;
this._addComputedEffect(p, prop.computed); this._addComputedEffect(p, prop.computed);
} }
if (prop.notify) { if (prop.notify) {
this._addPropertyEffect(p, 'notify'); this._addPropertyEffect(p, 'notify', { event: Polymer.CaseMap.camelToDashCase(p) + '-changed' });
} }
if (prop.reflectToAttribute) { if (prop.reflectToAttribute) {
this._addPropertyEffect(p, 'reflect'); this._addPropertyEffect(p, 'reflect', { attribute: Polymer.CaseMap.camelToDashCase(p) });
} }
if (prop.readOnly) { if (prop.readOnly) {
Polymer.Bind.ensurePropertyEffects(this, p); Polymer.Bind.ensurePropertyEffects(this, p);
...@@ -1552,14 +1729,14 @@ Polymer.Bind.ensurePropertyEffects(this, p); ...@@ -1552,14 +1729,14 @@ Polymer.Bind.ensurePropertyEffects(this, p);
}, },
_addComputedEffect: function (name, expression) { _addComputedEffect: function (name, expression) {
var sig = this._parseMethod(expression); var sig = this._parseMethod(expression);
sig.args.forEach(function (arg) { for (var i = 0, arg; i < sig.args.length && (arg = sig.args[i]); i++) {
this._addPropertyEffect(arg.model, 'compute', { this._addPropertyEffect(arg.model, 'compute', {
method: sig.method, method: sig.method,
args: sig.args, args: sig.args,
trigger: arg, trigger: arg,
property: name name: name
}); });
}, this); }
}, },
_addObserverEffect: function (property, observer) { _addObserverEffect: function (property, observer) {
this._addPropertyEffect(property, 'observer', { this._addPropertyEffect(property, 'observer', {
...@@ -1569,61 +1746,74 @@ property: property ...@@ -1569,61 +1746,74 @@ property: property
}, },
_addComplexObserverEffects: function (observers) { _addComplexObserverEffects: function (observers) {
if (observers) { if (observers) {
observers.forEach(function (observer) { for (var i = 0, o; i < observers.length && (o = observers[i]); i++) {
this._addComplexObserverEffect(observer); this._addComplexObserverEffect(o);
}, this); }
} }
}, },
_addComplexObserverEffect: function (observer) { _addComplexObserverEffect: function (observer) {
var sig = this._parseMethod(observer); var sig = this._parseMethod(observer);
sig.args.forEach(function (arg) { for (var i = 0, arg; i < sig.args.length && (arg = sig.args[i]); i++) {
this._addPropertyEffect(arg.model, 'complexObserver', { this._addPropertyEffect(arg.model, 'complexObserver', {
method: sig.method, method: sig.method,
args: sig.args, args: sig.args,
trigger: arg trigger: arg
}); });
}, this); }
}, },
_addAnnotationEffects: function (notes) { _addAnnotationEffects: function (notes) {
this._nodes = []; for (var i = 0, note; i < notes.length && (note = notes[i]); i++) {
notes.forEach(function (note) { var b$ = note.bindings;
var index = this._nodes.push(note) - 1; for (var j = 0, binding; j < b$.length && (binding = b$[j]); j++) {
note.bindings.forEach(function (binding) { this._addAnnotationEffect(binding, i);
this._addAnnotationEffect(binding, index); }
}, this); }
}, this);
}, },
_addAnnotationEffect: function (note, index) { _addAnnotationEffect: function (note, index) {
if (Polymer.Bind._shouldAddListener(note)) { if (Polymer.Bind._shouldAddListener(note)) {
Polymer.Bind._addAnnotatedListener(this, index, note.name, note.value, note.event); Polymer.Bind._addAnnotatedListener(this, index, note.name, note.parts[0].value, note.parts[0].event);
}
for (var i = 0; i < note.parts.length; i++) {
var part = note.parts[i];
if (part.signature) {
this._addAnnotatedComputationEffect(note, part, index);
} else if (!part.literal) {
this._addPropertyEffect(part.model, 'annotation', {
kind: note.kind,
index: index,
name: note.name,
value: part.value,
isCompound: note.isCompound,
compoundIndex: part.compoundIndex,
event: part.event,
customEvent: part.customEvent,
negate: part.negate
});
} }
if (note.signature) {
this._addAnnotatedComputationEffect(note, index);
} else {
note.index = index;
this._addPropertyEffect(note.model, 'annotation', note);
} }
}, },
_addAnnotatedComputationEffect: function (note, index) { _addAnnotatedComputationEffect: function (note, part, index) {
var sig = note.signature; var sig = part.signature;
if (sig.static) { if (sig.static) {
this.__addAnnotatedComputationEffect('__static__', index, note, sig, null); this.__addAnnotatedComputationEffect('__static__', index, note, part, null);
} else { } else {
sig.args.forEach(function (arg) { for (var i = 0, arg; i < sig.args.length && (arg = sig.args[i]); i++) {
if (!arg.literal) { if (!arg.literal) {
this.__addAnnotatedComputationEffect(arg.model, index, note, sig, arg); this.__addAnnotatedComputationEffect(arg.model, index, note, part, arg);
}
} }
}, this);
} }
}, },
__addAnnotatedComputationEffect: function (property, index, note, sig, trigger) { __addAnnotatedComputationEffect: function (property, index, note, part, trigger) {
this._addPropertyEffect(property, 'annotatedComputation', { this._addPropertyEffect(property, 'annotatedComputation', {
index: index, index: index,
isCompound: note.isCompound,
compoundIndex: part.compoundIndex,
kind: note.kind, kind: note.kind,
property: note.name, name: note.name,
negate: note.negate, negate: part.negate,
method: sig.method, method: part.signature.method,
args: sig.args, args: part.signature.args,
trigger: trigger trigger: trigger
}); });
}, },
...@@ -1690,11 +1880,18 @@ return a; ...@@ -1690,11 +1880,18 @@ return a;
}, },
_marshalInstanceEffects: function () { _marshalInstanceEffects: function () {
Polymer.Bind.prepareInstance(this); Polymer.Bind.prepareInstance(this);
if (this._bindListeners) {
Polymer.Bind.setupBindListeners(this); Polymer.Bind.setupBindListeners(this);
}
}, },
_applyEffectValue: function (value, info) { _applyEffectValue: function (info, value) {
var node = this._nodes[info.index]; var node = this._nodes[info.index];
var property = info.property || info.name || 'textContent'; var property = info.name;
if (info.isCompound) {
var storage = node.__compoundStorage__[property];
storage[info.compoundIndex] = value;
value = storage.join('');
}
if (info.kind == 'attribute') { if (info.kind == 'attribute') {
this.serializeValueToAttribute(value, property, node); this.serializeValueToAttribute(value, property, node);
} else { } else {
...@@ -1704,11 +1901,14 @@ value = this._scopeElementClass(node, value); ...@@ -1704,11 +1901,14 @@ value = this._scopeElementClass(node, value);
if (property === 'textContent' || node.localName == 'input' && property == 'value') { if (property === 'textContent' || node.localName == 'input' && property == 'value') {
value = value == undefined ? '' : value; value = value == undefined ? '' : value;
} }
return node[property] = value; var pinfo;
if (!node._propertyInfo || !(pinfo = node._propertyInfo[property]) || !pinfo.readOnly) {
this.__setProperty(property, value, true, node);
}
} }
}, },
_executeStaticEffects: function () { _executeStaticEffects: function () {
if (this._propertyEffects.__static__) { if (this._propertyEffects && this._propertyEffects.__static__) {
this._effectEffects('__static__', null, this._propertyEffects.__static__); this._effectEffects('__static__', null, this._propertyEffects.__static__);
} }
} }
...@@ -1716,12 +1916,14 @@ this._effectEffects('__static__', null, this._propertyEffects.__static__); ...@@ -1716,12 +1916,14 @@ this._effectEffects('__static__', null, this._propertyEffects.__static__);
Polymer.Base._addFeature({ Polymer.Base._addFeature({
_setupConfigure: function (initialConfig) { _setupConfigure: function (initialConfig) {
this._config = {}; this._config = {};
this._handlers = [];
if (initialConfig) {
for (var i in initialConfig) { for (var i in initialConfig) {
if (initialConfig[i] !== undefined) { if (initialConfig[i] !== undefined) {
this._config[i] = initialConfig[i]; this._config[i] = initialConfig[i];
} }
} }
this._handlers = []; }
}, },
_marshalAttributes: function () { _marshalAttributes: function () {
this._takeAttributesToModel(this._config); this._takeAttributesToModel(this._config);
...@@ -1731,7 +1933,10 @@ var model = this._clientsReadied ? this : this._config; ...@@ -1731,7 +1933,10 @@ var model = this._clientsReadied ? this : this._config;
this._setAttributeToProperty(model, name); this._setAttributeToProperty(model, name);
}, },
_configValue: function (name, value) { _configValue: function (name, value) {
var info = this._propertyInfo[name];
if (!info || !info.readOnly) {
this._config[name] = value; this._config[name] = value;
}
}, },
_beforeClientsReady: function () { _beforeClientsReady: function () {
this._configure(); this._configure();
...@@ -1740,13 +1945,15 @@ _configure: function () { ...@@ -1740,13 +1945,15 @@ _configure: function () {
this._configureAnnotationReferences(); this._configureAnnotationReferences();
this._aboveConfig = this.mixin({}, this._config); this._aboveConfig = this.mixin({}, this._config);
var config = {}; var config = {};
this.behaviors.forEach(function (b) { for (var i = 0; i < this.behaviors.length; i++) {
this._configureProperties(b.properties, config); this._configureProperties(this.behaviors[i].properties, config);
}, this); }
this._configureProperties(this.properties, config); this._configureProperties(this.properties, config);
this._mixinConfigure(config, this._aboveConfig); this.mixin(config, this._aboveConfig);
this._config = config; this._config = config;
if (this._clients && this._clients.length) {
this._distributeConfig(this._config); this._distributeConfig(this._config);
}
}, },
_configureProperties: function (properties, config) { _configureProperties: function (properties, config) {
for (var i in properties) { for (var i in properties) {
...@@ -1760,13 +1967,6 @@ config[i] = value; ...@@ -1760,13 +1967,6 @@ config[i] = value;
} }
} }
}, },
_mixinConfigure: function (a, b) {
for (var prop in b) {
if (!this.getPropertyInfo(prop).readOnly) {
a[prop] = b[prop];
}
}
},
_distributeConfig: function (config) { _distributeConfig: function (config) {
var fx$ = this._propertyEffects; var fx$ = this._propertyEffects;
if (fx$) { if (fx$) {
...@@ -1774,10 +1974,10 @@ for (var p in config) { ...@@ -1774,10 +1974,10 @@ for (var p in config) {
var fx = fx$[p]; var fx = fx$[p];
if (fx) { if (fx) {
for (var i = 0, l = fx.length, x; i < l && (x = fx[i]); i++) { for (var i = 0, l = fx.length, x; i < l && (x = fx[i]); i++) {
if (x.kind === 'annotation') { if (x.kind === 'annotation' && !x.isCompound) {
var node = this._nodes[x.effect.index]; var node = this._nodes[x.effect.index];
if (node._configValue) { if (node._configValue) {
var value = p === x.effect.value ? config[p] : this.get(x.effect.value, config); var value = p === x.effect.value ? config[p] : this._get(x.effect.value, config);
node._configValue(x.effect.name, value); node._configValue(x.effect.name, value);
} }
} }
...@@ -1799,14 +1999,22 @@ this.__setProperty(n, config[n], n in aboveConfig); ...@@ -1799,14 +1999,22 @@ this.__setProperty(n, config[n], n in aboveConfig);
} }
}, },
_notifyListener: function (fn, e) { _notifyListener: function (fn, e) {
if (!Polymer.Bind._isEventBogus(e, e.target)) {
var value, path;
if (e.detail) {
value = e.detail.value;
path = e.detail.path;
}
if (!this._clientsReadied) { if (!this._clientsReadied) {
this._queueHandler([ this._queueHandler([
fn, fn,
e, e.target,
e.target value,
path
]); ]);
} else { } else {
return fn.call(this, e, e.target); return fn.call(this, e.target, value, path);
}
} }
}, },
_queueHandler: function (args) { _queueHandler: function (args) {
...@@ -1815,7 +2023,7 @@ this._handlers.push(args); ...@@ -1815,7 +2023,7 @@ this._handlers.push(args);
_flushHandlers: function () { _flushHandlers: function () {
var h$ = this._handlers; var h$ = this._handlers;
for (var i = 0, l = h$.length, h; i < l && (h = h$[i]); i++) { for (var i = 0, l = h$.length, h; i < l && (h = h$[i]); i++) {
h[0].call(this, h[1], h[2]); h[0].call(this, h[1], h[2], h[3]);
} }
this._handlers = []; this._handlers = [];
} }
...@@ -1824,11 +2032,16 @@ this._handlers = []; ...@@ -1824,11 +2032,16 @@ this._handlers = [];
'use strict'; 'use strict';
Polymer.Base._addFeature({ Polymer.Base._addFeature({
notifyPath: function (path, value, fromAbove) { notifyPath: function (path, value, fromAbove) {
var info = {};
this._get(path, this, info);
this._notifyPath(info.path, value, fromAbove);
},
_notifyPath: function (path, value, fromAbove) {
var old = this._propertySetter(path, value); var old = this._propertySetter(path, value);
if (old !== value && (old === old || value === value)) { if (old !== value && (old === old || value === value)) {
this._pathEffector(path, value); this._pathEffector(path, value);
if (!fromAbove) { if (!fromAbove) {
this._notifyPath(path, value); this._notifyPathUp(path, value);
} }
return true; return true;
} }
...@@ -1855,52 +2068,78 @@ var last = parts[parts.length - 1]; ...@@ -1855,52 +2068,78 @@ var last = parts[parts.length - 1];
if (parts.length > 1) { if (parts.length > 1) {
for (var i = 0; i < parts.length - 1; i++) { for (var i = 0; i < parts.length - 1; i++) {
var part = parts[i]; var part = parts[i];
if (array && part[0] == '#') {
prop = Polymer.Collection.get(array).getItem(part);
} else {
prop = prop[part]; prop = prop[part];
if (array && parseInt(part) == part) { if (array && parseInt(part, 10) == part) {
parts[i] = Polymer.Collection.get(array).getKey(prop); parts[i] = Polymer.Collection.get(array).getKey(prop);
} }
}
if (!prop) { if (!prop) {
return; return;
} }
array = Array.isArray(prop) ? prop : null; array = Array.isArray(prop) ? prop : null;
} }
if (array && parseInt(last) == last) { if (array) {
var coll = Polymer.Collection.get(array); var coll = Polymer.Collection.get(array);
if (last[0] == '#') {
var key = last;
var old = coll.getItem(key);
last = array.indexOf(old);
coll.setItem(key, value);
} else if (parseInt(last, 10) == last) {
var old = prop[last]; var old = prop[last];
var key = coll.getKey(old); var key = coll.getKey(old);
parts[i] = key; parts[i] = key;
coll.setItem(key, value); coll.setItem(key, value);
} }
}
prop[last] = value; prop[last] = value;
if (!root) { if (!root) {
this.notifyPath(parts.join('.'), value); this._notifyPath(parts.join('.'), value);
} }
} else { } else {
prop[path] = value; prop[path] = value;
} }
}, },
get: function (path, root) { get: function (path, root) {
return this._get(path, root);
},
_get: function (path, root, info) {
var prop = root || this; var prop = root || this;
var parts = this._getPathParts(path); var parts = this._getPathParts(path);
var last = parts.pop(); var array;
while (parts.length) { for (var i = 0; i < parts.length; i++) {
prop = prop[parts.shift()];
if (!prop) { if (!prop) {
return; return;
} }
var part = parts[i];
if (array && part[0] == '#') {
prop = Polymer.Collection.get(array).getItem(part);
} else {
prop = prop[part];
if (info && array && parseInt(part, 10) == part) {
parts[i] = Polymer.Collection.get(array).getKey(prop);
}
}
array = Array.isArray(prop) ? prop : null;
} }
return prop[last]; if (info) {
info.path = parts.join('.');
}
return prop;
}, },
_pathEffector: function (path, value) { _pathEffector: function (path, value) {
var model = this._modelForPath(path); var model = this._modelForPath(path);
var fx$ = this._propertyEffects[model]; var fx$ = this._propertyEffects && this._propertyEffects[model];
if (fx$) { if (fx$) {
fx$.forEach(function (fx) { for (var i = 0, fx; i < fx$.length && (fx = fx$[i]); i++) {
var fxFn = this['_' + fx.kind + 'PathEffect']; var fxFn = fx.pathFn;
if (fxFn) { if (fxFn) {
fxFn.call(this, path, value, fx.effect); fxFn.call(this, path, value, fx.effect);
} }
}, this); }
} }
if (this._boundPaths) { if (this._boundPaths) {
this._notifyBoundPaths(path, value); this._notifyBoundPaths(path, value);
...@@ -1911,9 +2150,9 @@ if (effect.value === path || effect.value.indexOf(path + '.') === 0) { ...@@ -1911,9 +2150,9 @@ if (effect.value === path || effect.value.indexOf(path + '.') === 0) {
Polymer.Bind._annotationEffect.call(this, path, value, effect); Polymer.Bind._annotationEffect.call(this, path, value, effect);
} else if (path.indexOf(effect.value + '.') === 0 && !effect.negate) { } else if (path.indexOf(effect.value + '.') === 0 && !effect.negate) {
var node = this._nodes[effect.index]; var node = this._nodes[effect.index];
if (node && node.notifyPath) { if (node && node._notifyPath) {
var p = this._fixPath(effect.name, effect.value, path); var p = this._fixPath(effect.name, effect.value, path);
node.notifyPath(p, value, true); node._notifyPath(p, value, true);
} }
} }
}, },
...@@ -1953,70 +2192,88 @@ _notifyBoundPaths: function (path, value) { ...@@ -1953,70 +2192,88 @@ _notifyBoundPaths: function (path, value) {
for (var a in this._boundPaths) { for (var a in this._boundPaths) {
var b = this._boundPaths[a]; var b = this._boundPaths[a];
if (path.indexOf(a + '.') == 0) { if (path.indexOf(a + '.') == 0) {
this.notifyPath(this._fixPath(b, a, path), value); this._notifyPath(this._fixPath(b, a, path), value);
} else if (path.indexOf(b + '.') == 0) { } else if (path.indexOf(b + '.') == 0) {
this.notifyPath(this._fixPath(a, b, path), value); this._notifyPath(this._fixPath(a, b, path), value);
} }
} }
}, },
_fixPath: function (property, root, path) { _fixPath: function (property, root, path) {
return property + path.slice(root.length); return property + path.slice(root.length);
}, },
_notifyPath: function (path, value) { _notifyPathUp: function (path, value) {
var rootName = this._modelForPath(path); var rootName = this._modelForPath(path);
var dashCaseName = Polymer.CaseMap.camelToDashCase(rootName); var dashCaseName = Polymer.CaseMap.camelToDashCase(rootName);
var eventName = dashCaseName + this._EVENT_CHANGED; var eventName = dashCaseName + this._EVENT_CHANGED;
this.fire(eventName, { this.fire(eventName, {
path: path, path: path,
value: value value: value
}, { bubbles: false }); }, {
bubbles: false,
_useCache: true
});
}, },
_modelForPath: function (path) { _modelForPath: function (path) {
var dot = path.indexOf('.'); var dot = path.indexOf('.');
return dot < 0 ? path : path.slice(0, dot); return dot < 0 ? path : path.slice(0, dot);
}, },
_EVENT_CHANGED: '-changed', _EVENT_CHANGED: '-changed',
_notifySplice: function (array, path, index, added, removed) { notifySplices: function (path, splices) {
var splices = [{ var info = {};
index: index, var array = this._get(path, this, info);
addedCount: added, this._notifySplices(array, info.path, splices);
removed: removed, },
object: array, _notifySplices: function (array, path, splices) {
type: 'splice'
}];
var change = { var change = {
keySplices: Polymer.Collection.applySplices(array, splices), keySplices: Polymer.Collection.applySplices(array, splices),
indexSplices: splices indexSplices: splices
}; };
this.set(path + '.splices', change); if (!array.hasOwnProperty('splices')) {
if (added != removed.length) { Object.defineProperty(array, 'splices', {
this.notifyPath(path + '.length', array.length); configurable: true,
writable: true
});
} }
array.splices = change;
this._notifyPath(path + '.splices', change);
this._notifyPath(path + '.length', array.length);
change.keySplices = null; change.keySplices = null;
change.indexSplices = null; change.indexSplices = null;
}, },
_notifySplice: function (array, path, index, added, removed) {
this._notifySplices(array, path, [{
index: index,
addedCount: added,
removed: removed,
object: array,
type: 'splice'
}]);
},
push: function (path) { push: function (path) {
var array = this.get(path); var info = {};
var array = this._get(path, this, info);
var args = Array.prototype.slice.call(arguments, 1); var args = Array.prototype.slice.call(arguments, 1);
var len = array.length; var len = array.length;
var ret = array.push.apply(array, args); var ret = array.push.apply(array, args);
if (args.length) { if (args.length) {
this._notifySplice(array, path, len, args.length, []); this._notifySplice(array, info.path, len, args.length, []);
} }
return ret; return ret;
}, },
pop: function (path) { pop: function (path) {
var array = this.get(path); var info = {};
var array = this._get(path, this, info);
var hadLength = Boolean(array.length); var hadLength = Boolean(array.length);
var args = Array.prototype.slice.call(arguments, 1); var args = Array.prototype.slice.call(arguments, 1);
var ret = array.pop.apply(array, args); var ret = array.pop.apply(array, args);
if (hadLength) { if (hadLength) {
this._notifySplice(array, path, array.length, 0, [ret]); this._notifySplice(array, info.path, array.length, 0, [ret]);
} }
return ret; return ret;
}, },
splice: function (path, start, deleteCount) { splice: function (path, start, deleteCount) {
var array = this.get(path); var info = {};
var array = this._get(path, this, info);
if (start < 0) { if (start < 0) {
start = array.length - Math.floor(-start); start = array.length - Math.floor(-start);
} else { } else {
...@@ -2029,28 +2286,51 @@ var args = Array.prototype.slice.call(arguments, 1); ...@@ -2029,28 +2286,51 @@ var args = Array.prototype.slice.call(arguments, 1);
var ret = array.splice.apply(array, args); var ret = array.splice.apply(array, args);
var addedCount = Math.max(args.length - 2, 0); var addedCount = Math.max(args.length - 2, 0);
if (addedCount || ret.length) { if (addedCount || ret.length) {
this._notifySplice(array, path, start, addedCount, ret); this._notifySplice(array, info.path, start, addedCount, ret);
} }
return ret; return ret;
}, },
shift: function (path) { shift: function (path) {
var array = this.get(path); var info = {};
var array = this._get(path, this, info);
var hadLength = Boolean(array.length); var hadLength = Boolean(array.length);
var args = Array.prototype.slice.call(arguments, 1); var args = Array.prototype.slice.call(arguments, 1);
var ret = array.shift.apply(array, args); var ret = array.shift.apply(array, args);
if (hadLength) { if (hadLength) {
this._notifySplice(array, path, 0, 0, [ret]); this._notifySplice(array, info.path, 0, 0, [ret]);
} }
return ret; return ret;
}, },
unshift: function (path) { unshift: function (path) {
var array = this.get(path); var info = {};
var array = this._get(path, this, info);
var args = Array.prototype.slice.call(arguments, 1); var args = Array.prototype.slice.call(arguments, 1);
var ret = array.unshift.apply(array, args); var ret = array.unshift.apply(array, args);
if (args.length) { if (args.length) {
this._notifySplice(array, path, 0, args.length, []); this._notifySplice(array, info.path, 0, args.length, []);
} }
return ret; return ret;
},
prepareModelNotifyPath: function (model) {
this.mixin(model, {
fire: Polymer.Base.fire,
_getEvent: Polymer.Base._getEvent,
__eventCache: Polymer.Base.__eventCache,
notifyPath: Polymer.Base.notifyPath,
_get: Polymer.Base._get,
_EVENT_CHANGED: Polymer.Base._EVENT_CHANGED,
_notifyPath: Polymer.Base._notifyPath,
_notifyPathUp: Polymer.Base._notifyPathUp,
_pathEffector: Polymer.Base._pathEffector,
_annotationPathEffect: Polymer.Base._annotationPathEffect,
_complexObserverPathEffect: Polymer.Base._complexObserverPathEffect,
_annotatedComputationPathEffect: Polymer.Base._annotatedComputationPathEffect,
_computePathEffect: Polymer.Base._computePathEffect,
_modelForPath: Polymer.Base._modelForPath,
_pathMatchesEffect: Polymer.Base._pathMatchesEffect,
_notifyBoundPaths: Polymer.Base._notifyBoundPaths,
_getPathParts: Polymer.Base._getPathParts
});
} }
}); });
}()); }());
...@@ -2109,6 +2389,8 @@ node.parsedCssText = node.cssText = t.trim(); ...@@ -2109,6 +2389,8 @@ node.parsedCssText = node.cssText = t.trim();
if (node.parent) { if (node.parent) {
var ss = node.previous ? node.previous.end : node.parent.start; var ss = node.previous ? node.previous.end : node.parent.start;
t = text.substring(ss, node.start - 1); t = text.substring(ss, node.start - 1);
t = this._expandUnicodeEscapes(t);
t = t.replace(this._rx.multipleSpaces, ' ');
t = t.substring(t.lastIndexOf(';') + 1); t = t.substring(t.lastIndexOf(';') + 1);
var s = node.parsedSelector = node.selector = t.trim(); var s = node.parsedSelector = node.selector = t.trim();
node.atRule = s.indexOf(this.AT_START) === 0; node.atRule = s.indexOf(this.AT_START) === 0;
...@@ -2134,6 +2416,15 @@ this._parseCss(r, text); ...@@ -2134,6 +2416,15 @@ this._parseCss(r, text);
} }
return node; return node;
}, },
_expandUnicodeEscapes: function (s) {
return s.replace(/\\([0-9a-f]{1,6})\s/gi, function () {
var code = arguments[1], repeat = 6 - code.length;
while (repeat--) {
code = '0' + code;
}
return '\\' + code;
});
},
stringify: function (node, preserveProperties, text) { stringify: function (node, preserveProperties, text) {
text = text || ''; text = text || '';
var cssText = ''; var cssText = '';
...@@ -2163,7 +2454,7 @@ text += this.CLOSE_BRACE + '\n\n'; ...@@ -2163,7 +2454,7 @@ text += this.CLOSE_BRACE + '\n\n';
return text; return text;
}, },
_hasMixinRules: function (rules) { _hasMixinRules: function (rules) {
return rules[0].selector.indexOf(this.VAR_START) >= 0; return rules[0].selector.indexOf(this.VAR_START) === 0;
}, },
removeCustomProps: function (cssText) { removeCustomProps: function (cssText) {
cssText = this.removeCustomPropAssignment(cssText); cssText = this.removeCustomPropAssignment(cssText);
...@@ -2187,10 +2478,11 @@ _rx: { ...@@ -2187,10 +2478,11 @@ _rx: {
comments: /\/\*[^*]*\*+([^\/*][^*]*\*+)*\//gim, comments: /\/\*[^*]*\*+([^\/*][^*]*\*+)*\//gim,
port: /@import[^;]*;/gim, port: /@import[^;]*;/gim,
customProp: /(?:^|[\s;])--[^;{]*?:[^{};]*?(?:[;\n]|$)/gim, customProp: /(?:^|[\s;])--[^;{]*?:[^{};]*?(?:[;\n]|$)/gim,
mixinProp: /(?:^|[\s;])--[^;{]*?:[^{;]*?{[^}]*?}(?:[;\n]|$)?/gim, mixinProp: /(?:^|[\s;])?--[^;{]*?:[^{;]*?{[^}]*?}(?:[;\n]|$)?/gim,
mixinApply: /@apply[\s]*\([^)]*?\)[\s]*(?:[;\n]|$)?/gim, mixinApply: /@apply[\s]*\([^)]*?\)[\s]*(?:[;\n]|$)?/gim,
varApply: /[^;:]*?:[^;]*var[^;]*(?:[;\n]|$)?/gim, varApply: /[^;:]*?:[^;]*?var\([^;]*\)(?:[;\n]|$)?/gim,
keyframesRule: /^@[^\s]*keyframes/ keyframesRule: /^@[^\s]*keyframes/,
multipleSpaces: /\s+/g
}, },
VAR_START: '--', VAR_START: '--',
MEDIA_START: '@media', MEDIA_START: '@media',
...@@ -2270,21 +2562,21 @@ return cssText; ...@@ -2270,21 +2562,21 @@ return cssText;
cssFromModule: function (moduleId, warnIfNotFound) { cssFromModule: function (moduleId, warnIfNotFound) {
var m = Polymer.DomModule.import(moduleId); var m = Polymer.DomModule.import(moduleId);
if (m && !m._cssText) { if (m && !m._cssText) {
m._cssText = this._cssFromElement(m); m._cssText = this.cssFromElement(m);
} }
if (!m && warnIfNotFound) { if (!m && warnIfNotFound) {
console.warn('Could not find style data in module named', moduleId); console.warn('Could not find style data in module named', moduleId);
} }
return m && m._cssText || ''; return m && m._cssText || '';
}, },
_cssFromElement: function (element) { cssFromElement: function (element) {
var cssText = ''; var cssText = '';
var content = element.content || element; var content = element.content || element;
var e$ = Array.prototype.slice.call(content.querySelectorAll(this.MODULE_STYLES_SELECTOR)); var e$ = Polymer.DomApi.arrayCopy(content.querySelectorAll(this.MODULE_STYLES_SELECTOR));
for (var i = 0, e; i < e$.length; i++) { for (var i = 0, e; i < e$.length; i++) {
e = e$[i]; e = e$[i];
if (e.localName === 'template') { if (e.localName === 'template') {
cssText += this._cssFromElement(e); cssText += this.cssFromElement(e);
} else { } else {
if (e.localName === 'style') { if (e.localName === 'style') {
var include = e.getAttribute(this.INCLUDE_ATTR); var include = e.getAttribute(this.INCLUDE_ATTR);
...@@ -2533,7 +2825,7 @@ _extendRule: function (target, source) { ...@@ -2533,7 +2825,7 @@ _extendRule: function (target, source) {
if (target.parent !== source.parent) { if (target.parent !== source.parent) {
this._cloneAndAddRuleToParent(source, target.parent); this._cloneAndAddRuleToParent(source, target.parent);
} }
target.extends = target.extends || (target.extends = []); target.extends = target.extends || [];
target.extends.push(source); target.extends.push(source);
source.selector = source.selector.replace(this.rx.STRIP, ''); source.selector = source.selector.replace(this.rx.STRIP, '');
source.selector = (source.selector && source.selector + ',\n') + target.selector; source.selector = (source.selector && source.selector + ',\n') + target.selector;
...@@ -2574,14 +2866,18 @@ _prepStyles: function () { ...@@ -2574,14 +2866,18 @@ _prepStyles: function () {
if (this._encapsulateStyle === undefined) { if (this._encapsulateStyle === undefined) {
this._encapsulateStyle = !nativeShadow && Boolean(this._template); this._encapsulateStyle = !nativeShadow && Boolean(this._template);
} }
if (this._template) {
this._styles = this._collectStyles(); this._styles = this._collectStyles();
var cssText = styleTransformer.elementStyles(this); var cssText = styleTransformer.elementStyles(this);
if (cssText && this._template) { if (cssText) {
var style = styleUtil.applyCss(cssText, this.is, nativeShadow ? this._template.content : null); var style = styleUtil.applyCss(cssText, this.is, nativeShadow ? this._template.content : null);
if (!nativeShadow) { if (!nativeShadow) {
this._scopeStyle = style; this._scopeStyle = style;
} }
} }
} else {
this._styles = [];
}
}, },
_collectStyles: function () { _collectStyles: function () {
var styles = []; var styles = [];
...@@ -2592,6 +2888,10 @@ cssText += styleUtil.cssFromModule(m); ...@@ -2592,6 +2888,10 @@ cssText += styleUtil.cssFromModule(m);
} }
} }
cssText += styleUtil.cssFromModule(this.is); cssText += styleUtil.cssFromModule(this.is);
var p = this._template && this._template.parentNode;
if (this._template && (!p || p.id.toLowerCase() !== this.is)) {
cssText += styleUtil.cssFromElement(this._template);
}
if (cssText) { if (cssText) {
var style = document.createElement('style'); var style = document.createElement('style');
style.textContent = cssText; style.textContent = cssText;
...@@ -2625,21 +2925,21 @@ var scopify = function (node) { ...@@ -2625,21 +2925,21 @@ var scopify = function (node) {
if (node.nodeType === Node.ELEMENT_NODE) { if (node.nodeType === Node.ELEMENT_NODE) {
node.className = self._scopeElementClass(node, node.className); node.className = self._scopeElementClass(node, node.className);
var n$ = node.querySelectorAll('*'); var n$ = node.querySelectorAll('*');
Array.prototype.forEach.call(n$, function (n) { for (var i = 0, n; i < n$.length && (n = n$[i]); i++) {
n.className = self._scopeElementClass(n, n.className); n.className = self._scopeElementClass(n, n.className);
}); }
} }
}; };
scopify(container); scopify(container);
if (shouldObserve) { if (shouldObserve) {
var mo = new MutationObserver(function (mxns) { var mo = new MutationObserver(function (mxns) {
mxns.forEach(function (m) { for (var i = 0, m; i < mxns.length && (m = mxns[i]); i++) {
if (m.addedNodes) { if (m.addedNodes) {
for (var i = 0; i < m.addedNodes.length; i++) { for (var j = 0; j < m.addedNodes.length; j++) {
scopify(m.addedNodes[i]); scopify(m.addedNodes[j]);
}
} }
} }
});
}); });
mo.observe(container, { mo.observe(container, {
childList: true, childList: true,
...@@ -2764,7 +3064,9 @@ p = pp.join(':'); ...@@ -2764,7 +3064,9 @@ p = pp.join(':');
parts[i] = p && p.lastIndexOf(';') === p.length - 1 ? p.slice(0, -1) : p || ''; parts[i] = p && p.lastIndexOf(';') === p.length - 1 ? p.slice(0, -1) : p || '';
} }
} }
return parts.join(';'); return parts.filter(function (v) {
return v;
}).join(';');
}, },
applyProperties: function (rule, props) { applyProperties: function (rule, props) {
var output = ''; var output = '';
...@@ -2890,7 +3192,7 @@ props[i] = v; ...@@ -2890,7 +3192,7 @@ props[i] = v;
} }
}, },
rx: { rx: {
VAR_ASSIGN: /(?:^|[;\n]\s*)(--[\w-]*?):\s*(?:([^;{]*)|{([^}]*)})(?:(?=[;\n])|$)/gi, VAR_ASSIGN: /(?:^|[;\s{]\s*)(--[\w-]*?)\s*:\s*(?:([^;{]*)|{([^}]*)})(?:(?=[;\s}])|$)/gi,
MIXIN_MATCH: /(?:^|\W+)@apply[\s]*\(([^)]*)\)/i, MIXIN_MATCH: /(?:^|\W+)@apply[\s]*\(([^)]*)\)/i,
VAR_MATCH: /(^|\W+)var\([\s]*([^,)]*)[\s]*,?[\s]*((?:[^,)]*)|(?:[^;]*\([^;)]*\)))[\s]*?\)/gi, VAR_MATCH: /(^|\W+)var\([\s]*([^,)]*)[\s]*,?[\s]*((?:[^,)]*)|(?:[^;]*\([^;)]*\)))[\s]*?\)/gi,
VAR_CAPTURE: /\([\s]*(--[^,\s)]*)(?:,[\s]*(--[^,\s)]*))?(?:\)|,)/gi, VAR_CAPTURE: /\([\s]*(--[^,\s)]*)(?:,[\s]*(--[^,\s)]*))?(?:\)|,)/gi,
...@@ -3009,9 +3311,12 @@ var styleDefaults = Polymer.StyleDefaults; ...@@ -3009,9 +3311,12 @@ var styleDefaults = Polymer.StyleDefaults;
var nativeShadow = Polymer.Settings.useNativeShadow; var nativeShadow = Polymer.Settings.useNativeShadow;
Polymer.Base._addFeature({ Polymer.Base._addFeature({
_prepStyleProperties: function () { _prepStyleProperties: function () {
this._ownStylePropertyNames = this._styles ? propertyUtils.decorateStyles(this._styles) : []; this._ownStylePropertyNames = this._styles ? propertyUtils.decorateStyles(this._styles) : null;
},
customStyle: null,
getComputedStyleValue: function (property) {
return this._styleProperties && this._styleProperties[property] || getComputedStyle(this).getPropertyValue(property);
}, },
customStyle: {},
_setupStyleProperties: function () { _setupStyleProperties: function () {
this.customStyle = {}; this.customStyle = {};
}, },
...@@ -3108,7 +3413,7 @@ if (host) { ...@@ -3108,7 +3413,7 @@ if (host) {
value = host._scopeElementClass(node, value); value = host._scopeElementClass(node, value);
} }
} }
node = Polymer.dom(node); node = this.shadyRoot && this.shadyRoot._hasDistributed ? Polymer.dom(node) : node;
serializeValueToAttribute.call(this, value, attribute, node); serializeValueToAttribute.call(this, value, attribute, node);
}, },
_scopeElementClass: function (element, selector) { _scopeElementClass: function (element, selector) {
...@@ -3157,7 +3462,6 @@ var XSCOPE_NAME = propertyUtils.XSCOPE_NAME; ...@@ -3157,7 +3462,6 @@ var XSCOPE_NAME = propertyUtils.XSCOPE_NAME;
Polymer.Base._addFeature({ Polymer.Base._addFeature({
_registerFeatures: function () { _registerFeatures: function () {
this._prepIs(); this._prepIs();
this._prepAttributes();
this._prepConstructor(); this._prepConstructor();
this._prepTemplate(); this._prepTemplate();
this._prepStyles(); this._prepStyles();
...@@ -3165,6 +3469,7 @@ this._prepStyleProperties(); ...@@ -3165,6 +3469,7 @@ this._prepStyleProperties();
this._prepAnnotations(); this._prepAnnotations();
this._prepEffects(); this._prepEffects();
this._prepBehaviors(); this._prepBehaviors();
this._prepPropertyInfo();
this._prepBindings(); this._prepBindings();
this._prepShady(); this._prepShady();
}, },
...@@ -3174,23 +3479,28 @@ this._addComplexObserverEffects(b.observers); ...@@ -3174,23 +3479,28 @@ this._addComplexObserverEffects(b.observers);
this._addHostAttributes(b.hostAttributes); this._addHostAttributes(b.hostAttributes);
}, },
_initFeatures: function () { _initFeatures: function () {
this._poolContent();
this._setupConfigure(); this._setupConfigure();
this._setupStyleProperties(); this._setupStyleProperties();
this._pushHost(); this._setupDebouncers();
this._registerHost();
if (this._template) {
this._poolContent();
this._beginHosting();
this._stampTemplate(); this._stampTemplate();
this._popHost(); this._endHosting();
this._marshalAnnotationReferences(); this._marshalAnnotationReferences();
this._setupDebouncers(); }
this._marshalInstanceEffects(); this._marshalInstanceEffects();
this._marshalHostAttributes();
this._marshalBehaviors(); this._marshalBehaviors();
this._marshalHostAttributes();
this._marshalAttributes(); this._marshalAttributes();
this._tryReady(); this._tryReady();
}, },
_marshalBehavior: function (b) { _marshalBehavior: function (b) {
if (b.listeners) {
this._listenListeners(b.listeners); this._listenListeners(b.listeners);
} }
}
}); });
(function () { (function () {
var nativeShadow = Polymer.Settings.useNativeShadow; var nativeShadow = Polymer.Settings.useNativeShadow;
...@@ -3202,6 +3512,7 @@ var styleTransformer = Polymer.StyleTransformer; ...@@ -3202,6 +3512,7 @@ var styleTransformer = Polymer.StyleTransformer;
Polymer({ Polymer({
is: 'custom-style', is: 'custom-style',
extends: 'style', extends: 'style',
_template: null,
properties: { include: String }, properties: { include: String },
ready: function () { ready: function () {
this._tryApply(); this._tryApply();
...@@ -3218,10 +3529,11 @@ styleDefaults.addStyle(e); ...@@ -3218,10 +3529,11 @@ styleDefaults.addStyle(e);
if (e.textContent || this.include) { if (e.textContent || this.include) {
this._apply(); this._apply();
} else { } else {
var self = this;
var observer = new MutationObserver(function () { var observer = new MutationObserver(function () {
observer.disconnect(); observer.disconnect();
this._apply(); self._apply();
}.bind(this)); });
observer.observe(e, { childList: true }); observer.observe(e, { childList: true });
} }
} }
...@@ -3258,6 +3570,7 @@ properties: { __hideTemplateChildren__: { observer: '_showHideChildren' } }, ...@@ -3258,6 +3570,7 @@ properties: { __hideTemplateChildren__: { observer: '_showHideChildren' } },
_instanceProps: Polymer.nob, _instanceProps: Polymer.nob,
_parentPropPrefix: '_parent_', _parentPropPrefix: '_parent_',
templatize: function (template) { templatize: function (template) {
this._templatized = template;
if (!template._content) { if (!template._content) {
template._content = template.content; template._content = template.content;
} }
...@@ -3268,12 +3581,13 @@ return; ...@@ -3268,12 +3581,13 @@ return;
} }
var archetype = Object.create(Polymer.Base); var archetype = Object.create(Polymer.Base);
this._customPrepAnnotations(archetype, template); this._customPrepAnnotations(archetype, template);
this._prepParentProperties(archetype, template);
archetype._prepEffects(); archetype._prepEffects();
this._customPrepEffects(archetype); this._customPrepEffects(archetype);
archetype._prepBehaviors(); archetype._prepBehaviors();
archetype._prepPropertyInfo();
archetype._prepBindings(); archetype._prepBindings();
this._prepParentProperties(archetype, template); archetype._notifyPathUp = this._notifyPathUpImpl;
archetype._notifyPath = this._notifyPathImpl;
archetype._scopeElementClass = this._scopeElementClassImpl; archetype._scopeElementClass = this._scopeElementClassImpl;
archetype.listen = this._listenImpl; archetype.listen = this._listenImpl;
archetype._showHideChildren = this._showHideChildrenImpl; archetype._showHideChildren = this._showHideChildrenImpl;
...@@ -3334,7 +3648,9 @@ var c = template._content; ...@@ -3334,7 +3648,9 @@ var c = template._content;
if (!c._notes) { if (!c._notes) {
var rootDataHost = archetype._rootDataHost; var rootDataHost = archetype._rootDataHost;
if (rootDataHost) { if (rootDataHost) {
Polymer.Annotations.prepElement = rootDataHost._prepElement.bind(rootDataHost); Polymer.Annotations.prepElement = function () {
rootDataHost._prepElement();
};
} }
c._notes = Polymer.Annotations.parseAnnotations(template); c._notes = Polymer.Annotations.parseAnnotations(template);
Polymer.Annotations.prepElement = null; Polymer.Annotations.prepElement = null;
...@@ -3355,24 +3671,36 @@ delete parentProps[prop]; ...@@ -3355,24 +3671,36 @@ delete parentProps[prop];
proto = archetype._parentPropProto = Object.create(null); proto = archetype._parentPropProto = Object.create(null);
if (template != this) { if (template != this) {
Polymer.Bind.prepareModel(proto); Polymer.Bind.prepareModel(proto);
Polymer.Base.prepareModelNotifyPath(proto);
} }
for (prop in parentProps) { for (prop in parentProps) {
var parentProp = this._parentPropPrefix + prop; var parentProp = this._parentPropPrefix + prop;
var effects = [ var effects = [
{ {
kind: 'function', kind: 'function',
effect: this._createForwardPropEffector(prop) effect: this._createForwardPropEffector(prop),
fn: Polymer.Bind._functionEffect
}, },
{ kind: 'notify' } {
kind: 'notify',
fn: Polymer.Bind._notifyEffect,
effect: { event: Polymer.CaseMap.camelToDashCase(parentProp) + '-changed' }
}
]; ];
Polymer.Bind._createAccessors(proto, parentProp, effects); Polymer.Bind._createAccessors(proto, parentProp, effects);
} }
} }
var self = this;
if (template != this) { if (template != this) {
Polymer.Bind.prepareInstance(template); Polymer.Bind.prepareInstance(template);
template._forwardParentProp = this._forwardParentProp.bind(this); template._forwardParentProp = function (source, value) {
self._forwardParentProp(source, value);
};
} }
this._extendTemplate(template, proto); this._extendTemplate(template, proto);
template._pathEffector = function (path, value, fromAbove) {
return self._pathEffectorImpl(path, value, fromAbove);
};
} }
}, },
_createForwardPropEffector: function (prop) { _createForwardPropEffector: function (prop) {
...@@ -3383,7 +3711,7 @@ this._forwardParentProp(prop, value); ...@@ -3383,7 +3711,7 @@ this._forwardParentProp(prop, value);
_createHostPropEffector: function (prop) { _createHostPropEffector: function (prop) {
var prefix = this._parentPropPrefix; var prefix = this._parentPropPrefix;
return function (source, value) { return function (source, value) {
this.dataHost[prefix + prop] = value; this.dataHost._templatized[prefix + prop] = value;
}; };
}, },
_createInstancePropEffector: function (prop) { _createInstancePropEffector: function (prop) {
...@@ -3394,14 +3722,15 @@ this.dataHost._forwardInstanceProp(this, prop, value); ...@@ -3394,14 +3722,15 @@ this.dataHost._forwardInstanceProp(this, prop, value);
}; };
}, },
_extendTemplate: function (template, proto) { _extendTemplate: function (template, proto) {
Object.getOwnPropertyNames(proto).forEach(function (n) { var n$ = Object.getOwnPropertyNames(proto);
for (var i = 0, n; i < n$.length && (n = n$[i]); i++) {
var val = template[n]; var val = template[n];
var pd = Object.getOwnPropertyDescriptor(proto, n); var pd = Object.getOwnPropertyDescriptor(proto, n);
Object.defineProperty(template, n, pd); Object.defineProperty(template, n, pd);
if (val !== undefined) { if (val !== undefined) {
template._propertySetter(n, val); template._propertySetter(n, val);
} }
}); }
}, },
_showHideChildren: function (hidden) { _showHideChildren: function (hidden) {
}, },
...@@ -3409,31 +3738,36 @@ _forwardInstancePath: function (inst, path, value) { ...@@ -3409,31 +3738,36 @@ _forwardInstancePath: function (inst, path, value) {
}, },
_forwardInstanceProp: function (inst, prop, value) { _forwardInstanceProp: function (inst, prop, value) {
}, },
_notifyPathImpl: function (path, value) { _notifyPathUpImpl: function (path, value) {
var dataHost = this.dataHost; var dataHost = this.dataHost;
var dot = path.indexOf('.'); var dot = path.indexOf('.');
var root = dot < 0 ? path : path.slice(0, dot); var root = dot < 0 ? path : path.slice(0, dot);
dataHost._forwardInstancePath.call(dataHost, this, path, value); dataHost._forwardInstancePath.call(dataHost, this, path, value);
if (root in dataHost._parentProps) { if (root in dataHost._parentProps) {
dataHost.notifyPath(dataHost._parentPropPrefix + path, value); dataHost._templatized.notifyPath(dataHost._parentPropPrefix + path, value);
} }
}, },
_pathEffector: function (path, value, fromAbove) { _pathEffectorImpl: function (path, value, fromAbove) {
if (this._forwardParentPath) { if (this._forwardParentPath) {
if (path.indexOf(this._parentPropPrefix) === 0) { if (path.indexOf(this._parentPropPrefix) === 0) {
this._forwardParentPath(path.substring(8), value); var subPath = path.substring(this._parentPropPrefix.length);
var model = this._modelForPath(subPath);
if (model in this._parentProps) {
this._forwardParentPath(subPath, value);
}
} }
} }
Polymer.Base._pathEffector.apply(this, arguments); Polymer.Base._pathEffector.call(this._templatized, path, value, fromAbove);
}, },
_constructorImpl: function (model, host) { _constructorImpl: function (model, host) {
this._rootDataHost = host._getRootDataHost(); this._rootDataHost = host._getRootDataHost();
this._setupConfigure(model); this._setupConfigure(model);
this._pushHost(host); this._registerHost(host);
this._beginHosting();
this.root = this.instanceTemplate(this._template); this.root = this.instanceTemplate(this._template);
this.root.__noContent = !this._notes._hasContent; this.root.__noContent = !this._notes._hasContent;
this.root.__styleScoped = true; this.root.__styleScoped = true;
this._popHost(); this._endHosting();
this._marshalAnnotatedNodes(); this._marshalAnnotatedNodes();
this._marshalInstanceEffects(); this._marshalInstanceEffects();
this._marshalAnnotatedListeners(); this._marshalAnnotatedListeners();
...@@ -3467,8 +3801,9 @@ return host._scopeElementClass(node, value); ...@@ -3467,8 +3801,9 @@ return host._scopeElementClass(node, value);
stamp: function (model) { stamp: function (model) {
model = model || {}; model = model || {};
if (this._parentProps) { if (this._parentProps) {
var templatized = this._templatized;
for (var prop in this._parentProps) { for (var prop in this._parentProps) {
model[prop] = this[this._parentPropPrefix + prop]; model[prop] = templatized[this._parentPropPrefix + prop];
} }
} }
return new this.ctor(model, this); return new this.ctor(model, this);
...@@ -3491,6 +3826,7 @@ el = el.parentNode; ...@@ -3491,6 +3826,7 @@ el = el.parentNode;
Polymer({ Polymer({
is: 'dom-template', is: 'dom-template',
extends: 'template', extends: 'template',
_template: null,
behaviors: [Polymer.Templatizer], behaviors: [Polymer.Templatizer],
ready: function () { ready: function () {
this.templatize(this); this.templatize(this);
...@@ -3525,9 +3861,10 @@ this.omap.set(item, key); ...@@ -3525,9 +3861,10 @@ this.omap.set(item, key);
} else { } else {
this.pmap[item] = key; this.pmap[item] = key;
} }
return key; return '#' + key;
}, },
removeKey: function (key) { removeKey: function (key) {
key = this._parseKey(key);
this._removeFromMap(this.store[key]); this._removeFromMap(this.store[key]);
delete this.store[key]; delete this.store[key];
}, },
...@@ -3544,16 +3881,29 @@ this.removeKey(key); ...@@ -3544,16 +3881,29 @@ this.removeKey(key);
return key; return key;
}, },
getKey: function (item) { getKey: function (item) {
var key;
if (item && typeof item == 'object') { if (item && typeof item == 'object') {
return this.omap.get(item); key = this.omap.get(item);
} else { } else {
return this.pmap[item]; key = this.pmap[item];
}
if (key != undefined) {
return '#' + key;
} }
}, },
getKeys: function () { getKeys: function () {
return Object.keys(this.store); return Object.keys(this.store).map(function (key) {
return '#' + key;
});
},
_parseKey: function (key) {
if (key[0] == '#') {
return key.slice(1);
}
throw new Error('unexpected key ' + key);
}, },
setItem: function (key, item) { setItem: function (key, item) {
key = this._parseKey(key);
var old = this.store[key]; var old = this.store[key];
if (old) { if (old) {
this._removeFromMap(old); this._removeFromMap(old);
...@@ -3566,6 +3916,7 @@ this.pmap[item] = key; ...@@ -3566,6 +3916,7 @@ this.pmap[item] = key;
this.store[key] = item; this.store[key] = item;
}, },
getItem: function (key) { getItem: function (key) {
key = this._parseKey(key);
return this.store[key]; return this.store[key];
}, },
getItems: function () { getItems: function () {
...@@ -3576,21 +3927,21 @@ items.push(store[key]); ...@@ -3576,21 +3927,21 @@ items.push(store[key]);
return items; return items;
}, },
_applySplices: function (splices) { _applySplices: function (splices) {
var keyMap = {}, key, i; var keyMap = {}, key;
splices.forEach(function (s) { for (var i = 0, s; i < splices.length && (s = splices[i]); i++) {
s.addedKeys = []; s.addedKeys = [];
for (i = 0; i < s.removed.length; i++) { for (var j = 0; j < s.removed.length; j++) {
key = this.getKey(s.removed[i]); key = this.getKey(s.removed[j]);
keyMap[key] = keyMap[key] ? null : -1; keyMap[key] = keyMap[key] ? null : -1;
} }
for (i = 0; i < s.addedCount; i++) { for (var j = 0; j < s.addedCount; j++) {
var item = this.userArray[s.index + i]; var item = this.userArray[s.index + j];
key = this.getKey(item); key = this.getKey(item);
key = key === undefined ? this.add(item) : key; key = key === undefined ? this.add(item) : key;
keyMap[key] = keyMap[key] ? null : 1; keyMap[key] = keyMap[key] ? null : 1;
s.addedKeys.push(key); s.addedKeys.push(key);
} }
}, this); }
var removed = []; var removed = [];
var added = []; var added = [];
for (var key in keyMap) { for (var key in keyMap) {
...@@ -3618,6 +3969,7 @@ return coll ? coll._applySplices(splices) : null; ...@@ -3618,6 +3969,7 @@ return coll ? coll._applySplices(splices) : null;
Polymer({ Polymer({
is: 'dom-repeat', is: 'dom-repeat',
extends: 'template', extends: 'template',
_template: null,
properties: { properties: {
items: { type: Array }, items: { type: Array },
as: { as: {
...@@ -3640,22 +3992,37 @@ observe: { ...@@ -3640,22 +3992,37 @@ observe: {
type: String, type: String,
observer: '_observeChanged' observer: '_observeChanged'
}, },
delay: Number delay: Number,
initialCount: {
type: Number,
observer: '_initializeChunking'
},
targetFramerate: {
type: Number,
value: 20
},
_targetFrameTime: { computed: '_computeFrameTime(targetFramerate)' }
}, },
behaviors: [Polymer.Templatizer], behaviors: [Polymer.Templatizer],
observers: ['_itemsChanged(items.*)'], observers: ['_itemsChanged(items.*)'],
created: function () { created: function () {
this._instances = []; this._instances = [];
this._pool = [];
this._limit = Infinity;
var self = this;
this._boundRenderChunk = function () {
self._renderChunk();
};
}, },
detached: function () { detached: function () {
for (var i = 0; i < this._instances.length; i++) { for (var i = 0; i < this._instances.length; i++) {
this._detachRow(i); this._detachInstance(i);
} }
}, },
attached: function () { attached: function () {
var parentNode = Polymer.dom(this).parentNode; var parent = Polymer.dom(Polymer.dom(this).parentNode);
for (var i = 0; i < this._instances.length; i++) { for (var i = 0; i < this._instances.length; i++) {
Polymer.dom(parentNode).insertBefore(this._instances[i].root, this); this._attachInstance(i, parent);
} }
}, },
ready: function () { ready: function () {
...@@ -3666,9 +4033,8 @@ if (!this.ctor) { ...@@ -3666,9 +4033,8 @@ if (!this.ctor) {
this.templatize(this); this.templatize(this);
} }
}, },
_sortChanged: function () { _sortChanged: function (sort) {
var dataHost = this._getRootDataHost(); var dataHost = this._getRootDataHost();
var sort = this.sort;
this._sortFn = sort && (typeof sort == 'function' ? sort : function () { this._sortFn = sort && (typeof sort == 'function' ? sort : function () {
return dataHost[sort].apply(dataHost, arguments); return dataHost[sort].apply(dataHost, arguments);
}); });
...@@ -3677,9 +4043,8 @@ if (this.items) { ...@@ -3677,9 +4043,8 @@ if (this.items) {
this._debounceTemplate(this._render); this._debounceTemplate(this._render);
} }
}, },
_filterChanged: function () { _filterChanged: function (filter) {
var dataHost = this._getRootDataHost(); var dataHost = this._getRootDataHost();
var filter = this.filter;
this._filterFn = filter && (typeof filter == 'function' ? filter : function () { this._filterFn = filter && (typeof filter == 'function' ? filter : function () {
return dataHost[filter].apply(dataHost, arguments); return dataHost[filter].apply(dataHost, arguments);
}); });
...@@ -3688,6 +4053,32 @@ if (this.items) { ...@@ -3688,6 +4053,32 @@ if (this.items) {
this._debounceTemplate(this._render); this._debounceTemplate(this._render);
} }
}, },
_computeFrameTime: function (rate) {
return Math.ceil(1000 / rate);
},
_initializeChunking: function () {
if (this.initialCount) {
this._limit = this.initialCount;
this._chunkCount = this.initialCount;
this._lastChunkTime = performance.now();
}
},
_tryRenderChunk: function () {
if (this.items && this._limit < this.items.length) {
this.debounce('renderChunk', this._requestRenderChunk);
}
},
_requestRenderChunk: function () {
requestAnimationFrame(this._boundRenderChunk);
},
_renderChunk: function () {
var currChunkTime = performance.now();
var ratio = this._targetFrameTime / (currChunkTime - this._lastChunkTime);
this._chunkCount = Math.round(this._chunkCount * ratio) || 1;
this._limit += this._chunkCount;
this._lastChunkTime = currChunkTime;
this._debounceTemplate(this._render);
},
_observeChanged: function () { _observeChanged: function () {
this._observePaths = this.observe && this.observe.replace('.*', '.').split(' '); this._observePaths = this.observe && this.observe.replace('.*', '.').split(' ');
}, },
...@@ -3703,6 +4094,7 @@ this._error(this._logf('dom-repeat', 'expected array for `items`,' + ' found', t ...@@ -3703,6 +4094,7 @@ this._error(this._logf('dom-repeat', 'expected array for `items`,' + ' found', t
this._keySplices = []; this._keySplices = [];
this._indexSplices = []; this._indexSplices = [];
this._needFullRefresh = true; this._needFullRefresh = true;
this._initializeChunking();
this._debounceTemplate(this._render); this._debounceTemplate(this._render);
} else if (change.path == 'items.splices') { } else if (change.path == 'items.splices') {
this._keySplices = this._keySplices.concat(change.value.keySplices); this._keySplices = this._keySplices.concat(change.value.keySplices);
...@@ -3741,7 +4133,7 @@ var c = this.collection; ...@@ -3741,7 +4133,7 @@ var c = this.collection;
if (this._needFullRefresh) { if (this._needFullRefresh) {
this._applyFullRefresh(); this._applyFullRefresh();
this._needFullRefresh = false; this._needFullRefresh = false;
} else { } else if (this._keySplices.length) {
if (this._sortFn) { if (this._sortFn) {
this._applySplicesUserSort(this._keySplices); this._applySplicesUserSort(this._keySplices);
} else { } else {
...@@ -3751,16 +4143,26 @@ this._applyFullRefresh(); ...@@ -3751,16 +4143,26 @@ this._applyFullRefresh();
this._applySplicesArrayOrder(this._indexSplices); this._applySplicesArrayOrder(this._indexSplices);
} }
} }
} else {
} }
this._keySplices = []; this._keySplices = [];
this._indexSplices = []; this._indexSplices = [];
var keyToIdx = this._keyToInstIdx = {}; var keyToIdx = this._keyToInstIdx = {};
for (var i = 0; i < this._instances.length; i++) { for (var i = this._instances.length - 1; i >= 0; i--) {
var inst = this._instances[i]; var inst = this._instances[i];
if (inst.isPlaceholder && i < this._limit) {
inst = this._insertInstance(i, inst.__key__);
} else if (!inst.isPlaceholder && i >= this._limit) {
inst = this._downgradeInstance(i, inst.__key__);
}
keyToIdx[inst.__key__] = i; keyToIdx[inst.__key__] = i;
if (!inst.isPlaceholder) {
inst.__setProperty(this.indexAs, i, true); inst.__setProperty(this.indexAs, i, true);
} }
}
this._pool.length = 0;
this.fire('dom-change'); this.fire('dom-change');
this._tryRenderChunk();
}, },
_applyFullRefresh: function () { _applyFullRefresh: function () {
var c = this.collection; var c = this.collection;
...@@ -3776,33 +4178,34 @@ keys.push(c.getKey(items[i])); ...@@ -3776,33 +4178,34 @@ keys.push(c.getKey(items[i]));
} }
} }
} }
var self = this;
if (this._filterFn) { if (this._filterFn) {
keys = keys.filter(function (a) { keys = keys.filter(function (a) {
return this._filterFn(c.getItem(a)); return self._filterFn(c.getItem(a));
}, this); });
} }
if (this._sortFn) { if (this._sortFn) {
keys.sort(function (a, b) { keys.sort(function (a, b) {
return this._sortFn(c.getItem(a), c.getItem(b)); return self._sortFn(c.getItem(a), c.getItem(b));
}.bind(this)); });
} }
for (var i = 0; i < keys.length; i++) { for (var i = 0; i < keys.length; i++) {
var key = keys[i]; var key = keys[i];
var inst = this._instances[i]; var inst = this._instances[i];
if (inst) { if (inst) {
inst.__setProperty('__key__', key, true); inst.__key__ = key;
if (!inst.isPlaceholder && i < this._limit) {
inst.__setProperty(this.as, c.getItem(key), true); inst.__setProperty(this.as, c.getItem(key), true);
}
} else if (i < this._limit) {
this._insertInstance(i, key);
} else { } else {
this._instances.push(this._insertRow(i, key)); this._insertPlaceholder(i, key);
} }
} }
for (; i < this._instances.length; i++) { for (var j = this._instances.length - 1; j >= i; j--) {
this._detachRow(i); this._detachAndRemoveInstance(j);
} }
this._instances.splice(keys.length, this._instances.length - keys.length);
},
_keySort: function (a, b) {
return this.collection.getKey(a) - this.collection.getKey(b);
}, },
_numericSort: function (a, b) { _numericSort: function (a, b) {
return a - b; return a - b;
...@@ -3811,18 +4214,16 @@ _applySplicesUserSort: function (splices) { ...@@ -3811,18 +4214,16 @@ _applySplicesUserSort: function (splices) {
var c = this.collection; var c = this.collection;
var instances = this._instances; var instances = this._instances;
var keyMap = {}; var keyMap = {};
var pool = []; for (var i = 0, s; i < splices.length && (s = splices[i]); i++) {
var sortFn = this._sortFn || this._keySort.bind(this); for (var j = 0; j < s.removed.length; j++) {
splices.forEach(function (s) { var key = s.removed[j];
for (var i = 0; i < s.removed.length; i++) {
var key = s.removed[i];
keyMap[key] = keyMap[key] ? null : -1; keyMap[key] = keyMap[key] ? null : -1;
} }
for (var i = 0; i < s.added.length; i++) { for (var j = 0; j < s.added.length; j++) {
var key = s.added[i]; var key = s.added[j];
keyMap[key] = keyMap[key] ? null : 1; keyMap[key] = keyMap[key] ? null : 1;
} }
}, this); }
var removedIdxs = []; var removedIdxs = [];
var addedKeys = []; var addedKeys = [];
for (var key in keyMap) { for (var key in keyMap) {
...@@ -3838,36 +4239,35 @@ removedIdxs.sort(this._numericSort); ...@@ -3838,36 +4239,35 @@ removedIdxs.sort(this._numericSort);
for (var i = removedIdxs.length - 1; i >= 0; i--) { for (var i = removedIdxs.length - 1; i >= 0; i--) {
var idx = removedIdxs[i]; var idx = removedIdxs[i];
if (idx !== undefined) { if (idx !== undefined) {
pool.push(this._detachRow(idx)); this._detachAndRemoveInstance(idx);
instances.splice(idx, 1);
} }
} }
} }
var self = this;
if (addedKeys.length) { if (addedKeys.length) {
if (this._filterFn) { if (this._filterFn) {
addedKeys = addedKeys.filter(function (a) { addedKeys = addedKeys.filter(function (a) {
return this._filterFn(c.getItem(a)); return self._filterFn(c.getItem(a));
}, this); });
} }
addedKeys.sort(function (a, b) { addedKeys.sort(function (a, b) {
return this._sortFn(c.getItem(a), c.getItem(b)); return self._sortFn(c.getItem(a), c.getItem(b));
}.bind(this)); });
var start = 0; var start = 0;
for (var i = 0; i < addedKeys.length; i++) { for (var i = 0; i < addedKeys.length; i++) {
start = this._insertRowUserSort(start, addedKeys[i], pool); start = this._insertRowUserSort(start, addedKeys[i]);
} }
} }
}, },
_insertRowUserSort: function (start, key, pool) { _insertRowUserSort: function (start, key) {
var c = this.collection; var c = this.collection;
var item = c.getItem(key); var item = c.getItem(key);
var end = this._instances.length - 1; var end = this._instances.length - 1;
var idx = -1; var idx = -1;
var sortFn = this._sortFn || this._keySort.bind(this);
while (start <= end) { while (start <= end) {
var mid = start + end >> 1; var mid = start + end >> 1;
var midKey = this._instances[mid].__key__; var midKey = this._instances[mid].__key__;
var cmp = sortFn(c.getItem(midKey), item); var cmp = this._sortFn(c.getItem(midKey), item);
if (cmp < 0) { if (cmp < 0) {
start = mid + 1; start = mid + 1;
} else if (cmp > 0) { } else if (cmp > 0) {
...@@ -3880,65 +4280,80 @@ break; ...@@ -3880,65 +4280,80 @@ break;
if (idx < 0) { if (idx < 0) {
idx = end + 1; idx = end + 1;
} }
this._instances.splice(idx, 0, this._insertRow(idx, key, pool)); this._insertPlaceholder(idx, key);
return idx; return idx;
}, },
_applySplicesArrayOrder: function (splices) { _applySplicesArrayOrder: function (splices) {
var pool = [];
var c = this.collection; var c = this.collection;
splices.forEach(function (s) { for (var i = 0, s; i < splices.length && (s = splices[i]); i++) {
for (var i = 0; i < s.removed.length; i++) { for (var j = 0; j < s.removed.length; j++) {
var inst = this._detachRow(s.index + i); this._detachAndRemoveInstance(s.index);
if (!inst.isPlaceholder) {
pool.push(inst);
}
} }
this._instances.splice(s.index, s.removed.length); for (var j = 0; j < s.addedKeys.length; j++) {
for (var i = 0; i < s.addedKeys.length; i++) { this._insertPlaceholder(s.index + j, s.addedKeys[j]);
var inst = {
isPlaceholder: true,
key: s.addedKeys[i]
};
this._instances.splice(s.index + i, 0, inst);
}
}, this);
for (var i = this._instances.length - 1; i >= 0; i--) {
var inst = this._instances[i];
if (inst.isPlaceholder) {
this._instances[i] = this._insertRow(i, inst.key, pool, true);
} }
} }
}, },
_detachRow: function (idx) { _detachInstance: function (idx) {
var inst = this._instances[idx]; var inst = this._instances[idx];
if (!inst.isPlaceholder) { if (!inst.isPlaceholder) {
var parentNode = Polymer.dom(this).parentNode;
for (var i = 0; i < inst._children.length; i++) { for (var i = 0; i < inst._children.length; i++) {
var el = inst._children[i]; var el = inst._children[i];
Polymer.dom(inst.root).appendChild(el); Polymer.dom(inst.root).appendChild(el);
} }
}
return inst; return inst;
}
}, },
_insertRow: function (idx, key, pool, replace) { _attachInstance: function (idx, parent) {
var inst; var inst = this._instances[idx];
if (inst = pool && pool.pop()) { if (!inst.isPlaceholder) {
parent.insertBefore(inst.root, this);
}
},
_detachAndRemoveInstance: function (idx) {
var inst = this._detachInstance(idx);
if (inst) {
this._pool.push(inst);
}
this._instances.splice(idx, 1);
},
_insertPlaceholder: function (idx, key) {
this._instances.splice(idx, 0, {
isPlaceholder: true,
__key__: key
});
},
_stampInstance: function (idx, key) {
var model = { __key__: key };
model[this.as] = this.collection.getItem(key);
model[this.indexAs] = idx;
return this.stamp(model);
},
_insertInstance: function (idx, key) {
var inst = this._pool.pop();
if (inst) {
inst.__setProperty(this.as, this.collection.getItem(key), true); inst.__setProperty(this.as, this.collection.getItem(key), true);
inst.__setProperty('__key__', key, true); inst.__setProperty('__key__', key, true);
} else { } else {
inst = this._generateRow(idx, key); inst = this._stampInstance(idx, key);
} }
var beforeRow = this._instances[replace ? idx + 1 : idx]; var beforeRow = this._instances[idx + 1];
var beforeNode = beforeRow ? beforeRow._children[0] : this; var beforeNode = beforeRow && !beforeRow.isPlaceholder ? beforeRow._children[0] : this;
var parentNode = Polymer.dom(this).parentNode; var parentNode = Polymer.dom(this).parentNode;
Polymer.dom(parentNode).insertBefore(inst.root, beforeNode); Polymer.dom(parentNode).insertBefore(inst.root, beforeNode);
this._instances[idx] = inst;
return inst; return inst;
}, },
_generateRow: function (idx, key) { _downgradeInstance: function (idx, key) {
var model = { __key__: key }; var inst = this._detachInstance(idx);
model[this.as] = this.collection.getItem(key); if (inst) {
model[this.indexAs] = idx; this._pool.push(inst);
var inst = this.stamp(model); }
inst = {
isPlaceholder: true,
__key__: key
};
this._instances[idx] = inst;
return inst; return inst;
}, },
_showHideChildren: function (hidden) { _showHideChildren: function (hidden) {
...@@ -3959,18 +4374,24 @@ this.set('items.' + idx, value); ...@@ -3959,18 +4374,24 @@ this.set('items.' + idx, value);
}, },
_forwardInstancePath: function (inst, path, value) { _forwardInstancePath: function (inst, path, value) {
if (path.indexOf(this.as + '.') === 0) { if (path.indexOf(this.as + '.') === 0) {
this.notifyPath('items.' + inst.__key__ + '.' + path.slice(this.as.length + 1), value); this._notifyPath('items.' + inst.__key__ + '.' + path.slice(this.as.length + 1), value);
} }
}, },
_forwardParentProp: function (prop, value) { _forwardParentProp: function (prop, value) {
this._instances.forEach(function (inst) { var i$ = this._instances;
for (var i = 0, inst; i < i$.length && (inst = i$[i]); i++) {
if (!inst.isPlaceholder) {
inst.__setProperty(prop, value, true); inst.__setProperty(prop, value, true);
}, this); }
}
}, },
_forwardParentPath: function (path, value) { _forwardParentPath: function (path, value) {
this._instances.forEach(function (inst) { var i$ = this._instances;
inst.notifyPath(path, value, true); for (var i = 0, inst; i < i$.length && (inst = i$[i]); i++) {
}, this); if (!inst.isPlaceholder) {
inst._notifyPath(path, value, true);
}
}
}, },
_forwardItemPath: function (path, value) { _forwardItemPath: function (path, value) {
if (this._keyToInstIdx) { if (this._keyToInstIdx) {
...@@ -3978,10 +4399,10 @@ var dot = path.indexOf('.'); ...@@ -3978,10 +4399,10 @@ var dot = path.indexOf('.');
var key = path.substring(0, dot < 0 ? path.length : dot); var key = path.substring(0, dot < 0 ? path.length : dot);
var idx = this._keyToInstIdx[key]; var idx = this._keyToInstIdx[key];
var inst = this._instances[idx]; var inst = this._instances[idx];
if (inst) { if (inst && !inst.isPlaceholder) {
if (dot >= 0) { if (dot >= 0) {
path = this.as + '.' + path.substring(dot + 1); path = this.as + '.' + path.substring(dot + 1);
inst.notifyPath(path, value, true); inst._notifyPath(path, value, true);
} else { } else {
inst.__setProperty(this.as, value, true); inst.__setProperty(this.as, value, true);
} }
...@@ -4003,6 +4424,7 @@ return instance && instance[this.indexAs]; ...@@ -4003,6 +4424,7 @@ return instance && instance[this.indexAs];
}); });
Polymer({ Polymer({
is: 'array-selector', is: 'array-selector',
_template: null,
properties: { properties: {
items: { items: {
type: Array, type: Array,
...@@ -4033,6 +4455,7 @@ this.unlinkPaths('selected.' + i); ...@@ -4033,6 +4455,7 @@ this.unlinkPaths('selected.' + i);
} }
} else { } else {
this.unlinkPaths('selected'); this.unlinkPaths('selected');
this.unlinkPaths('selectedItem');
} }
if (this.multi) { if (this.multi) {
if (!this.selected || this.selected.length) { if (!this.selected || this.selected.length) {
...@@ -4076,7 +4499,7 @@ this.deselect(item); ...@@ -4076,7 +4499,7 @@ this.deselect(item);
} }
} else { } else {
this.push('selected', item); this.push('selected', item);
skey = this._selectedColl.getKey(item); var skey = this._selectedColl.getKey(item);
this.linkPaths('selected.' + skey, 'items.' + key); this.linkPaths('selected.' + skey, 'items.' + key);
} }
} else { } else {
...@@ -4094,6 +4517,7 @@ this.linkPaths('selectedItem', 'items.' + key); ...@@ -4094,6 +4517,7 @@ this.linkPaths('selectedItem', 'items.' + key);
Polymer({ Polymer({
is: 'dom-if', is: 'dom-if',
extends: 'template', extends: 'template',
_template: null,
properties: { properties: {
'if': { 'if': {
type: Boolean, type: Boolean,
...@@ -4141,20 +4565,23 @@ this._lastIf = this.if; ...@@ -4141,20 +4565,23 @@ this._lastIf = this.if;
}, },
_ensureInstance: function () { _ensureInstance: function () {
if (!this._instance) { if (!this._instance) {
var parentNode = Polymer.dom(this).parentNode;
if (parentNode) {
var parent = Polymer.dom(parentNode);
this._instance = this.stamp(); this._instance = this.stamp();
var root = this._instance.root; var root = this._instance.root;
var parent = Polymer.dom(Polymer.dom(this).parentNode);
parent.insertBefore(root, this); parent.insertBefore(root, this);
} }
}
}, },
_teardownInstance: function () { _teardownInstance: function () {
if (this._instance) { if (this._instance) {
var c = this._instance._children; var c$ = this._instance._children;
if (c) { if (c$) {
var parent = Polymer.dom(Polymer.dom(c[0]).parentNode); var parent = Polymer.dom(Polymer.dom(c$[0]).parentNode);
c.forEach(function (n) { for (var i = 0, n; i < c$.length && (n = c$[i]); i++) {
parent.removeChild(n); parent.removeChild(n);
}); }
} }
this._instance = null; this._instance = null;
} }
...@@ -4172,15 +4599,19 @@ this._instance[prop] = value; ...@@ -4172,15 +4599,19 @@ this._instance[prop] = value;
}, },
_forwardParentPath: function (path, value) { _forwardParentPath: function (path, value) {
if (this._instance) { if (this._instance) {
this._instance.notifyPath(path, value, true); this._instance._notifyPath(path, value, true);
} }
} }
}); });
Polymer({ Polymer({
is: 'dom-bind', is: 'dom-bind',
extends: 'template', extends: 'template',
_template: null,
created: function () { created: function () {
Polymer.RenderStatus.whenReady(this._markImportsReady.bind(this)); var self = this;
Polymer.RenderStatus.whenReady(function () {
self._markImportsReady();
});
}, },
_ensureReady: function () { _ensureReady: function () {
if (!this._readied) { if (!this._readied) {
...@@ -4219,7 +4650,10 @@ var config = {}; ...@@ -4219,7 +4650,10 @@ var config = {};
for (var prop in this._propertyEffects) { for (var prop in this._propertyEffects) {
config[prop] = this[prop]; config[prop] = this[prop];
} }
this._setupConfigure = this._setupConfigure.bind(this, config); var setupConfigure = this._setupConfigure;
this._setupConfigure = function () {
setupConfigure.call(this, config);
};
}, },
attached: function () { attached: function () {
if (this._importsReady) { if (this._importsReady) {
...@@ -4238,8 +4672,9 @@ this._prepEffects(); ...@@ -4238,8 +4672,9 @@ this._prepEffects();
this._prepBehaviors(); this._prepBehaviors();
this._prepConfigure(); this._prepConfigure();
this._prepBindings(); this._prepBindings();
this._prepPropertyInfo();
Polymer.Base._initFeatures.call(this); Polymer.Base._initFeatures.call(this);
this._children = Array.prototype.slice.call(this.root.childNodes); this._children = Polymer.DomApi.arrayCopyChildNodes(this.root);
} }
this._insertChildren(); this._insertChildren();
this.fire('dom-change'); this.fire('dom-change');
......
...@@ -7,6 +7,6 @@ ...@@ -7,6 +7,6 @@
* Code distributed by Google as part of the polymer project is also * Code distributed by Google as part of the polymer project is also
* subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt * subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
*/ */
// @version 0.7.14 // @version 0.7.17
window.WebComponents=window.WebComponents||{},function(e){var t=e.flags||{},n="webcomponents-lite.js",r=document.querySelector('script[src*="'+n+'"]');if(!t.noOpts){if(location.search.slice(1).split("&").forEach(function(e){var n,r=e.split("=");r[0]&&(n=r[0].match(/wc-(.+)/))&&(t[n[1]]=r[1]||!0)}),r)for(var o,i=0;o=r.attributes[i];i++)"src"!==o.name&&(t[o.name]=o.value||!0);if(t.log){var a=t.log.split(",");t.log={},a.forEach(function(e){t.log[e]=!0})}else t.log={}}t.shadow=t.shadow||t.shadowdom||t.polyfill,"native"===t.shadow?t.shadow=!1:t.shadow=t.shadow||!HTMLElement.prototype.createShadowRoot,t.register&&(window.CustomElements=window.CustomElements||{flags:{}},window.CustomElements.flags.register=t.register),e.flags=t}(window.WebComponents),function(e){"use strict";function t(e){return void 0!==h[e]}function n(){s.call(this),this._isInvalid=!0}function r(e){return""==e&&n.call(this),e.toLowerCase()}function o(e){var t=e.charCodeAt(0);return t>32&&127>t&&-1==[34,35,60,62,63,96].indexOf(t)?e:encodeURIComponent(e)}function i(e){var t=e.charCodeAt(0);return t>32&&127>t&&-1==[34,35,60,62,96].indexOf(t)?e:encodeURIComponent(e)}function a(e,a,s){function c(e){g.push(e)}var d=a||"scheme start",u=0,l="",w=!1,_=!1,g=[];e:for(;(e[u-1]!=p||0==u)&&!this._isInvalid;){var b=e[u];switch(d){case"scheme start":if(!b||!m.test(b)){if(a){c("Invalid scheme.");break e}l="",d="no scheme";continue}l+=b.toLowerCase(),d="scheme";break;case"scheme":if(b&&v.test(b))l+=b.toLowerCase();else{if(":"!=b){if(a){if(p==b)break e;c("Code point not allowed in scheme: "+b);break e}l="",u=0,d="no scheme";continue}if(this._scheme=l,l="",a)break e;t(this._scheme)&&(this._isRelative=!0),d="file"==this._scheme?"relative":this._isRelative&&s&&s._scheme==this._scheme?"relative or authority":this._isRelative?"authority first slash":"scheme data"}break;case"scheme data":"?"==b?(this._query="?",d="query"):"#"==b?(this._fragment="#",d="fragment"):p!=b&&" "!=b&&"\n"!=b&&"\r"!=b&&(this._schemeData+=o(b));break;case"no scheme":if(s&&t(s._scheme)){d="relative";continue}c("Missing scheme."),n.call(this);break;case"relative or authority":if("/"!=b||"/"!=e[u+1]){c("Expected /, got: "+b),d="relative";continue}d="authority ignore slashes";break;case"relative":if(this._isRelative=!0,"file"!=this._scheme&&(this._scheme=s._scheme),p==b){this._host=s._host,this._port=s._port,this._path=s._path.slice(),this._query=s._query,this._username=s._username,this._password=s._password;break e}if("/"==b||"\\"==b)"\\"==b&&c("\\ is an invalid code point."),d="relative slash";else if("?"==b)this._host=s._host,this._port=s._port,this._path=s._path.slice(),this._query="?",this._username=s._username,this._password=s._password,d="query";else{if("#"!=b){var y=e[u+1],E=e[u+2];("file"!=this._scheme||!m.test(b)||":"!=y&&"|"!=y||p!=E&&"/"!=E&&"\\"!=E&&"?"!=E&&"#"!=E)&&(this._host=s._host,this._port=s._port,this._username=s._username,this._password=s._password,this._path=s._path.slice(),this._path.pop()),d="relative path";continue}this._host=s._host,this._port=s._port,this._path=s._path.slice(),this._query=s._query,this._fragment="#",this._username=s._username,this._password=s._password,d="fragment"}break;case"relative slash":if("/"!=b&&"\\"!=b){"file"!=this._scheme&&(this._host=s._host,this._port=s._port,this._username=s._username,this._password=s._password),d="relative path";continue}"\\"==b&&c("\\ is an invalid code point."),d="file"==this._scheme?"file host":"authority ignore slashes";break;case"authority first slash":if("/"!=b){c("Expected '/', got: "+b),d="authority ignore slashes";continue}d="authority second slash";break;case"authority second slash":if(d="authority ignore slashes","/"!=b){c("Expected '/', got: "+b);continue}break;case"authority ignore slashes":if("/"!=b&&"\\"!=b){d="authority";continue}c("Expected authority, got: "+b);break;case"authority":if("@"==b){w&&(c("@ already seen."),l+="%40"),w=!0;for(var L=0;L<l.length;L++){var M=l[L];if(" "!=M&&"\n"!=M&&"\r"!=M)if(":"!=M||null!==this._password){var T=o(M);null!==this._password?this._password+=T:this._username+=T}else this._password="";else c("Invalid whitespace in authority.")}l=""}else{if(p==b||"/"==b||"\\"==b||"?"==b||"#"==b){u-=l.length,l="",d="host";continue}l+=b}break;case"file host":if(p==b||"/"==b||"\\"==b||"?"==b||"#"==b){2!=l.length||!m.test(l[0])||":"!=l[1]&&"|"!=l[1]?0==l.length?d="relative path start":(this._host=r.call(this,l),l="",d="relative path start"):d="relative path";continue}" "==b||"\n"==b||"\r"==b?c("Invalid whitespace in file host."):l+=b;break;case"host":case"hostname":if(":"!=b||_){if(p==b||"/"==b||"\\"==b||"?"==b||"#"==b){if(this._host=r.call(this,l),l="",d="relative path start",a)break e;continue}" "!=b&&"\n"!=b&&"\r"!=b?("["==b?_=!0:"]"==b&&(_=!1),l+=b):c("Invalid code point in host/hostname: "+b)}else if(this._host=r.call(this,l),l="",d="port","hostname"==a)break e;break;case"port":if(/[0-9]/.test(b))l+=b;else{if(p==b||"/"==b||"\\"==b||"?"==b||"#"==b||a){if(""!=l){var N=parseInt(l,10);N!=h[this._scheme]&&(this._port=N+""),l=""}if(a)break e;d="relative path start";continue}" "==b||"\n"==b||"\r"==b?c("Invalid code point in port: "+b):n.call(this)}break;case"relative path start":if("\\"==b&&c("'\\' not allowed in path."),d="relative path","/"!=b&&"\\"!=b)continue;break;case"relative path":if(p!=b&&"/"!=b&&"\\"!=b&&(a||"?"!=b&&"#"!=b))" "!=b&&"\n"!=b&&"\r"!=b&&(l+=o(b));else{"\\"==b&&c("\\ not allowed in relative path.");var O;(O=f[l.toLowerCase()])&&(l=O),".."==l?(this._path.pop(),"/"!=b&&"\\"!=b&&this._path.push("")):"."==l&&"/"!=b&&"\\"!=b?this._path.push(""):"."!=l&&("file"==this._scheme&&0==this._path.length&&2==l.length&&m.test(l[0])&&"|"==l[1]&&(l=l[0]+":"),this._path.push(l)),l="","?"==b?(this._query="?",d="query"):"#"==b&&(this._fragment="#",d="fragment")}break;case"query":a||"#"!=b?p!=b&&" "!=b&&"\n"!=b&&"\r"!=b&&(this._query+=i(b)):(this._fragment="#",d="fragment");break;case"fragment":p!=b&&" "!=b&&"\n"!=b&&"\r"!=b&&(this._fragment+=b)}u++}}function s(){this._scheme="",this._schemeData="",this._username="",this._password=null,this._host="",this._port="",this._path=[],this._query="",this._fragment="",this._isInvalid=!1,this._isRelative=!1}function c(e,t){void 0===t||t instanceof c||(t=new c(String(t))),this._url=e,s.call(this);var n=e.replace(/^[ \t\r\n\f]+|[ \t\r\n\f]+$/g,"");a.call(this,n,null,t)}var d=!1;if(!e.forceJURL)try{var u=new URL("b","http://a");u.pathname="c%20d",d="http://a/c%20d"===u.href}catch(l){}if(!d){var h=Object.create(null);h.ftp=21,h.file=0,h.gopher=70,h.http=80,h.https=443,h.ws=80,h.wss=443;var f=Object.create(null);f["%2e"]=".",f[".%2e"]="..",f["%2e."]="..",f["%2e%2e"]="..";var p=void 0,m=/[a-zA-Z]/,v=/[a-zA-Z0-9\+\-\.]/;c.prototype={toString:function(){return this.href},get href(){if(this._isInvalid)return this._url;var e="";return(""!=this._username||null!=this._password)&&(e=this._username+(null!=this._password?":"+this._password:"")+"@"),this.protocol+(this._isRelative?"//"+e+this.host:"")+this.pathname+this._query+this._fragment},set href(e){s.call(this),a.call(this,e)},get protocol(){return this._scheme+":"},set protocol(e){this._isInvalid||a.call(this,e+":","scheme start")},get host(){return this._isInvalid?"":this._port?this._host+":"+this._port:this._host},set host(e){!this._isInvalid&&this._isRelative&&a.call(this,e,"host")},get hostname(){return this._host},set hostname(e){!this._isInvalid&&this._isRelative&&a.call(this,e,"hostname")},get port(){return this._port},set port(e){!this._isInvalid&&this._isRelative&&a.call(this,e,"port")},get pathname(){return this._isInvalid?"":this._isRelative?"/"+this._path.join("/"):this._schemeData},set pathname(e){!this._isInvalid&&this._isRelative&&(this._path=[],a.call(this,e,"relative path start"))},get search(){return this._isInvalid||!this._query||"?"==this._query?"":this._query},set search(e){!this._isInvalid&&this._isRelative&&(this._query="?","?"==e[0]&&(e=e.slice(1)),a.call(this,e,"query"))},get hash(){return this._isInvalid||!this._fragment||"#"==this._fragment?"":this._fragment},set hash(e){this._isInvalid||(this._fragment="#","#"==e[0]&&(e=e.slice(1)),a.call(this,e,"fragment"))},get origin(){var e;if(this._isInvalid||!this._scheme)return"";switch(this._scheme){case"data":case"file":case"javascript":case"mailto":return"null"}return e=this.host,e?this._scheme+"://"+e:""}};var w=e.URL;w&&(c.createObjectURL=function(e){return w.createObjectURL.apply(w,arguments)},c.revokeObjectURL=function(e){w.revokeObjectURL(e)}),e.URL=c}}(self),"undefined"==typeof WeakMap&&!function(){var e=Object.defineProperty,t=Date.now()%1e9,n=function(){this.name="__st"+(1e9*Math.random()>>>0)+(t++ +"__")};n.prototype={set:function(t,n){var r=t[this.name];return r&&r[0]===t?r[1]=n:e(t,this.name,{value:[t,n],writable:!0}),this},get:function(e){var t;return(t=e[this.name])&&t[0]===e?t[1]:void 0},"delete":function(e){var t=e[this.name];return t&&t[0]===e?(t[0]=t[1]=void 0,!0):!1},has:function(e){var t=e[this.name];return t?t[0]===e:!1}},window.WeakMap=n}(),function(e){function t(e){b.push(e),g||(g=!0,m(r))}function n(e){return window.ShadowDOMPolyfill&&window.ShadowDOMPolyfill.wrapIfNeeded(e)||e}function r(){g=!1;var e=b;b=[],e.sort(function(e,t){return e.uid_-t.uid_});var t=!1;e.forEach(function(e){var n=e.takeRecords();o(e),n.length&&(e.callback_(n,e),t=!0)}),t&&r()}function o(e){e.nodes_.forEach(function(t){var n=v.get(t);n&&n.forEach(function(t){t.observer===e&&t.removeTransientObservers()})})}function i(e,t){for(var n=e;n;n=n.parentNode){var r=v.get(n);if(r)for(var o=0;o<r.length;o++){var i=r[o],a=i.options;if(n===e||a.subtree){var s=t(a);s&&i.enqueue(s)}}}}function a(e){this.callback_=e,this.nodes_=[],this.records_=[],this.uid_=++y}function s(e,t){this.type=e,this.target=t,this.addedNodes=[],this.removedNodes=[],this.previousSibling=null,this.nextSibling=null,this.attributeName=null,this.attributeNamespace=null,this.oldValue=null}function c(e){var t=new s(e.type,e.target);return t.addedNodes=e.addedNodes.slice(),t.removedNodes=e.removedNodes.slice(),t.previousSibling=e.previousSibling,t.nextSibling=e.nextSibling,t.attributeName=e.attributeName,t.attributeNamespace=e.attributeNamespace,t.oldValue=e.oldValue,t}function d(e,t){return E=new s(e,t)}function u(e){return L?L:(L=c(E),L.oldValue=e,L)}function l(){E=L=void 0}function h(e){return e===L||e===E}function f(e,t){return e===t?e:L&&h(e)?L:null}function p(e,t,n){this.observer=e,this.target=t,this.options=n,this.transientObservedNodes=[]}var m,v=new WeakMap;if(/Trident|Edge/.test(navigator.userAgent))m=setTimeout;else if(window.setImmediate)m=window.setImmediate;else{var w=[],_=String(Math.random());window.addEventListener("message",function(e){if(e.data===_){var t=w;w=[],t.forEach(function(e){e()})}}),m=function(e){w.push(e),window.postMessage(_,"*")}}var g=!1,b=[],y=0;a.prototype={observe:function(e,t){if(e=n(e),!t.childList&&!t.attributes&&!t.characterData||t.attributeOldValue&&!t.attributes||t.attributeFilter&&t.attributeFilter.length&&!t.attributes||t.characterDataOldValue&&!t.characterData)throw new SyntaxError;var r=v.get(e);r||v.set(e,r=[]);for(var o,i=0;i<r.length;i++)if(r[i].observer===this){o=r[i],o.removeListeners(),o.options=t;break}o||(o=new p(this,e,t),r.push(o),this.nodes_.push(e)),o.addListeners()},disconnect:function(){this.nodes_.forEach(function(e){for(var t=v.get(e),n=0;n<t.length;n++){var r=t[n];if(r.observer===this){r.removeListeners(),t.splice(n,1);break}}},this),this.records_=[]},takeRecords:function(){var e=this.records_;return this.records_=[],e}};var E,L;p.prototype={enqueue:function(e){var n=this.observer.records_,r=n.length;if(n.length>0){var o=n[r-1],i=f(o,e);if(i)return void(n[r-1]=i)}else t(this.observer);n[r]=e},addListeners:function(){this.addListeners_(this.target)},addListeners_:function(e){var t=this.options;t.attributes&&e.addEventListener("DOMAttrModified",this,!0),t.characterData&&e.addEventListener("DOMCharacterDataModified",this,!0),t.childList&&e.addEventListener("DOMNodeInserted",this,!0),(t.childList||t.subtree)&&e.addEventListener("DOMNodeRemoved",this,!0)},removeListeners:function(){this.removeListeners_(this.target)},removeListeners_:function(e){var t=this.options;t.attributes&&e.removeEventListener("DOMAttrModified",this,!0),t.characterData&&e.removeEventListener("DOMCharacterDataModified",this,!0),t.childList&&e.removeEventListener("DOMNodeInserted",this,!0),(t.childList||t.subtree)&&e.removeEventListener("DOMNodeRemoved",this,!0)},addTransientObserver:function(e){if(e!==this.target){this.addListeners_(e),this.transientObservedNodes.push(e);var t=v.get(e);t||v.set(e,t=[]),t.push(this)}},removeTransientObservers:function(){var e=this.transientObservedNodes;this.transientObservedNodes=[],e.forEach(function(e){this.removeListeners_(e);for(var t=v.get(e),n=0;n<t.length;n++)if(t[n]===this){t.splice(n,1);break}},this)},handleEvent:function(e){switch(e.stopImmediatePropagation(),e.type){case"DOMAttrModified":var t=e.attrName,n=e.relatedNode.namespaceURI,r=e.target,o=new d("attributes",r);o.attributeName=t,o.attributeNamespace=n;var a=e.attrChange===MutationEvent.ADDITION?null:e.prevValue;i(r,function(e){return!e.attributes||e.attributeFilter&&e.attributeFilter.length&&-1===e.attributeFilter.indexOf(t)&&-1===e.attributeFilter.indexOf(n)?void 0:e.attributeOldValue?u(a):o});break;case"DOMCharacterDataModified":var r=e.target,o=d("characterData",r),a=e.prevValue;i(r,function(e){return e.characterData?e.characterDataOldValue?u(a):o:void 0});break;case"DOMNodeRemoved":this.addTransientObserver(e.target);case"DOMNodeInserted":var s,c,h=e.target;"DOMNodeInserted"===e.type?(s=[h],c=[]):(s=[],c=[h]);var f=h.previousSibling,p=h.nextSibling,o=d("childList",e.target.parentNode);o.addedNodes=s,o.removedNodes=c,o.previousSibling=f,o.nextSibling=p,i(e.relatedNode,function(e){return e.childList?o:void 0})}l()}},e.JsMutationObserver=a,e.MutationObserver||(e.MutationObserver=a)}(self),window.HTMLImports=window.HTMLImports||{flags:{}},function(e){function t(e,t){t=t||p,r(function(){i(e,t)},t)}function n(e){return"complete"===e.readyState||e.readyState===w}function r(e,t){if(n(t))e&&e();else{var o=function(){("complete"===t.readyState||t.readyState===w)&&(t.removeEventListener(_,o),r(e,t))};t.addEventListener(_,o)}}function o(e){e.target.__loaded=!0}function i(e,t){function n(){c==d&&e&&e({allImports:s,loadedImports:u,errorImports:l})}function r(e){o(e),u.push(this),c++,n()}function i(e){l.push(this),c++,n()}var s=t.querySelectorAll("link[rel=import]"),c=0,d=s.length,u=[],l=[];if(d)for(var h,f=0;d>f&&(h=s[f]);f++)a(h)?(c++,n()):(h.addEventListener("load",r),h.addEventListener("error",i));else n()}function a(e){return l?e.__loaded||e["import"]&&"loading"!==e["import"].readyState:e.__importParsed}function s(e){for(var t,n=0,r=e.length;r>n&&(t=e[n]);n++)c(t)&&d(t)}function c(e){return"link"===e.localName&&"import"===e.rel}function d(e){var t=e["import"];t?o({target:e}):(e.addEventListener("load",o),e.addEventListener("error",o))}var u="import",l=Boolean(u in document.createElement("link")),h=Boolean(window.ShadowDOMPolyfill),f=function(e){return h?window.ShadowDOMPolyfill.wrapIfNeeded(e):e},p=f(document),m={get:function(){var e=window.HTMLImports.currentScript||document.currentScript||("complete"!==document.readyState?document.scripts[document.scripts.length-1]:null);return f(e)},configurable:!0};Object.defineProperty(document,"_currentScript",m),Object.defineProperty(p,"_currentScript",m);var v=/Trident/.test(navigator.userAgent),w=v?"complete":"interactive",_="readystatechange";l&&(new MutationObserver(function(e){for(var t,n=0,r=e.length;r>n&&(t=e[n]);n++)t.addedNodes&&s(t.addedNodes)}).observe(document.head,{childList:!0}),function(){if("loading"===document.readyState)for(var e,t=document.querySelectorAll("link[rel=import]"),n=0,r=t.length;r>n&&(e=t[n]);n++)d(e)}()),t(function(e){window.HTMLImports.ready=!0,window.HTMLImports.readyTime=(new Date).getTime();var t=p.createEvent("CustomEvent");t.initCustomEvent("HTMLImportsLoaded",!0,!0,e),p.dispatchEvent(t)}),e.IMPORT_LINK_TYPE=u,e.useNative=l,e.rootDocument=p,e.whenReady=t,e.isIE=v}(window.HTMLImports),function(e){var t=[],n=function(e){t.push(e)},r=function(){t.forEach(function(t){t(e)})};e.addModule=n,e.initializeModules=r}(window.HTMLImports),window.HTMLImports.addModule(function(e){var t=/(url\()([^)]*)(\))/g,n=/(@import[\s]+(?!url\())([^;]*)(;)/g,r={resolveUrlsInStyle:function(e,t){var n=e.ownerDocument,r=n.createElement("a");return e.textContent=this.resolveUrlsInCssText(e.textContent,t,r),e},resolveUrlsInCssText:function(e,r,o){var i=this.replaceUrls(e,o,r,t);return i=this.replaceUrls(i,o,r,n)},replaceUrls:function(e,t,n,r){return e.replace(r,function(e,r,o,i){var a=o.replace(/["']/g,"");return n&&(a=new URL(a,n).href),t.href=a,a=t.href,r+"'"+a+"'"+i})}};e.path=r}),window.HTMLImports.addModule(function(e){var t={async:!0,ok:function(e){return e.status>=200&&e.status<300||304===e.status||0===e.status},load:function(n,r,o){var i=new XMLHttpRequest;return(e.flags.debug||e.flags.bust)&&(n+="?"+Math.random()),i.open("GET",n,t.async),i.addEventListener("readystatechange",function(e){if(4===i.readyState){var n=i.getResponseHeader("Location"),a=null;if(n)var a="/"===n.substr(0,1)?location.origin+n:n;r.call(o,!t.ok(i)&&i,i.response||i.responseText,a)}}),i.send(),i},loadDocument:function(e,t,n){this.load(e,t,n).responseType="document"}};e.xhr=t}),window.HTMLImports.addModule(function(e){var t=e.xhr,n=e.flags,r=function(e,t){this.cache={},this.onload=e,this.oncomplete=t,this.inflight=0,this.pending={}};r.prototype={addNodes:function(e){this.inflight+=e.length;for(var t,n=0,r=e.length;r>n&&(t=e[n]);n++)this.require(t);this.checkDone()},addNode:function(e){this.inflight++,this.require(e),this.checkDone()},require:function(e){var t=e.src||e.href;e.__nodeUrl=t,this.dedupe(t,e)||this.fetch(t,e)},dedupe:function(e,t){if(this.pending[e])return this.pending[e].push(t),!0;return this.cache[e]?(this.onload(e,t,this.cache[e]),this.tail(),!0):(this.pending[e]=[t],!1)},fetch:function(e,r){if(n.load&&console.log("fetch",e,r),e)if(e.match(/^data:/)){var o=e.split(","),i=o[0],a=o[1];a=i.indexOf(";base64")>-1?atob(a):decodeURIComponent(a),setTimeout(function(){this.receive(e,r,null,a)}.bind(this),0)}else{var s=function(t,n,o){this.receive(e,r,t,n,o)}.bind(this);t.load(e,s)}else setTimeout(function(){this.receive(e,r,{error:"href must be specified"},null)}.bind(this),0)},receive:function(e,t,n,r,o){this.cache[e]=r;for(var i,a=this.pending[e],s=0,c=a.length;c>s&&(i=a[s]);s++)this.onload(e,i,r,n,o),this.tail();this.pending[e]=null},tail:function(){--this.inflight,this.checkDone()},checkDone:function(){this.inflight||this.oncomplete()}},e.Loader=r}),window.HTMLImports.addModule(function(e){var t=function(e){this.addCallback=e,this.mo=new MutationObserver(this.handler.bind(this))};t.prototype={handler:function(e){for(var t,n=0,r=e.length;r>n&&(t=e[n]);n++)"childList"===t.type&&t.addedNodes.length&&this.addedNodes(t.addedNodes)},addedNodes:function(e){this.addCallback&&this.addCallback(e);for(var t,n=0,r=e.length;r>n&&(t=e[n]);n++)t.children&&t.children.length&&this.addedNodes(t.children)},observe:function(e){this.mo.observe(e,{childList:!0,subtree:!0})}},e.Observer=t}),window.HTMLImports.addModule(function(e){function t(e){return"link"===e.localName&&e.rel===u}function n(e){var t=r(e);return"data:text/javascript;charset=utf-8,"+encodeURIComponent(t)}function r(e){return e.textContent+o(e)}function o(e){var t=e.ownerDocument;t.__importedScripts=t.__importedScripts||0;var n=e.ownerDocument.baseURI,r=t.__importedScripts?"-"+t.__importedScripts:"";return t.__importedScripts++,"\n//# sourceURL="+n+r+".js\n"}function i(e){var t=e.ownerDocument.createElement("style");return t.textContent=e.textContent,a.resolveUrlsInStyle(t),t}var a=e.path,s=e.rootDocument,c=e.flags,d=e.isIE,u=e.IMPORT_LINK_TYPE,l="link[rel="+u+"]",h={documentSelectors:l,importsSelectors:[l,"link[rel=stylesheet]:not([type])","style:not([type])","script:not([type])",'script[type="application/javascript"]','script[type="text/javascript"]'].join(","),map:{link:"parseLink",script:"parseScript",style:"parseStyle"},dynamicElements:[],parseNext:function(){var e=this.nextToParse();e&&this.parse(e)},parse:function(e){if(this.isParsed(e))return void(c.parse&&console.log("[%s] is already parsed",e.localName));var t=this[this.map[e.localName]];t&&(this.markParsing(e),t.call(this,e))},parseDynamic:function(e,t){this.dynamicElements.push(e),t||this.parseNext()},markParsing:function(e){c.parse&&console.log("parsing",e),this.parsingElement=e},markParsingComplete:function(e){e.__importParsed=!0,this.markDynamicParsingComplete(e),e.__importElement&&(e.__importElement.__importParsed=!0,this.markDynamicParsingComplete(e.__importElement)),this.parsingElement=null,c.parse&&console.log("completed",e)},markDynamicParsingComplete:function(e){var t=this.dynamicElements.indexOf(e);t>=0&&this.dynamicElements.splice(t,1)},parseImport:function(e){if(e["import"]=e.__doc,window.HTMLImports.__importsParsingHook&&window.HTMLImports.__importsParsingHook(e),e["import"]&&(e["import"].__importParsed=!0),this.markParsingComplete(e),e.__resource&&!e.__error?e.dispatchEvent(new CustomEvent("load",{bubbles:!1})):e.dispatchEvent(new CustomEvent("error",{bubbles:!1})),e.__pending)for(var t;e.__pending.length;)t=e.__pending.shift(),t&&t({target:e});this.parseNext()},parseLink:function(e){t(e)?this.parseImport(e):(e.href=e.href,this.parseGeneric(e))},parseStyle:function(e){var t=e;e=i(e),t.__appliedElement=e,e.__importElement=t,this.parseGeneric(e)},parseGeneric:function(e){this.trackElement(e),this.addElementToDocument(e)},rootImportForElement:function(e){for(var t=e;t.ownerDocument.__importLink;)t=t.ownerDocument.__importLink;return t},addElementToDocument:function(e){var t=this.rootImportForElement(e.__importElement||e);t.parentNode.insertBefore(e,t)},trackElement:function(e,t){var n=this,r=function(o){e.removeEventListener("load",r),e.removeEventListener("error",r),t&&t(o),n.markParsingComplete(e),n.parseNext()};if(e.addEventListener("load",r),e.addEventListener("error",r),d&&"style"===e.localName){var o=!1;if(-1==e.textContent.indexOf("@import"))o=!0;else if(e.sheet){o=!0;for(var i,a=e.sheet.cssRules,s=a?a.length:0,c=0;s>c&&(i=a[c]);c++)i.type===CSSRule.IMPORT_RULE&&(o=o&&Boolean(i.styleSheet))}o&&setTimeout(function(){e.dispatchEvent(new CustomEvent("load",{bubbles:!1}))})}},parseScript:function(t){var r=document.createElement("script");r.__importElement=t,r.src=t.src?t.src:n(t),e.currentScript=t,this.trackElement(r,function(t){r.parentNode&&r.parentNode.removeChild(r),e.currentScript=null}),this.addElementToDocument(r)},nextToParse:function(){return this._mayParse=[],!this.parsingElement&&(this.nextToParseInDoc(s)||this.nextToParseDynamic())},nextToParseInDoc:function(e,n){if(e&&this._mayParse.indexOf(e)<0){this._mayParse.push(e);for(var r,o=e.querySelectorAll(this.parseSelectorsForNode(e)),i=0,a=o.length;a>i&&(r=o[i]);i++)if(!this.isParsed(r))return this.hasResource(r)?t(r)?this.nextToParseInDoc(r.__doc,r):r:void 0}return n},nextToParseDynamic:function(){return this.dynamicElements[0]},parseSelectorsForNode:function(e){var t=e.ownerDocument||e;return t===s?this.documentSelectors:this.importsSelectors},isParsed:function(e){return e.__importParsed},needsDynamicParsing:function(e){return this.dynamicElements.indexOf(e)>=0},hasResource:function(e){return t(e)&&void 0===e.__doc?!1:!0}};e.parser=h,e.IMPORT_SELECTOR=l}),window.HTMLImports.addModule(function(e){function t(e){return n(e,a)}function n(e,t){return"link"===e.localName&&e.getAttribute("rel")===t}function r(e){return!!Object.getOwnPropertyDescriptor(e,"baseURI")}function o(e,t){var n=document.implementation.createHTMLDocument(a);n._URL=t;var o=n.createElement("base");o.setAttribute("href",t),n.baseURI||r(n)||Object.defineProperty(n,"baseURI",{value:t});var i=n.createElement("meta");return i.setAttribute("charset","utf-8"),n.head.appendChild(i),n.head.appendChild(o),n.body.innerHTML=e,window.HTMLTemplateElement&&HTMLTemplateElement.bootstrap&&HTMLTemplateElement.bootstrap(n),n}var i=e.flags,a=e.IMPORT_LINK_TYPE,s=e.IMPORT_SELECTOR,c=e.rootDocument,d=e.Loader,u=e.Observer,l=e.parser,h={documents:{},documentPreloadSelectors:s,importsPreloadSelectors:[s].join(","),loadNode:function(e){f.addNode(e)},loadSubtree:function(e){var t=this.marshalNodes(e);f.addNodes(t)},marshalNodes:function(e){return e.querySelectorAll(this.loadSelectorsForNode(e))},loadSelectorsForNode:function(e){var t=e.ownerDocument||e;return t===c?this.documentPreloadSelectors:this.importsPreloadSelectors},loaded:function(e,n,r,a,s){if(i.load&&console.log("loaded",e,n),n.__resource=r,n.__error=a,t(n)){var c=this.documents[e];void 0===c&&(c=a?null:o(r,s||e),c&&(c.__importLink=n,this.bootDocument(c)),this.documents[e]=c),n.__doc=c}l.parseNext()},bootDocument:function(e){this.loadSubtree(e),this.observer.observe(e),l.parseNext()},loadedAll:function(){l.parseNext()}},f=new d(h.loaded.bind(h),h.loadedAll.bind(h));if(h.observer=new u,!document.baseURI){var p={get:function(){var e=document.querySelector("base");return e?e.href:window.location.href},configurable:!0};Object.defineProperty(document,"baseURI",p),Object.defineProperty(c,"baseURI",p)}e.importer=h,e.importLoader=f}),window.HTMLImports.addModule(function(e){var t=e.parser,n=e.importer,r={added:function(e){for(var r,o,i,a,s=0,c=e.length;c>s&&(a=e[s]);s++)r||(r=a.ownerDocument,o=t.isParsed(r)),i=this.shouldLoadNode(a),i&&n.loadNode(a),this.shouldParseNode(a)&&o&&t.parseDynamic(a,i)},shouldLoadNode:function(e){return 1===e.nodeType&&o.call(e,n.loadSelectorsForNode(e))},shouldParseNode:function(e){return 1===e.nodeType&&o.call(e,t.parseSelectorsForNode(e))}};n.observer.addCallback=r.added.bind(r);var o=HTMLElement.prototype.matches||HTMLElement.prototype.matchesSelector||HTMLElement.prototype.webkitMatchesSelector||HTMLElement.prototype.mozMatchesSelector||HTMLElement.prototype.msMatchesSelector}),function(e){function t(){window.HTMLImports.importer.bootDocument(o)}var n=e.initializeModules,r=e.isIE;if(!e.useNative){(!window.CustomEvent||r&&"function"!=typeof window.CustomEvent)&&(window.CustomEvent=function(e,t){t=t||{};var n=document.createEvent("CustomEvent");return n.initCustomEvent(e,Boolean(t.bubbles),Boolean(t.cancelable),t.detail),n.preventDefault=function(){Object.defineProperty(this,"defaultPrevented",{get:function(){return!0}})},n},window.CustomEvent.prototype=window.Event.prototype),n();var o=e.rootDocument;"complete"===document.readyState||"interactive"===document.readyState&&!window.attachEvent?t():document.addEventListener("DOMContentLoaded",t)}}(window.HTMLImports),window.CustomElements=window.CustomElements||{flags:{}},function(e){var t=e.flags,n=[],r=function(e){n.push(e)},o=function(){n.forEach(function(t){t(e)})};e.addModule=r,e.initializeModules=o,e.hasNative=Boolean(document.registerElement),e.isIE=/Trident/.test(navigator.userAgent),e.useNative=!t.register&&e.hasNative&&!window.ShadowDOMPolyfill&&(!window.HTMLImports||window.HTMLImports.useNative)}(window.CustomElements),window.CustomElements.addModule(function(e){function t(e,t){n(e,function(e){return t(e)?!0:void r(e,t)}),r(e,t)}function n(e,t,r){var o=e.firstElementChild;if(!o)for(o=e.firstChild;o&&o.nodeType!==Node.ELEMENT_NODE;)o=o.nextSibling;for(;o;)t(o,r)!==!0&&n(o,t,r),o=o.nextElementSibling;return null}function r(e,n){for(var r=e.shadowRoot;r;)t(r,n),r=r.olderShadowRoot}function o(e,t){i(e,t,[])}function i(e,t,n){if(e=window.wrap(e),!(n.indexOf(e)>=0)){n.push(e);for(var r,o=e.querySelectorAll("link[rel="+a+"]"),s=0,c=o.length;c>s&&(r=o[s]);s++)r["import"]&&i(r["import"],t,n);t(e)}}var a=window.HTMLImports?window.HTMLImports.IMPORT_LINK_TYPE:"none";e.forDocumentTree=o,e.forSubtree=t}),window.CustomElements.addModule(function(e){function t(e,t){return n(e,t)||r(e,t)}function n(t,n){return e.upgrade(t,n)?!0:void(n&&a(t))}function r(e,t){g(e,function(e){return n(e,t)?!0:void 0})}function o(e){L.push(e),E||(E=!0,setTimeout(i))}function i(){E=!1;for(var e,t=L,n=0,r=t.length;r>n&&(e=t[n]);n++)e();L=[]}function a(e){y?o(function(){s(e)}):s(e)}function s(e){e.__upgraded__&&!e.__attached&&(e.__attached=!0,e.attachedCallback&&e.attachedCallback())}function c(e){d(e),g(e,function(e){d(e)})}function d(e){y?o(function(){u(e)}):u(e)}function u(e){e.__upgraded__&&e.__attached&&(e.__attached=!1,e.detachedCallback&&e.detachedCallback())}function l(e){for(var t=e,n=window.wrap(document);t;){if(t==n)return!0;t=t.parentNode||t.nodeType===Node.DOCUMENT_FRAGMENT_NODE&&t.host}}function h(e){if(e.shadowRoot&&!e.shadowRoot.__watched){_.dom&&console.log("watching shadow-root for: ",e.localName);for(var t=e.shadowRoot;t;)m(t),t=t.olderShadowRoot}}function f(e,n){if(_.dom){var r=n[0];if(r&&"childList"===r.type&&r.addedNodes&&r.addedNodes){for(var o=r.addedNodes[0];o&&o!==document&&!o.host;)o=o.parentNode;var i=o&&(o.URL||o._URL||o.host&&o.host.localName)||"";i=i.split("/?").shift().split("/").pop()}console.group("mutations (%d) [%s]",n.length,i||"")}var a=l(e);n.forEach(function(e){"childList"===e.type&&(M(e.addedNodes,function(e){e.localName&&t(e,a)}),M(e.removedNodes,function(e){e.localName&&c(e)}))}),_.dom&&console.groupEnd()}function p(e){for(e=window.wrap(e),e||(e=window.wrap(document));e.parentNode;)e=e.parentNode;var t=e.__observer;t&&(f(e,t.takeRecords()),i())}function m(e){if(!e.__observer){var t=new MutationObserver(f.bind(this,e));t.observe(e,{childList:!0,subtree:!0}),e.__observer=t}}function v(e){e=window.wrap(e),_.dom&&console.group("upgradeDocument: ",e.baseURI.split("/").pop());var n=e===window.wrap(document);t(e,n),m(e),_.dom&&console.groupEnd()}function w(e){b(e,v)}var _=e.flags,g=e.forSubtree,b=e.forDocumentTree,y=!window.MutationObserver||window.MutationObserver===window.JsMutationObserver;e.hasPolyfillMutations=y;var E=!1,L=[],M=Array.prototype.forEach.call.bind(Array.prototype.forEach),T=Element.prototype.createShadowRoot;T&&(Element.prototype.createShadowRoot=function(){var e=T.call(this);return window.CustomElements.watchShadow(this),e}),e.watchShadow=h,e.upgradeDocumentTree=w,e.upgradeDocument=v,e.upgradeSubtree=r,e.upgradeAll=t,e.attached=a,e.takeRecords=p}),window.CustomElements.addModule(function(e){function t(t,r){if(!t.__upgraded__&&t.nodeType===Node.ELEMENT_NODE){var o=t.getAttribute("is"),i=e.getRegisteredDefinition(t.localName)||e.getRegisteredDefinition(o);if(i&&(o&&i.tag==t.localName||!o&&!i["extends"]))return n(t,i,r)}}function n(t,n,o){return a.upgrade&&console.group("upgrade:",t.localName),n.is&&t.setAttribute("is",n.is),r(t,n),t.__upgraded__=!0,i(t),o&&e.attached(t),e.upgradeSubtree(t,o),a.upgrade&&console.groupEnd(),t}function r(e,t){Object.__proto__?e.__proto__=t.prototype:(o(e,t.prototype,t["native"]),e.__proto__=t.prototype)}function o(e,t,n){for(var r={},o=t;o!==n&&o!==HTMLElement.prototype;){for(var i,a=Object.getOwnPropertyNames(o),s=0;i=a[s];s++)r[i]||(Object.defineProperty(e,i,Object.getOwnPropertyDescriptor(o,i)),r[i]=1);o=Object.getPrototypeOf(o)}}function i(e){e.createdCallback&&e.createdCallback()}var a=e.flags;e.upgrade=t,e.upgradeWithDefinition=n,e.implementPrototype=r}),window.CustomElements.addModule(function(e){function t(t,r){var c=r||{};if(!t)throw new Error("document.registerElement: first argument `name` must not be empty");if(t.indexOf("-")<0)throw new Error("document.registerElement: first argument ('name') must contain a dash ('-'). Argument provided was '"+String(t)+"'.");if(o(t))throw new Error("Failed to execute 'registerElement' on 'Document': Registration failed for type '"+String(t)+"'. The type name is invalid.");if(d(t))throw new Error("DuplicateDefinitionError: a type with name '"+String(t)+"' is already registered");return c.prototype||(c.prototype=Object.create(HTMLElement.prototype)),c.__name=t.toLowerCase(),c.lifecycle=c.lifecycle||{},c.ancestry=i(c["extends"]),a(c),s(c),n(c.prototype),u(c.__name,c),c.ctor=l(c),c.ctor.prototype=c.prototype,c.prototype.constructor=c.ctor,e.ready&&w(document),c.ctor; !function(){window.WebComponents=window.WebComponents||{flags:{}};var e="webcomponents-lite.js",t=document.querySelector('script[src*="'+e+'"]'),n={};if(!n.noOpts){if(location.search.slice(1).split("&").forEach(function(e){var t,r=e.split("=");r[0]&&(t=r[0].match(/wc-(.+)/))&&(n[t[1]]=r[1]||!0)}),t)for(var r,o=0;r=t.attributes[o];o++)"src"!==r.name&&(n[r.name]=r.value||!0);if(n.log&&n.log.split){var i=n.log.split(",");n.log={},i.forEach(function(e){n.log[e]=!0})}else n.log={}}n.register&&(window.CustomElements=window.CustomElements||{flags:{}},window.CustomElements.flags.register=n.register),WebComponents.flags=n}(),function(e){"use strict";function t(e){return void 0!==h[e]}function n(){s.call(this),this._isInvalid=!0}function r(e){return""==e&&n.call(this),e.toLowerCase()}function o(e){var t=e.charCodeAt(0);return t>32&&127>t&&-1==[34,35,60,62,63,96].indexOf(t)?e:encodeURIComponent(e)}function i(e){var t=e.charCodeAt(0);return t>32&&127>t&&-1==[34,35,60,62,96].indexOf(t)?e:encodeURIComponent(e)}function a(e,a,s){function c(e){g.push(e)}var d=a||"scheme start",u=0,l="",_=!1,w=!1,g=[];e:for(;(e[u-1]!=p||0==u)&&!this._isInvalid;){var b=e[u];switch(d){case"scheme start":if(!b||!m.test(b)){if(a){c("Invalid scheme.");break e}l="",d="no scheme";continue}l+=b.toLowerCase(),d="scheme";break;case"scheme":if(b&&v.test(b))l+=b.toLowerCase();else{if(":"!=b){if(a){if(p==b)break e;c("Code point not allowed in scheme: "+b);break e}l="",u=0,d="no scheme";continue}if(this._scheme=l,l="",a)break e;t(this._scheme)&&(this._isRelative=!0),d="file"==this._scheme?"relative":this._isRelative&&s&&s._scheme==this._scheme?"relative or authority":this._isRelative?"authority first slash":"scheme data"}break;case"scheme data":"?"==b?(this._query="?",d="query"):"#"==b?(this._fragment="#",d="fragment"):p!=b&&" "!=b&&"\n"!=b&&"\r"!=b&&(this._schemeData+=o(b));break;case"no scheme":if(s&&t(s._scheme)){d="relative";continue}c("Missing scheme."),n.call(this);break;case"relative or authority":if("/"!=b||"/"!=e[u+1]){c("Expected /, got: "+b),d="relative";continue}d="authority ignore slashes";break;case"relative":if(this._isRelative=!0,"file"!=this._scheme&&(this._scheme=s._scheme),p==b){this._host=s._host,this._port=s._port,this._path=s._path.slice(),this._query=s._query,this._username=s._username,this._password=s._password;break e}if("/"==b||"\\"==b)"\\"==b&&c("\\ is an invalid code point."),d="relative slash";else if("?"==b)this._host=s._host,this._port=s._port,this._path=s._path.slice(),this._query="?",this._username=s._username,this._password=s._password,d="query";else{if("#"!=b){var y=e[u+1],E=e[u+2];("file"!=this._scheme||!m.test(b)||":"!=y&&"|"!=y||p!=E&&"/"!=E&&"\\"!=E&&"?"!=E&&"#"!=E)&&(this._host=s._host,this._port=s._port,this._username=s._username,this._password=s._password,this._path=s._path.slice(),this._path.pop()),d="relative path";continue}this._host=s._host,this._port=s._port,this._path=s._path.slice(),this._query=s._query,this._fragment="#",this._username=s._username,this._password=s._password,d="fragment"}break;case"relative slash":if("/"!=b&&"\\"!=b){"file"!=this._scheme&&(this._host=s._host,this._port=s._port,this._username=s._username,this._password=s._password),d="relative path";continue}"\\"==b&&c("\\ is an invalid code point."),d="file"==this._scheme?"file host":"authority ignore slashes";break;case"authority first slash":if("/"!=b){c("Expected '/', got: "+b),d="authority ignore slashes";continue}d="authority second slash";break;case"authority second slash":if(d="authority ignore slashes","/"!=b){c("Expected '/', got: "+b);continue}break;case"authority ignore slashes":if("/"!=b&&"\\"!=b){d="authority";continue}c("Expected authority, got: "+b);break;case"authority":if("@"==b){_&&(c("@ already seen."),l+="%40"),_=!0;for(var L=0;L<l.length;L++){var T=l[L];if(" "!=T&&"\n"!=T&&"\r"!=T)if(":"!=T||null!==this._password){var M=o(T);null!==this._password?this._password+=M:this._username+=M}else this._password="";else c("Invalid whitespace in authority.")}l=""}else{if(p==b||"/"==b||"\\"==b||"?"==b||"#"==b){u-=l.length,l="",d="host";continue}l+=b}break;case"file host":if(p==b||"/"==b||"\\"==b||"?"==b||"#"==b){2!=l.length||!m.test(l[0])||":"!=l[1]&&"|"!=l[1]?0==l.length?d="relative path start":(this._host=r.call(this,l),l="",d="relative path start"):d="relative path";continue}" "==b||"\n"==b||"\r"==b?c("Invalid whitespace in file host."):l+=b;break;case"host":case"hostname":if(":"!=b||w){if(p==b||"/"==b||"\\"==b||"?"==b||"#"==b){if(this._host=r.call(this,l),l="",d="relative path start",a)break e;continue}" "!=b&&"\n"!=b&&"\r"!=b?("["==b?w=!0:"]"==b&&(w=!1),l+=b):c("Invalid code point in host/hostname: "+b)}else if(this._host=r.call(this,l),l="",d="port","hostname"==a)break e;break;case"port":if(/[0-9]/.test(b))l+=b;else{if(p==b||"/"==b||"\\"==b||"?"==b||"#"==b||a){if(""!=l){var N=parseInt(l,10);N!=h[this._scheme]&&(this._port=N+""),l=""}if(a)break e;d="relative path start";continue}" "==b||"\n"==b||"\r"==b?c("Invalid code point in port: "+b):n.call(this)}break;case"relative path start":if("\\"==b&&c("'\\' not allowed in path."),d="relative path","/"!=b&&"\\"!=b)continue;break;case"relative path":if(p!=b&&"/"!=b&&"\\"!=b&&(a||"?"!=b&&"#"!=b))" "!=b&&"\n"!=b&&"\r"!=b&&(l+=o(b));else{"\\"==b&&c("\\ not allowed in relative path.");var O;(O=f[l.toLowerCase()])&&(l=O),".."==l?(this._path.pop(),"/"!=b&&"\\"!=b&&this._path.push("")):"."==l&&"/"!=b&&"\\"!=b?this._path.push(""):"."!=l&&("file"==this._scheme&&0==this._path.length&&2==l.length&&m.test(l[0])&&"|"==l[1]&&(l=l[0]+":"),this._path.push(l)),l="","?"==b?(this._query="?",d="query"):"#"==b&&(this._fragment="#",d="fragment")}break;case"query":a||"#"!=b?p!=b&&" "!=b&&"\n"!=b&&"\r"!=b&&(this._query+=i(b)):(this._fragment="#",d="fragment");break;case"fragment":p!=b&&" "!=b&&"\n"!=b&&"\r"!=b&&(this._fragment+=b)}u++}}function s(){this._scheme="",this._schemeData="",this._username="",this._password=null,this._host="",this._port="",this._path=[],this._query="",this._fragment="",this._isInvalid=!1,this._isRelative=!1}function c(e,t){void 0===t||t instanceof c||(t=new c(String(t))),this._url=e,s.call(this);var n=e.replace(/^[ \t\r\n\f]+|[ \t\r\n\f]+$/g,"");a.call(this,n,null,t)}var d=!1;if(!e.forceJURL)try{var u=new URL("b","http://a");u.pathname="c%20d",d="http://a/c%20d"===u.href}catch(l){}if(!d){var h=Object.create(null);h.ftp=21,h.file=0,h.gopher=70,h.http=80,h.https=443,h.ws=80,h.wss=443;var f=Object.create(null);f["%2e"]=".",f[".%2e"]="..",f["%2e."]="..",f["%2e%2e"]="..";var p=void 0,m=/[a-zA-Z]/,v=/[a-zA-Z0-9\+\-\.]/;c.prototype={toString:function(){return this.href},get href(){if(this._isInvalid)return this._url;var e="";return(""!=this._username||null!=this._password)&&(e=this._username+(null!=this._password?":"+this._password:"")+"@"),this.protocol+(this._isRelative?"//"+e+this.host:"")+this.pathname+this._query+this._fragment},set href(e){s.call(this),a.call(this,e)},get protocol(){return this._scheme+":"},set protocol(e){this._isInvalid||a.call(this,e+":","scheme start")},get host(){return this._isInvalid?"":this._port?this._host+":"+this._port:this._host},set host(e){!this._isInvalid&&this._isRelative&&a.call(this,e,"host")},get hostname(){return this._host},set hostname(e){!this._isInvalid&&this._isRelative&&a.call(this,e,"hostname")},get port(){return this._port},set port(e){!this._isInvalid&&this._isRelative&&a.call(this,e,"port")},get pathname(){return this._isInvalid?"":this._isRelative?"/"+this._path.join("/"):this._schemeData},set pathname(e){!this._isInvalid&&this._isRelative&&(this._path=[],a.call(this,e,"relative path start"))},get search(){return this._isInvalid||!this._query||"?"==this._query?"":this._query},set search(e){!this._isInvalid&&this._isRelative&&(this._query="?","?"==e[0]&&(e=e.slice(1)),a.call(this,e,"query"))},get hash(){return this._isInvalid||!this._fragment||"#"==this._fragment?"":this._fragment},set hash(e){this._isInvalid||(this._fragment="#","#"==e[0]&&(e=e.slice(1)),a.call(this,e,"fragment"))},get origin(){var e;if(this._isInvalid||!this._scheme)return"";switch(this._scheme){case"data":case"file":case"javascript":case"mailto":return"null"}return e=this.host,e?this._scheme+"://"+e:""}};var _=e.URL;_&&(c.createObjectURL=function(e){return _.createObjectURL.apply(_,arguments)},c.revokeObjectURL=function(e){_.revokeObjectURL(e)}),e.URL=c}}(self),"undefined"==typeof WeakMap&&!function(){var e=Object.defineProperty,t=Date.now()%1e9,n=function(){this.name="__st"+(1e9*Math.random()>>>0)+(t++ +"__")};n.prototype={set:function(t,n){var r=t[this.name];return r&&r[0]===t?r[1]=n:e(t,this.name,{value:[t,n],writable:!0}),this},get:function(e){var t;return(t=e[this.name])&&t[0]===e?t[1]:void 0},"delete":function(e){var t=e[this.name];return t&&t[0]===e?(t[0]=t[1]=void 0,!0):!1},has:function(e){var t=e[this.name];return t?t[0]===e:!1}},window.WeakMap=n}(),function(e){function t(e){b.push(e),g||(g=!0,m(r))}function n(e){return window.ShadowDOMPolyfill&&window.ShadowDOMPolyfill.wrapIfNeeded(e)||e}function r(){g=!1;var e=b;b=[],e.sort(function(e,t){return e.uid_-t.uid_});var t=!1;e.forEach(function(e){var n=e.takeRecords();o(e),n.length&&(e.callback_(n,e),t=!0)}),t&&r()}function o(e){e.nodes_.forEach(function(t){var n=v.get(t);n&&n.forEach(function(t){t.observer===e&&t.removeTransientObservers()})})}function i(e,t){for(var n=e;n;n=n.parentNode){var r=v.get(n);if(r)for(var o=0;o<r.length;o++){var i=r[o],a=i.options;if(n===e||a.subtree){var s=t(a);s&&i.enqueue(s)}}}}function a(e){this.callback_=e,this.nodes_=[],this.records_=[],this.uid_=++y}function s(e,t){this.type=e,this.target=t,this.addedNodes=[],this.removedNodes=[],this.previousSibling=null,this.nextSibling=null,this.attributeName=null,this.attributeNamespace=null,this.oldValue=null}function c(e){var t=new s(e.type,e.target);return t.addedNodes=e.addedNodes.slice(),t.removedNodes=e.removedNodes.slice(),t.previousSibling=e.previousSibling,t.nextSibling=e.nextSibling,t.attributeName=e.attributeName,t.attributeNamespace=e.attributeNamespace,t.oldValue=e.oldValue,t}function d(e,t){return E=new s(e,t)}function u(e){return L?L:(L=c(E),L.oldValue=e,L)}function l(){E=L=void 0}function h(e){return e===L||e===E}function f(e,t){return e===t?e:L&&h(e)?L:null}function p(e,t,n){this.observer=e,this.target=t,this.options=n,this.transientObservedNodes=[]}if(!e.JsMutationObserver){var m,v=new WeakMap;if(/Trident|Edge/.test(navigator.userAgent))m=setTimeout;else if(window.setImmediate)m=window.setImmediate;else{var _=[],w=String(Math.random());window.addEventListener("message",function(e){if(e.data===w){var t=_;_=[],t.forEach(function(e){e()})}}),m=function(e){_.push(e),window.postMessage(w,"*")}}var g=!1,b=[],y=0;a.prototype={observe:function(e,t){if(e=n(e),!t.childList&&!t.attributes&&!t.characterData||t.attributeOldValue&&!t.attributes||t.attributeFilter&&t.attributeFilter.length&&!t.attributes||t.characterDataOldValue&&!t.characterData)throw new SyntaxError;var r=v.get(e);r||v.set(e,r=[]);for(var o,i=0;i<r.length;i++)if(r[i].observer===this){o=r[i],o.removeListeners(),o.options=t;break}o||(o=new p(this,e,t),r.push(o),this.nodes_.push(e)),o.addListeners()},disconnect:function(){this.nodes_.forEach(function(e){for(var t=v.get(e),n=0;n<t.length;n++){var r=t[n];if(r.observer===this){r.removeListeners(),t.splice(n,1);break}}},this),this.records_=[]},takeRecords:function(){var e=this.records_;return this.records_=[],e}};var E,L;p.prototype={enqueue:function(e){var n=this.observer.records_,r=n.length;if(n.length>0){var o=n[r-1],i=f(o,e);if(i)return void(n[r-1]=i)}else t(this.observer);n[r]=e},addListeners:function(){this.addListeners_(this.target)},addListeners_:function(e){var t=this.options;t.attributes&&e.addEventListener("DOMAttrModified",this,!0),t.characterData&&e.addEventListener("DOMCharacterDataModified",this,!0),t.childList&&e.addEventListener("DOMNodeInserted",this,!0),(t.childList||t.subtree)&&e.addEventListener("DOMNodeRemoved",this,!0)},removeListeners:function(){this.removeListeners_(this.target)},removeListeners_:function(e){var t=this.options;t.attributes&&e.removeEventListener("DOMAttrModified",this,!0),t.characterData&&e.removeEventListener("DOMCharacterDataModified",this,!0),t.childList&&e.removeEventListener("DOMNodeInserted",this,!0),(t.childList||t.subtree)&&e.removeEventListener("DOMNodeRemoved",this,!0)},addTransientObserver:function(e){if(e!==this.target){this.addListeners_(e),this.transientObservedNodes.push(e);var t=v.get(e);t||v.set(e,t=[]),t.push(this)}},removeTransientObservers:function(){var e=this.transientObservedNodes;this.transientObservedNodes=[],e.forEach(function(e){this.removeListeners_(e);for(var t=v.get(e),n=0;n<t.length;n++)if(t[n]===this){t.splice(n,1);break}},this)},handleEvent:function(e){switch(e.stopImmediatePropagation(),e.type){case"DOMAttrModified":var t=e.attrName,n=e.relatedNode.namespaceURI,r=e.target,o=new d("attributes",r);o.attributeName=t,o.attributeNamespace=n;var a=e.attrChange===MutationEvent.ADDITION?null:e.prevValue;i(r,function(e){return!e.attributes||e.attributeFilter&&e.attributeFilter.length&&-1===e.attributeFilter.indexOf(t)&&-1===e.attributeFilter.indexOf(n)?void 0:e.attributeOldValue?u(a):o});break;case"DOMCharacterDataModified":var r=e.target,o=d("characterData",r),a=e.prevValue;i(r,function(e){return e.characterData?e.characterDataOldValue?u(a):o:void 0});break;case"DOMNodeRemoved":this.addTransientObserver(e.target);case"DOMNodeInserted":var s,c,h=e.target;"DOMNodeInserted"===e.type?(s=[h],c=[]):(s=[],c=[h]);var f=h.previousSibling,p=h.nextSibling,o=d("childList",e.target.parentNode);o.addedNodes=s,o.removedNodes=c,o.previousSibling=f,o.nextSibling=p,i(e.relatedNode,function(e){return e.childList?o:void 0})}l()}},e.JsMutationObserver=a,e.MutationObserver||(e.MutationObserver=a,a._isPolyfilled=!0)}}(self),"undefined"==typeof HTMLTemplateElement&&!function(){function e(e){switch(e){case"&":return"&amp;";case"<":return"&lt;";case">":return"&gt;";case" ":return"&nbsp;"}}function t(t){return t.replace(a,e)}var n="template",r=document.implementation.createHTMLDocument("template"),o=!0;HTMLTemplateElement=function(){},HTMLTemplateElement.prototype=Object.create(HTMLElement.prototype),HTMLTemplateElement.decorate=function(e){e.content||(e.content=r.createDocumentFragment());for(var n;n=e.firstChild;)e.content.appendChild(n);if(o)try{Object.defineProperty(e,"innerHTML",{get:function(){for(var e="",n=this.content.firstChild;n;n=n.nextSibling)e+=n.outerHTML||t(n.data);return e},set:function(e){for(r.body.innerHTML=e,HTMLTemplateElement.bootstrap(r);this.content.firstChild;)this.content.removeChild(this.content.firstChild);for(;r.body.firstChild;)this.content.appendChild(r.body.firstChild)},configurable:!0})}catch(i){o=!1}},HTMLTemplateElement.bootstrap=function(e){for(var t,r=e.querySelectorAll(n),o=0,i=r.length;i>o&&(t=r[o]);o++)HTMLTemplateElement.decorate(t)},document.addEventListener("DOMContentLoaded",function(){HTMLTemplateElement.bootstrap(document)});var i=document.createElement;document.createElement=function(){"use strict";var e=i.apply(document,arguments);return"template"==e.localName&&HTMLTemplateElement.decorate(e),e};var a=/[&\u00A0<>]/g}(),function(e){"use strict";if(!window.performance){var t=Date.now();window.performance={now:function(){return Date.now()-t}}}window.requestAnimationFrame||(window.requestAnimationFrame=function(){var e=window.webkitRequestAnimationFrame||window.mozRequestAnimationFrame;return e?function(t){return e(function(){t(performance.now())})}:function(e){return window.setTimeout(e,1e3/60)}}()),window.cancelAnimationFrame||(window.cancelAnimationFrame=function(){return window.webkitCancelAnimationFrame||window.mozCancelAnimationFrame||function(e){clearTimeout(e)}}());var n=function(){var e=document.createEvent("Event");return e.initEvent("foo",!0,!0),e.preventDefault(),e.defaultPrevented}();if(!n){var r=Event.prototype.preventDefault;Event.prototype.preventDefault=function(){this.cancelable&&(r.call(this),Object.defineProperty(this,"defaultPrevented",{get:function(){return!0}}))}}var o=/Trident/.test(navigator.userAgent);if((!window.CustomEvent||o&&"function"!=typeof window.CustomEvent)&&(window.CustomEvent=function(e,t){t=t||{};var n=document.createEvent("CustomEvent");return n.initCustomEvent(e,Boolean(t.bubbles),Boolean(t.cancelable),t.detail),n},window.CustomEvent.prototype=window.Event.prototype),!window.Event||o&&"function"!=typeof window.Event){var i=window.Event;window.Event=function(e,t){t=t||{};var n=document.createEvent("Event");return n.initEvent(e,Boolean(t.bubbles),Boolean(t.cancelable)),n},window.Event.prototype=i.prototype}}(window.WebComponents),window.HTMLImports=window.HTMLImports||{flags:{}},function(e){function t(e,t){t=t||p,r(function(){i(e,t)},t)}function n(e){return"complete"===e.readyState||e.readyState===_}function r(e,t){if(n(t))e&&e();else{var o=function(){("complete"===t.readyState||t.readyState===_)&&(t.removeEventListener(w,o),r(e,t))};t.addEventListener(w,o)}}function o(e){e.target.__loaded=!0}function i(e,t){function n(){c==d&&e&&e({allImports:s,loadedImports:u,errorImports:l})}function r(e){o(e),u.push(this),c++,n()}function i(e){l.push(this),c++,n()}var s=t.querySelectorAll("link[rel=import]"),c=0,d=s.length,u=[],l=[];if(d)for(var h,f=0;d>f&&(h=s[f]);f++)a(h)?(c++,n()):(h.addEventListener("load",r),h.addEventListener("error",i));else n()}function a(e){return l?e.__loaded||e["import"]&&"loading"!==e["import"].readyState:e.__importParsed}function s(e){for(var t,n=0,r=e.length;r>n&&(t=e[n]);n++)c(t)&&d(t)}function c(e){return"link"===e.localName&&"import"===e.rel}function d(e){var t=e["import"];t?o({target:e}):(e.addEventListener("load",o),e.addEventListener("error",o))}var u="import",l=Boolean(u in document.createElement("link")),h=Boolean(window.ShadowDOMPolyfill),f=function(e){return h?window.ShadowDOMPolyfill.wrapIfNeeded(e):e},p=f(document),m={get:function(){var e=window.HTMLImports.currentScript||document.currentScript||("complete"!==document.readyState?document.scripts[document.scripts.length-1]:null);return f(e)},configurable:!0};Object.defineProperty(document,"_currentScript",m),Object.defineProperty(p,"_currentScript",m);var v=/Trident/.test(navigator.userAgent),_=v?"complete":"interactive",w="readystatechange";l&&(new MutationObserver(function(e){for(var t,n=0,r=e.length;r>n&&(t=e[n]);n++)t.addedNodes&&s(t.addedNodes)}).observe(document.head,{childList:!0}),function(){if("loading"===document.readyState)for(var e,t=document.querySelectorAll("link[rel=import]"),n=0,r=t.length;r>n&&(e=t[n]);n++)d(e)}()),t(function(e){window.HTMLImports.ready=!0,window.HTMLImports.readyTime=(new Date).getTime();var t=p.createEvent("CustomEvent");t.initCustomEvent("HTMLImportsLoaded",!0,!0,e),p.dispatchEvent(t)}),e.IMPORT_LINK_TYPE=u,e.useNative=l,e.rootDocument=p,e.whenReady=t,e.isIE=v}(window.HTMLImports),function(e){var t=[],n=function(e){t.push(e)},r=function(){t.forEach(function(t){t(e)})};e.addModule=n,e.initializeModules=r}(window.HTMLImports),window.HTMLImports.addModule(function(e){var t=/(url\()([^)]*)(\))/g,n=/(@import[\s]+(?!url\())([^;]*)(;)/g,r={resolveUrlsInStyle:function(e,t){var n=e.ownerDocument,r=n.createElement("a");return e.textContent=this.resolveUrlsInCssText(e.textContent,t,r),e},resolveUrlsInCssText:function(e,r,o){var i=this.replaceUrls(e,o,r,t);return i=this.replaceUrls(i,o,r,n)},replaceUrls:function(e,t,n,r){return e.replace(r,function(e,r,o,i){var a=o.replace(/["']/g,"");return n&&(a=new URL(a,n).href),t.href=a,a=t.href,r+"'"+a+"'"+i})}};e.path=r}),window.HTMLImports.addModule(function(e){var t={async:!0,ok:function(e){return e.status>=200&&e.status<300||304===e.status||0===e.status},load:function(n,r,o){var i=new XMLHttpRequest;return(e.flags.debug||e.flags.bust)&&(n+="?"+Math.random()),i.open("GET",n,t.async),i.addEventListener("readystatechange",function(e){if(4===i.readyState){var n=null;try{var a=i.getResponseHeader("Location");a&&(n="/"===a.substr(0,1)?location.origin+a:a)}catch(e){console.error(e.message)}r.call(o,!t.ok(i)&&i,i.response||i.responseText,n)}}),i.send(),i},loadDocument:function(e,t,n){this.load(e,t,n).responseType="document"}};e.xhr=t}),window.HTMLImports.addModule(function(e){var t=e.xhr,n=e.flags,r=function(e,t){this.cache={},this.onload=e,this.oncomplete=t,this.inflight=0,this.pending={}};r.prototype={addNodes:function(e){this.inflight+=e.length;for(var t,n=0,r=e.length;r>n&&(t=e[n]);n++)this.require(t);this.checkDone()},addNode:function(e){this.inflight++,this.require(e),this.checkDone()},require:function(e){var t=e.src||e.href;e.__nodeUrl=t,this.dedupe(t,e)||this.fetch(t,e)},dedupe:function(e,t){if(this.pending[e])return this.pending[e].push(t),!0;return this.cache[e]?(this.onload(e,t,this.cache[e]),this.tail(),!0):(this.pending[e]=[t],!1)},fetch:function(e,r){if(n.load&&console.log("fetch",e,r),e)if(e.match(/^data:/)){var o=e.split(","),i=o[0],a=o[1];a=i.indexOf(";base64")>-1?atob(a):decodeURIComponent(a),setTimeout(function(){this.receive(e,r,null,a)}.bind(this),0)}else{var s=function(t,n,o){this.receive(e,r,t,n,o)}.bind(this);t.load(e,s)}else setTimeout(function(){this.receive(e,r,{error:"href must be specified"},null)}.bind(this),0)},receive:function(e,t,n,r,o){this.cache[e]=r;for(var i,a=this.pending[e],s=0,c=a.length;c>s&&(i=a[s]);s++)this.onload(e,i,r,n,o),this.tail();this.pending[e]=null},tail:function(){--this.inflight,this.checkDone()},checkDone:function(){this.inflight||this.oncomplete()}},e.Loader=r}),window.HTMLImports.addModule(function(e){var t=function(e){this.addCallback=e,this.mo=new MutationObserver(this.handler.bind(this))};t.prototype={handler:function(e){for(var t,n=0,r=e.length;r>n&&(t=e[n]);n++)"childList"===t.type&&t.addedNodes.length&&this.addedNodes(t.addedNodes)},addedNodes:function(e){this.addCallback&&this.addCallback(e);for(var t,n=0,r=e.length;r>n&&(t=e[n]);n++)t.children&&t.children.length&&this.addedNodes(t.children)},observe:function(e){this.mo.observe(e,{childList:!0,subtree:!0})}},e.Observer=t}),window.HTMLImports.addModule(function(e){function t(e){return"link"===e.localName&&e.rel===u}function n(e){var t=r(e);return"data:text/javascript;charset=utf-8,"+encodeURIComponent(t)}function r(e){return e.textContent+o(e)}function o(e){var t=e.ownerDocument;t.__importedScripts=t.__importedScripts||0;var n=e.ownerDocument.baseURI,r=t.__importedScripts?"-"+t.__importedScripts:"";return t.__importedScripts++,"\n//# sourceURL="+n+r+".js\n"}function i(e){var t=e.ownerDocument.createElement("style");return t.textContent=e.textContent,a.resolveUrlsInStyle(t),t}var a=e.path,s=e.rootDocument,c=e.flags,d=e.isIE,u=e.IMPORT_LINK_TYPE,l="link[rel="+u+"]",h={documentSelectors:l,importsSelectors:[l,"link[rel=stylesheet]:not([type])","style:not([type])","script:not([type])",'script[type="application/javascript"]','script[type="text/javascript"]'].join(","),map:{link:"parseLink",script:"parseScript",style:"parseStyle"},dynamicElements:[],parseNext:function(){var e=this.nextToParse();e&&this.parse(e)},parse:function(e){if(this.isParsed(e))return void(c.parse&&console.log("[%s] is already parsed",e.localName));var t=this[this.map[e.localName]];t&&(this.markParsing(e),t.call(this,e))},parseDynamic:function(e,t){this.dynamicElements.push(e),t||this.parseNext()},markParsing:function(e){c.parse&&console.log("parsing",e),this.parsingElement=e},markParsingComplete:function(e){e.__importParsed=!0,this.markDynamicParsingComplete(e),e.__importElement&&(e.__importElement.__importParsed=!0,this.markDynamicParsingComplete(e.__importElement)),this.parsingElement=null,c.parse&&console.log("completed",e)},markDynamicParsingComplete:function(e){var t=this.dynamicElements.indexOf(e);t>=0&&this.dynamicElements.splice(t,1)},parseImport:function(e){if(e["import"]=e.__doc,window.HTMLImports.__importsParsingHook&&window.HTMLImports.__importsParsingHook(e),e["import"]&&(e["import"].__importParsed=!0),this.markParsingComplete(e),e.__resource&&!e.__error?e.dispatchEvent(new CustomEvent("load",{bubbles:!1})):e.dispatchEvent(new CustomEvent("error",{bubbles:!1})),e.__pending)for(var t;e.__pending.length;)t=e.__pending.shift(),t&&t({target:e});this.parseNext()},parseLink:function(e){t(e)?this.parseImport(e):(e.href=e.href,this.parseGeneric(e))},parseStyle:function(e){var t=e;e=i(e),t.__appliedElement=e,e.__importElement=t,this.parseGeneric(e)},parseGeneric:function(e){this.trackElement(e),this.addElementToDocument(e)},rootImportForElement:function(e){for(var t=e;t.ownerDocument.__importLink;)t=t.ownerDocument.__importLink;return t},addElementToDocument:function(e){var t=this.rootImportForElement(e.__importElement||e);t.parentNode.insertBefore(e,t)},trackElement:function(e,t){var n=this,r=function(o){e.removeEventListener("load",r),e.removeEventListener("error",r),t&&t(o),n.markParsingComplete(e),n.parseNext()};if(e.addEventListener("load",r),e.addEventListener("error",r),d&&"style"===e.localName){var o=!1;if(-1==e.textContent.indexOf("@import"))o=!0;else if(e.sheet){o=!0;for(var i,a=e.sheet.cssRules,s=a?a.length:0,c=0;s>c&&(i=a[c]);c++)i.type===CSSRule.IMPORT_RULE&&(o=o&&Boolean(i.styleSheet))}o&&setTimeout(function(){e.dispatchEvent(new CustomEvent("load",{bubbles:!1}))})}},parseScript:function(t){var r=document.createElement("script");r.__importElement=t,r.src=t.src?t.src:n(t),e.currentScript=t,this.trackElement(r,function(t){r.parentNode&&r.parentNode.removeChild(r),e.currentScript=null}),this.addElementToDocument(r)},nextToParse:function(){return this._mayParse=[],!this.parsingElement&&(this.nextToParseInDoc(s)||this.nextToParseDynamic())},nextToParseInDoc:function(e,n){if(e&&this._mayParse.indexOf(e)<0){this._mayParse.push(e);for(var r,o=e.querySelectorAll(this.parseSelectorsForNode(e)),i=0,a=o.length;a>i&&(r=o[i]);i++)if(!this.isParsed(r))return this.hasResource(r)?t(r)?this.nextToParseInDoc(r.__doc,r):r:void 0}return n},nextToParseDynamic:function(){return this.dynamicElements[0]},parseSelectorsForNode:function(e){var t=e.ownerDocument||e;return t===s?this.documentSelectors:this.importsSelectors},isParsed:function(e){return e.__importParsed},needsDynamicParsing:function(e){return this.dynamicElements.indexOf(e)>=0},hasResource:function(e){return t(e)&&void 0===e.__doc?!1:!0}};e.parser=h,e.IMPORT_SELECTOR=l}),window.HTMLImports.addModule(function(e){function t(e){return n(e,a)}function n(e,t){return"link"===e.localName&&e.getAttribute("rel")===t}function r(e){return!!Object.getOwnPropertyDescriptor(e,"baseURI")}function o(e,t){var n=document.implementation.createHTMLDocument(a);n._URL=t;var o=n.createElement("base");o.setAttribute("href",t),n.baseURI||r(n)||Object.defineProperty(n,"baseURI",{value:t});var i=n.createElement("meta");return i.setAttribute("charset","utf-8"),n.head.appendChild(i),n.head.appendChild(o),n.body.innerHTML=e,window.HTMLTemplateElement&&HTMLTemplateElement.bootstrap&&HTMLTemplateElement.bootstrap(n),n}var i=e.flags,a=e.IMPORT_LINK_TYPE,s=e.IMPORT_SELECTOR,c=e.rootDocument,d=e.Loader,u=e.Observer,l=e.parser,h={documents:{},documentPreloadSelectors:s,importsPreloadSelectors:[s].join(","),loadNode:function(e){f.addNode(e)},loadSubtree:function(e){var t=this.marshalNodes(e);f.addNodes(t)},marshalNodes:function(e){return e.querySelectorAll(this.loadSelectorsForNode(e))},loadSelectorsForNode:function(e){var t=e.ownerDocument||e;return t===c?this.documentPreloadSelectors:this.importsPreloadSelectors},loaded:function(e,n,r,a,s){if(i.load&&console.log("loaded",e,n),n.__resource=r,n.__error=a,t(n)){var c=this.documents[e];void 0===c&&(c=a?null:o(r,s||e),c&&(c.__importLink=n,this.bootDocument(c)),this.documents[e]=c),n.__doc=c}l.parseNext()},bootDocument:function(e){this.loadSubtree(e),this.observer.observe(e),l.parseNext()},loadedAll:function(){l.parseNext()}},f=new d(h.loaded.bind(h),h.loadedAll.bind(h));if(h.observer=new u,!document.baseURI){var p={get:function(){var e=document.querySelector("base");return e?e.href:window.location.href},configurable:!0};Object.defineProperty(document,"baseURI",p),Object.defineProperty(c,"baseURI",p)}e.importer=h,e.importLoader=f}),window.HTMLImports.addModule(function(e){var t=e.parser,n=e.importer,r={added:function(e){for(var r,o,i,a,s=0,c=e.length;c>s&&(a=e[s]);s++)r||(r=a.ownerDocument,o=t.isParsed(r)),i=this.shouldLoadNode(a),i&&n.loadNode(a),this.shouldParseNode(a)&&o&&t.parseDynamic(a,i)},shouldLoadNode:function(e){return 1===e.nodeType&&o.call(e,n.loadSelectorsForNode(e))},shouldParseNode:function(e){return 1===e.nodeType&&o.call(e,t.parseSelectorsForNode(e))}};n.observer.addCallback=r.added.bind(r);var o=HTMLElement.prototype.matches||HTMLElement.prototype.matchesSelector||HTMLElement.prototype.webkitMatchesSelector||HTMLElement.prototype.mozMatchesSelector||HTMLElement.prototype.msMatchesSelector}),function(e){function t(){window.HTMLImports.importer.bootDocument(r)}var n=e.initializeModules;e.isIE;if(!e.useNative){n();var r=e.rootDocument;"complete"===document.readyState||"interactive"===document.readyState&&!window.attachEvent?t():document.addEventListener("DOMContentLoaded",t)}}(window.HTMLImports),window.CustomElements=window.CustomElements||{flags:{}},function(e){var t=e.flags,n=[],r=function(e){n.push(e)},o=function(){n.forEach(function(t){t(e)})};e.addModule=r,e.initializeModules=o,e.hasNative=Boolean(document.registerElement),e.isIE=/Trident/.test(navigator.userAgent),e.useNative=!t.register&&e.hasNative&&!window.ShadowDOMPolyfill&&(!window.HTMLImports||window.HTMLImports.useNative)}(window.CustomElements),window.CustomElements.addModule(function(e){function t(e,t){n(e,function(e){return t(e)?!0:void r(e,t)}),r(e,t)}function n(e,t,r){var o=e.firstElementChild;if(!o)for(o=e.firstChild;o&&o.nodeType!==Node.ELEMENT_NODE;)o=o.nextSibling;for(;o;)t(o,r)!==!0&&n(o,t,r),o=o.nextElementSibling;return null}function r(e,n){for(var r=e.shadowRoot;r;)t(r,n),r=r.olderShadowRoot}function o(e,t){i(e,t,[])}function i(e,t,n){if(e=window.wrap(e),!(n.indexOf(e)>=0)){n.push(e);for(var r,o=e.querySelectorAll("link[rel="+a+"]"),s=0,c=o.length;c>s&&(r=o[s]);s++)r["import"]&&i(r["import"],t,n);t(e)}}var a=window.HTMLImports?window.HTMLImports.IMPORT_LINK_TYPE:"none";e.forDocumentTree=o,e.forSubtree=t}),window.CustomElements.addModule(function(e){function t(e,t){return n(e,t)||r(e,t)}function n(t,n){return e.upgrade(t,n)?!0:void(n&&a(t))}function r(e,t){b(e,function(e){return n(e,t)?!0:void 0})}function o(e){T.push(e),L||(L=!0,setTimeout(i))}function i(){L=!1;for(var e,t=T,n=0,r=t.length;r>n&&(e=t[n]);n++)e();T=[]}function a(e){E?o(function(){s(e)}):s(e)}function s(e){e.__upgraded__&&!e.__attached&&(e.__attached=!0,e.attachedCallback&&e.attachedCallback())}function c(e){d(e),b(e,function(e){d(e)})}function d(e){E?o(function(){u(e)}):u(e)}function u(e){e.__upgraded__&&e.__attached&&(e.__attached=!1,e.detachedCallback&&e.detachedCallback())}function l(e){for(var t=e,n=window.wrap(document);t;){if(t==n)return!0;t=t.parentNode||t.nodeType===Node.DOCUMENT_FRAGMENT_NODE&&t.host}}function h(e){if(e.shadowRoot&&!e.shadowRoot.__watched){g.dom&&console.log("watching shadow-root for: ",e.localName);for(var t=e.shadowRoot;t;)m(t),t=t.olderShadowRoot}}function f(e,n){if(g.dom){var r=n[0];if(r&&"childList"===r.type&&r.addedNodes&&r.addedNodes){for(var o=r.addedNodes[0];o&&o!==document&&!o.host;)o=o.parentNode;var i=o&&(o.URL||o._URL||o.host&&o.host.localName)||"";i=i.split("/?").shift().split("/").pop()}console.group("mutations (%d) [%s]",n.length,i||"")}var a=l(e);n.forEach(function(e){"childList"===e.type&&(M(e.addedNodes,function(e){e.localName&&t(e,a)}),M(e.removedNodes,function(e){e.localName&&c(e)}))}),g.dom&&console.groupEnd()}function p(e){for(e=window.wrap(e),e||(e=window.wrap(document));e.parentNode;)e=e.parentNode;var t=e.__observer;t&&(f(e,t.takeRecords()),i())}function m(e){if(!e.__observer){var t=new MutationObserver(f.bind(this,e));t.observe(e,{childList:!0,subtree:!0}),e.__observer=t}}function v(e){e=window.wrap(e),g.dom&&console.group("upgradeDocument: ",e.baseURI.split("/").pop());var n=e===window.wrap(document);
}function n(e){if(!e.setAttribute._polyfilled){var t=e.setAttribute;e.setAttribute=function(e,n){r.call(this,e,n,t)};var n=e.removeAttribute;e.removeAttribute=function(e){r.call(this,e,null,n)},e.setAttribute._polyfilled=!0}}function r(e,t,n){e=e.toLowerCase();var r=this.getAttribute(e);n.apply(this,arguments);var o=this.getAttribute(e);this.attributeChangedCallback&&o!==r&&this.attributeChangedCallback(e,r,o)}function o(e){for(var t=0;t<E.length;t++)if(e===E[t])return!0}function i(e){var t=d(e);return t?i(t["extends"]).concat([t]):[]}function a(e){for(var t,n=e["extends"],r=0;t=e.ancestry[r];r++)n=t.is&&t.tag;e.tag=n||e.__name,n&&(e.is=e.__name)}function s(e){if(!Object.__proto__){var t=HTMLElement.prototype;if(e.is){var n=document.createElement(e.tag);t=Object.getPrototypeOf(n)}for(var r,o=e.prototype,i=!1;o;)o==t&&(i=!0),r=Object.getPrototypeOf(o),r&&(o.__proto__=r),o=r;i||console.warn(e.tag+" prototype not found in prototype chain for "+e.is),e["native"]=t}}function c(e){return g(T(e.tag),e)}function d(e){return e?L[e.toLowerCase()]:void 0}function u(e,t){L[e]=t}function l(e){return function(){return c(e)}}function h(e,t,n){return e===M?f(t,n):N(e,t)}function f(e,t){e&&(e=e.toLowerCase()),t&&(t=t.toLowerCase());var n=d(t||e);if(n){if(e==n.tag&&t==n.is)return new n.ctor;if(!t&&!n.is)return new n.ctor}var r;return t?(r=f(e),r.setAttribute("is",t),r):(r=T(e),e.indexOf("-")>=0&&b(r,HTMLElement),r)}function p(e,t){var n=e[t];e[t]=function(){var e=n.apply(this,arguments);return _(e),e}}var m,v=e.isIE,w=e.upgradeDocumentTree,_=e.upgradeAll,g=e.upgradeWithDefinition,b=e.implementPrototype,y=e.useNative,E=["annotation-xml","color-profile","font-face","font-face-src","font-face-uri","font-face-format","font-face-name","missing-glyph"],L={},M="http://www.w3.org/1999/xhtml",T=document.createElement.bind(document),N=document.createElementNS.bind(document);m=Object.__proto__||y?function(e,t){return e instanceof t}:function(e,t){if(e instanceof t)return!0;for(var n=e;n;){if(n===t.prototype)return!0;n=n.__proto__}return!1},p(Node.prototype,"cloneNode"),p(document,"importNode"),v&&!function(){var e=document.importNode;document.importNode=function(){var t=e.apply(document,arguments);if(t.nodeType==t.DOCUMENT_FRAGMENT_NODE){var n=document.createDocumentFragment();return n.appendChild(t),n}return t}}(),document.registerElement=t,document.createElement=f,document.createElementNS=h,e.registry=L,e["instanceof"]=m,e.reservedTagList=E,e.getRegisteredDefinition=d,document.register=document.registerElement}),function(e){function t(){a(window.wrap(document)),window.CustomElements.ready=!0;var e=window.requestAnimationFrame||function(e){setTimeout(e,16)};e(function(){setTimeout(function(){window.CustomElements.readyTime=Date.now(),window.HTMLImports&&(window.CustomElements.elapsed=window.CustomElements.readyTime-window.HTMLImports.readyTime),document.dispatchEvent(new CustomEvent("WebComponentsReady",{bubbles:!0}))})})}var n=e.useNative,r=e.initializeModules,o=e.isIE;if(n){var i=function(){};e.watchShadow=i,e.upgrade=i,e.upgradeAll=i,e.upgradeDocumentTree=i,e.upgradeSubtree=i,e.takeRecords=i,e["instanceof"]=function(e,t){return e instanceof t}}else r();var a=e.upgradeDocumentTree,s=e.upgradeDocument;if(window.wrap||(window.ShadowDOMPolyfill?(window.wrap=window.ShadowDOMPolyfill.wrapIfNeeded,window.unwrap=window.ShadowDOMPolyfill.unwrapIfNeeded):window.wrap=window.unwrap=function(e){return e}),window.HTMLImports&&(window.HTMLImports.__importsParsingHook=function(e){e["import"]&&s(wrap(e["import"]))}),(!window.CustomEvent||o&&"function"!=typeof window.CustomEvent)&&(window.CustomEvent=function(e,t){t=t||{};var n=document.createEvent("CustomEvent");return n.initCustomEvent(e,Boolean(t.bubbles),Boolean(t.cancelable),t.detail),n.preventDefault=function(){Object.defineProperty(this,"defaultPrevented",{get:function(){return!0}})},n},window.CustomEvent.prototype=window.Event.prototype),"complete"===document.readyState||e.flags.eager)t();else if("interactive"!==document.readyState||window.attachEvent||window.HTMLImports&&!window.HTMLImports.ready){var c=window.HTMLImports&&!window.HTMLImports.ready?"HTMLImportsLoaded":"DOMContentLoaded";window.addEventListener(c,t)}else t()}(window.CustomElements),"undefined"==typeof HTMLTemplateElement&&!function(){function e(e){switch(e){case"&":return"&amp;";case"<":return"&lt;";case">":return"&gt;";case" ":return"&nbsp;"}}function t(t){return t.replace(a,e)}var n="template",r=document.implementation.createHTMLDocument("template"),o=!0;HTMLTemplateElement=function(){},HTMLTemplateElement.prototype=Object.create(HTMLElement.prototype),HTMLTemplateElement.decorate=function(e){e.content||(e.content=r.createDocumentFragment());for(var n;n=e.firstChild;)e.content.appendChild(n);if(o)try{Object.defineProperty(e,"innerHTML",{get:function(){for(var e="",n=this.content.firstChild;n;n=n.nextSibling)e+=n.outerHTML||t(n.data);return e},set:function(e){for(r.body.innerHTML=e,HTMLTemplateElement.bootstrap(r);this.content.firstChild;)this.content.removeChild(this.content.firstChild);for(;r.body.firstChild;)this.content.appendChild(r.body.firstChild)},configurable:!0})}catch(i){o=!1}},HTMLTemplateElement.bootstrap=function(e){for(var t,r=e.querySelectorAll(n),o=0,i=r.length;i>o&&(t=r[o]);o++)HTMLTemplateElement.decorate(t)},window.addEventListener("DOMContentLoaded",function(){HTMLTemplateElement.bootstrap(document)});var i=document.createElement;document.createElement=function(){"use strict";var e=i.apply(document,arguments);return"template"==e.localName&&HTMLTemplateElement.decorate(e),e};var a=/[&\u00A0<>]/g}(),function(e){"use strict";if(!window.performance){var t=Date.now();window.performance={now:function(){return Date.now()-t}}}window.requestAnimationFrame||(window.requestAnimationFrame=function(){var e=window.webkitRequestAnimationFrame||window.mozRequestAnimationFrame;return e?function(t){return e(function(){t(performance.now())})}:function(e){return window.setTimeout(e,1e3/60)}}()),window.cancelAnimationFrame||(window.cancelAnimationFrame=function(){return window.webkitCancelAnimationFrame||window.mozCancelAnimationFrame||function(e){clearTimeout(e)}}())}(window.WebComponents),function(e){var t=document.createElement("style");t.textContent="body {transition: opacity ease-in 0.2s; } \nbody[unresolved] {opacity: 0; display: block; overflow: hidden; position: relative; } \n";var n=document.querySelector("head");n.insertBefore(t,n.firstChild)}(window.WebComponents); t(e,n),m(e),g.dom&&console.groupEnd()}function _(e){y(e,v)}function w(e){HTMLTemplateElement&&HTMLTemplateElement.bootstrap&&HTMLTemplateElement.bootstrap(e),t(e)}var g=e.flags,b=e.forSubtree,y=e.forDocumentTree,E=window.MutationObserver._isPolyfilled&&g["throttle-attached"];e.hasPolyfillMutations=E,e.hasThrottledAttached=E;var L=!1,T=[],M=Array.prototype.forEach.call.bind(Array.prototype.forEach),N=Element.prototype.createShadowRoot;N&&(Element.prototype.createShadowRoot=function(){var e=N.call(this);return window.CustomElements.watchShadow(this),e}),e.watchShadow=h,e.upgradeDocumentTree=_,e.upgradeDocument=v,e.upgradeSubtree=r,e.upgradeAll=w,e.attached=a,e.takeRecords=p}),window.CustomElements.addModule(function(e){function t(t,r){if(!t.__upgraded__&&t.nodeType===Node.ELEMENT_NODE){var o=t.getAttribute("is"),i=e.getRegisteredDefinition(t.localName)||e.getRegisteredDefinition(o);if(i&&(o&&i.tag==t.localName||!o&&!i["extends"]))return n(t,i,r)}}function n(t,n,o){return a.upgrade&&console.group("upgrade:",t.localName),n.is&&t.setAttribute("is",n.is),r(t,n),t.__upgraded__=!0,i(t),o&&e.attached(t),e.upgradeSubtree(t,o),a.upgrade&&console.groupEnd(),t}function r(e,t){Object.__proto__?e.__proto__=t.prototype:(o(e,t.prototype,t["native"]),e.__proto__=t.prototype)}function o(e,t,n){for(var r={},o=t;o!==n&&o!==HTMLElement.prototype;){for(var i,a=Object.getOwnPropertyNames(o),s=0;i=a[s];s++)r[i]||(Object.defineProperty(e,i,Object.getOwnPropertyDescriptor(o,i)),r[i]=1);o=Object.getPrototypeOf(o)}}function i(e){e.createdCallback&&e.createdCallback()}var a=e.flags;e.upgrade=t,e.upgradeWithDefinition=n,e.implementPrototype=r}),window.CustomElements.addModule(function(e){function t(t,r){var c=r||{};if(!t)throw new Error("document.registerElement: first argument `name` must not be empty");if(t.indexOf("-")<0)throw new Error("document.registerElement: first argument ('name') must contain a dash ('-'). Argument provided was '"+String(t)+"'.");if(o(t))throw new Error("Failed to execute 'registerElement' on 'Document': Registration failed for type '"+String(t)+"'. The type name is invalid.");if(d(t))throw new Error("DuplicateDefinitionError: a type with name '"+String(t)+"' is already registered");return c.prototype||(c.prototype=Object.create(HTMLElement.prototype)),c.__name=t.toLowerCase(),c.lifecycle=c.lifecycle||{},c.ancestry=i(c["extends"]),a(c),s(c),n(c.prototype),u(c.__name,c),c.ctor=l(c),c.ctor.prototype=c.prototype,c.prototype.constructor=c.ctor,e.ready&&_(document),c.ctor}function n(e){if(!e.setAttribute._polyfilled){var t=e.setAttribute;e.setAttribute=function(e,n){r.call(this,e,n,t)};var n=e.removeAttribute;e.removeAttribute=function(e){r.call(this,e,null,n)},e.setAttribute._polyfilled=!0}}function r(e,t,n){e=e.toLowerCase();var r=this.getAttribute(e);n.apply(this,arguments);var o=this.getAttribute(e);this.attributeChangedCallback&&o!==r&&this.attributeChangedCallback(e,r,o)}function o(e){for(var t=0;t<E.length;t++)if(e===E[t])return!0}function i(e){var t=d(e);return t?i(t["extends"]).concat([t]):[]}function a(e){for(var t,n=e["extends"],r=0;t=e.ancestry[r];r++)n=t.is&&t.tag;e.tag=n||e.__name,n&&(e.is=e.__name)}function s(e){if(!Object.__proto__){var t=HTMLElement.prototype;if(e.is){var n=document.createElement(e.tag);t=Object.getPrototypeOf(n)}for(var r,o=e.prototype,i=!1;o;)o==t&&(i=!0),r=Object.getPrototypeOf(o),r&&(o.__proto__=r),o=r;i||console.warn(e.tag+" prototype not found in prototype chain for "+e.is),e["native"]=t}}function c(e){return g(M(e.tag),e)}function d(e){return e?L[e.toLowerCase()]:void 0}function u(e,t){L[e]=t}function l(e){return function(){return c(e)}}function h(e,t,n){return e===T?f(t,n):N(e,t)}function f(e,t){e&&(e=e.toLowerCase()),t&&(t=t.toLowerCase());var n=d(t||e);if(n){if(e==n.tag&&t==n.is)return new n.ctor;if(!t&&!n.is)return new n.ctor}var r;return t?(r=f(e),r.setAttribute("is",t),r):(r=M(e),e.indexOf("-")>=0&&b(r,HTMLElement),r)}function p(e,t){var n=e[t];e[t]=function(){var e=n.apply(this,arguments);return w(e),e}}var m,v=e.isIE,_=e.upgradeDocumentTree,w=e.upgradeAll,g=e.upgradeWithDefinition,b=e.implementPrototype,y=e.useNative,E=["annotation-xml","color-profile","font-face","font-face-src","font-face-uri","font-face-format","font-face-name","missing-glyph"],L={},T="http://www.w3.org/1999/xhtml",M=document.createElement.bind(document),N=document.createElementNS.bind(document);m=Object.__proto__||y?function(e,t){return e instanceof t}:function(e,t){if(e instanceof t)return!0;for(var n=e;n;){if(n===t.prototype)return!0;n=n.__proto__}return!1},p(Node.prototype,"cloneNode"),p(document,"importNode"),v&&!function(){var e=document.importNode;document.importNode=function(){var t=e.apply(document,arguments);if(t.nodeType==t.DOCUMENT_FRAGMENT_NODE){var n=document.createDocumentFragment();return n.appendChild(t),n}return t}}(),document.registerElement=t,document.createElement=f,document.createElementNS=h,e.registry=L,e["instanceof"]=m,e.reservedTagList=E,e.getRegisteredDefinition=d,document.register=document.registerElement}),function(e){function t(){i(window.wrap(document)),window.CustomElements.ready=!0;var e=window.requestAnimationFrame||function(e){setTimeout(e,16)};e(function(){setTimeout(function(){window.CustomElements.readyTime=Date.now(),window.HTMLImports&&(window.CustomElements.elapsed=window.CustomElements.readyTime-window.HTMLImports.readyTime),document.dispatchEvent(new CustomEvent("WebComponentsReady",{bubbles:!0}))})})}var n=e.useNative,r=e.initializeModules;e.isIE;if(n){var o=function(){};e.watchShadow=o,e.upgrade=o,e.upgradeAll=o,e.upgradeDocumentTree=o,e.upgradeSubtree=o,e.takeRecords=o,e["instanceof"]=function(e,t){return e instanceof t}}else r();var i=e.upgradeDocumentTree,a=e.upgradeDocument;if(window.wrap||(window.ShadowDOMPolyfill?(window.wrap=window.ShadowDOMPolyfill.wrapIfNeeded,window.unwrap=window.ShadowDOMPolyfill.unwrapIfNeeded):window.wrap=window.unwrap=function(e){return e}),window.HTMLImports&&(window.HTMLImports.__importsParsingHook=function(e){e["import"]&&a(wrap(e["import"]))}),"complete"===document.readyState||e.flags.eager)t();else if("interactive"!==document.readyState||window.attachEvent||window.HTMLImports&&!window.HTMLImports.ready){var s=window.HTMLImports&&!window.HTMLImports.ready?"HTMLImportsLoaded":"DOMContentLoaded";window.addEventListener(s,t)}else t()}(window.CustomElements),function(e){var t=document.createElement("style");t.textContent="body {transition: opacity ease-in 0.2s; } \nbody[unresolved] {opacity: 0; display: block; overflow: hidden; position: relative; } \n";var n=document.querySelector("head");n.insertBefore(t,n.firstChild)}(window.WebComponents);
\ No newline at end of file \ No newline at end of file
This source diff could not be displayed because it is too large. You can view the blob instead.
...@@ -46,7 +46,7 @@ ...@@ -46,7 +46,7 @@
}, },
getActiveCount: function () { getActiveCount: function () {
return this.items.length - this.getCompletedCount(this.items); return this.items ? (this.items.length - this.getCompletedCount(this.items)) : 0;
}, },
matchesFilter: function(item, filter) { matchesFilter: function(item, filter) {
......
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