2016-09-22 13 views
1

スターターキット2のテンプレートを使用すると、アプリの引き出しをapp-header以下にすることはできますか?今では、アプリケーションドロワはビューポートの先頭から始まり、app-headerの横に列になっています。app-headerの下にアプリの引き出しを配置する

私のアプリは、GoogleヘッダーとGoogleのクラウドコンソールのようになります。アプリのヘッダーは、ビューポートの全幅にわたっていて、アプリの引き出しは下から始まります。

app-layoutの要素カタログを読み終えたら、これを設定するための公式API /属性はありませんでした。私はいくつかのことを試してみたが、何の成功:

<app-drawer-layout fullbleed> 
    <!-- Drawer content --> 
    <app-header condenses reveals effects="waterfall"> 
     <app-toolbar> 
     <paper-icon-button icon="menu" drawer-toggle></paper-icon-button> 
     <div main-title>My App</div> 
     </app-toolbar> 
    </app-header> 

    <app-drawer> 
    <app-toolbar>Menu</app-toolbar> 
    <iron-selector selected="[[page]]" attr-for-selected="name" class="drawer-list" role="navigation"> 
     <a name="view1" href="/view1">View One</a> 
     <a name="view2" href="/view2">View Two</a> 
     <a name="view3" href="/view3">View Three</a> 
    </iron-selector> 
    </app-drawer> 

enter image description here

答えて

8

基本的にはapp-header-layoutapp-drawer-layoutを使用する必要がありません。

ここに希望のレイアウトのJSBinがあります。

とコード自体:あなたは手動で引き出しボタンを処理する必要が

<dom-module id="test-app"> 
    <template> 

    <style> 

     :host { 
     display: block; 
     --app-primary-color: #3F51B5; 
     } 

     app-header { 
     background-color: var(--app-primary-color); 
     color: white; 
     } 

     app-drawer { 
     top: 64px; 
     --app-drawer-content-container: { 
      padding: 0px; 
      background-color: #eee; 
     }; 
     } 

    </style> 

    <app-header-layout fullbleed> 
     <app-header fixed shadow> 
     <app-toolbar id="toolbar"> 
      <paper-icon-button icon="menu" on-tap="_onTap"></paper-icon-button> 
      <div main-title>Stormwind</div> 
     </app-toolbar> 
     </app-header> 
     <app-drawer-layout> 
     <app-drawer id="drawer"> 
      drawer content 
     </app-drawer> 
     <div> 
      main content 
     </div> 
     </app-drawer-layout> 
    </app-header-layout> 

    </template> 
    <script> 
    Polymer({ 

     is: 'test-app', 

     properties: { 

     }, 

     ready: function() { 

     }, 

     attached: function() { 

     }, 

     _onTap: function() { 
     this.$.drawer.toggle(); 
     } 

    }); 
    </script> 
</dom-module> 

NOTE

drawer-toggleプロパティが動作しません)。

+0

すごく感謝!何らかの理由で私は 'app-drawer-layout'は常にすべての親コンテナでなければならないと考えました。 – dman

+0

ニース。うん、私はこのレイアウトも好きです。 のようなスクロールで凝縮する、より大きなヘッダーエフェクトのいくつかを使用する場合、これはどういう意味ですか?アプリ引き出しはGoogle Inboxのように何とか上/下に移動する必要がありますか? – Rhys

+0

@Rhysあなたは正しいです、それらの 'app-header'効果を使って、引き出しを修正する必要があるでしょう。私はdrawerをapp-headerの位置と状態に基づいてある種のアニメーションで動かすことができます。 'app-header'ドキュメンテーション(https://elements.polymer-project.org/elements/app-layout?active=app-header)をチェックすると、' thresholdTriggered'ブール値と 'getScrollState()'があります。これに使用する関数。 – Hunex

関連する問題