UNPKG

office-ui-fabric-react

Version:

Reusable React components for building experiences for Office 365.

106 lines 6.42 kB
define(["require", "exports", "tslib", "react", "office-ui-fabric-react/lib/Dropdown", "office-ui-fabric-react/lib/Slider", "office-ui-fabric-react/lib/Stack", "office-ui-fabric-react/lib/Styling"], function (require, exports, tslib_1, React, Dropdown_1, Slider_1, Stack_1, Styling_1) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); // Non-mutating styles definition var itemStyles = { alignItems: 'center', background: Styling_1.DefaultPalette.themePrimary, color: Styling_1.DefaultPalette.white, display: 'flex', height: 50, justifyContent: 'center', width: 50 }; // Tokens definition var sectionStackTokens = { childrenGap: 10 }; var configureStackTokens = { childrenGap: 20 }; var wrapStackTokens = { childrenGap: 30 }; var HorizontalStackWrapAdvancedExampleContent = function (props) { var stackWidth = props.stackWidth, containerHeight = props.containerHeight, overflow = props.overflow, horizontalAlignment = props.horizontalAlignment, verticalAlignment = props.verticalAlignment; // Mutating styles definition var stackStyles = { root: { background: Styling_1.DefaultPalette.themeTertiary, width: stackWidth + "%", overflow: overflow } }; var containerStyles = { height: containerHeight }; return (React.createElement("div", { style: containerStyles }, React.createElement(Stack_1.Stack, { horizontal: true, verticalFill: true, wrap: true, horizontalAlign: horizontalAlignment, verticalAlign: verticalAlignment, styles: stackStyles, tokens: wrapStackTokens }, _range(1, 10).map(function (n) { return (React.createElement("span", { style: itemStyles, key: n }, n)); })))); }; function _range(start, end) { var result = []; for (var i = start; i <= end; i++) { result.push(i); } return result; } var HorizontalStackWrapAdvancedExample = /** @class */ (function (_super) { tslib_1.__extends(HorizontalStackWrapAdvancedExample, _super); function HorizontalStackWrapAdvancedExample() { var _this = _super !== null && _super.apply(this, arguments) || this; _this.state = { stackWidth: 100, containerHeight: 150, horizontalAlignment: 'start', verticalAlignment: 'start', overflow: 'visible' }; _this._horizontalAlignmentOptions = [ { key: 'start', text: 'Left' }, { key: 'center', text: 'Center' }, { key: 'end', text: 'Right' }, { key: 'space-around', text: 'Space around' }, { key: 'space-between', text: 'Space between' }, { key: 'space-evenly', text: 'Space evenly' } ]; _this._verticalAlignmentOptions = [ { key: 'start', text: 'Top' }, { key: 'center', text: 'Center' }, { key: 'end', text: 'Bottom' } ]; _this._overflowOptions = [ { key: 'visible', text: 'Visible' }, { key: 'auto', text: 'Auto' }, { key: 'hidden', text: 'Hidden' } ]; _this._onWidthChange = function (value) { _this.setState({ stackWidth: value }); }; _this._onHeightChange = function (value) { _this.setState({ containerHeight: value }); }; _this._onHorizontalAlignChange = function (ev, option) { _this.setState({ horizontalAlignment: option.key }); }; _this._onVerticalAlignChange = function (ev, option) { _this.setState({ verticalAlignment: option.key }); }; _this._onOverflowChange = function (ev, option) { _this.setState({ overflow: option.key }); }; return _this; } HorizontalStackWrapAdvancedExample.prototype.render = function () { var _a = this.state, overflow = _a.overflow, horizontalAlignment = _a.horizontalAlignment, verticalAlignment = _a.verticalAlignment; return (React.createElement(Stack_1.Stack, { tokens: sectionStackTokens }, React.createElement(Stack_1.Stack, { horizontal: true }, React.createElement(Stack_1.Stack.Item, { grow: true }, React.createElement(Slider_1.Slider, { label: "Stack width:", min: 1, max: 100, step: 1, defaultValue: 100, showValue: true, onChange: this._onWidthChange })), React.createElement(Stack_1.Stack.Item, { grow: true }, React.createElement(Slider_1.Slider, { label: "Container height:", min: 1, max: 200, step: 1, defaultValue: 150, showValue: true, onChange: this._onHeightChange }))), React.createElement(Stack_1.Stack, { horizontal: true, tokens: configureStackTokens }, React.createElement(Stack_1.Stack.Item, { grow: true }, React.createElement(Dropdown_1.Dropdown, { selectedKey: horizontalAlignment, placeholder: "Select Horizontal Alignment", label: "Horizontal alignment:", options: this._horizontalAlignmentOptions, onChange: this._onHorizontalAlignChange })), React.createElement(Stack_1.Stack.Item, { grow: true }, React.createElement(Dropdown_1.Dropdown, { selectedKey: verticalAlignment, placeholder: "Select Vertical Alignment", label: "Vertical alignment:", options: this._verticalAlignmentOptions, onChange: this._onVerticalAlignChange })), React.createElement(Stack_1.Stack.Item, { grow: true }, React.createElement(Dropdown_1.Dropdown, { selectedKey: overflow, placeholder: "Select Overflow", label: "Overflow:", options: this._overflowOptions, onChange: this._onOverflowChange }))), React.createElement(HorizontalStackWrapAdvancedExampleContent, tslib_1.__assign({}, this.state)))); }; return HorizontalStackWrapAdvancedExample; }(React.Component)); exports.HorizontalStackWrapAdvancedExample = HorizontalStackWrapAdvancedExample; }); //# sourceMappingURL=Stack.Horizontal.WrapAdvanced.Example.js.map