UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

164 lines (163 loc) • 22 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "ListControls", { enumerable: true, get: function() { return ListControls; } }); const _windowinfo = require("@faceless-ui/window-info"); const _react = /*#__PURE__*/ _interop_require_wildcard(require("react")); const _reactanimateheight = /*#__PURE__*/ _interop_require_default(require("react-animate-height")); const _reacti18next = require("react-i18next"); const _types = require("../../../../fields/config/types"); const _getTranslation = require("../../../../utilities/getTranslation"); const _Chevron = /*#__PURE__*/ _interop_require_default(require("../../icons/Chevron")); const _SearchParams = require("../../utilities/SearchParams"); const _ColumnSelector = /*#__PURE__*/ _interop_require_default(require("../ColumnSelector")); const _DeleteMany = /*#__PURE__*/ _interop_require_default(require("../DeleteMany")); const _EditMany = /*#__PURE__*/ _interop_require_default(require("../EditMany")); const _Pill = /*#__PURE__*/ _interop_require_default(require("../Pill")); const _PublishMany = /*#__PURE__*/ _interop_require_default(require("../PublishMany")); const _SearchFilter = /*#__PURE__*/ _interop_require_default(require("../SearchFilter")); const _SortComplex = /*#__PURE__*/ _interop_require_default(require("../SortComplex")); const _UnpublishMany = /*#__PURE__*/ _interop_require_default(require("../UnpublishMany")); const _WhereBuilder = /*#__PURE__*/ _interop_require_default(require("../WhereBuilder")); const _validateWhereQuery = /*#__PURE__*/ _interop_require_default(require("../WhereBuilder/validateWhereQuery")); const _getTextFieldsToBeSearched = require("./getTextFieldsToBeSearched"); require("./index.scss"); 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 = 'list-controls'; const ListControls = (props)=>{ const { collection: { admin: { listSearchableFields }, fields }, collection, enableColumns = true, enableSort = false, handleSearchChange, handleSortChange, handleWhereChange, modifySearchQuery = true, resetParams, titleField } = props; const params = (0, _SearchParams.useSearchParams)(); const shouldInitializeWhereOpened = (0, _validateWhereQuery.default)(params?.where); const [textFieldsToBeSearched, setFieldsToBeSearched] = (0, _react.useState)((0, _getTextFieldsToBeSearched.getTextFieldsToBeSearched)(listSearchableFields, fields)); const [visibleDrawer, setVisibleDrawer] = (0, _react.useState)(shouldInitializeWhereOpened ? 'where' : undefined); const { i18n, t } = (0, _reacti18next.useTranslation)('general'); const { breakpoints: { s: smallBreak } } = (0, _windowinfo.useWindowInfo)(); _react.default.useEffect(()=>{ setFieldsToBeSearched((0, _getTextFieldsToBeSearched.getTextFieldsToBeSearched)(listSearchableFields, fields)); }, [ listSearchableFields, fields ]); return /*#__PURE__*/ _react.default.createElement("div", { className: baseClass }, /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__wrap` }, /*#__PURE__*/ _react.default.createElement(_SearchFilter.default, { fieldLabel: (titleField && (0, _getTranslation.getTranslation)(titleField.label || titleField.name, i18n)) ?? undefined, fieldName: titleField && (0, _types.fieldAffectsData)(titleField) ? titleField.name : undefined, handleChange: handleSearchChange, listSearchableFields: textFieldsToBeSearched, modifySearchQuery: modifySearchQuery }), /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__buttons` }, /*#__PURE__*/ _react.default.createElement("div", { className: `${baseClass}__buttons-wrap` }, !smallBreak && /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/ _react.default.createElement(_EditMany.default, { collection: collection, resetParams: resetParams }), /*#__PURE__*/ _react.default.createElement(_PublishMany.default, { collection: collection, resetParams: resetParams }), /*#__PURE__*/ _react.default.createElement(_UnpublishMany.default, { collection: collection, resetParams: resetParams }), /*#__PURE__*/ _react.default.createElement(_DeleteMany.default, { collection: collection, resetParams: resetParams })), enableColumns && /*#__PURE__*/ _react.default.createElement(_Pill.default, { "aria-controls": `${baseClass}-columns`, "aria-expanded": visibleDrawer === 'columns', className: `${baseClass}__toggle-columns ${visibleDrawer === 'columns' ? `${baseClass}__buttons-active` : ''}`, icon: /*#__PURE__*/ _react.default.createElement(_Chevron.default, null), onClick: ()=>setVisibleDrawer(visibleDrawer !== 'columns' ? 'columns' : undefined), pillStyle: "light" }, t('columns')), /*#__PURE__*/ _react.default.createElement(_Pill.default, { "aria-controls": `${baseClass}-where`, "aria-expanded": visibleDrawer === 'where', className: `${baseClass}__toggle-where ${visibleDrawer === 'where' ? `${baseClass}__buttons-active` : ''}`, icon: /*#__PURE__*/ _react.default.createElement(_Chevron.default, null), onClick: ()=>setVisibleDrawer(visibleDrawer !== 'where' ? 'where' : undefined), pillStyle: "light" }, t('filters')), enableSort && /*#__PURE__*/ _react.default.createElement(_Pill.default, { "aria-controls": `${baseClass}-sort`, "aria-expanded": visibleDrawer === 'sort', className: `${baseClass}__toggle-sort`, icon: /*#__PURE__*/ _react.default.createElement(_Chevron.default, null), onClick: ()=>setVisibleDrawer(visibleDrawer !== 'sort' ? 'sort' : undefined), pillStyle: "light" }, t('sort'))))), enableColumns && /*#__PURE__*/ _react.default.createElement(_reactanimateheight.default, { className: `${baseClass}__columns`, height: visibleDrawer === 'columns' ? 'auto' : 0, id: `${baseClass}-columns` }, /*#__PURE__*/ _react.default.createElement(_ColumnSelector.default, { collection: collection })), /*#__PURE__*/ _react.default.createElement(_reactanimateheight.default, { className: `${baseClass}__where`, height: visibleDrawer === 'where' ? 'auto' : 0, id: `${baseClass}-where` }, /*#__PURE__*/ _react.default.createElement(_WhereBuilder.default, { collection: collection, handleChange: handleWhereChange, modifySearchQuery: modifySearchQuery })), enableSort && /*#__PURE__*/ _react.default.createElement(_reactanimateheight.default, { className: `${baseClass}__sort`, height: visibleDrawer === 'sort' ? 'auto' : 0, id: `${baseClass}-sort` }, /*#__PURE__*/ _react.default.createElement(_SortComplex.default, { collection: collection, handleChange: handleSortChange, modifySearchQuery: modifySearchQuery }))); }; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/elements/ListControls/index.tsx"],"sourcesContent":["import { useWindowInfo } from '@faceless-ui/window-info'\nimport React, { useState } from 'react'\nimport AnimateHeight from 'react-animate-height'\nimport { useTranslation } from 'react-i18next'\n\nimport type { Props } from './types'\n\nimport { fieldAffectsData } from '../../../../fields/config/types'\nimport { getTranslation } from '../../../../utilities/getTranslation'\nimport Chevron from '../../icons/Chevron'\nimport { useSearchParams } from '../../utilities/SearchParams'\nimport Button from '../Button'\nimport ColumnSelector from '../ColumnSelector'\nimport DeleteMany from '../DeleteMany'\nimport EditMany from '../EditMany'\nimport Pill from '../Pill'\nimport PublishMany from '../PublishMany'\nimport SearchFilter from '../SearchFilter'\nimport SortComplex from '../SortComplex'\nimport UnpublishMany from '../UnpublishMany'\nimport WhereBuilder from '../WhereBuilder'\nimport validateWhereQuery from '../WhereBuilder/validateWhereQuery'\nimport { getTextFieldsToBeSearched } from './getTextFieldsToBeSearched'\nimport './index.scss'\n\nconst baseClass = 'list-controls'\n\n/**\n * The ListControls component is used to render the controls (search, filter, where)\n * for a collection's list view. You can find those directly above the table which lists\n * the collection's documents.\n */\nexport const ListControls: React.FC<Props> = (props) => {\n  const {\n    collection: {\n      admin: { listSearchableFields },\n      fields,\n    },\n    collection,\n    enableColumns = true,\n    enableSort = false,\n    handleSearchChange,\n    handleSortChange,\n    handleWhereChange,\n    modifySearchQuery = true,\n    resetParams,\n    titleField,\n  } = props\n\n  const params = useSearchParams()\n  const shouldInitializeWhereOpened = validateWhereQuery(params?.where)\n\n  const [textFieldsToBeSearched, setFieldsToBeSearched] = useState(\n    getTextFieldsToBeSearched(listSearchableFields, fields),\n  )\n  const [visibleDrawer, setVisibleDrawer] = useState<'columns' | 'sort' | 'where'>(\n    shouldInitializeWhereOpened ? 'where' : undefined,\n  )\n  const { i18n, t } = useTranslation('general')\n  const {\n    breakpoints: { s: smallBreak },\n  } = useWindowInfo()\n\n  React.useEffect(() => {\n    setFieldsToBeSearched(getTextFieldsToBeSearched(listSearchableFields, fields))\n  }, [listSearchableFields, fields])\n\n  return (\n    <div className={baseClass}>\n      <div className={`${baseClass}__wrap`}>\n        <SearchFilter\n          fieldLabel={\n            (titleField && getTranslation(titleField.label || titleField.name, i18n)) ?? undefined\n          }\n          fieldName={titleField && fieldAffectsData(titleField) ? titleField.name : undefined}\n          handleChange={handleSearchChange}\n          listSearchableFields={textFieldsToBeSearched}\n          modifySearchQuery={modifySearchQuery}\n        />\n        <div className={`${baseClass}__buttons`}>\n          <div className={`${baseClass}__buttons-wrap`}>\n            {!smallBreak && (\n              <React.Fragment>\n                <EditMany collection={collection} resetParams={resetParams} />\n                <PublishMany collection={collection} resetParams={resetParams} />\n                <UnpublishMany collection={collection} resetParams={resetParams} />\n                <DeleteMany collection={collection} resetParams={resetParams} />\n              </React.Fragment>\n            )}\n            {enableColumns && (\n              <Pill\n                aria-controls={`${baseClass}-columns`}\n                aria-expanded={visibleDrawer === 'columns'}\n                className={`${baseClass}__toggle-columns ${\n                  visibleDrawer === 'columns' ? `${baseClass}__buttons-active` : ''\n                }`}\n                icon={<Chevron />}\n                onClick={() =>\n                  setVisibleDrawer(visibleDrawer !== 'columns' ? 'columns' : undefined)\n                }\n                pillStyle=\"light\"\n              >\n                {t('columns')}\n              </Pill>\n            )}\n            <Pill\n              aria-controls={`${baseClass}-where`}\n              aria-expanded={visibleDrawer === 'where'}\n              className={`${baseClass}__toggle-where ${\n                visibleDrawer === 'where' ? `${baseClass}__buttons-active` : ''\n              }`}\n              icon={<Chevron />}\n              onClick={() => setVisibleDrawer(visibleDrawer !== 'where' ? 'where' : undefined)}\n              pillStyle=\"light\"\n            >\n              {t('filters')}\n            </Pill>\n            {enableSort && (\n              <Pill\n                aria-controls={`${baseClass}-sort`}\n                aria-expanded={visibleDrawer === 'sort'}\n                className={`${baseClass}__toggle-sort`}\n                icon={<Chevron />}\n                onClick={() => setVisibleDrawer(visibleDrawer !== 'sort' ? 'sort' : undefined)}\n                pillStyle=\"light\"\n              >\n                {t('sort')}\n              </Pill>\n            )}\n          </div>\n        </div>\n      </div>\n      {enableColumns && (\n        <AnimateHeight\n          className={`${baseClass}__columns`}\n          height={visibleDrawer === 'columns' ? 'auto' : 0}\n          id={`${baseClass}-columns`}\n        >\n          <ColumnSelector collection={collection} />\n        </AnimateHeight>\n      )}\n      <AnimateHeight\n        className={`${baseClass}__where`}\n        height={visibleDrawer === 'where' ? 'auto' : 0}\n        id={`${baseClass}-where`}\n      >\n        <WhereBuilder\n          collection={collection}\n          handleChange={handleWhereChange}\n          modifySearchQuery={modifySearchQuery}\n        />\n      </AnimateHeight>\n      {enableSort && (\n        <AnimateHeight\n          className={`${baseClass}__sort`}\n          height={visibleDrawer === 'sort' ? 'auto' : 0}\n          id={`${baseClass}-sort`}\n        >\n          <SortComplex\n            collection={collection}\n            handleChange={handleSortChange}\n            modifySearchQuery={modifySearchQuery}\n          />\n        </AnimateHeight>\n      )}\n    </div>\n  )\n}\n"],"names":["ListControls","baseClass","props","collection","admin","listSearchableFields","fields","enableColumns","enableSort","handleSearchChange","handleSortChange","handleWhereChange","modifySearchQuery","resetParams","titleField","params","useSearchParams","shouldInitializeWhereOpened","validateWhereQuery","where","textFieldsToBeSearched","setFieldsToBeSearched","useState","getTextFieldsToBeSearched","visibleDrawer","setVisibleDrawer","undefined","i18n","t","useTranslation","breakpoints","s","smallBreak","useWindowInfo","React","useEffect","div","className","SearchFilter","fieldLabel","getTranslation","label","name","fieldName","fieldAffectsData","handleChange","Fragment","EditMany","PublishMany","UnpublishMany","DeleteMany","Pill","aria-controls","aria-expanded","icon","Chevron","onClick","pillStyle","AnimateHeight","height","id","ColumnSelector","WhereBuilder","SortComplex"],"mappings":"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"}