Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(84)

Unified Diff: third_party/polymer/v0_8/components-chromium/more-routing/params-extracted.js

Issue 1140393002: Update more-routing for md-settings (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: third_party/polymer/v0_8/components-chromium/more-routing/params-extracted.js
diff --git a/third_party/polymer/v0_8/components-chromium/more-routing/params-extracted.js b/third_party/polymer/v0_8/components-chromium/more-routing/params-extracted.js
new file mode 100644
index 0000000000000000000000000000000000000000..9a9a1ee3d3cf494f19843f91a7dbdeb4c1e0b6d5
--- /dev/null
+++ b/third_party/polymer/v0_8/components-chromium/more-routing/params-extracted.js
@@ -0,0 +1,46 @@
+
+(function(scope) {
+var MoreRouting = scope.MoreRouting = scope.MoreRouting || {};
+MoreRouting.Params = Params;
+
+/**
+ * A collection of route parameters and their values, with nofications.
+ *
+ * Params prefixed by `__` are reserved.
+ *
+ * @param {!Array<string>} params The keys of the params being managed.
+ * @param {Params=} parent A parent route's params to inherit.
+ * @return {Params}
+ */
+function Params(params, parent) {
+ var model = Object.create(parent || Params.prototype);
+ // We have a different set of listeners at every level of the hierarchy.
+ Object.defineProperty(model, '__listeners', {value: []});
+
+ // We keep all state enclosed within this closure so that inheritance stays
+ // relatively straightfoward.
+ var state = {};
+ _compile(model, params, state);
+
+ return model;
+}
+Params.prototype = Object.create(MoreRouting.Emitter);
+
+// Utility
+
+function _compile(model, params, state) {
+ params.forEach(function(param) {
+ Object.defineProperty(model, param, {
+ get: function() {
+ return state[param];
+ },
+ set: function(value) {
+ if (state[param] === value) return;
+ state[param] = value;
+ model.__notify(param, value);
+ },
+ });
+ });
+}
+
+})(window);

Powered by Google App Engine
This is Rietveld 408576698