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