11320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci
21320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci    Polymer('paper-menu-button-transition', {
31320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci
41320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci      baseClass: 'paper-menu-button-transition',
51320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci      revealedClass: 'paper-menu-button-revealed',
61320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci      openedClass: 'paper-menu-button-opened',
71320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci      closedClass: 'paper-menu-button-closed',
81320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci
91320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci      duration: 500,
101320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci
111320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci      setup: function(node) {
121320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci        this.super(arguments);
131320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci
141320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci        var bg = node.querySelector('.paper-menu-button-overlay-bg');
151320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci        bg.style.transformOrigin = this.transformOrigin;
161320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci        bg.style.webkitTransformOrigin = this.transformOrigin;
171320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci      },
181320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci
191320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci      transitionOpened: function(node, opened) {
201320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci        this.super(arguments);
211320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci
221320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci        if (opened) {
231320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          if (this.player) {
241320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            this.player.cancel();
251320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          }
261320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci
271320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          var anims = [];
281320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci
291320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          var ink = node.querySelector('.paper-menu-button-overlay-ink');
301320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          var offset = 40 / Math.max(node.cachedSize.width, node.cachedSize.height);
311320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          anims.push(new Animation(ink, [{
321320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            'opacity': 0.9,
331320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            'transform': 'scale(0)',
341320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          }, {
351320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            'opacity': 0.9,
361320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            'transform': 'scale(1)'
371320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          }], {
381320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            duration: this.duration * offset
391320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          }));
401320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci
411320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          var bg = node.querySelector('.paper-menu-button-overlay-bg');
421320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          anims.push(new Animation(bg, [{
431320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            'opacity': 0.9,
441320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            'transform': 'scale(' + 40 / node.cachedSize.width + ',' + 40 / node.cachedSize.height + ')',
451320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          }, {
461320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            'opacity': 1,
471320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            'transform': 'scale(0.95, 0.5)'
481320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          }, {
491320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            'opacity': 1,
501320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            'transform': 'scale(1, 1)'
511320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          }], {
521320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            delay: this.duration * offset,
531320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            duration: this.duration * (1 - offset),
541320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            fill: 'forwards'
551320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          }));
561320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci
571320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          var nodes = window.ShadowDOMPolyfill ? Platform.queryAllShadows(node.querySelector('core-menu'), 'content').getDistributedNodes() : node.querySelector('core-menu::shadow content').getDistributedNodes().array();
581320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          var items = nodes.filter(function(n) {
591320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            return n.nodeType === Node.ELEMENT_NODE;
601320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          });
611320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          var itemDelay = offset + (1 - offset) / 2;
621320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          var itemDuration = this.duration * (1 - itemDelay) / items.length;
631320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          items.forEach(function(item, i) {
641320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            anims.push(new Animation(item, [{
651320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci              'opacity': 0
661320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            }, {
671320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci              'opacity': 1
681320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            }], {
691320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci              delay: this.duration * itemDelay + itemDuration * i,
701320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci              duration: itemDuration,
711320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci              fill: 'both'
721320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            }));
731320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          }.bind(this));
741320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci
751320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          var shadow = node.querySelector('paper-shadow');
761320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          anims.push(new Animation(shadow, function(t, target) {
771320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            if (t > offset * 2 && shadow.z === 0) {
781320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci              shadow.z = 1
791320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            }
801320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          }, {
811320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            duration: this.duration
821320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          }));
831320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci
841320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          var group = new AnimationGroup(anims, {
851320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci            easing: 'cubic-bezier(0.4, 0, 0.2, 1)'
861320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          });
871320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci          this.player = document.timeline.play(group);
881320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci        }
891320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci      },
901320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci
911320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci    });
921320f92c476a1ad9d19dba2a48c72b75566198e9Primiano Tucci