focus-components-v3
Version:
Focus web components to build applications (based on Material Design)
323 lines (277 loc) • 35.5 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _i18next = require('i18next');
var _i18next2 = _interopRequireDefault(_i18next);
var _button = require('../button');
var _button2 = _interopRequireDefault(_button);
var _reactRouter = require('react-router');
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _defaults(obj, defaults) { var keys = Object.getOwnPropertyNames(defaults); for (var i = 0; i < keys.length; i++) { var key = keys[i]; var value = Object.getOwnPropertyDescriptor(defaults, key); if (value && value.configurable && obj[key] === undefined) { Object.defineProperty(obj, key, value); } } return obj; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : _defaults(subClass, superClass); }
var defaultButtonProps = { icon: 'link', shape: 'icon', type: 'button' };
var MenuPanel = function MenuPanel(_ref) {
var children = _ref.children,
onClose = _ref.onClose;
var style = { 'width': document.body.clientWidth };
return _react2.default.createElement(
'div',
{ className: 'animate-menu', 'data-focus': 'menu-sub-panel', style: style, onClick: onClose },
_react2.default.createElement(
'div',
null,
children
)
);
};
MenuPanel.displayName = 'MenuPanel';
MenuPanel.PropTypes = {
onClose: _react.PropTypes.func
};
var MenuItem = function (_Component) {
_inherits(MenuItem, _Component);
function MenuItem(props) {
_classCallCheck(this, MenuItem);
var _this = _possibleConstructorReturn(this, _Component.call(this, props));
_this.state = {
displaySubMenu: false
};
_this._toggleSubMenuVisibility = _this._toggleSubMenuVisibility.bind(_this);
return _this;
}
MenuItem.prototype._toggleSubMenuVisibility = function _toggleSubMenuVisibility() {
var _props = this.props,
showLabels = _props.showLabels,
showPanel = _props.showPanel;
if (showLabels && !showPanel) {
var displaySubMenu = this.state.displaySubMenu;
this.setState({ displaySubMenu: !displaySubMenu });
}
};
MenuItem.prototype.findPathnameInPossibleRoute = function findPathnameInPossibleRoute(possibleRoutes, pathname) {
return possibleRoutes.reduce(function (acc, element) {
if (pathname.indexOf(element) !== -1) {
acc = true;
}
return acc;
}, false);
};
MenuItem.prototype.setActiveListClassName = function setActiveListClassName(route, homePath, pathname, possibleRoutes, isActive, hasSubMenus) {
if (route) {
if (route === homePath && pathname !== homePath || !isActive) {
return '';
} else if (pathname === route || possibleRoutes && this.findPathnameInPossibleRoute(possibleRoutes, pathname)) {
return 'activeList';
}
} else if (possibleRoutes && this.findPathnameInPossibleRoute(possibleRoutes, pathname)) {
return 'activeList';
}
return '';
};
MenuItem.prototype.render = function render() {
var _props2 = this.props,
menu = _props2.menu,
isActive = _props2.isActive,
onClick = _props2.onClick,
onClose = _props2.onClose,
showLabels = _props2.showLabels,
showPanel = _props2.showPanel,
homePath = _props2.homePath,
pathname = _props2.pathname;
var route = menu.route,
label = menu.label,
icon = menu.icon,
iconLibrary = menu.iconLibrary,
subMenus = menu.subMenus,
possibleRoutes = menu.possibleRoutes;
var displaySubMenu = this.state.displaySubMenu;
var buttonProps = _extends({}, defaultButtonProps, { label: label, icon: !showLabels && icon === undefined ? 'link' : icon, iconLibrary: iconLibrary, shape: showLabels ? null : 'icon', onClick: onClick });
var hasSubMenus = subMenus && subMenus.length > 0;
if (hasSubMenus) {
return _react2.default.createElement(
'li',
{ 'data-deployed': isActive, className: this.setActiveListClassName(route, homePath, pathname, possibleRoutes, isActive, hasSubMenus) },
_react2.default.createElement(_button2.default, _extends({}, buttonProps, { onClick: showPanel ? onClick : this._toggleSubMenuVisibility })),
displaySubMenu && _react2.default.createElement(
'ul',
{ 'data-focus': 'menu-sub-items' },
subMenus.map(function (menu, idx) {
return _react2.default.createElement(MenuItem, { key: idx, menu: menu, onClose: onClose, showLabels: showLabels });
})
)
);
} else {
var _onClick = buttonProps.onClick;
buttonProps.handleOnClick = _onClick;
return _react2.default.createElement(
'li',
{ className: this.setActiveListClassName(route, homePath, pathname, possibleRoutes, isActive, hasSubMenus) },
route && _react2.default.createElement(
_reactRouter.Link,
{ to: route, onClick: onClose },
_react2.default.createElement(_button2.default, buttonProps)
),
!route && _react2.default.createElement(_button2.default, buttonProps)
);
}
};
return MenuItem;
}(_react.Component);
;
MenuItem.displayName = 'MenuItem';
MenuItem.PropTypes = {
menu: _react.PropTypes.object.isRequired,
isActive: _react.PropTypes.bool,
onClick: _react.PropTypes.func,
onClose: _react.PropTypes.func,
showLabels: _react.PropTypes.bool.isRequired,
showPanel: _react.PropTypes.bool.isRequired
};
var MenuList = function MenuList(_ref2) {
var activeMenuId = _ref2.activeMenuId,
menus = _ref2.menus,
_ref2$offset = _ref2.offset,
offset = _ref2$offset === undefined ? 0 : _ref2$offset,
_onClick2 = _ref2.onClick,
onClose = _ref2.onClose,
showLabels = _ref2.showLabels,
showPanel = _ref2.showPanel,
homePath = _ref2.homePath,
pathname = _ref2.pathname;
var style = { 'position': 'relative', 'top': offset };
return _react2.default.createElement(
'ul',
{ 'data-focus': 'menu-items', style: style },
menus.map(function (menu, idx) {
var isActive = activeMenuId ? activeMenuId === idx : -1;
var route = menu.route,
label = menu.label,
icon = menu.icon,
subMenus = menu.subMenus;
var buttonProps = _extends({}, defaultButtonProps, { label: label, icon: !showLabels && icon === undefined ? 'link' : icon, shape: showLabels ? null : 'icon' });
return _react2.default.createElement(MenuItem, { key: idx, menu: menu, onClick: function onClick(evt) {
return _onClick2 && _onClick2(evt, idx);
}, homePath: homePath, onClose: onClose, isActive: isActive, pathname: pathname, showLabels: showLabels, showPanel: showPanel });
})
);
};
MenuList.displayName = 'MenuList';
MenuList.PropTypes = {
activeMenuId: _react.PropTypes.number,
menus: _react.PropTypes.array.isRequired,
onClick: _react.PropTypes.func,
onClose: _react.PropTypes.func,
showLabels: _react.PropTypes.bool.isRequired,
showPanel: _react.PropTypes.bool.isRequired
};
/**
*
* Requested data.
* [
* { icon: 'home', label: 'menu.home', route: '/' }, // route: 'home'
* { icon: 'search', label: 'menu.search', handleOnClick: () => toto() }},
* { label: 'menu.test', route: '/admin/masterdata', subMenus: [
* { label: 'menu.home', route: '/' },
* { label: 'menu.home', route: '/' },
* { label: 'menu.home', route: '/' },
* { label: 'menu.home', route: '/' }
* ]},
* { icon: 'settings', label: 'menu.admin', route: '/admin/masterdata', subMenus: [
* { icon: 'settings', label: 'menu.home', route: '/' },
* { icon: 'settings', label: 'menu.home', route: '/' },
* { icon: 'settings', label: 'menu.home', route: '/' },
* { icon: 'settings', label: 'menu.home', route: '/' }
* ]},
* ];
*
*/
var Menu = function (_Component2) {
_inherits(Menu, _Component2);
function Menu(props) {
_classCallCheck(this, Menu);
var _this2 = _possibleConstructorReturn(this, _Component2.call(this, props));
var subMenus = [];
props.menus.map(function (menu, idx) {
subMenus[idx] = menu.subMenus;
});
_this2.state = {
activeMenuId: null,
subMenus: subMenus,
yPosition: 0
};
_this2._onSelectMenu = _this2._onSelectMenu.bind(_this2);
_this2._onSubPanelClose = _this2._onSubPanelClose.bind(_this2);
return _this2;
}
Menu.prototype._onSelectMenu = function _onSelectMenu(evt, menuId) {
var targetPosition = evt.target.getBoundingClientRect();
this.setState({
activeMenuId: menuId,
yPosition: targetPosition.top - 35 //TODO temporary : to improve
});
};
Menu.prototype._onSubPanelClose = function _onSubPanelClose() {
this.setState({
activeMenuId: null
});
};
Menu.prototype.render = function render() {
var _props3 = this.props,
children = _props3.children,
handleBrandClick = _props3.handleBrandClick,
menus = _props3.menus,
showLabels = _props3.showLabels,
showPanel = _props3.showPanel,
homePath = _props3.homePath,
pathname = _props3.pathname;
var size = showLabels ? 'large' : 'small';
var _state = this.state,
activeMenuId = _state.activeMenuId,
subMenus = _state.subMenus,
yPosition = _state.yPosition;
var displayPanel = activeMenuId && subMenus[activeMenuId];
var subMenuItems = subMenus[activeMenuId];
return _react2.default.createElement(
'nav',
{ 'data-focus': 'menu', 'data-size': size },
_react2.default.createElement(
'div',
null,
_react2.default.createElement('div', { 'data-focus': 'menu-brand', 'data-click': !!handleBrandClick, onClick: function onClick() {
return handleBrandClick && handleBrandClick();
} }),
_react2.default.createElement(MenuList, { activeMenuId: activeMenuId, menus: menus, onClick: this._onSelectMenu, homePath: homePath, pathname: pathname, showLabels: showLabels, showPanel: showPanel }),
children,
showPanel && subMenuItems && _react2.default.createElement(
MenuPanel,
{ onClose: this._onSubPanelClose },
_react2.default.createElement(MenuList, { offset: yPosition, menus: subMenuItems, onClose: this._onSubPanelClose, showLabels: true, showPanel: false })
)
)
);
};
return Menu;
}(_react.Component);
Menu.displayName = 'Menu';
Menu.propTypes = {
handleBrandClick: _react.PropTypes.func,
menus: _react.PropTypes.array.isRequired,
homePath: _react.PropTypes.string,
pathname: _react.PropTypes.string,
showPanel: _react.PropTypes.bool,
showLabels: _react.PropTypes.bool
};
Menu.defaultProps = {
menus: [],
showLabels: false,
showPanel: true
};
exports.default = Menu;
module.exports = exports['default'];
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["fr-FR.js"],"names":["defaultButtonProps","icon","shape","type","MenuPanel","children","onClose","style","document","body","clientWidth","displayName","PropTypes","func","MenuItem","props","state","displaySubMenu","_toggleSubMenuVisibility","bind","showLabels","showPanel","setState","findPathnameInPossibleRoute","possibleRoutes","pathname","reduce","acc","element","indexOf","setActiveListClassName","route","homePath","isActive","hasSubMenus","render","menu","onClick","label","iconLibrary","subMenus","buttonProps","undefined","length","map","idx","handleOnClick","object","isRequired","bool","MenuList","activeMenuId","menus","offset","evt","number","array","Menu","yPosition","_onSelectMenu","_onSubPanelClose","menuId","targetPosition","target","getBoundingClientRect","top","handleBrandClick","size","displayPanel","subMenuItems","propTypes","string","defaultProps"],"mappings":"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","file":"fr-FR.js","sourcesContent":["import React, {Component, PropTypes} from 'react';\r\nimport i18next from 'i18next';\r\nimport Button from '../button';\r\nimport {Link} from 'react-router';\r\n\r\nconst defaultButtonProps = {icon: 'link', shape: 'icon', type: 'button'};\r\n\r\nconst MenuPanel = ({children, onClose}) => {\r\n    const style = { 'width': document.body.clientWidth }\r\n    return (\r\n        <div className='animate-menu' data-focus='menu-sub-panel' style={style} onClick={onClose}>\r\n            <div>\r\n                {children}\r\n            </div>\r\n        </div>\r\n    );\r\n}\r\nMenuPanel.displayName = 'MenuPanel';\r\nMenuPanel.PropTypes = {\r\n    onClose: PropTypes.func\r\n};\r\n\r\nclass MenuItem extends Component {\r\n    constructor(props) {\r\n        super(props);\r\n        this.state = {\r\n            displaySubMenu: false\r\n        };\r\n        this._toggleSubMenuVisibility = this._toggleSubMenuVisibility.bind(this);\r\n    }\r\n    _toggleSubMenuVisibility() {\r\n        const {showLabels, showPanel} = this.props;\r\n        if(showLabels && !showPanel) {\r\n            const {displaySubMenu} = this.state;\r\n            this.setState({displaySubMenu: !displaySubMenu});\r\n        }\r\n    }\r\n\r\n    findPathnameInPossibleRoute(possibleRoutes, pathname){\r\n      return possibleRoutes.reduce((acc, element) => {\r\n         if(pathname.indexOf(element) !== -1) {\r\n            acc = true;\r\n          }\r\n          return acc;\r\n        },false)\r\n    }\r\n    setActiveListClassName(route, homePath, pathname,possibleRoutes, isActive, hasSubMenus) {\r\n        if(route ) {\r\n            if((route === homePath && pathname !== homePath )|| !isActive) {\r\n                return ''\r\n            } else if (pathname=== route || (possibleRoutes && this.findPathnameInPossibleRoute(possibleRoutes, pathname)) ) {\r\n                return 'activeList';\r\n            }\r\n        }else if (possibleRoutes && this.findPathnameInPossibleRoute(possibleRoutes, pathname)) {\r\n          return 'activeList';\r\n        }\r\n        return '';\r\n    }\r\n    render() {\r\n        const {menu, isActive, onClick, onClose, showLabels, showPanel, homePath, pathname} = this.props;\r\n        const {route, label, icon, iconLibrary, subMenus, possibleRoutes} = menu;\r\n        const {displaySubMenu} = this.state;\r\n        const buttonProps = {...defaultButtonProps, label, icon: (!showLabels && icon === undefined ? 'link' : icon), iconLibrary, shape: (showLabels ? null : 'icon'), onClick};\r\n        const hasSubMenus = subMenus && subMenus.length > 0;\r\n        if(hasSubMenus) {\r\n            return (\r\n                <li data-deployed={isActive} className={this.setActiveListClassName(route, homePath, pathname,possibleRoutes, isActive,hasSubMenus)}>\r\n                    <Button {...buttonProps} onClick={showPanel ? onClick : this._toggleSubMenuVisibility} />\r\n                    {displaySubMenu &&\r\n                        <ul data-focus='menu-sub-items'>\r\n                            {subMenus.map((menu, idx) => (\r\n                                <MenuItem key={idx} menu={menu} onClose={onClose} showLabels={showLabels} />\r\n                            ))}\r\n                        </ul>\r\n                    }\r\n                </li>\r\n            );\r\n        } else {\r\n            const {onClick} = buttonProps;\r\n            buttonProps.handleOnClick = onClick\r\n            return (\r\n                <li className={this.setActiveListClassName(route, homePath, pathname,possibleRoutes , isActive, hasSubMenus)}>\r\n                    {route && <Link to={route} onClick={onClose}><Button {...buttonProps} /></Link>}\r\n                    {!route && <Button {...buttonProps} />}\r\n                </li>\r\n            );\r\n        }\r\n    }\r\n};\r\nMenuItem.displayName = 'MenuItem';\r\nMenuItem.PropTypes = {\r\n    menu: PropTypes.object.isRequired,\r\n    isActive: PropTypes.bool,\r\n    onClick: PropTypes.func,\r\n    onClose: PropTypes.func,\r\n    showLabels: PropTypes.bool.isRequired,\r\n    showPanel: PropTypes.bool.isRequired\r\n};\r\n\r\n\r\nconst MenuList = ({activeMenuId, menus, offset = 0, onClick, onClose, showLabels, showPanel, homePath, pathname}) => {\r\n    const style = {'position': 'relative', 'top': offset };\r\n    return (\r\n        <ul data-focus='menu-items' style={style}>\r\n            {menus.map((menu, idx) => {\r\n                const isActive = activeMenuId ? activeMenuId === idx : -1;\r\n                const {route, label, icon, subMenus} = menu;\r\n                const buttonProps = {...defaultButtonProps, label, icon: (!showLabels && icon === undefined ? 'link' : icon), shape: (showLabels ? null : 'icon')};\r\n                return (\r\n                    <MenuItem key={idx} menu={menu} onClick={(evt) => onClick && onClick(evt, idx)} homePath={homePath} onClose={onClose} isActive={isActive} pathname={pathname} showLabels={showLabels} showPanel={showPanel} />\r\n                );\r\n            })}\r\n        </ul>\r\n    );\r\n};\r\nMenuList.displayName = 'MenuList';\r\nMenuList.PropTypes = {\r\n    activeMenuId: PropTypes.number,\r\n    menus: PropTypes.array.isRequired,\r\n    onClick: PropTypes.func,\r\n    onClose: PropTypes.func,\r\n    showLabels: PropTypes.bool.isRequired,\r\n    showPanel: PropTypes.bool.isRequired\r\n};\r\n\r\n\r\n/**\r\n *\r\n * Requested data.\r\n * [\r\n *    { icon: 'home', label: 'menu.home', route: '/' }, // route: 'home'\r\n *    { icon: 'search', label: 'menu.search', handleOnClick: () => toto() }},\r\n *    { label: 'menu.test', route: '/admin/masterdata', subMenus: [\r\n *        { label: 'menu.home', route: '/' },\r\n *        { label: 'menu.home', route: '/' },\r\n *        { label: 'menu.home', route: '/' },\r\n *        { label: 'menu.home', route: '/' }\r\n *    ]},\r\n *    { icon: 'settings', label: 'menu.admin', route: '/admin/masterdata', subMenus: [\r\n *        { icon: 'settings', label: 'menu.home', route: '/' },\r\n *        { icon: 'settings', label: 'menu.home', route: '/' },\r\n *        { icon: 'settings', label: 'menu.home', route: '/' },\r\n *        { icon: 'settings', label: 'menu.home', route: '/' }\r\n *    ]},\r\n * ];\r\n *\r\n */\r\nclass Menu extends Component {\r\n    constructor(props) {\r\n        super(props);\r\n        const subMenus = [];\r\n        props.menus.map((menu, idx) => {\r\n            subMenus[idx] = menu.subMenus;\r\n        });\r\n        this.state = {\r\n            activeMenuId: null,\r\n            subMenus,\r\n            yPosition: 0\r\n        };\r\n        this._onSelectMenu = this._onSelectMenu.bind(this);\r\n        this._onSubPanelClose = this._onSubPanelClose.bind(this);\r\n    }\r\n    _onSelectMenu(evt, menuId) {\r\n        const targetPosition = evt.target.getBoundingClientRect();\r\n        this.setState({\r\n            activeMenuId: menuId,\r\n            yPosition: targetPosition.top - 35 //TODO temporary : to improve\r\n        });\r\n    }\r\n    _onSubPanelClose() {\r\n        this.setState({\r\n            activeMenuId: null\r\n        })\r\n    }\r\n    render() {\r\n        const { children, handleBrandClick, menus, showLabels, showPanel, homePath, pathname } = this.props;\r\n        const size = showLabels ? 'large' : 'small';\r\n        const {activeMenuId, subMenus, yPosition} = this.state;\r\n        const displayPanel = activeMenuId && subMenus[activeMenuId];\r\n        const subMenuItems = subMenus[activeMenuId];\r\n        return (\r\n            <nav data-focus='menu' data-size={size}>\r\n                <div>\r\n                    <div data-focus='menu-brand' data-click={!!handleBrandClick} onClick={() => handleBrandClick && handleBrandClick()} />\r\n                    <MenuList activeMenuId={activeMenuId} menus={menus} onClick={this._onSelectMenu} homePath={homePath} pathname={pathname} showLabels={showLabels} showPanel={showPanel} />\r\n                    {children}\r\n                    {showPanel && subMenuItems &&\r\n                        <MenuPanel onClose={this._onSubPanelClose}>\r\n                            <MenuList offset={yPosition} menus={subMenuItems} onClose={this._onSubPanelClose} showLabels={true} showPanel={false} />\r\n                        </MenuPanel>\r\n                    }\r\n                </div>\r\n            </nav>\r\n        );\r\n    };\r\n}\r\nMenu.displayName = 'Menu';\r\nMenu.propTypes = {\r\n    handleBrandClick: PropTypes.func,\r\n    menus: PropTypes.array.isRequired,\r\n    homePath: PropTypes.string,\r\n    pathname: PropTypes.string,\r\n    showPanel: PropTypes.bool,\r\n    showLabels: PropTypes.bool\r\n};\r\nMenu.defaultProps =  {\r\n    menus: [],\r\n    showLabels: false,\r\n    showPanel: true\r\n};\r\nexport default Menu;\r\n"]}