payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
219 lines (218 loc) • 23.1 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "default", {
enumerable: true,
get: function() {
return _default;
}
});
const _modal = require("@faceless-ui/modal");
const _react = /*#__PURE__*/ _interop_require_wildcard(require("react"));
const _reacti18next = require("react-i18next");
const _getTranslation = require("../../../../utilities/getTranslation");
const _Form = /*#__PURE__*/ _interop_require_default(require("../../forms/Form"));
const _context = require("../../forms/Form/context");
const _RenderFields = /*#__PURE__*/ _interop_require_default(require("../../forms/RenderFields"));
const _Submit = /*#__PURE__*/ _interop_require_default(require("../../forms/Submit"));
const _fieldtypes = require("../../forms/field-types");
const _X = /*#__PURE__*/ _interop_require_default(require("../../icons/X"));
const _Auth = require("../../utilities/Auth");
const _Config = require("../../utilities/Config");
const _DocumentInfo = require("../../utilities/DocumentInfo");
const _OperationProvider = require("../../utilities/OperationProvider");
const _SelectionProvider = require("../../views/collections/List/SelectionProvider");
const _Drawer = require("../Drawer");
const _FieldSelect = require("../FieldSelect");
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 = 'edit-many';
const Submit = ({ action, disabled })=>{
const { submit } = (0, _context.useForm)();
const { t } = (0, _reacti18next.useTranslation)('general');
const save = (0, _react.useCallback)(()=>{
submit({
action,
method: 'PATCH',
skipValidation: true
});
}, [
action,
submit
]);
return /*#__PURE__*/ _react.default.createElement(_Submit.default, {
className: `${baseClass}__save`,
disabled: disabled,
onClick: save
}, t('save'));
};
const Publish = ({ action, disabled })=>{
const { submit } = (0, _context.useForm)();
const { t } = (0, _reacti18next.useTranslation)('version');
const save = (0, _react.useCallback)(()=>{
submit({
action,
method: 'PATCH',
overrides: {
_status: 'published'
},
skipValidation: true
});
}, [
action,
submit
]);
return /*#__PURE__*/ _react.default.createElement(_Submit.default, {
className: `${baseClass}__publish`,
disabled: disabled,
onClick: save
}, t('publishChanges'));
};
const SaveDraft = ({ action, disabled })=>{
const { submit } = (0, _context.useForm)();
const { t } = (0, _reacti18next.useTranslation)('version');
const save = (0, _react.useCallback)(()=>{
submit({
action,
method: 'PATCH',
overrides: {
_status: 'draft'
},
skipValidation: true
});
}, [
action,
submit
]);
return /*#__PURE__*/ _react.default.createElement(_Submit.default, {
className: `${baseClass}__draft`,
disabled: disabled,
onClick: save
}, t('saveDraft'));
};
const EditMany = (props)=>{
const { collection: { fields, labels: { plural }, slug } = {}, collection, resetParams } = props;
const { permissions } = (0, _Auth.useAuth)();
const { closeModal } = (0, _modal.useModal)();
const { routes: { api }, serverURL } = (0, _Config.useConfig)();
const { count, getQueryParams, selectAll } = (0, _SelectionProvider.useSelection)();
const { i18n, t } = (0, _reacti18next.useTranslation)('general');
const [selected, setSelected] = (0, _react.useState)([]);
const collectionPermissions = permissions?.collections?.[slug];
const hasUpdatePermission = collectionPermissions?.update?.permission;
const drawerSlug = `edit-${slug}`;
if (selectAll === _SelectionProvider.SelectAllStatus.None || !hasUpdatePermission) {
return null;
}
const onSuccess = ()=>{
resetParams({
page: selectAll === _SelectionProvider.SelectAllStatus.AllAvailable ? 1 : undefined
});
};
return /*#__PURE__*/ _react.default.createElement("div", {
className: baseClass
}, /*#__PURE__*/ _react.default.createElement(_Drawer.DrawerToggler, {
"aria-label": t('edit'),
className: `${baseClass}__toggle`,
onClick: ()=>{
setSelected([]);
},
slug: drawerSlug
}, t('edit')), /*#__PURE__*/ _react.default.createElement(_Drawer.Drawer, {
header: null,
slug: drawerSlug
}, /*#__PURE__*/ _react.default.createElement(_DocumentInfo.DocumentInfoProvider, {
collection: collection
}, /*#__PURE__*/ _react.default.createElement(_OperationProvider.OperationContext.Provider, {
value: "update"
}, /*#__PURE__*/ _react.default.createElement(_Form.default, {
className: `${baseClass}__form`,
onSuccess: onSuccess
}, /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__main`
}, /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__header`
}, /*#__PURE__*/ _react.default.createElement("h2", {
className: `${baseClass}__header__title`
}, t('editingLabel', {
count,
label: (0, _getTranslation.getTranslation)(plural, i18n)
})), /*#__PURE__*/ _react.default.createElement("button", {
"aria-label": t('close'),
className: `${baseClass}__header__close`,
id: `close-drawer__${drawerSlug}`,
onClick: ()=>closeModal(drawerSlug),
type: "button"
}, /*#__PURE__*/ _react.default.createElement(_X.default, null))), /*#__PURE__*/ _react.default.createElement(_FieldSelect.FieldSelect, {
fields: fields,
setSelected: setSelected
}), /*#__PURE__*/ _react.default.createElement(_RenderFields.default, {
fieldSchema: selected,
fieldTypes: _fieldtypes.fieldTypes
}), /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__sidebar-wrap`
}, /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__sidebar`
}, /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__sidebar-sticky-wrap`
}, /*#__PURE__*/ _react.default.createElement("div", {
className: `${baseClass}__document-actions`
}, collection.versions ? /*#__PURE__*/ _react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/ _react.default.createElement(Publish, {
action: `${serverURL}${api}/${slug}${getQueryParams()}`,
disabled: selected.length === 0
}), /*#__PURE__*/ _react.default.createElement(SaveDraft, {
action: `${serverURL}${api}/${slug}${getQueryParams()}`,
disabled: selected.length === 0
})) : /*#__PURE__*/ _react.default.createElement(Submit, {
action: `${serverURL}${api}/${slug}${getQueryParams()}`,
disabled: selected.length === 0
})))))))))));
};
const _default = EditMany;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/elements/EditMany/index.tsx"],"sourcesContent":["import { useModal } from '@faceless-ui/modal'\nimport React, { useCallback, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\n\nimport type { Props } from './types'\n\nimport { getTranslation } from '../../../../utilities/getTranslation'\nimport Form from '../../forms/Form'\nimport { useForm } from '../../forms/Form/context'\nimport RenderFields from '../../forms/RenderFields'\nimport FormSubmit from '../../forms/Submit'\nimport { fieldTypes } from '../../forms/field-types'\nimport X from '../../icons/X'\nimport { useAuth } from '../../utilities/Auth'\nimport { useConfig } from '../../utilities/Config'\nimport { DocumentInfoProvider } from '../../utilities/DocumentInfo'\nimport { OperationContext } from '../../utilities/OperationProvider'\nimport { SelectAllStatus, useSelection } from '../../views/collections/List/SelectionProvider'\nimport { Drawer, DrawerToggler } from '../Drawer'\nimport { FieldSelect } from '../FieldSelect'\nimport './index.scss'\n\nconst baseClass = 'edit-many'\n\nconst Submit: React.FC<{ action: string; disabled: boolean }> = ({ action, disabled }) => {\n  const { submit } = useForm()\n  const { t } = useTranslation('general')\n\n  const save = useCallback(() => {\n    submit({\n      action,\n      method: 'PATCH',\n      skipValidation: true,\n    })\n  }, [action, submit])\n\n  return (\n    <FormSubmit className={`${baseClass}__save`} disabled={disabled} onClick={save}>\n      {t('save')}\n    </FormSubmit>\n  )\n}\nconst Publish: React.FC<{ action: string; disabled: boolean }> = ({ action, disabled }) => {\n  const { submit } = useForm()\n  const { t } = useTranslation('version')\n\n  const save = useCallback(() => {\n    submit({\n      action,\n      method: 'PATCH',\n      overrides: {\n        _status: 'published',\n      },\n      skipValidation: true,\n    })\n  }, [action, submit])\n\n  return (\n    <FormSubmit className={`${baseClass}__publish`} disabled={disabled} onClick={save}>\n      {t('publishChanges')}\n    </FormSubmit>\n  )\n}\nconst SaveDraft: React.FC<{ action: string; disabled: boolean }> = ({ action, disabled }) => {\n  const { submit } = useForm()\n  const { t } = useTranslation('version')\n\n  const save = useCallback(() => {\n    submit({\n      action,\n      method: 'PATCH',\n      overrides: {\n        _status: 'draft',\n      },\n      skipValidation: true,\n    })\n  }, [action, submit])\n\n  return (\n    <FormSubmit className={`${baseClass}__draft`} disabled={disabled} onClick={save}>\n      {t('saveDraft')}\n    </FormSubmit>\n  )\n}\nconst EditMany: React.FC<Props> = (props) => {\n  const { collection: { fields, labels: { plural }, slug } = {}, collection, resetParams } = props\n\n  const { permissions } = useAuth()\n  const { closeModal } = useModal()\n  const {\n    routes: { api },\n    serverURL,\n  } = useConfig()\n  const { count, getQueryParams, selectAll } = useSelection()\n  const { i18n, t } = useTranslation('general')\n  const [selected, setSelected] = useState([])\n\n  const collectionPermissions = permissions?.collections?.[slug]\n  const hasUpdatePermission = collectionPermissions?.update?.permission\n\n  const drawerSlug = `edit-${slug}`\n\n  if (selectAll === SelectAllStatus.None || !hasUpdatePermission) {\n    return null\n  }\n\n  const onSuccess = () => {\n    resetParams({ page: selectAll === SelectAllStatus.AllAvailable ? 1 : undefined })\n  }\n\n  return (\n    <div className={baseClass}>\n      <DrawerToggler\n        aria-label={t('edit')}\n        className={`${baseClass}__toggle`}\n        onClick={() => {\n          setSelected([])\n        }}\n        slug={drawerSlug}\n      >\n        {t('edit')}\n      </DrawerToggler>\n      <Drawer header={null} slug={drawerSlug}>\n        <DocumentInfoProvider collection={collection}>\n          <OperationContext.Provider value=\"update\">\n            <Form className={`${baseClass}__form`} onSuccess={onSuccess}>\n              <div className={`${baseClass}__main`}>\n                <div className={`${baseClass}__header`}>\n                  <h2 className={`${baseClass}__header__title`}>\n                    {t('editingLabel', { count, label: getTranslation(plural, i18n) })}\n                  </h2>\n                  <button\n                    aria-label={t('close')}\n                    className={`${baseClass}__header__close`}\n                    id={`close-drawer__${drawerSlug}`}\n                    onClick={() => closeModal(drawerSlug)}\n                    type=\"button\"\n                  >\n                    <X />\n                  </button>\n                </div>\n                <FieldSelect fields={fields} setSelected={setSelected} />\n                <RenderFields fieldSchema={selected} fieldTypes={fieldTypes} />\n                <div className={`${baseClass}__sidebar-wrap`}>\n                  <div className={`${baseClass}__sidebar`}>\n                    <div className={`${baseClass}__sidebar-sticky-wrap`}>\n                      <div className={`${baseClass}__document-actions`}>\n                        {collection.versions ? (\n                          <React.Fragment>\n                            <Publish\n                              action={`${serverURL}${api}/${slug}${getQueryParams()}`}\n                              disabled={selected.length === 0}\n                            />\n                            <SaveDraft\n                              action={`${serverURL}${api}/${slug}${getQueryParams()}`}\n                              disabled={selected.length === 0}\n                            />\n                          </React.Fragment>\n                        ) : (\n                          <Submit\n                            action={`${serverURL}${api}/${slug}${getQueryParams()}`}\n                            disabled={selected.length === 0}\n                          />\n                        )}\n                      </div>\n                    </div>\n                  </div>\n                </div>\n              </div>\n            </Form>\n          </OperationContext.Provider>\n        </DocumentInfoProvider>\n      </Drawer>\n    </div>\n  )\n}\n\nexport default EditMany\n"],"names":["baseClass","Submit","action","disabled","submit","useForm","t","useTranslation","save","useCallback","method","skipValidation","FormSubmit","className","onClick","Publish","overrides","_status","SaveDraft","EditMany","props","collection","fields","labels","plural","slug","resetParams","permissions","useAuth","closeModal","useModal","routes","api","serverURL","useConfig","count","getQueryParams","selectAll","useSelection","i18n","selected","setSelected","useState","collectionPermissions","collections","hasUpdatePermission","update","permission","drawerSlug","SelectAllStatus","None","onSuccess","page","AllAvailable","undefined","div","DrawerToggler","aria-label","Drawer","header","DocumentInfoProvider","OperationContext","Provider","value","Form","h2","label","getTranslation","button","id","type","X","FieldSelect","RenderFields","fieldSchema","fieldTypes","versions","React","Fragment","length"],"mappings":"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"}