office-ui-fabric-react
Version: 
Reusable React components for building experiences for Office 365.
167 lines (165 loc) • 9.66 kB
JavaScript
define(["require", "exports", "tslib", "react", "office-ui-fabric-react/lib/Button", "office-ui-fabric-react/lib/Checkbox", "office-ui-fabric-react/lib/ContextualMenu", "office-ui-fabric-react/lib/Dropdown", "office-ui-fabric-react/lib/Slider", "office-ui-fabric-react/lib/Utilities", "./ContextualMenuExample.scss"], function (require, exports, tslib_1, React, Button_1, Checkbox_1, ContextualMenu_1, Dropdown_1, Slider_1, Utilities_1) {
    "use strict";
    Object.defineProperty(exports, "__esModule", { value: true });
    var DIRECTION_OPTIONS = [
        { key: ContextualMenu_1.DirectionalHint[ContextualMenu_1.DirectionalHint.topLeftEdge], text: 'Top Left Edge' },
        { key: ContextualMenu_1.DirectionalHint[ContextualMenu_1.DirectionalHint.topCenter], text: 'Top Center' },
        { key: ContextualMenu_1.DirectionalHint[ContextualMenu_1.DirectionalHint.topRightEdge], text: 'Top Right Edge' },
        { key: ContextualMenu_1.DirectionalHint[ContextualMenu_1.DirectionalHint.topAutoEdge], text: 'Top Auto Edge' },
        { key: ContextualMenu_1.DirectionalHint[ContextualMenu_1.DirectionalHint.bottomLeftEdge], text: 'Bottom Left Edge' },
        { key: ContextualMenu_1.DirectionalHint[ContextualMenu_1.DirectionalHint.bottomCenter], text: 'Bottom Center' },
        { key: ContextualMenu_1.DirectionalHint[ContextualMenu_1.DirectionalHint.bottomRightEdge], text: 'Bottom Right Edge' },
        { key: ContextualMenu_1.DirectionalHint[ContextualMenu_1.DirectionalHint.bottomAutoEdge], text: 'Bottom Auto Edge' },
        { key: ContextualMenu_1.DirectionalHint[ContextualMenu_1.DirectionalHint.leftTopEdge], text: 'Left Top Edge' },
        { key: ContextualMenu_1.DirectionalHint[ContextualMenu_1.DirectionalHint.leftCenter], text: 'Left Center' },
        { key: ContextualMenu_1.DirectionalHint[ContextualMenu_1.DirectionalHint.leftBottomEdge], text: 'Left Bottom Edge' },
        { key: ContextualMenu_1.DirectionalHint[ContextualMenu_1.DirectionalHint.rightTopEdge], text: 'Right Top Edge' },
        { key: ContextualMenu_1.DirectionalHint[ContextualMenu_1.DirectionalHint.rightCenter], text: 'Right Center' },
        { key: ContextualMenu_1.DirectionalHint[ContextualMenu_1.DirectionalHint.rightBottomEdge], text: 'Right Bottom Edge' },
    ];
    var ContextualMenuDirectionalExample = (function (_super) {
        tslib_1.__extends(ContextualMenuDirectionalExample, _super);
        function ContextualMenuDirectionalExample() {
            var _this = _super.call(this) || this;
            _this.state = {
                isContextualMenuVisible: false,
                isBeakVisible: false,
                directionalHint: ContextualMenu_1.DirectionalHint.bottomLeftEdge,
                gapSpace: 0,
                beakWidth: 10,
                edgeFixed: false
            };
            return _this;
        }
        ContextualMenuDirectionalExample.prototype.render = function () {
            var _a = this.state, isContextualMenuVisible = _a.isContextualMenuVisible, isBeakVisible = _a.isBeakVisible, directionalHint = _a.directionalHint, gapSpace = _a.gapSpace, beakWidth = _a.beakWidth, edgeFixed = _a.edgeFixed;
            return (React.createElement("div", { className: 'ms-ContextualMenuDirectionalExample' },
                React.createElement("div", { className: 'ms-ContextualMenuDirectionalExample-configArea' },
                    React.createElement(Checkbox_1.Checkbox, { label: 'Show beak', checked: isBeakVisible, onChange: this._onShowBeakChange }),
                    React.createElement(Checkbox_1.Checkbox, { label: 'Fix Edge', checked: edgeFixed, onChange: this._onFixEdgeChange }),
                    React.createElement(Slider_1.Slider, { max: 20, label: 'Gap Space', min: 0, defaultValue: 0, onChange: this._onGapSlider }),
                    isBeakVisible &&
                        (React.createElement(Slider_1.Slider, { max: 50, label: 'Beak Width', min: 10, defaultValue: 10, onChange: this._onBeakWidthSlider })),
                    React.createElement(Dropdown_1.Dropdown, { label: 'Directional hint', selectedKey: ContextualMenu_1.DirectionalHint[directionalHint], options: DIRECTION_OPTIONS, onChanged: this._onDirectionalChanged })),
                React.createElement("div", { className: 'ms-ContextualMenuDirectionalExample-buttonArea', ref: 'menuButton' },
                    React.createElement(Button_1.DefaultButton, { onClick: this._onShowMenuClicked, text: isContextualMenuVisible ? 'Hide context menu' : 'Show context menu' })),
                isContextualMenuVisible ? (React.createElement(ContextualMenu_1.ContextualMenu, { target: this.refs.menuButton, isBeakVisible: isBeakVisible, directionalHint: directionalHint, gapSpace: gapSpace, beakWidth: beakWidth, directionalHintFixed: edgeFixed, items: [
                        {
                            key: 'newItem',
                            name: 'New',
                            icon: 'Add',
                            subMenuProps: {
                                items: [
                                    {
                                        key: 'emailMessage',
                                        name: 'Email message',
                                    },
                                    {
                                        key: 'calendarEvent',
                                        name: 'Calendar event',
                                    }
                                ]
                            },
                        },
                        {
                            key: 'upload',
                            name: 'Upload',
                            icon: 'Upload'
                        },
                        {
                            key: 'rename',
                            name: 'Rename',
                        },
                        {
                            key: '-',
                            itemType: ContextualMenu_1.ContextualMenuItemType.Divider
                        },
                        {
                            key: 'share',
                            name: 'Share',
                            icon: 'Share',
                            items: [
                                {
                                    key: 'sharetoemail',
                                    name: 'Share to Email',
                                    icon: 'Mail'
                                },
                                {
                                    key: 'sharetofacebook',
                                    name: 'Share to Facebook',
                                },
                                {
                                    key: 'sharetotwitter',
                                    name: 'Share to Twitter',
                                    icon: 'Share'
                                },
                            ]
                        },
                        {
                            key: 'print',
                            name: 'Print',
                            icon: 'Print'
                        },
                        {
                            key: 'display',
                            name: 'display'
                        },
                        {
                            key: 'properties',
                            name: 'Properties'
                        },
                    ] })) : (null)));
        };
        ContextualMenuDirectionalExample.prototype._onShowBeakChange = function (ev, isVisible) {
            this.setState({
                isBeakVisible: isVisible
            });
        };
        ContextualMenuDirectionalExample.prototype._onFixEdgeChange = function (ev, isVisible) {
            this.setState({
                edgeFixed: isVisible
            });
        };
        ContextualMenuDirectionalExample.prototype._onShowMenuClicked = function () {
            this.setState({
                isContextualMenuVisible: !this.state.isContextualMenuVisible
            });
        };
        ContextualMenuDirectionalExample.prototype._onDirectionalChanged = function (option) {
            this.setState({
                directionalHint: ContextualMenu_1.DirectionalHint[option.key]
            });
        };
        ContextualMenuDirectionalExample.prototype._onGapSlider = function (value) {
            this.setState({
                gapSpace: value
            });
        };
        ContextualMenuDirectionalExample.prototype._onBeakWidthSlider = function (value) {
            this.setState({
                beakWidth: value
            });
        };
        return ContextualMenuDirectionalExample;
    }(React.Component));
    tslib_1.__decorate([
        Utilities_1.autobind
    ], ContextualMenuDirectionalExample.prototype, "_onShowBeakChange", null);
    tslib_1.__decorate([
        Utilities_1.autobind
    ], ContextualMenuDirectionalExample.prototype, "_onFixEdgeChange", null);
    tslib_1.__decorate([
        Utilities_1.autobind
    ], ContextualMenuDirectionalExample.prototype, "_onShowMenuClicked", null);
    tslib_1.__decorate([
        Utilities_1.autobind
    ], ContextualMenuDirectionalExample.prototype, "_onDirectionalChanged", null);
    tslib_1.__decorate([
        Utilities_1.autobind
    ], ContextualMenuDirectionalExample.prototype, "_onGapSlider", null);
    tslib_1.__decorate([
        Utilities_1.autobind
    ], ContextualMenuDirectionalExample.prototype, "_onBeakWidthSlider", null);
    exports.ContextualMenuDirectionalExample = ContextualMenuDirectionalExample;
});
//# sourceMappingURL=ContextualMenu.Directional.Example.js.map