Merge Chromium + Blink git repositories
[chromium-blink-merge.git] / chrome / browser / resources / pdf / elements / viewer-toolbar-dropdown / viewer-toolbar-dropdown.js
blob165a511e16d8bea7a46fc2b456f6b7289d8fdf53
1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 (function() {
6 /**
7 * Size of additional padding in the inner scrollable section of the dropdown.
8 */
9 var DROPDOWN_INNER_PADDING = 12;
11 /** Size of vertical padding on the outer #dropdown element. */
12 var DROPDOWN_OUTER_PADDING = 2;
14 /** Minimum height of toolbar dropdowns (px). */
15 var MIN_DROPDOWN_HEIGHT = 200;
17 Polymer({
18 is: 'viewer-toolbar-dropdown',
20 properties: {
21 /** String to be displayed at the top of the dropdown. */
22 header: String,
24 /** Icon to display when the dropdown is closed. */
25 closedIcon: String,
27 /** Icon to display when the dropdown is open. */
28 openIcon: String,
30 /** True if the dropdown is currently open. */
31 dropdownOpen: {
32 type: Boolean,
33 value: false
36 /** Toolbar icon currently being displayed. */
37 dropdownIcon: {
38 type: String,
39 computed: 'computeIcon_(dropdownOpen, closedIcon, openIcon)'
42 /** Lowest vertical point that the dropdown should occupy (px). */
43 lowerBound: {
44 type: Number,
45 observer: 'lowerBoundChanged_'
48 /**
49 * True if the max-height CSS property for the dropdown scroll container
50 * is valid. If false, the height will be updated the next time the
51 * dropdown is visible.
53 maxHeightValid_: false,
55 /** Current animation being played, or null if there is none. */
56 animation_: Object
59 computeIcon_: function(dropdownOpen, closedIcon, openIcon) {
60 return dropdownOpen ? openIcon : closedIcon;
63 lowerBoundChanged_: function() {
64 this.maxHeightValid_ = false;
65 if (this.dropdownOpen)
66 this.updateMaxHeight();
69 toggleDropdown: function() {
70 this.dropdownOpen = !this.dropdownOpen;
71 if (this.dropdownOpen) {
72 this.$.icon.classList.add('open');
73 this.$.dropdown.style.display = 'block';
74 if (!this.maxHeightValid_)
75 this.updateMaxHeight();
76 } else {
77 this.$.icon.classList.remove('open');
79 this.cancelAnimation_();
80 this.playAnimation_(this.dropdownOpen);
83 updateMaxHeight: function() {
84 var scrollContainer = this.$['scroll-container'];
85 var height = this.lowerBound -
86 scrollContainer.getBoundingClientRect().top -
87 DROPDOWN_INNER_PADDING;
88 height = Math.max(height, MIN_DROPDOWN_HEIGHT);
89 scrollContainer.style.maxHeight = height + 'px';
90 this.maxHeightValid_ = true;
93 cancelAnimation_: function() {
94 if (this._animation)
95 this._animation.cancel();
98 /**
99 * Start an animation on the dropdown.
100 * @param {boolean} isEntry True to play entry animation, false to play
101 * exit.
102 * @private
104 playAnimation_: function(isEntry) {
105 this.animation_ = isEntry ? this.animateEntry_() : this.animateExit_();
106 this.animation_.onfinish = function() {
107 this.animation_ = null;
108 if (!this.dropdownOpen)
109 this.$.dropdown.style.display = 'none';
110 }.bind(this);
113 animateEntry_: function() {
114 var maxHeight = this.$.dropdown.getBoundingClientRect().height -
115 DROPDOWN_OUTER_PADDING;
117 if (maxHeight < 0)
118 maxHeight = 0;
120 var fade = new KeyframeEffect(this.$.dropdown, [
121 {opacity: 0},
122 {opacity: 1}
123 ], {duration: 150, easing: 'cubic-bezier(0, 0, 0.2, 1)'});
124 var slide = new KeyframeEffect(this.$.dropdown, [
125 {height: '20px', transform: 'translateY(-10px)'},
126 {height: maxHeight + 'px', transform: 'translateY(0)'}
127 ], {duration: 250, easing: 'cubic-bezier(0, 0, 0.2, 1)'});
129 return document.timeline.play(new GroupEffect([fade, slide]));
132 animateExit_: function() {
133 return this.$.dropdown.animate([
134 {transform: 'translateY(0)', opacity: 1},
135 {transform: 'translateY(-5px)', opacity: 0}
136 ], {duration: 100, easing: 'cubic-bezier(0.4, 0, 1, 1)'});
140 })();