@sanity/desk-tool
Version:
Tool for managing all sorts of content in a structured manner
134 lines (129 loc) • 8.84 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.DocumentPanelHeader = void 0;
var _negate2 = _interopRequireDefault(require("lodash/negate"));
var _icons = require("@sanity/icons");
var _ui = require("@sanity/ui");
var _languageSelectComponent = _interopRequireDefault(require("part:@sanity/desk-tool/language-select-component?"));
var _react = _interopRequireWildcard(require("react"));
var _pane = require("../../../../components/pane");
var _deskTool = require("../../../../contexts/deskTool");
var _paneRouter = require("../../../../contexts/paneRouter");
var _timeline = require("../../timeline");
var _useDocumentPane2 = require("../../useDocumentPane");
var _DocumentHeaderTabs = require("./DocumentHeaderTabs");
var _ValidationMenu = require("./ValidationMenu");
var _DocumentHeaderTitle = require("./DocumentHeaderTitle");
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } // @todo: remove the following line when part imports has been removed from this file
///<reference types="@sanity/types/parts" />
var isActionButton = item => Boolean(item.showAsAction);
var isMenuButton = (0, _negate2.default)(isActionButton);
var DocumentPanelHeader = /*#__PURE__*/(0, _react.forwardRef)(function DocumentPanelHeader(_ref, ref) {
var rootElement = _ref.rootElement;
var _useDocumentPane = (0, _useDocumentPane2.useDocumentPane)(),
documentSchema = _useDocumentPane.documentSchema,
handleMenuAction = _useDocumentPane.handleMenuAction,
handlePaneClose = _useDocumentPane.handlePaneClose,
handlePaneSplit = _useDocumentPane.handlePaneSplit,
historyController = _useDocumentPane.historyController,
markers = _useDocumentPane.markers,
menuItems = _useDocumentPane.menuItems,
menuItemGroups = _useDocumentPane.menuItemGroups,
ready = _useDocumentPane.ready,
views = _useDocumentPane.views,
totalReferenceCount = _useDocumentPane.totalReferenceCount;
var rev = historyController.revTime;
var _useDeskTool = (0, _deskTool.useDeskTool)(),
features = _useDeskTool.features;
var _usePaneRouter = (0, _paneRouter.usePaneRouter)(),
index = _usePaneRouter.index,
BackLink = _usePaneRouter.BackLink,
hasGroupSiblings = _usePaneRouter.hasGroupSiblings;
var contextMenuItems = (0, _react.useMemo)(() => menuItems.filter(isMenuButton), [menuItems]);
var _React$useState = _react.default.useState(false),
_React$useState2 = _slicedToArray(_React$useState, 2),
isValidationOpen = _React$useState2[0],
setValidationOpen = _React$useState2[1];
var showTabs = views.length > 1;
var showVersionMenu = features.reviewChanges;
// there are three kinds of buttons possible:
//
// 1. split pane - creates a new split pane
// 2. close split pane — closes the current split pane
// 3. close pane group — closes the current pane group
// show the split pane button if they're enabled and there is more than one
// view available to use to create a split view
var showSplitPaneButton = features.splitViews && handlePaneSplit && views.length > 1;
// show the split pane button close button if the split button is showing
// and there is more than one split pane open (aka has-siblings)
var showSplitPaneCloseButton = showSplitPaneButton && hasGroupSiblings;
// show the pane group close button if the `showSplitPaneCloseButton` is
// _not_ showing (the split pane button replaces the group close button)
// and if the back button is not showing (the back button and the close
// button) do the same thing and shouldn't be shown at the same time)
var showPaneGroupCloseButton = !showSplitPaneCloseButton && !features.backButton;
return /*#__PURE__*/_react.default.createElement(_pane.PaneHeader, {
ref: ref,
loading: !ready,
title: /*#__PURE__*/_react.default.createElement(_DocumentHeaderTitle.DocumentHeaderTitle, null),
tabs: showTabs && /*#__PURE__*/_react.default.createElement(_DocumentHeaderTabs.DocumentHeaderTabs, null),
backButton: features.backButton && index > 0 && /*#__PURE__*/_react.default.createElement(_ui.Button, {
as: BackLink,
"data-as": "a",
icon: _icons.ArrowLeftIcon,
mode: "bleed"
}),
subActions: showVersionMenu && /*#__PURE__*/_react.default.createElement(_timeline.TimelineMenu, {
chunk: rev,
mode: "rev"
}),
totalReferenceCount: totalReferenceCount,
actions: /*#__PURE__*/_react.default.createElement(_ui.Inline, {
space: 1
}, _languageSelectComponent.default && /*#__PURE__*/_react.default.createElement(_languageSelectComponent.default, {
key: "language-menu",
schemaType: documentSchema
}), markers.length > 0 && /*#__PURE__*/_react.default.createElement(_ValidationMenu.ValidationMenu, {
boundaryElement: rootElement,
isOpen: isValidationOpen,
key: "validation-menu",
setOpen: setValidationOpen
}), /*#__PURE__*/_react.default.createElement(_pane.PaneContextMenuButton, {
itemGroups: menuItemGroups,
items: contextMenuItems,
key: "context-menu",
onAction: handleMenuAction
}), showSplitPaneButton && /*#__PURE__*/_react.default.createElement(_ui.Button, {
icon: _icons.SplitVerticalIcon,
key: "split-pane-button",
mode: "bleed",
onClick: handlePaneSplit,
title: "Split pane right"
}), showSplitPaneCloseButton && /*#__PURE__*/_react.default.createElement(_ui.Button, {
icon: _icons.CloseIcon,
key: "close-view-button",
mode: "bleed",
onClick: handlePaneClose,
title: "Close split pane"
}), showPaneGroupCloseButton && /*#__PURE__*/_react.default.createElement(_ui.Button, {
icon: _icons.CloseIcon,
key: "close-view-button",
mode: "bleed",
title: "Close pane group",
as: BackLink
}))
});
});
var MemoizedDocumentPanelHeader = /*#__PURE__*/(0, _react.memo)(DocumentPanelHeader);
exports.DocumentPanelHeader = MemoizedDocumentPanelHeader;
MemoizedDocumentPanelHeader.displayName = 'MemoizedDocumentPanelHeader';