payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
127 lines (126 loc) • 13.5 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "Collapsible", {
enumerable: true,
get: function() {
return Collapsible;
}
});
const _react = /*#__PURE__*/ _interop_require_wildcard(require("react"));
const _reactanimateheight = /*#__PURE__*/ _interop_require_default(require("react-animate-height"));
const _reacti18next = require("react-i18next");
const _Chevron = /*#__PURE__*/ _interop_require_default(require("../../icons/Chevron"));
const _Drag = /*#__PURE__*/ _interop_require_default(require("../../icons/Drag"));
require("./index.scss");
const _provider = require("./provider");
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
function _getRequireWildcardCache(nodeInterop) {
if (typeof WeakMap !== "function") return null;
var cacheBabelInterop = new WeakMap();
var cacheNodeInterop = new WeakMap();
return (_getRequireWildcardCache = function(nodeInterop) {
return nodeInterop ? cacheNodeInterop : cacheBabelInterop;
})(nodeInterop);
}
function _interop_require_wildcard(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 = {
__proto__: null
};
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;
}
const baseClass = 'collapsible';
const Collapsible = ({ actions, children, className, collapsed: collapsedFromProps, collapsibleStyle = 'default', dragHandleProps, header, initCollapsed, onToggle })=>{
const [collapsedLocal, setCollapsedLocal] = (0, _react.useState)(Boolean(initCollapsed));
const [hoveringToggle, setHoveringToggle] = (0, _react.useState)(false);
const { withinCollapsible } = (0, _provider.useCollapsible)();
const { t } = (0, _reacti18next.useTranslation)('fields');
const collapsed = typeof collapsedFromProps === 'boolean' ? collapsedFromProps : collapsedLocal;
const toggleCollapsible = _react.default.useCallback(()=>{
if (typeof onToggle === 'function') onToggle(!collapsed);
setCollapsedLocal(!collapsed);
}, [
onToggle,
collapsed
]);
return /*#__PURE__*/ _react.default.createElement("div", {
className: [
baseClass,
className,
dragHandleProps && `${baseClass}--has-drag-handle`,
collapsed && `${baseClass}--collapsed`,
withinCollapsible && `${baseClass}--nested`,
hoveringToggle && `${baseClass}--hovered`,
`${baseClass}--style-${collapsibleStyle}`
].filter(Boolean).join(' ')
}, /*#__PURE__*/ _react.default.createElement(_provider.CollapsibleProvider, {
collapsed: collapsed,
toggle: toggleCollapsible
}, /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__toggle-wrap`,
onMouseEnter: ()=>setHoveringToggle(true),
onMouseLeave: ()=>setHoveringToggle(false)
}, dragHandleProps && /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__drag`,
...dragHandleProps.attributes,
...dragHandleProps.listeners
}, /*#__PURE__*/ _react.default.createElement(_Drag.default, null)), /*#__PURE__*/ _react.default.createElement("button", {
className: [
`${baseClass}__toggle`,
`${baseClass}__toggle--${collapsed ? 'collapsed' : 'open'}`
].filter(Boolean).join(' '),
onClick: toggleCollapsible,
type: "button"
}, /*#__PURE__*/ _react.default.createElement("span", null, t('toggleBlock'))), header && /*#__PURE__*/ _react.default.createElement("div", {
className: [
`${baseClass}__header-wrap`,
dragHandleProps && `${baseClass}__header-wrap--has-drag-handle`
].filter(Boolean).join(' ')
}, header && header), /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__actions-wrap`
}, actions && /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__actions`
}, actions), /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__indicator`
}, /*#__PURE__*/ _react.default.createElement(_Chevron.default, {
direction: !collapsed ? 'up' : undefined
})))), /*#__PURE__*/ _react.default.createElement(_reactanimateheight.default, {
duration: 200,
height: collapsed ? 0 : 'auto'
}, /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__content`
}, children))));
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/elements/Collapsible/index.tsx"],"sourcesContent":["import React, { useState } from 'react'\nimport AnimateHeight from 'react-animate-height'\nimport { useTranslation } from 'react-i18next'\n\nimport type { Props } from './types'\n\nimport Chevron from '../../icons/Chevron'\nimport DragHandle from '../../icons/Drag'\nimport './index.scss'\nimport { CollapsibleProvider, useCollapsible } from './provider'\n\nconst baseClass = 'collapsible'\n\nexport const Collapsible: React.FC<Props> = ({\n  actions,\n  children,\n  className,\n  collapsed: collapsedFromProps,\n  collapsibleStyle = 'default',\n  dragHandleProps,\n  header,\n  initCollapsed,\n  onToggle,\n}) => {\n  const [collapsedLocal, setCollapsedLocal] = useState(Boolean(initCollapsed))\n  const [hoveringToggle, setHoveringToggle] = useState(false)\n  const { withinCollapsible } = useCollapsible()\n  const { t } = useTranslation('fields')\n\n  const collapsed = typeof collapsedFromProps === 'boolean' ? collapsedFromProps : collapsedLocal\n\n  const toggleCollapsible = React.useCallback(() => {\n    if (typeof onToggle === 'function') onToggle(!collapsed)\n    setCollapsedLocal(!collapsed)\n  }, [onToggle, collapsed])\n\n  return (\n    <div\n      className={[\n        baseClass,\n        className,\n        dragHandleProps && `${baseClass}--has-drag-handle`,\n        collapsed && `${baseClass}--collapsed`,\n        withinCollapsible && `${baseClass}--nested`,\n        hoveringToggle && `${baseClass}--hovered`,\n        `${baseClass}--style-${collapsibleStyle}`,\n      ]\n        .filter(Boolean)\n        .join(' ')}\n    >\n      <CollapsibleProvider collapsed={collapsed} toggle={toggleCollapsible}>\n        <div\n          className={`${baseClass}__toggle-wrap`}\n          onMouseEnter={() => setHoveringToggle(true)}\n          onMouseLeave={() => setHoveringToggle(false)}\n        >\n          {dragHandleProps && (\n            <div\n              className={`${baseClass}__drag`}\n              {...dragHandleProps.attributes}\n              {...dragHandleProps.listeners}\n            >\n              <DragHandle />\n            </div>\n          )}\n          <button\n            className={[\n              `${baseClass}__toggle`,\n              `${baseClass}__toggle--${collapsed ? 'collapsed' : 'open'}`,\n            ]\n              .filter(Boolean)\n              .join(' ')}\n            onClick={toggleCollapsible}\n            type=\"button\"\n          >\n            <span>{t('toggleBlock')}</span>\n          </button>\n          {header && (\n            <div\n              className={[\n                `${baseClass}__header-wrap`,\n                dragHandleProps && `${baseClass}__header-wrap--has-drag-handle`,\n              ]\n                .filter(Boolean)\n                .join(' ')}\n            >\n              {header && header}\n            </div>\n          )}\n          <div className={`${baseClass}__actions-wrap`}>\n            {actions && <div className={`${baseClass}__actions`}>{actions}</div>}\n            <div className={`${baseClass}__indicator`}>\n              <Chevron direction={!collapsed ? 'up' : undefined} />\n            </div>\n          </div>\n        </div>\n        <AnimateHeight duration={200} height={collapsed ? 0 : 'auto'}>\n          <div className={`${baseClass}__content`}>{children}</div>\n        </AnimateHeight>\n      </CollapsibleProvider>\n    </div>\n  )\n}\n"],"names":["Collapsible","baseClass","actions","children","className","collapsed","collapsedFromProps","collapsibleStyle","dragHandleProps","header","initCollapsed","onToggle","collapsedLocal","setCollapsedLocal","useState","Boolean","hoveringToggle","setHoveringToggle","withinCollapsible","useCollapsible","t","useTranslation","toggleCollapsible","React","useCallback","div","filter","join","CollapsibleProvider","toggle","onMouseEnter","onMouseLeave","attributes","listeners","DragHandle","button","onClick","type","span","Chevron","direction","undefined","AnimateHeight","duration","height"],"mappings":";;;;+BAaaA;;;eAAAA;;;+DAbmB;2EACN;8BACK;gEAIX;6DACG;QAChB;0BAC6C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEpD,MAAMC,YAAY;AAEX,MAAMD,cAA+B,CAAC,EAC3CE,OAAO,EACPC,QAAQ,EACRC,SAAS,EACTC,WAAWC,kBAAkB,EAC7BC,mBAAmB,SAAS,EAC5BC,eAAe,EACfC,MAAM,EACNC,aAAa,EACbC,QAAQ,EACT;IACC,MAAM,CAACC,gBAAgBC,kBAAkB,GAAGC,IAAAA,eAAQ,EAACC,QAAQL;IAC7D,MAAM,CAACM,gBAAgBC,kBAAkB,GAAGH,IAAAA,eAAQ,EAAC;IACrD,MAAM,EAAEI,iBAAiB,EAAE,GAAGC,IAAAA,wBAAc;IAC5C,MAAM,EAAEC,CAAC,EAAE,GAAGC,IAAAA,4BAAc,EAAC;IAE7B,MAAMhB,YAAY,OAAOC,uBAAuB,YAAYA,qBAAqBM;IAEjF,MAAMU,oBAAoBC,cAAK,CAACC,WAAW,CAAC;QAC1C,IAAI,OAAOb,aAAa,YAAYA,SAAS,CAACN;QAC9CQ,kBAAkB,CAACR;IACrB,GAAG;QAACM;QAAUN;KAAU;IAExB,qBACE,6BAACoB;QACCrB,WAAW;YACTH;YACAG;YACAI,mBAAmB,CAAC,EAAEP,UAAU,iBAAiB,CAAC;YAClDI,aAAa,CAAC,EAAEJ,UAAU,WAAW,CAAC;YACtCiB,qBAAqB,CAAC,EAAEjB,UAAU,QAAQ,CAAC;YAC3Ce,kBAAkB,CAAC,EAAEf,UAAU,SAAS,CAAC;YACzC,CAAC,EAAEA,UAAU,QAAQ,EAAEM,iBAAiB,CAAC;SAC1C,CACEmB,MAAM,CAACX,SACPY,IAAI,CAAC;qBAER,6BAACC,6BAAmB;QAACvB,WAAWA;QAAWwB,QAAQP;qBACjD,6BAACG;QACCrB,WAAW,CAAC,EAAEH,UAAU,aAAa,CAAC;QACtC6B,cAAc,IAAMb,kBAAkB;QACtCc,cAAc,IAAMd,kBAAkB;OAErCT,iCACC,6BAACiB;QACCrB,WAAW,CAAC,EAAEH,UAAU,MAAM,CAAC;QAC9B,GAAGO,gBAAgBwB,UAAU;QAC7B,GAAGxB,gBAAgByB,SAAS;qBAE7B,6BAACC,aAAU,wBAGf,6BAACC;QACC/B,WAAW;YACT,CAAC,EAAEH,UAAU,QAAQ,CAAC;YACtB,CAAC,EAAEA,UAAU,UAAU,EAAEI,YAAY,cAAc,OAAO,CAAC;SAC5D,CACEqB,MAAM,CAACX,SACPY,IAAI,CAAC;QACRS,SAASd;QACTe,MAAK;qBAEL,6BAACC,cAAMlB,EAAE,kBAEVX,wBACC,6BAACgB;QACCrB,WAAW;YACT,CAAC,EAAEH,UAAU,aAAa,CAAC;YAC3BO,mBAAmB,CAAC,EAAEP,UAAU,8BAA8B,CAAC;SAChE,CACEyB,MAAM,CAACX,SACPY,IAAI,CAAC;OAEPlB,UAAUA,uBAGf,6BAACgB;QAAIrB,WAAW,CAAC,EAAEH,UAAU,cAAc,CAAC;OACzCC,yBAAW,6BAACuB;QAAIrB,WAAW,CAAC,EAAEH,UAAU,SAAS,CAAC;OAAGC,wBACtD,6BAACuB;QAAIrB,WAAW,CAAC,EAAEH,UAAU,WAAW,CAAC;qBACvC,6BAACsC,gBAAO;QAACC,WAAW,CAACnC,YAAY,OAAOoC;yBAI9C,6BAACC,2BAAa;QAACC,UAAU;QAAKC,QAAQvC,YAAY,IAAI;qBACpD,6BAACoB;QAAIrB,WAAW,CAAC,EAAEH,UAAU,SAAS,CAAC;OAAGE;AAKpD"}