UNPKG

@atlaskit/editor-common

Version:

A package that contains common classes and components for editor and renderer

334 lines (330 loc) • 13.1 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _react = _interopRequireWildcard(require("react")); var _react2 = require("@emotion/react"); var _reactIntlNext = require("react-intl-next"); var _analyticsNext = require("@atlaskit/analytics-next"); var _analytics = require("../../analytics"); var _constants = require("../constants"); var _useContainerWidth2 = _interopRequireDefault(require("../hooks/use-container-width")); var _useSelectAndFocusOnArrowNavigation = _interopRequireDefault(require("../hooks/use-select-and-focus-on-arrow-navigation")); var _ViewMore = require("../ViewMore"); var _CategoryList = _interopRequireDefault(require("./CategoryList")); var _ElementList = _interopRequireDefault(require("./ElementList/ElementList")); var _ElementSearch = _interopRequireDefault(require("./ElementSearch")); function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } /** @jsx jsx */ var wrapper = (0, _react2.css)({ width: '100%', maxHeight: 'inherit', overflow: 'hidden' }); var baseBrowserContainerStyles = (0, _react2.css)({ display: 'flex', height: '100%', minHeight: '-webkit-fill-available' }); var mobileElementBrowserContainer = (0, _react2.css)(baseBrowserContainerStyles, { flexDirection: 'column' }); var elementBrowserContainer = (0, _react2.css)(baseBrowserContainerStyles, { flexDirection: 'row' }); var baseSidebarStyles = (0, _react2.css)({ display: 'flex', flexDirection: 'column', overflowX: 'auto', overflowY: 'hidden' }); var mobileSideBar = (0, _react2.css)(baseSidebarStyles, { flex: "0 0 ".concat(_constants.INLINE_SIDEBAR_HEIGHT), padding: "var(--ds-space-150, 12px)".concat(" ", "var(--ds-space-150, 12px)", " 0 ", "var(--ds-space-150, 12px)") }); var mobileSideBarShowCategories = (0, _react2.css)({ flex: '0 0 auto' }); var sideBar = (0, _react2.css)(baseSidebarStyles, { flex: "0 0 'auto'" }); var sideBarShowCategories = (0, _react2.css)(baseSidebarStyles, { flex: "0 0 ".concat(_constants.SIDEBAR_WIDTH) }); var sidebarHeading = (0, _react2.css)({ flex: "0 0 ".concat(_constants.SIDEBAR_HEADING_WRAPPER_HEIGHT), display: 'inline-flex', alignItems: 'center', paddingLeft: "var(--ds-space-150, 12px)", fontWeight: 700 }); var mobileMainContent = (0, _react2.css)({ flex: '1 1 auto', display: 'flex', flexDirection: 'column', overflowY: 'auto', height: '100%' }); var mainContent = (0, _react2.css)(mobileMainContent, { marginLeft: "var(--ds-space-200, 16px)", height: 'auto' }); var searchContainer = (0, _react2.css)({ paddingBottom: "var(--ds-space-200, 16px)" }); var mobileCategoryListWrapper = (0, _react2.css)({ display: 'flex', overflowX: 'auto', padding: "var(--ds-space-200, 8px)".concat(" 0 ", "var(--ds-space-200, 16px)", " 0"), minHeight: "".concat(_constants.GRID_SIZE * 4, "px"), overflow: '-moz-scrollbars-none', '::-webkit-scrollbar': { display: 'none' }, scrollbarWidth: 'none', MsOverflowStyle: 'none' }); var categoryListWrapper = (0, _react2.css)(mobileCategoryListWrapper, { padding: 0, marginTop: "var(--ds-space-200, 24px)", flexDirection: 'column' }); function StatelessElementBrowser(props) { var items = props.items, onSelectItem = props.onSelectItem, onInsertItem = props.onInsertItem, viewMoreItem = props.viewMoreItem; var _useContainerWidth = (0, _useContainerWidth2.default)(), containerWidth = _useContainerWidth.containerWidth, ContainerWidthMonitor = _useContainerWidth.ContainerWidthMonitor; var _useState = (0, _react.useState)(1), _useState2 = (0, _slicedToArray2.default)(_useState, 2), columnCount = _useState2[0], setColumnCount = _useState2[1]; var _useSelectAndFocusOnA = (0, _useSelectAndFocusOnArrowNavigation.default)(items.length - 1, columnCount, !!viewMoreItem), selectedItemIndex = _useSelectAndFocusOnA.selectedItemIndex, focusedItemIndex = _useSelectAndFocusOnA.focusedItemIndex, setFocusedItemIndex = _useSelectAndFocusOnA.setFocusedItemIndex, focusOnSearch = _useSelectAndFocusOnA.focusOnSearch, focusOnViewMore = _useSelectAndFocusOnA.focusOnViewMore, onKeyDown = _useSelectAndFocusOnA.onKeyDown, setFocusOnSearch = _useSelectAndFocusOnA.setFocusOnSearch; (0, _react.useEffect)(function () { (0, _analytics.fireAnalyticsEvent)(props.createAnalyticsEvent)({ payload: { action: _analytics.ACTION.OPENED, actionSubject: _analytics.ACTION_SUBJECT.ELEMENT_BROWSER, eventType: _analytics.EVENT_TYPE.UI, attributes: { mode: props.mode } } }); return function () { (0, _analytics.fireAnalyticsEvent)(props.createAnalyticsEvent)({ payload: { action: _analytics.ACTION.CLOSED, actionSubject: _analytics.ACTION_SUBJECT.ELEMENT_BROWSER, eventType: _analytics.EVENT_TYPE.UI, attributes: { mode: props.mode } } }); }; }, [props.createAnalyticsEvent, props.mode]); /* Only for hitting enter to select item when focused on search bar, * The actual enter key press is handled on individual items level. */ var selectedItem = selectedItemIndex !== undefined ? items[selectedItemIndex] : null; var onItemsEnterKeyPress = (0, _react.useCallback)(function (e) { if (e.key !== 'Enter') { return; } if (onInsertItem && selectedItem != null) { onInsertItem(selectedItem); } e.preventDefault(); }, [onInsertItem, selectedItem]); /** * On arrow key selection and clicks the selectedItemIndex will change. * Making sure to update parent component. */ (0, _react.useEffect)(function () { if (onSelectItem && selectedItem != null) { onSelectItem(selectedItem); } }, [onSelectItem, selectedItem]); return (0, _react2.jsx)("div", { css: wrapper, "data-testid": "element-browser" }, (0, _react2.jsx)(ContainerWidthMonitor, null), containerWidth < _constants.DEVICE_BREAKPOINT_NUMBERS.medium ? (0, _react2.jsx)(MobileBrowser, (0, _extends2.default)({}, props, { selectedItemIndex: selectedItemIndex, focusedItemIndex: focusedItemIndex, setFocusedItemIndex: setFocusedItemIndex, focusOnSearch: focusOnSearch, setColumnCount: setColumnCount, setFocusOnSearch: setFocusOnSearch, onKeyPress: onItemsEnterKeyPress, onKeyDown: onKeyDown, viewMoreItem: viewMoreItem, focusOnViewMore: focusOnViewMore })) : (0, _react2.jsx)(DesktopBrowser, (0, _extends2.default)({}, props, { selectedItemIndex: selectedItemIndex, focusedItemIndex: focusedItemIndex, setFocusedItemIndex: setFocusedItemIndex, focusOnSearch: focusOnSearch, setColumnCount: setColumnCount, setFocusOnSearch: setFocusOnSearch, onKeyPress: onItemsEnterKeyPress, onKeyDown: onKeyDown }))); } function MobileBrowser(_ref) { var showCategories = _ref.showCategories, showSearch = _ref.showSearch, onSearch = _ref.onSearch, mode = _ref.mode, categories = _ref.categories, onSelectCategory = _ref.onSelectCategory, items = _ref.items, onInsertItem = _ref.onInsertItem, selectedCategory = _ref.selectedCategory, selectedItemIndex = _ref.selectedItemIndex, focusedItemIndex = _ref.focusedItemIndex, setFocusedItemIndex = _ref.setFocusedItemIndex, focusOnSearch = _ref.focusOnSearch, focusOnViewMore = _ref.focusOnViewMore, setColumnCount = _ref.setColumnCount, setFocusOnSearch = _ref.setFocusOnSearch, onKeyPress = _ref.onKeyPress, onKeyDown = _ref.onKeyDown, searchTerm = _ref.searchTerm, createAnalyticsEvent = _ref.createAnalyticsEvent, emptyStateHandler = _ref.emptyStateHandler, viewMoreItem = _ref.viewMoreItem; return (0, _react2.jsx)("div", { css: mobileElementBrowserContainer, onKeyDown: onKeyDown, "data-testid": "mobile__element-browser" }, (0, _react2.jsx)("div", { css: showCategories ? [mobileSideBar, mobileSideBarShowCategories] : mobileSideBar }, showSearch && (0, _react2.jsx)(_ElementSearch.default, { onSearch: onSearch, onKeyDown: onKeyPress, mode: mode, focus: focusOnSearch, onClick: setFocusOnSearch, searchTerm: searchTerm, items: items, selectedItemIndex: selectedItemIndex }), showCategories && (0, _react2.jsx)("nav", { css: mobileCategoryListWrapper, tabIndex: -1 }, (0, _react2.jsx)(_CategoryList.default, { categories: categories, onSelectCategory: onSelectCategory, selectedCategory: selectedCategory }))), (0, _react2.jsx)("div", { css: mobileMainContent }, (0, _react2.jsx)(_ElementList.default, { items: items, mode: mode, onInsertItem: onInsertItem, selectedItemIndex: selectedItemIndex, focusedItemIndex: focusedItemIndex, setFocusedItemIndex: setFocusedItemIndex, setColumnCount: setColumnCount, createAnalyticsEvent: createAnalyticsEvent, emptyStateHandler: emptyStateHandler, selectedCategory: selectedCategory, searchTerm: searchTerm })), viewMoreItem && (0, _react2.jsx)(_ViewMore.ViewMore, { item: viewMoreItem, focus: focusOnViewMore })); } function DesktopBrowser(_ref2) { var showCategories = _ref2.showCategories, showSearch = _ref2.showSearch, onSearch = _ref2.onSearch, mode = _ref2.mode, categories = _ref2.categories, onSelectCategory = _ref2.onSelectCategory, items = _ref2.items, onInsertItem = _ref2.onInsertItem, selectedCategory = _ref2.selectedCategory, selectedItemIndex = _ref2.selectedItemIndex, focusedItemIndex = _ref2.focusedItemIndex, setFocusedItemIndex = _ref2.setFocusedItemIndex, focusOnSearch = _ref2.focusOnSearch, setColumnCount = _ref2.setColumnCount, setFocusOnSearch = _ref2.setFocusOnSearch, onKeyPress = _ref2.onKeyPress, onKeyDown = _ref2.onKeyDown, searchTerm = _ref2.searchTerm, createAnalyticsEvent = _ref2.createAnalyticsEvent, emptyStateHandler = _ref2.emptyStateHandler; return (0, _react2.jsx)("div", { css: elementBrowserContainer, "data-testid": "desktop__element-browser" }, showCategories && (0, _react2.jsx)("div", { css: showCategories ? sideBarShowCategories : sideBar }, (0, _react2.jsx)("h2", { css: sidebarHeading, "data-testid": "sidebar-heading", id: "sidebar-heading" }, (0, _react2.jsx)(_reactIntlNext.FormattedMessage, { id: "fabric.editor.elementbrowser.sidebar.heading", defaultMessage: "Browse", description: "Sidebar heading" })), (0, _react2.jsx)("nav", { role: "tablist", "aria-labelledby": "sidebar-heading", css: categoryListWrapper }, (0, _react2.jsx)(_CategoryList.default, { categories: categories, onSelectCategory: onSelectCategory, selectedCategory: selectedCategory, createAnalyticsEvent: createAnalyticsEvent }))), (0, _react2.jsx)("div", { css: mainContent, onKeyDown: onKeyDown, "data-testid": "main-content" }, showSearch && // eslint-disable-next-line (0, _react2.jsx)("div", { css: searchContainer }, (0, _react2.jsx)(_ElementSearch.default, { onSearch: onSearch, onKeyDown: onKeyPress, mode: mode, focus: focusOnSearch, onClick: setFocusOnSearch, searchTerm: searchTerm, items: items, selectedItemIndex: selectedItemIndex })), (0, _react2.jsx)(_ElementList.default, { items: items, mode: mode, onInsertItem: onInsertItem, selectedItemIndex: selectedItemIndex, focusedItemIndex: focusedItemIndex, setFocusedItemIndex: setFocusedItemIndex, setColumnCount: setColumnCount, createAnalyticsEvent: createAnalyticsEvent, emptyStateHandler: emptyStateHandler, selectedCategory: selectedCategory, searchTerm: searchTerm }))); } var MemoizedElementBrowser = /*#__PURE__*/(0, _react.memo)((0, _analyticsNext.withAnalyticsContext)({ source: 'ElementBrowser' })((0, _analyticsNext.withAnalyticsEvents)()(StatelessElementBrowser))); var _default = exports.default = MemoizedElementBrowser;