UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

155 lines (154 loc) • 13.5 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); function _export(target, all) { for(var name in all)Object.defineProperty(target, name, { enumerable: true, get: all[name] }); } _export(exports, { RelationshipProvider: function() { return RelationshipProvider; }, useListRelationships: function() { return useListRelationships; } }); const _qs = /*#__PURE__*/ _interop_require_default(require("qs")); const _react = /*#__PURE__*/ _interop_require_wildcard(require("react")); const _reacti18next = require("react-i18next"); const _useDebounce = /*#__PURE__*/ _interop_require_default(require("../../../../../hooks/useDebounce")); const _Config = require("../../../../utilities/Config"); const _Locale = require("../../../../utilities/Locale"); const _reducer = require("./reducer"); 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 Context = /*#__PURE__*/ (0, _react.createContext)({}); const RelationshipProvider = ({ children })=>{ const [documents, dispatchDocuments] = (0, _react.useReducer)(_reducer.reducer, {}); const debouncedDocuments = (0, _useDebounce.default)(documents, 100); const config = (0, _Config.useConfig)(); const { i18n } = (0, _reacti18next.useTranslation)(); const { code: locale } = (0, _Locale.useLocale)(); const prevLocale = (0, _react.useRef)(locale); const { routes: { api }, serverURL } = config; const loadRelationshipDocs = (0, _react.useCallback)(async (reloadAll = false)=>{ Object.entries(debouncedDocuments).forEach(async ([slug, docs])=>{ const idsToLoad = []; Object.entries(docs).forEach(([id, value])=>{ if (value === null || reloadAll) { idsToLoad.push(id); } }); if (idsToLoad.length > 0) { const url = `${serverURL}${api}/${slug}`; const params = { depth: 0, limit: 250, locale, 'where[id][in]': idsToLoad }; const query = _qs.default.stringify(params, { addQueryPrefix: true }); const result = await fetch(`${url}${query}`, { credentials: 'include', headers: { 'Accept-Language': i18n.language } }); if (result.ok) { const json = await result.json(); if (json.docs) { dispatchDocuments({ docs: json.docs, idsToLoad, relationTo: slug, type: 'ADD_LOADED' }); } } else { dispatchDocuments({ docs: [], idsToLoad, relationTo: slug, type: 'ADD_LOADED' }); } } }); }, [ debouncedDocuments, serverURL, api, i18n, locale ]); (0, _react.useEffect)(()=>{ loadRelationshipDocs(locale && prevLocale.current !== locale); prevLocale.current = locale; }, [ locale, loadRelationshipDocs ]); const getRelationships = (0, _react.useCallback)(async (relationships)=>{ dispatchDocuments({ docs: relationships, type: 'REQUEST' }); }, []); return /*#__PURE__*/ _react.default.createElement(Context.Provider, { value: { documents, getRelationships } }, children); }; const useListRelationships = ()=>(0, _react.useContext)(Context); //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../../src/admin/components/views/collections/List/RelationshipProvider/index.tsx"],"sourcesContent":["import querystring from 'qs'\nimport React, { createContext, useCallback, useContext, useEffect, useReducer, useRef } from 'react'\nimport { useTranslation } from 'react-i18next'\n\nimport type { TypeWithID } from '../../../../../../collections/config/types'\n\nimport useDebounce from '../../../../../hooks/useDebounce'\nimport { useConfig } from '../../../../utilities/Config'\nimport { useLocale } from '../../../../utilities/Locale'\nimport { reducer } from './reducer'\n\n// documents are first set to null when requested\n// set to false when no doc is returned\n// or set to the document returned\nexport type Documents = {\n  [slug: string]: {\n    [id: number | string]: TypeWithID | false | null\n  }\n}\n\ntype ListRelationshipContext = {\n  documents: Documents\n  getRelationships: (\n    docs: {\n      relationTo: string\n      value: number | string\n    }[],\n  ) => void\n}\n\nconst Context = createContext({} as ListRelationshipContext)\n\nexport const RelationshipProvider: React.FC<{ children?: React.ReactNode }> = ({ children }) => {\n  const [documents, dispatchDocuments] = useReducer(reducer, {})\n  const debouncedDocuments = useDebounce(documents, 100)\n  const config = useConfig()\n  const { i18n } = useTranslation()\n  const { code: locale } = useLocale()\n  const prevLocale = useRef(locale)\n\n  const {\n    routes: { api },\n    serverURL,\n  } = config\n\n  const loadRelationshipDocs = useCallback(\n    async (reloadAll = false) => {\n      Object.entries(debouncedDocuments).forEach(async ([slug, docs]) => {\n        const idsToLoad: (number | string)[] = []\n\n        Object.entries(docs).forEach(([id, value]) => {\n          if (value === null || reloadAll) {\n            idsToLoad.push(id)\n          }\n        })\n\n        if (idsToLoad.length > 0) {\n          const url = `${serverURL}${api}/${slug}`\n          const params = {\n            depth: 0,\n            limit: 250,\n            locale,\n            'where[id][in]': idsToLoad,\n          }\n\n          const query = querystring.stringify(params, { addQueryPrefix: true })\n          const result = await fetch(`${url}${query}`, {\n            credentials: 'include',\n            headers: {\n              'Accept-Language': i18n.language,\n            },\n          })\n\n          if (result.ok) {\n            const json = await result.json()\n            if (json.docs) {\n              dispatchDocuments({\n                docs: json.docs,\n                idsToLoad,\n                relationTo: slug,\n                type: 'ADD_LOADED',\n              })\n            }\n          } else {\n            dispatchDocuments({ docs: [], idsToLoad, relationTo: slug, type: 'ADD_LOADED' })\n          }\n        }\n      })\n    },\n    [debouncedDocuments, serverURL, api, i18n, locale],\n  )\n\n  useEffect(() => {\n    loadRelationshipDocs(locale && prevLocale.current !== locale)\n    prevLocale.current = locale\n  }, [locale, loadRelationshipDocs])\n\n  const getRelationships = useCallback(\n    async (relationships: { relationTo: string; value: number | string }[]) => {\n      dispatchDocuments({ docs: relationships, type: 'REQUEST' })\n    },\n    [],\n  )\n\n  return <Context.Provider value={{ documents, getRelationships }}>{children}</Context.Provider>\n}\n\nexport const useListRelationships = (): ListRelationshipContext => useContext(Context)\n"],"names":["RelationshipProvider","useListRelationships","Context","createContext","children","documents","dispatchDocuments","useReducer","reducer","debouncedDocuments","useDebounce","config","useConfig","i18n","useTranslation","code","locale","useLocale","prevLocale","useRef","routes","api","serverURL","loadRelationshipDocs","useCallback","reloadAll","Object","entries","forEach","slug","docs","idsToLoad","id","value","push","length","url","params","depth","limit","query","querystring","stringify","addQueryPrefix","result","fetch","credentials","headers","language","ok","json","relationTo","type","useEffect","current","getRelationships","relationships","Provider","useContext"],"mappings":";;;;;;;;;;;IAgCaA,oBAAoB;eAApBA;;IA2EAC,oBAAoB;eAApBA;;;2DA3GW;+DACqE;8BAC9D;oEAIP;wBACE;wBACA;yBACF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAqBxB,MAAMC,wBAAUC,IAAAA,oBAAa,EAAC,CAAC;AAExB,MAAMH,uBAAiE,CAAC,EAAEI,QAAQ,EAAE;IACzF,MAAM,CAACC,WAAWC,kBAAkB,GAAGC,IAAAA,iBAAU,EAACC,gBAAO,EAAE,CAAC;IAC5D,MAAMC,qBAAqBC,IAAAA,oBAAW,EAACL,WAAW;IAClD,MAAMM,SAASC,IAAAA,iBAAS;IACxB,MAAM,EAAEC,IAAI,EAAE,GAAGC,IAAAA,4BAAc;IAC/B,MAAM,EAAEC,MAAMC,MAAM,EAAE,GAAGC,IAAAA,iBAAS;IAClC,MAAMC,aAAaC,IAAAA,aAAM,EAACH;IAE1B,MAAM,EACJI,QAAQ,EAAEC,GAAG,EAAE,EACfC,SAAS,EACV,GAAGX;IAEJ,MAAMY,uBAAuBC,IAAAA,kBAAW,EACtC,OAAOC,YAAY,KAAK;QACtBC,OAAOC,OAAO,CAAClB,oBAAoBmB,OAAO,CAAC,OAAO,CAACC,MAAMC,KAAK;YAC5D,MAAMC,YAAiC,EAAE;YAEzCL,OAAOC,OAAO,CAACG,MAAMF,OAAO,CAAC,CAAC,CAACI,IAAIC,MAAM;gBACvC,IAAIA,UAAU,QAAQR,WAAW;oBAC/BM,UAAUG,IAAI,CAACF;gBACjB;YACF;YAEA,IAAID,UAAUI,MAAM,GAAG,GAAG;gBACxB,MAAMC,MAAM,CAAC,EAAEd,UAAU,EAAED,IAAI,CAAC,EAAEQ,KAAK,CAAC;gBACxC,MAAMQ,SAAS;oBACbC,OAAO;oBACPC,OAAO;oBACPvB;oBACA,iBAAiBe;gBACnB;gBAEA,MAAMS,QAAQC,WAAW,CAACC,SAAS,CAACL,QAAQ;oBAAEM,gBAAgB;gBAAK;gBACnE,MAAMC,SAAS,MAAMC,MAAM,CAAC,EAAET,IAAI,EAAEI,MAAM,CAAC,EAAE;oBAC3CM,aAAa;oBACbC,SAAS;wBACP,mBAAmBlC,KAAKmC,QAAQ;oBAClC;gBACF;gBAEA,IAAIJ,OAAOK,EAAE,EAAE;oBACb,MAAMC,OAAO,MAAMN,OAAOM,IAAI;oBAC9B,IAAIA,KAAKpB,IAAI,EAAE;wBACbxB,kBAAkB;4BAChBwB,MAAMoB,KAAKpB,IAAI;4BACfC;4BACAoB,YAAYtB;4BACZuB,MAAM;wBACR;oBACF;gBACF,OAAO;oBACL9C,kBAAkB;wBAAEwB,MAAM,EAAE;wBAAEC;wBAAWoB,YAAYtB;wBAAMuB,MAAM;oBAAa;gBAChF;YACF;QACF;IACF,GACA;QAAC3C;QAAoBa;QAAWD;QAAKR;QAAMG;KAAO;IAGpDqC,IAAAA,gBAAS,EAAC;QACR9B,qBAAqBP,UAAUE,WAAWoC,OAAO,KAAKtC;QACtDE,WAAWoC,OAAO,GAAGtC;IACvB,GAAG;QAACA;QAAQO;KAAqB;IAEjC,MAAMgC,mBAAmB/B,IAAAA,kBAAW,EAClC,OAAOgC;QACLlD,kBAAkB;YAAEwB,MAAM0B;YAAeJ,MAAM;QAAU;IAC3D,GACA,EAAE;IAGJ,qBAAO,6BAAClD,QAAQuD,QAAQ;QAACxB,OAAO;YAAE5B;YAAWkD;QAAiB;OAAInD;AACpE;AAEO,MAAMH,uBAAuB,IAA+ByD,IAAAA,iBAAU,EAACxD"}