Index: third_party/polymer/v0_8/components-chromium/neon-animation/neon-shared-element-animation-behavior-extracted.js |
diff --git a/third_party/polymer/v0_8/components-chromium/neon-animation/neon-shared-element-animation-behavior-extracted.js b/third_party/polymer/v0_8/components-chromium/neon-animation/neon-shared-element-animation-behavior-extracted.js |
new file mode 100644 |
index 0000000000000000000000000000000000000000..e5cd7c9ef7f9ba1365ccf3178f6c27ecf7078a11 |
--- /dev/null |
+++ b/third_party/polymer/v0_8/components-chromium/neon-animation/neon-shared-element-animation-behavior-extracted.js |
@@ -0,0 +1,52 @@ |
+ |
+ |
+ /** |
+ * Use `Polymer.NeonSharedElementAnimationBehavior` to implement shared element animations. |
+ * @polymerBehavior |
+ */ |
+ Polymer.NeonSharedElementAnimationBehavior = [Polymer.NeonAnimationBehavior, { |
+ |
+ properties: { |
+ |
+ /** |
+ * Cached copy of shared elements. |
+ */ |
+ sharedElements: { |
+ type: Object |
+ } |
+ |
+ }, |
+ |
+ /** |
+ * Finds shared elements based on `config`. |
+ */ |
+ findSharedElements: function(config) { |
+ var fromPage = config.fromPage; |
+ var toPage = config.toPage; |
+ if (!fromPage || !toPage) { |
+ console.warn(this.is + ':', !fromPage ? 'fromPage' : 'toPage', 'is undefined!'); |
+ return null; |
+ }; |
+ |
+ if (!fromPage.sharedElements || !toPage.sharedElements) { |
+ console.warn(this.is + ':', 'sharedElements are undefined for', !fromPage.sharedElements ? fromPage : toPage); |
+ return null; |
+ }; |
+ |
+ var from = fromPage.sharedElements[config.id] |
+ var to = toPage.sharedElements[config.id]; |
+ |
+ if (!from || !to) { |
+ console.warn(this.is + ':', 'sharedElement with id', config.id, 'not found in', !from ? fromPage : toPage); |
+ return null; |
+ } |
+ |
+ this.sharedElements = { |
+ from: from, |
+ to: to |
+ }; |
+ return this.sharedElements; |
+ } |
+ |
+ }]; |
+ |