JSPM

  • Created
  • Published
  • Downloads 11993
  • Score
    100M100P100Q146545F
  • License BSD-3-Clause

A set of layout elements for your app

Package Exports

  • @polymer/app-layout
  • @polymer/app-layout/app-drawer-layout/app-drawer-layout
  • @polymer/app-layout/app-drawer-layout/app-drawer-layout.js
  • @polymer/app-layout/app-drawer/app-drawer
  • @polymer/app-layout/app-drawer/app-drawer.js
  • @polymer/app-layout/app-grid/app-grid-style
  • @polymer/app-layout/app-grid/app-grid-style.js
  • @polymer/app-layout/app-header-layout/app-header-layout
  • @polymer/app-layout/app-header-layout/app-header-layout.js
  • @polymer/app-layout/app-header/app-header
  • @polymer/app-layout/app-header/app-header.js
  • @polymer/app-layout/app-layout
  • @polymer/app-layout/app-layout.js
  • @polymer/app-layout/app-scroll-effects/app-scroll-effects
  • @polymer/app-layout/app-scroll-effects/app-scroll-effects.js
  • @polymer/app-layout/app-scroll-effects/effects/material.js
  • @polymer/app-layout/app-scroll-effects/effects/resize-title.js
  • @polymer/app-layout/app-scroll-effects/effects/waterfall
  • @polymer/app-layout/app-scroll-effects/effects/waterfall.js
  • @polymer/app-layout/app-toolbar/app-toolbar
  • @polymer/app-layout/app-toolbar/app-toolbar.js
  • @polymer/app-layout/demo/sample-content.js
  • @polymer/app-layout/helpers/helpers.js

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@polymer/app-layout) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

Published on NPM Build status Published on webcomponents.org

App Layout

A collection of elements, along with guidelines and templates that can be used to structure your app’s layout.

What is inside

Elements

  • app-box - A container element that can have scroll effects - visual effects based on scroll position.

  • app-drawer - A navigation drawer that can slide in from the left or right.

  • app-drawer-layout - A wrapper element that positions an app-drawer and other content.

  • app-grid - A helper class useful for creating responsive, fluid grid layouts using custom properties.

  • app-header - A container element for app-toolbars at the top of the screen that can have scroll effects - visual effects based on scroll position.

  • app-header-layout - A wrapper element that positions an app-header and other content.

  • app-toolbar - A horizontal toolbar containing items that can be used for label, navigation, search and actions.

Templates

The templates are a means to define, illustrate and share best practices in App Layout. Pick a template and customize it:

Patterns

Sample code for various UI patterns:

  • Transform navigation: As more screen space is available, side navigation can transform into tabs. (Demo - Source)

  • Expand Card: Content cards may expand to take up more horizontal space. (Demo - Source)

  • Material Design Responsive Toolbar: Toolbar changes its height and padding to adapt mobile screen size. (Demo - Source)

Users

Here are some web apps built with App Layout:

See: Documentation, Demo.

Usage

Installation

npm install --save @polymer/app-layout

In an html file

<html>
  <head>
    <script type="module">
      import '@polymer/app-layout/app-layout.js';
    </script>
  </head>
  <body>
    <app-header reveals>
      <app-toolbar>
        <div main-title>My app</div>
      </app-toolbar>
    </app-header>
    <app-drawer id="drawer" swipe-open></app-drawer>
  </body>
</html>

In a Polymer 3 element

import {PolymerElement, html} from '@polymer/polymer';
import '@polymer/app-layout/app-layout.js';

class SampleElement extends PolymerElement {
  static get template() {
    return html`
      <app-header reveals>
        <app-toolbar>
          <div main-title>My app</div>
        </app-toolbar>
      </app-header>
      <app-drawer id="drawer" swipe-open></app-drawer>
    `;
  }
}
customElements.define('sample-element', SampleElement);

Contributing

If you want to send a PR to this element, here are the instructions for running the tests and demo locally:

Installation

git clone https://github.com/PolymerElements/app-layout
cd app-layout
npm install
npm install -g polymer-cli

Running the demo locally

polymer serve --npm
open http://127.0.0.1:<port>/demo/

Running the tests

polymer test --npm