payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
164 lines (163 loc) • 22 kB
JavaScript
;
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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"}