UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

317 lines (316 loc) • 37.6 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); Object.defineProperty(exports, "API", { enumerable: true, get: function() { return API; } }); const _react = /*#__PURE__*/ _interop_require_wildcard(require("react")); const _reacti18next = require("react-i18next"); const _ = require("../.."); const _api = require("../../../api"); const _CopyToClipboard = /*#__PURE__*/ _interop_require_default(require("../../elements/CopyToClipboard")); const _Gutter = require("../../elements/Gutter"); const _Input = require("../../forms/field-types/Checkbox/Input"); const _Input1 = /*#__PURE__*/ _interop_require_default(require("../../forms/field-types/Select/Input")); const _MinimizeMaximize = require("../../icons/MinimizeMaximize"); const _ActionsProvider = require("../../utilities/ActionsProvider"); const _Config = require("../../utilities/Config"); const _DocumentInfo = require("../../utilities/DocumentInfo"); const _Locale = require("../../utilities/Locale"); const _SetStepNav = require("../collections/Edit/SetStepNav"); 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 chars = { leftCurlyBracket: '\u007B', leftSquareBracket: '\u005B', rightCurlyBracket: '\u007D', rightSquareBracket: '\u005D' }; const baseClass = 'query-inspector'; const Bracket = ({ comma = false, position, type })=>{ const rightBracket = type === 'object' ? chars.rightCurlyBracket : chars.rightSquareBracket; const leftBracket = type === 'object' ? chars.leftCurlyBracket : chars.leftSquareBracket; const bracketToRender = position === 'end' ? rightBracket : leftBracket; return /*#__PURE__*/ _react.createElement("span", { className: `${baseClass}__bracket ${baseClass}__bracket--position-${position}` }, bracketToRender, position === 'end' && comma ? ',' : null); }; const RecursivelyRenderObjectData = ({ isEmpty = false, object, objectKey, parentType = 'object', trailingComma = false })=>{ const objectKeys = Object.keys(object); const objectLength = objectKeys.length; const [isOpen, setIsOpen] = _react.useState(true); return /*#__PURE__*/ _react.createElement("li", null, /*#__PURE__*/ _react.createElement("button", { "aria-label": "toggle", className: `${baseClass}__list-toggle ${isEmpty ? `${baseClass}__list-toggle--empty` : ''}`, onClick: ()=>setIsOpen(!isOpen), type: "button" }, isEmpty ? null : /*#__PURE__*/ _react.createElement(_.Chevron, { className: `${baseClass}__toggle-row-icon ${baseClass}__toggle-row-icon--${isOpen ? 'open' : 'closed'}` }), /*#__PURE__*/ _react.createElement("span", null, objectKey && `"${objectKey}": `, /*#__PURE__*/ _react.createElement(Bracket, { position: "start", type: parentType }), isEmpty ? /*#__PURE__*/ _react.createElement(Bracket, { comma: trailingComma, position: "end", type: parentType }) : null)), /*#__PURE__*/ _react.createElement("ul", { className: `${baseClass}__json-children` }, isOpen && objectKeys.map((key, keyIndex)=>{ let value = object[key]; let type = 'string'; const isLastKey = keyIndex === objectLength - 1; if (value === null) { type = 'null'; } else if (value instanceof Date) { type = 'date'; value = value.toISOString(); } else if (Array.isArray(value)) { type = 'array'; } else if (typeof value === 'object') { type = 'object'; } else if (typeof value === 'number') { type = 'number'; } else if (typeof value === 'boolean') { type = 'boolean'; } else { type = 'string'; } if (type === 'object' || type === 'array') { return /*#__PURE__*/ _react.createElement(RecursivelyRenderObjectData, { isEmpty: value.length === 0 || Object.keys(value).length === 0, key: `${key}-${keyIndex}`, object: value, objectKey: parentType === 'object' ? key : undefined, parentType: type, trailingComma: !isLastKey }); } if (type === 'date' || type === 'string' || type === 'null' || type === 'number' || type === 'boolean') { const parentHasKey = Boolean(parentType === 'object' && key); const rowClasses = [ `${baseClass}__row-line`, `${baseClass}__value-type--${type}`, `${baseClass}__row-line--${objectKey ? 'nested' : 'top'}` ].filter(Boolean).join(' '); return /*#__PURE__*/ _react.createElement("li", { className: rowClasses, key: `${key}-${keyIndex}` }, parentHasKey ? /*#__PURE__*/ _react.createElement("span", null, `"${key}": `) : null, /*#__PURE__*/ _react.createElement("span", { className: `${baseClass}__value` }, JSON.stringify(value)), isLastKey ? '' : ','); } })), !isEmpty && /*#__PURE__*/ _react.createElement("span", null, /*#__PURE__*/ _react.createElement(Bracket, { comma: trailingComma, position: "end", type: parentType }))); }; function createURL(url) { if (url.startsWith('/')) { const domain = window.location.origin; return new URL(url, domain); } else { return new URL(url); } } const API = (props)=>{ const { apiURL } = props; const { i18n } = (0, _reacti18next.useTranslation)(); const { localization, routes: { api }, serverURL } = (0, _Config.useConfig)(); const { id, collection, global } = (0, _DocumentInfo.useDocumentInfo)(); const { code } = (0, _Locale.useLocale)(); const url = createURL(apiURL); const { setViewActions } = (0, _ActionsProvider.useActions)(); const draftsEnabled = collection?.versions?.drafts || global?.versions?.drafts; const docEndpoint = global ? `/globals/${global.slug}` : `/${collection.slug}/${id}`; const [data, setData] = _react.useState({}); const [draft, setDraft] = _react.useState(url.searchParams.get('draft') === 'true'); const [locale, setLocale] = _react.useState(url.searchParams.get('locale') || code); const [depth, setDepth] = _react.useState(url.searchParams.get('depth') || '1'); const [authenticated, setAuthenticated] = _react.useState(true); const [fullscreen, setFullscreen] = _react.useState(false); const fetchURL = `${serverURL}${api}${docEndpoint}?locale=${locale}&draft=${draft}&depth=${depth}`; _react.useEffect(()=>{ const fetchData = async ()=>{ const request = await _api.requests.get(fetchURL, { credentials: authenticated ? 'include' : 'omit', headers: { 'Accept-Language': i18n.language } }); const json = await request.json(); setData(json); }; fetchData(); }, [ i18n.language, fetchURL, authenticated ]); _react.useEffect(()=>{ const editConfig = (collection || global)?.admin?.components?.views?.Edit; const apiActions = editConfig && 'API' in editConfig && 'actions' in editConfig.API ? editConfig.API.actions : []; setViewActions(apiActions); return ()=>{ setViewActions([]); }; }, [ collection, global, setViewActions ]); const localeOptions = localization && localization.locales.map((locale)=>({ label: locale.label, value: locale.code })); const classes = [ baseClass, fullscreen && `${baseClass}--fullscreen` ].filter(Boolean).join(' '); let isEditing; if ('collection' in props) { isEditing = props?.isEditing; } return /*#__PURE__*/ _react.createElement(_Gutter.Gutter, { className: classes, right: false }, /*#__PURE__*/ _react.createElement(_SetStepNav.SetStepNav, { collection: collection, global: global, id: id, isEditing: isEditing, view: "API" }), /*#__PURE__*/ _react.createElement("div", { className: `${baseClass}__configuration` }, /*#__PURE__*/ _react.createElement("div", { className: `${baseClass}__api-url` }, /*#__PURE__*/ _react.createElement("span", { className: `${baseClass}__label` }, "API URL ", /*#__PURE__*/ _react.createElement(_CopyToClipboard.default, { value: fetchURL })), /*#__PURE__*/ _react.createElement("a", { href: fetchURL, rel: "noopener noreferrer", target: "_blank" }, fetchURL)), /*#__PURE__*/ _react.createElement("div", { className: `${baseClass}__form-fields` }, /*#__PURE__*/ _react.createElement("div", { className: `${baseClass}__filter-query-checkboxes` }, draftsEnabled && /*#__PURE__*/ _react.createElement(_Input.CheckboxInput, { checked: draft, id: "draft-checkbox", label: "Draft", onToggle: ()=>setDraft(!draft) }), /*#__PURE__*/ _react.createElement(_Input.CheckboxInput, { checked: authenticated, id: "auth-checkbox", label: "Authenticated", onToggle: ()=>setAuthenticated(!authenticated) })), localeOptions && /*#__PURE__*/ _react.createElement(_Input1.default, { defaultValue: { label: locale, value: locale }, label: "Locale", name: "locale", onChange: (e)=>setLocale(e.value), options: localeOptions, path: "locale" }), /*#__PURE__*/ _react.createElement(_Input1.default, { defaultValue: { label: depth, value: depth }, label: "Depth", name: "depth", onChange: (e)=>setDepth(e.value), options: [ { label: '0', value: '0' }, { label: '1', value: '1' }, { label: '2', value: '2' }, { label: '3', value: '3' }, { label: '4', value: '4' } ], path: "depth" }))), /*#__PURE__*/ _react.createElement("div", { className: `${baseClass}__results-wrapper` }, /*#__PURE__*/ _react.createElement("div", { className: `${baseClass}__toggle-fullscreen-button-container` }, /*#__PURE__*/ _react.createElement("button", { "aria-label": "toggle fullscreen", className: `${baseClass}__toggle-fullscreen-button`, onClick: ()=>setFullscreen(!fullscreen), type: "button" }, /*#__PURE__*/ _react.createElement(_MinimizeMaximize.MinimizeMaximize, { isMinimized: !fullscreen }))), /*#__PURE__*/ _react.createElement("div", { className: `${baseClass}__results` }, /*#__PURE__*/ _react.createElement(RecursivelyRenderObjectData, { object: data })))); }; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/views/API/index.tsx"],"sourcesContent":["import * as React from 'react'\nimport { useTranslation } from 'react-i18next'\n\nimport type { EditViewProps } from '../types'\n\nimport { Chevron } from '../..'\nimport { requests } from '../../../api'\nimport CopyToClipboard from '../../elements/CopyToClipboard'\nimport { Gutter } from '../../elements/Gutter'\nimport { CheckboxInput } from '../../forms/field-types/Checkbox/Input'\nimport SelectInput from '../../forms/field-types/Select/Input'\nimport { MinimizeMaximize } from '../../icons/MinimizeMaximize'\nimport { useActions } from '../../utilities/ActionsProvider'\nimport { useConfig } from '../../utilities/Config'\nimport { useDocumentInfo } from '../../utilities/DocumentInfo'\nimport { useLocale } from '../../utilities/Locale'\nimport { SetStepNav } from '../collections/Edit/SetStepNav'\nimport './index.scss'\n\nconst chars = {\n  leftCurlyBracket: '\\u007B',\n  leftSquareBracket: '\\u005B',\n  rightCurlyBracket: '\\u007D',\n  rightSquareBracket: '\\u005D',\n}\n\nconst baseClass = 'query-inspector'\n\nconst Bracket = ({\n  comma = false,\n  position,\n  type,\n}: {\n  comma?: boolean\n  position: 'end' | 'start'\n  type: 'array' | 'object'\n}) => {\n  const rightBracket = type === 'object' ? chars.rightCurlyBracket : chars.rightSquareBracket\n  const leftBracket = type === 'object' ? chars.leftCurlyBracket : chars.leftSquareBracket\n  const bracketToRender = position === 'end' ? rightBracket : leftBracket\n  return (\n    <span className={`${baseClass}__bracket ${baseClass}__bracket--position-${position}`}>\n      {bracketToRender}\n      {position === 'end' && comma ? ',' : null}\n    </span>\n  )\n}\n\ntype Args = {\n  isEmpty?: boolean\n  object: Record<string, any> | any[]\n  objectKey?: string\n  parentType?: 'array' | 'object'\n  trailingComma?: boolean\n}\n\nconst RecursivelyRenderObjectData = ({\n  isEmpty = false,\n  object,\n  objectKey,\n  parentType = 'object',\n  trailingComma = false,\n}: Args) => {\n  const objectKeys = Object.keys(object)\n  const objectLength = objectKeys.length\n  const [isOpen, setIsOpen] = React.useState<boolean>(true)\n\n  return (\n    <li>\n      <button\n        aria-label=\"toggle\"\n        className={`${baseClass}__list-toggle ${isEmpty ? `${baseClass}__list-toggle--empty` : ''}`}\n        onClick={() => setIsOpen(!isOpen)}\n        type=\"button\"\n      >\n        {isEmpty ? null : (\n          <Chevron\n            className={`${baseClass}__toggle-row-icon ${baseClass}__toggle-row-icon--${\n              isOpen ? 'open' : 'closed'\n            }`}\n          />\n        )}\n        <span>\n          {objectKey && `\"${objectKey}\": `}\n          <Bracket position=\"start\" type={parentType} />\n          {isEmpty ? <Bracket comma={trailingComma} position=\"end\" type={parentType} /> : null}\n        </span>\n      </button>\n\n      <ul className={`${baseClass}__json-children`}>\n        {isOpen &&\n          objectKeys.map((key, keyIndex) => {\n            let value = object[key]\n            let type = 'string'\n            const isLastKey = keyIndex === objectLength - 1\n\n            if (value === null) {\n              type = 'null'\n            } else if (value instanceof Date) {\n              type = 'date'\n              value = value.toISOString()\n            } else if (Array.isArray(value)) {\n              type = 'array'\n            } else if (typeof value === 'object') {\n              type = 'object'\n            } else if (typeof value === 'number') {\n              type = 'number'\n            } else if (typeof value === 'boolean') {\n              type = 'boolean'\n            } else {\n              type = 'string'\n            }\n\n            if (type === 'object' || type === 'array') {\n              return (\n                <RecursivelyRenderObjectData\n                  isEmpty={value.length === 0 || Object.keys(value).length === 0}\n                  key={`${key}-${keyIndex}`}\n                  object={value}\n                  objectKey={parentType === 'object' ? key : undefined}\n                  parentType={type}\n                  trailingComma={!isLastKey}\n                />\n              )\n            }\n\n            if (\n              type === 'date' ||\n              type === 'string' ||\n              type === 'null' ||\n              type === 'number' ||\n              type === 'boolean'\n            ) {\n              const parentHasKey = Boolean(parentType === 'object' && key)\n\n              const rowClasses = [\n                `${baseClass}__row-line`,\n                `${baseClass}__value-type--${type}`,\n                `${baseClass}__row-line--${objectKey ? 'nested' : 'top'}`,\n              ]\n                .filter(Boolean)\n                .join(' ')\n\n              return (\n                <li className={rowClasses} key={`${key}-${keyIndex}`}>\n                  {parentHasKey ? <span>{`\"${key}\": `}</span> : null}\n\n                  <span className={`${baseClass}__value`}>{JSON.stringify(value)}</span>\n                  {isLastKey ? '' : ','}\n                </li>\n              )\n            }\n          })}\n      </ul>\n\n      {!isEmpty && (\n        <span>\n          <Bracket comma={trailingComma} position=\"end\" type={parentType} />\n        </span>\n      )}\n    </li>\n  )\n}\n\nfunction createURL(url: string) {\n  if (url.startsWith('/')) {\n    const domain = window.location.origin\n    return new URL(url, domain)\n  } else {\n    return new URL(url)\n  }\n}\n\nexport const API: React.FC<EditViewProps> = (props) => {\n  const { apiURL } = props\n  const { i18n } = useTranslation()\n  const {\n    localization,\n    routes: { api },\n    serverURL,\n  } = useConfig()\n  const { id, collection, global } = useDocumentInfo()\n  const { code } = useLocale()\n  const url = createURL(apiURL)\n\n  const { setViewActions } = useActions()\n\n  const draftsEnabled = collection?.versions?.drafts || global?.versions?.drafts\n  const docEndpoint = global ? `/globals/${global.slug}` : `/${collection.slug}/${id}`\n\n  const [data, setData] = React.useState<any>({})\n  const [draft, setDraft] = React.useState<boolean>(url.searchParams.get('draft') === 'true')\n  const [locale, setLocale] = React.useState<string>(url.searchParams.get('locale') || code)\n  const [depth, setDepth] = React.useState<string>(url.searchParams.get('depth') || '1')\n  const [authenticated, setAuthenticated] = React.useState<boolean>(true)\n  const [fullscreen, setFullscreen] = React.useState<boolean>(false)\n\n  const fetchURL = `${serverURL}${api}${docEndpoint}?locale=${locale}&draft=${draft}&depth=${depth}`\n\n  React.useEffect(() => {\n    const fetchData = async () => {\n      const request = await requests.get(fetchURL, {\n        credentials: authenticated ? 'include' : 'omit',\n        headers: {\n          'Accept-Language': i18n.language,\n        },\n      })\n\n      const json = await request.json()\n      setData(json)\n    }\n\n    fetchData()\n  }, [i18n.language, fetchURL, authenticated])\n\n  React.useEffect(() => {\n    const editConfig = (collection || global)?.admin?.components?.views?.Edit\n    const apiActions =\n      editConfig && 'API' in editConfig && 'actions' in editConfig.API ? editConfig.API.actions : []\n\n    setViewActions(apiActions)\n\n    return () => {\n      setViewActions([])\n    }\n  }, [collection, global, setViewActions])\n\n  const localeOptions =\n    localization &&\n    localization.locales.map((locale) => ({ label: locale.label, value: locale.code }))\n\n  const classes = [baseClass, fullscreen && `${baseClass}--fullscreen`].filter(Boolean).join(' ')\n\n  let isEditing: boolean\n\n  if ('collection' in props) {\n    isEditing = props?.isEditing\n  }\n\n  return (\n    <Gutter className={classes} right={false}>\n      <SetStepNav\n        collection={collection}\n        global={global}\n        id={id}\n        isEditing={isEditing}\n        view=\"API\"\n      />\n      <div className={`${baseClass}__configuration`}>\n        <div className={`${baseClass}__api-url`}>\n          <span className={`${baseClass}__label`}>\n            API URL <CopyToClipboard value={fetchURL} />\n          </span>\n          <a href={fetchURL} rel=\"noopener noreferrer\" target=\"_blank\">\n            {fetchURL}\n          </a>\n        </div>\n\n        <div className={`${baseClass}__form-fields`}>\n          <div className={`${baseClass}__filter-query-checkboxes`}>\n            {draftsEnabled && (\n              <CheckboxInput\n                checked={draft}\n                id=\"draft-checkbox\"\n                label=\"Draft\"\n                onToggle={() => setDraft(!draft)}\n              />\n            )}\n            <CheckboxInput\n              checked={authenticated}\n              id=\"auth-checkbox\"\n              label=\"Authenticated\"\n              onToggle={() => setAuthenticated(!authenticated)}\n            />\n          </div>\n\n          {localeOptions && (\n            <SelectInput\n              defaultValue={{\n                label: locale,\n                value: locale,\n              }}\n              label=\"Locale\"\n              name=\"locale\"\n              onChange={(e) => setLocale(e.value as string)}\n              options={localeOptions}\n              path=\"locale\"\n            />\n          )}\n          <SelectInput\n            defaultValue={{\n              label: depth,\n              value: depth,\n            }}\n            label=\"Depth\"\n            name=\"depth\"\n            onChange={(e) => setDepth(e.value as string)}\n            options={[\n              {\n                label: '0',\n                value: '0',\n              },\n              {\n                label: '1',\n                value: '1',\n              },\n              {\n                label: '2',\n                value: '2',\n              },\n              {\n                label: '3',\n                value: '3',\n              },\n              {\n                label: '4',\n                value: '4',\n              },\n            ]}\n            path=\"depth\"\n          />\n        </div>\n      </div>\n\n      <div className={`${baseClass}__results-wrapper`}>\n        <div className={`${baseClass}__toggle-fullscreen-button-container`}>\n          <button\n            aria-label=\"toggle fullscreen\"\n            className={`${baseClass}__toggle-fullscreen-button`}\n            onClick={() => setFullscreen(!fullscreen)}\n            type=\"button\"\n          >\n            <MinimizeMaximize isMinimized={!fullscreen} />\n          </button>\n        </div>\n        <div className={`${baseClass}__results`}>\n          <RecursivelyRenderObjectData object={data} />\n        </div>\n      </div>\n    </Gutter>\n  )\n}\n"],"names":["API","chars","leftCurlyBracket","leftSquareBracket","rightCurlyBracket","rightSquareBracket","baseClass","Bracket","comma","position","type","rightBracket","leftBracket","bracketToRender","span","className","RecursivelyRenderObjectData","isEmpty","object","objectKey","parentType","trailingComma","objectKeys","Object","keys","objectLength","length","isOpen","setIsOpen","React","useState","li","button","aria-label","onClick","Chevron","ul","map","key","keyIndex","value","isLastKey","Date","toISOString","Array","isArray","undefined","parentHasKey","Boolean","rowClasses","filter","join","JSON","stringify","createURL","url","startsWith","domain","window","location","origin","URL","props","apiURL","i18n","useTranslation","localization","routes","api","serverURL","useConfig","id","collection","global","useDocumentInfo","code","useLocale","setViewActions","useActions","draftsEnabled","versions","drafts","docEndpoint","slug","data","setData","draft","setDraft","searchParams","get","locale","setLocale","depth","setDepth","authenticated","setAuthenticated","fullscreen","setFullscreen","fetchURL","useEffect","fetchData","request","requests","credentials","headers","language","json","editConfig","admin","components","views","Edit","apiActions","actions","localeOptions","locales","label","classes","isEditing","Gutter","right","SetStepNav","view","div","CopyToClipboard","a","href","rel","target","CheckboxInput","checked","onToggle","SelectInput","defaultValue","name","onChange","e","options","path","MinimizeMaximize","isMinimized"],"mappings":"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"}