2016-11-20 25 views
0

の1つのタイプをグリッドの形でレイアウトするareaに追加できるという要件があります。ウィジェット自体には、bootstrapクラスを使用して幅を決定する値が含まれています。ここではウィジェット定義ウィジェットラッパーの作成方法ブートストラップクラスを含む

// lib/modules/grid-item-widget/index.js 

module.exports={ 
    extend: 'apostrophe-widgets', 
    label: 'Grid Item', 

    addFields: [ 
    { 
     name: 'grid', 
     type: 'select', 
     choices:[ 
     {label:'10%',value:'col-md-2'} 
     ,{label:'30%',value:'col-md-3'} 
     ,{label:'50%',value:'col-md-6'} 
     ,{label:'70%',value:'col-md-8'} 
     ,{label:'100%',value:'col-md-12'} 
     ] 
    }, 
    { 
     name: 'image', 
     type: 'singleton', 
     label: 'Presentation Image', 
     widgetType: 'apostrophe-images', 
     options: { 
     limit: 1 
     } 
    } 
    ] 
}; 

であり、これは

//lib/modules/grid-item-widget/views/widget.html 

<div class="col-xs-12 col-md-{{ data.widget.grid }}"> 
    {{ 
     apos.singleton(data.widget,'image','apostrophe-images',{edit:false}) 
    }} 
</div> 

問題はエリア項目の一部としてAPOS-UI要素が含まれているマークアップがたくさんあるということであるhtmlです。そして、これらの列をエリアラッパーマークアップの一部にしたいので、要素がapos-uiコントロールとともに適切にページ上に浮かびます。

現時点では、apos-uiコントロールが互いにオーバーラップするため、ユーザーエクスペリエンスはあまり直感的ではありません。

答えて

1

プロジェクトレベルでapostrophe-areas/views/widget.htmlを延長することをお勧めします。このテンプレートでは、data.widget.gridにアクセスする必要があります。そうすれば、ウィジェットラッパークラスを変更することができます。

+0

こんにちはアレックス、これは私の最初の試みでしたが、私がしたいことはしません。 'apostrophe-areas/area.html'と' apostrophe-areas/widget.html'カスケード。これは、 'container'と' row'ブートストラップクラスをインクルードするためにこれら2つのファイルをオーバーライドすると、それらが含まれているすべてのウィジェットに存在することを意味します。 // {{apos.singleton(data.widget、 'images'、 'apostrophe-images'、{edit:false})}} 次のような検索が行われます アポストロフィウィジェットラッパー(.container) アポストロフィウィジェット(.row) アポストロフィウィジェットラッパー(.container) –

+0

ああ、素晴らしい点。グリッドウィジェット内に追加のウィジェットを入れ子にしていると、それがどのように複雑になるかを見ることができます。現時点では他に選択肢がありませんが、探している動作を達成するために特定のコアテンプレートをオーバーライドする方法がいくつかあります。 –

関連する問題