UNPKG

@selfcommunity/react-core

Version:

React Core Components useful for integrating UI Community components (react-ui).

97 lines (96 loc) 4.22 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const api_services_1 = require("@selfcommunity/api-services"); const utils_1 = require("@selfcommunity/utils"); const react_1 = require("react"); const use_deep_compare_effect_1 = require("use-deep-compare-effect"); const SCUserProvider_1 = require("../components/provider/SCUserProvider"); const Cache_1 = require("../constants/Cache"); const Errors_1 = require("../constants/Errors"); /** :::info This custom hook is used to fetch a course object. ::: * @param object * @param object.id * @param object.course * @param object.cacheStrategy * @param object.params */ function useSCFetchCourse({ id = null, course = null, cacheStrategy = utils_1.CacheStrategies.CACHE_FIRST, params = null, }) { const __courseId = (0, react_1.useMemo)(() => (course === null || course === void 0 ? void 0 : course.id) || id, [course, id]); // CONTEXT const scUserContext = (0, SCUserProvider_1.useSCUser)(); const authUserId = (0, react_1.useMemo)(() => { var _a; return ((_a = scUserContext.user) === null || _a === void 0 ? void 0 : _a.id) || null; }, [scUserContext.user]); // CACHE const __courseCacheKey = (0, react_1.useMemo)(() => (0, Cache_1.getCourseObjectCacheKey)(__courseId), [__courseId]); const __course = (0, react_1.useMemo)(() => (authUserId ? course : (0, utils_1.objectWithoutProperties)(course, ['join_status'])), [authUserId, course]); const [scCourse, setScCourse] = (0, react_1.useState)(cacheStrategy !== utils_1.CacheStrategies.NETWORK_ONLY ? utils_1.LRUCache.get(__courseCacheKey, __course) : null); const [error, setError] = (0, react_1.useState)(null); const setSCCourse = (0, react_1.useCallback)((c) => { setScCourse(c); utils_1.LRUCache.set(__courseCacheKey, c); }, [setScCourse, __courseCacheKey]); /** * Memoized fetchTag */ const fetchCourse = (0, react_1.useMemo)(() => (id) => { return api_services_1.http .request({ url: api_services_1.Endpoints.GetCourseInfo.url({ id }), method: api_services_1.Endpoints.GetCourseInfo.method, params: params !== null && params !== void 0 ? params : {}, }) .then((res) => { if (res.status >= 300) { return Promise.reject(res); } return Promise.resolve(res.data); }); }, []); /** * Refresh course */ const refreshCourse = (0, react_1.useMemo)(() => () => { fetchCourse(id) .then((e) => { setSCCourse(e); }) .catch((err) => { utils_1.LRUCache.delete(__courseCacheKey); setError(`Error on refresh course with id ${id}`); utils_1.Logger.error(Errors_1.SCOPE_SC_CORE, `Error on refresh course with id ${id}`); utils_1.Logger.error(Errors_1.SCOPE_SC_CORE, err.message); }); }, [id, __courseCacheKey, setSCCourse]); /** * If id attempt to get the course by id */ (0, react_1.useEffect)(() => { if (id !== null && id !== undefined && !course) { fetchCourse(id) .then((e) => { setSCCourse(e); }) .catch((err) => { utils_1.LRUCache.delete(__courseCacheKey); if (err.status === 403) { setError('You do not have permission to perform this action.'); utils_1.Logger.error(Errors_1.SCOPE_SC_CORE, 'You do not have permission to perform this action.'); } else { setError(`Course with id ${id} not found`); utils_1.Logger.error(Errors_1.SCOPE_SC_CORE, `Course with id ${id} not found`); } utils_1.Logger.error(Errors_1.SCOPE_SC_CORE, err.message); }); } }, [id, course, authUserId]); (0, use_deep_compare_effect_1.useDeepCompareEffectNoCheck)(() => { if (course) { setSCCourse(course); } }, [course, authUserId]); return { scCourse, setSCCourse, error, refreshCourse }; } exports.default = useSCFetchCourse;