UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

127 lines (126 loc) • 13.5 kB
"use strict"; 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"}