Index: third_party/polymer/components/core-drawer-panel/core-drawer-panel.html |
diff --git a/third_party/polymer/components/core-drawer-panel/core-drawer-panel.html b/third_party/polymer/components/core-drawer-panel/core-drawer-panel.html |
new file mode 100644 |
index 0000000000000000000000000000000000000000..bd68d94593bf1e8721e22fb6eff600119d884e8f |
--- /dev/null |
+++ b/third_party/polymer/components/core-drawer-panel/core-drawer-panel.html |
@@ -0,0 +1,273 @@ |
+<!-- |
+Copyright (c) 2014 The Polymer Project Authors. All rights reserved. |
+This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt |
+The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt |
+The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt |
+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 |
+--> |
+ |
+<!-- |
+`core-drawer-panel` contains a drawer panel and a main panel. The drawer |
+and the main panel are side-by-side with drawer on the left. When browser |
+window size is smaller than the `responsiveWidth`, `core-drawer-panel` |
+changes to narrow layout. In narrow layout, the drawer will be stacked on top |
+of the main panel. The drawer will be slided in/out to hide/reveal the main |
+panel. |
+ |
+Use the attribute `drawer` to indicate the element is a drawer panel and |
+`main` to indicate is a main panel. |
+ |
+Example: |
+ |
+ <core-drawer-panel> |
+ <div drawer> Drawer panel... </div> |
+ <div main> Main panel... </div> |
+ </core-drawer-panel> |
+ |
+The drawer and the main panels are not scrollable. You can set CSS overflow |
+property on the elements to make them scrollable or use `core-header-panel`. |
+ |
+Example: |
+ |
+ <core-drawer-panel> |
+ <core-header-panel drawer> |
+ <core-toolbar></core-toolbar> |
+ <div> Drawer content... </div> |
+ </core-header-panel> |
+ <core-header-panel main> |
+ <core-toolbar></core-toolbar> |
+ <div> Main content... </div> |
+ </core-header-panel> |
+ </core-drawer-panel> |
+ |
+To position the drawer to the right, add `rightDrawer` attribute. |
+ |
+ <core-drawer-panel rightDrawer> |
+ <div drawer> Drawer panel... </div> |
+ <div main> Main panel... </div> |
+ </core-drawer-panel> |
+ |
+@group Polymer Core Elements |
+@element core-drawer-panel |
+@homepage github.io |
+--> |
+ |
+<link rel="import" href="../core-media-query/core-media-query.html"> |
+<link rel="import" href="../core-selector/core-selector.html"> |
+ |
+<polymer-element name="core-drawer-panel" touch-action="auto"> |
+<template> |
+ |
+ <link rel="stylesheet" href="core-drawer-panel.css"> |
+ |
+ <core-media-query query="max-width: {{responsiveWidth}}" queryMatches="{{queryMatches}}"></core-media-query> |
+ |
+ <core-selector class="{{ {'narrow-layout' : queryMatches, transition : transition, dragging : dragging, 'right-drawer': rightDrawer} | tokenList }}" valueattr="id" selected="{{selected}}"> |
+ |
+ <div id="main" _style="left: {{ narrow || rightDrawer ? '0' : drawerWidth }}; right: {{ rightDrawer ? (narrow ? '' : drawerWidth) : '' }};"> |
+ <content select="[main]"></content> |
+ <div id="scrim" on-tap="{{togglePanel}}"></div> |
+ </div> |
+ |
+ <div id="drawer" _style="width: {{ drawerWidth }}"> |
+ <content select="[drawer]"></content> |
+ </div> |
+ |
+ </core-selector> |
+ |
+</template> |
+<script> |
+ |
+ Polymer('core-drawer-panel', { |
+ /** |
+ * Fired when the narrow layout changes. |
+ * |
+ * @event core-responsive-change |
+ * @param {Object} detail |
+ * @param {boolean} detail.narrow true if the panel is in narrow layout. |
+ */ |
+ |
+ publish: { |
+ |
+ /** |
+ * Width of the drawer panel. |
+ * |
+ * @attribute drawerWidth |
+ * @type string |
+ * @default '256px' |
+ */ |
+ drawerWidth: '256px', |
+ |
+ /** |
+ * Max-width when the panel changes to narrow layout. |
+ * |
+ * @attribute responsiveWidth |
+ * @type string |
+ * @default '640px' |
+ */ |
+ responsiveWidth: '640px', |
+ |
+ /** |
+ * The panel that is being selected. `drawer` for the drawer panel and |
+ * `main` for the main panel. |
+ * |
+ * @attribute selected |
+ * @type string |
+ * @default null |
+ */ |
+ selected: {value: null, reflect: true}, |
+ |
+ /** |
+ * The panel to be selected when `core-drawer-panel` changes to narrow |
+ * layout. |
+ * |
+ * @attribute defaultSelected |
+ * @type string |
+ * @default 'main' |
+ */ |
+ defaultSelected: 'main', |
+ |
+ /** |
+ * Returns true if the panel is in narrow layout. This is useful if you |
+ * need to show/hide elements based on the layout. |
+ * |
+ * @attribute narrow |
+ * @type boolean |
+ * @default false |
+ */ |
+ narrow: {value: false, reflect: true}, |
+ |
+ /** |
+ * If true, position the drawer to the right. |
+ * |
+ * @attribute rightDrawer |
+ * @type boolean |
+ * @default false |
+ */ |
+ rightDrawer: false, |
+ |
+ /** |
+ * If true, swipe to open/close the drawer is disabled. |
+ * |
+ * @attribute disableSwipe |
+ * @type boolean |
+ * @default false |
+ */ |
+ disableSwipe: false |
+ }, |
+ |
+ eventDelegates: { |
+ trackstart: 'trackStart', |
+ trackx: 'trackx', |
+ trackend: 'trackEnd' |
+ }, |
+ |
+ transition: false, |
+ |
+ edgeSwipeSensitivity : 15, |
+ |
+ dragging : false, |
+ |
+ domReady: function() { |
+ // to avoid transition at the beginning e.g. page loads |
+ // NOTE: domReady is already raf delayed and delaying another frame |
+ // ensures a layout has occurred. |
+ this.async(function() { |
+ this.transition = true; |
+ }); |
+ }, |
+ |
+ /** |
+ * Toggles the panel open and closed. |
+ * |
+ * @method togglePanel |
+ */ |
+ togglePanel: function() { |
+ this.selected = this.selected === 'main' ? 'drawer' : 'main'; |
+ }, |
+ |
+ /** |
+ * Opens the drawer. |
+ * |
+ * @method openDrawer |
+ */ |
+ openDrawer: function() { |
+ this.selected = 'drawer'; |
+ }, |
+ |
+ /** |
+ * Closes the drawer. |
+ * |
+ * @method closeDrawer |
+ */ |
+ closeDrawer: function() { |
+ this.selected = 'main'; |
+ }, |
+ |
+ queryMatchesChanged: function() { |
+ if (this.queryMatches) { |
+ this.selected = this.defaultSelected; |
+ } |
+ this.narrow = this.queryMatches; |
+ this.setAttribute('touch-action', |
+ this.narrow && !this.disableSwipe ? 'pan-y' : ''); |
+ this.fire('core-responsive-change', {narrow: this.narrow}); |
+ }, |
+ |
+ // swipe support for the drawer, inspired by |
+ // https://github.com/Polymer/core-drawer-panel/pull/6 |
+ trackStart : function(e) { |
+ if (this.narrow && !this.disableSwipe) { |
+ this.dragging = true; |
+ |
+ if (this.selected === 'main') { |
+ this.dragging = this.rightDrawer ? |
+ e.pageX >= this.offsetWidth - this.edgeSwipeSensitivity : |
+ e.pageX <= this.edgeSwipeSensitivity; |
+ } |
+ |
+ if (this.dragging) { |
+ this.width = this.$.drawer.offsetWidth; |
+ this.transition = false; |
+ e.preventTap(); |
+ } |
+ } |
+ }, |
+ |
+ trackx : function(e) { |
+ if (this.dragging) { |
+ var x; |
+ if (this.rightDrawer) { |
+ x = Math.max(0, (this.selected === 'main') ? this.width + e.dx : e.dx); |
+ } else { |
+ x = Math.min(0, (this.selected === 'main') ? e.dx - this.width : e.dx); |
+ } |
+ this.moveDrawer(x); |
+ } |
+ }, |
+ |
+ trackEnd : function(e) { |
+ if (this.dragging) { |
+ this.dragging = false; |
+ this.transition = true; |
+ this.moveDrawer(null); |
+ |
+ if (this.rightDrawer) { |
+ this.selected = e.xDirection > 0 ? 'main' : 'drawer'; |
+ } else { |
+ this.selected = e.xDirection > 0 ? 'drawer' : 'main'; |
+ } |
+ } |
+ }, |
+ |
+ moveDrawer: function(translateX) { |
+ var s = this.$.drawer.style; |
+ s.webkitTransform = s.transform = |
+ translateX === null ? '' : 'translate3d(' + translateX + 'px, 0, 0)'; |
+ } |
+ |
+ }); |
+ |
+</script> |
+</polymer-element> |