Skip to content
This repository has been archived by the owner on Dec 2, 2021. It is now read-only.

Latest commit

 

History

History
56 lines (48 loc) · 2.07 KB

CollectionLayout.md

File metadata and controls

56 lines (48 loc) · 2.07 KB

CollectionLayout

Lays a collection of renderables from left to right or top to bottom, and when the right/bottom edge is reached, continues at the next column/row.

options type description
[itemSize] Size/Function Size of an item to layout or callback function which should return the size, e.g.: function(renderNode, contextSize)
[cells] Array.Number Number of columns and rows: [columns, rows]. When used causes the itemSize to be calculated from the number of number of cells that should be displayed.
[margins] Number/Array Margins shorthand (e.g. 5, [10, 20], [2, 5, 2, 10])
[spacing] Number/Array Spacing between items (e.g. 5, [10, 10])
[justify] Bool/Array.Bool Justify the renderables accross the width/height

Example:

var CollectionLayout = require('famous-flex/layouts/CollectionLayout');

// Create scrollable layout where items have a fixed width/height
var scrollView = new FlexScrollView({
  layout: CollectionLayout,
  layoutOptions: {
    itemSize: [100, 100],    // item has width and height of 100 pixels
    margins: [10, 5, 10, 5], // outer margins
    spacing: [10, 10]        // spacing between items
  },
  dataSource: [
    new Surface({content: 'item 1'}),
    new Surface({content: 'item 2'}),
    new Surface({content: 'item 3'})
  ]
});

// Create grid layout with a fixed number of columns and rows.
var gridLayout = new LayoutController({
  layout: CollectionLayout,
  layoutOptions: {
    cells: [3, 5],           // 3 columns and 5 rows
    margins: [10, 5, 10, 5], // outer margins
    spacing: [10, 10]        // spacing between items
  },
  dataSource: [
    new Surface({content: 'item 1'}),
    new Surface({content: 'item 2'}),
    new Surface({content: 'item 3'})
  ]
});

Notes:

  • Recall that the direction option is given to FlexScrollView and not the ColllectionLayout. As such, it affects scroll direction and not layout direction. With direction Y, items are laid out horizontally, but multiple rows scroll vertically, and this is the correct behaviour.