UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

219 lines (218 loc) • 23.1 kB
"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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"}