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

Unified Diff: third_party/polymer/components/core-drawer-panel/core-drawer-panel.html

Issue 582873003: Polymer elements added to third_party/polymer. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 3 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/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>

Powered by Google App Engine
This is Rietveld 408576698