@openmrs/esm-app-shell 8.0.1-pre.3783 → 8.0.1-pre.3786

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (50) hide show
  1. package/.turbo/turbo-build.log +9 -9
  2. package/dist/1aae2824ab4cfb18.js.map +1 -0
  3. package/dist/3a53ffcc01189e32.js.map +1 -0
  4. package/dist/6424d3e282801be1.js.map +1 -0
  5. package/dist/ce6b7df8d10e9ce8.js.map +1 -0
  6. package/dist/index.html +1 -1
  7. package/dist/{openmrs.9d2c16ca3f8dd751.js → openmrs.6e296921eb685274.js} +1 -1
  8. package/dist/{openmrs.9d2c16ca3f8dd751.js.map → openmrs.6e296921eb685274.js.map} +1 -1
  9. package/dist/service-worker.js +1 -1
  10. package/lib/{f6407c15881d934e.js → 5eb49ace081ba40a.js} +29 -29
  11. package/lib/{f6511157fbbd5327.js → a2ed1505d14f2a59.js} +1 -1
  12. package/lib/{3638c8e3f0e987f1.js → d9f2f67efb776126.js} +12 -12
  13. package/lib/esm-help-menu-app/460.js.map +1 -1
  14. package/lib/esm-help-menu-app/main.js +1 -1
  15. package/lib/esm-help-menu-app/openmrs-esm-help-menu-app.js +1 -1
  16. package/lib/esm-help-menu-app/openmrs-esm-help-menu-app.js.buildmanifest.json +5 -5
  17. package/lib/esm-help-menu-app/routes.json +1 -1
  18. package/lib/esm-implementer-tools-app/5460.js.map +1 -1
  19. package/lib/esm-implementer-tools-app/main.js +1 -1
  20. package/lib/esm-implementer-tools-app/openmrs-esm-implementer-tools-app.js +1 -1
  21. package/lib/esm-implementer-tools-app/openmrs-esm-implementer-tools-app.js.buildmanifest.json +5 -5
  22. package/lib/esm-implementer-tools-app/routes.json +1 -1
  23. package/lib/esm-login-app/14.js.map +1 -1
  24. package/lib/esm-login-app/main.js +1 -1
  25. package/lib/esm-login-app/openmrs-esm-login-app.js +1 -1
  26. package/lib/esm-login-app/openmrs-esm-login-app.js.buildmanifest.json +5 -5
  27. package/lib/esm-login-app/routes.json +1 -1
  28. package/lib/esm-offline-tools-app/5460.js.map +1 -1
  29. package/lib/esm-offline-tools-app/main.js +1 -1
  30. package/lib/esm-offline-tools-app/openmrs-esm-offline-tools-app.js +1 -1
  31. package/lib/esm-offline-tools-app/openmrs-esm-offline-tools-app.js.buildmanifest.json +5 -5
  32. package/lib/esm-offline-tools-app/routes.json +1 -1
  33. package/lib/esm-primary-navigation-app/5460.js.map +1 -1
  34. package/lib/esm-primary-navigation-app/main.js +1 -1
  35. package/lib/esm-primary-navigation-app/openmrs-esm-primary-navigation-app.js +1 -1
  36. package/lib/esm-primary-navigation-app/openmrs-esm-primary-navigation-app.js.buildmanifest.json +5 -5
  37. package/lib/esm-primary-navigation-app/routes.json +1 -1
  38. package/lib/{abbcede00223b828.js → fa464755b8e8e50b.js} +3 -3
  39. package/lib/index.html +1 -1
  40. package/lib/openmrs.js +9 -9
  41. package/lib/service-worker.js +1 -1
  42. package/package.json +3 -3
  43. package/dist/1d1bdf194ce3de30.js.map +0 -1
  44. package/dist/22d92f2e1d413f13.js.map +0 -1
  45. package/dist/5916e32850548842.js.map +0 -1
  46. package/dist/cab43002f9e725ab.js.map +0 -1
  47. /package/dist/{1d1bdf194ce3de30.js → 1aae2824ab4cfb18.js} +0 -0
  48. /package/dist/{cab43002f9e725ab.js → 3a53ffcc01189e32.js} +0 -0
  49. /package/dist/{22d92f2e1d413f13.js → 6424d3e282801be1.js} +0 -0
  50. /package/dist/{5916e32850548842.js → ce6b7df8d10e9ce8.js} +0 -0
@@ -25,7 +25,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
25
25
  \****************************************************/
26
26
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
27
27
 
28
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ clearCurrentUser: () => (/* binding */ clearCurrentUser),\n/* harmony export */ getCurrentUser: () => (/* binding */ getCurrentUser),\n/* harmony export */ getLoggedInUser: () => (/* binding */ getLoggedInUser),\n/* harmony export */ getSessionLocation: () => (/* binding */ getSessionLocation),\n/* harmony export */ getSessionStore: () => (/* binding */ getSessionStore),\n/* harmony export */ refetchCurrentUser: () => (/* binding */ refetchCurrentUser),\n/* harmony export */ sessionStore: () => (/* binding */ sessionStore),\n/* harmony export */ setSessionLocation: () => (/* binding */ setSessionLocation),\n/* harmony export */ setUserLanguage: () => (/* binding */ setUserLanguage),\n/* harmony export */ setUserProperties: () => (/* binding */ setUserProperties),\n/* harmony export */ userHasAccess: () => (/* binding */ userHasAccess)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_error_handling__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-error-handling */ \"../../framework/esm-error-handling/dist/index.js\");\n/* harmony import */ var _openmrs_esm_state__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-state */ \"../../framework/esm-state/dist/index.js\");\n/* harmony import */ var lodash_es__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! lodash-es */ \"../../../node_modules/lodash-es/isUndefined.js\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! rxjs */ \"webpack/sharing/consume/default/rxjs/rxjs\");\n/* harmony import */ var _openmrs_fetch_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./openmrs-fetch.js */ \"../../framework/esm-api/dist/openmrs-fetch.js\");\n/** @module @category API */ \n\n\n\n\n/** @internal */ const sessionStore = (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_1__.createGlobalStore)('session', {\n loaded: false,\n session: null\n});\nlet lastFetchTimeMillis = 0;\nfunction getCurrentUser(opts = {\n includeAuthStatus: true\n}) {\n if (lastFetchTimeMillis < Date.now() - 1000 * 60 || !sessionStore.getState().loaded) {\n refetchCurrentUser();\n }\n return new rxjs__WEBPACK_IMPORTED_MODULE_2__.Observable((subscriber)=>{\n const handler = (state)=>{\n if (state.loaded) {\n if (opts.includeAuthStatus) {\n subscriber.next(state.session);\n } else {\n subscriber.next(state.session?.user);\n }\n }\n };\n handler(sessionStore.getState());\n // The observable subscribe function should return an unsubscribe function,\n // which happens to be exactly what `subscribe` returns.\n return sessionStore.subscribe(handler);\n });\n}\n\nfunction getSessionStore() {\n if (lastFetchTimeMillis < Date.now() - 1000 * 60 || !sessionStore.getState().loaded) {\n refetchCurrentUser();\n }\n return sessionStore;\n}\n// NB locale is string only if this returns true\nfunction isValidLocale(locale) {\n if (locale === undefined || typeof locale !== 'string') {\n return false;\n }\n try {\n new Intl.Locale(locale);\n } catch (e) {\n return false;\n }\n return true;\n}\nfunction setUserLanguage(data) {\n let locale = data.locale ?? data.user?.userProperties?.defaultLocale;\n if (locale && locale.includes('_')) {\n locale = locale.replaceAll('_', '-');\n }\n if (isValidLocale(locale) && locale !== document.documentElement.getAttribute('lang')) {\n document.documentElement.setAttribute('lang', locale);\n }\n}\nsessionStore.subscribe((state)=>{\n if (state.loaded && state.session) {\n setUserLanguage(state.session);\n }\n});\nfunction userHasPrivilege(requiredPrivilege, user) {\n if (typeof requiredPrivilege === 'string') {\n return !(0,lodash_es__WEBPACK_IMPORTED_MODULE_4__[\"default\"])(user.privileges.find((p)=>requiredPrivilege === p.display));\n } else if (Array.isArray(requiredPrivilege)) {\n return requiredPrivilege.every((rp)=>!(0,lodash_es__WEBPACK_IMPORTED_MODULE_4__[\"default\"])(user.privileges.find((p)=>rp === p.display)));\n } else if (!(0,lodash_es__WEBPACK_IMPORTED_MODULE_4__[\"default\"])(requiredPrivilege)) {\n console.error(`Could not understand privileges \"${requiredPrivilege}\"`);\n }\n return true;\n}\nfunction isSuperUser(user) {\n return !(0,lodash_es__WEBPACK_IMPORTED_MODULE_4__[\"default\"])(user.roles.find((role)=>role.display === 'System Developer'));\n}\n/**\n * The `refetchCurrentUser` function causes a network request to redownload\n * the user. All subscribers to the current user will be notified of the\n * new users once the new version of the user object is downloaded.\n *\n * @returns The same observable as returned by [[getCurrentUser]].\n *\n * #### Example\n * ```js\n * import { refetchCurrentUser } from '@openmrs/esm-api'\n * refetchCurrentUser()\n * ```\n */ function refetchCurrentUser(username, password) {\n lastFetchTimeMillis = Date.now();\n let headers = {};\n if (username && password) {\n headers['Authorization'] = `Basic ${window.btoa(`${username}:${password}`)}`;\n }\n return handleSessionResponse((0,_openmrs_fetch_js__WEBPACK_IMPORTED_MODULE_3__.openmrsFetch)(_openmrs_fetch_js__WEBPACK_IMPORTED_MODULE_3__.sessionEndpoint, {\n headers\n }));\n}\nfunction clearCurrentUser() {\n sessionStore.setState({\n loaded: true,\n session: {\n authenticated: false,\n sessionId: ''\n }\n });\n}\nfunction userHasAccess(requiredPrivilege, user) {\n if (user === undefined) {\n // if the user hasn't been loaded, then return false iff there is a required privilege\n return !Boolean(requiredPrivilege);\n }\n if (!Boolean(requiredPrivilege)) {\n // if user exists but no requiredPrivilege is defined\n return true;\n }\n return userHasPrivilege(requiredPrivilege, user) || isSuperUser(user);\n}\nfunction getLoggedInUser() {\n let user;\n let unsubscribe;\n return new Promise((res)=>{\n const handler = (state)=>{\n if (state.loaded && state.session.user) {\n user = state.session.user;\n res(state.session.user);\n if (unsubscribe) {\n unsubscribe();\n }\n }\n };\n handler(sessionStore.getState());\n if (!user) {\n unsubscribe = sessionStore.subscribe(handler);\n }\n });\n}\nfunction getSessionLocation() {\n return new Promise((res, rej)=>{\n const sub = getCurrentUser().subscribe((session)=>{\n res(session.sessionLocation);\n }, rej);\n sub.unsubscribe();\n });\n}\nasync function setSessionLocation(locationUuid, abortController) {\n return handleSessionResponse((0,_openmrs_fetch_js__WEBPACK_IMPORTED_MODULE_3__.openmrsFetch)(_openmrs_fetch_js__WEBPACK_IMPORTED_MODULE_3__.sessionEndpoint, {\n method: 'POST',\n body: {\n sessionLocation: locationUuid\n },\n headers: {\n 'Content-Type': 'application/json'\n },\n signal: abortController.signal\n }));\n}\nasync function setUserProperties(userUuid, userProperties, abortController) {\n if (!abortController) {\n abortController = new AbortController();\n }\n await (0,_openmrs_fetch_js__WEBPACK_IMPORTED_MODULE_3__.openmrsFetch)(`${_openmrs_fetch_js__WEBPACK_IMPORTED_MODULE_3__.restBaseUrl}/user/${userUuid}`, {\n method: 'POST',\n body: {\n userProperties\n },\n headers: {\n 'Content-Type': 'application/json'\n },\n signal: abortController.signal\n });\n return refetchCurrentUser();\n}\nfunction handleSessionResponse(result) {\n return new Promise((resolve, reject)=>{\n result.then((res)=>{\n let nextState;\n if (typeof res?.data === 'object') {\n nextState = {\n loaded: true,\n session: res.data\n };\n sessionStore.setState(nextState);\n resolve(nextState);\n } else {\n nextState = {\n loaded: false,\n session: null\n };\n sessionStore.setState(nextState);\n reject(nextState);\n }\n }).catch((err)=>{\n (0,_openmrs_esm_error_handling__WEBPACK_IMPORTED_MODULE_0__.reportError)(`Failed to fetch new session information: ${err}`);\n const nextState = {\n loaded: false,\n session: null\n };\n sessionStore.setState(nextState);\n reject(nextState);\n });\n });\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-api/dist/current-user.js","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-api/dist/current-user.js?c00f"],"sourcesContent":["/** @module @category API */ import { reportError } from \"@openmrs/esm-error-handling\";\nimport { createGlobalStore } from \"@openmrs/esm-state\";\nimport { isUndefined } from \"lodash-es\";\nimport { Observable } from \"rxjs\";\nimport { openmrsFetch, restBaseUrl, sessionEndpoint } from \"./openmrs-fetch.js\";\n/** @internal */ export const sessionStore = createGlobalStore('session', {\n    loaded: false,\n    session: null\n});\nlet lastFetchTimeMillis = 0;\nfunction getCurrentUser(opts = {\n    includeAuthStatus: true\n}) {\n    if (lastFetchTimeMillis < Date.now() - 1000 * 60 || !sessionStore.getState().loaded) {\n        refetchCurrentUser();\n    }\n    return new Observable((subscriber)=>{\n        const handler = (state)=>{\n            if (state.loaded) {\n                if (opts.includeAuthStatus) {\n                    subscriber.next(state.session);\n                } else {\n                    subscriber.next(state.session?.user);\n                }\n            }\n        };\n        handler(sessionStore.getState());\n        // The observable subscribe function should return an unsubscribe function,\n        // which happens to be exactly what `subscribe` returns.\n        return sessionStore.subscribe(handler);\n    });\n}\nexport { getCurrentUser };\nexport function getSessionStore() {\n    if (lastFetchTimeMillis < Date.now() - 1000 * 60 || !sessionStore.getState().loaded) {\n        refetchCurrentUser();\n    }\n    return sessionStore;\n}\n// NB locale is string only if this returns true\nfunction isValidLocale(locale) {\n    if (locale === undefined || typeof locale !== 'string') {\n        return false;\n    }\n    try {\n        new Intl.Locale(locale);\n    } catch (e) {\n        return false;\n    }\n    return true;\n}\nexport function setUserLanguage(data) {\n    let locale = data.locale ?? data.user?.userProperties?.defaultLocale;\n    if (locale && locale.includes('_')) {\n        locale = locale.replaceAll('_', '-');\n    }\n    if (isValidLocale(locale) && locale !== document.documentElement.getAttribute('lang')) {\n        document.documentElement.setAttribute('lang', locale);\n    }\n}\nsessionStore.subscribe((state)=>{\n    if (state.loaded && state.session) {\n        setUserLanguage(state.session);\n    }\n});\nfunction userHasPrivilege(requiredPrivilege, user) {\n    if (typeof requiredPrivilege === 'string') {\n        return !isUndefined(user.privileges.find((p)=>requiredPrivilege === p.display));\n    } else if (Array.isArray(requiredPrivilege)) {\n        return requiredPrivilege.every((rp)=>!isUndefined(user.privileges.find((p)=>rp === p.display)));\n    } else if (!isUndefined(requiredPrivilege)) {\n        console.error(`Could not understand privileges \"${requiredPrivilege}\"`);\n    }\n    return true;\n}\nfunction isSuperUser(user) {\n    return !isUndefined(user.roles.find((role)=>role.display === 'System Developer'));\n}\n/**\n * The `refetchCurrentUser` function causes a network request to redownload\n * the user. All subscribers to the current user will be notified of the\n * new users once the new version of the user object is downloaded.\n *\n * @returns The same observable as returned by [[getCurrentUser]].\n *\n * #### Example\n * ```js\n * import { refetchCurrentUser } from '@openmrs/esm-api'\n * refetchCurrentUser()\n * ```\n */ export function refetchCurrentUser(username, password) {\n    lastFetchTimeMillis = Date.now();\n    let headers = {};\n    if (username && password) {\n        headers['Authorization'] = `Basic ${window.btoa(`${username}:${password}`)}`;\n    }\n    return handleSessionResponse(openmrsFetch(sessionEndpoint, {\n        headers\n    }));\n}\nexport function clearCurrentUser() {\n    sessionStore.setState({\n        loaded: true,\n        session: {\n            authenticated: false,\n            sessionId: ''\n        }\n    });\n}\nexport function userHasAccess(requiredPrivilege, user) {\n    if (user === undefined) {\n        // if the user hasn't been loaded, then return false iff there is a required privilege\n        return !Boolean(requiredPrivilege);\n    }\n    if (!Boolean(requiredPrivilege)) {\n        // if user exists but no requiredPrivilege is defined\n        return true;\n    }\n    return userHasPrivilege(requiredPrivilege, user) || isSuperUser(user);\n}\nexport function getLoggedInUser() {\n    let user;\n    let unsubscribe;\n    return new Promise((res)=>{\n        const handler = (state)=>{\n            if (state.loaded && state.session.user) {\n                user = state.session.user;\n                res(state.session.user);\n                if (unsubscribe) {\n                    unsubscribe();\n                }\n            }\n        };\n        handler(sessionStore.getState());\n        if (!user) {\n            unsubscribe = sessionStore.subscribe(handler);\n        }\n    });\n}\nexport function getSessionLocation() {\n    return new Promise((res, rej)=>{\n        const sub = getCurrentUser().subscribe((session)=>{\n            res(session.sessionLocation);\n        }, rej);\n        sub.unsubscribe();\n    });\n}\nexport async function setSessionLocation(locationUuid, abortController) {\n    return handleSessionResponse(openmrsFetch(sessionEndpoint, {\n        method: 'POST',\n        body: {\n            sessionLocation: locationUuid\n        },\n        headers: {\n            'Content-Type': 'application/json'\n        },\n        signal: abortController.signal\n    }));\n}\nexport async function setUserProperties(userUuid, userProperties, abortController) {\n    if (!abortController) {\n        abortController = new AbortController();\n    }\n    await openmrsFetch(`${restBaseUrl}/user/${userUuid}`, {\n        method: 'POST',\n        body: {\n            userProperties\n        },\n        headers: {\n            'Content-Type': 'application/json'\n        },\n        signal: abortController.signal\n    });\n    return refetchCurrentUser();\n}\nfunction handleSessionResponse(result) {\n    return new Promise((resolve, reject)=>{\n        result.then((res)=>{\n            let nextState;\n            if (typeof res?.data === 'object') {\n                nextState = {\n                    loaded: true,\n                    session: res.data\n                };\n                sessionStore.setState(nextState);\n                resolve(nextState);\n            } else {\n                nextState = {\n                    loaded: false,\n                    session: null\n                };\n                sessionStore.setState(nextState);\n                reject(nextState);\n            }\n        }).catch((err)=>{\n            reportError(`Failed to fetch new session information: ${err}`);\n            const nextState = {\n                loaded: false,\n                session: null\n            };\n            sessionStore.setState(nextState);\n            reject(nextState);\n        });\n    });\n}\n"],"names":["reportError","createGlobalStore","isUndefined","Observable","openmrsFetch","restBaseUrl","sessionEndpoint","sessionStore","loaded","session","lastFetchTimeMillis","getCurrentUser","opts","includeAuthStatus","Date","now","getState","refetchCurrentUser","subscriber","handler","state","next","user","subscribe","getSessionStore","isValidLocale","locale","undefined","Intl","Locale","e","setUserLanguage","data","userProperties","defaultLocale","includes","replaceAll","document","documentElement","getAttribute","setAttribute","userHasPrivilege","requiredPrivilege","privileges","find","p","display","Array","isArray","every","rp","console","error","isSuperUser","roles","role","username","password","headers","window","btoa","handleSessionResponse","clearCurrentUser","setState","authenticated","sessionId","userHasAccess","Boolean","getLoggedInUser","unsubscribe","Promise","res","getSessionLocation","rej","sub","sessionLocation","setSessionLocation","locationUuid","abortController","method","body","signal","setUserProperties","userUuid","AbortController","result","resolve","reject","then","nextState","catch","err"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-api/dist/current-user.js\n");
28
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ clearCurrentUser: () => (/* binding */ clearCurrentUser),\n/* harmony export */ getCurrentUser: () => (/* binding */ getCurrentUser),\n/* harmony export */ getLoggedInUser: () => (/* binding */ getLoggedInUser),\n/* harmony export */ getSessionLocation: () => (/* binding */ getSessionLocation),\n/* harmony export */ getSessionStore: () => (/* binding */ getSessionStore),\n/* harmony export */ refetchCurrentUser: () => (/* binding */ refetchCurrentUser),\n/* harmony export */ sessionStore: () => (/* binding */ sessionStore),\n/* harmony export */ setSessionLocation: () => (/* binding */ setSessionLocation),\n/* harmony export */ setUserLanguage: () => (/* binding */ setUserLanguage),\n/* harmony export */ setUserProperties: () => (/* binding */ setUserProperties),\n/* harmony export */ userHasAccess: () => (/* binding */ userHasAccess)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_error_handling__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-error-handling */ \"../../framework/esm-error-handling/dist/index.js\");\n/* harmony import */ var _openmrs_esm_state__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-state */ \"../../framework/esm-state/dist/index.js\");\n/* harmony import */ var lodash_es__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! lodash-es */ \"../../../node_modules/lodash-es/isUndefined.js\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! rxjs */ \"webpack/sharing/consume/default/rxjs/rxjs\");\n/* harmony import */ var _openmrs_fetch_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./openmrs-fetch.js */ \"../../framework/esm-api/dist/openmrs-fetch.js\");\n/** @module @category API */ \n\n\n\n\n/** @internal */ const sessionStore = (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_1__.createGlobalStore)('session', {\n loaded: false,\n session: null\n});\nlet lastFetchTimeMillis = 0;\nfunction getCurrentUser(opts = {\n includeAuthStatus: true\n}) {\n if (lastFetchTimeMillis < Date.now() - 1000 * 60 || !sessionStore.getState().loaded) {\n refetchCurrentUser();\n }\n return new rxjs__WEBPACK_IMPORTED_MODULE_2__.Observable((subscriber)=>{\n const handler = (state)=>{\n if (state.loaded) {\n if (opts.includeAuthStatus) {\n subscriber.next(state.session);\n } else {\n subscriber.next(state.session?.user);\n }\n }\n };\n handler(sessionStore.getState());\n // The observable subscribe function should return an unsubscribe function,\n // which happens to be exactly what `subscribe` returns.\n return sessionStore.subscribe(handler);\n });\n}\n\n/**\n * Returns the global session store containing the current user's session information.\n * If the session data is stale (older than 1 minute) or not yet loaded, this function\n * will trigger a refetch of the current user's session.\n *\n * @returns The global session store that can be subscribed to for session updates.\n *\n * @example\n * ```ts\n * import { getSessionStore } from '@openmrs/esm-api';\n * const store = getSessionStore();\n * const unsubscribe = store.subscribe((state) => {\n * if (state.loaded) {\n * console.log('Session:', state.session);\n * }\n * });\n * ```\n */ function getSessionStore() {\n if (lastFetchTimeMillis < Date.now() - 1000 * 60 || !sessionStore.getState().loaded) {\n refetchCurrentUser();\n }\n return sessionStore;\n}\n// NB locale is string only if this returns true\nfunction isValidLocale(locale) {\n if (locale === undefined || typeof locale !== 'string') {\n return false;\n }\n try {\n new Intl.Locale(locale);\n } catch (e) {\n return false;\n }\n return true;\n}\n/**\n * Sets the document's language attribute based on the user's locale preference\n * from the session data. This affects the HTML `lang` attribute which is used\n * for accessibility and internationalization.\n *\n * The locale is determined from either the session's locale or the user's\n * default locale property. Underscores in the locale are converted to hyphens\n * to match BCP 47 language tag format.\n *\n * @param data The session object containing locale information.\n */ function setUserLanguage(data) {\n let locale = data.locale ?? data.user?.userProperties?.defaultLocale;\n if (locale && locale.includes('_')) {\n locale = locale.replaceAll('_', '-');\n }\n if (isValidLocale(locale) && locale !== document.documentElement.getAttribute('lang')) {\n document.documentElement.setAttribute('lang', locale);\n }\n}\nsessionStore.subscribe((state)=>{\n if (state.loaded && state.session) {\n setUserLanguage(state.session);\n }\n});\nfunction userHasPrivilege(requiredPrivilege, user) {\n if (typeof requiredPrivilege === 'string') {\n return !(0,lodash_es__WEBPACK_IMPORTED_MODULE_4__[\"default\"])(user.privileges.find((p)=>requiredPrivilege === p.display));\n } else if (Array.isArray(requiredPrivilege)) {\n return requiredPrivilege.every((rp)=>!(0,lodash_es__WEBPACK_IMPORTED_MODULE_4__[\"default\"])(user.privileges.find((p)=>rp === p.display)));\n } else if (!(0,lodash_es__WEBPACK_IMPORTED_MODULE_4__[\"default\"])(requiredPrivilege)) {\n console.error(`Could not understand privileges \"${requiredPrivilege}\"`);\n }\n return true;\n}\nfunction isSuperUser(user) {\n return !(0,lodash_es__WEBPACK_IMPORTED_MODULE_4__[\"default\"])(user.roles.find((role)=>role.display === 'System Developer'));\n}\n/**\n * The `refetchCurrentUser` function causes a network request to redownload\n * the user. All subscribers to the current user will be notified of the\n * new users once the new version of the user object is downloaded.\n *\n * @returns The same observable as returned by {@link getCurrentUser}.\n *\n * @example\n * ```js\n * import { refetchCurrentUser } from '@openmrs/esm-api'\n * refetchCurrentUser()\n * ```\n */ function refetchCurrentUser(username, password) {\n lastFetchTimeMillis = Date.now();\n let headers = {};\n if (username && password) {\n headers['Authorization'] = `Basic ${window.btoa(`${username}:${password}`)}`;\n }\n return handleSessionResponse((0,_openmrs_fetch_js__WEBPACK_IMPORTED_MODULE_3__.openmrsFetch)(_openmrs_fetch_js__WEBPACK_IMPORTED_MODULE_3__.sessionEndpoint, {\n headers\n }));\n}\n/**\n * Clears the current user session from the session store, setting the session\n * to an unauthenticated state. This is typically called during logout to reset\n * the application's authentication state.\n *\n * @example\n * ```ts\n * import { clearCurrentUser } from '@openmrs/esm-api';\n * // During logout\n * clearCurrentUser();\n * ```\n */ function clearCurrentUser() {\n sessionStore.setState({\n loaded: true,\n session: {\n authenticated: false,\n sessionId: ''\n }\n });\n}\n/**\n * Checks whether the given user has access based on the required privilege(s).\n * A user has access if they have the required privilege(s) or if they are a\n * \"System Developer\" (super user). If no privilege is required, access is granted.\n *\n * @param requiredPrivilege A single privilege string or an array of privilege strings\n * that the user must have. If an array is provided, the user must have ALL privileges.\n * @param user The user object containing their privileges and roles.\n * @returns `true` if the user has access, `false` otherwise. Returns `true` if no\n * privilege is required, and `false` if the user is undefined but a privilege is required.\n *\n * @example\n * ```ts\n * import { userHasAccess } from '@openmrs/esm-api';\n * const hasAccess = userHasAccess('View Patients', currentUser);\n * const hasMultipleAccess = userHasAccess(['View Patients', 'Edit Patients'], currentUser);\n * ```\n */ function userHasAccess(requiredPrivilege, user) {\n if (user === undefined) {\n // if the user hasn't been loaded, then return false iff there is a required privilege\n return !Boolean(requiredPrivilege);\n }\n if (!Boolean(requiredPrivilege)) {\n // if user exists but no requiredPrivilege is defined\n return true;\n }\n return userHasPrivilege(requiredPrivilege, user) || isSuperUser(user);\n}\n/**\n * Returns a Promise that resolves with the currently logged-in user object.\n * If the user is already loaded in the session store, the Promise resolves immediately.\n * Otherwise, it subscribes to the session store and resolves when a logged-in user\n * becomes available.\n *\n * @returns A Promise that resolves with the LoggedInUser object once available.\n *\n * @example\n * ```ts\n * import { getLoggedInUser } from '@openmrs/esm-api';\n * const user = await getLoggedInUser();\n * console.log('Logged in as:', user.display);\n * ```\n */ function getLoggedInUser() {\n let user;\n let unsubscribe;\n return new Promise((res)=>{\n const handler = (state)=>{\n if (state.loaded && state.session.user) {\n user = state.session.user;\n res(state.session.user);\n if (unsubscribe) {\n unsubscribe();\n }\n }\n };\n handler(sessionStore.getState());\n if (!user) {\n unsubscribe = sessionStore.subscribe(handler);\n }\n });\n}\n/**\n * Returns a Promise that resolves with the current session location, if one is set.\n * The session location represents the physical location where the user is currently\n * working (e.g., a clinic or ward).\n *\n * @returns A Promise that resolves with the SessionLocation object, or `undefined`\n * if no session location is set.\n *\n * @example\n * ```ts\n * import { getSessionLocation } from '@openmrs/esm-api';\n * const location = await getSessionLocation();\n * if (location) {\n * console.log('Current location:', location.display);\n * }\n * ```\n */ function getSessionLocation() {\n return new Promise((res, rej)=>{\n const sub = getCurrentUser().subscribe((session)=>{\n res(session.sessionLocation);\n }, rej);\n sub.unsubscribe();\n });\n}\n/**\n * Sets the session location for the current user. The session location represents\n * the physical location where the user is working (e.g., a clinic or ward).\n * This triggers a server request to update the session and refreshes the local\n * session store.\n *\n * @param locationUuid The UUID of the location to set as the session location.\n * @param abortController An AbortController to allow cancellation of the request.\n * @returns A Promise that resolves with the updated SessionStore.\n *\n * @example\n * ```ts\n * import { setSessionLocation } from '@openmrs/esm-api';\n * const abortController = new AbortController();\n * await setSessionLocation('location-uuid-here', abortController);\n * ```\n */ async function setSessionLocation(locationUuid, abortController) {\n return handleSessionResponse((0,_openmrs_fetch_js__WEBPACK_IMPORTED_MODULE_3__.openmrsFetch)(_openmrs_fetch_js__WEBPACK_IMPORTED_MODULE_3__.sessionEndpoint, {\n method: 'POST',\n body: {\n sessionLocation: locationUuid\n },\n headers: {\n 'Content-Type': 'application/json'\n },\n signal: abortController.signal\n }));\n}\n/**\n * Updates the user properties for a specific user. User properties are key-value\n * pairs that store user-specific settings and preferences. After updating the\n * properties on the server, the current user session is refetched to reflect\n * the changes.\n *\n * @param userUuid The UUID of the user whose properties should be updated.\n * @param userProperties An object containing the properties to set or update.\n * @param abortController Optional AbortController to allow cancellation of the request.\n * If not provided, a new AbortController is created.\n * @returns A Promise that resolves with the updated SessionStore after refetching\n * the current user.\n *\n * @example\n * ```ts\n * import { getLoggedInUser, setUserProperties } from '@openmrs/esm-api';\n * const user = await getLoggedInUser();\n * await setUserProperties(user.uuid, {\n * defaultLocale: 'en_GB',\n * customSetting: 'value'\n * });\n * ```\n */ async function setUserProperties(userUuid, userProperties, abortController) {\n if (!abortController) {\n abortController = new AbortController();\n }\n await (0,_openmrs_fetch_js__WEBPACK_IMPORTED_MODULE_3__.openmrsFetch)(`${_openmrs_fetch_js__WEBPACK_IMPORTED_MODULE_3__.restBaseUrl}/user/${userUuid}`, {\n method: 'POST',\n body: {\n userProperties\n },\n headers: {\n 'Content-Type': 'application/json'\n },\n signal: abortController.signal\n });\n return refetchCurrentUser();\n}\nfunction handleSessionResponse(result) {\n return new Promise((resolve, reject)=>{\n result.then((res)=>{\n let nextState;\n if (typeof res?.data === 'object') {\n nextState = {\n loaded: true,\n session: res.data\n };\n sessionStore.setState(nextState);\n resolve(nextState);\n } else {\n nextState = {\n loaded: false,\n session: null\n };\n sessionStore.setState(nextState);\n reject(nextState);\n }\n }).catch((err)=>{\n (0,_openmrs_esm_error_handling__WEBPACK_IMPORTED_MODULE_0__.reportError)(`Failed to fetch new session information: ${err}`);\n const nextState = {\n loaded: false,\n session: null\n };\n sessionStore.setState(nextState);\n reject(nextState);\n });\n });\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-api/dist/current-user.js","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-api/dist/current-user.js?c00f"],"sourcesContent":["/** @module @category API */ import { reportError } from \"@openmrs/esm-error-handling\";\nimport { createGlobalStore } from \"@openmrs/esm-state\";\nimport { isUndefined } from \"lodash-es\";\nimport { Observable } from \"rxjs\";\nimport { openmrsFetch, restBaseUrl, sessionEndpoint } from \"./openmrs-fetch.js\";\n/** @internal */ export const sessionStore = createGlobalStore('session', {\n    loaded: false,\n    session: null\n});\nlet lastFetchTimeMillis = 0;\nfunction getCurrentUser(opts = {\n    includeAuthStatus: true\n}) {\n    if (lastFetchTimeMillis < Date.now() - 1000 * 60 || !sessionStore.getState().loaded) {\n        refetchCurrentUser();\n    }\n    return new Observable((subscriber)=>{\n        const handler = (state)=>{\n            if (state.loaded) {\n                if (opts.includeAuthStatus) {\n                    subscriber.next(state.session);\n                } else {\n                    subscriber.next(state.session?.user);\n                }\n            }\n        };\n        handler(sessionStore.getState());\n        // The observable subscribe function should return an unsubscribe function,\n        // which happens to be exactly what `subscribe` returns.\n        return sessionStore.subscribe(handler);\n    });\n}\nexport { getCurrentUser };\n/**\n * Returns the global session store containing the current user's session information.\n * If the session data is stale (older than 1 minute) or not yet loaded, this function\n * will trigger a refetch of the current user's session.\n *\n * @returns The global session store that can be subscribed to for session updates.\n *\n * @example\n * ```ts\n * import { getSessionStore } from '@openmrs/esm-api';\n * const store = getSessionStore();\n * const unsubscribe = store.subscribe((state) => {\n *   if (state.loaded) {\n *     console.log('Session:', state.session);\n *   }\n * });\n * ```\n */ export function getSessionStore() {\n    if (lastFetchTimeMillis < Date.now() - 1000 * 60 || !sessionStore.getState().loaded) {\n        refetchCurrentUser();\n    }\n    return sessionStore;\n}\n// NB locale is string only if this returns true\nfunction isValidLocale(locale) {\n    if (locale === undefined || typeof locale !== 'string') {\n        return false;\n    }\n    try {\n        new Intl.Locale(locale);\n    } catch (e) {\n        return false;\n    }\n    return true;\n}\n/**\n * Sets the document's language attribute based on the user's locale preference\n * from the session data. This affects the HTML `lang` attribute which is used\n * for accessibility and internationalization.\n *\n * The locale is determined from either the session's locale or the user's\n * default locale property. Underscores in the locale are converted to hyphens\n * to match BCP 47 language tag format.\n *\n * @param data The session object containing locale information.\n */ export function setUserLanguage(data) {\n    let locale = data.locale ?? data.user?.userProperties?.defaultLocale;\n    if (locale && locale.includes('_')) {\n        locale = locale.replaceAll('_', '-');\n    }\n    if (isValidLocale(locale) && locale !== document.documentElement.getAttribute('lang')) {\n        document.documentElement.setAttribute('lang', locale);\n    }\n}\nsessionStore.subscribe((state)=>{\n    if (state.loaded && state.session) {\n        setUserLanguage(state.session);\n    }\n});\nfunction userHasPrivilege(requiredPrivilege, user) {\n    if (typeof requiredPrivilege === 'string') {\n        return !isUndefined(user.privileges.find((p)=>requiredPrivilege === p.display));\n    } else if (Array.isArray(requiredPrivilege)) {\n        return requiredPrivilege.every((rp)=>!isUndefined(user.privileges.find((p)=>rp === p.display)));\n    } else if (!isUndefined(requiredPrivilege)) {\n        console.error(`Could not understand privileges \"${requiredPrivilege}\"`);\n    }\n    return true;\n}\nfunction isSuperUser(user) {\n    return !isUndefined(user.roles.find((role)=>role.display === 'System Developer'));\n}\n/**\n * The `refetchCurrentUser` function causes a network request to redownload\n * the user. All subscribers to the current user will be notified of the\n * new users once the new version of the user object is downloaded.\n *\n * @returns The same observable as returned by {@link getCurrentUser}.\n *\n * @example\n * ```js\n * import { refetchCurrentUser } from '@openmrs/esm-api'\n * refetchCurrentUser()\n * ```\n */ export function refetchCurrentUser(username, password) {\n    lastFetchTimeMillis = Date.now();\n    let headers = {};\n    if (username && password) {\n        headers['Authorization'] = `Basic ${window.btoa(`${username}:${password}`)}`;\n    }\n    return handleSessionResponse(openmrsFetch(sessionEndpoint, {\n        headers\n    }));\n}\n/**\n * Clears the current user session from the session store, setting the session\n * to an unauthenticated state. This is typically called during logout to reset\n * the application's authentication state.\n *\n * @example\n * ```ts\n * import { clearCurrentUser } from '@openmrs/esm-api';\n * // During logout\n * clearCurrentUser();\n * ```\n */ export function clearCurrentUser() {\n    sessionStore.setState({\n        loaded: true,\n        session: {\n            authenticated: false,\n            sessionId: ''\n        }\n    });\n}\n/**\n * Checks whether the given user has access based on the required privilege(s).\n * A user has access if they have the required privilege(s) or if they are a\n * \"System Developer\" (super user). If no privilege is required, access is granted.\n *\n * @param requiredPrivilege A single privilege string or an array of privilege strings\n *   that the user must have. If an array is provided, the user must have ALL privileges.\n * @param user The user object containing their privileges and roles.\n * @returns `true` if the user has access, `false` otherwise. Returns `true` if no\n *   privilege is required, and `false` if the user is undefined but a privilege is required.\n *\n * @example\n * ```ts\n * import { userHasAccess } from '@openmrs/esm-api';\n * const hasAccess = userHasAccess('View Patients', currentUser);\n * const hasMultipleAccess = userHasAccess(['View Patients', 'Edit Patients'], currentUser);\n * ```\n */ export function userHasAccess(requiredPrivilege, user) {\n    if (user === undefined) {\n        // if the user hasn't been loaded, then return false iff there is a required privilege\n        return !Boolean(requiredPrivilege);\n    }\n    if (!Boolean(requiredPrivilege)) {\n        // if user exists but no requiredPrivilege is defined\n        return true;\n    }\n    return userHasPrivilege(requiredPrivilege, user) || isSuperUser(user);\n}\n/**\n * Returns a Promise that resolves with the currently logged-in user object.\n * If the user is already loaded in the session store, the Promise resolves immediately.\n * Otherwise, it subscribes to the session store and resolves when a logged-in user\n * becomes available.\n *\n * @returns A Promise that resolves with the LoggedInUser object once available.\n *\n * @example\n * ```ts\n * import { getLoggedInUser } from '@openmrs/esm-api';\n * const user = await getLoggedInUser();\n * console.log('Logged in as:', user.display);\n * ```\n */ export function getLoggedInUser() {\n    let user;\n    let unsubscribe;\n    return new Promise((res)=>{\n        const handler = (state)=>{\n            if (state.loaded && state.session.user) {\n                user = state.session.user;\n                res(state.session.user);\n                if (unsubscribe) {\n                    unsubscribe();\n                }\n            }\n        };\n        handler(sessionStore.getState());\n        if (!user) {\n            unsubscribe = sessionStore.subscribe(handler);\n        }\n    });\n}\n/**\n * Returns a Promise that resolves with the current session location, if one is set.\n * The session location represents the physical location where the user is currently\n * working (e.g., a clinic or ward).\n *\n * @returns A Promise that resolves with the SessionLocation object, or `undefined`\n *   if no session location is set.\n *\n * @example\n * ```ts\n * import { getSessionLocation } from '@openmrs/esm-api';\n * const location = await getSessionLocation();\n * if (location) {\n *   console.log('Current location:', location.display);\n * }\n * ```\n */ export function getSessionLocation() {\n    return new Promise((res, rej)=>{\n        const sub = getCurrentUser().subscribe((session)=>{\n            res(session.sessionLocation);\n        }, rej);\n        sub.unsubscribe();\n    });\n}\n/**\n * Sets the session location for the current user. The session location represents\n * the physical location where the user is working (e.g., a clinic or ward).\n * This triggers a server request to update the session and refreshes the local\n * session store.\n *\n * @param locationUuid The UUID of the location to set as the session location.\n * @param abortController An AbortController to allow cancellation of the request.\n * @returns A Promise that resolves with the updated SessionStore.\n *\n * @example\n * ```ts\n * import { setSessionLocation } from '@openmrs/esm-api';\n * const abortController = new AbortController();\n * await setSessionLocation('location-uuid-here', abortController);\n * ```\n */ export async function setSessionLocation(locationUuid, abortController) {\n    return handleSessionResponse(openmrsFetch(sessionEndpoint, {\n        method: 'POST',\n        body: {\n            sessionLocation: locationUuid\n        },\n        headers: {\n            'Content-Type': 'application/json'\n        },\n        signal: abortController.signal\n    }));\n}\n/**\n * Updates the user properties for a specific user. User properties are key-value\n * pairs that store user-specific settings and preferences. After updating the\n * properties on the server, the current user session is refetched to reflect\n * the changes.\n *\n * @param userUuid The UUID of the user whose properties should be updated.\n * @param userProperties An object containing the properties to set or update.\n * @param abortController Optional AbortController to allow cancellation of the request.\n *   If not provided, a new AbortController is created.\n * @returns A Promise that resolves with the updated SessionStore after refetching\n *   the current user.\n *\n * @example\n * ```ts\n * import { getLoggedInUser, setUserProperties } from '@openmrs/esm-api';\n * const user = await getLoggedInUser();\n * await setUserProperties(user.uuid, {\n *   defaultLocale: 'en_GB',\n *   customSetting: 'value'\n * });\n * ```\n */ export async function setUserProperties(userUuid, userProperties, abortController) {\n    if (!abortController) {\n        abortController = new AbortController();\n    }\n    await openmrsFetch(`${restBaseUrl}/user/${userUuid}`, {\n        method: 'POST',\n        body: {\n            userProperties\n        },\n        headers: {\n            'Content-Type': 'application/json'\n        },\n        signal: abortController.signal\n    });\n    return refetchCurrentUser();\n}\nfunction handleSessionResponse(result) {\n    return new Promise((resolve, reject)=>{\n        result.then((res)=>{\n            let nextState;\n            if (typeof res?.data === 'object') {\n                nextState = {\n                    loaded: true,\n                    session: res.data\n                };\n                sessionStore.setState(nextState);\n                resolve(nextState);\n            } else {\n                nextState = {\n                    loaded: false,\n                    session: null\n                };\n                sessionStore.setState(nextState);\n                reject(nextState);\n            }\n        }).catch((err)=>{\n            reportError(`Failed to fetch new session information: ${err}`);\n            const nextState = {\n                loaded: false,\n                session: null\n            };\n            sessionStore.setState(nextState);\n            reject(nextState);\n        });\n    });\n}\n"],"names":["reportError","createGlobalStore","isUndefined","Observable","openmrsFetch","restBaseUrl","sessionEndpoint","sessionStore","loaded","session","lastFetchTimeMillis","getCurrentUser","opts","includeAuthStatus","Date","now","getState","refetchCurrentUser","subscriber","handler","state","next","user","subscribe","getSessionStore","isValidLocale","locale","undefined","Intl","Locale","e","setUserLanguage","data","userProperties","defaultLocale","includes","replaceAll","document","documentElement","getAttribute","setAttribute","userHasPrivilege","requiredPrivilege","privileges","find","p","display","Array","isArray","every","rp","console","error","isSuperUser","roles","role","username","password","headers","window","btoa","handleSessionResponse","clearCurrentUser","setState","authenticated","sessionId","userHasAccess","Boolean","getLoggedInUser","unsubscribe","Promise","res","getSessionLocation","rej","sub","sessionLocation","setSessionLocation","locationUuid","abortController","method","body","signal","setUserProperties","userUuid","AbortController","result","resolve","reject","then","nextState","catch","err"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-api/dist/current-user.js\n");
29
29
 
30
30
  /***/ }),
31
31
 
@@ -55,7 +55,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
55
55
  \********************************************************************/
56
56
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
57
57
 
58
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ backendDependencies: () => (/* binding */ backendDependencies)\n/* harmony export */ });\nconst backendDependencies = {\n 'webservices.rest': '2.24.0',\n fhir2: '1.0.0-SNAPSHOT'\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1hcGkvZGlzdC9vcGVubXJzLWJhY2tlbmQtZGVwZW5kZW5jaWVzLmpzIiwibWFwcGluZ3MiOiI7Ozs7QUFBTyxNQUFNQSxzQkFBc0I7SUFDL0Isb0JBQW9CO0lBQ3BCQyxPQUFPO0FBQ1gsRUFBRSIsInNvdXJjZXMiOlsid2VicGFjazovL0BvcGVubXJzL2VzbS1hcHAtc2hlbGwvLi4vLi4vZnJhbWV3b3JrL2VzbS1hcGkvZGlzdC9vcGVubXJzLWJhY2tlbmQtZGVwZW5kZW5jaWVzLmpzPzU2MWIiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IGJhY2tlbmREZXBlbmRlbmNpZXMgPSB7XG4gICAgJ3dlYnNlcnZpY2VzLnJlc3QnOiAnMi4yNC4wJyxcbiAgICBmaGlyMjogJzEuMC4wLVNOQVBTSE9UJ1xufTtcbiJdLCJuYW1lcyI6WyJiYWNrZW5kRGVwZW5kZW5jaWVzIiwiZmhpcjIiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///../../framework/esm-api/dist/openmrs-backend-dependencies.js\n");
58
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ backendDependencies: () => (/* binding */ backendDependencies)\n/* harmony export */ });\n/**\n * Defines the minimum required versions of OpenMRS backend modules that the\n * frontend framework depends on. These versions are checked at startup to ensure\n * compatibility between the frontend and backend.\n */ const backendDependencies = {\n 'webservices.rest': '2.24.0',\n fhir2: '1.0.0-SNAPSHOT'\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1hcGkvZGlzdC9vcGVubXJzLWJhY2tlbmQtZGVwZW5kZW5jaWVzLmpzIiwibWFwcGluZ3MiOiI7Ozs7QUFBQTs7OztDQUlDLEdBQVUsTUFBTUEsc0JBQXNCO0lBQ25DLG9CQUFvQjtJQUNwQkMsT0FBTztBQUNYLEVBQUUiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tYXBpL2Rpc3Qvb3Blbm1ycy1iYWNrZW5kLWRlcGVuZGVuY2llcy5qcz81NjFiIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRGVmaW5lcyB0aGUgbWluaW11bSByZXF1aXJlZCB2ZXJzaW9ucyBvZiBPcGVuTVJTIGJhY2tlbmQgbW9kdWxlcyB0aGF0IHRoZVxuICogZnJvbnRlbmQgZnJhbWV3b3JrIGRlcGVuZHMgb24uIFRoZXNlIHZlcnNpb25zIGFyZSBjaGVja2VkIGF0IHN0YXJ0dXAgdG8gZW5zdXJlXG4gKiBjb21wYXRpYmlsaXR5IGJldHdlZW4gdGhlIGZyb250ZW5kIGFuZCBiYWNrZW5kLlxuICovIGV4cG9ydCBjb25zdCBiYWNrZW5kRGVwZW5kZW5jaWVzID0ge1xuICAgICd3ZWJzZXJ2aWNlcy5yZXN0JzogJzIuMjQuMCcsXG4gICAgZmhpcjI6ICcxLjAuMC1TTkFQU0hPVCdcbn07XG4iXSwibmFtZXMiOlsiYmFja2VuZERlcGVuZGVuY2llcyIsImZoaXIyIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///../../framework/esm-api/dist/openmrs-backend-dependencies.js\n");
59
59
 
60
60
  /***/ }),
61
61
 
@@ -65,7 +65,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
65
65
  \*****************************************************/
66
66
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
67
67
 
68
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ OpenmrsFetchError: () => (/* binding */ OpenmrsFetchError),\n/* harmony export */ fhirBaseUrl: () => (/* binding */ fhirBaseUrl),\n/* harmony export */ makeUrl: () => (/* binding */ makeUrl),\n/* harmony export */ openmrsFetch: () => (/* binding */ openmrsFetch),\n/* harmony export */ openmrsObservableFetch: () => (/* binding */ openmrsObservableFetch),\n/* harmony export */ restBaseUrl: () => (/* binding */ restBaseUrl),\n/* harmony export */ sessionEndpoint: () => (/* binding */ sessionEndpoint)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"webpack/sharing/consume/default/rxjs/rxjs\");\n/* harmony import */ var lodash_es__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! lodash-es */ \"../../../node_modules/lodash-es/isPlainObject.js\");\n/* harmony import */ var _openmrs_esm_config__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-config */ \"../../framework/esm-config/dist/index.js\");\n/* harmony import */ var _openmrs_esm_navigation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @openmrs/esm-navigation */ \"../../framework/esm-navigation/dist/index.js\");\n/* harmony import */ var _config_schema_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./config-schema.js */ \"../../framework/esm-api/dist/config-schema.js\");\n/** @module @category API */ function _define_property(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\n\n\n\n\n\nconst restBaseUrl = '/ws/rest/v1';\nconst fhirBaseUrl = '/ws/fhir2/R4';\nconst sessionEndpoint = `${restBaseUrl}/session`;\n/**\n * Append `path` to the OpenMRS SPA base.\n *\n * #### Example\n *\n * ```ts\n * makeUrl('/foo/bar');\n * // => '/openmrs/foo/bar'\n * ```\n */ function makeUrl(path) {\n if (path && path.startsWith('http')) {\n return path;\n } else if (path[0] !== '/') {\n // ensure path starts with /\n path = '/' + path;\n }\n return window.openmrsBase + path;\n}\n/**\n * The openmrsFetch function is a wrapper around the\n * [browser's built-in fetch function](https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API/Using_Fetch),\n * with extra handling for OpenMRS-specific API behaviors, such as\n * request headers, authentication, authorization, and the API urls.\n *\n * @param path A string url to make the request to. Note that the\n * openmrs base url (by default `/openmrs`) will be automatically\n * prepended to the URL, so there is no need to include it.\n * @param fetchInit A [fetch init object](https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/fetch#Syntax).\n * Note that the `body` property does not need to be `JSON.stringify()`ed\n * because openmrsFetch will do that for you.\n * @returns A [Promise](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise)\n * that resolves with a [Response object](https://developer.mozilla.org/en-US/docs/Web/API/Response).\n * Note that the openmrs version of the Response object has already\n * downloaded the HTTP response body as json, and has an additional\n * `data` property with the HTTP response json as a javascript object.\n *\n * #### Example\n * ```js\n * import { openmrsFetch } from '@openmrs/esm-api'\n * const abortController = new AbortController();\n * openmrsFetch(`${restBaseUrl}/session', {signal: abortController.signal})\n * .then(response => {\n * console.log(response.data.authenticated)\n * })\n * .catch(err => {\n * console.error(err.status);\n * })\n * abortController.abort();\n * openmrsFetch(`${restBaseUrl}/session', {\n * method: 'POST',\n * body: {\n * username: 'hi',\n * password: 'there',\n * }\n * })\n * ```\n *\n * #### Cancellation\n *\n * To cancel a network request, use an\n * [AbortController](https://developer.mozilla.org/en-US/docs/Web/API/AbortController/abort).\n * It is best practice to cancel your network requests when the user\n * navigates away from a page while the request is pending request, to\n * free up memory and network resources and to prevent race conditions.\n *\n * @category API\n */ function openmrsFetch(path, fetchInit = {}) {\n if (typeof path !== 'string') {\n throw Error(\"The first argument to @openmrs/api's openmrsFetch function must be a url string\");\n }\n if (typeof fetchInit !== 'object') {\n throw Error(\"The second argument to @openmrs/api's openmrsFetch function must be a plain object.\");\n }\n if (!window.openmrsBase) {\n throw Error(\"@openmrs/api is running in a browser that doesn't have window.openmrsBase, which is provided by openmrs-module-spa's HTML file.\");\n }\n // Prefix the url with the openmrs spa base\n let url = makeUrl(path);\n // We're going to need some headers\n if (!fetchInit.headers) {\n fetchInit.headers = {};\n }\n /* Automatically stringify javascript objects being sent in the\n * request body.\n */ if ((0,lodash_es__WEBPACK_IMPORTED_MODULE_4__[\"default\"])(fetchInit.body)) {\n fetchInit.body = JSON.stringify(fetchInit.body);\n }\n /* Add a request header to tell the server to respond with json,\n * since frontend code almost always wants json and the OpenMRS\n * server won't give you json unless you explicitly ask for it.\n * If a different Accept header is preferred, pass it into the fetchInit.\n * If no Accept header is desired, pass it in explicitly as null.\n */ if (typeof fetchInit.headers.Accept === 'undefined') {\n fetchInit.headers.Accept = 'application/json';\n }\n if (fetchInit.headers.Accept === null) {\n delete fetchInit.headers.Accept;\n }\n /* This tells the OpenMRS REST API not to return a WWW-Authenticate\n * header. Returning that header is useful when using the API, but\n * not from a UI.\n */ if (path.startsWith(restBaseUrl) && typeof fetchInit.headers['Disable-WWW-Authenticate'] === 'undefined') {\n fetchInit.headers['Disable-WWW-Authenticate'] = 'true';\n }\n if (path.startsWith(fhirBaseUrl)) {\n const urlUrl = new URL(url, window.location.toString());\n if (!urlUrl.searchParams.has('_summary')) {\n urlUrl.searchParams.set('_summary', 'data');\n url = urlUrl.toString();\n }\n }\n /* We capture the stacktrace before making the request, so that if an error occurs we can\n * log a full stacktrace that includes the code that made the request and handled the response\n * Otherwise, we could run into situations where the stacktrace doesn't even show which code\n * called @openmrs/api.\n */ const requestStacktrace = Error();\n return window.fetch(url, fetchInit).then(async (r)=>{\n const response = r;\n const { redirectAuthFailure, followRedirects } = await (0,_openmrs_esm_config__WEBPACK_IMPORTED_MODULE_1__.getConfig)('@openmrs/esm-api');\n if (response.ok) {\n if (response.status === 204) {\n if (followRedirects && response.headers.has('location')) {\n const location = response.headers.get('location');\n if (location) {\n (0,_openmrs_esm_navigation__WEBPACK_IMPORTED_MODULE_2__.navigate)({\n to: location\n });\n }\n }\n /* HTTP 204 - No Content\n * We should not try to download the empty response as json. Instead,\n * we return null since there is no response body.\n */ response.data = null;\n return response;\n } else {\n // HTTP 200s - The request succeeded\n return response.clone().text().then((responseText)=>{\n try {\n if (responseText) {\n response.data = JSON.parse(responseText);\n }\n } catch (err) {\n // Server didn't respond with json\n }\n return response;\n });\n }\n } else {\n /* HTTP response status is not in 200s. Usually this will mean\n * either HTTP 400s (bad request from browser) or HTTP 500s (server error)\n * Our goal is to come up with best possible stacktrace and error message\n * to help developers understand the problem and debug\n */ /*\n * Redirect to given url when redirect on auth failure is enabled\n */ if (url === makeUrl(sessionEndpoint) && response.status === 403 || redirectAuthFailure.enabled && redirectAuthFailure.errors.includes(response.status)) {\n (0,_openmrs_esm_navigation__WEBPACK_IMPORTED_MODULE_2__.clearHistory)();\n // by default, redirect to the url specified in the config.\n // If blank, use the location header from the response.\n // If that is also blank, use the default redirect url.\n const location = redirectAuthFailure.url || response.headers.get('location') || _config_schema_js__WEBPACK_IMPORTED_MODULE_3__.defaultRedirectAuthFailureUrl;\n (0,_openmrs_esm_navigation__WEBPACK_IMPORTED_MODULE_2__.navigate)({\n to: location\n });\n /* We sometimes don't really want this promise to resolve since there's no response data,\n * nor do we want it to reject because that would trigger error handling. We instead\n * want it to remain in pending status while the navigation occurs.\n */ return redirectAuthFailure.resolvePromise ? Promise.resolve() : new Promise(()=>{});\n } else {\n // Attempt to download a response body, if it has one\n return response.clone().text().then((responseText)=>{\n let responseBody = responseText;\n try {\n responseBody = JSON.parse(responseText);\n } catch (err) {\n // Server didn't respond with json, so just go with the response text string\n }\n /* Make the fetch promise go into \"rejected\" status, with the best\n * possible stacktrace and error message.\n */ throw new OpenmrsFetchError(url, response, responseBody, requestStacktrace);\n }, (err)=>{\n /* We weren't able to download a response body for this error.\n * Time to just give the best possible stacktrace and error message.\n */ throw new OpenmrsFetchError(url, response, null, requestStacktrace);\n });\n }\n }\n });\n}\n/**\n * The openmrsObservableFetch function is a wrapper around openmrsFetch\n * that returns an [Observable](https://rxjs-dev.firebaseapp.com/guide/observable)\n * instead of a promise. It exists in case using an Observable is\n * preferred or more convenient than a promise.\n *\n * @param url See [[openmrsFetch]]\n * @param fetchInit See [[openmrsFetch]]\n * @returns An Observable that produces exactly one Response object.\n * The response object is exactly the same as for [[openmrsFetch]].\n *\n * #### Example\n *\n * ```js\n * import { openmrsObservableFetch } from '@openmrs/esm-api'\n * const subscription = openmrsObservableFetch(`${restBaseUrl}/session').subscribe(\n * response => console.log(response.data),\n * err => {throw err},\n * () => console.log('finished')\n * )\n * subscription.unsubscribe()\n * ```\n *\n * #### Cancellation\n *\n * To cancel the network request, simply call `subscription.unsubscribe();`\n *\n * @category API\n */ function openmrsObservableFetch(url, fetchInit = {}) {\n if (typeof fetchInit !== 'object') {\n throw Error('The second argument to openmrsObservableFetch must be either omitted or an object');\n }\n const abortController = new AbortController();\n fetchInit.signal = abortController.signal;\n return new rxjs__WEBPACK_IMPORTED_MODULE_0__.Observable((observer)=>{\n let hasResponse = false;\n openmrsFetch(url, fetchInit).then((response)=>{\n hasResponse = true;\n observer.next(response);\n observer.complete();\n }, (err)=>{\n hasResponse = true;\n observer.error(err);\n });\n return ()=>{\n if (!hasResponse) {\n abortController.abort();\n }\n };\n });\n}\nclass OpenmrsFetchError extends Error {\n constructor(url, response, responseBody, requestStacktrace){\n super(), _define_property(this, \"response\", void 0), _define_property(this, \"responseBody\", void 0);\n this.message = `Server responded with ${response.status} (${response.statusText}) for url ${url}. Check err.responseBody or network tab in dev tools for more info`;\n requestStacktrace.message = this.message;\n this.responseBody = responseBody;\n this.response = response;\n this.stack = `Stacktrace for outgoing request:\\n${requestStacktrace.stack}\\nStacktrace for incoming response:\\n${this.stack}`;\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-api/dist/openmrs-fetch.js","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-api/dist/openmrs-fetch.js?fe19"],"sourcesContent":["/** @module @category API */ function _define_property(obj, key, value) {\n    if (key in obj) {\n        Object.defineProperty(obj, key, {\n            value: value,\n            enumerable: true,\n            configurable: true,\n            writable: true\n        });\n    } else {\n        obj[key] = value;\n    }\n    return obj;\n}\nimport { Observable } from \"rxjs\";\nimport { isPlainObject } from \"lodash-es\";\nimport { getConfig } from \"@openmrs/esm-config\";\nimport { clearHistory, navigate } from \"@openmrs/esm-navigation\";\nimport { defaultRedirectAuthFailureUrl } from \"./config-schema.js\";\nexport const restBaseUrl = '/ws/rest/v1';\nexport const fhirBaseUrl = '/ws/fhir2/R4';\nexport const sessionEndpoint = `${restBaseUrl}/session`;\n/**\n * Append `path` to the OpenMRS SPA base.\n *\n * #### Example\n *\n * ```ts\n * makeUrl('/foo/bar');\n * // => '/openmrs/foo/bar'\n * ```\n */ export function makeUrl(path) {\n    if (path && path.startsWith('http')) {\n        return path;\n    } else if (path[0] !== '/') {\n        // ensure path starts with /\n        path = '/' + path;\n    }\n    return window.openmrsBase + path;\n}\n/**\n * The openmrsFetch function is a wrapper around the\n * [browser's built-in fetch function](https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API/Using_Fetch),\n * with extra handling for OpenMRS-specific API behaviors, such as\n * request headers, authentication, authorization, and the API urls.\n *\n * @param path A string url to make the request to. Note that the\n *   openmrs base url (by default `/openmrs`) will be automatically\n *   prepended to the URL, so there is no need to include it.\n * @param fetchInit A [fetch init object](https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/fetch#Syntax).\n *   Note that the `body` property does not need to be `JSON.stringify()`ed\n *   because openmrsFetch will do that for you.\n * @returns A [Promise](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise)\n *   that resolves with a [Response object](https://developer.mozilla.org/en-US/docs/Web/API/Response).\n *   Note that the openmrs version of the Response object has already\n *   downloaded the HTTP response body as json, and has an additional\n *   `data` property with the HTTP response json as a javascript object.\n *\n * #### Example\n * ```js\n * import { openmrsFetch } from '@openmrs/esm-api'\n * const abortController = new AbortController();\n * openmrsFetch(`${restBaseUrl}/session', {signal: abortController.signal})\n *   .then(response => {\n *     console.log(response.data.authenticated)\n *   })\n *   .catch(err => {\n *     console.error(err.status);\n *   })\n * abortController.abort();\n * openmrsFetch(`${restBaseUrl}/session', {\n *   method: 'POST',\n *   body: {\n *     username: 'hi',\n *     password: 'there',\n *   }\n * })\n * ```\n *\n * #### Cancellation\n *\n * To cancel a network request, use an\n * [AbortController](https://developer.mozilla.org/en-US/docs/Web/API/AbortController/abort).\n * It is best practice to cancel your network requests when the user\n * navigates away from a page while the request is pending request, to\n * free up memory and network resources and to prevent race conditions.\n *\n * @category API\n */ export function openmrsFetch(path, fetchInit = {}) {\n    if (typeof path !== 'string') {\n        throw Error(\"The first argument to @openmrs/api's openmrsFetch function must be a url string\");\n    }\n    if (typeof fetchInit !== 'object') {\n        throw Error(\"The second argument to @openmrs/api's openmrsFetch function must be a plain object.\");\n    }\n    if (!window.openmrsBase) {\n        throw Error(\"@openmrs/api is running in a browser that doesn't have window.openmrsBase, which is provided by openmrs-module-spa's HTML file.\");\n    }\n    // Prefix the url with the openmrs spa base\n    let url = makeUrl(path);\n    // We're going to need some headers\n    if (!fetchInit.headers) {\n        fetchInit.headers = {};\n    }\n    /* Automatically stringify javascript objects being sent in the\n   * request body.\n   */ if (isPlainObject(fetchInit.body)) {\n        fetchInit.body = JSON.stringify(fetchInit.body);\n    }\n    /* Add a request header to tell the server to respond with json,\n   * since frontend code almost always wants json and the OpenMRS\n   * server won't give you json unless you explicitly ask for it.\n   * If a different Accept header is preferred, pass it into the fetchInit.\n   * If no Accept header is desired, pass it in explicitly as null.\n   */ if (typeof fetchInit.headers.Accept === 'undefined') {\n        fetchInit.headers.Accept = 'application/json';\n    }\n    if (fetchInit.headers.Accept === null) {\n        delete fetchInit.headers.Accept;\n    }\n    /* This tells the OpenMRS REST API not to return a WWW-Authenticate\n   * header. Returning that header is useful when using the API, but\n   * not from a UI.\n   */ if (path.startsWith(restBaseUrl) && typeof fetchInit.headers['Disable-WWW-Authenticate'] === 'undefined') {\n        fetchInit.headers['Disable-WWW-Authenticate'] = 'true';\n    }\n    if (path.startsWith(fhirBaseUrl)) {\n        const urlUrl = new URL(url, window.location.toString());\n        if (!urlUrl.searchParams.has('_summary')) {\n            urlUrl.searchParams.set('_summary', 'data');\n            url = urlUrl.toString();\n        }\n    }\n    /* We capture the stacktrace before making the request, so that if an error occurs we can\n   * log a full stacktrace that includes the code that made the request and handled the response\n   * Otherwise, we could run into situations where the stacktrace doesn't even show which code\n   * called @openmrs/api.\n   */ const requestStacktrace = Error();\n    return window.fetch(url, fetchInit).then(async (r)=>{\n        const response = r;\n        const { redirectAuthFailure, followRedirects } = await getConfig('@openmrs/esm-api');\n        if (response.ok) {\n            if (response.status === 204) {\n                if (followRedirects && response.headers.has('location')) {\n                    const location = response.headers.get('location');\n                    if (location) {\n                        navigate({\n                            to: location\n                        });\n                    }\n                }\n                /* HTTP 204 - No Content\n         * We should not try to download the empty response as json. Instead,\n         * we return null since there is no response body.\n         */ response.data = null;\n                return response;\n            } else {\n                // HTTP 200s - The request succeeded\n                return response.clone().text().then((responseText)=>{\n                    try {\n                        if (responseText) {\n                            response.data = JSON.parse(responseText);\n                        }\n                    } catch (err) {\n                    // Server didn't respond with json\n                    }\n                    return response;\n                });\n            }\n        } else {\n            /* HTTP response status is not in 200s. Usually this will mean\n       * either HTTP 400s (bad request from browser) or HTTP 500s (server error)\n       * Our goal is to come up with best possible stacktrace and error message\n       * to help developers understand the problem and debug\n       */ /*\n       * Redirect to given url when redirect on auth failure is enabled\n       */ if (url === makeUrl(sessionEndpoint) && response.status === 403 || redirectAuthFailure.enabled && redirectAuthFailure.errors.includes(response.status)) {\n                clearHistory();\n                // by default, redirect to the url specified in the config.\n                // If blank, use the location header from the response.\n                // If that is also blank, use the default redirect url.\n                const location = redirectAuthFailure.url || response.headers.get('location') || defaultRedirectAuthFailureUrl;\n                navigate({\n                    to: location\n                });\n                /* We sometimes don't really want this promise to resolve since there's no response data,\n         * nor do we want it to reject because that would trigger error handling. We instead\n         * want it to remain in pending status while the navigation occurs.\n         */ return redirectAuthFailure.resolvePromise ? Promise.resolve() : new Promise(()=>{});\n            } else {\n                // Attempt to download a response body, if it has one\n                return response.clone().text().then((responseText)=>{\n                    let responseBody = responseText;\n                    try {\n                        responseBody = JSON.parse(responseText);\n                    } catch (err) {\n                    // Server didn't respond with json, so just go with the response text string\n                    }\n                    /* Make the fetch promise go into \"rejected\" status, with the best\n               * possible stacktrace and error message.\n               */ throw new OpenmrsFetchError(url, response, responseBody, requestStacktrace);\n                }, (err)=>{\n                    /* We weren't able to download a response body for this error.\n               * Time to just give the best possible stacktrace and error message.\n               */ throw new OpenmrsFetchError(url, response, null, requestStacktrace);\n                });\n            }\n        }\n    });\n}\n/**\n * The openmrsObservableFetch function is a wrapper around openmrsFetch\n * that returns an [Observable](https://rxjs-dev.firebaseapp.com/guide/observable)\n * instead of a promise. It exists in case using an Observable is\n * preferred or more convenient than a promise.\n *\n * @param url See [[openmrsFetch]]\n * @param fetchInit See [[openmrsFetch]]\n * @returns An Observable that produces exactly one Response object.\n * The response object is exactly the same as for [[openmrsFetch]].\n *\n * #### Example\n *\n * ```js\n * import { openmrsObservableFetch } from '@openmrs/esm-api'\n * const subscription = openmrsObservableFetch(`${restBaseUrl}/session').subscribe(\n *   response => console.log(response.data),\n *   err => {throw err},\n *   () => console.log('finished')\n * )\n * subscription.unsubscribe()\n * ```\n *\n * #### Cancellation\n *\n * To cancel the network request, simply call `subscription.unsubscribe();`\n *\n * @category API\n */ export function openmrsObservableFetch(url, fetchInit = {}) {\n    if (typeof fetchInit !== 'object') {\n        throw Error('The second argument to openmrsObservableFetch must be either omitted or an object');\n    }\n    const abortController = new AbortController();\n    fetchInit.signal = abortController.signal;\n    return new Observable((observer)=>{\n        let hasResponse = false;\n        openmrsFetch(url, fetchInit).then((response)=>{\n            hasResponse = true;\n            observer.next(response);\n            observer.complete();\n        }, (err)=>{\n            hasResponse = true;\n            observer.error(err);\n        });\n        return ()=>{\n            if (!hasResponse) {\n                abortController.abort();\n            }\n        };\n    });\n}\nexport class OpenmrsFetchError extends Error {\n    constructor(url, response, responseBody, requestStacktrace){\n        super(), _define_property(this, \"response\", void 0), _define_property(this, \"responseBody\", void 0);\n        this.message = `Server responded with ${response.status} (${response.statusText}) for url ${url}. Check err.responseBody or network tab in dev tools for more info`;\n        requestStacktrace.message = this.message;\n        this.responseBody = responseBody;\n        this.response = response;\n        this.stack = `Stacktrace for outgoing request:\\n${requestStacktrace.stack}\\nStacktrace for incoming response:\\n${this.stack}`;\n    }\n}\n"],"names":["_define_property","obj","key","value","Object","defineProperty","enumerable","configurable","writable","Observable","isPlainObject","getConfig","clearHistory","navigate","defaultRedirectAuthFailureUrl","restBaseUrl","fhirBaseUrl","sessionEndpoint","makeUrl","path","startsWith","window","openmrsBase","openmrsFetch","fetchInit","Error","url","headers","body","JSON","stringify","Accept","urlUrl","URL","location","toString","searchParams","has","set","requestStacktrace","fetch","then","r","response","redirectAuthFailure","followRedirects","ok","status","get","to","data","clone","text","responseText","parse","err","enabled","errors","includes","resolvePromise","Promise","resolve","responseBody","OpenmrsFetchError","openmrsObservableFetch","abortController","AbortController","signal","observer","hasResponse","next","complete","error","abort","message","statusText","stack"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-api/dist/openmrs-fetch.js\n");
68
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ OpenmrsFetchError: () => (/* binding */ OpenmrsFetchError),\n/* harmony export */ fhirBaseUrl: () => (/* binding */ fhirBaseUrl),\n/* harmony export */ makeUrl: () => (/* binding */ makeUrl),\n/* harmony export */ openmrsFetch: () => (/* binding */ openmrsFetch),\n/* harmony export */ openmrsObservableFetch: () => (/* binding */ openmrsObservableFetch),\n/* harmony export */ restBaseUrl: () => (/* binding */ restBaseUrl),\n/* harmony export */ sessionEndpoint: () => (/* binding */ sessionEndpoint)\n/* harmony export */ });\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! rxjs */ \"webpack/sharing/consume/default/rxjs/rxjs\");\n/* harmony import */ var lodash_es__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! lodash-es */ \"../../../node_modules/lodash-es/isPlainObject.js\");\n/* harmony import */ var _openmrs_esm_config__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-config */ \"../../framework/esm-config/dist/index.js\");\n/* harmony import */ var _openmrs_esm_navigation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @openmrs/esm-navigation */ \"../../framework/esm-navigation/dist/index.js\");\n/* harmony import */ var _config_schema_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./config-schema.js */ \"../../framework/esm-api/dist/config-schema.js\");\n/** @module @category API */ function _define_property(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\n\n\n\n\n\n/** The base URL for the OpenMRS REST API (e.g., '/ws/rest/v1'). */ const restBaseUrl = '/ws/rest/v1';\n/** The base URL for the OpenMRS FHIR R4 API (e.g., '/ws/fhir2/R4'). */ const fhirBaseUrl = '/ws/fhir2/R4';\n/** The endpoint for session management operations. */ const sessionEndpoint = `${restBaseUrl}/session`;\n/**\n * Append `path` to the OpenMRS SPA base.\n *\n * @param path The path to append to the OpenMRS base URL.\n * @returns The full URL with the OpenMRS base prepended. If the path is already\n * an absolute URL (starting with 'http'), it is returned unchanged.\n *\n * @example\n *\n * ```ts\n * makeUrl('/foo/bar');\n * // => '/openmrs/foo/bar'\n * ```\n */ function makeUrl(path) {\n if (path && path.startsWith('http')) {\n return path;\n } else if (path[0] !== '/') {\n // ensure path starts with /\n path = '/' + path;\n }\n return window.openmrsBase + path;\n}\n/**\n * The openmrsFetch function is a wrapper around the\n * [browser's built-in fetch function](https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API/Using_Fetch),\n * with extra handling for OpenMRS-specific API behaviors, such as\n * request headers, authentication, authorization, and the API urls.\n *\n * @param path A string url to make the request to. Note that the\n * openmrs base url (by default `/openmrs`) will be automatically\n * prepended to the URL, so there is no need to include it.\n * @param fetchInit A [fetch init object](https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/fetch#Syntax).\n * Note that the `body` property does not need to be `JSON.stringify()`ed\n * because openmrsFetch will do that for you.\n * @returns A [Promise](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise)\n * that resolves with a [Response object](https://developer.mozilla.org/en-US/docs/Web/API/Response).\n * Note that the openmrs version of the Response object has already\n * downloaded the HTTP response body as json, and has an additional\n * `data` property with the HTTP response json as a javascript object.\n *\n * @example\n * ```js\n * import { openmrsFetch } from '@openmrs/esm-api'\n * const abortController = new AbortController();\n * openmrsFetch(`${restBaseUrl}/session', {signal: abortController.signal})\n * .then(response => {\n * console.log(response.data.authenticated)\n * })\n * .catch(err => {\n * console.error(err.status);\n * })\n * abortController.abort();\n * openmrsFetch(`${restBaseUrl}/session', {\n * method: 'POST',\n * body: {\n * username: 'hi',\n * password: 'there',\n * }\n * })\n * ```\n *\n * #### Cancellation\n *\n * To cancel a network request, use an\n * [AbortController](https://developer.mozilla.org/en-US/docs/Web/API/AbortController/abort).\n * It is best practice to cancel your network requests when the user\n * navigates away from a page while the request is pending request, to\n * free up memory and network resources and to prevent race conditions.\n *\n * @category API\n */ function openmrsFetch(path, fetchInit = {}) {\n if (typeof path !== 'string') {\n throw Error(\"The first argument to @openmrs/api's openmrsFetch function must be a url string\");\n }\n if (typeof fetchInit !== 'object') {\n throw Error(\"The second argument to @openmrs/api's openmrsFetch function must be a plain object.\");\n }\n if (!window.openmrsBase) {\n throw Error(\"@openmrs/api is running in a browser that doesn't have window.openmrsBase, which is provided by openmrs-module-spa's HTML file.\");\n }\n // Prefix the url with the openmrs spa base\n let url = makeUrl(path);\n // We're going to need some headers\n if (!fetchInit.headers) {\n fetchInit.headers = {};\n }\n /* Automatically stringify javascript objects being sent in the\n * request body.\n */ if ((0,lodash_es__WEBPACK_IMPORTED_MODULE_4__[\"default\"])(fetchInit.body)) {\n fetchInit.body = JSON.stringify(fetchInit.body);\n }\n /* Add a request header to tell the server to respond with json,\n * since frontend code almost always wants json and the OpenMRS\n * server won't give you json unless you explicitly ask for it.\n * If a different Accept header is preferred, pass it into the fetchInit.\n * If no Accept header is desired, pass it in explicitly as null.\n */ if (typeof fetchInit.headers.Accept === 'undefined') {\n fetchInit.headers.Accept = 'application/json';\n }\n if (fetchInit.headers.Accept === null) {\n delete fetchInit.headers.Accept;\n }\n /* This tells the OpenMRS REST API not to return a WWW-Authenticate\n * header. Returning that header is useful when using the API, but\n * not from a UI.\n */ if (path.startsWith(restBaseUrl) && typeof fetchInit.headers['Disable-WWW-Authenticate'] === 'undefined') {\n fetchInit.headers['Disable-WWW-Authenticate'] = 'true';\n }\n if (path.startsWith(fhirBaseUrl)) {\n const urlUrl = new URL(url, window.location.toString());\n if (!urlUrl.searchParams.has('_summary')) {\n urlUrl.searchParams.set('_summary', 'data');\n url = urlUrl.toString();\n }\n }\n /* We capture the stacktrace before making the request, so that if an error occurs we can\n * log a full stacktrace that includes the code that made the request and handled the response\n * Otherwise, we could run into situations where the stacktrace doesn't even show which code\n * called @openmrs/api.\n */ const requestStacktrace = Error();\n return window.fetch(url, fetchInit).then(async (r)=>{\n const response = r;\n const { redirectAuthFailure, followRedirects } = await (0,_openmrs_esm_config__WEBPACK_IMPORTED_MODULE_1__.getConfig)('@openmrs/esm-api');\n if (response.ok) {\n if (response.status === 204) {\n if (followRedirects && response.headers.has('location')) {\n const location = response.headers.get('location');\n if (location) {\n (0,_openmrs_esm_navigation__WEBPACK_IMPORTED_MODULE_2__.navigate)({\n to: location\n });\n }\n }\n /* HTTP 204 - No Content\n * We should not try to download the empty response as json. Instead,\n * we return null since there is no response body.\n */ response.data = null;\n return response;\n } else {\n // HTTP 200s - The request succeeded\n return response.clone().text().then((responseText)=>{\n try {\n if (responseText) {\n response.data = JSON.parse(responseText);\n }\n } catch (err) {\n // Server didn't respond with json\n }\n return response;\n });\n }\n } else {\n /* HTTP response status is not in 200s. Usually this will mean\n * either HTTP 400s (bad request from browser) or HTTP 500s (server error)\n * Our goal is to come up with best possible stacktrace and error message\n * to help developers understand the problem and debug\n */ /*\n * Redirect to given url when redirect on auth failure is enabled\n */ if (url === makeUrl(sessionEndpoint) && response.status === 403 || redirectAuthFailure.enabled && redirectAuthFailure.errors.includes(response.status)) {\n (0,_openmrs_esm_navigation__WEBPACK_IMPORTED_MODULE_2__.clearHistory)();\n // by default, redirect to the url specified in the config.\n // If blank, use the location header from the response.\n // If that is also blank, use the default redirect url.\n const location = redirectAuthFailure.url || response.headers.get('location') || _config_schema_js__WEBPACK_IMPORTED_MODULE_3__.defaultRedirectAuthFailureUrl;\n (0,_openmrs_esm_navigation__WEBPACK_IMPORTED_MODULE_2__.navigate)({\n to: location\n });\n /* We sometimes don't really want this promise to resolve since there's no response data,\n * nor do we want it to reject because that would trigger error handling. We instead\n * want it to remain in pending status while the navigation occurs.\n */ return redirectAuthFailure.resolvePromise ? Promise.resolve() : new Promise(()=>{});\n } else {\n // Attempt to download a response body, if it has one\n return response.clone().text().then((responseText)=>{\n let responseBody = responseText;\n try {\n responseBody = JSON.parse(responseText);\n } catch (err) {\n // Server didn't respond with json, so just go with the response text string\n }\n /* Make the fetch promise go into \"rejected\" status, with the best\n * possible stacktrace and error message.\n */ throw new OpenmrsFetchError(url, response, responseBody, requestStacktrace);\n }, (err)=>{\n /* We weren't able to download a response body for this error.\n * Time to just give the best possible stacktrace and error message.\n */ throw new OpenmrsFetchError(url, response, null, requestStacktrace);\n });\n }\n }\n });\n}\n/**\n * The openmrsObservableFetch function is a wrapper around openmrsFetch\n * that returns an [Observable](https://rxjs-dev.firebaseapp.com/guide/observable)\n * instead of a promise. It exists in case using an Observable is\n * preferred or more convenient than a promise.\n *\n * @param url See [[openmrsFetch]]\n * @param fetchInit See [[openmrsFetch]]\n * @returns An Observable that produces exactly one Response object.\n * The response object is exactly the same as for [[openmrsFetch]].\n *\n * @example\n *\n * ```js\n * import { openmrsObservableFetch } from '@openmrs/esm-api'\n * const subscription = openmrsObservableFetch(`${restBaseUrl}/session').subscribe(\n * response => console.log(response.data),\n * err => {throw err},\n * () => console.log('finished')\n * )\n * subscription.unsubscribe()\n * ```\n *\n * #### Cancellation\n *\n * To cancel the network request, simply call `subscription.unsubscribe();`\n *\n * @category API\n */ function openmrsObservableFetch(url, fetchInit = {}) {\n if (typeof fetchInit !== 'object') {\n throw Error('The second argument to openmrsObservableFetch must be either omitted or an object');\n }\n const abortController = new AbortController();\n fetchInit.signal = abortController.signal;\n return new rxjs__WEBPACK_IMPORTED_MODULE_0__.Observable((observer)=>{\n let hasResponse = false;\n openmrsFetch(url, fetchInit).then((response)=>{\n hasResponse = true;\n observer.next(response);\n observer.complete();\n }, (err)=>{\n hasResponse = true;\n observer.error(err);\n });\n return ()=>{\n if (!hasResponse) {\n abortController.abort();\n }\n };\n });\n}\nclass OpenmrsFetchError extends Error {\n constructor(url, response, responseBody, requestStacktrace){\n super(), _define_property(this, \"response\", void 0), _define_property(this, \"responseBody\", void 0);\n this.message = `Server responded with ${response.status} (${response.statusText}) for url ${url}. Check err.responseBody or network tab in dev tools for more info`;\n requestStacktrace.message = this.message;\n this.responseBody = responseBody;\n this.response = response;\n this.stack = `Stacktrace for outgoing request:\\n${requestStacktrace.stack}\\nStacktrace for incoming response:\\n${this.stack}`;\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-api/dist/openmrs-fetch.js","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-api/dist/openmrs-fetch.js?fe19"],"sourcesContent":["/** @module @category API */ function _define_property(obj, key, value) {\n    if (key in obj) {\n        Object.defineProperty(obj, key, {\n            value: value,\n            enumerable: true,\n            configurable: true,\n            writable: true\n        });\n    } else {\n        obj[key] = value;\n    }\n    return obj;\n}\nimport { Observable } from \"rxjs\";\nimport { isPlainObject } from \"lodash-es\";\nimport { getConfig } from \"@openmrs/esm-config\";\nimport { clearHistory, navigate } from \"@openmrs/esm-navigation\";\nimport { defaultRedirectAuthFailureUrl } from \"./config-schema.js\";\n/** The base URL for the OpenMRS REST API (e.g., '/ws/rest/v1'). */ export const restBaseUrl = '/ws/rest/v1';\n/** The base URL for the OpenMRS FHIR R4 API (e.g., '/ws/fhir2/R4'). */ export const fhirBaseUrl = '/ws/fhir2/R4';\n/** The endpoint for session management operations. */ export const sessionEndpoint = `${restBaseUrl}/session`;\n/**\n * Append `path` to the OpenMRS SPA base.\n *\n * @param path The path to append to the OpenMRS base URL.\n * @returns The full URL with the OpenMRS base prepended. If the path is already\n *   an absolute URL (starting with 'http'), it is returned unchanged.\n *\n * @example\n *\n * ```ts\n * makeUrl('/foo/bar');\n * // => '/openmrs/foo/bar'\n * ```\n */ export function makeUrl(path) {\n    if (path && path.startsWith('http')) {\n        return path;\n    } else if (path[0] !== '/') {\n        // ensure path starts with /\n        path = '/' + path;\n    }\n    return window.openmrsBase + path;\n}\n/**\n * The openmrsFetch function is a wrapper around the\n * [browser's built-in fetch function](https://developer.mozilla.org/en-US/docs/Web/API/Fetch_API/Using_Fetch),\n * with extra handling for OpenMRS-specific API behaviors, such as\n * request headers, authentication, authorization, and the API urls.\n *\n * @param path A string url to make the request to. Note that the\n *   openmrs base url (by default `/openmrs`) will be automatically\n *   prepended to the URL, so there is no need to include it.\n * @param fetchInit A [fetch init object](https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/fetch#Syntax).\n *   Note that the `body` property does not need to be `JSON.stringify()`ed\n *   because openmrsFetch will do that for you.\n * @returns A [Promise](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise)\n *   that resolves with a [Response object](https://developer.mozilla.org/en-US/docs/Web/API/Response).\n *   Note that the openmrs version of the Response object has already\n *   downloaded the HTTP response body as json, and has an additional\n *   `data` property with the HTTP response json as a javascript object.\n *\n * @example\n * ```js\n * import { openmrsFetch } from '@openmrs/esm-api'\n * const abortController = new AbortController();\n * openmrsFetch(`${restBaseUrl}/session', {signal: abortController.signal})\n *   .then(response => {\n *     console.log(response.data.authenticated)\n *   })\n *   .catch(err => {\n *     console.error(err.status);\n *   })\n * abortController.abort();\n * openmrsFetch(`${restBaseUrl}/session', {\n *   method: 'POST',\n *   body: {\n *     username: 'hi',\n *     password: 'there',\n *   }\n * })\n * ```\n *\n * #### Cancellation\n *\n * To cancel a network request, use an\n * [AbortController](https://developer.mozilla.org/en-US/docs/Web/API/AbortController/abort).\n * It is best practice to cancel your network requests when the user\n * navigates away from a page while the request is pending request, to\n * free up memory and network resources and to prevent race conditions.\n *\n * @category API\n */ export function openmrsFetch(path, fetchInit = {}) {\n    if (typeof path !== 'string') {\n        throw Error(\"The first argument to @openmrs/api's openmrsFetch function must be a url string\");\n    }\n    if (typeof fetchInit !== 'object') {\n        throw Error(\"The second argument to @openmrs/api's openmrsFetch function must be a plain object.\");\n    }\n    if (!window.openmrsBase) {\n        throw Error(\"@openmrs/api is running in a browser that doesn't have window.openmrsBase, which is provided by openmrs-module-spa's HTML file.\");\n    }\n    // Prefix the url with the openmrs spa base\n    let url = makeUrl(path);\n    // We're going to need some headers\n    if (!fetchInit.headers) {\n        fetchInit.headers = {};\n    }\n    /* Automatically stringify javascript objects being sent in the\n   * request body.\n   */ if (isPlainObject(fetchInit.body)) {\n        fetchInit.body = JSON.stringify(fetchInit.body);\n    }\n    /* Add a request header to tell the server to respond with json,\n   * since frontend code almost always wants json and the OpenMRS\n   * server won't give you json unless you explicitly ask for it.\n   * If a different Accept header is preferred, pass it into the fetchInit.\n   * If no Accept header is desired, pass it in explicitly as null.\n   */ if (typeof fetchInit.headers.Accept === 'undefined') {\n        fetchInit.headers.Accept = 'application/json';\n    }\n    if (fetchInit.headers.Accept === null) {\n        delete fetchInit.headers.Accept;\n    }\n    /* This tells the OpenMRS REST API not to return a WWW-Authenticate\n   * header. Returning that header is useful when using the API, but\n   * not from a UI.\n   */ if (path.startsWith(restBaseUrl) && typeof fetchInit.headers['Disable-WWW-Authenticate'] === 'undefined') {\n        fetchInit.headers['Disable-WWW-Authenticate'] = 'true';\n    }\n    if (path.startsWith(fhirBaseUrl)) {\n        const urlUrl = new URL(url, window.location.toString());\n        if (!urlUrl.searchParams.has('_summary')) {\n            urlUrl.searchParams.set('_summary', 'data');\n            url = urlUrl.toString();\n        }\n    }\n    /* We capture the stacktrace before making the request, so that if an error occurs we can\n   * log a full stacktrace that includes the code that made the request and handled the response\n   * Otherwise, we could run into situations where the stacktrace doesn't even show which code\n   * called @openmrs/api.\n   */ const requestStacktrace = Error();\n    return window.fetch(url, fetchInit).then(async (r)=>{\n        const response = r;\n        const { redirectAuthFailure, followRedirects } = await getConfig('@openmrs/esm-api');\n        if (response.ok) {\n            if (response.status === 204) {\n                if (followRedirects && response.headers.has('location')) {\n                    const location = response.headers.get('location');\n                    if (location) {\n                        navigate({\n                            to: location\n                        });\n                    }\n                }\n                /* HTTP 204 - No Content\n         * We should not try to download the empty response as json. Instead,\n         * we return null since there is no response body.\n         */ response.data = null;\n                return response;\n            } else {\n                // HTTP 200s - The request succeeded\n                return response.clone().text().then((responseText)=>{\n                    try {\n                        if (responseText) {\n                            response.data = JSON.parse(responseText);\n                        }\n                    } catch (err) {\n                    // Server didn't respond with json\n                    }\n                    return response;\n                });\n            }\n        } else {\n            /* HTTP response status is not in 200s. Usually this will mean\n       * either HTTP 400s (bad request from browser) or HTTP 500s (server error)\n       * Our goal is to come up with best possible stacktrace and error message\n       * to help developers understand the problem and debug\n       */ /*\n       * Redirect to given url when redirect on auth failure is enabled\n       */ if (url === makeUrl(sessionEndpoint) && response.status === 403 || redirectAuthFailure.enabled && redirectAuthFailure.errors.includes(response.status)) {\n                clearHistory();\n                // by default, redirect to the url specified in the config.\n                // If blank, use the location header from the response.\n                // If that is also blank, use the default redirect url.\n                const location = redirectAuthFailure.url || response.headers.get('location') || defaultRedirectAuthFailureUrl;\n                navigate({\n                    to: location\n                });\n                /* We sometimes don't really want this promise to resolve since there's no response data,\n         * nor do we want it to reject because that would trigger error handling. We instead\n         * want it to remain in pending status while the navigation occurs.\n         */ return redirectAuthFailure.resolvePromise ? Promise.resolve() : new Promise(()=>{});\n            } else {\n                // Attempt to download a response body, if it has one\n                return response.clone().text().then((responseText)=>{\n                    let responseBody = responseText;\n                    try {\n                        responseBody = JSON.parse(responseText);\n                    } catch (err) {\n                    // Server didn't respond with json, so just go with the response text string\n                    }\n                    /* Make the fetch promise go into \"rejected\" status, with the best\n               * possible stacktrace and error message.\n               */ throw new OpenmrsFetchError(url, response, responseBody, requestStacktrace);\n                }, (err)=>{\n                    /* We weren't able to download a response body for this error.\n               * Time to just give the best possible stacktrace and error message.\n               */ throw new OpenmrsFetchError(url, response, null, requestStacktrace);\n                });\n            }\n        }\n    });\n}\n/**\n * The openmrsObservableFetch function is a wrapper around openmrsFetch\n * that returns an [Observable](https://rxjs-dev.firebaseapp.com/guide/observable)\n * instead of a promise. It exists in case using an Observable is\n * preferred or more convenient than a promise.\n *\n * @param url See [[openmrsFetch]]\n * @param fetchInit See [[openmrsFetch]]\n * @returns An Observable that produces exactly one Response object.\n * The response object is exactly the same as for [[openmrsFetch]].\n *\n * @example\n *\n * ```js\n * import { openmrsObservableFetch } from '@openmrs/esm-api'\n * const subscription = openmrsObservableFetch(`${restBaseUrl}/session').subscribe(\n *   response => console.log(response.data),\n *   err => {throw err},\n *   () => console.log('finished')\n * )\n * subscription.unsubscribe()\n * ```\n *\n * #### Cancellation\n *\n * To cancel the network request, simply call `subscription.unsubscribe();`\n *\n * @category API\n */ export function openmrsObservableFetch(url, fetchInit = {}) {\n    if (typeof fetchInit !== 'object') {\n        throw Error('The second argument to openmrsObservableFetch must be either omitted or an object');\n    }\n    const abortController = new AbortController();\n    fetchInit.signal = abortController.signal;\n    return new Observable((observer)=>{\n        let hasResponse = false;\n        openmrsFetch(url, fetchInit).then((response)=>{\n            hasResponse = true;\n            observer.next(response);\n            observer.complete();\n        }, (err)=>{\n            hasResponse = true;\n            observer.error(err);\n        });\n        return ()=>{\n            if (!hasResponse) {\n                abortController.abort();\n            }\n        };\n    });\n}\nexport class OpenmrsFetchError extends Error {\n    constructor(url, response, responseBody, requestStacktrace){\n        super(), _define_property(this, \"response\", void 0), _define_property(this, \"responseBody\", void 0);\n        this.message = `Server responded with ${response.status} (${response.statusText}) for url ${url}. Check err.responseBody or network tab in dev tools for more info`;\n        requestStacktrace.message = this.message;\n        this.responseBody = responseBody;\n        this.response = response;\n        this.stack = `Stacktrace for outgoing request:\\n${requestStacktrace.stack}\\nStacktrace for incoming response:\\n${this.stack}`;\n    }\n}\n"],"names":["_define_property","obj","key","value","Object","defineProperty","enumerable","configurable","writable","Observable","isPlainObject","getConfig","clearHistory","navigate","defaultRedirectAuthFailureUrl","restBaseUrl","fhirBaseUrl","sessionEndpoint","makeUrl","path","startsWith","window","openmrsBase","openmrsFetch","fetchInit","Error","url","headers","body","JSON","stringify","Accept","urlUrl","URL","location","toString","searchParams","has","set","requestStacktrace","fetch","then","r","response","redirectAuthFailure","followRedirects","ok","status","get","to","data","clone","text","responseText","parse","err","enabled","errors","includes","resolvePromise","Promise","resolve","responseBody","OpenmrsFetchError","openmrsObservableFetch","abortController","AbortController","signal","observer","hasResponse","next","complete","error","abort","message","statusText","stack"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-api/dist/openmrs-fetch.js\n");
69
69
 
70
70
  /***/ }),
71
71
 
@@ -155,7 +155,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
155
155
  \**********************************************************************/
156
156
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
157
157
 
158
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ clearConfigErrors: () => (/* binding */ clearConfigErrors),\n/* harmony export */ defineConfigSchema: () => (/* binding */ defineConfigSchema),\n/* harmony export */ defineExtensionConfigSchema: () => (/* binding */ defineExtensionConfigSchema),\n/* harmony export */ getConfig: () => (/* binding */ getConfig),\n/* harmony export */ getTranslationOverrides: () => (/* binding */ getTranslationOverrides),\n/* harmony export */ processConfig: () => (/* binding */ processConfig),\n/* harmony export */ provide: () => (/* binding */ provide),\n/* harmony export */ registerModuleLoad: () => (/* binding */ registerModuleLoad),\n/* harmony export */ registerModuleWithConfigSystem: () => (/* binding */ registerModuleWithConfigSystem),\n/* harmony export */ registerTranslationNamespace: () => (/* binding */ registerTranslationNamespace),\n/* harmony export */ resetConfigSystem: () => (/* binding */ resetConfigSystem)\n/* harmony export */ });\n/* harmony import */ var ramda__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ramda */ \"../../../node_modules/ramda/es/equals.js\");\n/* harmony import */ var ramda__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ramda */ \"../../../node_modules/ramda/es/mergeDeepRight.js\");\n/* harmony import */ var ramda__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ramda */ \"../../../node_modules/ramda/es/omit.js\");\n/* harmony import */ var ramda__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ramda */ \"../../../node_modules/ramda/es/clone.js\");\n/* harmony import */ var ramda__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ramda */ \"../../../node_modules/ramda/es/reduce.js\");\n/* harmony import */ var _types_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../types.js */ \"../../framework/esm-config/dist/types.js\");\n/* harmony import */ var _validators_type_validators_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../validators/type-validators.js */ \"../../framework/esm-config/dist/validators/type-validators.js\");\n/* harmony import */ var _validators_validator_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../validators/validator.js */ \"../../framework/esm-config/dist/validators/validator.js\");\n/* harmony import */ var _state_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./state.js */ \"../../framework/esm-config/dist/module-config/state.js\");\n/** @module @category Config */ \n\n\n\n\n/**\n * Store setup\n *\n *\n * Set up stores and subscriptions so that inputs get processed appropriately.\n *\n * There are *input* stores and *output* stores. The *input* stores\n * are configInternalStore, temporaryConfigStore, and configExtensionStore. The\n * output stores are set in the `compute...` functions. They are the module\n * config stores, the extension slot config stores (by module), the extension\n * config stores, and the implementer tools config store.\n *\n * This code sets up the subscriptions so that when an input store changes,\n * the correct set of output stores are updated.\n *\n * All `compute...` functions except `computeExtensionConfigs` are pure\n * (or are supposed to be), other than the fact that they all `setState`\n * store values at the end. `computeExtensionConfigs` calls `getGlobalStore`,\n * which creates stores.\n */ // Store unsubscribe functions to allow cleanup (e.g., in tests or hot module reloading)\nconst configSubscriptions = [];\n/**\n * Recomputes all configuration derived stores based on current state of input stores.\n * Called whenever any input store (configInternalStore, temporaryConfigStore, configExtensionStore) changes.\n */ function recomputeAllConfigs() {\n const configState = _state_js__WEBPACK_IMPORTED_MODULE_3__.configInternalStore.getState();\n const tempConfigState = _state_js__WEBPACK_IMPORTED_MODULE_3__.temporaryConfigStore.getState();\n const extensionState = _state_js__WEBPACK_IMPORTED_MODULE_3__.configExtensionStore.getState();\n computeModuleConfig(configState, tempConfigState);\n computeImplementerToolsConfig(configState, tempConfigState);\n computeExtensionSlotConfigs(configState, tempConfigState);\n computeExtensionConfigs(configState, extensionState, tempConfigState);\n}\nfunction setupConfigSubscriptions() {\n // Initial computation\n recomputeAllConfigs();\n // Subscribe to all input stores with a single handler\n // This ensures we only recompute once even if multiple stores change simultaneously\n configSubscriptions.push(_state_js__WEBPACK_IMPORTED_MODULE_3__.configInternalStore.subscribe(recomputeAllConfigs));\n configSubscriptions.push(_state_js__WEBPACK_IMPORTED_MODULE_3__.temporaryConfigStore.subscribe(recomputeAllConfigs));\n configSubscriptions.push(_state_js__WEBPACK_IMPORTED_MODULE_3__.configExtensionStore.subscribe(recomputeAllConfigs));\n}\n// Set up subscriptions at module load time\nsetupConfigSubscriptions();\nfunction computeModuleConfig(state, tempState) {\n for (let moduleName of Object.keys(state.schemas)){\n // At this point the schema could be either just the implicit schema or the actually\n // defined schema. We run with just the implicit schema because we want to populate\n // the config store with the translation overrides as soon as possible. In fact, the\n // translation system will throw for Suspense until the translation overrides are\n // available, which as of this writing blocks the schema definition from occurring\n // for modules loaded based on their extensions.\n const moduleStore = (0,_state_js__WEBPACK_IMPORTED_MODULE_3__.getConfigStore)(moduleName);\n let newState;\n if (state.moduleLoaded[moduleName]) {\n const config = getConfigForModule(moduleName, state, tempState);\n newState = {\n translationOverridesLoaded: true,\n loaded: true,\n config\n };\n } else {\n const config = getConfigForModuleImplicitSchema(moduleName, state, tempState);\n newState = {\n translationOverridesLoaded: true,\n loaded: false,\n config\n };\n }\n moduleStore.setState(newState);\n }\n}\nfunction computeExtensionSlotConfigs(state, tempState) {\n const slotConfigs = getExtensionSlotConfigs(state, tempState);\n const newSlotStoreEntries = Object.fromEntries(Object.entries(slotConfigs).map(([slotName, config])=>[\n slotName,\n {\n loaded: true,\n config\n }\n ]));\n const slotStore = (0,_state_js__WEBPACK_IMPORTED_MODULE_3__.getExtensionSlotsConfigStore)();\n const oldState = slotStore.getState();\n const newState = {\n slots: {\n ...oldState.slots,\n ...newSlotStoreEntries\n }\n };\n if (!(0,ramda__WEBPACK_IMPORTED_MODULE_4__[\"default\"])(oldState.slots, newState.slots)) {\n slotStore.setState(newState);\n }\n}\nfunction computeImplementerToolsConfig(state, tempConfigState) {\n const oldState = _state_js__WEBPACK_IMPORTED_MODULE_3__.implementerToolsConfigStore.getState();\n const config = getImplementerToolsConfig(state, tempConfigState);\n const newState = {\n config\n };\n // Use deep equality on the actual config content, not the wrapper object\n if (!(0,ramda__WEBPACK_IMPORTED_MODULE_4__[\"default\"])(oldState.config, newState.config)) {\n _state_js__WEBPACK_IMPORTED_MODULE_3__.implementerToolsConfigStore.setState(newState);\n }\n}\nfunction computeExtensionConfigs(configState, extensionState, tempConfigState) {\n const configs = {};\n // We assume that the module schema has already been defined, since the extension\n // it contains is mounted.\n for (let extension of extensionState.mountedExtensions){\n const config = computeExtensionConfig(extension.slotModuleName, extension.extensionModuleName, extension.slotName, extension.extensionId, configState, tempConfigState);\n if (!configs[extension.slotName]) {\n configs[extension.slotName] = {};\n }\n configs[extension.slotName][extension.extensionId] = {\n config,\n loaded: true\n };\n }\n const extensionsConfigStore = (0,_state_js__WEBPACK_IMPORTED_MODULE_3__.getExtensionsConfigStore)();\n const oldState = extensionsConfigStore.getState();\n const newState = {\n configs\n };\n // Use deep equality to only update if configs actually changed\n if (!(0,ramda__WEBPACK_IMPORTED_MODULE_4__[\"default\"])(oldState.configs, newState.configs)) {\n extensionsConfigStore.setState(newState);\n }\n}\n/*\n * API\n *\n */ /**\n * This defines a configuration schema for a module. The schema tells the\n * configuration system how the module can be configured. It specifies\n * what makes configuration valid or invalid.\n *\n * See [Configuration System](https://o3-docs.openmrs.org/docs/configuration-system)\n * for more information about defining a config schema.\n *\n * @param moduleName Name of the module the schema is being defined for. Generally\n * should be the one in which the `defineConfigSchema` call takes place.\n * @param schema The config schema for the module\n */ function defineConfigSchema(moduleName, schema) {\n validateConfigSchema(moduleName, schema);\n const enhancedSchema = (0,ramda__WEBPACK_IMPORTED_MODULE_5__[\"default\"])(schema, implicitConfigSchema);\n _state_js__WEBPACK_IMPORTED_MODULE_3__.configInternalStore.setState((state)=>({\n ...state,\n schemas: {\n ...state.schemas,\n [moduleName]: enhancedSchema\n },\n moduleLoaded: {\n ...state.moduleLoaded,\n [moduleName]: true\n }\n }));\n}\n/**\n * This alerts the configuration system that a module exists. This allows config to be\n * processed, while still allowing the extension system to know whether the module has\n * actually had its front bundle executed yet.\n *\n * This should only be used in esm-app-shell.\n *\n * @internal\n * @param moduleName\n */ function registerModuleWithConfigSystem(moduleName) {\n _state_js__WEBPACK_IMPORTED_MODULE_3__.configInternalStore.setState((state)=>({\n ...state,\n schemas: {\n ...state.schemas,\n [moduleName]: implicitConfigSchema\n }\n }));\n}\n/**\n * This alerts the configuration system that a module has been loaded.\n *\n * This should only be used in esm-app-shell.\n *\n * @internal\n * @param moduleName\n */ function registerModuleLoad(moduleName) {\n _state_js__WEBPACK_IMPORTED_MODULE_3__.configInternalStore.setState((state)=>({\n ...state,\n moduleLoaded: {\n ...state.moduleLoaded,\n [moduleName]: true\n }\n }));\n}\n/**\n * This allows the config system to support translation overrides for namespaces that\n * do not correspond to modules.\n *\n * This should only be used in esm-app-shell.\n *\n * @internal\n * @param namespace\n */ function registerTranslationNamespace(namespace) {\n _state_js__WEBPACK_IMPORTED_MODULE_3__.configInternalStore.setState((state)=>({\n ...state,\n schemas: {\n ...state.schemas,\n [namespace]: translationOverridesSchema\n }\n }));\n}\n/**\n * This defines a configuration schema for an extension. When a schema is defined\n * for an extension, that extension will receive the configuration corresponding\n * to that schema, rather than the configuration corresponding to the module\n * in which it is defined.\n *\n * The schema tells the configuration system how the module can be configured.\n * It specifies what makes configuration valid or invalid.\n *\n * See [Configuration System](https://o3-docs.openmrs.org/docs/configuration-system)\n * for more information about defining a config schema.\n *\n * @param extensionName Name of the extension the schema is being defined for.\n * Should match the `name` of one of the `extensions` entries defined in\n * the app's `routes.json` file.\n * @param schema The config schema for the extension\n */ function defineExtensionConfigSchema(extensionName, schema) {\n validateConfigSchema(extensionName, schema);\n const enhancedSchema = (0,ramda__WEBPACK_IMPORTED_MODULE_5__[\"default\"])(schema, implicitConfigSchema);\n const state = _state_js__WEBPACK_IMPORTED_MODULE_3__.configInternalStore.getState();\n if (state.schemas[extensionName]) {\n console.error(`Config schema for extension ${extensionName} already exists. If there are multiple extensions with this same name, one will probably crash.`);\n }\n _state_js__WEBPACK_IMPORTED_MODULE_3__.configInternalStore.setState((state)=>({\n ...state,\n schemas: {\n ...state.schemas,\n [extensionName]: enhancedSchema\n }\n }));\n}\nfunction provide(config, sourceName = 'provided') {\n _state_js__WEBPACK_IMPORTED_MODULE_3__.configInternalStore.setState((state)=>({\n ...state,\n providedConfigs: [\n ...state.providedConfigs,\n {\n source: sourceName,\n config\n }\n ]\n }));\n}\n/**\n * A promise-based way to access the config as soon as it is fully loaded.\n * If it is already loaded, resolves the config in its present state.\n *\n * This is a useful function if you need to get the config in the course\n * of the execution of a function.\n *\n * @param moduleName The name of the module for which to look up the config\n */ function getConfig(moduleName) {\n return new Promise((resolve)=>{\n const store = (0,_state_js__WEBPACK_IMPORTED_MODULE_3__.getConfigStore)(moduleName);\n function update(state) {\n if (state.loaded && state.config) {\n const config = (0,ramda__WEBPACK_IMPORTED_MODULE_6__[\"default\"])([\n 'Display conditions',\n 'Translation overrides'\n ], state.config);\n resolve(config);\n if (unsubscribe) {\n unsubscribe();\n }\n }\n }\n update(store.getState());\n const unsubscribe = store.subscribe(update);\n });\n}\n/** @internal */ function getTranslationOverrides(moduleName, slotName, extensionId) {\n const promises = [\n new Promise((resolve)=>{\n const configStore = (0,_state_js__WEBPACK_IMPORTED_MODULE_3__.getConfigStore)(moduleName);\n function update(state) {\n if (state.translationOverridesLoaded && state.config) {\n const translationOverrides = state.config['Translation overrides'] ?? {};\n resolve(translationOverrides);\n if (unsubscribe) {\n unsubscribe();\n }\n }\n }\n update(configStore.getState());\n const unsubscribe = configStore.subscribe(update);\n })\n ];\n if (slotName && extensionId) {\n promises.push(new Promise((resolve)=>{\n const configStore = (0,_state_js__WEBPACK_IMPORTED_MODULE_3__.getExtensionConfig)(slotName, extensionId);\n function update(state) {\n if (state.loaded && state.config) {\n const translationOverrides = state.config['Translation overrides'] ?? {};\n resolve(translationOverrides);\n if (unsubscribe) {\n unsubscribe();\n }\n }\n }\n update(configStore.getState());\n const unsubscribe = configStore.subscribe(update);\n }));\n }\n return Promise.all(promises);\n}\n/**\n * Validate and interpolate defaults for `providedConfig` according to `schema`\n *\n * @param schema a configuration schema\n * @param providedConfig an object of config values (without the top-level module name)\n * @param keyPathContext a dot-deparated string which helps the user figure out where\n * the provided config came from\n * @internal\n */ function processConfig(schema, providedConfig, keyPathContext) {\n validateStructure(schema, providedConfig, keyPathContext);\n const config = setDefaults(schema, providedConfig);\n runAllValidatorsInConfigTree(schema, config, keyPathContext);\n return config;\n}\n/*\n * Helper functions\n *\n */ /**\n * Returns the configuration for an extension. This configuration is specific\n * to the slot in which it is mounted, and its ID within that slot.\n *\n * The schema for that configuration is the extension schema. If no extension\n * schema has been provided, the schema used is the schema of the module in\n * which the extension is defined.\n *\n * @param slotModuleName The name of the module which defines the extension slot\n * @param extensionModuleName The name of the module which defines the extension (and therefore the config schema)\n * @param slotName The name of the extension slot where the extension is mounted\n * @param extensionId The ID of the extension in its slot\n */ function computeExtensionConfig(slotModuleName, extensionModuleName, slotName, extensionId, configState, tempConfigState) {\n const extensionName = getExtensionNameFromId(extensionId);\n const extensionConfigSchema = configState.schemas[extensionName];\n const nameOfSchemaSource = extensionConfigSchema ? extensionName : extensionModuleName;\n const providedConfigs = getProvidedConfigs(configState, tempConfigState);\n const slotModuleConfig = mergeConfigsFor(slotModuleName, providedConfigs);\n const configOverride = slotModuleConfig?.extensionSlots?.[slotName]?.configure?.[extensionId] ?? {};\n const extensionConfig = mergeConfigsFor(nameOfSchemaSource, providedConfigs);\n const combinedConfig = mergeConfigs([\n extensionConfig,\n configOverride\n ]);\n const schema = extensionConfigSchema ?? configState.schemas[extensionModuleName];\n validateStructure(schema, combinedConfig, nameOfSchemaSource);\n const config = setDefaults(schema, combinedConfig);\n runAllValidatorsInConfigTree(schema, config, nameOfSchemaSource);\n delete config.extensionSlots;\n return config;\n}\nfunction getImplementerToolsConfig(configState, tempConfigState) {\n let result = getSchemaWithValuesAndSources((0,ramda__WEBPACK_IMPORTED_MODULE_7__[\"default\"])(configState.schemas));\n const configsAndSources = [\n ...configState.providedConfigs.map((c)=>[\n c.config,\n c.source\n ]),\n [\n tempConfigState.config,\n 'temporary config'\n ]\n ];\n for (let [config, source] of configsAndSources){\n result = mergeConfigs([\n result,\n createValuesAndSourcesTree(config, source)\n ]);\n }\n return result;\n}\nfunction getSchemaWithValuesAndSources(schema) {\n if (schema.hasOwnProperty('_default')) {\n return {\n ...schema,\n _value: schema._default,\n _source: 'default'\n };\n } else if (isOrdinaryObject(schema)) {\n return Object.keys(schema).reduce((obj, key)=>{\n obj[key] = getSchemaWithValuesAndSources(schema[key]);\n return obj;\n }, {});\n } else {\n // at this point, the schema is bad and an error will have been logged during schema validation\n return {};\n }\n}\nfunction createValuesAndSourcesTree(config, source) {\n if (isOrdinaryObject(config)) {\n return Object.keys(config).reduce((obj, key)=>{\n obj[key] = createValuesAndSourcesTree(config[key], source);\n return obj;\n }, {});\n } else {\n return {\n _value: config,\n _source: source\n };\n }\n}\nfunction getExtensionSlotConfigs(configState, tempConfigState) {\n const allConfigs = mergeConfigs(getProvidedConfigs(configState, tempConfigState));\n const slotConfigPerModule = Object.keys(allConfigs).reduce((obj, key)=>{\n if (allConfigs[key]?.extensionSlots) {\n obj[key] = allConfigs[key]?.extensionSlots;\n }\n return obj;\n }, {});\n validateAllExtensionSlotConfigs(slotConfigPerModule);\n const slotConfigs = Object.keys(slotConfigPerModule).reduce((obj, key)=>{\n obj = {\n ...obj,\n ...slotConfigPerModule[key]\n };\n return obj;\n }, {});\n return slotConfigs;\n}\nfunction validateAllExtensionSlotConfigs(slotConfigPerModule) {\n for (let [moduleName, configBySlotName] of Object.entries(slotConfigPerModule)){\n for (let [slotName, config] of Object.entries(configBySlotName)){\n validateExtensionSlotConfig(config, moduleName, slotName);\n }\n }\n}\nfunction validateExtensionSlotConfig(config, moduleName, slotName) {\n const keyPath = `${moduleName}.extensionSlots.${slotName}`;\n const errorPrefix = `Extension slot config '${keyPath}'`;\n const invalidKeys = Object.keys(config).filter((k)=>![\n 'add',\n 'remove',\n 'order',\n 'configure'\n ].includes(k));\n if (invalidKeys.length) {\n logError(keyPath, errorPrefix + `' contains invalid keys '${invalidKeys.join(\"', '\")}'`);\n }\n if (config.add) {\n if (!Array.isArray(config.add) || !config.add.every((n)=>typeof n === 'string')) {\n logError(keyPath, errorPrefix + `.add' is invalid. Must be an array of strings (extension IDs)`);\n }\n }\n if (config.remove) {\n if (!Array.isArray(config.remove) || !config.remove.every((n)=>typeof n === 'string')) {\n logError(keyPath, errorPrefix + `.remove' is invalid. Must be an array of strings (extension IDs)`);\n }\n }\n if (config.order) {\n if (!Array.isArray(config.order) || !config.order.every((n)=>typeof n === 'string')) {\n logError(keyPath, errorPrefix + `.order' is invalid. Must be an array of strings (extension IDs)`);\n }\n }\n if (config.configure) {\n if (!isOrdinaryObject(config.configure)) {\n logError(keyPath, errorPrefix + `.configure' is invalid. Must be an object with extension IDs for keys`);\n }\n }\n}\nfunction getProvidedConfigs(configState, tempConfigState) {\n return [\n ...configState.providedConfigs.map((c)=>c.config),\n tempConfigState.config\n ];\n}\n/**\n * Validates the config schema for a module. Since problems identified here are programming errors\n * that hopefully will be caught during development, this function logs errors to the console directly;\n * it's fine if we spam the user with these errors.\n */ function validateConfigSchema(moduleName, schema, keyPath = '') {\n const updateMessage = `Please verify that you are running the latest version and, if so, alert the maintainer.`;\n for (const key of Object.keys(schema).filter((k)=>!k.startsWith('_'))){\n const thisKeyPath = keyPath + (keyPath && '.') + key;\n const schemaPart = schema[key];\n if (thisKeyPath === 'Display conditions') {\n console.error(`${moduleName} declares a configuration option called \"Display conditions\"; the \"Display conditions\" option is a reserved name. ${updateMessage}`);\n }\n if (thisKeyPath === 'Translation overrides') {\n console.error(`${moduleName} declares a configuration option called \"Translation overrides\"; the \"Translation overrides\" option is a reserved name. ${updateMessage}`);\n }\n if (!isOrdinaryObject(schemaPart)) {\n console.error(`${moduleName} has bad config schema definition for key '${thisKeyPath}'. ${updateMessage}`);\n continue;\n }\n if (!schemaPart.hasOwnProperty('_default')) {\n // recurse for nested config keys\n validateConfigSchema(moduleName, schemaPart, thisKeyPath);\n }\n const elements = schemaPart._elements;\n if (hasObjectSchema(elements)) {\n validateConfigSchema(moduleName, elements, thisKeyPath + '._elements');\n }\n if (schemaPart._validators) {\n for (let validator of schemaPart._validators){\n if (typeof validator !== 'function') {\n console.error(`${moduleName} has invalid validator for key '${thisKeyPath}' ${updateMessage}.` + `\\n\\nIf you're the maintainer: validators must be functions that return either ` + `undefined or an error string. Received ${validator}.`);\n }\n }\n }\n const valueType = schemaPart._type;\n if (valueType && !Object.values(_types_js__WEBPACK_IMPORTED_MODULE_0__.Type).includes(valueType)) {\n console.error(`${moduleName} has invalid type for key '${thisKeyPath}' ${updateMessage}.` + `\\n\\nIf you're the maintainer: the allowed types are ${Object.values(_types_js__WEBPACK_IMPORTED_MODULE_0__.Type).join(', ')}. ` + `Received '${valueType}'`);\n }\n if (Object.keys(schemaPart).every((k)=>[\n '_description',\n '_validators',\n '_elements',\n '_type'\n ].includes(k)) && !keyPath.includes('._elements')) {\n console.error(`${moduleName} has bad config schema definition for key '${thisKeyPath}'. ${updateMessage}.` + `\\n\\nIf you're the maintainer: all config elements must have a default. ` + `Received ${JSON.stringify(schemaPart)}`);\n }\n if (elements && valueType && ![\n _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.Array,\n _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.Object\n ].includes(valueType)) {\n console.error(`${moduleName} has bad config schema definition for key '${thisKeyPath}'. ${updateMessage}.` + `\\n\\nIf you're the maintainer: the 'elements' key only works with '_type' equal to 'Array' or 'Object'. ` + `Received ${JSON.stringify(valueType)}`);\n }\n }\n}\nfunction getConfigForModule(moduleName, configState, tempConfigState) {\n const schema = configState.schemas[moduleName];\n const inputConfig = mergeConfigsFor(moduleName, getProvidedConfigs(configState, tempConfigState));\n validateStructure(schema, inputConfig, moduleName);\n const config = setDefaults(schema, inputConfig);\n runAllValidatorsInConfigTree(schema, config, moduleName);\n delete config.extensionSlots;\n return config;\n}\nfunction getConfigForModuleImplicitSchema(moduleName, configState, tempConfigState) {\n const inputConfig = mergeConfigsFor(moduleName, getProvidedConfigs(configState, tempConfigState));\n const config = setDefaults(implicitConfigSchema, inputConfig);\n runAllValidatorsInConfigTree(implicitConfigSchema, config, moduleName);\n delete config.extensionSlots;\n return config;\n}\nfunction mergeConfigsFor(moduleName, allConfigs) {\n const allConfigsForModule = allConfigs.map(({ [moduleName]: c })=>c).filter((c)=>!!c);\n return mergeConfigs(allConfigsForModule);\n}\nfunction mergeConfigs(configs) {\n const mergeDeepAll = (0,ramda__WEBPACK_IMPORTED_MODULE_8__[\"default\"])(ramda__WEBPACK_IMPORTED_MODULE_5__[\"default\"]);\n return mergeDeepAll({}, configs);\n}\n/**\n * Recursively check the provided config tree to make sure that all\n * of the provided properties exist in the schema, and that types are\n * correct. Does not run validators yet, since those will be run on\n * the config with the defaults filled in.\n */ function validateStructure(schema, config, keyPath = '') {\n // validate each constituent element\n for (const key of Object.keys(config)){\n const value = config[key];\n const thisKeyPath = keyPath + '.' + key;\n const schemaPart = schema[key];\n if (!schema.hasOwnProperty(key)) {\n if (!(key === 'extensionSlots' && keyPath !== '')) {\n logError(thisKeyPath, `Unknown config key '${thisKeyPath}' provided. Ignoring.`);\n }\n continue;\n }\n validateBranchStructure(schemaPart, value, thisKeyPath);\n }\n}\nfunction validateBranchStructure(schemaPart, value, keyPath) {\n checkType(keyPath, schemaPart._type, value);\n if (isOrdinaryObject(value)) {\n if (schemaPart._type === _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.Object) {\n // validate as freeform object\n validateFreeformObjectStructure(schemaPart, value, keyPath);\n } else if (!(schemaPart.hasOwnProperty('_default') || schemaPart.hasOwnProperty('_type'))) {\n // validate as normal nested config\n validateStructure(schemaPart, value, keyPath);\n }\n } else {\n if (schemaPart._type === _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.Array) {\n validateArrayStructure(schemaPart, value, keyPath);\n }\n }\n}\nfunction validateFreeformObjectStructure(freeformObjectSchema, config, keyPath) {\n if (freeformObjectSchema._elements) {\n for (const key of Object.keys(config)){\n const value = config[key];\n validateBranchStructure(freeformObjectSchema._elements, value, `${keyPath}.${key}`);\n }\n }\n}\nfunction validateArrayStructure(arraySchema, value, keyPath) {\n const validatedAsArray = checkType(keyPath, _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.Array, value);\n if (!validatedAsArray) {\n return;\n }\n // if there is an array element object schema, verify that elements match it\n if (hasObjectSchema(arraySchema._elements)) {\n for(let i = 0; i < value.length; i++){\n validateBranchStructure(arraySchema._elements, value[i], `${keyPath}[${i}]`);\n }\n }\n for(let i = 0; i < value.length; i++){\n checkType(`${keyPath}[${i}]`, arraySchema._elements?._type, value[i]);\n }\n}\n/**\n * Run all the validators in the config tree. This should be run\n * on the config object after it has been filled in with all the defaults, since\n * higher-level validators may refer to default values.\n */ function runAllValidatorsInConfigTree(schema, config, keyPath = '') {\n // If `!schema`, there should have been a structural validation error printed already.\n if (schema) {\n if (config !== schema._default) {\n runValidators(keyPath, schema._validators, config);\n }\n if (isOrdinaryObject(config)) {\n for (const key of Object.keys(config)){\n const value = config[key];\n const thisKeyPath = keyPath + '.' + key;\n const schemaPart = schema[key];\n if (schema._type === _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.Object && schema._elements) {\n runAllValidatorsInConfigTree(schema._elements, value, thisKeyPath);\n } else {\n runAllValidatorsInConfigTree(schemaPart, value, thisKeyPath);\n }\n }\n } else if (Array.isArray(config) && schema._elements) {\n for(let i = 0; i < config.length; i++){\n runAllValidatorsInConfigTree(schema._elements, config[i], `${keyPath}[${i}]`);\n }\n }\n }\n}\n/**\n * Run type validation for the value, logging any errors.\n * @returns true if validation passes, false otherwise\n */ function checkType(keyPath, _type, value) {\n if (_type) {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\n const validator = {\n Array: _validators_type_validators_js__WEBPACK_IMPORTED_MODULE_1__.isArray,\n Boolean: _validators_type_validators_js__WEBPACK_IMPORTED_MODULE_1__.isBoolean,\n ConceptUuid: _validators_type_validators_js__WEBPACK_IMPORTED_MODULE_1__.isUuid,\n Number: _validators_type_validators_js__WEBPACK_IMPORTED_MODULE_1__.isNumber,\n Object: _validators_type_validators_js__WEBPACK_IMPORTED_MODULE_1__.isObject,\n String: _validators_type_validators_js__WEBPACK_IMPORTED_MODULE_1__.isString,\n UUID: _validators_type_validators_js__WEBPACK_IMPORTED_MODULE_1__.isUuid,\n PersonAttributeTypeUuid: _validators_type_validators_js__WEBPACK_IMPORTED_MODULE_1__.isUuid,\n PatientIdentifierTypeUuid: _validators_type_validators_js__WEBPACK_IMPORTED_MODULE_1__.isUuid\n };\n return runValidators(keyPath, [\n validator[_type]\n ], value);\n }\n return true;\n}\n/**\n * Runs validators, logging errors.\n * @returns true if all pass, false otherwise.\n */ // eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\nfunction runValidators(keyPath, validators, value) {\n let returnValue = true;\n if (validators) {\n try {\n for (let validator of validators){\n const validatorResult = validator(value);\n if (typeof validatorResult === 'string') {\n const message = typeof value === 'object' ? `Invalid configuration for ${keyPath}: ${validatorResult}` : `Invalid configuration value ${value} for ${keyPath}: ${validatorResult}`;\n logError(keyPath, message);\n returnValue = false;\n }\n }\n } catch (e) {\n console.error(`Skipping invalid validator at \"${keyPath}\". Encountered error\\n\\t${e}`);\n }\n }\n return returnValue;\n}\n// Recursively fill in the config with values from the schema.\nconst setDefaults = (schema, inputConfig)=>{\n const config = (0,ramda__WEBPACK_IMPORTED_MODULE_7__[\"default\"])(inputConfig);\n if (!schema) {\n return config;\n }\n for (const key of Object.keys(schema)){\n const configPart = config[key];\n const schemaPart = schema[key];\n // The `schemaPart &&` clause of this `if` statement will only fail\n // if the schema is very invalid. It is there to prevent the app from\n // crashing completely, though it will produce unexpected behavior.\n // If this happens, there should be legible errors in the console from\n // the schema validator.\n if (schemaPart && (schemaPart.hasOwnProperty('_type') || schemaPart.hasOwnProperty('_default'))) {\n // We assume that schemaPart defines a config value, since it has\n // a property `_type` or `_default`.\n if (!config.hasOwnProperty(key)) {\n config[key] = schemaPart['_default'];\n }\n // We also check if it is an object or array with object elements, in which case we recurse\n const elements = schemaPart._elements;\n if (configPart && hasObjectSchema(elements)) {\n if (schemaPart._type === _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.Array && Array.isArray(configPart)) {\n const configWithDefaults = configPart.map((conf)=>setDefaults(elements, conf));\n config[key] = configWithDefaults;\n } else if (schemaPart._type === _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.Object) {\n for (let objectKey of Object.keys(configPart)){\n configPart[objectKey] = setDefaults(elements, configPart[objectKey]);\n }\n }\n }\n } else if (isOrdinaryObject(schemaPart)) {\n // Since schemaPart has no property \"_type\", if it's an ordinary object\n // (unlike, importantly, the validators array), we assume it is a parent config property.\n // We recurse to config[key] and schema[key]. Default config[key] to {}.\n const selectedConfigPart = configPart ?? {};\n // There will have been a validation error already if configPart is not a plain object.\n if (isOrdinaryObject(selectedConfigPart)) {\n config[key] = setDefaults(schemaPart, selectedConfigPart);\n }\n }\n }\n return config;\n};\nfunction hasObjectSchema(elementsSchema) {\n return !!elementsSchema && Object.keys(elementsSchema).filter((e)=>![\n '_default',\n '_validators'\n ].includes(e)).length > 0;\n}\nfunction isOrdinaryObject(value) {\n return typeof value === 'object' && !Array.isArray(value) && value !== null;\n}\n/** Keep track of which validation errors we have displayed. Each one should only be displayed once. */ let displayedValidationMessages = new Set();\nfunction logError(keyPath, message) {\n const key = `${keyPath}:::${message}`;\n // technically, this should not be possible, but because of how things wind-up transpiled, this isn't impossible\n if (!displayedValidationMessages) {\n displayedValidationMessages = new Set();\n }\n if (!displayedValidationMessages.has(key)) {\n console.error(message);\n displayedValidationMessages.add(key);\n }\n}\n/**\n * Normally, configuration errors are only displayed once. This function clears the list of\n * displayed errors, so that they will be displayed again.\n *\n * @internal\n */ function clearConfigErrors(keyPath) {\n if (keyPath) {\n displayedValidationMessages.forEach((key)=>{\n if (key.startsWith(keyPath)) {\n displayedValidationMessages.delete(key);\n }\n });\n } else {\n displayedValidationMessages.clear();\n }\n}\n/**\n * Cleans up all config store subscriptions and re-establishes them. This is primarily\n * useful for testing, where subscriptions set up at module load time need to be cleared\n * between tests to prevent infinite update loops. After clearing, subscriptions are\n * re-established so the config system continues to work normally.\n *\n * @internal\n */ function resetConfigSystem() {\n configSubscriptions.forEach((unsubscribe)=>unsubscribe());\n configSubscriptions.length = 0;\n setupConfigSubscriptions();\n}\n/**\n * Copied over from esm-extensions. It rightly belongs to that module, but esm-config\n * cannot depend on esm-extensions.\n */ function getExtensionNameFromId(extensionId) {\n const [extensionName] = extensionId.split('#');\n return extensionName;\n}\n/**\n * The translation overrides schema is used in the implicit schema given to every module;\n * plus any additional translation namespaces (at time of writing, this is just 'core').\n */ const translationOverridesSchema = {\n 'Translation overrides': {\n _description: 'Per-language overrides for frontend translations should be keyed by language code and each language dictionary contains the translation key and the display value',\n _type: _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.Object,\n _default: {},\n _validators: [\n (0,_validators_validator_js__WEBPACK_IMPORTED_MODULE_2__.validator)((o)=>Object.keys(o).every((k)=>/^[a-z]{2,3}(-[A-Z]{2,3})?$/.test(k)), (o)=>{\n const badKeys = Object.keys(o).filter((k)=>!/^[a-z]{2,3}(-[A-Z]{2,3})?$/.test(k));\n return `The 'Translation overrides' object should have language codes for keys. Language codes must be in the form of a two-to-three letter language code optionally followed by a hyphen and a two-to-three letter country code. The following keys do not conform: ${badKeys.join(', ')}.`;\n })\n ]\n }\n};\n/**\n * The implicitConfigSchema is implicitly included in every configuration schema\n */ const implicitConfigSchema = {\n 'Display conditions': {\n privileges: {\n _description: 'The privilege(s) the user must have to use this extension',\n _type: _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.Array,\n _default: []\n },\n expression: {\n _description: 'The expression that determines whether the extension is displayed',\n _type: _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.String,\n _default: undefined\n }\n },\n ...translationOverridesSchema\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-config/dist/module-config/module-config.js","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-config/dist/module-config/module-config.js?8dfe"],"sourcesContent":["/** @module @category Config */ import { clone, equals, reduce, mergeDeepRight, omit } from \"ramda\";\nimport { Type } from \"../types.js\";\nimport { isArray, isBoolean, isUuid, isNumber, isObject, isString } from \"../validators/type-validators.js\";\nimport { validator } from \"../validators/validator.js\";\nimport { configExtensionStore, configInternalStore, getConfigStore, getExtensionConfig, getExtensionSlotsConfigStore, getExtensionsConfigStore, implementerToolsConfigStore, temporaryConfigStore } from \"./state.js\";\n/**\n * Store setup\n *\n *\n * Set up stores and subscriptions so that inputs get processed appropriately.\n *\n * There are *input* stores and *output* stores. The *input* stores\n * are configInternalStore, temporaryConfigStore, and configExtensionStore. The\n * output stores are set in the `compute...` functions. They are the module\n * config stores, the extension slot config stores (by module), the extension\n * config stores, and the implementer tools config store.\n *\n * This code sets up the subscriptions so that when an input store changes,\n * the correct set of output stores are updated.\n *\n * All `compute...` functions except `computeExtensionConfigs` are pure\n * (or are supposed to be), other than the fact that they all `setState`\n * store values at the end. `computeExtensionConfigs` calls `getGlobalStore`,\n * which creates stores.\n */ // Store unsubscribe functions to allow cleanup (e.g., in tests or hot module reloading)\nconst configSubscriptions = [];\n/**\n * Recomputes all configuration derived stores based on current state of input stores.\n * Called whenever any input store (configInternalStore, temporaryConfigStore, configExtensionStore) changes.\n */ function recomputeAllConfigs() {\n    const configState = configInternalStore.getState();\n    const tempConfigState = temporaryConfigStore.getState();\n    const extensionState = configExtensionStore.getState();\n    computeModuleConfig(configState, tempConfigState);\n    computeImplementerToolsConfig(configState, tempConfigState);\n    computeExtensionSlotConfigs(configState, tempConfigState);\n    computeExtensionConfigs(configState, extensionState, tempConfigState);\n}\nfunction setupConfigSubscriptions() {\n    // Initial computation\n    recomputeAllConfigs();\n    // Subscribe to all input stores with a single handler\n    // This ensures we only recompute once even if multiple stores change simultaneously\n    configSubscriptions.push(configInternalStore.subscribe(recomputeAllConfigs));\n    configSubscriptions.push(temporaryConfigStore.subscribe(recomputeAllConfigs));\n    configSubscriptions.push(configExtensionStore.subscribe(recomputeAllConfigs));\n}\n// Set up subscriptions at module load time\nsetupConfigSubscriptions();\nfunction computeModuleConfig(state, tempState) {\n    for (let moduleName of Object.keys(state.schemas)){\n        // At this point the schema could be either just the implicit schema or the actually\n        // defined schema. We run with just the implicit schema because we want to populate\n        // the config store with the translation overrides as soon as possible. In fact, the\n        // translation system will throw for Suspense until the translation overrides are\n        // available, which as of this writing blocks the schema definition from occurring\n        // for modules loaded based on their extensions.\n        const moduleStore = getConfigStore(moduleName);\n        let newState;\n        if (state.moduleLoaded[moduleName]) {\n            const config = getConfigForModule(moduleName, state, tempState);\n            newState = {\n                translationOverridesLoaded: true,\n                loaded: true,\n                config\n            };\n        } else {\n            const config = getConfigForModuleImplicitSchema(moduleName, state, tempState);\n            newState = {\n                translationOverridesLoaded: true,\n                loaded: false,\n                config\n            };\n        }\n        moduleStore.setState(newState);\n    }\n}\nfunction computeExtensionSlotConfigs(state, tempState) {\n    const slotConfigs = getExtensionSlotConfigs(state, tempState);\n    const newSlotStoreEntries = Object.fromEntries(Object.entries(slotConfigs).map(([slotName, config])=>[\n            slotName,\n            {\n                loaded: true,\n                config\n            }\n        ]));\n    const slotStore = getExtensionSlotsConfigStore();\n    const oldState = slotStore.getState();\n    const newState = {\n        slots: {\n            ...oldState.slots,\n            ...newSlotStoreEntries\n        }\n    };\n    if (!equals(oldState.slots, newState.slots)) {\n        slotStore.setState(newState);\n    }\n}\nfunction computeImplementerToolsConfig(state, tempConfigState) {\n    const oldState = implementerToolsConfigStore.getState();\n    const config = getImplementerToolsConfig(state, tempConfigState);\n    const newState = {\n        config\n    };\n    // Use deep equality on the actual config content, not the wrapper object\n    if (!equals(oldState.config, newState.config)) {\n        implementerToolsConfigStore.setState(newState);\n    }\n}\nfunction computeExtensionConfigs(configState, extensionState, tempConfigState) {\n    const configs = {};\n    // We assume that the module schema has already been defined, since the extension\n    // it contains is mounted.\n    for (let extension of extensionState.mountedExtensions){\n        const config = computeExtensionConfig(extension.slotModuleName, extension.extensionModuleName, extension.slotName, extension.extensionId, configState, tempConfigState);\n        if (!configs[extension.slotName]) {\n            configs[extension.slotName] = {};\n        }\n        configs[extension.slotName][extension.extensionId] = {\n            config,\n            loaded: true\n        };\n    }\n    const extensionsConfigStore = getExtensionsConfigStore();\n    const oldState = extensionsConfigStore.getState();\n    const newState = {\n        configs\n    };\n    // Use deep equality to only update if configs actually changed\n    if (!equals(oldState.configs, newState.configs)) {\n        extensionsConfigStore.setState(newState);\n    }\n}\n/*\n * API\n *\n */ /**\n * This defines a configuration schema for a module. The schema tells the\n * configuration system how the module can be configured. It specifies\n * what makes configuration valid or invalid.\n *\n * See [Configuration System](https://o3-docs.openmrs.org/docs/configuration-system)\n * for more information about defining a config schema.\n *\n * @param moduleName Name of the module the schema is being defined for. Generally\n *   should be the one in which the `defineConfigSchema` call takes place.\n * @param schema The config schema for the module\n */ export function defineConfigSchema(moduleName, schema) {\n    validateConfigSchema(moduleName, schema);\n    const enhancedSchema = mergeDeepRight(schema, implicitConfigSchema);\n    configInternalStore.setState((state)=>({\n            ...state,\n            schemas: {\n                ...state.schemas,\n                [moduleName]: enhancedSchema\n            },\n            moduleLoaded: {\n                ...state.moduleLoaded,\n                [moduleName]: true\n            }\n        }));\n}\n/**\n * This alerts the configuration system that a module exists. This allows config to be\n * processed, while still allowing the extension system to know whether the module has\n * actually had its front bundle executed yet.\n *\n * This should only be used in esm-app-shell.\n *\n * @internal\n * @param moduleName\n */ export function registerModuleWithConfigSystem(moduleName) {\n    configInternalStore.setState((state)=>({\n            ...state,\n            schemas: {\n                ...state.schemas,\n                [moduleName]: implicitConfigSchema\n            }\n        }));\n}\n/**\n * This alerts the configuration system that a module has been loaded.\n *\n * This should only be used in esm-app-shell.\n *\n * @internal\n * @param moduleName\n */ export function registerModuleLoad(moduleName) {\n    configInternalStore.setState((state)=>({\n            ...state,\n            moduleLoaded: {\n                ...state.moduleLoaded,\n                [moduleName]: true\n            }\n        }));\n}\n/**\n * This allows the config system to support translation overrides for namespaces that\n * do not correspond to modules.\n *\n * This should only be used in esm-app-shell.\n *\n * @internal\n * @param namespace\n */ export function registerTranslationNamespace(namespace) {\n    configInternalStore.setState((state)=>({\n            ...state,\n            schemas: {\n                ...state.schemas,\n                [namespace]: translationOverridesSchema\n            }\n        }));\n}\n/**\n * This defines a configuration schema for an extension. When a schema is defined\n * for an extension, that extension will receive the configuration corresponding\n * to that schema, rather than the configuration corresponding to the module\n * in which it is defined.\n *\n * The schema tells the configuration system how the module can be configured.\n * It specifies what makes configuration valid or invalid.\n *\n * See [Configuration System](https://o3-docs.openmrs.org/docs/configuration-system)\n * for more information about defining a config schema.\n *\n * @param extensionName Name of the extension the schema is being defined for.\n *   Should match the `name` of one of the `extensions` entries defined in\n *   the app's `routes.json` file.\n * @param schema The config schema for the extension\n */ export function defineExtensionConfigSchema(extensionName, schema) {\n    validateConfigSchema(extensionName, schema);\n    const enhancedSchema = mergeDeepRight(schema, implicitConfigSchema);\n    const state = configInternalStore.getState();\n    if (state.schemas[extensionName]) {\n        console.error(`Config schema for extension ${extensionName} already exists. If there are multiple extensions with this same name, one will probably crash.`);\n    }\n    configInternalStore.setState((state)=>({\n            ...state,\n            schemas: {\n                ...state.schemas,\n                [extensionName]: enhancedSchema\n            }\n        }));\n}\nexport function provide(config, sourceName = 'provided') {\n    configInternalStore.setState((state)=>({\n            ...state,\n            providedConfigs: [\n                ...state.providedConfigs,\n                {\n                    source: sourceName,\n                    config\n                }\n            ]\n        }));\n}\n/**\n * A promise-based way to access the config as soon as it is fully loaded.\n * If it is already loaded, resolves the config in its present state.\n *\n * This is a useful function if you need to get the config in the course\n * of the execution of a function.\n *\n * @param moduleName The name of the module for which to look up the config\n */ export function getConfig(moduleName) {\n    return new Promise((resolve)=>{\n        const store = getConfigStore(moduleName);\n        function update(state) {\n            if (state.loaded && state.config) {\n                const config = omit([\n                    'Display conditions',\n                    'Translation overrides'\n                ], state.config);\n                resolve(config);\n                if (unsubscribe) {\n                    unsubscribe();\n                }\n            }\n        }\n        update(store.getState());\n        const unsubscribe = store.subscribe(update);\n    });\n}\n/** @internal */ export function getTranslationOverrides(moduleName, slotName, extensionId) {\n    const promises = [\n        new Promise((resolve)=>{\n            const configStore = getConfigStore(moduleName);\n            function update(state) {\n                if (state.translationOverridesLoaded && state.config) {\n                    const translationOverrides = state.config['Translation overrides'] ?? {};\n                    resolve(translationOverrides);\n                    if (unsubscribe) {\n                        unsubscribe();\n                    }\n                }\n            }\n            update(configStore.getState());\n            const unsubscribe = configStore.subscribe(update);\n        })\n    ];\n    if (slotName && extensionId) {\n        promises.push(new Promise((resolve)=>{\n            const configStore = getExtensionConfig(slotName, extensionId);\n            function update(state) {\n                if (state.loaded && state.config) {\n                    const translationOverrides = state.config['Translation overrides'] ?? {};\n                    resolve(translationOverrides);\n                    if (unsubscribe) {\n                        unsubscribe();\n                    }\n                }\n            }\n            update(configStore.getState());\n            const unsubscribe = configStore.subscribe(update);\n        }));\n    }\n    return Promise.all(promises);\n}\n/**\n * Validate and interpolate defaults for `providedConfig` according to `schema`\n *\n * @param schema  a configuration schema\n * @param providedConfig  an object of config values (without the top-level module name)\n * @param keyPathContext  a dot-deparated string which helps the user figure out where\n *     the provided config came from\n * @internal\n */ export function processConfig(schema, providedConfig, keyPathContext) {\n    validateStructure(schema, providedConfig, keyPathContext);\n    const config = setDefaults(schema, providedConfig);\n    runAllValidatorsInConfigTree(schema, config, keyPathContext);\n    return config;\n}\n/*\n * Helper functions\n *\n */ /**\n * Returns the configuration for an extension. This configuration is specific\n * to the slot in which it is mounted, and its ID within that slot.\n *\n * The schema for that configuration is the extension schema. If no extension\n * schema has been provided, the schema used is the schema of the module in\n * which the extension is defined.\n *\n * @param slotModuleName The name of the module which defines the extension slot\n * @param extensionModuleName The name of the module which defines the extension (and therefore the config schema)\n * @param slotName The name of the extension slot where the extension is mounted\n * @param extensionId The ID of the extension in its slot\n */ function computeExtensionConfig(slotModuleName, extensionModuleName, slotName, extensionId, configState, tempConfigState) {\n    const extensionName = getExtensionNameFromId(extensionId);\n    const extensionConfigSchema = configState.schemas[extensionName];\n    const nameOfSchemaSource = extensionConfigSchema ? extensionName : extensionModuleName;\n    const providedConfigs = getProvidedConfigs(configState, tempConfigState);\n    const slotModuleConfig = mergeConfigsFor(slotModuleName, providedConfigs);\n    const configOverride = slotModuleConfig?.extensionSlots?.[slotName]?.configure?.[extensionId] ?? {};\n    const extensionConfig = mergeConfigsFor(nameOfSchemaSource, providedConfigs);\n    const combinedConfig = mergeConfigs([\n        extensionConfig,\n        configOverride\n    ]);\n    const schema = extensionConfigSchema ?? configState.schemas[extensionModuleName];\n    validateStructure(schema, combinedConfig, nameOfSchemaSource);\n    const config = setDefaults(schema, combinedConfig);\n    runAllValidatorsInConfigTree(schema, config, nameOfSchemaSource);\n    delete config.extensionSlots;\n    return config;\n}\nfunction getImplementerToolsConfig(configState, tempConfigState) {\n    let result = getSchemaWithValuesAndSources(clone(configState.schemas));\n    const configsAndSources = [\n        ...configState.providedConfigs.map((c)=>[\n                c.config,\n                c.source\n            ]),\n        [\n            tempConfigState.config,\n            'temporary config'\n        ]\n    ];\n    for (let [config, source] of configsAndSources){\n        result = mergeConfigs([\n            result,\n            createValuesAndSourcesTree(config, source)\n        ]);\n    }\n    return result;\n}\nfunction getSchemaWithValuesAndSources(schema) {\n    if (schema.hasOwnProperty('_default')) {\n        return {\n            ...schema,\n            _value: schema._default,\n            _source: 'default'\n        };\n    } else if (isOrdinaryObject(schema)) {\n        return Object.keys(schema).reduce((obj, key)=>{\n            obj[key] = getSchemaWithValuesAndSources(schema[key]);\n            return obj;\n        }, {});\n    } else {\n        // at this point, the schema is bad and an error will have been logged during schema validation\n        return {};\n    }\n}\nfunction createValuesAndSourcesTree(config, source) {\n    if (isOrdinaryObject(config)) {\n        return Object.keys(config).reduce((obj, key)=>{\n            obj[key] = createValuesAndSourcesTree(config[key], source);\n            return obj;\n        }, {});\n    } else {\n        return {\n            _value: config,\n            _source: source\n        };\n    }\n}\nfunction getExtensionSlotConfigs(configState, tempConfigState) {\n    const allConfigs = mergeConfigs(getProvidedConfigs(configState, tempConfigState));\n    const slotConfigPerModule = Object.keys(allConfigs).reduce((obj, key)=>{\n        if (allConfigs[key]?.extensionSlots) {\n            obj[key] = allConfigs[key]?.extensionSlots;\n        }\n        return obj;\n    }, {});\n    validateAllExtensionSlotConfigs(slotConfigPerModule);\n    const slotConfigs = Object.keys(slotConfigPerModule).reduce((obj, key)=>{\n        obj = {\n            ...obj,\n            ...slotConfigPerModule[key]\n        };\n        return obj;\n    }, {});\n    return slotConfigs;\n}\nfunction validateAllExtensionSlotConfigs(slotConfigPerModule) {\n    for (let [moduleName, configBySlotName] of Object.entries(slotConfigPerModule)){\n        for (let [slotName, config] of Object.entries(configBySlotName)){\n            validateExtensionSlotConfig(config, moduleName, slotName);\n        }\n    }\n}\nfunction validateExtensionSlotConfig(config, moduleName, slotName) {\n    const keyPath = `${moduleName}.extensionSlots.${slotName}`;\n    const errorPrefix = `Extension slot config '${keyPath}'`;\n    const invalidKeys = Object.keys(config).filter((k)=>![\n            'add',\n            'remove',\n            'order',\n            'configure'\n        ].includes(k));\n    if (invalidKeys.length) {\n        logError(keyPath, errorPrefix + `' contains invalid keys '${invalidKeys.join(\"', '\")}'`);\n    }\n    if (config.add) {\n        if (!Array.isArray(config.add) || !config.add.every((n)=>typeof n === 'string')) {\n            logError(keyPath, errorPrefix + `.add' is invalid. Must be an array of strings (extension IDs)`);\n        }\n    }\n    if (config.remove) {\n        if (!Array.isArray(config.remove) || !config.remove.every((n)=>typeof n === 'string')) {\n            logError(keyPath, errorPrefix + `.remove' is invalid. Must be an array of strings (extension IDs)`);\n        }\n    }\n    if (config.order) {\n        if (!Array.isArray(config.order) || !config.order.every((n)=>typeof n === 'string')) {\n            logError(keyPath, errorPrefix + `.order' is invalid. Must be an array of strings (extension IDs)`);\n        }\n    }\n    if (config.configure) {\n        if (!isOrdinaryObject(config.configure)) {\n            logError(keyPath, errorPrefix + `.configure' is invalid. Must be an object with extension IDs for keys`);\n        }\n    }\n}\nfunction getProvidedConfigs(configState, tempConfigState) {\n    return [\n        ...configState.providedConfigs.map((c)=>c.config),\n        tempConfigState.config\n    ];\n}\n/**\n * Validates the config schema for a module. Since problems identified here are programming errors\n * that hopefully will be caught during development, this function logs errors to the console directly;\n * it's fine if we spam the user with these errors.\n */ function validateConfigSchema(moduleName, schema, keyPath = '') {\n    const updateMessage = `Please verify that you are running the latest version and, if so, alert the maintainer.`;\n    for (const key of Object.keys(schema).filter((k)=>!k.startsWith('_'))){\n        const thisKeyPath = keyPath + (keyPath && '.') + key;\n        const schemaPart = schema[key];\n        if (thisKeyPath === 'Display conditions') {\n            console.error(`${moduleName} declares a configuration option called \"Display conditions\"; the \"Display conditions\" option is a reserved name. ${updateMessage}`);\n        }\n        if (thisKeyPath === 'Translation overrides') {\n            console.error(`${moduleName} declares a configuration option called \"Translation overrides\"; the \"Translation overrides\" option is a reserved name. ${updateMessage}`);\n        }\n        if (!isOrdinaryObject(schemaPart)) {\n            console.error(`${moduleName} has bad config schema definition for key '${thisKeyPath}'. ${updateMessage}`);\n            continue;\n        }\n        if (!schemaPart.hasOwnProperty('_default')) {\n            // recurse for nested config keys\n            validateConfigSchema(moduleName, schemaPart, thisKeyPath);\n        }\n        const elements = schemaPart._elements;\n        if (hasObjectSchema(elements)) {\n            validateConfigSchema(moduleName, elements, thisKeyPath + '._elements');\n        }\n        if (schemaPart._validators) {\n            for (let validator of schemaPart._validators){\n                if (typeof validator !== 'function') {\n                    console.error(`${moduleName} has invalid validator for key '${thisKeyPath}' ${updateMessage}.` + `\\n\\nIf you're the maintainer: validators must be functions that return either ` + `undefined or an error string. Received ${validator}.`);\n                }\n            }\n        }\n        const valueType = schemaPart._type;\n        if (valueType && !Object.values(Type).includes(valueType)) {\n            console.error(`${moduleName} has invalid type for key '${thisKeyPath}' ${updateMessage}.` + `\\n\\nIf you're the maintainer: the allowed types are ${Object.values(Type).join(', ')}. ` + `Received '${valueType}'`);\n        }\n        if (Object.keys(schemaPart).every((k)=>[\n                '_description',\n                '_validators',\n                '_elements',\n                '_type'\n            ].includes(k)) && !keyPath.includes('._elements')) {\n            console.error(`${moduleName} has bad config schema definition for key '${thisKeyPath}'. ${updateMessage}.` + `\\n\\nIf you're the maintainer: all config elements must have a default. ` + `Received ${JSON.stringify(schemaPart)}`);\n        }\n        if (elements && valueType && ![\n            Type.Array,\n            Type.Object\n        ].includes(valueType)) {\n            console.error(`${moduleName} has bad config schema definition for key '${thisKeyPath}'. ${updateMessage}.` + `\\n\\nIf you're the maintainer: the 'elements' key only works with '_type' equal to 'Array' or 'Object'. ` + `Received ${JSON.stringify(valueType)}`);\n        }\n    }\n}\nfunction getConfigForModule(moduleName, configState, tempConfigState) {\n    const schema = configState.schemas[moduleName];\n    const inputConfig = mergeConfigsFor(moduleName, getProvidedConfigs(configState, tempConfigState));\n    validateStructure(schema, inputConfig, moduleName);\n    const config = setDefaults(schema, inputConfig);\n    runAllValidatorsInConfigTree(schema, config, moduleName);\n    delete config.extensionSlots;\n    return config;\n}\nfunction getConfigForModuleImplicitSchema(moduleName, configState, tempConfigState) {\n    const inputConfig = mergeConfigsFor(moduleName, getProvidedConfigs(configState, tempConfigState));\n    const config = setDefaults(implicitConfigSchema, inputConfig);\n    runAllValidatorsInConfigTree(implicitConfigSchema, config, moduleName);\n    delete config.extensionSlots;\n    return config;\n}\nfunction mergeConfigsFor(moduleName, allConfigs) {\n    const allConfigsForModule = allConfigs.map(({ [moduleName]: c })=>c).filter((c)=>!!c);\n    return mergeConfigs(allConfigsForModule);\n}\nfunction mergeConfigs(configs) {\n    const mergeDeepAll = reduce(mergeDeepRight);\n    return mergeDeepAll({}, configs);\n}\n/**\n * Recursively check the provided config tree to make sure that all\n * of the provided properties exist in the schema, and that types are\n * correct. Does not run validators yet, since those will be run on\n * the config with the defaults filled in.\n */ function validateStructure(schema, config, keyPath = '') {\n    // validate each constituent element\n    for (const key of Object.keys(config)){\n        const value = config[key];\n        const thisKeyPath = keyPath + '.' + key;\n        const schemaPart = schema[key];\n        if (!schema.hasOwnProperty(key)) {\n            if (!(key === 'extensionSlots' && keyPath !== '')) {\n                logError(thisKeyPath, `Unknown config key '${thisKeyPath}' provided. Ignoring.`);\n            }\n            continue;\n        }\n        validateBranchStructure(schemaPart, value, thisKeyPath);\n    }\n}\nfunction validateBranchStructure(schemaPart, value, keyPath) {\n    checkType(keyPath, schemaPart._type, value);\n    if (isOrdinaryObject(value)) {\n        if (schemaPart._type === Type.Object) {\n            // validate as freeform object\n            validateFreeformObjectStructure(schemaPart, value, keyPath);\n        } else if (!(schemaPart.hasOwnProperty('_default') || schemaPart.hasOwnProperty('_type'))) {\n            // validate as normal nested config\n            validateStructure(schemaPart, value, keyPath);\n        }\n    } else {\n        if (schemaPart._type === Type.Array) {\n            validateArrayStructure(schemaPart, value, keyPath);\n        }\n    }\n}\nfunction validateFreeformObjectStructure(freeformObjectSchema, config, keyPath) {\n    if (freeformObjectSchema._elements) {\n        for (const key of Object.keys(config)){\n            const value = config[key];\n            validateBranchStructure(freeformObjectSchema._elements, value, `${keyPath}.${key}`);\n        }\n    }\n}\nfunction validateArrayStructure(arraySchema, value, keyPath) {\n    const validatedAsArray = checkType(keyPath, Type.Array, value);\n    if (!validatedAsArray) {\n        return;\n    }\n    // if there is an array element object schema, verify that elements match it\n    if (hasObjectSchema(arraySchema._elements)) {\n        for(let i = 0; i < value.length; i++){\n            validateBranchStructure(arraySchema._elements, value[i], `${keyPath}[${i}]`);\n        }\n    }\n    for(let i = 0; i < value.length; i++){\n        checkType(`${keyPath}[${i}]`, arraySchema._elements?._type, value[i]);\n    }\n}\n/**\n * Run all the validators in the config tree. This should be run\n * on the config object after it has been filled in with all the defaults, since\n * higher-level validators may refer to default values.\n */ function runAllValidatorsInConfigTree(schema, config, keyPath = '') {\n    // If `!schema`, there should have been a structural validation error printed already.\n    if (schema) {\n        if (config !== schema._default) {\n            runValidators(keyPath, schema._validators, config);\n        }\n        if (isOrdinaryObject(config)) {\n            for (const key of Object.keys(config)){\n                const value = config[key];\n                const thisKeyPath = keyPath + '.' + key;\n                const schemaPart = schema[key];\n                if (schema._type === Type.Object && schema._elements) {\n                    runAllValidatorsInConfigTree(schema._elements, value, thisKeyPath);\n                } else {\n                    runAllValidatorsInConfigTree(schemaPart, value, thisKeyPath);\n                }\n            }\n        } else if (Array.isArray(config) && schema._elements) {\n            for(let i = 0; i < config.length; i++){\n                runAllValidatorsInConfigTree(schema._elements, config[i], `${keyPath}[${i}]`);\n            }\n        }\n    }\n}\n/**\n * Run type validation for the value, logging any errors.\n * @returns true if validation passes, false otherwise\n */ function checkType(keyPath, _type, value) {\n    if (_type) {\n        // eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\n        const validator = {\n            Array: isArray,\n            Boolean: isBoolean,\n            ConceptUuid: isUuid,\n            Number: isNumber,\n            Object: isObject,\n            String: isString,\n            UUID: isUuid,\n            PersonAttributeTypeUuid: isUuid,\n            PatientIdentifierTypeUuid: isUuid\n        };\n        return runValidators(keyPath, [\n            validator[_type]\n        ], value);\n    }\n    return true;\n}\n/**\n * Runs validators, logging errors.\n * @returns true if all pass, false otherwise.\n */ // eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\nfunction runValidators(keyPath, validators, value) {\n    let returnValue = true;\n    if (validators) {\n        try {\n            for (let validator of validators){\n                const validatorResult = validator(value);\n                if (typeof validatorResult === 'string') {\n                    const message = typeof value === 'object' ? `Invalid configuration for ${keyPath}: ${validatorResult}` : `Invalid configuration value ${value} for ${keyPath}: ${validatorResult}`;\n                    logError(keyPath, message);\n                    returnValue = false;\n                }\n            }\n        } catch (e) {\n            console.error(`Skipping invalid validator at \"${keyPath}\". Encountered error\\n\\t${e}`);\n        }\n    }\n    return returnValue;\n}\n// Recursively fill in the config with values from the schema.\nconst setDefaults = (schema, inputConfig)=>{\n    const config = clone(inputConfig);\n    if (!schema) {\n        return config;\n    }\n    for (const key of Object.keys(schema)){\n        const configPart = config[key];\n        const schemaPart = schema[key];\n        // The `schemaPart &&` clause of this `if` statement will only fail\n        // if the schema is very invalid. It is there to prevent the app from\n        // crashing completely, though it will produce unexpected behavior.\n        // If this happens, there should be legible errors in the console from\n        // the schema validator.\n        if (schemaPart && (schemaPart.hasOwnProperty('_type') || schemaPart.hasOwnProperty('_default'))) {\n            // We assume that schemaPart defines a config value, since it has\n            // a property `_type` or `_default`.\n            if (!config.hasOwnProperty(key)) {\n                config[key] = schemaPart['_default'];\n            }\n            // We also check if it is an object or array with object elements, in which case we recurse\n            const elements = schemaPart._elements;\n            if (configPart && hasObjectSchema(elements)) {\n                if (schemaPart._type === Type.Array && Array.isArray(configPart)) {\n                    const configWithDefaults = configPart.map((conf)=>setDefaults(elements, conf));\n                    config[key] = configWithDefaults;\n                } else if (schemaPart._type === Type.Object) {\n                    for (let objectKey of Object.keys(configPart)){\n                        configPart[objectKey] = setDefaults(elements, configPart[objectKey]);\n                    }\n                }\n            }\n        } else if (isOrdinaryObject(schemaPart)) {\n            // Since schemaPart has no property \"_type\", if it's an ordinary object\n            // (unlike, importantly, the validators array), we assume it is a parent config property.\n            // We recurse to config[key] and schema[key]. Default config[key] to {}.\n            const selectedConfigPart = configPart ?? {};\n            // There will have been a validation error already if configPart is not a plain object.\n            if (isOrdinaryObject(selectedConfigPart)) {\n                config[key] = setDefaults(schemaPart, selectedConfigPart);\n            }\n        }\n    }\n    return config;\n};\nfunction hasObjectSchema(elementsSchema) {\n    return !!elementsSchema && Object.keys(elementsSchema).filter((e)=>![\n            '_default',\n            '_validators'\n        ].includes(e)).length > 0;\n}\nfunction isOrdinaryObject(value) {\n    return typeof value === 'object' && !Array.isArray(value) && value !== null;\n}\n/** Keep track of which validation errors we have displayed. Each one should only be displayed once. */ let displayedValidationMessages = new Set();\nfunction logError(keyPath, message) {\n    const key = `${keyPath}:::${message}`;\n    // technically, this should not be possible, but because of how things wind-up transpiled, this isn't impossible\n    if (!displayedValidationMessages) {\n        displayedValidationMessages = new Set();\n    }\n    if (!displayedValidationMessages.has(key)) {\n        console.error(message);\n        displayedValidationMessages.add(key);\n    }\n}\n/**\n * Normally, configuration errors are only displayed once. This function clears the list of\n * displayed errors, so that they will be displayed again.\n *\n * @internal\n */ export function clearConfigErrors(keyPath) {\n    if (keyPath) {\n        displayedValidationMessages.forEach((key)=>{\n            if (key.startsWith(keyPath)) {\n                displayedValidationMessages.delete(key);\n            }\n        });\n    } else {\n        displayedValidationMessages.clear();\n    }\n}\n/**\n * Cleans up all config store subscriptions and re-establishes them. This is primarily\n * useful for testing, where subscriptions set up at module load time need to be cleared\n * between tests to prevent infinite update loops. After clearing, subscriptions are\n * re-established so the config system continues to work normally.\n *\n * @internal\n */ export function resetConfigSystem() {\n    configSubscriptions.forEach((unsubscribe)=>unsubscribe());\n    configSubscriptions.length = 0;\n    setupConfigSubscriptions();\n}\n/**\n * Copied over from esm-extensions. It rightly belongs to that module, but esm-config\n * cannot depend on esm-extensions.\n */ function getExtensionNameFromId(extensionId) {\n    const [extensionName] = extensionId.split('#');\n    return extensionName;\n}\n/**\n * The translation overrides schema is used in the implicit schema given to every module;\n * plus any additional translation namespaces (at time of writing, this is just 'core').\n */ const translationOverridesSchema = {\n    'Translation overrides': {\n        _description: 'Per-language overrides for frontend translations should be keyed by language code and each language dictionary contains the translation key and the display value',\n        _type: Type.Object,\n        _default: {},\n        _validators: [\n            validator((o)=>Object.keys(o).every((k)=>/^[a-z]{2,3}(-[A-Z]{2,3})?$/.test(k)), (o)=>{\n                const badKeys = Object.keys(o).filter((k)=>!/^[a-z]{2,3}(-[A-Z]{2,3})?$/.test(k));\n                return `The 'Translation overrides' object should have language codes for keys. Language codes must be in the form of a two-to-three letter language code optionally followed by a hyphen and a two-to-three letter country code. The following keys do not conform: ${badKeys.join(', ')}.`;\n            })\n        ]\n    }\n};\n/**\n * The implicitConfigSchema is implicitly included in every configuration schema\n */ const implicitConfigSchema = {\n    'Display conditions': {\n        privileges: {\n            _description: 'The privilege(s) the user must have to use this extension',\n            _type: Type.Array,\n            _default: []\n        },\n        expression: {\n            _description: 'The expression that determines whether the extension is displayed',\n            _type: Type.String,\n            _default: undefined\n        }\n    },\n    ...translationOverridesSchema\n};\n"],"names":["clone","equals","reduce","mergeDeepRight","omit","Type","isArray","isBoolean","isUuid","isNumber","isObject","isString","validator","configExtensionStore","configInternalStore","getConfigStore","getExtensionConfig","getExtensionSlotsConfigStore","getExtensionsConfigStore","implementerToolsConfigStore","temporaryConfigStore","configSubscriptions","recomputeAllConfigs","configState","getState","tempConfigState","extensionState","computeModuleConfig","computeImplementerToolsConfig","computeExtensionSlotConfigs","computeExtensionConfigs","setupConfigSubscriptions","push","subscribe","state","tempState","moduleName","Object","keys","schemas","moduleStore","newState","moduleLoaded","config","getConfigForModule","translationOverridesLoaded","loaded","getConfigForModuleImplicitSchema","setState","slotConfigs","getExtensionSlotConfigs","newSlotStoreEntries","fromEntries","entries","map","slotName","slotStore","oldState","slots","getImplementerToolsConfig","configs","extension","mountedExtensions","computeExtensionConfig","slotModuleName","extensionModuleName","extensionId","extensionsConfigStore","defineConfigSchema","schema","validateConfigSchema","enhancedSchema","implicitConfigSchema","registerModuleWithConfigSystem","registerModuleLoad","registerTranslationNamespace","namespace","translationOverridesSchema","defineExtensionConfigSchema","extensionName","console","error","provide","sourceName","providedConfigs","source","getConfig","Promise","resolve","store","update","unsubscribe","getTranslationOverrides","promises","configStore","translationOverrides","all","processConfig","providedConfig","keyPathContext","validateStructure","setDefaults","runAllValidatorsInConfigTree","getExtensionNameFromId","extensionConfigSchema","nameOfSchemaSource","getProvidedConfigs","slotModuleConfig","mergeConfigsFor","configOverride","extensionSlots","configure","extensionConfig","combinedConfig","mergeConfigs","result","getSchemaWithValuesAndSources","configsAndSources","c","createValuesAndSourcesTree","hasOwnProperty","_value","_default","_source","isOrdinaryObject","obj","key","allConfigs","slotConfigPerModule","validateAllExtensionSlotConfigs","configBySlotName","validateExtensionSlotConfig","keyPath","errorPrefix","invalidKeys","filter","k","includes","length","logError","join","add","Array","every","n","remove","order","updateMessage","startsWith","thisKeyPath","schemaPart","elements","_elements","hasObjectSchema","_validators","valueType","_type","values","JSON","stringify","inputConfig","allConfigsForModule","mergeDeepAll","value","validateBranchStructure","checkType","validateFreeformObjectStructure","validateArrayStructure","freeformObjectSchema","arraySchema","validatedAsArray","i","runValidators","Boolean","ConceptUuid","Number","String","UUID","PersonAttributeTypeUuid","PatientIdentifierTypeUuid","validators","returnValue","validatorResult","message","e","configPart","configWithDefaults","conf","objectKey","selectedConfigPart","elementsSchema","displayedValidationMessages","Set","has","clearConfigErrors","forEach","delete","clear","resetConfigSystem","split","_description","o","test","badKeys","privileges","expression","undefined"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-config/dist/module-config/module-config.js\n");
158
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ clearConfigErrors: () => (/* binding */ clearConfigErrors),\n/* harmony export */ defineConfigSchema: () => (/* binding */ defineConfigSchema),\n/* harmony export */ defineExtensionConfigSchema: () => (/* binding */ defineExtensionConfigSchema),\n/* harmony export */ getConfig: () => (/* binding */ getConfig),\n/* harmony export */ getTranslationOverrides: () => (/* binding */ getTranslationOverrides),\n/* harmony export */ processConfig: () => (/* binding */ processConfig),\n/* harmony export */ provide: () => (/* binding */ provide),\n/* harmony export */ registerModuleLoad: () => (/* binding */ registerModuleLoad),\n/* harmony export */ registerModuleWithConfigSystem: () => (/* binding */ registerModuleWithConfigSystem),\n/* harmony export */ registerTranslationNamespace: () => (/* binding */ registerTranslationNamespace),\n/* harmony export */ resetConfigSystem: () => (/* binding */ resetConfigSystem)\n/* harmony export */ });\n/* harmony import */ var ramda__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ramda */ \"../../../node_modules/ramda/es/equals.js\");\n/* harmony import */ var ramda__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ramda */ \"../../../node_modules/ramda/es/mergeDeepRight.js\");\n/* harmony import */ var ramda__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ramda */ \"../../../node_modules/ramda/es/omit.js\");\n/* harmony import */ var ramda__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ramda */ \"../../../node_modules/ramda/es/clone.js\");\n/* harmony import */ var ramda__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ramda */ \"../../../node_modules/ramda/es/reduce.js\");\n/* harmony import */ var _types_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../types.js */ \"../../framework/esm-config/dist/types.js\");\n/* harmony import */ var _validators_type_validators_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../validators/type-validators.js */ \"../../framework/esm-config/dist/validators/type-validators.js\");\n/* harmony import */ var _validators_validator_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../validators/validator.js */ \"../../framework/esm-config/dist/validators/validator.js\");\n/* harmony import */ var _state_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./state.js */ \"../../framework/esm-config/dist/module-config/state.js\");\n/** @module @category Config */ \n\n\n\n\n/**\n * Store setup\n *\n *\n * Set up stores and subscriptions so that inputs get processed appropriately.\n *\n * There are *input* stores and *output* stores. The *input* stores\n * are configInternalStore, temporaryConfigStore, and configExtensionStore. The\n * output stores are set in the `compute...` functions. They are the module\n * config stores, the extension slot config stores (by module), the extension\n * config stores, and the implementer tools config store.\n *\n * This code sets up the subscriptions so that when an input store changes,\n * the correct set of output stores are updated.\n *\n * All `compute...` functions except `computeExtensionConfigs` are pure\n * (or are supposed to be), other than the fact that they all `setState`\n * store values at the end. `computeExtensionConfigs` calls `getGlobalStore`,\n * which creates stores.\n */ // Store unsubscribe functions to allow cleanup (e.g., in tests or hot module reloading)\nconst configSubscriptions = [];\n/**\n * Recomputes all configuration derived stores based on current state of input stores.\n * Called whenever any input store (configInternalStore, temporaryConfigStore, configExtensionStore) changes.\n */ function recomputeAllConfigs() {\n const configState = _state_js__WEBPACK_IMPORTED_MODULE_3__.configInternalStore.getState();\n const tempConfigState = _state_js__WEBPACK_IMPORTED_MODULE_3__.temporaryConfigStore.getState();\n const extensionState = _state_js__WEBPACK_IMPORTED_MODULE_3__.configExtensionStore.getState();\n computeModuleConfig(configState, tempConfigState);\n computeImplementerToolsConfig(configState, tempConfigState);\n computeExtensionSlotConfigs(configState, tempConfigState);\n computeExtensionConfigs(configState, extensionState, tempConfigState);\n}\nfunction setupConfigSubscriptions() {\n // Initial computation\n recomputeAllConfigs();\n // Subscribe to all input stores with a single handler\n // This ensures we only recompute once even if multiple stores change simultaneously\n configSubscriptions.push(_state_js__WEBPACK_IMPORTED_MODULE_3__.configInternalStore.subscribe(recomputeAllConfigs));\n configSubscriptions.push(_state_js__WEBPACK_IMPORTED_MODULE_3__.temporaryConfigStore.subscribe(recomputeAllConfigs));\n configSubscriptions.push(_state_js__WEBPACK_IMPORTED_MODULE_3__.configExtensionStore.subscribe(recomputeAllConfigs));\n}\n// Set up subscriptions at module load time\nsetupConfigSubscriptions();\nfunction computeModuleConfig(state, tempState) {\n for (let moduleName of Object.keys(state.schemas)){\n // At this point the schema could be either just the implicit schema or the actually\n // defined schema. We run with just the implicit schema because we want to populate\n // the config store with the translation overrides as soon as possible. In fact, the\n // translation system will throw for Suspense until the translation overrides are\n // available, which as of this writing blocks the schema definition from occurring\n // for modules loaded based on their extensions.\n const moduleStore = (0,_state_js__WEBPACK_IMPORTED_MODULE_3__.getConfigStore)(moduleName);\n let newState;\n if (state.moduleLoaded[moduleName]) {\n const config = getConfigForModule(moduleName, state, tempState);\n newState = {\n translationOverridesLoaded: true,\n loaded: true,\n config\n };\n } else {\n const config = getConfigForModuleImplicitSchema(moduleName, state, tempState);\n newState = {\n translationOverridesLoaded: true,\n loaded: false,\n config\n };\n }\n moduleStore.setState(newState);\n }\n}\nfunction computeExtensionSlotConfigs(state, tempState) {\n const slotConfigs = getExtensionSlotConfigs(state, tempState);\n const newSlotStoreEntries = Object.fromEntries(Object.entries(slotConfigs).map(([slotName, config])=>[\n slotName,\n {\n loaded: true,\n config\n }\n ]));\n const slotStore = (0,_state_js__WEBPACK_IMPORTED_MODULE_3__.getExtensionSlotsConfigStore)();\n const oldState = slotStore.getState();\n const newState = {\n slots: {\n ...oldState.slots,\n ...newSlotStoreEntries\n }\n };\n if (!(0,ramda__WEBPACK_IMPORTED_MODULE_4__[\"default\"])(oldState.slots, newState.slots)) {\n slotStore.setState(newState);\n }\n}\nfunction computeImplementerToolsConfig(state, tempConfigState) {\n const oldState = _state_js__WEBPACK_IMPORTED_MODULE_3__.implementerToolsConfigStore.getState();\n const config = getImplementerToolsConfig(state, tempConfigState);\n const newState = {\n config\n };\n // Use deep equality on the actual config content, not the wrapper object\n if (!(0,ramda__WEBPACK_IMPORTED_MODULE_4__[\"default\"])(oldState.config, newState.config)) {\n _state_js__WEBPACK_IMPORTED_MODULE_3__.implementerToolsConfigStore.setState(newState);\n }\n}\nfunction computeExtensionConfigs(configState, extensionState, tempConfigState) {\n const configs = {};\n // We assume that the module schema has already been defined, since the extension\n // it contains is mounted.\n for (let extension of extensionState.mountedExtensions){\n const config = computeExtensionConfig(extension.slotModuleName, extension.extensionModuleName, extension.slotName, extension.extensionId, configState, tempConfigState);\n if (!configs[extension.slotName]) {\n configs[extension.slotName] = {};\n }\n configs[extension.slotName][extension.extensionId] = {\n config,\n loaded: true\n };\n }\n const extensionsConfigStore = (0,_state_js__WEBPACK_IMPORTED_MODULE_3__.getExtensionsConfigStore)();\n const oldState = extensionsConfigStore.getState();\n const newState = {\n configs\n };\n // Use deep equality to only update if configs actually changed\n if (!(0,ramda__WEBPACK_IMPORTED_MODULE_4__[\"default\"])(oldState.configs, newState.configs)) {\n extensionsConfigStore.setState(newState);\n }\n}\n/*\n * API\n *\n */ /**\n * This defines a configuration schema for a module. The schema tells the\n * configuration system how the module can be configured. It specifies\n * what makes configuration valid or invalid.\n *\n * See [Configuration System](https://o3-docs.openmrs.org/docs/configuration-system)\n * for more information about defining a config schema.\n *\n * @param moduleName Name of the module the schema is being defined for. Generally\n * should be the one in which the `defineConfigSchema` call takes place.\n * @param schema The config schema for the module\n */ function defineConfigSchema(moduleName, schema) {\n validateConfigSchema(moduleName, schema);\n const enhancedSchema = (0,ramda__WEBPACK_IMPORTED_MODULE_5__[\"default\"])(schema, implicitConfigSchema);\n _state_js__WEBPACK_IMPORTED_MODULE_3__.configInternalStore.setState((state)=>({\n ...state,\n schemas: {\n ...state.schemas,\n [moduleName]: enhancedSchema\n },\n moduleLoaded: {\n ...state.moduleLoaded,\n [moduleName]: true\n }\n }));\n}\n/**\n * This alerts the configuration system that a module exists. This allows config to be\n * processed, while still allowing the extension system to know whether the module has\n * actually had its front bundle executed yet.\n *\n * This should only be used in esm-app-shell.\n *\n * @internal\n * @param moduleName\n */ function registerModuleWithConfigSystem(moduleName) {\n _state_js__WEBPACK_IMPORTED_MODULE_3__.configInternalStore.setState((state)=>({\n ...state,\n schemas: {\n ...state.schemas,\n [moduleName]: implicitConfigSchema\n }\n }));\n}\n/**\n * This alerts the configuration system that a module has been loaded.\n *\n * This should only be used in esm-app-shell.\n *\n * @internal\n * @param moduleName\n */ function registerModuleLoad(moduleName) {\n _state_js__WEBPACK_IMPORTED_MODULE_3__.configInternalStore.setState((state)=>({\n ...state,\n moduleLoaded: {\n ...state.moduleLoaded,\n [moduleName]: true\n }\n }));\n}\n/**\n * This allows the config system to support translation overrides for namespaces that\n * do not correspond to modules.\n *\n * This should only be used in esm-app-shell.\n *\n * @internal\n * @param namespace\n */ function registerTranslationNamespace(namespace) {\n _state_js__WEBPACK_IMPORTED_MODULE_3__.configInternalStore.setState((state)=>({\n ...state,\n schemas: {\n ...state.schemas,\n [namespace]: translationOverridesSchema\n }\n }));\n}\n/**\n * This defines a configuration schema for an extension. When a schema is defined\n * for an extension, that extension will receive the configuration corresponding\n * to that schema, rather than the configuration corresponding to the module\n * in which it is defined.\n *\n * The schema tells the configuration system how the module can be configured.\n * It specifies what makes configuration valid or invalid.\n *\n * See [Configuration System](https://o3-docs.openmrs.org/docs/configuration-system)\n * for more information about defining a config schema.\n *\n * @param extensionName Name of the extension the schema is being defined for.\n * Should match the `name` of one of the `extensions` entries defined in\n * the app's `routes.json` file.\n * @param schema The config schema for the extension\n */ function defineExtensionConfigSchema(extensionName, schema) {\n validateConfigSchema(extensionName, schema);\n const enhancedSchema = (0,ramda__WEBPACK_IMPORTED_MODULE_5__[\"default\"])(schema, implicitConfigSchema);\n const state = _state_js__WEBPACK_IMPORTED_MODULE_3__.configInternalStore.getState();\n if (state.schemas[extensionName]) {\n console.error(`Config schema for extension ${extensionName} already exists. If there are multiple extensions with this same name, one will probably crash.`);\n }\n _state_js__WEBPACK_IMPORTED_MODULE_3__.configInternalStore.setState((state)=>({\n ...state,\n schemas: {\n ...state.schemas,\n [extensionName]: enhancedSchema\n }\n }));\n}\n/**\n * Provides configuration values programmatically. This is an alternative to\n * providing configuration through the config-file. Configuration provided this\n * way will be merged with configuration from other sources.\n *\n * @param config A configuration object to merge into the existing configuration.\n * @param sourceName An optional name to identify the source of this configuration,\n * used for debugging purposes. Defaults to 'provided'.\n */ function provide(config, sourceName = 'provided') {\n _state_js__WEBPACK_IMPORTED_MODULE_3__.configInternalStore.setState((state)=>({\n ...state,\n providedConfigs: [\n ...state.providedConfigs,\n {\n source: sourceName,\n config\n }\n ]\n }));\n}\n/**\n * A promise-based way to access the config as soon as it is fully loaded.\n * If it is already loaded, resolves the config in its present state.\n *\n * This is a useful function if you need to get the config in the course\n * of the execution of a function.\n *\n * @param moduleName The name of the module for which to look up the config\n */ function getConfig(moduleName) {\n return new Promise((resolve)=>{\n const store = (0,_state_js__WEBPACK_IMPORTED_MODULE_3__.getConfigStore)(moduleName);\n function update(state) {\n if (state.loaded && state.config) {\n const config = (0,ramda__WEBPACK_IMPORTED_MODULE_6__[\"default\"])([\n 'Display conditions',\n 'Translation overrides'\n ], state.config);\n resolve(config);\n if (unsubscribe) {\n unsubscribe();\n }\n }\n }\n update(store.getState());\n const unsubscribe = store.subscribe(update);\n });\n}\n/**\n * Retrieves translation overrides for an extension, optionally scoped to a specific\n * extension slot. When called with only a module name, retrieves module-level overrides.\n * Translation overrides allow customizing translated strings without modifying the\n * original translation files.\n *\n * @param moduleName The name of the module providing the translation context.\n * @param slotName Optional extension slot name to include slot-specific overrides.\n * @param extensionId Optional extension ID to include extension-specific overrides.\n * @returns A Promise resolving to an array of translation override objects.\n *\n * @internal\n */ function getTranslationOverrides(moduleName, slotName, extensionId) {\n const promises = [\n new Promise((resolve)=>{\n const configStore = (0,_state_js__WEBPACK_IMPORTED_MODULE_3__.getConfigStore)(moduleName);\n function update(state) {\n if (state.translationOverridesLoaded && state.config) {\n const translationOverrides = state.config['Translation overrides'] ?? {};\n resolve(translationOverrides);\n if (unsubscribe) {\n unsubscribe();\n }\n }\n }\n update(configStore.getState());\n const unsubscribe = configStore.subscribe(update);\n })\n ];\n if (slotName && extensionId) {\n promises.push(new Promise((resolve)=>{\n const configStore = (0,_state_js__WEBPACK_IMPORTED_MODULE_3__.getExtensionConfig)(slotName, extensionId);\n function update(state) {\n if (state.loaded && state.config) {\n const translationOverrides = state.config['Translation overrides'] ?? {};\n resolve(translationOverrides);\n if (unsubscribe) {\n unsubscribe();\n }\n }\n }\n update(configStore.getState());\n const unsubscribe = configStore.subscribe(update);\n }));\n }\n return Promise.all(promises);\n}\n/**\n * Validate and interpolate defaults for `providedConfig` according to `schema`\n *\n * @param schema a configuration schema\n * @param providedConfig an object of config values (without the top-level module name)\n * @param keyPathContext a dot-separated string which helps the user figure out where\n * the provided config came from\n * @returns The validated and processed configuration object with defaults applied.\n * @internal\n */ function processConfig(schema, providedConfig, keyPathContext) {\n validateStructure(schema, providedConfig, keyPathContext);\n const config = setDefaults(schema, providedConfig);\n runAllValidatorsInConfigTree(schema, config, keyPathContext);\n return config;\n}\n/*\n * Helper functions\n *\n */ /**\n * Returns the configuration for an extension. This configuration is specific\n * to the slot in which it is mounted, and its ID within that slot.\n *\n * The schema for that configuration is the extension schema. If no extension\n * schema has been provided, the schema used is the schema of the module in\n * which the extension is defined.\n *\n * @param slotModuleName The name of the module which defines the extension slot\n * @param extensionModuleName The name of the module which defines the extension (and therefore the config schema)\n * @param slotName The name of the extension slot where the extension is mounted\n * @param extensionId The ID of the extension in its slot\n */ function computeExtensionConfig(slotModuleName, extensionModuleName, slotName, extensionId, configState, tempConfigState) {\n const extensionName = getExtensionNameFromId(extensionId);\n const extensionConfigSchema = configState.schemas[extensionName];\n const nameOfSchemaSource = extensionConfigSchema ? extensionName : extensionModuleName;\n const providedConfigs = getProvidedConfigs(configState, tempConfigState);\n const slotModuleConfig = mergeConfigsFor(slotModuleName, providedConfigs);\n const configOverride = slotModuleConfig?.extensionSlots?.[slotName]?.configure?.[extensionId] ?? {};\n const extensionConfig = mergeConfigsFor(nameOfSchemaSource, providedConfigs);\n const combinedConfig = mergeConfigs([\n extensionConfig,\n configOverride\n ]);\n const schema = extensionConfigSchema ?? configState.schemas[extensionModuleName];\n validateStructure(schema, combinedConfig, nameOfSchemaSource);\n const config = setDefaults(schema, combinedConfig);\n runAllValidatorsInConfigTree(schema, config, nameOfSchemaSource);\n delete config.extensionSlots;\n return config;\n}\nfunction getImplementerToolsConfig(configState, tempConfigState) {\n let result = getSchemaWithValuesAndSources((0,ramda__WEBPACK_IMPORTED_MODULE_7__[\"default\"])(configState.schemas));\n const configsAndSources = [\n ...configState.providedConfigs.map((c)=>[\n c.config,\n c.source\n ]),\n [\n tempConfigState.config,\n 'temporary config'\n ]\n ];\n for (let [config, source] of configsAndSources){\n result = mergeConfigs([\n result,\n createValuesAndSourcesTree(config, source)\n ]);\n }\n return result;\n}\nfunction getSchemaWithValuesAndSources(schema) {\n if (schema.hasOwnProperty('_default')) {\n return {\n ...schema,\n _value: schema._default,\n _source: 'default'\n };\n } else if (isOrdinaryObject(schema)) {\n return Object.keys(schema).reduce((obj, key)=>{\n obj[key] = getSchemaWithValuesAndSources(schema[key]);\n return obj;\n }, {});\n } else {\n // at this point, the schema is bad and an error will have been logged during schema validation\n return {};\n }\n}\nfunction createValuesAndSourcesTree(config, source) {\n if (isOrdinaryObject(config)) {\n return Object.keys(config).reduce((obj, key)=>{\n obj[key] = createValuesAndSourcesTree(config[key], source);\n return obj;\n }, {});\n } else {\n return {\n _value: config,\n _source: source\n };\n }\n}\nfunction getExtensionSlotConfigs(configState, tempConfigState) {\n const allConfigs = mergeConfigs(getProvidedConfigs(configState, tempConfigState));\n const slotConfigPerModule = Object.keys(allConfigs).reduce((obj, key)=>{\n if (allConfigs[key]?.extensionSlots) {\n obj[key] = allConfigs[key]?.extensionSlots;\n }\n return obj;\n }, {});\n validateAllExtensionSlotConfigs(slotConfigPerModule);\n const slotConfigs = Object.keys(slotConfigPerModule).reduce((obj, key)=>{\n obj = {\n ...obj,\n ...slotConfigPerModule[key]\n };\n return obj;\n }, {});\n return slotConfigs;\n}\nfunction validateAllExtensionSlotConfigs(slotConfigPerModule) {\n for (let [moduleName, configBySlotName] of Object.entries(slotConfigPerModule)){\n for (let [slotName, config] of Object.entries(configBySlotName)){\n validateExtensionSlotConfig(config, moduleName, slotName);\n }\n }\n}\nfunction validateExtensionSlotConfig(config, moduleName, slotName) {\n const keyPath = `${moduleName}.extensionSlots.${slotName}`;\n const errorPrefix = `Extension slot config '${keyPath}'`;\n const invalidKeys = Object.keys(config).filter((k)=>![\n 'add',\n 'remove',\n 'order',\n 'configure'\n ].includes(k));\n if (invalidKeys.length) {\n logError(keyPath, errorPrefix + `' contains invalid keys '${invalidKeys.join(\"', '\")}'`);\n }\n if (config.add) {\n if (!Array.isArray(config.add) || !config.add.every((n)=>typeof n === 'string')) {\n logError(keyPath, errorPrefix + `.add' is invalid. Must be an array of strings (extension IDs)`);\n }\n }\n if (config.remove) {\n if (!Array.isArray(config.remove) || !config.remove.every((n)=>typeof n === 'string')) {\n logError(keyPath, errorPrefix + `.remove' is invalid. Must be an array of strings (extension IDs)`);\n }\n }\n if (config.order) {\n if (!Array.isArray(config.order) || !config.order.every((n)=>typeof n === 'string')) {\n logError(keyPath, errorPrefix + `.order' is invalid. Must be an array of strings (extension IDs)`);\n }\n }\n if (config.configure) {\n if (!isOrdinaryObject(config.configure)) {\n logError(keyPath, errorPrefix + `.configure' is invalid. Must be an object with extension IDs for keys`);\n }\n }\n}\nfunction getProvidedConfigs(configState, tempConfigState) {\n return [\n ...configState.providedConfigs.map((c)=>c.config),\n tempConfigState.config\n ];\n}\n/**\n * Validates the config schema for a module. Since problems identified here are programming errors\n * that hopefully will be caught during development, this function logs errors to the console directly;\n * it's fine if we spam the user with these errors.\n */ function validateConfigSchema(moduleName, schema, keyPath = '') {\n const updateMessage = `Please verify that you are running the latest version and, if so, alert the maintainer.`;\n for (const key of Object.keys(schema).filter((k)=>!k.startsWith('_'))){\n const thisKeyPath = keyPath + (keyPath && '.') + key;\n const schemaPart = schema[key];\n if (thisKeyPath === 'Display conditions') {\n console.error(`${moduleName} declares a configuration option called \"Display conditions\"; the \"Display conditions\" option is a reserved name. ${updateMessage}`);\n }\n if (thisKeyPath === 'Translation overrides') {\n console.error(`${moduleName} declares a configuration option called \"Translation overrides\"; the \"Translation overrides\" option is a reserved name. ${updateMessage}`);\n }\n if (!isOrdinaryObject(schemaPart)) {\n console.error(`${moduleName} has bad config schema definition for key '${thisKeyPath}'. ${updateMessage}`);\n continue;\n }\n if (!schemaPart.hasOwnProperty('_default')) {\n // recurse for nested config keys\n validateConfigSchema(moduleName, schemaPart, thisKeyPath);\n }\n const elements = schemaPart._elements;\n if (hasObjectSchema(elements)) {\n validateConfigSchema(moduleName, elements, thisKeyPath + '._elements');\n }\n if (schemaPart._validators) {\n for (let validator of schemaPart._validators){\n if (typeof validator !== 'function') {\n console.error(`${moduleName} has invalid validator for key '${thisKeyPath}' ${updateMessage}.` + `\\n\\nIf you're the maintainer: validators must be functions that return either ` + `undefined or an error string. Received ${validator}.`);\n }\n }\n }\n const valueType = schemaPart._type;\n if (valueType && !Object.values(_types_js__WEBPACK_IMPORTED_MODULE_0__.Type).includes(valueType)) {\n console.error(`${moduleName} has invalid type for key '${thisKeyPath}' ${updateMessage}.` + `\\n\\nIf you're the maintainer: the allowed types are ${Object.values(_types_js__WEBPACK_IMPORTED_MODULE_0__.Type).join(', ')}. ` + `Received '${valueType}'`);\n }\n if (Object.keys(schemaPart).every((k)=>[\n '_description',\n '_validators',\n '_elements',\n '_type'\n ].includes(k)) && !keyPath.includes('._elements')) {\n console.error(`${moduleName} has bad config schema definition for key '${thisKeyPath}'. ${updateMessage}.` + `\\n\\nIf you're the maintainer: all config elements must have a default. ` + `Received ${JSON.stringify(schemaPart)}`);\n }\n if (elements && valueType && ![\n _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.Array,\n _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.Object\n ].includes(valueType)) {\n console.error(`${moduleName} has bad config schema definition for key '${thisKeyPath}'. ${updateMessage}.` + `\\n\\nIf you're the maintainer: the 'elements' key only works with '_type' equal to 'Array' or 'Object'. ` + `Received ${JSON.stringify(valueType)}`);\n }\n }\n}\nfunction getConfigForModule(moduleName, configState, tempConfigState) {\n const schema = configState.schemas[moduleName];\n const inputConfig = mergeConfigsFor(moduleName, getProvidedConfigs(configState, tempConfigState));\n validateStructure(schema, inputConfig, moduleName);\n const config = setDefaults(schema, inputConfig);\n runAllValidatorsInConfigTree(schema, config, moduleName);\n delete config.extensionSlots;\n return config;\n}\nfunction getConfigForModuleImplicitSchema(moduleName, configState, tempConfigState) {\n const inputConfig = mergeConfigsFor(moduleName, getProvidedConfigs(configState, tempConfigState));\n const config = setDefaults(implicitConfigSchema, inputConfig);\n runAllValidatorsInConfigTree(implicitConfigSchema, config, moduleName);\n delete config.extensionSlots;\n return config;\n}\nfunction mergeConfigsFor(moduleName, allConfigs) {\n const allConfigsForModule = allConfigs.map(({ [moduleName]: c })=>c).filter((c)=>!!c);\n return mergeConfigs(allConfigsForModule);\n}\nfunction mergeConfigs(configs) {\n const mergeDeepAll = (0,ramda__WEBPACK_IMPORTED_MODULE_8__[\"default\"])(ramda__WEBPACK_IMPORTED_MODULE_5__[\"default\"]);\n return mergeDeepAll({}, configs);\n}\n/**\n * Recursively check the provided config tree to make sure that all\n * of the provided properties exist in the schema, and that types are\n * correct. Does not run validators yet, since those will be run on\n * the config with the defaults filled in.\n */ function validateStructure(schema, config, keyPath = '') {\n // validate each constituent element\n for (const key of Object.keys(config)){\n const value = config[key];\n const thisKeyPath = keyPath + '.' + key;\n const schemaPart = schema[key];\n if (!schema.hasOwnProperty(key)) {\n if (!(key === 'extensionSlots' && keyPath !== '')) {\n logError(thisKeyPath, `Unknown config key '${thisKeyPath}' provided. Ignoring.`);\n }\n continue;\n }\n validateBranchStructure(schemaPart, value, thisKeyPath);\n }\n}\nfunction validateBranchStructure(schemaPart, value, keyPath) {\n checkType(keyPath, schemaPart._type, value);\n if (isOrdinaryObject(value)) {\n if (schemaPart._type === _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.Object) {\n // validate as freeform object\n validateFreeformObjectStructure(schemaPart, value, keyPath);\n } else if (!(schemaPart.hasOwnProperty('_default') || schemaPart.hasOwnProperty('_type'))) {\n // validate as normal nested config\n validateStructure(schemaPart, value, keyPath);\n }\n } else {\n if (schemaPart._type === _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.Array) {\n validateArrayStructure(schemaPart, value, keyPath);\n }\n }\n}\nfunction validateFreeformObjectStructure(freeformObjectSchema, config, keyPath) {\n if (freeformObjectSchema._elements) {\n for (const key of Object.keys(config)){\n const value = config[key];\n validateBranchStructure(freeformObjectSchema._elements, value, `${keyPath}.${key}`);\n }\n }\n}\nfunction validateArrayStructure(arraySchema, value, keyPath) {\n const validatedAsArray = checkType(keyPath, _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.Array, value);\n if (!validatedAsArray) {\n return;\n }\n // if there is an array element object schema, verify that elements match it\n if (hasObjectSchema(arraySchema._elements)) {\n for(let i = 0; i < value.length; i++){\n validateBranchStructure(arraySchema._elements, value[i], `${keyPath}[${i}]`);\n }\n }\n for(let i = 0; i < value.length; i++){\n checkType(`${keyPath}[${i}]`, arraySchema._elements?._type, value[i]);\n }\n}\n/**\n * Run all the validators in the config tree. This should be run\n * on the config object after it has been filled in with all the defaults, since\n * higher-level validators may refer to default values.\n */ function runAllValidatorsInConfigTree(schema, config, keyPath = '') {\n // If `!schema`, there should have been a structural validation error printed already.\n if (schema) {\n if (config !== schema._default) {\n runValidators(keyPath, schema._validators, config);\n }\n if (isOrdinaryObject(config)) {\n for (const key of Object.keys(config)){\n const value = config[key];\n const thisKeyPath = keyPath + '.' + key;\n const schemaPart = schema[key];\n if (schema._type === _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.Object && schema._elements) {\n runAllValidatorsInConfigTree(schema._elements, value, thisKeyPath);\n } else {\n runAllValidatorsInConfigTree(schemaPart, value, thisKeyPath);\n }\n }\n } else if (Array.isArray(config) && schema._elements) {\n for(let i = 0; i < config.length; i++){\n runAllValidatorsInConfigTree(schema._elements, config[i], `${keyPath}[${i}]`);\n }\n }\n }\n}\n/**\n * Run type validation for the value, logging any errors.\n * @returns true if validation passes, false otherwise\n */ function checkType(keyPath, _type, value) {\n if (_type) {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\n const validator = {\n Array: _validators_type_validators_js__WEBPACK_IMPORTED_MODULE_1__.isArray,\n Boolean: _validators_type_validators_js__WEBPACK_IMPORTED_MODULE_1__.isBoolean,\n ConceptUuid: _validators_type_validators_js__WEBPACK_IMPORTED_MODULE_1__.isUuid,\n Number: _validators_type_validators_js__WEBPACK_IMPORTED_MODULE_1__.isNumber,\n Object: _validators_type_validators_js__WEBPACK_IMPORTED_MODULE_1__.isObject,\n String: _validators_type_validators_js__WEBPACK_IMPORTED_MODULE_1__.isString,\n UUID: _validators_type_validators_js__WEBPACK_IMPORTED_MODULE_1__.isUuid,\n PersonAttributeTypeUuid: _validators_type_validators_js__WEBPACK_IMPORTED_MODULE_1__.isUuid,\n PatientIdentifierTypeUuid: _validators_type_validators_js__WEBPACK_IMPORTED_MODULE_1__.isUuid\n };\n return runValidators(keyPath, [\n validator[_type]\n ], value);\n }\n return true;\n}\n/**\n * Runs validators, logging errors.\n * @returns true if all pass, false otherwise.\n */ // eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\nfunction runValidators(keyPath, validators, value) {\n let returnValue = true;\n if (validators) {\n try {\n for (let validator of validators){\n const validatorResult = validator(value);\n if (typeof validatorResult === 'string') {\n const message = typeof value === 'object' ? `Invalid configuration for ${keyPath}: ${validatorResult}` : `Invalid configuration value ${value} for ${keyPath}: ${validatorResult}`;\n logError(keyPath, message);\n returnValue = false;\n }\n }\n } catch (e) {\n console.error(`Skipping invalid validator at \"${keyPath}\". Encountered error\\n\\t${e}`);\n }\n }\n return returnValue;\n}\n// Recursively fill in the config with values from the schema.\nconst setDefaults = (schema, inputConfig)=>{\n const config = (0,ramda__WEBPACK_IMPORTED_MODULE_7__[\"default\"])(inputConfig);\n if (!schema) {\n return config;\n }\n for (const key of Object.keys(schema)){\n const configPart = config[key];\n const schemaPart = schema[key];\n // The `schemaPart &&` clause of this `if` statement will only fail\n // if the schema is very invalid. It is there to prevent the app from\n // crashing completely, though it will produce unexpected behavior.\n // If this happens, there should be legible errors in the console from\n // the schema validator.\n if (schemaPart && (schemaPart.hasOwnProperty('_type') || schemaPart.hasOwnProperty('_default'))) {\n // We assume that schemaPart defines a config value, since it has\n // a property `_type` or `_default`.\n if (!config.hasOwnProperty(key)) {\n config[key] = schemaPart['_default'];\n }\n // We also check if it is an object or array with object elements, in which case we recurse\n const elements = schemaPart._elements;\n if (configPart && hasObjectSchema(elements)) {\n if (schemaPart._type === _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.Array && Array.isArray(configPart)) {\n const configWithDefaults = configPart.map((conf)=>setDefaults(elements, conf));\n config[key] = configWithDefaults;\n } else if (schemaPart._type === _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.Object) {\n for (let objectKey of Object.keys(configPart)){\n configPart[objectKey] = setDefaults(elements, configPart[objectKey]);\n }\n }\n }\n } else if (isOrdinaryObject(schemaPart)) {\n // Since schemaPart has no property \"_type\", if it's an ordinary object\n // (unlike, importantly, the validators array), we assume it is a parent config property.\n // We recurse to config[key] and schema[key]. Default config[key] to {}.\n const selectedConfigPart = configPart ?? {};\n // There will have been a validation error already if configPart is not a plain object.\n if (isOrdinaryObject(selectedConfigPart)) {\n config[key] = setDefaults(schemaPart, selectedConfigPart);\n }\n }\n }\n return config;\n};\nfunction hasObjectSchema(elementsSchema) {\n return !!elementsSchema && Object.keys(elementsSchema).filter((e)=>![\n '_default',\n '_validators'\n ].includes(e)).length > 0;\n}\nfunction isOrdinaryObject(value) {\n return typeof value === 'object' && !Array.isArray(value) && value !== null;\n}\n/** Keep track of which validation errors we have displayed. Each one should only be displayed once. */ let displayedValidationMessages = new Set();\nfunction logError(keyPath, message) {\n const key = `${keyPath}:::${message}`;\n // technically, this should not be possible, but because of how things wind-up transpiled, this isn't impossible\n if (!displayedValidationMessages) {\n displayedValidationMessages = new Set();\n }\n if (!displayedValidationMessages.has(key)) {\n console.error(message);\n displayedValidationMessages.add(key);\n }\n}\n/**\n * Normally, configuration errors are only displayed once. This function clears the list of\n * displayed errors, so that they will be displayed again.\n *\n * @internal\n */ function clearConfigErrors(keyPath) {\n if (keyPath) {\n displayedValidationMessages.forEach((key)=>{\n if (key.startsWith(keyPath)) {\n displayedValidationMessages.delete(key);\n }\n });\n } else {\n displayedValidationMessages.clear();\n }\n}\n/**\n * Cleans up all config store subscriptions and re-establishes them. This is primarily\n * useful for testing, where subscriptions set up at module load time need to be cleared\n * between tests to prevent infinite update loops. After clearing, subscriptions are\n * re-established so the config system continues to work normally.\n *\n * @internal\n */ function resetConfigSystem() {\n configSubscriptions.forEach((unsubscribe)=>unsubscribe());\n configSubscriptions.length = 0;\n setupConfigSubscriptions();\n}\n/**\n * Copied over from esm-extensions. It rightly belongs to that module, but esm-config\n * cannot depend on esm-extensions.\n */ function getExtensionNameFromId(extensionId) {\n const [extensionName] = extensionId.split('#');\n return extensionName;\n}\n/**\n * The translation overrides schema is used in the implicit schema given to every module;\n * plus any additional translation namespaces (at time of writing, this is just 'core').\n */ const translationOverridesSchema = {\n 'Translation overrides': {\n _description: 'Per-language overrides for frontend translations should be keyed by language code and each language dictionary contains the translation key and the display value',\n _type: _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.Object,\n _default: {},\n _validators: [\n (0,_validators_validator_js__WEBPACK_IMPORTED_MODULE_2__.validator)((o)=>Object.keys(o).every((k)=>/^[a-z]{2,3}(-[A-Z]{2,3})?$/.test(k)), (o)=>{\n const badKeys = Object.keys(o).filter((k)=>!/^[a-z]{2,3}(-[A-Z]{2,3})?$/.test(k));\n return `The 'Translation overrides' object should have language codes for keys. Language codes must be in the form of a two-to-three letter language code optionally followed by a hyphen and a two-to-three letter country code. The following keys do not conform: ${badKeys.join(', ')}.`;\n })\n ]\n }\n};\n/**\n * The implicitConfigSchema is implicitly included in every configuration schema\n */ const implicitConfigSchema = {\n 'Display conditions': {\n privileges: {\n _description: 'The privilege(s) the user must have to use this extension',\n _type: _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.Array,\n _default: []\n },\n expression: {\n _description: 'The expression that determines whether the extension is displayed',\n _type: _types_js__WEBPACK_IMPORTED_MODULE_0__.Type.String,\n _default: undefined\n }\n },\n ...translationOverridesSchema\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-config/dist/module-config/module-config.js","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-config/dist/module-config/module-config.js?8dfe"],"sourcesContent":["/** @module @category Config */ import { clone, equals, reduce, mergeDeepRight, omit } from \"ramda\";\nimport { Type } from \"../types.js\";\nimport { isArray, isBoolean, isUuid, isNumber, isObject, isString } from \"../validators/type-validators.js\";\nimport { validator } from \"../validators/validator.js\";\nimport { configExtensionStore, configInternalStore, getConfigStore, getExtensionConfig, getExtensionSlotsConfigStore, getExtensionsConfigStore, implementerToolsConfigStore, temporaryConfigStore } from \"./state.js\";\n/**\n * Store setup\n *\n *\n * Set up stores and subscriptions so that inputs get processed appropriately.\n *\n * There are *input* stores and *output* stores. The *input* stores\n * are configInternalStore, temporaryConfigStore, and configExtensionStore. The\n * output stores are set in the `compute...` functions. They are the module\n * config stores, the extension slot config stores (by module), the extension\n * config stores, and the implementer tools config store.\n *\n * This code sets up the subscriptions so that when an input store changes,\n * the correct set of output stores are updated.\n *\n * All `compute...` functions except `computeExtensionConfigs` are pure\n * (or are supposed to be), other than the fact that they all `setState`\n * store values at the end. `computeExtensionConfigs` calls `getGlobalStore`,\n * which creates stores.\n */ // Store unsubscribe functions to allow cleanup (e.g., in tests or hot module reloading)\nconst configSubscriptions = [];\n/**\n * Recomputes all configuration derived stores based on current state of input stores.\n * Called whenever any input store (configInternalStore, temporaryConfigStore, configExtensionStore) changes.\n */ function recomputeAllConfigs() {\n    const configState = configInternalStore.getState();\n    const tempConfigState = temporaryConfigStore.getState();\n    const extensionState = configExtensionStore.getState();\n    computeModuleConfig(configState, tempConfigState);\n    computeImplementerToolsConfig(configState, tempConfigState);\n    computeExtensionSlotConfigs(configState, tempConfigState);\n    computeExtensionConfigs(configState, extensionState, tempConfigState);\n}\nfunction setupConfigSubscriptions() {\n    // Initial computation\n    recomputeAllConfigs();\n    // Subscribe to all input stores with a single handler\n    // This ensures we only recompute once even if multiple stores change simultaneously\n    configSubscriptions.push(configInternalStore.subscribe(recomputeAllConfigs));\n    configSubscriptions.push(temporaryConfigStore.subscribe(recomputeAllConfigs));\n    configSubscriptions.push(configExtensionStore.subscribe(recomputeAllConfigs));\n}\n// Set up subscriptions at module load time\nsetupConfigSubscriptions();\nfunction computeModuleConfig(state, tempState) {\n    for (let moduleName of Object.keys(state.schemas)){\n        // At this point the schema could be either just the implicit schema or the actually\n        // defined schema. We run with just the implicit schema because we want to populate\n        // the config store with the translation overrides as soon as possible. In fact, the\n        // translation system will throw for Suspense until the translation overrides are\n        // available, which as of this writing blocks the schema definition from occurring\n        // for modules loaded based on their extensions.\n        const moduleStore = getConfigStore(moduleName);\n        let newState;\n        if (state.moduleLoaded[moduleName]) {\n            const config = getConfigForModule(moduleName, state, tempState);\n            newState = {\n                translationOverridesLoaded: true,\n                loaded: true,\n                config\n            };\n        } else {\n            const config = getConfigForModuleImplicitSchema(moduleName, state, tempState);\n            newState = {\n                translationOverridesLoaded: true,\n                loaded: false,\n                config\n            };\n        }\n        moduleStore.setState(newState);\n    }\n}\nfunction computeExtensionSlotConfigs(state, tempState) {\n    const slotConfigs = getExtensionSlotConfigs(state, tempState);\n    const newSlotStoreEntries = Object.fromEntries(Object.entries(slotConfigs).map(([slotName, config])=>[\n            slotName,\n            {\n                loaded: true,\n                config\n            }\n        ]));\n    const slotStore = getExtensionSlotsConfigStore();\n    const oldState = slotStore.getState();\n    const newState = {\n        slots: {\n            ...oldState.slots,\n            ...newSlotStoreEntries\n        }\n    };\n    if (!equals(oldState.slots, newState.slots)) {\n        slotStore.setState(newState);\n    }\n}\nfunction computeImplementerToolsConfig(state, tempConfigState) {\n    const oldState = implementerToolsConfigStore.getState();\n    const config = getImplementerToolsConfig(state, tempConfigState);\n    const newState = {\n        config\n    };\n    // Use deep equality on the actual config content, not the wrapper object\n    if (!equals(oldState.config, newState.config)) {\n        implementerToolsConfigStore.setState(newState);\n    }\n}\nfunction computeExtensionConfigs(configState, extensionState, tempConfigState) {\n    const configs = {};\n    // We assume that the module schema has already been defined, since the extension\n    // it contains is mounted.\n    for (let extension of extensionState.mountedExtensions){\n        const config = computeExtensionConfig(extension.slotModuleName, extension.extensionModuleName, extension.slotName, extension.extensionId, configState, tempConfigState);\n        if (!configs[extension.slotName]) {\n            configs[extension.slotName] = {};\n        }\n        configs[extension.slotName][extension.extensionId] = {\n            config,\n            loaded: true\n        };\n    }\n    const extensionsConfigStore = getExtensionsConfigStore();\n    const oldState = extensionsConfigStore.getState();\n    const newState = {\n        configs\n    };\n    // Use deep equality to only update if configs actually changed\n    if (!equals(oldState.configs, newState.configs)) {\n        extensionsConfigStore.setState(newState);\n    }\n}\n/*\n * API\n *\n */ /**\n * This defines a configuration schema for a module. The schema tells the\n * configuration system how the module can be configured. It specifies\n * what makes configuration valid or invalid.\n *\n * See [Configuration System](https://o3-docs.openmrs.org/docs/configuration-system)\n * for more information about defining a config schema.\n *\n * @param moduleName Name of the module the schema is being defined for. Generally\n *   should be the one in which the `defineConfigSchema` call takes place.\n * @param schema The config schema for the module\n */ export function defineConfigSchema(moduleName, schema) {\n    validateConfigSchema(moduleName, schema);\n    const enhancedSchema = mergeDeepRight(schema, implicitConfigSchema);\n    configInternalStore.setState((state)=>({\n            ...state,\n            schemas: {\n                ...state.schemas,\n                [moduleName]: enhancedSchema\n            },\n            moduleLoaded: {\n                ...state.moduleLoaded,\n                [moduleName]: true\n            }\n        }));\n}\n/**\n * This alerts the configuration system that a module exists. This allows config to be\n * processed, while still allowing the extension system to know whether the module has\n * actually had its front bundle executed yet.\n *\n * This should only be used in esm-app-shell.\n *\n * @internal\n * @param moduleName\n */ export function registerModuleWithConfigSystem(moduleName) {\n    configInternalStore.setState((state)=>({\n            ...state,\n            schemas: {\n                ...state.schemas,\n                [moduleName]: implicitConfigSchema\n            }\n        }));\n}\n/**\n * This alerts the configuration system that a module has been loaded.\n *\n * This should only be used in esm-app-shell.\n *\n * @internal\n * @param moduleName\n */ export function registerModuleLoad(moduleName) {\n    configInternalStore.setState((state)=>({\n            ...state,\n            moduleLoaded: {\n                ...state.moduleLoaded,\n                [moduleName]: true\n            }\n        }));\n}\n/**\n * This allows the config system to support translation overrides for namespaces that\n * do not correspond to modules.\n *\n * This should only be used in esm-app-shell.\n *\n * @internal\n * @param namespace\n */ export function registerTranslationNamespace(namespace) {\n    configInternalStore.setState((state)=>({\n            ...state,\n            schemas: {\n                ...state.schemas,\n                [namespace]: translationOverridesSchema\n            }\n        }));\n}\n/**\n * This defines a configuration schema for an extension. When a schema is defined\n * for an extension, that extension will receive the configuration corresponding\n * to that schema, rather than the configuration corresponding to the module\n * in which it is defined.\n *\n * The schema tells the configuration system how the module can be configured.\n * It specifies what makes configuration valid or invalid.\n *\n * See [Configuration System](https://o3-docs.openmrs.org/docs/configuration-system)\n * for more information about defining a config schema.\n *\n * @param extensionName Name of the extension the schema is being defined for.\n *   Should match the `name` of one of the `extensions` entries defined in\n *   the app's `routes.json` file.\n * @param schema The config schema for the extension\n */ export function defineExtensionConfigSchema(extensionName, schema) {\n    validateConfigSchema(extensionName, schema);\n    const enhancedSchema = mergeDeepRight(schema, implicitConfigSchema);\n    const state = configInternalStore.getState();\n    if (state.schemas[extensionName]) {\n        console.error(`Config schema for extension ${extensionName} already exists. If there are multiple extensions with this same name, one will probably crash.`);\n    }\n    configInternalStore.setState((state)=>({\n            ...state,\n            schemas: {\n                ...state.schemas,\n                [extensionName]: enhancedSchema\n            }\n        }));\n}\n/**\n * Provides configuration values programmatically. This is an alternative to\n * providing configuration through the config-file. Configuration provided this\n * way will be merged with configuration from other sources.\n *\n * @param config A configuration object to merge into the existing configuration.\n * @param sourceName An optional name to identify the source of this configuration,\n *   used for debugging purposes. Defaults to 'provided'.\n */ export function provide(config, sourceName = 'provided') {\n    configInternalStore.setState((state)=>({\n            ...state,\n            providedConfigs: [\n                ...state.providedConfigs,\n                {\n                    source: sourceName,\n                    config\n                }\n            ]\n        }));\n}\n/**\n * A promise-based way to access the config as soon as it is fully loaded.\n * If it is already loaded, resolves the config in its present state.\n *\n * This is a useful function if you need to get the config in the course\n * of the execution of a function.\n *\n * @param moduleName The name of the module for which to look up the config\n */ export function getConfig(moduleName) {\n    return new Promise((resolve)=>{\n        const store = getConfigStore(moduleName);\n        function update(state) {\n            if (state.loaded && state.config) {\n                const config = omit([\n                    'Display conditions',\n                    'Translation overrides'\n                ], state.config);\n                resolve(config);\n                if (unsubscribe) {\n                    unsubscribe();\n                }\n            }\n        }\n        update(store.getState());\n        const unsubscribe = store.subscribe(update);\n    });\n}\n/**\n * Retrieves translation overrides for an extension, optionally scoped to a specific\n * extension slot. When called with only a module name, retrieves module-level overrides.\n * Translation overrides allow customizing translated strings without modifying the\n * original translation files.\n *\n * @param moduleName The name of the module providing the translation context.\n * @param slotName Optional extension slot name to include slot-specific overrides.\n * @param extensionId Optional extension ID to include extension-specific overrides.\n * @returns A Promise resolving to an array of translation override objects.\n *\n * @internal\n */ export function getTranslationOverrides(moduleName, slotName, extensionId) {\n    const promises = [\n        new Promise((resolve)=>{\n            const configStore = getConfigStore(moduleName);\n            function update(state) {\n                if (state.translationOverridesLoaded && state.config) {\n                    const translationOverrides = state.config['Translation overrides'] ?? {};\n                    resolve(translationOverrides);\n                    if (unsubscribe) {\n                        unsubscribe();\n                    }\n                }\n            }\n            update(configStore.getState());\n            const unsubscribe = configStore.subscribe(update);\n        })\n    ];\n    if (slotName && extensionId) {\n        promises.push(new Promise((resolve)=>{\n            const configStore = getExtensionConfig(slotName, extensionId);\n            function update(state) {\n                if (state.loaded && state.config) {\n                    const translationOverrides = state.config['Translation overrides'] ?? {};\n                    resolve(translationOverrides);\n                    if (unsubscribe) {\n                        unsubscribe();\n                    }\n                }\n            }\n            update(configStore.getState());\n            const unsubscribe = configStore.subscribe(update);\n        }));\n    }\n    return Promise.all(promises);\n}\n/**\n * Validate and interpolate defaults for `providedConfig` according to `schema`\n *\n * @param schema  a configuration schema\n * @param providedConfig  an object of config values (without the top-level module name)\n * @param keyPathContext  a dot-separated string which helps the user figure out where\n *     the provided config came from\n * @returns The validated and processed configuration object with defaults applied.\n * @internal\n */ export function processConfig(schema, providedConfig, keyPathContext) {\n    validateStructure(schema, providedConfig, keyPathContext);\n    const config = setDefaults(schema, providedConfig);\n    runAllValidatorsInConfigTree(schema, config, keyPathContext);\n    return config;\n}\n/*\n * Helper functions\n *\n */ /**\n * Returns the configuration for an extension. This configuration is specific\n * to the slot in which it is mounted, and its ID within that slot.\n *\n * The schema for that configuration is the extension schema. If no extension\n * schema has been provided, the schema used is the schema of the module in\n * which the extension is defined.\n *\n * @param slotModuleName The name of the module which defines the extension slot\n * @param extensionModuleName The name of the module which defines the extension (and therefore the config schema)\n * @param slotName The name of the extension slot where the extension is mounted\n * @param extensionId The ID of the extension in its slot\n */ function computeExtensionConfig(slotModuleName, extensionModuleName, slotName, extensionId, configState, tempConfigState) {\n    const extensionName = getExtensionNameFromId(extensionId);\n    const extensionConfigSchema = configState.schemas[extensionName];\n    const nameOfSchemaSource = extensionConfigSchema ? extensionName : extensionModuleName;\n    const providedConfigs = getProvidedConfigs(configState, tempConfigState);\n    const slotModuleConfig = mergeConfigsFor(slotModuleName, providedConfigs);\n    const configOverride = slotModuleConfig?.extensionSlots?.[slotName]?.configure?.[extensionId] ?? {};\n    const extensionConfig = mergeConfigsFor(nameOfSchemaSource, providedConfigs);\n    const combinedConfig = mergeConfigs([\n        extensionConfig,\n        configOverride\n    ]);\n    const schema = extensionConfigSchema ?? configState.schemas[extensionModuleName];\n    validateStructure(schema, combinedConfig, nameOfSchemaSource);\n    const config = setDefaults(schema, combinedConfig);\n    runAllValidatorsInConfigTree(schema, config, nameOfSchemaSource);\n    delete config.extensionSlots;\n    return config;\n}\nfunction getImplementerToolsConfig(configState, tempConfigState) {\n    let result = getSchemaWithValuesAndSources(clone(configState.schemas));\n    const configsAndSources = [\n        ...configState.providedConfigs.map((c)=>[\n                c.config,\n                c.source\n            ]),\n        [\n            tempConfigState.config,\n            'temporary config'\n        ]\n    ];\n    for (let [config, source] of configsAndSources){\n        result = mergeConfigs([\n            result,\n            createValuesAndSourcesTree(config, source)\n        ]);\n    }\n    return result;\n}\nfunction getSchemaWithValuesAndSources(schema) {\n    if (schema.hasOwnProperty('_default')) {\n        return {\n            ...schema,\n            _value: schema._default,\n            _source: 'default'\n        };\n    } else if (isOrdinaryObject(schema)) {\n        return Object.keys(schema).reduce((obj, key)=>{\n            obj[key] = getSchemaWithValuesAndSources(schema[key]);\n            return obj;\n        }, {});\n    } else {\n        // at this point, the schema is bad and an error will have been logged during schema validation\n        return {};\n    }\n}\nfunction createValuesAndSourcesTree(config, source) {\n    if (isOrdinaryObject(config)) {\n        return Object.keys(config).reduce((obj, key)=>{\n            obj[key] = createValuesAndSourcesTree(config[key], source);\n            return obj;\n        }, {});\n    } else {\n        return {\n            _value: config,\n            _source: source\n        };\n    }\n}\nfunction getExtensionSlotConfigs(configState, tempConfigState) {\n    const allConfigs = mergeConfigs(getProvidedConfigs(configState, tempConfigState));\n    const slotConfigPerModule = Object.keys(allConfigs).reduce((obj, key)=>{\n        if (allConfigs[key]?.extensionSlots) {\n            obj[key] = allConfigs[key]?.extensionSlots;\n        }\n        return obj;\n    }, {});\n    validateAllExtensionSlotConfigs(slotConfigPerModule);\n    const slotConfigs = Object.keys(slotConfigPerModule).reduce((obj, key)=>{\n        obj = {\n            ...obj,\n            ...slotConfigPerModule[key]\n        };\n        return obj;\n    }, {});\n    return slotConfigs;\n}\nfunction validateAllExtensionSlotConfigs(slotConfigPerModule) {\n    for (let [moduleName, configBySlotName] of Object.entries(slotConfigPerModule)){\n        for (let [slotName, config] of Object.entries(configBySlotName)){\n            validateExtensionSlotConfig(config, moduleName, slotName);\n        }\n    }\n}\nfunction validateExtensionSlotConfig(config, moduleName, slotName) {\n    const keyPath = `${moduleName}.extensionSlots.${slotName}`;\n    const errorPrefix = `Extension slot config '${keyPath}'`;\n    const invalidKeys = Object.keys(config).filter((k)=>![\n            'add',\n            'remove',\n            'order',\n            'configure'\n        ].includes(k));\n    if (invalidKeys.length) {\n        logError(keyPath, errorPrefix + `' contains invalid keys '${invalidKeys.join(\"', '\")}'`);\n    }\n    if (config.add) {\n        if (!Array.isArray(config.add) || !config.add.every((n)=>typeof n === 'string')) {\n            logError(keyPath, errorPrefix + `.add' is invalid. Must be an array of strings (extension IDs)`);\n        }\n    }\n    if (config.remove) {\n        if (!Array.isArray(config.remove) || !config.remove.every((n)=>typeof n === 'string')) {\n            logError(keyPath, errorPrefix + `.remove' is invalid. Must be an array of strings (extension IDs)`);\n        }\n    }\n    if (config.order) {\n        if (!Array.isArray(config.order) || !config.order.every((n)=>typeof n === 'string')) {\n            logError(keyPath, errorPrefix + `.order' is invalid. Must be an array of strings (extension IDs)`);\n        }\n    }\n    if (config.configure) {\n        if (!isOrdinaryObject(config.configure)) {\n            logError(keyPath, errorPrefix + `.configure' is invalid. Must be an object with extension IDs for keys`);\n        }\n    }\n}\nfunction getProvidedConfigs(configState, tempConfigState) {\n    return [\n        ...configState.providedConfigs.map((c)=>c.config),\n        tempConfigState.config\n    ];\n}\n/**\n * Validates the config schema for a module. Since problems identified here are programming errors\n * that hopefully will be caught during development, this function logs errors to the console directly;\n * it's fine if we spam the user with these errors.\n */ function validateConfigSchema(moduleName, schema, keyPath = '') {\n    const updateMessage = `Please verify that you are running the latest version and, if so, alert the maintainer.`;\n    for (const key of Object.keys(schema).filter((k)=>!k.startsWith('_'))){\n        const thisKeyPath = keyPath + (keyPath && '.') + key;\n        const schemaPart = schema[key];\n        if (thisKeyPath === 'Display conditions') {\n            console.error(`${moduleName} declares a configuration option called \"Display conditions\"; the \"Display conditions\" option is a reserved name. ${updateMessage}`);\n        }\n        if (thisKeyPath === 'Translation overrides') {\n            console.error(`${moduleName} declares a configuration option called \"Translation overrides\"; the \"Translation overrides\" option is a reserved name. ${updateMessage}`);\n        }\n        if (!isOrdinaryObject(schemaPart)) {\n            console.error(`${moduleName} has bad config schema definition for key '${thisKeyPath}'. ${updateMessage}`);\n            continue;\n        }\n        if (!schemaPart.hasOwnProperty('_default')) {\n            // recurse for nested config keys\n            validateConfigSchema(moduleName, schemaPart, thisKeyPath);\n        }\n        const elements = schemaPart._elements;\n        if (hasObjectSchema(elements)) {\n            validateConfigSchema(moduleName, elements, thisKeyPath + '._elements');\n        }\n        if (schemaPart._validators) {\n            for (let validator of schemaPart._validators){\n                if (typeof validator !== 'function') {\n                    console.error(`${moduleName} has invalid validator for key '${thisKeyPath}' ${updateMessage}.` + `\\n\\nIf you're the maintainer: validators must be functions that return either ` + `undefined or an error string. Received ${validator}.`);\n                }\n            }\n        }\n        const valueType = schemaPart._type;\n        if (valueType && !Object.values(Type).includes(valueType)) {\n            console.error(`${moduleName} has invalid type for key '${thisKeyPath}' ${updateMessage}.` + `\\n\\nIf you're the maintainer: the allowed types are ${Object.values(Type).join(', ')}. ` + `Received '${valueType}'`);\n        }\n        if (Object.keys(schemaPart).every((k)=>[\n                '_description',\n                '_validators',\n                '_elements',\n                '_type'\n            ].includes(k)) && !keyPath.includes('._elements')) {\n            console.error(`${moduleName} has bad config schema definition for key '${thisKeyPath}'. ${updateMessage}.` + `\\n\\nIf you're the maintainer: all config elements must have a default. ` + `Received ${JSON.stringify(schemaPart)}`);\n        }\n        if (elements && valueType && ![\n            Type.Array,\n            Type.Object\n        ].includes(valueType)) {\n            console.error(`${moduleName} has bad config schema definition for key '${thisKeyPath}'. ${updateMessage}.` + `\\n\\nIf you're the maintainer: the 'elements' key only works with '_type' equal to 'Array' or 'Object'. ` + `Received ${JSON.stringify(valueType)}`);\n        }\n    }\n}\nfunction getConfigForModule(moduleName, configState, tempConfigState) {\n    const schema = configState.schemas[moduleName];\n    const inputConfig = mergeConfigsFor(moduleName, getProvidedConfigs(configState, tempConfigState));\n    validateStructure(schema, inputConfig, moduleName);\n    const config = setDefaults(schema, inputConfig);\n    runAllValidatorsInConfigTree(schema, config, moduleName);\n    delete config.extensionSlots;\n    return config;\n}\nfunction getConfigForModuleImplicitSchema(moduleName, configState, tempConfigState) {\n    const inputConfig = mergeConfigsFor(moduleName, getProvidedConfigs(configState, tempConfigState));\n    const config = setDefaults(implicitConfigSchema, inputConfig);\n    runAllValidatorsInConfigTree(implicitConfigSchema, config, moduleName);\n    delete config.extensionSlots;\n    return config;\n}\nfunction mergeConfigsFor(moduleName, allConfigs) {\n    const allConfigsForModule = allConfigs.map(({ [moduleName]: c })=>c).filter((c)=>!!c);\n    return mergeConfigs(allConfigsForModule);\n}\nfunction mergeConfigs(configs) {\n    const mergeDeepAll = reduce(mergeDeepRight);\n    return mergeDeepAll({}, configs);\n}\n/**\n * Recursively check the provided config tree to make sure that all\n * of the provided properties exist in the schema, and that types are\n * correct. Does not run validators yet, since those will be run on\n * the config with the defaults filled in.\n */ function validateStructure(schema, config, keyPath = '') {\n    // validate each constituent element\n    for (const key of Object.keys(config)){\n        const value = config[key];\n        const thisKeyPath = keyPath + '.' + key;\n        const schemaPart = schema[key];\n        if (!schema.hasOwnProperty(key)) {\n            if (!(key === 'extensionSlots' && keyPath !== '')) {\n                logError(thisKeyPath, `Unknown config key '${thisKeyPath}' provided. Ignoring.`);\n            }\n            continue;\n        }\n        validateBranchStructure(schemaPart, value, thisKeyPath);\n    }\n}\nfunction validateBranchStructure(schemaPart, value, keyPath) {\n    checkType(keyPath, schemaPart._type, value);\n    if (isOrdinaryObject(value)) {\n        if (schemaPart._type === Type.Object) {\n            // validate as freeform object\n            validateFreeformObjectStructure(schemaPart, value, keyPath);\n        } else if (!(schemaPart.hasOwnProperty('_default') || schemaPart.hasOwnProperty('_type'))) {\n            // validate as normal nested config\n            validateStructure(schemaPart, value, keyPath);\n        }\n    } else {\n        if (schemaPart._type === Type.Array) {\n            validateArrayStructure(schemaPart, value, keyPath);\n        }\n    }\n}\nfunction validateFreeformObjectStructure(freeformObjectSchema, config, keyPath) {\n    if (freeformObjectSchema._elements) {\n        for (const key of Object.keys(config)){\n            const value = config[key];\n            validateBranchStructure(freeformObjectSchema._elements, value, `${keyPath}.${key}`);\n        }\n    }\n}\nfunction validateArrayStructure(arraySchema, value, keyPath) {\n    const validatedAsArray = checkType(keyPath, Type.Array, value);\n    if (!validatedAsArray) {\n        return;\n    }\n    // if there is an array element object schema, verify that elements match it\n    if (hasObjectSchema(arraySchema._elements)) {\n        for(let i = 0; i < value.length; i++){\n            validateBranchStructure(arraySchema._elements, value[i], `${keyPath}[${i}]`);\n        }\n    }\n    for(let i = 0; i < value.length; i++){\n        checkType(`${keyPath}[${i}]`, arraySchema._elements?._type, value[i]);\n    }\n}\n/**\n * Run all the validators in the config tree. This should be run\n * on the config object after it has been filled in with all the defaults, since\n * higher-level validators may refer to default values.\n */ function runAllValidatorsInConfigTree(schema, config, keyPath = '') {\n    // If `!schema`, there should have been a structural validation error printed already.\n    if (schema) {\n        if (config !== schema._default) {\n            runValidators(keyPath, schema._validators, config);\n        }\n        if (isOrdinaryObject(config)) {\n            for (const key of Object.keys(config)){\n                const value = config[key];\n                const thisKeyPath = keyPath + '.' + key;\n                const schemaPart = schema[key];\n                if (schema._type === Type.Object && schema._elements) {\n                    runAllValidatorsInConfigTree(schema._elements, value, thisKeyPath);\n                } else {\n                    runAllValidatorsInConfigTree(schemaPart, value, thisKeyPath);\n                }\n            }\n        } else if (Array.isArray(config) && schema._elements) {\n            for(let i = 0; i < config.length; i++){\n                runAllValidatorsInConfigTree(schema._elements, config[i], `${keyPath}[${i}]`);\n            }\n        }\n    }\n}\n/**\n * Run type validation for the value, logging any errors.\n * @returns true if validation passes, false otherwise\n */ function checkType(keyPath, _type, value) {\n    if (_type) {\n        // eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\n        const validator = {\n            Array: isArray,\n            Boolean: isBoolean,\n            ConceptUuid: isUuid,\n            Number: isNumber,\n            Object: isObject,\n            String: isString,\n            UUID: isUuid,\n            PersonAttributeTypeUuid: isUuid,\n            PatientIdentifierTypeUuid: isUuid\n        };\n        return runValidators(keyPath, [\n            validator[_type]\n        ], value);\n    }\n    return true;\n}\n/**\n * Runs validators, logging errors.\n * @returns true if all pass, false otherwise.\n */ // eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\nfunction runValidators(keyPath, validators, value) {\n    let returnValue = true;\n    if (validators) {\n        try {\n            for (let validator of validators){\n                const validatorResult = validator(value);\n                if (typeof validatorResult === 'string') {\n                    const message = typeof value === 'object' ? `Invalid configuration for ${keyPath}: ${validatorResult}` : `Invalid configuration value ${value} for ${keyPath}: ${validatorResult}`;\n                    logError(keyPath, message);\n                    returnValue = false;\n                }\n            }\n        } catch (e) {\n            console.error(`Skipping invalid validator at \"${keyPath}\". Encountered error\\n\\t${e}`);\n        }\n    }\n    return returnValue;\n}\n// Recursively fill in the config with values from the schema.\nconst setDefaults = (schema, inputConfig)=>{\n    const config = clone(inputConfig);\n    if (!schema) {\n        return config;\n    }\n    for (const key of Object.keys(schema)){\n        const configPart = config[key];\n        const schemaPart = schema[key];\n        // The `schemaPart &&` clause of this `if` statement will only fail\n        // if the schema is very invalid. It is there to prevent the app from\n        // crashing completely, though it will produce unexpected behavior.\n        // If this happens, there should be legible errors in the console from\n        // the schema validator.\n        if (schemaPart && (schemaPart.hasOwnProperty('_type') || schemaPart.hasOwnProperty('_default'))) {\n            // We assume that schemaPart defines a config value, since it has\n            // a property `_type` or `_default`.\n            if (!config.hasOwnProperty(key)) {\n                config[key] = schemaPart['_default'];\n            }\n            // We also check if it is an object or array with object elements, in which case we recurse\n            const elements = schemaPart._elements;\n            if (configPart && hasObjectSchema(elements)) {\n                if (schemaPart._type === Type.Array && Array.isArray(configPart)) {\n                    const configWithDefaults = configPart.map((conf)=>setDefaults(elements, conf));\n                    config[key] = configWithDefaults;\n                } else if (schemaPart._type === Type.Object) {\n                    for (let objectKey of Object.keys(configPart)){\n                        configPart[objectKey] = setDefaults(elements, configPart[objectKey]);\n                    }\n                }\n            }\n        } else if (isOrdinaryObject(schemaPart)) {\n            // Since schemaPart has no property \"_type\", if it's an ordinary object\n            // (unlike, importantly, the validators array), we assume it is a parent config property.\n            // We recurse to config[key] and schema[key]. Default config[key] to {}.\n            const selectedConfigPart = configPart ?? {};\n            // There will have been a validation error already if configPart is not a plain object.\n            if (isOrdinaryObject(selectedConfigPart)) {\n                config[key] = setDefaults(schemaPart, selectedConfigPart);\n            }\n        }\n    }\n    return config;\n};\nfunction hasObjectSchema(elementsSchema) {\n    return !!elementsSchema && Object.keys(elementsSchema).filter((e)=>![\n            '_default',\n            '_validators'\n        ].includes(e)).length > 0;\n}\nfunction isOrdinaryObject(value) {\n    return typeof value === 'object' && !Array.isArray(value) && value !== null;\n}\n/** Keep track of which validation errors we have displayed. Each one should only be displayed once. */ let displayedValidationMessages = new Set();\nfunction logError(keyPath, message) {\n    const key = `${keyPath}:::${message}`;\n    // technically, this should not be possible, but because of how things wind-up transpiled, this isn't impossible\n    if (!displayedValidationMessages) {\n        displayedValidationMessages = new Set();\n    }\n    if (!displayedValidationMessages.has(key)) {\n        console.error(message);\n        displayedValidationMessages.add(key);\n    }\n}\n/**\n * Normally, configuration errors are only displayed once. This function clears the list of\n * displayed errors, so that they will be displayed again.\n *\n * @internal\n */ export function clearConfigErrors(keyPath) {\n    if (keyPath) {\n        displayedValidationMessages.forEach((key)=>{\n            if (key.startsWith(keyPath)) {\n                displayedValidationMessages.delete(key);\n            }\n        });\n    } else {\n        displayedValidationMessages.clear();\n    }\n}\n/**\n * Cleans up all config store subscriptions and re-establishes them. This is primarily\n * useful for testing, where subscriptions set up at module load time need to be cleared\n * between tests to prevent infinite update loops. After clearing, subscriptions are\n * re-established so the config system continues to work normally.\n *\n * @internal\n */ export function resetConfigSystem() {\n    configSubscriptions.forEach((unsubscribe)=>unsubscribe());\n    configSubscriptions.length = 0;\n    setupConfigSubscriptions();\n}\n/**\n * Copied over from esm-extensions. It rightly belongs to that module, but esm-config\n * cannot depend on esm-extensions.\n */ function getExtensionNameFromId(extensionId) {\n    const [extensionName] = extensionId.split('#');\n    return extensionName;\n}\n/**\n * The translation overrides schema is used in the implicit schema given to every module;\n * plus any additional translation namespaces (at time of writing, this is just 'core').\n */ const translationOverridesSchema = {\n    'Translation overrides': {\n        _description: 'Per-language overrides for frontend translations should be keyed by language code and each language dictionary contains the translation key and the display value',\n        _type: Type.Object,\n        _default: {},\n        _validators: [\n            validator((o)=>Object.keys(o).every((k)=>/^[a-z]{2,3}(-[A-Z]{2,3})?$/.test(k)), (o)=>{\n                const badKeys = Object.keys(o).filter((k)=>!/^[a-z]{2,3}(-[A-Z]{2,3})?$/.test(k));\n                return `The 'Translation overrides' object should have language codes for keys. Language codes must be in the form of a two-to-three letter language code optionally followed by a hyphen and a two-to-three letter country code. The following keys do not conform: ${badKeys.join(', ')}.`;\n            })\n        ]\n    }\n};\n/**\n * The implicitConfigSchema is implicitly included in every configuration schema\n */ const implicitConfigSchema = {\n    'Display conditions': {\n        privileges: {\n            _description: 'The privilege(s) the user must have to use this extension',\n            _type: Type.Array,\n            _default: []\n        },\n        expression: {\n            _description: 'The expression that determines whether the extension is displayed',\n            _type: Type.String,\n            _default: undefined\n        }\n    },\n    ...translationOverridesSchema\n};\n"],"names":["clone","equals","reduce","mergeDeepRight","omit","Type","isArray","isBoolean","isUuid","isNumber","isObject","isString","validator","configExtensionStore","configInternalStore","getConfigStore","getExtensionConfig","getExtensionSlotsConfigStore","getExtensionsConfigStore","implementerToolsConfigStore","temporaryConfigStore","configSubscriptions","recomputeAllConfigs","configState","getState","tempConfigState","extensionState","computeModuleConfig","computeImplementerToolsConfig","computeExtensionSlotConfigs","computeExtensionConfigs","setupConfigSubscriptions","push","subscribe","state","tempState","moduleName","Object","keys","schemas","moduleStore","newState","moduleLoaded","config","getConfigForModule","translationOverridesLoaded","loaded","getConfigForModuleImplicitSchema","setState","slotConfigs","getExtensionSlotConfigs","newSlotStoreEntries","fromEntries","entries","map","slotName","slotStore","oldState","slots","getImplementerToolsConfig","configs","extension","mountedExtensions","computeExtensionConfig","slotModuleName","extensionModuleName","extensionId","extensionsConfigStore","defineConfigSchema","schema","validateConfigSchema","enhancedSchema","implicitConfigSchema","registerModuleWithConfigSystem","registerModuleLoad","registerTranslationNamespace","namespace","translationOverridesSchema","defineExtensionConfigSchema","extensionName","console","error","provide","sourceName","providedConfigs","source","getConfig","Promise","resolve","store","update","unsubscribe","getTranslationOverrides","promises","configStore","translationOverrides","all","processConfig","providedConfig","keyPathContext","validateStructure","setDefaults","runAllValidatorsInConfigTree","getExtensionNameFromId","extensionConfigSchema","nameOfSchemaSource","getProvidedConfigs","slotModuleConfig","mergeConfigsFor","configOverride","extensionSlots","configure","extensionConfig","combinedConfig","mergeConfigs","result","getSchemaWithValuesAndSources","configsAndSources","c","createValuesAndSourcesTree","hasOwnProperty","_value","_default","_source","isOrdinaryObject","obj","key","allConfigs","slotConfigPerModule","validateAllExtensionSlotConfigs","configBySlotName","validateExtensionSlotConfig","keyPath","errorPrefix","invalidKeys","filter","k","includes","length","logError","join","add","Array","every","n","remove","order","updateMessage","startsWith","thisKeyPath","schemaPart","elements","_elements","hasObjectSchema","_validators","valueType","_type","values","JSON","stringify","inputConfig","allConfigsForModule","mergeDeepAll","value","validateBranchStructure","checkType","validateFreeformObjectStructure","validateArrayStructure","freeformObjectSchema","arraySchema","validatedAsArray","i","runValidators","Boolean","ConceptUuid","Number","String","UUID","PersonAttributeTypeUuid","PatientIdentifierTypeUuid","validators","returnValue","validatorResult","message","e","configPart","configWithDefaults","conf","objectKey","selectedConfigPart","elementsSchema","displayedValidationMessages","Set","has","clearConfigErrors","forEach","delete","clear","resetConfigSystem","split","_description","o","test","badKeys","privileges","expression","undefined"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-config/dist/module-config/module-config.js\n");
159
159
 
160
160
  /***/ }),
161
161
 
@@ -165,7 +165,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
165
165
  \**************************************************************/
166
166
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
167
167
 
168
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ configExtensionStore: () => (/* binding */ configExtensionStore),\n/* harmony export */ configInternalStore: () => (/* binding */ configInternalStore),\n/* harmony export */ getConfigStore: () => (/* binding */ getConfigStore),\n/* harmony export */ getExtensionConfig: () => (/* binding */ getExtensionConfig),\n/* harmony export */ getExtensionConfigFromExtensionSlotStore: () => (/* binding */ getExtensionConfigFromExtensionSlotStore),\n/* harmony export */ getExtensionConfigFromStore: () => (/* binding */ getExtensionConfigFromStore),\n/* harmony export */ getExtensionSlotConfig: () => (/* binding */ getExtensionSlotConfig),\n/* harmony export */ getExtensionSlotConfigFromStore: () => (/* binding */ getExtensionSlotConfigFromStore),\n/* harmony export */ getExtensionSlotsConfigStore: () => (/* binding */ getExtensionSlotsConfigStore),\n/* harmony export */ getExtensionsConfigStore: () => (/* binding */ getExtensionsConfigStore),\n/* harmony export */ implementerToolsConfigStore: () => (/* binding */ implementerToolsConfigStore),\n/* harmony export */ temporaryConfigStore: () => (/* binding */ temporaryConfigStore)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-state */ \"../../framework/esm-state/dist/index.js\");\n/* harmony import */ var _openmrs_esm_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-utils */ \"../../framework/esm-utils/dist/shallowEqual.js\");\n\n\nconst configInternalStoreInitialValue = {\n providedConfigs: [],\n schemas: {},\n moduleLoaded: {}\n};\n/**\n * @internal\n */ const configInternalStore = (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__.createGlobalStore)('config-internal', configInternalStoreInitialValue);\n/** @internal */ const temporaryConfigStore = (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__.createGlobalStore)('temporary-config', {\n config: getTemporaryConfig()\n});\ntemporaryConfigStore.subscribe((state)=>{\n setTemporaryConfig(state.config);\n});\nfunction setTemporaryConfig(value) {\n localStorage.setItem('openmrs:temporaryConfig', JSON.stringify(value));\n}\nfunction getTemporaryConfig() {\n try {\n return JSON.parse(localStorage.getItem('openmrs:temporaryConfig') || '{}');\n } catch (e) {\n return {};\n }\n}\n/** @internal */ const configExtensionStore = (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__.createGlobalStore)('config-store-of-extension-state', {\n mountedExtensions: []\n});\nfunction initializeConfigStore() {\n return {\n config: null,\n loaded: false,\n translationOverridesLoaded: false\n };\n}\n/** @internal */ function getConfigStore(moduleName) {\n // We use a store for each module's config, named `config-module-${moduleName}`\n return (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__.getGlobalStore)(`config-module-${moduleName}`, initializeConfigStore());\n}\n/** @internal */ function getExtensionSlotsConfigStore() {\n return (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__.getGlobalStore)(`config-extension-slots`, {\n slots: {}\n });\n}\n/** @internal */ function getExtensionSlotConfig(slotName) {\n return getExtensionSlotConfigFromStore(getExtensionSlotsConfigStore().getState(), slotName);\n}\n/** @internal */ function getExtensionSlotConfigFromStore(state, slotName) {\n const slotConfig = state.slots[slotName];\n return slotConfig ?? {\n loaded: false,\n config: {}\n };\n}\n/**\n * One store for all the extensions\n * @internal\n */ function getExtensionsConfigStore() {\n return (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__.getGlobalStore)(`config-extensions`, {\n configs: {}\n });\n}\n/** @internal */ function getExtensionConfig(slotName, extensionId) {\n if (typeof slotName !== 'string' || typeof extensionId !== 'string' || slotName === '__proto__' || extensionId === '__proto__' || slotName === 'constructor' || extensionId === 'constructor' || slotName === 'prototype' || extensionId === 'prototype') {\n throw new Error('Attempted to call `getExtensionConfig()` with invalid argument');\n }\n const extensionConfigStore = getExtensionsConfigStore();\n const selector = (configStore)=>configStore.configs[slotName]?.[extensionId];\n return {\n getInitialState () {\n return selector(extensionConfigStore.getInitialState());\n },\n getState () {\n return selector(extensionConfigStore.getState()) ?? {\n loaded: false,\n config: null\n };\n },\n setState (partial, replace = false) {\n extensionConfigStore.setState((state)=>{\n if (!state.configs[slotName]) {\n state.configs[slotName] = {};\n }\n const newState = typeof partial === 'function' ? partial(state.configs.slotName[extensionId]) : partial;\n if (replace) {\n state.configs[slotName][extensionId] = Object.assign({}, newState);\n } else {\n state.configs[slotName][extensionId] = Object.assign({}, state.configs[slotName][extensionId], newState);\n }\n return state;\n });\n },\n subscribe (listener) {\n return extensionConfigStore.subscribe((state, prevState)=>{\n const newState = selector(state);\n const oldState = selector(prevState);\n if (!(0,_openmrs_esm_utils__WEBPACK_IMPORTED_MODULE_1__.shallowEqual)(newState, oldState)) {\n listener(newState, oldState);\n }\n });\n },\n destroy () {\n /* this is a no-op */ }\n };\n}\n/** @internal */ function getExtensionConfigFromStore(state, slotName, extensionId) {\n const extensionConfig = state.configs[slotName]?.[extensionId];\n return extensionConfig ?? {\n loaded: false,\n config: null\n };\n}\n/** @internal */ function getExtensionConfigFromExtensionSlotStore(state, slotName, extensionId) {\n const extensionConfig = state.configure?.[extensionId];\n return extensionConfig ?? null;\n}\n/** @internal */ const implementerToolsConfigStore = (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__.createGlobalStore)('config-implementer-tools', {\n config: {}\n});\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-config/dist/module-config/state.js","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-config/dist/module-config/state.js?e900"],"sourcesContent":["import { createGlobalStore, getGlobalStore } from \"@openmrs/esm-state\";\nimport { shallowEqual } from \"@openmrs/esm-utils\";\nconst configInternalStoreInitialValue = {\n    providedConfigs: [],\n    schemas: {},\n    moduleLoaded: {}\n};\n/**\n * @internal\n */ export const configInternalStore = createGlobalStore('config-internal', configInternalStoreInitialValue);\n/** @internal */ export const temporaryConfigStore = createGlobalStore('temporary-config', {\n    config: getTemporaryConfig()\n});\ntemporaryConfigStore.subscribe((state)=>{\n    setTemporaryConfig(state.config);\n});\nfunction setTemporaryConfig(value) {\n    localStorage.setItem('openmrs:temporaryConfig', JSON.stringify(value));\n}\nfunction getTemporaryConfig() {\n    try {\n        return JSON.parse(localStorage.getItem('openmrs:temporaryConfig') || '{}');\n    } catch (e) {\n        return {};\n    }\n}\n/** @internal */ export const configExtensionStore = createGlobalStore('config-store-of-extension-state', {\n    mountedExtensions: []\n});\nfunction initializeConfigStore() {\n    return {\n        config: null,\n        loaded: false,\n        translationOverridesLoaded: false\n    };\n}\n/** @internal */ export function getConfigStore(moduleName) {\n    // We use a store for each module's config, named `config-module-${moduleName}`\n    return getGlobalStore(`config-module-${moduleName}`, initializeConfigStore());\n}\n/** @internal */ export function getExtensionSlotsConfigStore() {\n    return getGlobalStore(`config-extension-slots`, {\n        slots: {}\n    });\n}\n/** @internal */ export function getExtensionSlotConfig(slotName) {\n    return getExtensionSlotConfigFromStore(getExtensionSlotsConfigStore().getState(), slotName);\n}\n/** @internal */ export function getExtensionSlotConfigFromStore(state, slotName) {\n    const slotConfig = state.slots[slotName];\n    return slotConfig ?? {\n        loaded: false,\n        config: {}\n    };\n}\n/**\n * One store for all the extensions\n * @internal\n */ export function getExtensionsConfigStore() {\n    return getGlobalStore(`config-extensions`, {\n        configs: {}\n    });\n}\n/** @internal */ export function getExtensionConfig(slotName, extensionId) {\n    if (typeof slotName !== 'string' || typeof extensionId !== 'string' || slotName === '__proto__' || extensionId === '__proto__' || slotName === 'constructor' || extensionId === 'constructor' || slotName === 'prototype' || extensionId === 'prototype') {\n        throw new Error('Attempted to call `getExtensionConfig()` with invalid argument');\n    }\n    const extensionConfigStore = getExtensionsConfigStore();\n    const selector = (configStore)=>configStore.configs[slotName]?.[extensionId];\n    return {\n        getInitialState () {\n            return selector(extensionConfigStore.getInitialState());\n        },\n        getState () {\n            return selector(extensionConfigStore.getState()) ?? {\n                loaded: false,\n                config: null\n            };\n        },\n        setState (partial, replace = false) {\n            extensionConfigStore.setState((state)=>{\n                if (!state.configs[slotName]) {\n                    state.configs[slotName] = {};\n                }\n                const newState = typeof partial === 'function' ? partial(state.configs.slotName[extensionId]) : partial;\n                if (replace) {\n                    state.configs[slotName][extensionId] = Object.assign({}, newState);\n                } else {\n                    state.configs[slotName][extensionId] = Object.assign({}, state.configs[slotName][extensionId], newState);\n                }\n                return state;\n            });\n        },\n        subscribe (listener) {\n            return extensionConfigStore.subscribe((state, prevState)=>{\n                const newState = selector(state);\n                const oldState = selector(prevState);\n                if (!shallowEqual(newState, oldState)) {\n                    listener(newState, oldState);\n                }\n            });\n        },\n        destroy () {\n        /* this is a no-op */ }\n    };\n}\n/** @internal */ export function getExtensionConfigFromStore(state, slotName, extensionId) {\n    const extensionConfig = state.configs[slotName]?.[extensionId];\n    return extensionConfig ?? {\n        loaded: false,\n        config: null\n    };\n}\n/** @internal */ export function getExtensionConfigFromExtensionSlotStore(state, slotName, extensionId) {\n    const extensionConfig = state.configure?.[extensionId];\n    return extensionConfig ?? null;\n}\n/** @internal */ export const implementerToolsConfigStore = createGlobalStore('config-implementer-tools', {\n    config: {}\n});\n"],"names":["createGlobalStore","getGlobalStore","shallowEqual","configInternalStoreInitialValue","providedConfigs","schemas","moduleLoaded","configInternalStore","temporaryConfigStore","config","getTemporaryConfig","subscribe","state","setTemporaryConfig","value","localStorage","setItem","JSON","stringify","parse","getItem","e","configExtensionStore","mountedExtensions","initializeConfigStore","loaded","translationOverridesLoaded","getConfigStore","moduleName","getExtensionSlotsConfigStore","slots","getExtensionSlotConfig","slotName","getExtensionSlotConfigFromStore","getState","slotConfig","getExtensionsConfigStore","configs","getExtensionConfig","extensionId","Error","extensionConfigStore","selector","configStore","getInitialState","setState","partial","replace","newState","Object","assign","listener","prevState","oldState","destroy","getExtensionConfigFromStore","extensionConfig","getExtensionConfigFromExtensionSlotStore","configure","implementerToolsConfigStore"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-config/dist/module-config/state.js\n");
168
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ configExtensionStore: () => (/* binding */ configExtensionStore),\n/* harmony export */ configInternalStore: () => (/* binding */ configInternalStore),\n/* harmony export */ getConfigStore: () => (/* binding */ getConfigStore),\n/* harmony export */ getExtensionConfig: () => (/* binding */ getExtensionConfig),\n/* harmony export */ getExtensionConfigFromExtensionSlotStore: () => (/* binding */ getExtensionConfigFromExtensionSlotStore),\n/* harmony export */ getExtensionConfigFromStore: () => (/* binding */ getExtensionConfigFromStore),\n/* harmony export */ getExtensionSlotConfig: () => (/* binding */ getExtensionSlotConfig),\n/* harmony export */ getExtensionSlotConfigFromStore: () => (/* binding */ getExtensionSlotConfigFromStore),\n/* harmony export */ getExtensionSlotsConfigStore: () => (/* binding */ getExtensionSlotsConfigStore),\n/* harmony export */ getExtensionsConfigStore: () => (/* binding */ getExtensionsConfigStore),\n/* harmony export */ implementerToolsConfigStore: () => (/* binding */ implementerToolsConfigStore),\n/* harmony export */ temporaryConfigStore: () => (/* binding */ temporaryConfigStore)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-state */ \"../../framework/esm-state/dist/index.js\");\n/* harmony import */ var _openmrs_esm_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-utils */ \"../../framework/esm-utils/dist/shallowEqual.js\");\n\n\nconst configInternalStoreInitialValue = {\n providedConfigs: [],\n schemas: {},\n moduleLoaded: {}\n};\n/**\n * @internal\n */ const configInternalStore = (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__.createGlobalStore)('config-internal', configInternalStoreInitialValue);\n/** @internal */ const temporaryConfigStore = (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__.createGlobalStore)('temporary-config', {\n config: getTemporaryConfig()\n});\ntemporaryConfigStore.subscribe((state)=>{\n setTemporaryConfig(state.config);\n});\nfunction setTemporaryConfig(value) {\n localStorage.setItem('openmrs:temporaryConfig', JSON.stringify(value));\n}\nfunction getTemporaryConfig() {\n try {\n return JSON.parse(localStorage.getItem('openmrs:temporaryConfig') || '{}');\n } catch (e) {\n return {};\n }\n}\n/** @internal */ const configExtensionStore = (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__.createGlobalStore)('config-store-of-extension-state', {\n mountedExtensions: []\n});\nfunction initializeConfigStore() {\n return {\n config: null,\n loaded: false,\n translationOverridesLoaded: false\n };\n}\n/**\n * Returns the configuration store for a specific module. Each module has its\n * own store that tracks the loading state and resolved configuration values.\n *\n * @param moduleName The name of the module whose config store to retrieve.\n * @returns A Zustand store containing the module's configuration state.\n *\n * @internal\n */ function getConfigStore(moduleName) {\n // We use a store for each module's config, named `config-module-${moduleName}`\n return (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__.getGlobalStore)(`config-module-${moduleName}`, initializeConfigStore());\n}\n/** @internal */ function getExtensionSlotsConfigStore() {\n return (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__.getGlobalStore)(`config-extension-slots`, {\n slots: {}\n });\n}\n/** @internal */ function getExtensionSlotConfig(slotName) {\n return getExtensionSlotConfigFromStore(getExtensionSlotsConfigStore().getState(), slotName);\n}\n/** @internal */ function getExtensionSlotConfigFromStore(state, slotName) {\n const slotConfig = state.slots[slotName];\n return slotConfig ?? {\n loaded: false,\n config: {}\n };\n}\n/**\n * One store for all the extensions\n * @internal\n */ function getExtensionsConfigStore() {\n return (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__.getGlobalStore)(`config-extensions`, {\n configs: {}\n });\n}\n/** @internal */ function getExtensionConfig(slotName, extensionId) {\n if (typeof slotName !== 'string' || typeof extensionId !== 'string' || slotName === '__proto__' || extensionId === '__proto__' || slotName === 'constructor' || extensionId === 'constructor' || slotName === 'prototype' || extensionId === 'prototype') {\n throw new Error('Attempted to call `getExtensionConfig()` with invalid argument');\n }\n const extensionConfigStore = getExtensionsConfigStore();\n const selector = (configStore)=>configStore.configs[slotName]?.[extensionId];\n return {\n getInitialState () {\n return selector(extensionConfigStore.getInitialState());\n },\n getState () {\n return selector(extensionConfigStore.getState()) ?? {\n loaded: false,\n config: null\n };\n },\n setState (partial, replace = false) {\n extensionConfigStore.setState((state)=>{\n if (!state.configs[slotName]) {\n state.configs[slotName] = {};\n }\n const newState = typeof partial === 'function' ? partial(state.configs.slotName[extensionId]) : partial;\n if (replace) {\n state.configs[slotName][extensionId] = Object.assign({}, newState);\n } else {\n state.configs[slotName][extensionId] = Object.assign({}, state.configs[slotName][extensionId], newState);\n }\n return state;\n });\n },\n subscribe (listener) {\n return extensionConfigStore.subscribe((state, prevState)=>{\n const newState = selector(state);\n const oldState = selector(prevState);\n if (!(0,_openmrs_esm_utils__WEBPACK_IMPORTED_MODULE_1__.shallowEqual)(newState, oldState)) {\n listener(newState, oldState);\n }\n });\n },\n destroy () {\n /* this is a no-op */ }\n };\n}\n/** @internal */ function getExtensionConfigFromStore(state, slotName, extensionId) {\n const extensionConfig = state.configs[slotName]?.[extensionId];\n return extensionConfig ?? {\n loaded: false,\n config: null\n };\n}\n/** @internal */ function getExtensionConfigFromExtensionSlotStore(state, slotName, extensionId) {\n const extensionConfig = state.configure?.[extensionId];\n return extensionConfig ?? null;\n}\n/** @internal */ const implementerToolsConfigStore = (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__.createGlobalStore)('config-implementer-tools', {\n config: {}\n});\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-config/dist/module-config/state.js","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-config/dist/module-config/state.js?e900"],"sourcesContent":["import { createGlobalStore, getGlobalStore } from \"@openmrs/esm-state\";\nimport { shallowEqual } from \"@openmrs/esm-utils\";\nconst configInternalStoreInitialValue = {\n    providedConfigs: [],\n    schemas: {},\n    moduleLoaded: {}\n};\n/**\n * @internal\n */ export const configInternalStore = createGlobalStore('config-internal', configInternalStoreInitialValue);\n/** @internal */ export const temporaryConfigStore = createGlobalStore('temporary-config', {\n    config: getTemporaryConfig()\n});\ntemporaryConfigStore.subscribe((state)=>{\n    setTemporaryConfig(state.config);\n});\nfunction setTemporaryConfig(value) {\n    localStorage.setItem('openmrs:temporaryConfig', JSON.stringify(value));\n}\nfunction getTemporaryConfig() {\n    try {\n        return JSON.parse(localStorage.getItem('openmrs:temporaryConfig') || '{}');\n    } catch (e) {\n        return {};\n    }\n}\n/** @internal */ export const configExtensionStore = createGlobalStore('config-store-of-extension-state', {\n    mountedExtensions: []\n});\nfunction initializeConfigStore() {\n    return {\n        config: null,\n        loaded: false,\n        translationOverridesLoaded: false\n    };\n}\n/**\n * Returns the configuration store for a specific module. Each module has its\n * own store that tracks the loading state and resolved configuration values.\n *\n * @param moduleName The name of the module whose config store to retrieve.\n * @returns A Zustand store containing the module's configuration state.\n *\n * @internal\n */ export function getConfigStore(moduleName) {\n    // We use a store for each module's config, named `config-module-${moduleName}`\n    return getGlobalStore(`config-module-${moduleName}`, initializeConfigStore());\n}\n/** @internal */ export function getExtensionSlotsConfigStore() {\n    return getGlobalStore(`config-extension-slots`, {\n        slots: {}\n    });\n}\n/** @internal */ export function getExtensionSlotConfig(slotName) {\n    return getExtensionSlotConfigFromStore(getExtensionSlotsConfigStore().getState(), slotName);\n}\n/** @internal */ export function getExtensionSlotConfigFromStore(state, slotName) {\n    const slotConfig = state.slots[slotName];\n    return slotConfig ?? {\n        loaded: false,\n        config: {}\n    };\n}\n/**\n * One store for all the extensions\n * @internal\n */ export function getExtensionsConfigStore() {\n    return getGlobalStore(`config-extensions`, {\n        configs: {}\n    });\n}\n/** @internal */ export function getExtensionConfig(slotName, extensionId) {\n    if (typeof slotName !== 'string' || typeof extensionId !== 'string' || slotName === '__proto__' || extensionId === '__proto__' || slotName === 'constructor' || extensionId === 'constructor' || slotName === 'prototype' || extensionId === 'prototype') {\n        throw new Error('Attempted to call `getExtensionConfig()` with invalid argument');\n    }\n    const extensionConfigStore = getExtensionsConfigStore();\n    const selector = (configStore)=>configStore.configs[slotName]?.[extensionId];\n    return {\n        getInitialState () {\n            return selector(extensionConfigStore.getInitialState());\n        },\n        getState () {\n            return selector(extensionConfigStore.getState()) ?? {\n                loaded: false,\n                config: null\n            };\n        },\n        setState (partial, replace = false) {\n            extensionConfigStore.setState((state)=>{\n                if (!state.configs[slotName]) {\n                    state.configs[slotName] = {};\n                }\n                const newState = typeof partial === 'function' ? partial(state.configs.slotName[extensionId]) : partial;\n                if (replace) {\n                    state.configs[slotName][extensionId] = Object.assign({}, newState);\n                } else {\n                    state.configs[slotName][extensionId] = Object.assign({}, state.configs[slotName][extensionId], newState);\n                }\n                return state;\n            });\n        },\n        subscribe (listener) {\n            return extensionConfigStore.subscribe((state, prevState)=>{\n                const newState = selector(state);\n                const oldState = selector(prevState);\n                if (!shallowEqual(newState, oldState)) {\n                    listener(newState, oldState);\n                }\n            });\n        },\n        destroy () {\n        /* this is a no-op */ }\n    };\n}\n/** @internal */ export function getExtensionConfigFromStore(state, slotName, extensionId) {\n    const extensionConfig = state.configs[slotName]?.[extensionId];\n    return extensionConfig ?? {\n        loaded: false,\n        config: null\n    };\n}\n/** @internal */ export function getExtensionConfigFromExtensionSlotStore(state, slotName, extensionId) {\n    const extensionConfig = state.configure?.[extensionId];\n    return extensionConfig ?? null;\n}\n/** @internal */ export const implementerToolsConfigStore = createGlobalStore('config-implementer-tools', {\n    config: {}\n});\n"],"names":["createGlobalStore","getGlobalStore","shallowEqual","configInternalStoreInitialValue","providedConfigs","schemas","moduleLoaded","configInternalStore","temporaryConfigStore","config","getTemporaryConfig","subscribe","state","setTemporaryConfig","value","localStorage","setItem","JSON","stringify","parse","getItem","e","configExtensionStore","mountedExtensions","initializeConfigStore","loaded","translationOverridesLoaded","getConfigStore","moduleName","getExtensionSlotsConfigStore","slots","getExtensionSlotConfig","slotName","getExtensionSlotConfigFromStore","getState","slotConfig","getExtensionsConfigStore","configs","getExtensionConfig","extensionId","Error","extensionConfigStore","selector","configStore","getInitialState","setState","partial","replace","newState","Object","assign","listener","prevState","oldState","destroy","getExtensionConfigFromStore","extensionConfig","getExtensionConfigFromExtensionSlotStore","configure","implementerToolsConfigStore"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-config/dist/module-config/state.js\n");
169
169
 
170
170
  /***/ }),
171
171
 
@@ -205,7 +205,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
205
205
  \****************************************************************/
206
206
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
207
207
 
208
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ inRange: () => (/* binding */ inRange),\n/* harmony export */ isUrl: () => (/* binding */ isUrl),\n/* harmony export */ isUrlWithTemplateParameters: () => (/* binding */ isUrlWithTemplateParameters),\n/* harmony export */ oneOf: () => (/* binding */ oneOf),\n/* harmony export */ validators: () => (/* binding */ validators)\n/* harmony export */ });\n/* harmony import */ var _validator_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validator.js */ \"../../framework/esm-config/dist/validators/validator.js\");\n/** @module @category Config Validation */ \n/**\n * Verifies that the value is between the provided minimum and maximum\n *\n * @param min Minimum acceptable value\n * @param max Maximum acceptable value\n */ const inRange = (min, max)=>{\n return (0,_validator_js__WEBPACK_IMPORTED_MODULE_0__.validator)((val)=>min <= val && val <= max, `must be between ${min} and ${max}`);\n};\n/**\n * Verifies that a string contains only the default URL template\n * parameters, plus any specified in `allowedTemplateParameters`.\n *\n * @param allowedTemplateParameters To be added to `openmrsBase` and `openmrsSpaBase`\n * @category Navigation\n */ const isUrlWithTemplateParameters = (allowedTemplateParameters)=>{\n const allowedParams = allowedTemplateParameters.concat([\n 'openmrsBase',\n 'openmrsSpaBase'\n ]);\n return (0,_validator_js__WEBPACK_IMPORTED_MODULE_0__.validator)((val)=>{\n if (!val || typeof val != 'string') {\n return false;\n }\n const rx = /\\${(.*?)}/g;\n let match = rx.exec(val);\n while(match){\n if (!allowedParams.includes(match[1])) {\n return false;\n }\n match = rx.exec(val);\n }\n return true;\n }, 'Should be a URL or path. The allowed template parameters are ' + allowedParams.map((p)=>'${' + p + '}').join(', '));\n};\n/**\n * Verifies that a string contains only the default URL template parameters.\n *\n * @category Navigation\n */ const isUrl = isUrlWithTemplateParameters([]);\n/**\n * Verifies that the value is one of the allowed options.\n * @param allowedValues The list of allowable values\n */ const oneOf = (allowedValues)=>{\n return (0,_validator_js__WEBPACK_IMPORTED_MODULE_0__.validator)((val)=>allowedValues.includes(val), `Must be one of the following: '${allowedValues.join(\"', '\")}'.`);\n};\nconst validators = {\n inRange,\n isUrl,\n isUrlWithTemplateParameters,\n oneOf\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1jb25maWcvZGlzdC92YWxpZGF0b3JzL3ZhbGlkYXRvcnMuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUEsd0NBQXdDLEdBQThDO0FBQ3RGOzs7OztDQUtDLEdBQVUsTUFBTUMsVUFBVSxDQUFDQyxLQUFLQztJQUM3QixPQUFPSCx3REFBU0EsQ0FBQyxDQUFDSSxNQUFNRixPQUFPRSxPQUFPQSxPQUFPRCxLQUFLLENBQUMsZ0JBQWdCLEVBQUVELElBQUksS0FBSyxFQUFFQyxLQUFLO0FBQ3pGLEVBQUU7QUFDRjs7Ozs7O0NBTUMsR0FBVSxNQUFNRSw4QkFBOEIsQ0FBQ0M7SUFDNUMsTUFBTUMsZ0JBQWdCRCwwQkFBMEJFLE1BQU0sQ0FBQztRQUNuRDtRQUNBO0tBQ0g7SUFDRCxPQUFPUix3REFBU0EsQ0FBQyxDQUFDSTtRQUNkLElBQUksQ0FBQ0EsT0FBTyxPQUFPQSxPQUFPLFVBQVU7WUFDaEMsT0FBTztRQUNYO1FBQ0EsTUFBTUssS0FBSztRQUNYLElBQUlDLFFBQVFELEdBQUdFLElBQUksQ0FBQ1A7UUFDcEIsTUFBTU0sTUFBTTtZQUNSLElBQUksQ0FBQ0gsY0FBY0ssUUFBUSxDQUFDRixLQUFLLENBQUMsRUFBRSxHQUFHO2dCQUNuQyxPQUFPO1lBQ1g7WUFDQUEsUUFBUUQsR0FBR0UsSUFBSSxDQUFDUDtRQUNwQjtRQUNBLE9BQU87SUFDWCxHQUFHLGtFQUFrRUcsY0FBY00sR0FBRyxDQUFDLENBQUNDLElBQUksT0FBT0EsSUFBSSxLQUFLQyxJQUFJLENBQUM7QUFDckgsRUFBRTtBQUNGOzs7O0NBSUMsR0FBVSxNQUFNQyxRQUFRWCw0QkFBNEIsRUFBRSxFQUFFO0FBQ3pEOzs7Q0FHQyxHQUFVLE1BQU1ZLFFBQVEsQ0FBQ0M7SUFDdEIsT0FBT2xCLHdEQUFTQSxDQUFDLENBQUNJLE1BQU1jLGNBQWNOLFFBQVEsQ0FBQ1IsTUFBTSxDQUFDLCtCQUErQixFQUFFYyxjQUFjSCxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7QUFDekgsRUFBRTtBQUNLLE1BQU1JLGFBQWE7SUFDdEJsQjtJQUNBZTtJQUNBWDtJQUNBWTtBQUNKLEVBQUUiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tY29uZmlnL2Rpc3QvdmFsaWRhdG9ycy92YWxpZGF0b3JzLmpzPzJmYjAiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBtb2R1bGUgQGNhdGVnb3J5IENvbmZpZyBWYWxpZGF0aW9uICovIGltcG9ydCB7IHZhbGlkYXRvciB9IGZyb20gXCIuL3ZhbGlkYXRvci5qc1wiO1xuLyoqXG4gKiBWZXJpZmllcyB0aGF0IHRoZSB2YWx1ZSBpcyBiZXR3ZWVuIHRoZSBwcm92aWRlZCBtaW5pbXVtIGFuZCBtYXhpbXVtXG4gKlxuICogQHBhcmFtIG1pbiBNaW5pbXVtIGFjY2VwdGFibGUgdmFsdWVcbiAqIEBwYXJhbSBtYXggTWF4aW11bSBhY2NlcHRhYmxlIHZhbHVlXG4gKi8gZXhwb3J0IGNvbnN0IGluUmFuZ2UgPSAobWluLCBtYXgpPT57XG4gICAgcmV0dXJuIHZhbGlkYXRvcigodmFsKT0+bWluIDw9IHZhbCAmJiB2YWwgPD0gbWF4LCBgbXVzdCBiZSBiZXR3ZWVuICR7bWlufSBhbmQgJHttYXh9YCk7XG59O1xuLyoqXG4gKiBWZXJpZmllcyB0aGF0IGEgc3RyaW5nIGNvbnRhaW5zIG9ubHkgdGhlIGRlZmF1bHQgVVJMIHRlbXBsYXRlXG4gKiBwYXJhbWV0ZXJzLCBwbHVzIGFueSBzcGVjaWZpZWQgaW4gYGFsbG93ZWRUZW1wbGF0ZVBhcmFtZXRlcnNgLlxuICpcbiAqIEBwYXJhbSBhbGxvd2VkVGVtcGxhdGVQYXJhbWV0ZXJzIFRvIGJlIGFkZGVkIHRvIGBvcGVubXJzQmFzZWAgYW5kIGBvcGVubXJzU3BhQmFzZWBcbiAqIEBjYXRlZ29yeSBOYXZpZ2F0aW9uXG4gKi8gZXhwb3J0IGNvbnN0IGlzVXJsV2l0aFRlbXBsYXRlUGFyYW1ldGVycyA9IChhbGxvd2VkVGVtcGxhdGVQYXJhbWV0ZXJzKT0+e1xuICAgIGNvbnN0IGFsbG93ZWRQYXJhbXMgPSBhbGxvd2VkVGVtcGxhdGVQYXJhbWV0ZXJzLmNvbmNhdChbXG4gICAgICAgICdvcGVubXJzQmFzZScsXG4gICAgICAgICdvcGVubXJzU3BhQmFzZSdcbiAgICBdKTtcbiAgICByZXR1cm4gdmFsaWRhdG9yKCh2YWwpPT57XG4gICAgICAgIGlmICghdmFsIHx8IHR5cGVvZiB2YWwgIT0gJ3N0cmluZycpIHtcbiAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgfVxuICAgICAgICBjb25zdCByeCA9IC9cXCR7KC4qPyl9L2c7XG4gICAgICAgIGxldCBtYXRjaCA9IHJ4LmV4ZWModmFsKTtcbiAgICAgICAgd2hpbGUobWF0Y2gpe1xuICAgICAgICAgICAgaWYgKCFhbGxvd2VkUGFyYW1zLmluY2x1ZGVzKG1hdGNoWzFdKSkge1xuICAgICAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIG1hdGNoID0gcnguZXhlYyh2YWwpO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgIH0sICdTaG91bGQgYmUgYSBVUkwgb3IgcGF0aC4gVGhlIGFsbG93ZWQgdGVtcGxhdGUgcGFyYW1ldGVycyBhcmUgJyArIGFsbG93ZWRQYXJhbXMubWFwKChwKT0+JyR7JyArIHAgKyAnfScpLmpvaW4oJywgJykpO1xufTtcbi8qKlxuICogVmVyaWZpZXMgdGhhdCBhIHN0cmluZyBjb250YWlucyBvbmx5IHRoZSBkZWZhdWx0IFVSTCB0ZW1wbGF0ZSBwYXJhbWV0ZXJzLlxuICpcbiAqIEBjYXRlZ29yeSBOYXZpZ2F0aW9uXG4gKi8gZXhwb3J0IGNvbnN0IGlzVXJsID0gaXNVcmxXaXRoVGVtcGxhdGVQYXJhbWV0ZXJzKFtdKTtcbi8qKlxuICogVmVyaWZpZXMgdGhhdCB0aGUgdmFsdWUgaXMgb25lIG9mIHRoZSBhbGxvd2VkIG9wdGlvbnMuXG4gKiBAcGFyYW0gYWxsb3dlZFZhbHVlcyBUaGUgbGlzdCBvZiBhbGxvd2FibGUgdmFsdWVzXG4gKi8gZXhwb3J0IGNvbnN0IG9uZU9mID0gKGFsbG93ZWRWYWx1ZXMpPT57XG4gICAgcmV0dXJuIHZhbGlkYXRvcigodmFsKT0+YWxsb3dlZFZhbHVlcy5pbmNsdWRlcyh2YWwpLCBgTXVzdCBiZSBvbmUgb2YgdGhlIGZvbGxvd2luZzogJyR7YWxsb3dlZFZhbHVlcy5qb2luKFwiJywgJ1wiKX0nLmApO1xufTtcbmV4cG9ydCBjb25zdCB2YWxpZGF0b3JzID0ge1xuICAgIGluUmFuZ2UsXG4gICAgaXNVcmwsXG4gICAgaXNVcmxXaXRoVGVtcGxhdGVQYXJhbWV0ZXJzLFxuICAgIG9uZU9mXG59O1xuIl0sIm5hbWVzIjpbInZhbGlkYXRvciIsImluUmFuZ2UiLCJtaW4iLCJtYXgiLCJ2YWwiLCJpc1VybFdpdGhUZW1wbGF0ZVBhcmFtZXRlcnMiLCJhbGxvd2VkVGVtcGxhdGVQYXJhbWV0ZXJzIiwiYWxsb3dlZFBhcmFtcyIsImNvbmNhdCIsInJ4IiwibWF0Y2giLCJleGVjIiwiaW5jbHVkZXMiLCJtYXAiLCJwIiwiam9pbiIsImlzVXJsIiwib25lT2YiLCJhbGxvd2VkVmFsdWVzIiwidmFsaWRhdG9ycyJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///../../framework/esm-config/dist/validators/validators.js\n");
208
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ inRange: () => (/* binding */ inRange),\n/* harmony export */ isUrl: () => (/* binding */ isUrl),\n/* harmony export */ isUrlWithTemplateParameters: () => (/* binding */ isUrlWithTemplateParameters),\n/* harmony export */ oneOf: () => (/* binding */ oneOf),\n/* harmony export */ validators: () => (/* binding */ validators)\n/* harmony export */ });\n/* harmony import */ var _validator_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./validator.js */ \"../../framework/esm-config/dist/validators/validator.js\");\n/** @module @category Config Validation */ \n/**\n * Verifies that the value is between the provided minimum and maximum\n *\n * @param min Minimum acceptable value\n * @param max Maximum acceptable value\n * @returns A validator function that checks if a value is within the specified range.\n */ const inRange = (min, max)=>{\n return (0,_validator_js__WEBPACK_IMPORTED_MODULE_0__.validator)((val)=>min <= val && val <= max, `must be between ${min} and ${max}`);\n};\n/**\n * Verifies that a string contains only the default URL template\n * parameters, plus any specified in `allowedTemplateParameters`.\n *\n * @param allowedTemplateParameters To be added to `openmrsBase` and `openmrsSpaBase`\n * @returns A validator function that checks if a URL contains only allowed template parameters.\n * @category Navigation\n */ const isUrlWithTemplateParameters = (allowedTemplateParameters)=>{\n const allowedParams = allowedTemplateParameters.concat([\n 'openmrsBase',\n 'openmrsSpaBase'\n ]);\n return (0,_validator_js__WEBPACK_IMPORTED_MODULE_0__.validator)((val)=>{\n if (!val || typeof val != 'string') {\n return false;\n }\n const rx = /\\${(.*?)}/g;\n let match = rx.exec(val);\n while(match){\n if (!allowedParams.includes(match[1])) {\n return false;\n }\n match = rx.exec(val);\n }\n return true;\n }, 'Should be a URL or path. The allowed template parameters are ' + allowedParams.map((p)=>'${' + p + '}').join(', '));\n};\n/**\n * Verifies that a string contains only the default URL template parameters.\n *\n * @category Navigation\n */ const isUrl = isUrlWithTemplateParameters([]);\n/**\n * Verifies that the value is one of the allowed options.\n *\n * @param allowedValues The list of allowable values\n * @returns A validator function that checks if a value is in the allowed list.\n */ const oneOf = (allowedValues)=>{\n return (0,_validator_js__WEBPACK_IMPORTED_MODULE_0__.validator)((val)=>allowedValues.includes(val), `Must be one of the following: '${allowedValues.join(\"', '\")}'.`);\n};\nconst validators = {\n inRange,\n isUrl,\n isUrlWithTemplateParameters,\n oneOf\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1jb25maWcvZGlzdC92YWxpZGF0b3JzL3ZhbGlkYXRvcnMuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUEsd0NBQXdDLEdBQThDO0FBQ3RGOzs7Ozs7Q0FNQyxHQUFVLE1BQU1DLFVBQVUsQ0FBQ0MsS0FBS0M7SUFDN0IsT0FBT0gsd0RBQVNBLENBQUMsQ0FBQ0ksTUFBTUYsT0FBT0UsT0FBT0EsT0FBT0QsS0FBSyxDQUFDLGdCQUFnQixFQUFFRCxJQUFJLEtBQUssRUFBRUMsS0FBSztBQUN6RixFQUFFO0FBQ0Y7Ozs7Ozs7Q0FPQyxHQUFVLE1BQU1FLDhCQUE4QixDQUFDQztJQUM1QyxNQUFNQyxnQkFBZ0JELDBCQUEwQkUsTUFBTSxDQUFDO1FBQ25EO1FBQ0E7S0FDSDtJQUNELE9BQU9SLHdEQUFTQSxDQUFDLENBQUNJO1FBQ2QsSUFBSSxDQUFDQSxPQUFPLE9BQU9BLE9BQU8sVUFBVTtZQUNoQyxPQUFPO1FBQ1g7UUFDQSxNQUFNSyxLQUFLO1FBQ1gsSUFBSUMsUUFBUUQsR0FBR0UsSUFBSSxDQUFDUDtRQUNwQixNQUFNTSxNQUFNO1lBQ1IsSUFBSSxDQUFDSCxjQUFjSyxRQUFRLENBQUNGLEtBQUssQ0FBQyxFQUFFLEdBQUc7Z0JBQ25DLE9BQU87WUFDWDtZQUNBQSxRQUFRRCxHQUFHRSxJQUFJLENBQUNQO1FBQ3BCO1FBQ0EsT0FBTztJQUNYLEdBQUcsa0VBQWtFRyxjQUFjTSxHQUFHLENBQUMsQ0FBQ0MsSUFBSSxPQUFPQSxJQUFJLEtBQUtDLElBQUksQ0FBQztBQUNySCxFQUFFO0FBQ0Y7Ozs7Q0FJQyxHQUFVLE1BQU1DLFFBQVFYLDRCQUE0QixFQUFFLEVBQUU7QUFDekQ7Ozs7O0NBS0MsR0FBVSxNQUFNWSxRQUFRLENBQUNDO0lBQ3RCLE9BQU9sQix3REFBU0EsQ0FBQyxDQUFDSSxNQUFNYyxjQUFjTixRQUFRLENBQUNSLE1BQU0sQ0FBQywrQkFBK0IsRUFBRWMsY0FBY0gsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO0FBQ3pILEVBQUU7QUFDSyxNQUFNSSxhQUFhO0lBQ3RCbEI7SUFDQWU7SUFDQVg7SUFDQVk7QUFDSixFQUFFIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQG9wZW5tcnMvZXNtLWFwcC1zaGVsbC8uLi8uLi9mcmFtZXdvcmsvZXNtLWNvbmZpZy9kaXN0L3ZhbGlkYXRvcnMvdmFsaWRhdG9ycy5qcz8yZmIwIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBAbW9kdWxlIEBjYXRlZ29yeSBDb25maWcgVmFsaWRhdGlvbiAqLyBpbXBvcnQgeyB2YWxpZGF0b3IgfSBmcm9tIFwiLi92YWxpZGF0b3IuanNcIjtcbi8qKlxuICogVmVyaWZpZXMgdGhhdCB0aGUgdmFsdWUgaXMgYmV0d2VlbiB0aGUgcHJvdmlkZWQgbWluaW11bSBhbmQgbWF4aW11bVxuICpcbiAqIEBwYXJhbSBtaW4gTWluaW11bSBhY2NlcHRhYmxlIHZhbHVlXG4gKiBAcGFyYW0gbWF4IE1heGltdW0gYWNjZXB0YWJsZSB2YWx1ZVxuICogQHJldHVybnMgQSB2YWxpZGF0b3IgZnVuY3Rpb24gdGhhdCBjaGVja3MgaWYgYSB2YWx1ZSBpcyB3aXRoaW4gdGhlIHNwZWNpZmllZCByYW5nZS5cbiAqLyBleHBvcnQgY29uc3QgaW5SYW5nZSA9IChtaW4sIG1heCk9PntcbiAgICByZXR1cm4gdmFsaWRhdG9yKCh2YWwpPT5taW4gPD0gdmFsICYmIHZhbCA8PSBtYXgsIGBtdXN0IGJlIGJldHdlZW4gJHttaW59IGFuZCAke21heH1gKTtcbn07XG4vKipcbiAqIFZlcmlmaWVzIHRoYXQgYSBzdHJpbmcgY29udGFpbnMgb25seSB0aGUgZGVmYXVsdCBVUkwgdGVtcGxhdGVcbiAqIHBhcmFtZXRlcnMsIHBsdXMgYW55IHNwZWNpZmllZCBpbiBgYWxsb3dlZFRlbXBsYXRlUGFyYW1ldGVyc2AuXG4gKlxuICogQHBhcmFtIGFsbG93ZWRUZW1wbGF0ZVBhcmFtZXRlcnMgVG8gYmUgYWRkZWQgdG8gYG9wZW5tcnNCYXNlYCBhbmQgYG9wZW5tcnNTcGFCYXNlYFxuICogQHJldHVybnMgQSB2YWxpZGF0b3IgZnVuY3Rpb24gdGhhdCBjaGVja3MgaWYgYSBVUkwgY29udGFpbnMgb25seSBhbGxvd2VkIHRlbXBsYXRlIHBhcmFtZXRlcnMuXG4gKiBAY2F0ZWdvcnkgTmF2aWdhdGlvblxuICovIGV4cG9ydCBjb25zdCBpc1VybFdpdGhUZW1wbGF0ZVBhcmFtZXRlcnMgPSAoYWxsb3dlZFRlbXBsYXRlUGFyYW1ldGVycyk9PntcbiAgICBjb25zdCBhbGxvd2VkUGFyYW1zID0gYWxsb3dlZFRlbXBsYXRlUGFyYW1ldGVycy5jb25jYXQoW1xuICAgICAgICAnb3Blbm1yc0Jhc2UnLFxuICAgICAgICAnb3Blbm1yc1NwYUJhc2UnXG4gICAgXSk7XG4gICAgcmV0dXJuIHZhbGlkYXRvcigodmFsKT0+e1xuICAgICAgICBpZiAoIXZhbCB8fCB0eXBlb2YgdmFsICE9ICdzdHJpbmcnKSB7XG4gICAgICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICAgIH1cbiAgICAgICAgY29uc3QgcnggPSAvXFwkeyguKj8pfS9nO1xuICAgICAgICBsZXQgbWF0Y2ggPSByeC5leGVjKHZhbCk7XG4gICAgICAgIHdoaWxlKG1hdGNoKXtcbiAgICAgICAgICAgIGlmICghYWxsb3dlZFBhcmFtcy5pbmNsdWRlcyhtYXRjaFsxXSkpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBtYXRjaCA9IHJ4LmV4ZWModmFsKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9LCAnU2hvdWxkIGJlIGEgVVJMIG9yIHBhdGguIFRoZSBhbGxvd2VkIHRlbXBsYXRlIHBhcmFtZXRlcnMgYXJlICcgKyBhbGxvd2VkUGFyYW1zLm1hcCgocCk9PickeycgKyBwICsgJ30nKS5qb2luKCcsICcpKTtcbn07XG4vKipcbiAqIFZlcmlmaWVzIHRoYXQgYSBzdHJpbmcgY29udGFpbnMgb25seSB0aGUgZGVmYXVsdCBVUkwgdGVtcGxhdGUgcGFyYW1ldGVycy5cbiAqXG4gKiBAY2F0ZWdvcnkgTmF2aWdhdGlvblxuICovIGV4cG9ydCBjb25zdCBpc1VybCA9IGlzVXJsV2l0aFRlbXBsYXRlUGFyYW1ldGVycyhbXSk7XG4vKipcbiAqIFZlcmlmaWVzIHRoYXQgdGhlIHZhbHVlIGlzIG9uZSBvZiB0aGUgYWxsb3dlZCBvcHRpb25zLlxuICpcbiAqIEBwYXJhbSBhbGxvd2VkVmFsdWVzIFRoZSBsaXN0IG9mIGFsbG93YWJsZSB2YWx1ZXNcbiAqIEByZXR1cm5zIEEgdmFsaWRhdG9yIGZ1bmN0aW9uIHRoYXQgY2hlY2tzIGlmIGEgdmFsdWUgaXMgaW4gdGhlIGFsbG93ZWQgbGlzdC5cbiAqLyBleHBvcnQgY29uc3Qgb25lT2YgPSAoYWxsb3dlZFZhbHVlcyk9PntcbiAgICByZXR1cm4gdmFsaWRhdG9yKCh2YWwpPT5hbGxvd2VkVmFsdWVzLmluY2x1ZGVzKHZhbCksIGBNdXN0IGJlIG9uZSBvZiB0aGUgZm9sbG93aW5nOiAnJHthbGxvd2VkVmFsdWVzLmpvaW4oXCInLCAnXCIpfScuYCk7XG59O1xuZXhwb3J0IGNvbnN0IHZhbGlkYXRvcnMgPSB7XG4gICAgaW5SYW5nZSxcbiAgICBpc1VybCxcbiAgICBpc1VybFdpdGhUZW1wbGF0ZVBhcmFtZXRlcnMsXG4gICAgb25lT2Zcbn07XG4iXSwibmFtZXMiOlsidmFsaWRhdG9yIiwiaW5SYW5nZSIsIm1pbiIsIm1heCIsInZhbCIsImlzVXJsV2l0aFRlbXBsYXRlUGFyYW1ldGVycyIsImFsbG93ZWRUZW1wbGF0ZVBhcmFtZXRlcnMiLCJhbGxvd2VkUGFyYW1zIiwiY29uY2F0IiwicngiLCJtYXRjaCIsImV4ZWMiLCJpbmNsdWRlcyIsIm1hcCIsInAiLCJqb2luIiwiaXNVcmwiLCJvbmVPZiIsImFsbG93ZWRWYWx1ZXMiLCJ2YWxpZGF0b3JzIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///../../framework/esm-config/dist/validators/validators.js\n");
209
209
 
210
210
  /***/ }),
211
211
 
@@ -215,7 +215,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
215
215
  \***************************************************/
216
216
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
217
217
 
218
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ contextStore: () => (/* binding */ contextStore),\n/* harmony export */ getContext: () => (/* binding */ getContext),\n/* harmony export */ registerContext: () => (/* binding */ registerContext),\n/* harmony export */ subscribeToContext: () => (/* binding */ subscribeToContext),\n/* harmony export */ unregisterContext: () => (/* binding */ unregisterContext),\n/* harmony export */ updateContext: () => (/* binding */ updateContext)\n/* harmony export */ });\n/* harmony import */ var zustand_vanilla__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! zustand/vanilla */ \"../../../node_modules/zustand/esm/vanilla.mjs\");\n/* harmony import */ var _openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-state */ \"../../framework/esm-state/dist/index.js\");\n/** @module @category Context */ \n\n\n/**\n * @internal\n *\n * The application context store, using immer to potentially simplify updates\n */ const contextStore = (0,zustand_vanilla__WEBPACK_IMPORTED_MODULE_1__.createStore)()(()=>({}));\n(0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__.registerGlobalStore)('openmrs-app-context', contextStore);\nconst nothing = Object();\n/**\n * Used by callers to register a new namespace in the application context. Attempting to register\n * an already-registered namespace will display a warning and make no modifications to the state.\n *\n * @param namespace the namespace to register\n * @param initialValue the initial value of the namespace\n */ function registerContext(namespace, initialValue = nothing) {\n contextStore.setState((state)=>{\n if (namespace in state) {\n throw new Error(`Attempted to re-register namespace ${namespace} in the app context. Each namespace must be unregistered before the name can be registered again.`);\n }\n return Object.assign({}, state, {\n [namespace]: initialValue === nothing ? {} : initialValue\n });\n });\n}\n/**\n * Used by caller to unregister a namespace in the application context. Unregistering a namespace\n * will remove the namespace and all associated data.\n */ function unregisterContext(namespace) {\n contextStore.setState((state)=>{\n if (namespace in state) {\n delete state[namespace];\n }\n return state;\n });\n}\n/**\n * Returns an _immutable_ version of the state of the namespace as it is currently\n *\n * @typeParam T The type of the value stored in the namespace\n * @typeParam U The return type of this hook which is mostly relevant when using a selector\n * @param namespace The namespace to load properties from\n * @param selector An optional function which extracts the relevant part of the state\n */ function getContext(namespace, selector = (state)=>state) {\n const state = contextStore.getState();\n if (namespace in state) {\n return Object.freeze(Object.assign({}, selector ? selector(state[namespace]) : state[namespace]));\n }\n return null;\n}\n/**\n * Updates a namespace in the global context. If the namespace does not exist, it is registered.\n */ function updateContext(namespace, update) {\n contextStore.setState((state)=>{\n if (!(namespace in state)) {\n state[namespace] = {};\n }\n state[namespace] = update(state[namespace]);\n return Object.assign({}, state);\n });\n}\n/**\n * Subscribes to updates of a given namespace. Note that the returned object is immutable.\n *\n * @param namespace the namespace to subscribe to\n * @param callback a function invoked with the current context whenever\n * @returns A function to unsubscribe from the context\n */ function subscribeToContext(namespace, callback) {\n let previous = getContext(namespace);\n // set initial value\n callback(Object.freeze(Object.assign({}, previous)));\n return contextStore.subscribe((state)=>{\n let current = namespace in state ? state[namespace] : null;\n if (current !== previous) {\n previous = current;\n callback(Object.freeze(Object.assign({}, current)));\n }\n });\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1jb250ZXh0L2Rpc3QvY29udGV4dC5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUFBLDhCQUE4QixHQUFnQjtBQUNBO0FBQ1c7QUFDekQ7Ozs7Q0FJQyxHQUFVLE1BQU1FLGVBQWVGLDREQUFXQSxHQUFHLElBQUssRUFBQyxJQUFJO0FBQ3hEQyx1RUFBbUJBLENBQUMsdUJBQXVCQztBQUMzQyxNQUFNQyxVQUFVQztBQUNoQjs7Ozs7O0NBTUMsR0FBVSxTQUFTQyxnQkFBZ0JDLFNBQVMsRUFBRUMsZUFBZUosT0FBTztJQUNqRUQsYUFBYU0sUUFBUSxDQUFDLENBQUNDO1FBQ25CLElBQUlILGFBQWFHLE9BQU87WUFDcEIsTUFBTSxJQUFJQyxNQUFNLENBQUMsbUNBQW1DLEVBQUVKLFVBQVUsaUdBQWlHLENBQUM7UUFDdEs7UUFDQSxPQUFPRixPQUFPTyxNQUFNLENBQUMsQ0FBQyxHQUFHRixPQUFPO1lBQzVCLENBQUNILFVBQVUsRUFBRUMsaUJBQWlCSixVQUFVLENBQUMsSUFBSUk7UUFDakQ7SUFDSjtBQUNKO0FBQ0E7OztDQUdDLEdBQVUsU0FBU0ssa0JBQWtCTixTQUFTO0lBQzNDSixhQUFhTSxRQUFRLENBQUMsQ0FBQ0M7UUFDbkIsSUFBSUgsYUFBYUcsT0FBTztZQUNwQixPQUFPQSxLQUFLLENBQUNILFVBQVU7UUFDM0I7UUFDQSxPQUFPRztJQUNYO0FBQ0o7QUFDQTs7Ozs7OztDQU9DLEdBQVUsU0FBU0ksV0FBV1AsU0FBUyxFQUFFUSxXQUFXLENBQUNMLFFBQVFBLEtBQUs7SUFDL0QsTUFBTUEsUUFBUVAsYUFBYWEsUUFBUTtJQUNuQyxJQUFJVCxhQUFhRyxPQUFPO1FBQ3BCLE9BQU9MLE9BQU9ZLE1BQU0sQ0FBQ1osT0FBT08sTUFBTSxDQUFDLENBQUMsR0FBR0csV0FBV0EsU0FBU0wsS0FBSyxDQUFDSCxVQUFVLElBQUlHLEtBQUssQ0FBQ0gsVUFBVTtJQUNuRztJQUNBLE9BQU87QUFDWDtBQUNBOztDQUVDLEdBQVUsU0FBU1csY0FBY1gsU0FBUyxFQUFFWSxNQUFNO0lBQy9DaEIsYUFBYU0sUUFBUSxDQUFDLENBQUNDO1FBQ25CLElBQUksQ0FBRUgsQ0FBQUEsYUFBYUcsS0FBSSxHQUFJO1lBQ3ZCQSxLQUFLLENBQUNILFVBQVUsR0FBRyxDQUFDO1FBQ3hCO1FBQ0FHLEtBQUssQ0FBQ0gsVUFBVSxHQUFHWSxPQUFPVCxLQUFLLENBQUNILFVBQVU7UUFDMUMsT0FBT0YsT0FBT08sTUFBTSxDQUFDLENBQUMsR0FBR0Y7SUFDN0I7QUFDSjtBQUNBOzs7Ozs7Q0FNQyxHQUFVLFNBQVNVLG1CQUFtQmIsU0FBUyxFQUFFYyxRQUFRO0lBQ3RELElBQUlDLFdBQVdSLFdBQVdQO0lBQzFCLG9CQUFvQjtJQUNwQmMsU0FBU2hCLE9BQU9ZLE1BQU0sQ0FBQ1osT0FBT08sTUFBTSxDQUFDLENBQUMsR0FBR1U7SUFDekMsT0FBT25CLGFBQWFvQixTQUFTLENBQUMsQ0FBQ2I7UUFDM0IsSUFBSWMsVUFBVWpCLGFBQWFHLFFBQVFBLEtBQUssQ0FBQ0gsVUFBVSxHQUFHO1FBQ3RELElBQUlpQixZQUFZRixVQUFVO1lBQ3RCQSxXQUFXRTtZQUNYSCxTQUFTaEIsT0FBT1ksTUFBTSxDQUFDWixPQUFPTyxNQUFNLENBQUMsQ0FBQyxHQUFHWTtRQUM3QztJQUNKO0FBQ0oiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tY29udGV4dC9kaXN0L2NvbnRleHQuanM/ZWViOSJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQG1vZHVsZSBAY2F0ZWdvcnkgQ29udGV4dCAqLyAndXNlIHN0cmljdCc7XG5pbXBvcnQgeyBjcmVhdGVTdG9yZSB9IGZyb20gXCJ6dXN0YW5kL3ZhbmlsbGFcIjtcbmltcG9ydCB7IHJlZ2lzdGVyR2xvYmFsU3RvcmUgfSBmcm9tIFwiQG9wZW5tcnMvZXNtLXN0YXRlXCI7XG4vKipcbiAqIEBpbnRlcm5hbFxuICpcbiAqIFRoZSBhcHBsaWNhdGlvbiBjb250ZXh0IHN0b3JlLCB1c2luZyBpbW1lciB0byBwb3RlbnRpYWxseSBzaW1wbGlmeSB1cGRhdGVzXG4gKi8gZXhwb3J0IGNvbnN0IGNvbnRleHRTdG9yZSA9IGNyZWF0ZVN0b3JlKCkoKCk9Pih7fSkpO1xucmVnaXN0ZXJHbG9iYWxTdG9yZSgnb3Blbm1ycy1hcHAtY29udGV4dCcsIGNvbnRleHRTdG9yZSk7XG5jb25zdCBub3RoaW5nID0gT2JqZWN0KCk7XG4vKipcbiAqIFVzZWQgYnkgY2FsbGVycyB0byByZWdpc3RlciBhIG5ldyBuYW1lc3BhY2UgaW4gdGhlIGFwcGxpY2F0aW9uIGNvbnRleHQuIEF0dGVtcHRpbmcgdG8gcmVnaXN0ZXJcbiAqIGFuIGFscmVhZHktcmVnaXN0ZXJlZCBuYW1lc3BhY2Ugd2lsbCBkaXNwbGF5IGEgd2FybmluZyBhbmQgbWFrZSBubyBtb2RpZmljYXRpb25zIHRvIHRoZSBzdGF0ZS5cbiAqXG4gKiBAcGFyYW0gbmFtZXNwYWNlIHRoZSBuYW1lc3BhY2UgdG8gcmVnaXN0ZXJcbiAqIEBwYXJhbSBpbml0aWFsVmFsdWUgdGhlIGluaXRpYWwgdmFsdWUgb2YgdGhlIG5hbWVzcGFjZVxuICovIGV4cG9ydCBmdW5jdGlvbiByZWdpc3RlckNvbnRleHQobmFtZXNwYWNlLCBpbml0aWFsVmFsdWUgPSBub3RoaW5nKSB7XG4gICAgY29udGV4dFN0b3JlLnNldFN0YXRlKChzdGF0ZSk9PntcbiAgICAgICAgaWYgKG5hbWVzcGFjZSBpbiBzdGF0ZSkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBBdHRlbXB0ZWQgdG8gcmUtcmVnaXN0ZXIgbmFtZXNwYWNlICR7bmFtZXNwYWNlfSBpbiB0aGUgYXBwIGNvbnRleHQuIEVhY2ggbmFtZXNwYWNlIG11c3QgYmUgdW5yZWdpc3RlcmVkIGJlZm9yZSB0aGUgbmFtZSBjYW4gYmUgcmVnaXN0ZXJlZCBhZ2Fpbi5gKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gT2JqZWN0LmFzc2lnbih7fSwgc3RhdGUsIHtcbiAgICAgICAgICAgIFtuYW1lc3BhY2VdOiBpbml0aWFsVmFsdWUgPT09IG5vdGhpbmcgPyB7fSA6IGluaXRpYWxWYWx1ZVxuICAgICAgICB9KTtcbiAgICB9KTtcbn1cbi8qKlxuICogVXNlZCBieSBjYWxsZXIgdG8gdW5yZWdpc3RlciBhIG5hbWVzcGFjZSBpbiB0aGUgYXBwbGljYXRpb24gY29udGV4dC4gVW5yZWdpc3RlcmluZyBhIG5hbWVzcGFjZVxuICogd2lsbCByZW1vdmUgdGhlIG5hbWVzcGFjZSBhbmQgYWxsIGFzc29jaWF0ZWQgZGF0YS5cbiAqLyBleHBvcnQgZnVuY3Rpb24gdW5yZWdpc3RlckNvbnRleHQobmFtZXNwYWNlKSB7XG4gICAgY29udGV4dFN0b3JlLnNldFN0YXRlKChzdGF0ZSk9PntcbiAgICAgICAgaWYgKG5hbWVzcGFjZSBpbiBzdGF0ZSkge1xuICAgICAgICAgICAgZGVsZXRlIHN0YXRlW25hbWVzcGFjZV07XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHN0YXRlO1xuICAgIH0pO1xufVxuLyoqXG4gKiBSZXR1cm5zIGFuIF9pbW11dGFibGVfIHZlcnNpb24gb2YgdGhlIHN0YXRlIG9mIHRoZSBuYW1lc3BhY2UgYXMgaXQgaXMgY3VycmVudGx5XG4gKlxuICogQHR5cGVQYXJhbSBUIFRoZSB0eXBlIG9mIHRoZSB2YWx1ZSBzdG9yZWQgaW4gdGhlIG5hbWVzcGFjZVxuICogQHR5cGVQYXJhbSBVIFRoZSByZXR1cm4gdHlwZSBvZiB0aGlzIGhvb2sgd2hpY2ggaXMgbW9zdGx5IHJlbGV2YW50IHdoZW4gdXNpbmcgYSBzZWxlY3RvclxuICogQHBhcmFtIG5hbWVzcGFjZSBUaGUgbmFtZXNwYWNlIHRvIGxvYWQgcHJvcGVydGllcyBmcm9tXG4gKiBAcGFyYW0gc2VsZWN0b3IgQW4gb3B0aW9uYWwgZnVuY3Rpb24gd2hpY2ggZXh0cmFjdHMgdGhlIHJlbGV2YW50IHBhcnQgb2YgdGhlIHN0YXRlXG4gKi8gZXhwb3J0IGZ1bmN0aW9uIGdldENvbnRleHQobmFtZXNwYWNlLCBzZWxlY3RvciA9IChzdGF0ZSk9PnN0YXRlKSB7XG4gICAgY29uc3Qgc3RhdGUgPSBjb250ZXh0U3RvcmUuZ2V0U3RhdGUoKTtcbiAgICBpZiAobmFtZXNwYWNlIGluIHN0YXRlKSB7XG4gICAgICAgIHJldHVybiBPYmplY3QuZnJlZXplKE9iamVjdC5hc3NpZ24oe30sIHNlbGVjdG9yID8gc2VsZWN0b3Ioc3RhdGVbbmFtZXNwYWNlXSkgOiBzdGF0ZVtuYW1lc3BhY2VdKSk7XG4gICAgfVxuICAgIHJldHVybiBudWxsO1xufVxuLyoqXG4gKiBVcGRhdGVzIGEgbmFtZXNwYWNlIGluIHRoZSBnbG9iYWwgY29udGV4dC4gSWYgdGhlIG5hbWVzcGFjZSBkb2VzIG5vdCBleGlzdCwgaXQgaXMgcmVnaXN0ZXJlZC5cbiAqLyBleHBvcnQgZnVuY3Rpb24gdXBkYXRlQ29udGV4dChuYW1lc3BhY2UsIHVwZGF0ZSkge1xuICAgIGNvbnRleHRTdG9yZS5zZXRTdGF0ZSgoc3RhdGUpPT57XG4gICAgICAgIGlmICghKG5hbWVzcGFjZSBpbiBzdGF0ZSkpIHtcbiAgICAgICAgICAgIHN0YXRlW25hbWVzcGFjZV0gPSB7fTtcbiAgICAgICAgfVxuICAgICAgICBzdGF0ZVtuYW1lc3BhY2VdID0gdXBkYXRlKHN0YXRlW25hbWVzcGFjZV0pO1xuICAgICAgICByZXR1cm4gT2JqZWN0LmFzc2lnbih7fSwgc3RhdGUpO1xuICAgIH0pO1xufVxuLyoqXG4gKiBTdWJzY3JpYmVzIHRvIHVwZGF0ZXMgb2YgYSBnaXZlbiBuYW1lc3BhY2UuIE5vdGUgdGhhdCB0aGUgcmV0dXJuZWQgb2JqZWN0IGlzIGltbXV0YWJsZS5cbiAqXG4gKiBAcGFyYW0gbmFtZXNwYWNlIHRoZSBuYW1lc3BhY2UgdG8gc3Vic2NyaWJlIHRvXG4gKiBAcGFyYW0gY2FsbGJhY2sgYSBmdW5jdGlvbiBpbnZva2VkIHdpdGggdGhlIGN1cnJlbnQgY29udGV4dCB3aGVuZXZlclxuICogQHJldHVybnMgQSBmdW5jdGlvbiB0byB1bnN1YnNjcmliZSBmcm9tIHRoZSBjb250ZXh0XG4gKi8gZXhwb3J0IGZ1bmN0aW9uIHN1YnNjcmliZVRvQ29udGV4dChuYW1lc3BhY2UsIGNhbGxiYWNrKSB7XG4gICAgbGV0IHByZXZpb3VzID0gZ2V0Q29udGV4dChuYW1lc3BhY2UpO1xuICAgIC8vIHNldCBpbml0aWFsIHZhbHVlXG4gICAgY2FsbGJhY2soT2JqZWN0LmZyZWV6ZShPYmplY3QuYXNzaWduKHt9LCBwcmV2aW91cykpKTtcbiAgICByZXR1cm4gY29udGV4dFN0b3JlLnN1YnNjcmliZSgoc3RhdGUpPT57XG4gICAgICAgIGxldCBjdXJyZW50ID0gbmFtZXNwYWNlIGluIHN0YXRlID8gc3RhdGVbbmFtZXNwYWNlXSA6IG51bGw7XG4gICAgICAgIGlmIChjdXJyZW50ICE9PSBwcmV2aW91cykge1xuICAgICAgICAgICAgcHJldmlvdXMgPSBjdXJyZW50O1xuICAgICAgICAgICAgY2FsbGJhY2soT2JqZWN0LmZyZWV6ZShPYmplY3QuYXNzaWduKHt9LCBjdXJyZW50KSkpO1xuICAgICAgICB9XG4gICAgfSk7XG59XG4iXSwibmFtZXMiOlsiY3JlYXRlU3RvcmUiLCJyZWdpc3Rlckdsb2JhbFN0b3JlIiwiY29udGV4dFN0b3JlIiwibm90aGluZyIsIk9iamVjdCIsInJlZ2lzdGVyQ29udGV4dCIsIm5hbWVzcGFjZSIsImluaXRpYWxWYWx1ZSIsInNldFN0YXRlIiwic3RhdGUiLCJFcnJvciIsImFzc2lnbiIsInVucmVnaXN0ZXJDb250ZXh0IiwiZ2V0Q29udGV4dCIsInNlbGVjdG9yIiwiZ2V0U3RhdGUiLCJmcmVlemUiLCJ1cGRhdGVDb250ZXh0IiwidXBkYXRlIiwic3Vic2NyaWJlVG9Db250ZXh0IiwiY2FsbGJhY2siLCJwcmV2aW91cyIsInN1YnNjcmliZSIsImN1cnJlbnQiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///../../framework/esm-context/dist/context.js\n");
218
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ contextStore: () => (/* binding */ contextStore),\n/* harmony export */ getContext: () => (/* binding */ getContext),\n/* harmony export */ registerContext: () => (/* binding */ registerContext),\n/* harmony export */ subscribeToContext: () => (/* binding */ subscribeToContext),\n/* harmony export */ unregisterContext: () => (/* binding */ unregisterContext),\n/* harmony export */ updateContext: () => (/* binding */ updateContext)\n/* harmony export */ });\n/* harmony import */ var zustand_vanilla__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! zustand/vanilla */ \"../../../node_modules/zustand/esm/vanilla.mjs\");\n/* harmony import */ var _openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-state */ \"../../framework/esm-state/dist/index.js\");\n/** @module @category Context */ \n\n\n/**\n * @internal\n *\n * The application context store, using immer to potentially simplify updates\n */ const contextStore = (0,zustand_vanilla__WEBPACK_IMPORTED_MODULE_1__.createStore)()(()=>({}));\n(0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__.registerGlobalStore)('openmrs-app-context', contextStore);\nconst nothing = Object();\n/**\n * Used by callers to register a new namespace in the application context. Attempting to register\n * an already-registered namespace will display a warning and make no modifications to the state.\n *\n * @param namespace the namespace to register\n * @param initialValue the initial value of the namespace\n */ function registerContext(namespace, initialValue = nothing) {\n contextStore.setState((state)=>{\n if (namespace in state) {\n throw new Error(`Attempted to re-register namespace ${namespace} in the app context. Each namespace must be unregistered before the name can be registered again.`);\n }\n return Object.assign({}, state, {\n [namespace]: initialValue === nothing ? {} : initialValue\n });\n });\n}\n/**\n * Used by caller to unregister a namespace in the application context. Unregistering a namespace\n * will remove the namespace and all associated data.\n */ function unregisterContext(namespace) {\n contextStore.setState((state)=>{\n if (namespace in state) {\n delete state[namespace];\n }\n return state;\n });\n}\n/**\n * Returns an _immutable_ version of the state of the namespace as it is currently\n *\n * @typeParam T The type of the value stored in the namespace\n * @typeParam U The return type of this hook which is mostly relevant when using a selector\n * @param namespace The namespace to load properties from\n * @param selector An optional function which extracts the relevant part of the state\n * @returns The immutable state (or selected portion) of the namespace, or `null` if the namespace is not registered.\n */ function getContext(namespace, selector = (state)=>state) {\n const state = contextStore.getState();\n if (namespace in state) {\n return Object.freeze(Object.assign({}, selector ? selector(state[namespace]) : state[namespace]));\n }\n return null;\n}\n/**\n * Updates a namespace in the global context. If the namespace does not exist, it is registered.\n */ function updateContext(namespace, update) {\n contextStore.setState((state)=>{\n if (!(namespace in state)) {\n state[namespace] = {};\n }\n state[namespace] = update(state[namespace]);\n return Object.assign({}, state);\n });\n}\n/**\n * Subscribes to updates of a given namespace. Note that the returned object is immutable.\n *\n * @param namespace the namespace to subscribe to\n * @param callback a function invoked with the current context whenever\n * @returns A function to unsubscribe from the context\n */ function subscribeToContext(namespace, callback) {\n let previous = getContext(namespace);\n // set initial value\n callback(Object.freeze(Object.assign({}, previous)));\n return contextStore.subscribe((state)=>{\n let current = namespace in state ? state[namespace] : null;\n if (current !== previous) {\n previous = current;\n callback(Object.freeze(Object.assign({}, current)));\n }\n });\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1jb250ZXh0L2Rpc3QvY29udGV4dC5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUFBLDhCQUE4QixHQUFnQjtBQUNBO0FBQ1c7QUFDekQ7Ozs7Q0FJQyxHQUFVLE1BQU1FLGVBQWVGLDREQUFXQSxHQUFHLElBQUssRUFBQyxJQUFJO0FBQ3hEQyx1RUFBbUJBLENBQUMsdUJBQXVCQztBQUMzQyxNQUFNQyxVQUFVQztBQUNoQjs7Ozs7O0NBTUMsR0FBVSxTQUFTQyxnQkFBZ0JDLFNBQVMsRUFBRUMsZUFBZUosT0FBTztJQUNqRUQsYUFBYU0sUUFBUSxDQUFDLENBQUNDO1FBQ25CLElBQUlILGFBQWFHLE9BQU87WUFDcEIsTUFBTSxJQUFJQyxNQUFNLENBQUMsbUNBQW1DLEVBQUVKLFVBQVUsaUdBQWlHLENBQUM7UUFDdEs7UUFDQSxPQUFPRixPQUFPTyxNQUFNLENBQUMsQ0FBQyxHQUFHRixPQUFPO1lBQzVCLENBQUNILFVBQVUsRUFBRUMsaUJBQWlCSixVQUFVLENBQUMsSUFBSUk7UUFDakQ7SUFDSjtBQUNKO0FBQ0E7OztDQUdDLEdBQVUsU0FBU0ssa0JBQWtCTixTQUFTO0lBQzNDSixhQUFhTSxRQUFRLENBQUMsQ0FBQ0M7UUFDbkIsSUFBSUgsYUFBYUcsT0FBTztZQUNwQixPQUFPQSxLQUFLLENBQUNILFVBQVU7UUFDM0I7UUFDQSxPQUFPRztJQUNYO0FBQ0o7QUFDQTs7Ozs7Ozs7Q0FRQyxHQUFVLFNBQVNJLFdBQVdQLFNBQVMsRUFBRVEsV0FBVyxDQUFDTCxRQUFRQSxLQUFLO0lBQy9ELE1BQU1BLFFBQVFQLGFBQWFhLFFBQVE7SUFDbkMsSUFBSVQsYUFBYUcsT0FBTztRQUNwQixPQUFPTCxPQUFPWSxNQUFNLENBQUNaLE9BQU9PLE1BQU0sQ0FBQyxDQUFDLEdBQUdHLFdBQVdBLFNBQVNMLEtBQUssQ0FBQ0gsVUFBVSxJQUFJRyxLQUFLLENBQUNILFVBQVU7SUFDbkc7SUFDQSxPQUFPO0FBQ1g7QUFDQTs7Q0FFQyxHQUFVLFNBQVNXLGNBQWNYLFNBQVMsRUFBRVksTUFBTTtJQUMvQ2hCLGFBQWFNLFFBQVEsQ0FBQyxDQUFDQztRQUNuQixJQUFJLENBQUVILENBQUFBLGFBQWFHLEtBQUksR0FBSTtZQUN2QkEsS0FBSyxDQUFDSCxVQUFVLEdBQUcsQ0FBQztRQUN4QjtRQUNBRyxLQUFLLENBQUNILFVBQVUsR0FBR1ksT0FBT1QsS0FBSyxDQUFDSCxVQUFVO1FBQzFDLE9BQU9GLE9BQU9PLE1BQU0sQ0FBQyxDQUFDLEdBQUdGO0lBQzdCO0FBQ0o7QUFDQTs7Ozs7O0NBTUMsR0FBVSxTQUFTVSxtQkFBbUJiLFNBQVMsRUFBRWMsUUFBUTtJQUN0RCxJQUFJQyxXQUFXUixXQUFXUDtJQUMxQixvQkFBb0I7SUFDcEJjLFNBQVNoQixPQUFPWSxNQUFNLENBQUNaLE9BQU9PLE1BQU0sQ0FBQyxDQUFDLEdBQUdVO0lBQ3pDLE9BQU9uQixhQUFhb0IsU0FBUyxDQUFDLENBQUNiO1FBQzNCLElBQUljLFVBQVVqQixhQUFhRyxRQUFRQSxLQUFLLENBQUNILFVBQVUsR0FBRztRQUN0RCxJQUFJaUIsWUFBWUYsVUFBVTtZQUN0QkEsV0FBV0U7WUFDWEgsU0FBU2hCLE9BQU9ZLE1BQU0sQ0FBQ1osT0FBT08sTUFBTSxDQUFDLENBQUMsR0FBR1k7UUFDN0M7SUFDSjtBQUNKIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQG9wZW5tcnMvZXNtLWFwcC1zaGVsbC8uLi8uLi9mcmFtZXdvcmsvZXNtLWNvbnRleHQvZGlzdC9jb250ZXh0LmpzP2VlYjkiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBtb2R1bGUgQGNhdGVnb3J5IENvbnRleHQgKi8gJ3VzZSBzdHJpY3QnO1xuaW1wb3J0IHsgY3JlYXRlU3RvcmUgfSBmcm9tIFwienVzdGFuZC92YW5pbGxhXCI7XG5pbXBvcnQgeyByZWdpc3Rlckdsb2JhbFN0b3JlIH0gZnJvbSBcIkBvcGVubXJzL2VzbS1zdGF0ZVwiO1xuLyoqXG4gKiBAaW50ZXJuYWxcbiAqXG4gKiBUaGUgYXBwbGljYXRpb24gY29udGV4dCBzdG9yZSwgdXNpbmcgaW1tZXIgdG8gcG90ZW50aWFsbHkgc2ltcGxpZnkgdXBkYXRlc1xuICovIGV4cG9ydCBjb25zdCBjb250ZXh0U3RvcmUgPSBjcmVhdGVTdG9yZSgpKCgpPT4oe30pKTtcbnJlZ2lzdGVyR2xvYmFsU3RvcmUoJ29wZW5tcnMtYXBwLWNvbnRleHQnLCBjb250ZXh0U3RvcmUpO1xuY29uc3Qgbm90aGluZyA9IE9iamVjdCgpO1xuLyoqXG4gKiBVc2VkIGJ5IGNhbGxlcnMgdG8gcmVnaXN0ZXIgYSBuZXcgbmFtZXNwYWNlIGluIHRoZSBhcHBsaWNhdGlvbiBjb250ZXh0LiBBdHRlbXB0aW5nIHRvIHJlZ2lzdGVyXG4gKiBhbiBhbHJlYWR5LXJlZ2lzdGVyZWQgbmFtZXNwYWNlIHdpbGwgZGlzcGxheSBhIHdhcm5pbmcgYW5kIG1ha2Ugbm8gbW9kaWZpY2F0aW9ucyB0byB0aGUgc3RhdGUuXG4gKlxuICogQHBhcmFtIG5hbWVzcGFjZSB0aGUgbmFtZXNwYWNlIHRvIHJlZ2lzdGVyXG4gKiBAcGFyYW0gaW5pdGlhbFZhbHVlIHRoZSBpbml0aWFsIHZhbHVlIG9mIHRoZSBuYW1lc3BhY2VcbiAqLyBleHBvcnQgZnVuY3Rpb24gcmVnaXN0ZXJDb250ZXh0KG5hbWVzcGFjZSwgaW5pdGlhbFZhbHVlID0gbm90aGluZykge1xuICAgIGNvbnRleHRTdG9yZS5zZXRTdGF0ZSgoc3RhdGUpPT57XG4gICAgICAgIGlmIChuYW1lc3BhY2UgaW4gc3RhdGUpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgQXR0ZW1wdGVkIHRvIHJlLXJlZ2lzdGVyIG5hbWVzcGFjZSAke25hbWVzcGFjZX0gaW4gdGhlIGFwcCBjb250ZXh0LiBFYWNoIG5hbWVzcGFjZSBtdXN0IGJlIHVucmVnaXN0ZXJlZCBiZWZvcmUgdGhlIG5hbWUgY2FuIGJlIHJlZ2lzdGVyZWQgYWdhaW4uYCk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIE9iamVjdC5hc3NpZ24oe30sIHN0YXRlLCB7XG4gICAgICAgICAgICBbbmFtZXNwYWNlXTogaW5pdGlhbFZhbHVlID09PSBub3RoaW5nID8ge30gOiBpbml0aWFsVmFsdWVcbiAgICAgICAgfSk7XG4gICAgfSk7XG59XG4vKipcbiAqIFVzZWQgYnkgY2FsbGVyIHRvIHVucmVnaXN0ZXIgYSBuYW1lc3BhY2UgaW4gdGhlIGFwcGxpY2F0aW9uIGNvbnRleHQuIFVucmVnaXN0ZXJpbmcgYSBuYW1lc3BhY2VcbiAqIHdpbGwgcmVtb3ZlIHRoZSBuYW1lc3BhY2UgYW5kIGFsbCBhc3NvY2lhdGVkIGRhdGEuXG4gKi8gZXhwb3J0IGZ1bmN0aW9uIHVucmVnaXN0ZXJDb250ZXh0KG5hbWVzcGFjZSkge1xuICAgIGNvbnRleHRTdG9yZS5zZXRTdGF0ZSgoc3RhdGUpPT57XG4gICAgICAgIGlmIChuYW1lc3BhY2UgaW4gc3RhdGUpIHtcbiAgICAgICAgICAgIGRlbGV0ZSBzdGF0ZVtuYW1lc3BhY2VdO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiBzdGF0ZTtcbiAgICB9KTtcbn1cbi8qKlxuICogUmV0dXJucyBhbiBfaW1tdXRhYmxlXyB2ZXJzaW9uIG9mIHRoZSBzdGF0ZSBvZiB0aGUgbmFtZXNwYWNlIGFzIGl0IGlzIGN1cnJlbnRseVxuICpcbiAqIEB0eXBlUGFyYW0gVCBUaGUgdHlwZSBvZiB0aGUgdmFsdWUgc3RvcmVkIGluIHRoZSBuYW1lc3BhY2VcbiAqIEB0eXBlUGFyYW0gVSBUaGUgcmV0dXJuIHR5cGUgb2YgdGhpcyBob29rIHdoaWNoIGlzIG1vc3RseSByZWxldmFudCB3aGVuIHVzaW5nIGEgc2VsZWN0b3JcbiAqIEBwYXJhbSBuYW1lc3BhY2UgVGhlIG5hbWVzcGFjZSB0byBsb2FkIHByb3BlcnRpZXMgZnJvbVxuICogQHBhcmFtIHNlbGVjdG9yIEFuIG9wdGlvbmFsIGZ1bmN0aW9uIHdoaWNoIGV4dHJhY3RzIHRoZSByZWxldmFudCBwYXJ0IG9mIHRoZSBzdGF0ZVxuICogQHJldHVybnMgVGhlIGltbXV0YWJsZSBzdGF0ZSAob3Igc2VsZWN0ZWQgcG9ydGlvbikgb2YgdGhlIG5hbWVzcGFjZSwgb3IgYG51bGxgIGlmIHRoZSBuYW1lc3BhY2UgaXMgbm90IHJlZ2lzdGVyZWQuXG4gKi8gZXhwb3J0IGZ1bmN0aW9uIGdldENvbnRleHQobmFtZXNwYWNlLCBzZWxlY3RvciA9IChzdGF0ZSk9PnN0YXRlKSB7XG4gICAgY29uc3Qgc3RhdGUgPSBjb250ZXh0U3RvcmUuZ2V0U3RhdGUoKTtcbiAgICBpZiAobmFtZXNwYWNlIGluIHN0YXRlKSB7XG4gICAgICAgIHJldHVybiBPYmplY3QuZnJlZXplKE9iamVjdC5hc3NpZ24oe30sIHNlbGVjdG9yID8gc2VsZWN0b3Ioc3RhdGVbbmFtZXNwYWNlXSkgOiBzdGF0ZVtuYW1lc3BhY2VdKSk7XG4gICAgfVxuICAgIHJldHVybiBudWxsO1xufVxuLyoqXG4gKiBVcGRhdGVzIGEgbmFtZXNwYWNlIGluIHRoZSBnbG9iYWwgY29udGV4dC4gSWYgdGhlIG5hbWVzcGFjZSBkb2VzIG5vdCBleGlzdCwgaXQgaXMgcmVnaXN0ZXJlZC5cbiAqLyBleHBvcnQgZnVuY3Rpb24gdXBkYXRlQ29udGV4dChuYW1lc3BhY2UsIHVwZGF0ZSkge1xuICAgIGNvbnRleHRTdG9yZS5zZXRTdGF0ZSgoc3RhdGUpPT57XG4gICAgICAgIGlmICghKG5hbWVzcGFjZSBpbiBzdGF0ZSkpIHtcbiAgICAgICAgICAgIHN0YXRlW25hbWVzcGFjZV0gPSB7fTtcbiAgICAgICAgfVxuICAgICAgICBzdGF0ZVtuYW1lc3BhY2VdID0gdXBkYXRlKHN0YXRlW25hbWVzcGFjZV0pO1xuICAgICAgICByZXR1cm4gT2JqZWN0LmFzc2lnbih7fSwgc3RhdGUpO1xuICAgIH0pO1xufVxuLyoqXG4gKiBTdWJzY3JpYmVzIHRvIHVwZGF0ZXMgb2YgYSBnaXZlbiBuYW1lc3BhY2UuIE5vdGUgdGhhdCB0aGUgcmV0dXJuZWQgb2JqZWN0IGlzIGltbXV0YWJsZS5cbiAqXG4gKiBAcGFyYW0gbmFtZXNwYWNlIHRoZSBuYW1lc3BhY2UgdG8gc3Vic2NyaWJlIHRvXG4gKiBAcGFyYW0gY2FsbGJhY2sgYSBmdW5jdGlvbiBpbnZva2VkIHdpdGggdGhlIGN1cnJlbnQgY29udGV4dCB3aGVuZXZlclxuICogQHJldHVybnMgQSBmdW5jdGlvbiB0byB1bnN1YnNjcmliZSBmcm9tIHRoZSBjb250ZXh0XG4gKi8gZXhwb3J0IGZ1bmN0aW9uIHN1YnNjcmliZVRvQ29udGV4dChuYW1lc3BhY2UsIGNhbGxiYWNrKSB7XG4gICAgbGV0IHByZXZpb3VzID0gZ2V0Q29udGV4dChuYW1lc3BhY2UpO1xuICAgIC8vIHNldCBpbml0aWFsIHZhbHVlXG4gICAgY2FsbGJhY2soT2JqZWN0LmZyZWV6ZShPYmplY3QuYXNzaWduKHt9LCBwcmV2aW91cykpKTtcbiAgICByZXR1cm4gY29udGV4dFN0b3JlLnN1YnNjcmliZSgoc3RhdGUpPT57XG4gICAgICAgIGxldCBjdXJyZW50ID0gbmFtZXNwYWNlIGluIHN0YXRlID8gc3RhdGVbbmFtZXNwYWNlXSA6IG51bGw7XG4gICAgICAgIGlmIChjdXJyZW50ICE9PSBwcmV2aW91cykge1xuICAgICAgICAgICAgcHJldmlvdXMgPSBjdXJyZW50O1xuICAgICAgICAgICAgY2FsbGJhY2soT2JqZWN0LmZyZWV6ZShPYmplY3QuYXNzaWduKHt9LCBjdXJyZW50KSkpO1xuICAgICAgICB9XG4gICAgfSk7XG59XG4iXSwibmFtZXMiOlsiY3JlYXRlU3RvcmUiLCJyZWdpc3Rlckdsb2JhbFN0b3JlIiwiY29udGV4dFN0b3JlIiwibm90aGluZyIsIk9iamVjdCIsInJlZ2lzdGVyQ29udGV4dCIsIm5hbWVzcGFjZSIsImluaXRpYWxWYWx1ZSIsInNldFN0YXRlIiwic3RhdGUiLCJFcnJvciIsImFzc2lnbiIsInVucmVnaXN0ZXJDb250ZXh0IiwiZ2V0Q29udGV4dCIsInNlbGVjdG9yIiwiZ2V0U3RhdGUiLCJmcmVlemUiLCJ1cGRhdGVDb250ZXh0IiwidXBkYXRlIiwic3Vic2NyaWJlVG9Db250ZXh0IiwiY2FsbGJhY2siLCJwcmV2aW91cyIsInN1YnNjcmliZSIsImN1cnJlbnQiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///../../framework/esm-context/dist/context.js\n");
219
219
 
220
220
  /***/ }),
221
221
 
@@ -225,7 +225,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
225
225
  \*******************************************************/
226
226
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
227
227
 
228
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ attachmentUrl: () => (/* binding */ attachmentUrl),\n/* harmony export */ createAttachment: () => (/* binding */ createAttachment),\n/* harmony export */ deleteAttachmentPermanently: () => (/* binding */ deleteAttachmentPermanently),\n/* harmony export */ getAttachmentByUuid: () => (/* binding */ getAttachmentByUuid),\n/* harmony export */ getAttachments: () => (/* binding */ getAttachments)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-api */ \"../../framework/esm-api/dist/index.js\");\n/** @module @category API */ \nconst attachmentUrl = `${_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.restBaseUrl}/attachment`;\nfunction getAttachmentByUuid(attachmentUuid, abortController) {\n return (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.openmrsFetch)(`${attachmentUrl}/${attachmentUuid}`, {\n signal: abortController.signal\n });\n}\nfunction getAttachments(patientUuid, includeEncounterless, abortController) {\n return (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.openmrsFetch)(`${attachmentUrl}?patient=${patientUuid}&includeEncounterless=${includeEncounterless}`, {\n signal: abortController.signal\n });\n}\nasync function createAttachment(patientUuid, fileToUpload) {\n const formData = new FormData();\n formData.append('fileCaption', fileToUpload.fileDescription);\n formData.append('patient', patientUuid);\n if (fileToUpload.file) {\n formData.append('file', fileToUpload.file, fileToUpload.fileName);\n } else {\n formData.append('file', new File([\n ''\n ], fileToUpload.fileName), fileToUpload.fileName);\n formData.append('base64Content', fileToUpload.base64Content);\n }\n return (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.openmrsFetch)(`${attachmentUrl}`, {\n method: 'POST',\n body: formData\n });\n}\nfunction deleteAttachmentPermanently(attachmentUuid, abortController) {\n return (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.openmrsFetch)(`${attachmentUrl}/${attachmentUuid}`, {\n method: 'DELETE',\n signal: abortController.signal\n });\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1lbXItYXBpL2Rpc3QvYXR0YWNobWVudHMuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUEsMEJBQTBCLEdBQWdFO0FBQ25GLE1BQU1FLGdCQUFnQixHQUFHRCx5REFBV0EsQ0FBQyxXQUFXLENBQUMsQ0FBQztBQUNsRCxTQUFTRSxvQkFBb0JDLGNBQWMsRUFBRUMsZUFBZTtJQUMvRCxPQUFPTCw4REFBWUEsQ0FBQyxHQUFHRSxjQUFjLENBQUMsRUFBRUUsZ0JBQWdCLEVBQUU7UUFDdERFLFFBQVFELGdCQUFnQkMsTUFBTTtJQUNsQztBQUNKO0FBQ08sU0FBU0MsZUFBZUMsV0FBVyxFQUFFQyxvQkFBb0IsRUFBRUosZUFBZTtJQUM3RSxPQUFPTCw4REFBWUEsQ0FBQyxHQUFHRSxjQUFjLFNBQVMsRUFBRU0sWUFBWSxzQkFBc0IsRUFBRUMsc0JBQXNCLEVBQUU7UUFDeEdILFFBQVFELGdCQUFnQkMsTUFBTTtJQUNsQztBQUNKO0FBQ08sZUFBZUksaUJBQWlCRixXQUFXLEVBQUVHLFlBQVk7SUFDNUQsTUFBTUMsV0FBVyxJQUFJQztJQUNyQkQsU0FBU0UsTUFBTSxDQUFDLGVBQWVILGFBQWFJLGVBQWU7SUFDM0RILFNBQVNFLE1BQU0sQ0FBQyxXQUFXTjtJQUMzQixJQUFJRyxhQUFhSyxJQUFJLEVBQUU7UUFDbkJKLFNBQVNFLE1BQU0sQ0FBQyxRQUFRSCxhQUFhSyxJQUFJLEVBQUVMLGFBQWFNLFFBQVE7SUFDcEUsT0FBTztRQUNITCxTQUFTRSxNQUFNLENBQUMsUUFBUSxJQUFJSSxLQUFLO1lBQzdCO1NBQ0gsRUFBRVAsYUFBYU0sUUFBUSxHQUFHTixhQUFhTSxRQUFRO1FBQ2hETCxTQUFTRSxNQUFNLENBQUMsaUJBQWlCSCxhQUFhUSxhQUFhO0lBQy9EO0lBQ0EsT0FBT25CLDhEQUFZQSxDQUFDLEdBQUdFLGVBQWUsRUFBRTtRQUNwQ2tCLFFBQVE7UUFDUkMsTUFBTVQ7SUFDVjtBQUNKO0FBQ08sU0FBU1UsNEJBQTRCbEIsY0FBYyxFQUFFQyxlQUFlO0lBQ3ZFLE9BQU9MLDhEQUFZQSxDQUFDLEdBQUdFLGNBQWMsQ0FBQyxFQUFFRSxnQkFBZ0IsRUFBRTtRQUN0RGdCLFFBQVE7UUFDUmQsUUFBUUQsZ0JBQWdCQyxNQUFNO0lBQ2xDO0FBQ0oiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tZW1yLWFwaS9kaXN0L2F0dGFjaG1lbnRzLmpzPzY0NWMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBtb2R1bGUgQGNhdGVnb3J5IEFQSSAqLyBpbXBvcnQgeyBvcGVubXJzRmV0Y2gsIHJlc3RCYXNlVXJsIH0gZnJvbSBcIkBvcGVubXJzL2VzbS1hcGlcIjtcbmV4cG9ydCBjb25zdCBhdHRhY2htZW50VXJsID0gYCR7cmVzdEJhc2VVcmx9L2F0dGFjaG1lbnRgO1xuZXhwb3J0IGZ1bmN0aW9uIGdldEF0dGFjaG1lbnRCeVV1aWQoYXR0YWNobWVudFV1aWQsIGFib3J0Q29udHJvbGxlcikge1xuICAgIHJldHVybiBvcGVubXJzRmV0Y2goYCR7YXR0YWNobWVudFVybH0vJHthdHRhY2htZW50VXVpZH1gLCB7XG4gICAgICAgIHNpZ25hbDogYWJvcnRDb250cm9sbGVyLnNpZ25hbFxuICAgIH0pO1xufVxuZXhwb3J0IGZ1bmN0aW9uIGdldEF0dGFjaG1lbnRzKHBhdGllbnRVdWlkLCBpbmNsdWRlRW5jb3VudGVybGVzcywgYWJvcnRDb250cm9sbGVyKSB7XG4gICAgcmV0dXJuIG9wZW5tcnNGZXRjaChgJHthdHRhY2htZW50VXJsfT9wYXRpZW50PSR7cGF0aWVudFV1aWR9JmluY2x1ZGVFbmNvdW50ZXJsZXNzPSR7aW5jbHVkZUVuY291bnRlcmxlc3N9YCwge1xuICAgICAgICBzaWduYWw6IGFib3J0Q29udHJvbGxlci5zaWduYWxcbiAgICB9KTtcbn1cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBjcmVhdGVBdHRhY2htZW50KHBhdGllbnRVdWlkLCBmaWxlVG9VcGxvYWQpIHtcbiAgICBjb25zdCBmb3JtRGF0YSA9IG5ldyBGb3JtRGF0YSgpO1xuICAgIGZvcm1EYXRhLmFwcGVuZCgnZmlsZUNhcHRpb24nLCBmaWxlVG9VcGxvYWQuZmlsZURlc2NyaXB0aW9uKTtcbiAgICBmb3JtRGF0YS5hcHBlbmQoJ3BhdGllbnQnLCBwYXRpZW50VXVpZCk7XG4gICAgaWYgKGZpbGVUb1VwbG9hZC5maWxlKSB7XG4gICAgICAgIGZvcm1EYXRhLmFwcGVuZCgnZmlsZScsIGZpbGVUb1VwbG9hZC5maWxlLCBmaWxlVG9VcGxvYWQuZmlsZU5hbWUpO1xuICAgIH0gZWxzZSB7XG4gICAgICAgIGZvcm1EYXRhLmFwcGVuZCgnZmlsZScsIG5ldyBGaWxlKFtcbiAgICAgICAgICAgICcnXG4gICAgICAgIF0sIGZpbGVUb1VwbG9hZC5maWxlTmFtZSksIGZpbGVUb1VwbG9hZC5maWxlTmFtZSk7XG4gICAgICAgIGZvcm1EYXRhLmFwcGVuZCgnYmFzZTY0Q29udGVudCcsIGZpbGVUb1VwbG9hZC5iYXNlNjRDb250ZW50KTtcbiAgICB9XG4gICAgcmV0dXJuIG9wZW5tcnNGZXRjaChgJHthdHRhY2htZW50VXJsfWAsIHtcbiAgICAgICAgbWV0aG9kOiAnUE9TVCcsXG4gICAgICAgIGJvZHk6IGZvcm1EYXRhXG4gICAgfSk7XG59XG5leHBvcnQgZnVuY3Rpb24gZGVsZXRlQXR0YWNobWVudFBlcm1hbmVudGx5KGF0dGFjaG1lbnRVdWlkLCBhYm9ydENvbnRyb2xsZXIpIHtcbiAgICByZXR1cm4gb3Blbm1yc0ZldGNoKGAke2F0dGFjaG1lbnRVcmx9LyR7YXR0YWNobWVudFV1aWR9YCwge1xuICAgICAgICBtZXRob2Q6ICdERUxFVEUnLFxuICAgICAgICBzaWduYWw6IGFib3J0Q29udHJvbGxlci5zaWduYWxcbiAgICB9KTtcbn1cbiJdLCJuYW1lcyI6WyJvcGVubXJzRmV0Y2giLCJyZXN0QmFzZVVybCIsImF0dGFjaG1lbnRVcmwiLCJnZXRBdHRhY2htZW50QnlVdWlkIiwiYXR0YWNobWVudFV1aWQiLCJhYm9ydENvbnRyb2xsZXIiLCJzaWduYWwiLCJnZXRBdHRhY2htZW50cyIsInBhdGllbnRVdWlkIiwiaW5jbHVkZUVuY291bnRlcmxlc3MiLCJjcmVhdGVBdHRhY2htZW50IiwiZmlsZVRvVXBsb2FkIiwiZm9ybURhdGEiLCJGb3JtRGF0YSIsImFwcGVuZCIsImZpbGVEZXNjcmlwdGlvbiIsImZpbGUiLCJmaWxlTmFtZSIsIkZpbGUiLCJiYXNlNjRDb250ZW50IiwibWV0aG9kIiwiYm9keSIsImRlbGV0ZUF0dGFjaG1lbnRQZXJtYW5lbnRseSJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///../../framework/esm-emr-api/dist/attachments.js\n");
228
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ attachmentUrl: () => (/* binding */ attachmentUrl),\n/* harmony export */ createAttachment: () => (/* binding */ createAttachment),\n/* harmony export */ deleteAttachmentPermanently: () => (/* binding */ deleteAttachmentPermanently),\n/* harmony export */ getAttachmentByUuid: () => (/* binding */ getAttachmentByUuid),\n/* harmony export */ getAttachments: () => (/* binding */ getAttachments)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-api */ \"../../framework/esm-api/dist/index.js\");\n/** @module @category API */ \n/** Base URL for the attachment REST API endpoint. */ const attachmentUrl = `${_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.restBaseUrl}/attachment`;\n/**\n * Fetches a single attachment by its UUID from the OpenMRS server.\n *\n * @param attachmentUuid The UUID of the attachment to fetch.\n * @param abortController An AbortController to allow cancellation of the request.\n * @returns A Promise that resolves with the FetchResponse containing the attachment data.\n *\n * @example\n * ```ts\n * import { getAttachmentByUuid } from '@openmrs/esm-framework';\n * const abortController = new AbortController();\n * const response = await getAttachmentByUuid('attachment-uuid', abortController);\n * console.log(response.data);\n * ```\n */ function getAttachmentByUuid(attachmentUuid, abortController) {\n return (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.openmrsFetch)(`${attachmentUrl}/${attachmentUuid}`, {\n signal: abortController.signal\n });\n}\n/**\n * Fetches all attachments for a specific patient from the OpenMRS server.\n *\n * @param patientUuid The UUID of the patient whose attachments should be fetched.\n * @param includeEncounterless Whether to include attachments that are not associated\n * with any encounter.\n * @param abortController An AbortController to allow cancellation of the request.\n * @returns A Promise that resolves with the FetchResponse containing an array of attachments.\n *\n * @example\n * ```ts\n * import { getAttachments } from '@openmrs/esm-framework';\n * const abortController = new AbortController();\n * const response = await getAttachments('patient-uuid', true, abortController);\n * console.log(response.data.results);\n * ```\n */ function getAttachments(patientUuid, includeEncounterless, abortController) {\n return (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.openmrsFetch)(`${attachmentUrl}?patient=${patientUuid}&includeEncounterless=${includeEncounterless}`, {\n signal: abortController.signal\n });\n}\n/**\n * Creates a new attachment for a patient by uploading a file to the OpenMRS server.\n * The file can be provided either as a File object or as base64-encoded content.\n *\n * @param patientUuid The UUID of the patient to associate the attachment with.\n * @param fileToUpload An object containing the file data and metadata to upload.\n * Should include `file` (File object) or `base64Content`, plus `fileName` and\n * `fileDescription`.\n * @returns A Promise that resolves with the FetchResponse containing the created\n * attachment data.\n *\n * @example\n * ```ts\n * import { createAttachment } from '@openmrs/esm-framework';\n * const response = await createAttachment('patient-uuid', {\n * file: selectedFile,\n * fileName: 'document.pdf',\n * fileDescription: 'Patient consent form'\n * });\n * ```\n */ async function createAttachment(patientUuid, fileToUpload) {\n const formData = new FormData();\n formData.append('fileCaption', fileToUpload.fileDescription);\n formData.append('patient', patientUuid);\n if (fileToUpload.file) {\n formData.append('file', fileToUpload.file, fileToUpload.fileName);\n } else {\n formData.append('file', new File([\n ''\n ], fileToUpload.fileName), fileToUpload.fileName);\n formData.append('base64Content', fileToUpload.base64Content);\n }\n return (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.openmrsFetch)(`${attachmentUrl}`, {\n method: 'POST',\n body: formData\n });\n}\n/**\n * Permanently deletes an attachment from the OpenMRS server. This action cannot\n * be undone.\n *\n * @param attachmentUuid The UUID of the attachment to delete.\n * @param abortController An AbortController to allow cancellation of the request.\n * @returns A Promise that resolves with the FetchResponse confirming deletion.\n *\n * @example\n * ```ts\n * import { deleteAttachmentPermanently } from '@openmrs/esm-framework';\n * const abortController = new AbortController();\n * await deleteAttachmentPermanently('attachment-uuid', abortController);\n * ```\n */ function deleteAttachmentPermanently(attachmentUuid, abortController) {\n return (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.openmrsFetch)(`${attachmentUrl}/${attachmentUuid}`, {\n method: 'DELETE',\n signal: abortController.signal\n });\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1lbXItYXBpL2Rpc3QvYXR0YWNobWVudHMuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7O0FBQUEsMEJBQTBCLEdBQWdFO0FBQzFGLG1EQUFtRCxHQUFVLE1BQU1FLGdCQUFnQixHQUFHRCx5REFBV0EsQ0FBQyxXQUFXLENBQUMsQ0FBQztBQUMvRzs7Ozs7Ozs7Ozs7Ozs7Q0FjQyxHQUFVLFNBQVNFLG9CQUFvQkMsY0FBYyxFQUFFQyxlQUFlO0lBQ25FLE9BQU9MLDhEQUFZQSxDQUFDLEdBQUdFLGNBQWMsQ0FBQyxFQUFFRSxnQkFBZ0IsRUFBRTtRQUN0REUsUUFBUUQsZ0JBQWdCQyxNQUFNO0lBQ2xDO0FBQ0o7QUFDQTs7Ozs7Ozs7Ozs7Ozs7OztDQWdCQyxHQUFVLFNBQVNDLGVBQWVDLFdBQVcsRUFBRUMsb0JBQW9CLEVBQUVKLGVBQWU7SUFDakYsT0FBT0wsOERBQVlBLENBQUMsR0FBR0UsY0FBYyxTQUFTLEVBQUVNLFlBQVksc0JBQXNCLEVBQUVDLHNCQUFzQixFQUFFO1FBQ3hHSCxRQUFRRCxnQkFBZ0JDLE1BQU07SUFDbEM7QUFDSjtBQUNBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztDQW9CQyxHQUFVLGVBQWVJLGlCQUFpQkYsV0FBVyxFQUFFRyxZQUFZO0lBQ2hFLE1BQU1DLFdBQVcsSUFBSUM7SUFDckJELFNBQVNFLE1BQU0sQ0FBQyxlQUFlSCxhQUFhSSxlQUFlO0lBQzNESCxTQUFTRSxNQUFNLENBQUMsV0FBV047SUFDM0IsSUFBSUcsYUFBYUssSUFBSSxFQUFFO1FBQ25CSixTQUFTRSxNQUFNLENBQUMsUUFBUUgsYUFBYUssSUFBSSxFQUFFTCxhQUFhTSxRQUFRO0lBQ3BFLE9BQU87UUFDSEwsU0FBU0UsTUFBTSxDQUFDLFFBQVEsSUFBSUksS0FBSztZQUM3QjtTQUNILEVBQUVQLGFBQWFNLFFBQVEsR0FBR04sYUFBYU0sUUFBUTtRQUNoREwsU0FBU0UsTUFBTSxDQUFDLGlCQUFpQkgsYUFBYVEsYUFBYTtJQUMvRDtJQUNBLE9BQU9uQiw4REFBWUEsQ0FBQyxHQUFHRSxlQUFlLEVBQUU7UUFDcENrQixRQUFRO1FBQ1JDLE1BQU1UO0lBQ1Y7QUFDSjtBQUNBOzs7Ozs7Ozs7Ozs7OztDQWNDLEdBQVUsU0FBU1UsNEJBQTRCbEIsY0FBYyxFQUFFQyxlQUFlO0lBQzNFLE9BQU9MLDhEQUFZQSxDQUFDLEdBQUdFLGNBQWMsQ0FBQyxFQUFFRSxnQkFBZ0IsRUFBRTtRQUN0RGdCLFFBQVE7UUFDUmQsUUFBUUQsZ0JBQWdCQyxNQUFNO0lBQ2xDO0FBQ0oiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tZW1yLWFwaS9kaXN0L2F0dGFjaG1lbnRzLmpzPzY0NWMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBtb2R1bGUgQGNhdGVnb3J5IEFQSSAqLyBpbXBvcnQgeyBvcGVubXJzRmV0Y2gsIHJlc3RCYXNlVXJsIH0gZnJvbSBcIkBvcGVubXJzL2VzbS1hcGlcIjtcbi8qKiBCYXNlIFVSTCBmb3IgdGhlIGF0dGFjaG1lbnQgUkVTVCBBUEkgZW5kcG9pbnQuICovIGV4cG9ydCBjb25zdCBhdHRhY2htZW50VXJsID0gYCR7cmVzdEJhc2VVcmx9L2F0dGFjaG1lbnRgO1xuLyoqXG4gKiBGZXRjaGVzIGEgc2luZ2xlIGF0dGFjaG1lbnQgYnkgaXRzIFVVSUQgZnJvbSB0aGUgT3Blbk1SUyBzZXJ2ZXIuXG4gKlxuICogQHBhcmFtIGF0dGFjaG1lbnRVdWlkIFRoZSBVVUlEIG9mIHRoZSBhdHRhY2htZW50IHRvIGZldGNoLlxuICogQHBhcmFtIGFib3J0Q29udHJvbGxlciBBbiBBYm9ydENvbnRyb2xsZXIgdG8gYWxsb3cgY2FuY2VsbGF0aW9uIG9mIHRoZSByZXF1ZXN0LlxuICogQHJldHVybnMgQSBQcm9taXNlIHRoYXQgcmVzb2x2ZXMgd2l0aCB0aGUgRmV0Y2hSZXNwb25zZSBjb250YWluaW5nIHRoZSBhdHRhY2htZW50IGRhdGEuXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHRzXG4gKiBpbXBvcnQgeyBnZXRBdHRhY2htZW50QnlVdWlkIH0gZnJvbSAnQG9wZW5tcnMvZXNtLWZyYW1ld29yayc7XG4gKiBjb25zdCBhYm9ydENvbnRyb2xsZXIgPSBuZXcgQWJvcnRDb250cm9sbGVyKCk7XG4gKiBjb25zdCByZXNwb25zZSA9IGF3YWl0IGdldEF0dGFjaG1lbnRCeVV1aWQoJ2F0dGFjaG1lbnQtdXVpZCcsIGFib3J0Q29udHJvbGxlcik7XG4gKiBjb25zb2xlLmxvZyhyZXNwb25zZS5kYXRhKTtcbiAqIGBgYFxuICovIGV4cG9ydCBmdW5jdGlvbiBnZXRBdHRhY2htZW50QnlVdWlkKGF0dGFjaG1lbnRVdWlkLCBhYm9ydENvbnRyb2xsZXIpIHtcbiAgICByZXR1cm4gb3Blbm1yc0ZldGNoKGAke2F0dGFjaG1lbnRVcmx9LyR7YXR0YWNobWVudFV1aWR9YCwge1xuICAgICAgICBzaWduYWw6IGFib3J0Q29udHJvbGxlci5zaWduYWxcbiAgICB9KTtcbn1cbi8qKlxuICogRmV0Y2hlcyBhbGwgYXR0YWNobWVudHMgZm9yIGEgc3BlY2lmaWMgcGF0aWVudCBmcm9tIHRoZSBPcGVuTVJTIHNlcnZlci5cbiAqXG4gKiBAcGFyYW0gcGF0aWVudFV1aWQgVGhlIFVVSUQgb2YgdGhlIHBhdGllbnQgd2hvc2UgYXR0YWNobWVudHMgc2hvdWxkIGJlIGZldGNoZWQuXG4gKiBAcGFyYW0gaW5jbHVkZUVuY291bnRlcmxlc3MgV2hldGhlciB0byBpbmNsdWRlIGF0dGFjaG1lbnRzIHRoYXQgYXJlIG5vdCBhc3NvY2lhdGVkXG4gKiAgIHdpdGggYW55IGVuY291bnRlci5cbiAqIEBwYXJhbSBhYm9ydENvbnRyb2xsZXIgQW4gQWJvcnRDb250cm9sbGVyIHRvIGFsbG93IGNhbmNlbGxhdGlvbiBvZiB0aGUgcmVxdWVzdC5cbiAqIEByZXR1cm5zIEEgUHJvbWlzZSB0aGF0IHJlc29sdmVzIHdpdGggdGhlIEZldGNoUmVzcG9uc2UgY29udGFpbmluZyBhbiBhcnJheSBvZiBhdHRhY2htZW50cy5cbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHNcbiAqIGltcG9ydCB7IGdldEF0dGFjaG1lbnRzIH0gZnJvbSAnQG9wZW5tcnMvZXNtLWZyYW1ld29yayc7XG4gKiBjb25zdCBhYm9ydENvbnRyb2xsZXIgPSBuZXcgQWJvcnRDb250cm9sbGVyKCk7XG4gKiBjb25zdCByZXNwb25zZSA9IGF3YWl0IGdldEF0dGFjaG1lbnRzKCdwYXRpZW50LXV1aWQnLCB0cnVlLCBhYm9ydENvbnRyb2xsZXIpO1xuICogY29uc29sZS5sb2cocmVzcG9uc2UuZGF0YS5yZXN1bHRzKTtcbiAqIGBgYFxuICovIGV4cG9ydCBmdW5jdGlvbiBnZXRBdHRhY2htZW50cyhwYXRpZW50VXVpZCwgaW5jbHVkZUVuY291bnRlcmxlc3MsIGFib3J0Q29udHJvbGxlcikge1xuICAgIHJldHVybiBvcGVubXJzRmV0Y2goYCR7YXR0YWNobWVudFVybH0/cGF0aWVudD0ke3BhdGllbnRVdWlkfSZpbmNsdWRlRW5jb3VudGVybGVzcz0ke2luY2x1ZGVFbmNvdW50ZXJsZXNzfWAsIHtcbiAgICAgICAgc2lnbmFsOiBhYm9ydENvbnRyb2xsZXIuc2lnbmFsXG4gICAgfSk7XG59XG4vKipcbiAqIENyZWF0ZXMgYSBuZXcgYXR0YWNobWVudCBmb3IgYSBwYXRpZW50IGJ5IHVwbG9hZGluZyBhIGZpbGUgdG8gdGhlIE9wZW5NUlMgc2VydmVyLlxuICogVGhlIGZpbGUgY2FuIGJlIHByb3ZpZGVkIGVpdGhlciBhcyBhIEZpbGUgb2JqZWN0IG9yIGFzIGJhc2U2NC1lbmNvZGVkIGNvbnRlbnQuXG4gKlxuICogQHBhcmFtIHBhdGllbnRVdWlkIFRoZSBVVUlEIG9mIHRoZSBwYXRpZW50IHRvIGFzc29jaWF0ZSB0aGUgYXR0YWNobWVudCB3aXRoLlxuICogQHBhcmFtIGZpbGVUb1VwbG9hZCBBbiBvYmplY3QgY29udGFpbmluZyB0aGUgZmlsZSBkYXRhIGFuZCBtZXRhZGF0YSB0byB1cGxvYWQuXG4gKiAgIFNob3VsZCBpbmNsdWRlIGBmaWxlYCAoRmlsZSBvYmplY3QpIG9yIGBiYXNlNjRDb250ZW50YCwgcGx1cyBgZmlsZU5hbWVgIGFuZFxuICogICBgZmlsZURlc2NyaXB0aW9uYC5cbiAqIEByZXR1cm5zIEEgUHJvbWlzZSB0aGF0IHJlc29sdmVzIHdpdGggdGhlIEZldGNoUmVzcG9uc2UgY29udGFpbmluZyB0aGUgY3JlYXRlZFxuICogICBhdHRhY2htZW50IGRhdGEuXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHRzXG4gKiBpbXBvcnQgeyBjcmVhdGVBdHRhY2htZW50IH0gZnJvbSAnQG9wZW5tcnMvZXNtLWZyYW1ld29yayc7XG4gKiBjb25zdCByZXNwb25zZSA9IGF3YWl0IGNyZWF0ZUF0dGFjaG1lbnQoJ3BhdGllbnQtdXVpZCcsIHtcbiAqICAgZmlsZTogc2VsZWN0ZWRGaWxlLFxuICogICBmaWxlTmFtZTogJ2RvY3VtZW50LnBkZicsXG4gKiAgIGZpbGVEZXNjcmlwdGlvbjogJ1BhdGllbnQgY29uc2VudCBmb3JtJ1xuICogfSk7XG4gKiBgYGBcbiAqLyBleHBvcnQgYXN5bmMgZnVuY3Rpb24gY3JlYXRlQXR0YWNobWVudChwYXRpZW50VXVpZCwgZmlsZVRvVXBsb2FkKSB7XG4gICAgY29uc3QgZm9ybURhdGEgPSBuZXcgRm9ybURhdGEoKTtcbiAgICBmb3JtRGF0YS5hcHBlbmQoJ2ZpbGVDYXB0aW9uJywgZmlsZVRvVXBsb2FkLmZpbGVEZXNjcmlwdGlvbik7XG4gICAgZm9ybURhdGEuYXBwZW5kKCdwYXRpZW50JywgcGF0aWVudFV1aWQpO1xuICAgIGlmIChmaWxlVG9VcGxvYWQuZmlsZSkge1xuICAgICAgICBmb3JtRGF0YS5hcHBlbmQoJ2ZpbGUnLCBmaWxlVG9VcGxvYWQuZmlsZSwgZmlsZVRvVXBsb2FkLmZpbGVOYW1lKTtcbiAgICB9IGVsc2Uge1xuICAgICAgICBmb3JtRGF0YS5hcHBlbmQoJ2ZpbGUnLCBuZXcgRmlsZShbXG4gICAgICAgICAgICAnJ1xuICAgICAgICBdLCBmaWxlVG9VcGxvYWQuZmlsZU5hbWUpLCBmaWxlVG9VcGxvYWQuZmlsZU5hbWUpO1xuICAgICAgICBmb3JtRGF0YS5hcHBlbmQoJ2Jhc2U2NENvbnRlbnQnLCBmaWxlVG9VcGxvYWQuYmFzZTY0Q29udGVudCk7XG4gICAgfVxuICAgIHJldHVybiBvcGVubXJzRmV0Y2goYCR7YXR0YWNobWVudFVybH1gLCB7XG4gICAgICAgIG1ldGhvZDogJ1BPU1QnLFxuICAgICAgICBib2R5OiBmb3JtRGF0YVxuICAgIH0pO1xufVxuLyoqXG4gKiBQZXJtYW5lbnRseSBkZWxldGVzIGFuIGF0dGFjaG1lbnQgZnJvbSB0aGUgT3Blbk1SUyBzZXJ2ZXIuIFRoaXMgYWN0aW9uIGNhbm5vdFxuICogYmUgdW5kb25lLlxuICpcbiAqIEBwYXJhbSBhdHRhY2htZW50VXVpZCBUaGUgVVVJRCBvZiB0aGUgYXR0YWNobWVudCB0byBkZWxldGUuXG4gKiBAcGFyYW0gYWJvcnRDb250cm9sbGVyIEFuIEFib3J0Q29udHJvbGxlciB0byBhbGxvdyBjYW5jZWxsYXRpb24gb2YgdGhlIHJlcXVlc3QuXG4gKiBAcmV0dXJucyBBIFByb21pc2UgdGhhdCByZXNvbHZlcyB3aXRoIHRoZSBGZXRjaFJlc3BvbnNlIGNvbmZpcm1pbmcgZGVsZXRpb24uXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHRzXG4gKiBpbXBvcnQgeyBkZWxldGVBdHRhY2htZW50UGVybWFuZW50bHkgfSBmcm9tICdAb3Blbm1ycy9lc20tZnJhbWV3b3JrJztcbiAqIGNvbnN0IGFib3J0Q29udHJvbGxlciA9IG5ldyBBYm9ydENvbnRyb2xsZXIoKTtcbiAqIGF3YWl0IGRlbGV0ZUF0dGFjaG1lbnRQZXJtYW5lbnRseSgnYXR0YWNobWVudC11dWlkJywgYWJvcnRDb250cm9sbGVyKTtcbiAqIGBgYFxuICovIGV4cG9ydCBmdW5jdGlvbiBkZWxldGVBdHRhY2htZW50UGVybWFuZW50bHkoYXR0YWNobWVudFV1aWQsIGFib3J0Q29udHJvbGxlcikge1xuICAgIHJldHVybiBvcGVubXJzRmV0Y2goYCR7YXR0YWNobWVudFVybH0vJHthdHRhY2htZW50VXVpZH1gLCB7XG4gICAgICAgIG1ldGhvZDogJ0RFTEVURScsXG4gICAgICAgIHNpZ25hbDogYWJvcnRDb250cm9sbGVyLnNpZ25hbFxuICAgIH0pO1xufVxuIl0sIm5hbWVzIjpbIm9wZW5tcnNGZXRjaCIsInJlc3RCYXNlVXJsIiwiYXR0YWNobWVudFVybCIsImdldEF0dGFjaG1lbnRCeVV1aWQiLCJhdHRhY2htZW50VXVpZCIsImFib3J0Q29udHJvbGxlciIsInNpZ25hbCIsImdldEF0dGFjaG1lbnRzIiwicGF0aWVudFV1aWQiLCJpbmNsdWRlRW5jb3VudGVybGVzcyIsImNyZWF0ZUF0dGFjaG1lbnQiLCJmaWxlVG9VcGxvYWQiLCJmb3JtRGF0YSIsIkZvcm1EYXRhIiwiYXBwZW5kIiwiZmlsZURlc2NyaXB0aW9uIiwiZmlsZSIsImZpbGVOYW1lIiwiRmlsZSIsImJhc2U2NENvbnRlbnQiLCJtZXRob2QiLCJib2R5IiwiZGVsZXRlQXR0YWNobWVudFBlcm1hbmVudGx5Il0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///../../framework/esm-emr-api/dist/attachments.js\n");
229
229
 
230
230
  /***/ }),
231
231
 
@@ -235,7 +235,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
235
235
  \***********************************************************/
236
236
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
237
237
 
238
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ fetchCurrentPatient: () => (/* binding */ fetchCurrentPatient)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-api */ \"../../framework/esm-api/dist/index.js\");\n/* harmony import */ var _openmrs_esm_offline__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-offline */ \"../../framework/esm-offline/dist/index.js\");\n/** @module @category API */ \n\nasync function fetchCurrentPatient(patientUuid, fetchInit, includeOfflinePatients = true) {\n if (patientUuid) {\n let err = null;\n const [onlinePatient, offlinePatient] = await Promise.all([\n (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.openmrsFetch)(`${_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.fhirBaseUrl}/Patient/${patientUuid}`, fetchInit).catch((e)=>err = e),\n includeOfflinePatients ? getOfflineRegisteredPatientAsFhirPatient(patientUuid) : Promise.resolve(null)\n ]);\n if (onlinePatient.ok) {\n return onlinePatient.data;\n }\n if (offlinePatient) {\n return offlinePatient;\n }\n if (err) {\n throw err;\n }\n }\n return null;\n}\nasync function getOfflineRegisteredPatientAsFhirPatient(patientUuid) {\n const patientRegistrationSyncItems = await (0,_openmrs_esm_offline__WEBPACK_IMPORTED_MODULE_1__.getSynchronizationItems)('patient-registration');\n const patientSyncItem = patientRegistrationSyncItems.find((item)=>item.fhirPatient.id === patientUuid);\n return patientSyncItem?.fhirPatient ?? null;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1lbXItYXBpL2Rpc3QvY3VycmVudC1wYXRpZW50LmpzIiwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLDBCQUEwQixHQUFnRTtBQUMzQjtBQUN4RCxlQUFlRyxvQkFBb0JDLFdBQVcsRUFBRUMsU0FBUyxFQUFFQyx5QkFBeUIsSUFBSTtJQUMzRixJQUFJRixhQUFhO1FBQ2IsSUFBSUcsTUFBTTtRQUNWLE1BQU0sQ0FBQ0MsZUFBZUMsZUFBZSxHQUFHLE1BQU1DLFFBQVFDLEdBQUcsQ0FBQztZQUN0RFYsOERBQVlBLENBQUMsR0FBR0QseURBQVdBLENBQUMsU0FBUyxFQUFFSSxhQUFhLEVBQUVDLFdBQVdPLEtBQUssQ0FBQyxDQUFDQyxJQUFJTixNQUFNTTtZQUNsRlAseUJBQXlCUSx5Q0FBeUNWLGVBQWVNLFFBQVFLLE9BQU8sQ0FBQztTQUNwRztRQUNELElBQUlQLGNBQWNRLEVBQUUsRUFBRTtZQUNsQixPQUFPUixjQUFjUyxJQUFJO1FBQzdCO1FBQ0EsSUFBSVIsZ0JBQWdCO1lBQ2hCLE9BQU9BO1FBQ1g7UUFDQSxJQUFJRixLQUFLO1lBQ0wsTUFBTUE7UUFDVjtJQUNKO0lBQ0EsT0FBTztBQUNYO0FBQ0EsZUFBZU8seUNBQXlDVixXQUFXO0lBQy9ELE1BQU1jLCtCQUErQixNQUFNaEIsNkVBQXVCQSxDQUFDO0lBQ25FLE1BQU1pQixrQkFBa0JELDZCQUE2QkUsSUFBSSxDQUFDLENBQUNDLE9BQU9BLEtBQUtDLFdBQVcsQ0FBQ0MsRUFBRSxLQUFLbkI7SUFDMUYsT0FBT2UsaUJBQWlCRyxlQUFlO0FBQzNDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQG9wZW5tcnMvZXNtLWFwcC1zaGVsbC8uLi8uLi9mcmFtZXdvcmsvZXNtLWVtci1hcGkvZGlzdC9jdXJyZW50LXBhdGllbnQuanM/YzE1MyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQG1vZHVsZSBAY2F0ZWdvcnkgQVBJICovIGltcG9ydCB7IGZoaXJCYXNlVXJsLCBvcGVubXJzRmV0Y2ggfSBmcm9tIFwiQG9wZW5tcnMvZXNtLWFwaVwiO1xuaW1wb3J0IHsgZ2V0U3luY2hyb25pemF0aW9uSXRlbXMgfSBmcm9tIFwiQG9wZW5tcnMvZXNtLW9mZmxpbmVcIjtcbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBmZXRjaEN1cnJlbnRQYXRpZW50KHBhdGllbnRVdWlkLCBmZXRjaEluaXQsIGluY2x1ZGVPZmZsaW5lUGF0aWVudHMgPSB0cnVlKSB7XG4gICAgaWYgKHBhdGllbnRVdWlkKSB7XG4gICAgICAgIGxldCBlcnIgPSBudWxsO1xuICAgICAgICBjb25zdCBbb25saW5lUGF0aWVudCwgb2ZmbGluZVBhdGllbnRdID0gYXdhaXQgUHJvbWlzZS5hbGwoW1xuICAgICAgICAgICAgb3Blbm1yc0ZldGNoKGAke2ZoaXJCYXNlVXJsfS9QYXRpZW50LyR7cGF0aWVudFV1aWR9YCwgZmV0Y2hJbml0KS5jYXRjaCgoZSk9PmVyciA9IGUpLFxuICAgICAgICAgICAgaW5jbHVkZU9mZmxpbmVQYXRpZW50cyA/IGdldE9mZmxpbmVSZWdpc3RlcmVkUGF0aWVudEFzRmhpclBhdGllbnQocGF0aWVudFV1aWQpIDogUHJvbWlzZS5yZXNvbHZlKG51bGwpXG4gICAgICAgIF0pO1xuICAgICAgICBpZiAob25saW5lUGF0aWVudC5vaykge1xuICAgICAgICAgICAgcmV0dXJuIG9ubGluZVBhdGllbnQuZGF0YTtcbiAgICAgICAgfVxuICAgICAgICBpZiAob2ZmbGluZVBhdGllbnQpIHtcbiAgICAgICAgICAgIHJldHVybiBvZmZsaW5lUGF0aWVudDtcbiAgICAgICAgfVxuICAgICAgICBpZiAoZXJyKSB7XG4gICAgICAgICAgICB0aHJvdyBlcnI7XG4gICAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIG51bGw7XG59XG5hc3luYyBmdW5jdGlvbiBnZXRPZmZsaW5lUmVnaXN0ZXJlZFBhdGllbnRBc0ZoaXJQYXRpZW50KHBhdGllbnRVdWlkKSB7XG4gICAgY29uc3QgcGF0aWVudFJlZ2lzdHJhdGlvblN5bmNJdGVtcyA9IGF3YWl0IGdldFN5bmNocm9uaXphdGlvbkl0ZW1zKCdwYXRpZW50LXJlZ2lzdHJhdGlvbicpO1xuICAgIGNvbnN0IHBhdGllbnRTeW5jSXRlbSA9IHBhdGllbnRSZWdpc3RyYXRpb25TeW5jSXRlbXMuZmluZCgoaXRlbSk9Pml0ZW0uZmhpclBhdGllbnQuaWQgPT09IHBhdGllbnRVdWlkKTtcbiAgICByZXR1cm4gcGF0aWVudFN5bmNJdGVtPy5maGlyUGF0aWVudCA/PyBudWxsO1xufVxuIl0sIm5hbWVzIjpbImZoaXJCYXNlVXJsIiwib3Blbm1yc0ZldGNoIiwiZ2V0U3luY2hyb25pemF0aW9uSXRlbXMiLCJmZXRjaEN1cnJlbnRQYXRpZW50IiwicGF0aWVudFV1aWQiLCJmZXRjaEluaXQiLCJpbmNsdWRlT2ZmbGluZVBhdGllbnRzIiwiZXJyIiwib25saW5lUGF0aWVudCIsIm9mZmxpbmVQYXRpZW50IiwiUHJvbWlzZSIsImFsbCIsImNhdGNoIiwiZSIsImdldE9mZmxpbmVSZWdpc3RlcmVkUGF0aWVudEFzRmhpclBhdGllbnQiLCJyZXNvbHZlIiwib2siLCJkYXRhIiwicGF0aWVudFJlZ2lzdHJhdGlvblN5bmNJdGVtcyIsInBhdGllbnRTeW5jSXRlbSIsImZpbmQiLCJpdGVtIiwiZmhpclBhdGllbnQiLCJpZCJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///../../framework/esm-emr-api/dist/current-patient.js\n");
238
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ fetchCurrentPatient: () => (/* binding */ fetchCurrentPatient)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-api */ \"../../framework/esm-api/dist/index.js\");\n/* harmony import */ var _openmrs_esm_offline__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-offline */ \"../../framework/esm-offline/dist/index.js\");\n/** @module @category API */ \n\n/**\n * Fetches a patient by their UUID from the FHIR API. This function first attempts\n * to fetch the patient from the server. If the server request fails and offline\n * patients are included, it will check for a matching patient in the offline\n * patient registration sync queue.\n *\n * @param patientUuid The UUID of the patient to fetch, or `null`.\n * @param fetchInit Optional fetch configuration options to pass to the request.\n * @param includeOfflinePatients Whether to include patients from the offline\n * registration queue if the server request fails. Defaults to `true`.\n * @returns A Promise that resolves with the FHIR Patient object, or `null` if\n * the patient UUID is null or the patient is not found.\n * @throws Rethrows any error from the server request if no offline patient is found.\n *\n * @example\n * ```ts\n * import { fetchCurrentPatient } from '@openmrs/esm-framework';\n * const patient = await fetchCurrentPatient('patient-uuid');\n * if (patient) {\n * console.log('Patient name:', patient.name?.[0]?.text);\n * }\n * ```\n */ async function fetchCurrentPatient(patientUuid, fetchInit, includeOfflinePatients = true) {\n if (patientUuid) {\n let err = null;\n const [onlinePatient, offlinePatient] = await Promise.all([\n (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.openmrsFetch)(`${_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.fhirBaseUrl}/Patient/${patientUuid}`, fetchInit).catch((e)=>err = e),\n includeOfflinePatients ? getOfflineRegisteredPatientAsFhirPatient(patientUuid) : Promise.resolve(null)\n ]);\n if (onlinePatient.ok) {\n return onlinePatient.data;\n }\n if (offlinePatient) {\n return offlinePatient;\n }\n if (err) {\n throw err;\n }\n }\n return null;\n}\nasync function getOfflineRegisteredPatientAsFhirPatient(patientUuid) {\n const patientRegistrationSyncItems = await (0,_openmrs_esm_offline__WEBPACK_IMPORTED_MODULE_1__.getSynchronizationItems)('patient-registration');\n const patientSyncItem = patientRegistrationSyncItems.find((item)=>item.fhirPatient.id === patientUuid);\n return patientSyncItem?.fhirPatient ?? null;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1lbXItYXBpL2Rpc3QvY3VycmVudC1wYXRpZW50LmpzIiwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLDBCQUEwQixHQUFnRTtBQUMzQjtBQUMvRDs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztDQXNCQyxHQUFVLGVBQWVHLG9CQUFvQkMsV0FBVyxFQUFFQyxTQUFTLEVBQUVDLHlCQUF5QixJQUFJO0lBQy9GLElBQUlGLGFBQWE7UUFDYixJQUFJRyxNQUFNO1FBQ1YsTUFBTSxDQUFDQyxlQUFlQyxlQUFlLEdBQUcsTUFBTUMsUUFBUUMsR0FBRyxDQUFDO1lBQ3REViw4REFBWUEsQ0FBQyxHQUFHRCx5REFBV0EsQ0FBQyxTQUFTLEVBQUVJLGFBQWEsRUFBRUMsV0FBV08sS0FBSyxDQUFDLENBQUNDLElBQUlOLE1BQU1NO1lBQ2xGUCx5QkFBeUJRLHlDQUF5Q1YsZUFBZU0sUUFBUUssT0FBTyxDQUFDO1NBQ3BHO1FBQ0QsSUFBSVAsY0FBY1EsRUFBRSxFQUFFO1lBQ2xCLE9BQU9SLGNBQWNTLElBQUk7UUFDN0I7UUFDQSxJQUFJUixnQkFBZ0I7WUFDaEIsT0FBT0E7UUFDWDtRQUNBLElBQUlGLEtBQUs7WUFDTCxNQUFNQTtRQUNWO0lBQ0o7SUFDQSxPQUFPO0FBQ1g7QUFDQSxlQUFlTyx5Q0FBeUNWLFdBQVc7SUFDL0QsTUFBTWMsK0JBQStCLE1BQU1oQiw2RUFBdUJBLENBQUM7SUFDbkUsTUFBTWlCLGtCQUFrQkQsNkJBQTZCRSxJQUFJLENBQUMsQ0FBQ0MsT0FBT0EsS0FBS0MsV0FBVyxDQUFDQyxFQUFFLEtBQUtuQjtJQUMxRixPQUFPZSxpQkFBaUJHLGVBQWU7QUFDM0MiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tZW1yLWFwaS9kaXN0L2N1cnJlbnQtcGF0aWVudC5qcz9jMTUzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBAbW9kdWxlIEBjYXRlZ29yeSBBUEkgKi8gaW1wb3J0IHsgZmhpckJhc2VVcmwsIG9wZW5tcnNGZXRjaCB9IGZyb20gXCJAb3Blbm1ycy9lc20tYXBpXCI7XG5pbXBvcnQgeyBnZXRTeW5jaHJvbml6YXRpb25JdGVtcyB9IGZyb20gXCJAb3Blbm1ycy9lc20tb2ZmbGluZVwiO1xuLyoqXG4gKiBGZXRjaGVzIGEgcGF0aWVudCBieSB0aGVpciBVVUlEIGZyb20gdGhlIEZISVIgQVBJLiBUaGlzIGZ1bmN0aW9uIGZpcnN0IGF0dGVtcHRzXG4gKiB0byBmZXRjaCB0aGUgcGF0aWVudCBmcm9tIHRoZSBzZXJ2ZXIuIElmIHRoZSBzZXJ2ZXIgcmVxdWVzdCBmYWlscyBhbmQgb2ZmbGluZVxuICogcGF0aWVudHMgYXJlIGluY2x1ZGVkLCBpdCB3aWxsIGNoZWNrIGZvciBhIG1hdGNoaW5nIHBhdGllbnQgaW4gdGhlIG9mZmxpbmVcbiAqIHBhdGllbnQgcmVnaXN0cmF0aW9uIHN5bmMgcXVldWUuXG4gKlxuICogQHBhcmFtIHBhdGllbnRVdWlkIFRoZSBVVUlEIG9mIHRoZSBwYXRpZW50IHRvIGZldGNoLCBvciBgbnVsbGAuXG4gKiBAcGFyYW0gZmV0Y2hJbml0IE9wdGlvbmFsIGZldGNoIGNvbmZpZ3VyYXRpb24gb3B0aW9ucyB0byBwYXNzIHRvIHRoZSByZXF1ZXN0LlxuICogQHBhcmFtIGluY2x1ZGVPZmZsaW5lUGF0aWVudHMgV2hldGhlciB0byBpbmNsdWRlIHBhdGllbnRzIGZyb20gdGhlIG9mZmxpbmVcbiAqICAgcmVnaXN0cmF0aW9uIHF1ZXVlIGlmIHRoZSBzZXJ2ZXIgcmVxdWVzdCBmYWlscy4gRGVmYXVsdHMgdG8gYHRydWVgLlxuICogQHJldHVybnMgQSBQcm9taXNlIHRoYXQgcmVzb2x2ZXMgd2l0aCB0aGUgRkhJUiBQYXRpZW50IG9iamVjdCwgb3IgYG51bGxgIGlmXG4gKiAgIHRoZSBwYXRpZW50IFVVSUQgaXMgbnVsbCBvciB0aGUgcGF0aWVudCBpcyBub3QgZm91bmQuXG4gKiBAdGhyb3dzIFJldGhyb3dzIGFueSBlcnJvciBmcm9tIHRoZSBzZXJ2ZXIgcmVxdWVzdCBpZiBubyBvZmZsaW5lIHBhdGllbnQgaXMgZm91bmQuXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHRzXG4gKiBpbXBvcnQgeyBmZXRjaEN1cnJlbnRQYXRpZW50IH0gZnJvbSAnQG9wZW5tcnMvZXNtLWZyYW1ld29yayc7XG4gKiBjb25zdCBwYXRpZW50ID0gYXdhaXQgZmV0Y2hDdXJyZW50UGF0aWVudCgncGF0aWVudC11dWlkJyk7XG4gKiBpZiAocGF0aWVudCkge1xuICogICBjb25zb2xlLmxvZygnUGF0aWVudCBuYW1lOicsIHBhdGllbnQubmFtZT8uWzBdPy50ZXh0KTtcbiAqIH1cbiAqIGBgYFxuICovIGV4cG9ydCBhc3luYyBmdW5jdGlvbiBmZXRjaEN1cnJlbnRQYXRpZW50KHBhdGllbnRVdWlkLCBmZXRjaEluaXQsIGluY2x1ZGVPZmZsaW5lUGF0aWVudHMgPSB0cnVlKSB7XG4gICAgaWYgKHBhdGllbnRVdWlkKSB7XG4gICAgICAgIGxldCBlcnIgPSBudWxsO1xuICAgICAgICBjb25zdCBbb25saW5lUGF0aWVudCwgb2ZmbGluZVBhdGllbnRdID0gYXdhaXQgUHJvbWlzZS5hbGwoW1xuICAgICAgICAgICAgb3Blbm1yc0ZldGNoKGAke2ZoaXJCYXNlVXJsfS9QYXRpZW50LyR7cGF0aWVudFV1aWR9YCwgZmV0Y2hJbml0KS5jYXRjaCgoZSk9PmVyciA9IGUpLFxuICAgICAgICAgICAgaW5jbHVkZU9mZmxpbmVQYXRpZW50cyA/IGdldE9mZmxpbmVSZWdpc3RlcmVkUGF0aWVudEFzRmhpclBhdGllbnQocGF0aWVudFV1aWQpIDogUHJvbWlzZS5yZXNvbHZlKG51bGwpXG4gICAgICAgIF0pO1xuICAgICAgICBpZiAob25saW5lUGF0aWVudC5vaykge1xuICAgICAgICAgICAgcmV0dXJuIG9ubGluZVBhdGllbnQuZGF0YTtcbiAgICAgICAgfVxuICAgICAgICBpZiAob2ZmbGluZVBhdGllbnQpIHtcbiAgICAgICAgICAgIHJldHVybiBvZmZsaW5lUGF0aWVudDtcbiAgICAgICAgfVxuICAgICAgICBpZiAoZXJyKSB7XG4gICAgICAgICAgICB0aHJvdyBlcnI7XG4gICAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIG51bGw7XG59XG5hc3luYyBmdW5jdGlvbiBnZXRPZmZsaW5lUmVnaXN0ZXJlZFBhdGllbnRBc0ZoaXJQYXRpZW50KHBhdGllbnRVdWlkKSB7XG4gICAgY29uc3QgcGF0aWVudFJlZ2lzdHJhdGlvblN5bmNJdGVtcyA9IGF3YWl0IGdldFN5bmNocm9uaXphdGlvbkl0ZW1zKCdwYXRpZW50LXJlZ2lzdHJhdGlvbicpO1xuICAgIGNvbnN0IHBhdGllbnRTeW5jSXRlbSA9IHBhdGllbnRSZWdpc3RyYXRpb25TeW5jSXRlbXMuZmluZCgoaXRlbSk9Pml0ZW0uZmhpclBhdGllbnQuaWQgPT09IHBhdGllbnRVdWlkKTtcbiAgICByZXR1cm4gcGF0aWVudFN5bmNJdGVtPy5maGlyUGF0aWVudCA/PyBudWxsO1xufVxuIl0sIm5hbWVzIjpbImZoaXJCYXNlVXJsIiwib3Blbm1yc0ZldGNoIiwiZ2V0U3luY2hyb25pemF0aW9uSXRlbXMiLCJmZXRjaEN1cnJlbnRQYXRpZW50IiwicGF0aWVudFV1aWQiLCJmZXRjaEluaXQiLCJpbmNsdWRlT2ZmbGluZVBhdGllbnRzIiwiZXJyIiwib25saW5lUGF0aWVudCIsIm9mZmxpbmVQYXRpZW50IiwiUHJvbWlzZSIsImFsbCIsImNhdGNoIiwiZSIsImdldE9mZmxpbmVSZWdpc3RlcmVkUGF0aWVudEFzRmhpclBhdGllbnQiLCJyZXNvbHZlIiwib2siLCJkYXRhIiwicGF0aWVudFJlZ2lzdHJhdGlvblN5bmNJdGVtcyIsInBhdGllbnRTeW5jSXRlbSIsImZpbmQiLCJpdGVtIiwiZmhpclBhdGllbnQiLCJpZCJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///../../framework/esm-emr-api/dist/current-patient.js\n");
239
239
 
240
240
  /***/ }),
241
241
 
@@ -395,7 +395,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n\n//# sourceURL=[module]\n//#
395
395
  \******************************************************/
396
396
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
397
397
 
398
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ getVisitTypes: () => (/* binding */ getVisitTypes),\n/* harmony export */ toVisitTypeObject: () => (/* binding */ toVisitTypeObject)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-api */ \"../../framework/esm-api/dist/index.js\");\n/* harmony import */ var rxjs_operators_index_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! rxjs/operators/index.js */ \"../../../node_modules/rxjs/operators/index.js\");\n/** @module @category API */ \n\nfunction toVisitTypeObject(openmrsRestForm) {\n return {\n uuid: openmrsRestForm.uuid,\n display: openmrsRestForm.display,\n name: openmrsRestForm.name\n };\n}\nfunction getVisitTypes() {\n return (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.openmrsObservableFetch)(`${_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.restBaseUrl}/visittype`).pipe((0,rxjs_operators_index_js__WEBPACK_IMPORTED_MODULE_1__.map)((results)=>{\n const visitTypes = results.data.results.map(toVisitTypeObject);\n return visitTypes;\n })).pipe((0,rxjs_operators_index_js__WEBPACK_IMPORTED_MODULE_1__.take)(1));\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1lbXItYXBpL2Rpc3QvdmlzaXQtdHlwZS5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUEsMEJBQTBCLEdBQTBFO0FBQ2hEO0FBQzdDLFNBQVNJLGtCQUFrQkMsZUFBZTtJQUM3QyxPQUFPO1FBQ0hDLE1BQU1ELGdCQUFnQkMsSUFBSTtRQUMxQkMsU0FBU0YsZ0JBQWdCRSxPQUFPO1FBQ2hDQyxNQUFNSCxnQkFBZ0JHLElBQUk7SUFDOUI7QUFDSjtBQUNPLFNBQVNDO0lBQ1osT0FBT1Qsd0VBQXNCQSxDQUFDLEdBQUdDLHlEQUFXQSxDQUFDLFVBQVUsQ0FBQyxFQUFFUyxJQUFJLENBQUNSLDREQUFHQSxDQUFDLENBQUNTO1FBQ2hFLE1BQU1DLGFBQWFELFFBQVFFLElBQUksQ0FBQ0YsT0FBTyxDQUFDVCxHQUFHLENBQUNFO1FBQzVDLE9BQU9RO0lBQ1gsSUFBSUYsSUFBSSxDQUFDUCw2REFBSUEsQ0FBQztBQUNsQiIsInNvdXJjZXMiOlsid2VicGFjazovL0BvcGVubXJzL2VzbS1hcHAtc2hlbGwvLi4vLi4vZnJhbWV3b3JrL2VzbS1lbXItYXBpL2Rpc3QvdmlzaXQtdHlwZS5qcz9lMjU1Il0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBAbW9kdWxlIEBjYXRlZ29yeSBBUEkgKi8gaW1wb3J0IHsgb3Blbm1yc09ic2VydmFibGVGZXRjaCwgcmVzdEJhc2VVcmwgfSBmcm9tIFwiQG9wZW5tcnMvZXNtLWFwaVwiO1xuaW1wb3J0IHsgbWFwLCB0YWtlIH0gZnJvbSBcInJ4anMvb3BlcmF0b3JzL2luZGV4LmpzXCI7XG5leHBvcnQgZnVuY3Rpb24gdG9WaXNpdFR5cGVPYmplY3Qob3Blbm1yc1Jlc3RGb3JtKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgICAgdXVpZDogb3Blbm1yc1Jlc3RGb3JtLnV1aWQsXG4gICAgICAgIGRpc3BsYXk6IG9wZW5tcnNSZXN0Rm9ybS5kaXNwbGF5LFxuICAgICAgICBuYW1lOiBvcGVubXJzUmVzdEZvcm0ubmFtZVxuICAgIH07XG59XG5leHBvcnQgZnVuY3Rpb24gZ2V0VmlzaXRUeXBlcygpIHtcbiAgICByZXR1cm4gb3Blbm1yc09ic2VydmFibGVGZXRjaChgJHtyZXN0QmFzZVVybH0vdmlzaXR0eXBlYCkucGlwZShtYXAoKHJlc3VsdHMpPT57XG4gICAgICAgIGNvbnN0IHZpc2l0VHlwZXMgPSByZXN1bHRzLmRhdGEucmVzdWx0cy5tYXAodG9WaXNpdFR5cGVPYmplY3QpO1xuICAgICAgICByZXR1cm4gdmlzaXRUeXBlcztcbiAgICB9KSkucGlwZSh0YWtlKDEpKTtcbn1cbiJdLCJuYW1lcyI6WyJvcGVubXJzT2JzZXJ2YWJsZUZldGNoIiwicmVzdEJhc2VVcmwiLCJtYXAiLCJ0YWtlIiwidG9WaXNpdFR5cGVPYmplY3QiLCJvcGVubXJzUmVzdEZvcm0iLCJ1dWlkIiwiZGlzcGxheSIsIm5hbWUiLCJnZXRWaXNpdFR5cGVzIiwicGlwZSIsInJlc3VsdHMiLCJ2aXNpdFR5cGVzIiwiZGF0YSJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///../../framework/esm-emr-api/dist/visit-type.js\n");
398
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ getVisitTypes: () => (/* binding */ getVisitTypes),\n/* harmony export */ toVisitTypeObject: () => (/* binding */ toVisitTypeObject)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-api */ \"../../framework/esm-api/dist/index.js\");\n/* harmony import */ var rxjs_operators_index_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! rxjs/operators/index.js */ \"../../../node_modules/rxjs/operators/index.js\");\n/** @module @category API */ \n\nfunction toVisitTypeObject(openmrsRestForm) {\n return {\n uuid: openmrsRestForm.uuid,\n display: openmrsRestForm.display,\n name: openmrsRestForm.name\n };\n}\n/**\n * Fetches all available visit types from the OpenMRS REST API.\n *\n * @returns An Observable that emits an array of VisitType objects and then completes.\n * The Observable will emit exactly one value containing all visit types.\n *\n * @example\n * ```ts\n * import { getVisitTypes } from '@openmrs/esm-framework';\n * getVisitTypes().subscribe((visitTypes) => {\n * console.log('Available visit types:', visitTypes);\n * });\n * ```\n */ function getVisitTypes() {\n return (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.openmrsObservableFetch)(`${_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.restBaseUrl}/visittype`).pipe((0,rxjs_operators_index_js__WEBPACK_IMPORTED_MODULE_1__.map)((results)=>{\n const visitTypes = results.data.results.map(toVisitTypeObject);\n return visitTypes;\n })).pipe((0,rxjs_operators_index_js__WEBPACK_IMPORTED_MODULE_1__.take)(1));\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1lbXItYXBpL2Rpc3QvdmlzaXQtdHlwZS5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUEsMEJBQTBCLEdBQTBFO0FBQ2hEO0FBQzdDLFNBQVNJLGtCQUFrQkMsZUFBZTtJQUM3QyxPQUFPO1FBQ0hDLE1BQU1ELGdCQUFnQkMsSUFBSTtRQUMxQkMsU0FBU0YsZ0JBQWdCRSxPQUFPO1FBQ2hDQyxNQUFNSCxnQkFBZ0JHLElBQUk7SUFDOUI7QUFDSjtBQUNBOzs7Ozs7Ozs7Ozs7O0NBYUMsR0FBVSxTQUFTQztJQUNoQixPQUFPVCx3RUFBc0JBLENBQUMsR0FBR0MseURBQVdBLENBQUMsVUFBVSxDQUFDLEVBQUVTLElBQUksQ0FBQ1IsNERBQUdBLENBQUMsQ0FBQ1M7UUFDaEUsTUFBTUMsYUFBYUQsUUFBUUUsSUFBSSxDQUFDRixPQUFPLENBQUNULEdBQUcsQ0FBQ0U7UUFDNUMsT0FBT1E7SUFDWCxJQUFJRixJQUFJLENBQUNQLDZEQUFJQSxDQUFDO0FBQ2xCIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQG9wZW5tcnMvZXNtLWFwcC1zaGVsbC8uLi8uLi9mcmFtZXdvcmsvZXNtLWVtci1hcGkvZGlzdC92aXNpdC10eXBlLmpzP2UyNTUiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBtb2R1bGUgQGNhdGVnb3J5IEFQSSAqLyBpbXBvcnQgeyBvcGVubXJzT2JzZXJ2YWJsZUZldGNoLCByZXN0QmFzZVVybCB9IGZyb20gXCJAb3Blbm1ycy9lc20tYXBpXCI7XG5pbXBvcnQgeyBtYXAsIHRha2UgfSBmcm9tIFwicnhqcy9vcGVyYXRvcnMvaW5kZXguanNcIjtcbmV4cG9ydCBmdW5jdGlvbiB0b1Zpc2l0VHlwZU9iamVjdChvcGVubXJzUmVzdEZvcm0pIHtcbiAgICByZXR1cm4ge1xuICAgICAgICB1dWlkOiBvcGVubXJzUmVzdEZvcm0udXVpZCxcbiAgICAgICAgZGlzcGxheTogb3Blbm1yc1Jlc3RGb3JtLmRpc3BsYXksXG4gICAgICAgIG5hbWU6IG9wZW5tcnNSZXN0Rm9ybS5uYW1lXG4gICAgfTtcbn1cbi8qKlxuICogRmV0Y2hlcyBhbGwgYXZhaWxhYmxlIHZpc2l0IHR5cGVzIGZyb20gdGhlIE9wZW5NUlMgUkVTVCBBUEkuXG4gKlxuICogQHJldHVybnMgQW4gT2JzZXJ2YWJsZSB0aGF0IGVtaXRzIGFuIGFycmF5IG9mIFZpc2l0VHlwZSBvYmplY3RzIGFuZCB0aGVuIGNvbXBsZXRlcy5cbiAqICAgVGhlIE9ic2VydmFibGUgd2lsbCBlbWl0IGV4YWN0bHkgb25lIHZhbHVlIGNvbnRhaW5pbmcgYWxsIHZpc2l0IHR5cGVzLlxuICpcbiAqIEBleGFtcGxlXG4gKiBgYGB0c1xuICogaW1wb3J0IHsgZ2V0VmlzaXRUeXBlcyB9IGZyb20gJ0BvcGVubXJzL2VzbS1mcmFtZXdvcmsnO1xuICogZ2V0VmlzaXRUeXBlcygpLnN1YnNjcmliZSgodmlzaXRUeXBlcykgPT4ge1xuICogICBjb25zb2xlLmxvZygnQXZhaWxhYmxlIHZpc2l0IHR5cGVzOicsIHZpc2l0VHlwZXMpO1xuICogfSk7XG4gKiBgYGBcbiAqLyBleHBvcnQgZnVuY3Rpb24gZ2V0VmlzaXRUeXBlcygpIHtcbiAgICByZXR1cm4gb3Blbm1yc09ic2VydmFibGVGZXRjaChgJHtyZXN0QmFzZVVybH0vdmlzaXR0eXBlYCkucGlwZShtYXAoKHJlc3VsdHMpPT57XG4gICAgICAgIGNvbnN0IHZpc2l0VHlwZXMgPSByZXN1bHRzLmRhdGEucmVzdWx0cy5tYXAodG9WaXNpdFR5cGVPYmplY3QpO1xuICAgICAgICByZXR1cm4gdmlzaXRUeXBlcztcbiAgICB9KSkucGlwZSh0YWtlKDEpKTtcbn1cbiJdLCJuYW1lcyI6WyJvcGVubXJzT2JzZXJ2YWJsZUZldGNoIiwicmVzdEJhc2VVcmwiLCJtYXAiLCJ0YWtlIiwidG9WaXNpdFR5cGVPYmplY3QiLCJvcGVubXJzUmVzdEZvcm0iLCJ1dWlkIiwiZGlzcGxheSIsIm5hbWUiLCJnZXRWaXNpdFR5cGVzIiwicGlwZSIsInJlc3VsdHMiLCJ2aXNpdFR5cGVzIiwiZGF0YSJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///../../framework/esm-emr-api/dist/visit-type.js\n");
399
399
 
400
400
  /***/ }),
401
401
 
@@ -405,7 +405,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
405
405
  \*******************************************************/
406
406
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
407
407
 
408
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ VisitMode: () => (/* binding */ VisitMode),\n/* harmony export */ VisitStatus: () => (/* binding */ VisitStatus),\n/* harmony export */ defaultVisitCustomRepresentation: () => (/* binding */ defaultVisitCustomRepresentation),\n/* harmony export */ getStartedVisit: () => (/* binding */ getStartedVisit),\n/* harmony export */ getVisitStore: () => (/* binding */ getVisitStore),\n/* harmony export */ getVisitsForPatient: () => (/* binding */ getVisitsForPatient),\n/* harmony export */ saveVisit: () => (/* binding */ saveVisit),\n/* harmony export */ setCurrentVisit: () => (/* binding */ setCurrentVisit),\n/* harmony export */ updateVisit: () => (/* binding */ updateVisit)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-api */ \"../../framework/esm-api/dist/index.js\");\n/* harmony import */ var _openmrs_esm_state__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-state */ \"../../framework/esm-state/dist/index.js\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! rxjs */ \"webpack/sharing/consume/default/rxjs/rxjs\");\n/** @module @category API */ \n\n\nvar VisitMode = /*#__PURE__*/ function(VisitMode) {\n VisitMode[\"NEWVISIT\"] = \"startVisit\";\n VisitMode[\"EDITVISIT\"] = \"editVisit\";\n VisitMode[\"LOADING\"] = \"loadingVisit\";\n return VisitMode;\n}({});\nvar VisitStatus = /*#__PURE__*/ function(VisitStatus) {\n VisitStatus[\"NOTSTARTED\"] = \"notStarted\";\n VisitStatus[\"ONGOING\"] = \"ongoing\";\n return VisitStatus;\n}({});\nconst defaultVisitCustomRepresentation = 'custom:(uuid,display,voided,indication,startDatetime,stopDatetime,' + 'encounters:(uuid,display,encounterDatetime,' + 'form:(uuid,name),location:ref,' + 'encounterType:ref,' + 'encounterProviders:(uuid,display,' + 'provider:(uuid,display))),' + 'patient:(uuid,display),' + 'visitType:(uuid,name,display),' + 'attributes:(uuid,display,attributeType:(name,datatypeClassname,uuid),value),' + 'location:(uuid,name,display))';\nconst initialState = getVisitSessionStorage() || {\n patientUuid: null,\n manuallySetVisitUuid: null,\n mutateVisitCallbacks: {}\n};\nfunction getVisitStore() {\n return (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_1__.getGlobalStore)('visit', initialState);\n}\nfunction setCurrentVisit(patientUuid, visitUuid) {\n getVisitStore().setState({\n patientUuid,\n manuallySetVisitUuid: visitUuid\n });\n}\ngetVisitStore().subscribe((state)=>{\n setVisitSessionStorage(state);\n});\nfunction setVisitSessionStorage(value) {\n sessionStorage.setItem('openmrs:visitStoreState', JSON.stringify(value));\n}\nfunction getVisitSessionStorage() {\n try {\n return JSON.parse(sessionStorage.getItem('openmrs:visitStoreState') || 'null');\n } catch (e) {\n return null;\n }\n}\nfunction saveVisit(payload, abortController) {\n return (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.openmrsFetch)(`${_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.restBaseUrl}/visit`, {\n signal: abortController.signal,\n method: 'POST',\n headers: {\n 'Content-type': 'application/json'\n },\n body: payload\n });\n}\nfunction updateVisit(uuid, payload, abortController) {\n return (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.openmrsFetch)(`${_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.restBaseUrl}/visit/${uuid}`, {\n signal: abortController.signal,\n method: 'POST',\n headers: {\n 'Content-type': 'application/json'\n },\n body: payload\n });\n}\n/**\n * @deprecated Use the `useVisit` hook instead.\n */ function getVisitsForPatient(patientUuid, abortController, v) {\n const custom = v ?? defaultVisitCustomRepresentation;\n return (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.openmrsFetch)(`${_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.restBaseUrl}/visit?patient=${patientUuid}&v=${custom}`, {\n signal: abortController.signal,\n method: 'GET',\n headers: {\n 'Content-type': 'application/json'\n }\n });\n}\n/** @deprecated */ const getStartedVisit = new rxjs__WEBPACK_IMPORTED_MODULE_2__.BehaviorSubject(null);\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1lbXItYXBpL2Rpc3QvdmlzaXQtdXRpbHMuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsMEJBQTBCLEdBQWdFO0FBQ3RDO0FBQ2I7QUFDaEMsSUFBSUksWUFBWSxXQUFXLEdBQUcsU0FBU0EsU0FBUztJQUNuREEsU0FBUyxDQUFDLFdBQVcsR0FBRztJQUN4QkEsU0FBUyxDQUFDLFlBQVksR0FBRztJQUN6QkEsU0FBUyxDQUFDLFVBQVUsR0FBRztJQUN2QixPQUFPQTtBQUNYLEVBQUUsQ0FBQyxHQUFHO0FBQ0MsSUFBSUMsY0FBYyxXQUFXLEdBQUcsU0FBU0EsV0FBVztJQUN2REEsV0FBVyxDQUFDLGFBQWEsR0FBRztJQUM1QkEsV0FBVyxDQUFDLFVBQVUsR0FBRztJQUN6QixPQUFPQTtBQUNYLEVBQUUsQ0FBQyxHQUFHO0FBQ0MsTUFBTUMsbUNBQW1DLHVFQUF1RSxnREFBZ0QsbUNBQW1DLHVCQUF1QixzQ0FBc0MsK0JBQStCLDRCQUE0QixtQ0FBbUMsaUZBQWlGLGdDQUFnQztBQUN0ZCxNQUFNQyxlQUFlQyw0QkFBNEI7SUFDN0NDLGFBQWE7SUFDYkMsc0JBQXNCO0lBQ3RCQyxzQkFBc0IsQ0FBQztBQUMzQjtBQUNPLFNBQVNDO0lBQ1osT0FBT1Ysa0VBQWNBLENBQUMsU0FBU0s7QUFDbkM7QUFDTyxTQUFTTSxnQkFBZ0JKLFdBQVcsRUFBRUssU0FBUztJQUNsREYsZ0JBQWdCRyxRQUFRLENBQUM7UUFDckJOO1FBQ0FDLHNCQUFzQkk7SUFDMUI7QUFDSjtBQUNBRixnQkFBZ0JJLFNBQVMsQ0FBQyxDQUFDQztJQUN2QkMsdUJBQXVCRDtBQUMzQjtBQUNBLFNBQVNDLHVCQUF1QkMsS0FBSztJQUNqQ0MsZUFBZUMsT0FBTyxDQUFDLDJCQUEyQkMsS0FBS0MsU0FBUyxDQUFDSjtBQUNyRTtBQUNBLFNBQVNYO0lBQ0wsSUFBSTtRQUNBLE9BQU9jLEtBQUtFLEtBQUssQ0FBQ0osZUFBZUssT0FBTyxDQUFDLDhCQUE4QjtJQUMzRSxFQUFFLE9BQU9DLEdBQUc7UUFDUixPQUFPO0lBQ1g7QUFDSjtBQUNPLFNBQVNDLFVBQVVDLE9BQU8sRUFBRUMsZUFBZTtJQUM5QyxPQUFPN0IsOERBQVlBLENBQUMsR0FBR0MseURBQVdBLENBQUMsTUFBTSxDQUFDLEVBQUU7UUFDeEM2QixRQUFRRCxnQkFBZ0JDLE1BQU07UUFDOUJDLFFBQVE7UUFDUkMsU0FBUztZQUNMLGdCQUFnQjtRQUNwQjtRQUNBQyxNQUFNTDtJQUNWO0FBQ0o7QUFDTyxTQUFTTSxZQUFZQyxJQUFJLEVBQUVQLE9BQU8sRUFBRUMsZUFBZTtJQUN0RCxPQUFPN0IsOERBQVlBLENBQUMsR0FBR0MseURBQVdBLENBQUMsT0FBTyxFQUFFa0MsTUFBTSxFQUFFO1FBQ2hETCxRQUFRRCxnQkFBZ0JDLE1BQU07UUFDOUJDLFFBQVE7UUFDUkMsU0FBUztZQUNMLGdCQUFnQjtRQUNwQjtRQUNBQyxNQUFNTDtJQUNWO0FBQ0o7QUFDQTs7Q0FFQyxHQUFVLFNBQVNRLG9CQUFvQjNCLFdBQVcsRUFBRW9CLGVBQWUsRUFBRVEsQ0FBQztJQUNuRSxNQUFNQyxTQUFTRCxLQUFLL0I7SUFDcEIsT0FBT04sOERBQVlBLENBQUMsR0FBR0MseURBQVdBLENBQUMsZUFBZSxFQUFFUSxZQUFZLEdBQUcsRUFBRTZCLFFBQVEsRUFBRTtRQUMzRVIsUUFBUUQsZ0JBQWdCQyxNQUFNO1FBQzlCQyxRQUFRO1FBQ1JDLFNBQVM7WUFDTCxnQkFBZ0I7UUFDcEI7SUFDSjtBQUNKO0FBQ0EsZ0JBQWdCLEdBQVUsTUFBTU8sa0JBQWtCLElBQUlwQyxpREFBZUEsQ0FBQyxNQUFNIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQG9wZW5tcnMvZXNtLWFwcC1zaGVsbC8uLi8uLi9mcmFtZXdvcmsvZXNtLWVtci1hcGkvZGlzdC92aXNpdC11dGlscy5qcz82ZGU4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBAbW9kdWxlIEBjYXRlZ29yeSBBUEkgKi8gaW1wb3J0IHsgb3Blbm1yc0ZldGNoLCByZXN0QmFzZVVybCB9IGZyb20gXCJAb3Blbm1ycy9lc20tYXBpXCI7XG5pbXBvcnQgeyBnZXRHbG9iYWxTdG9yZSB9IGZyb20gXCJAb3Blbm1ycy9lc20tc3RhdGVcIjtcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCB9IGZyb20gXCJyeGpzXCI7XG5leHBvcnQgdmFyIFZpc2l0TW9kZSA9IC8qI19fUFVSRV9fKi8gZnVuY3Rpb24oVmlzaXRNb2RlKSB7XG4gICAgVmlzaXRNb2RlW1wiTkVXVklTSVRcIl0gPSBcInN0YXJ0VmlzaXRcIjtcbiAgICBWaXNpdE1vZGVbXCJFRElUVklTSVRcIl0gPSBcImVkaXRWaXNpdFwiO1xuICAgIFZpc2l0TW9kZVtcIkxPQURJTkdcIl0gPSBcImxvYWRpbmdWaXNpdFwiO1xuICAgIHJldHVybiBWaXNpdE1vZGU7XG59KHt9KTtcbmV4cG9ydCB2YXIgVmlzaXRTdGF0dXMgPSAvKiNfX1BVUkVfXyovIGZ1bmN0aW9uKFZpc2l0U3RhdHVzKSB7XG4gICAgVmlzaXRTdGF0dXNbXCJOT1RTVEFSVEVEXCJdID0gXCJub3RTdGFydGVkXCI7XG4gICAgVmlzaXRTdGF0dXNbXCJPTkdPSU5HXCJdID0gXCJvbmdvaW5nXCI7XG4gICAgcmV0dXJuIFZpc2l0U3RhdHVzO1xufSh7fSk7XG5leHBvcnQgY29uc3QgZGVmYXVsdFZpc2l0Q3VzdG9tUmVwcmVzZW50YXRpb24gPSAnY3VzdG9tOih1dWlkLGRpc3BsYXksdm9pZGVkLGluZGljYXRpb24sc3RhcnREYXRldGltZSxzdG9wRGF0ZXRpbWUsJyArICdlbmNvdW50ZXJzOih1dWlkLGRpc3BsYXksZW5jb3VudGVyRGF0ZXRpbWUsJyArICdmb3JtOih1dWlkLG5hbWUpLGxvY2F0aW9uOnJlZiwnICsgJ2VuY291bnRlclR5cGU6cmVmLCcgKyAnZW5jb3VudGVyUHJvdmlkZXJzOih1dWlkLGRpc3BsYXksJyArICdwcm92aWRlcjoodXVpZCxkaXNwbGF5KSkpLCcgKyAncGF0aWVudDoodXVpZCxkaXNwbGF5KSwnICsgJ3Zpc2l0VHlwZToodXVpZCxuYW1lLGRpc3BsYXkpLCcgKyAnYXR0cmlidXRlczoodXVpZCxkaXNwbGF5LGF0dHJpYnV0ZVR5cGU6KG5hbWUsZGF0YXR5cGVDbGFzc25hbWUsdXVpZCksdmFsdWUpLCcgKyAnbG9jYXRpb246KHV1aWQsbmFtZSxkaXNwbGF5KSknO1xuY29uc3QgaW5pdGlhbFN0YXRlID0gZ2V0VmlzaXRTZXNzaW9uU3RvcmFnZSgpIHx8IHtcbiAgICBwYXRpZW50VXVpZDogbnVsbCxcbiAgICBtYW51YWxseVNldFZpc2l0VXVpZDogbnVsbCxcbiAgICBtdXRhdGVWaXNpdENhbGxiYWNrczoge31cbn07XG5leHBvcnQgZnVuY3Rpb24gZ2V0VmlzaXRTdG9yZSgpIHtcbiAgICByZXR1cm4gZ2V0R2xvYmFsU3RvcmUoJ3Zpc2l0JywgaW5pdGlhbFN0YXRlKTtcbn1cbmV4cG9ydCBmdW5jdGlvbiBzZXRDdXJyZW50VmlzaXQocGF0aWVudFV1aWQsIHZpc2l0VXVpZCkge1xuICAgIGdldFZpc2l0U3RvcmUoKS5zZXRTdGF0ZSh7XG4gICAgICAgIHBhdGllbnRVdWlkLFxuICAgICAgICBtYW51YWxseVNldFZpc2l0VXVpZDogdmlzaXRVdWlkXG4gICAgfSk7XG59XG5nZXRWaXNpdFN0b3JlKCkuc3Vic2NyaWJlKChzdGF0ZSk9PntcbiAgICBzZXRWaXNpdFNlc3Npb25TdG9yYWdlKHN0YXRlKTtcbn0pO1xuZnVuY3Rpb24gc2V0VmlzaXRTZXNzaW9uU3RvcmFnZSh2YWx1ZSkge1xuICAgIHNlc3Npb25TdG9yYWdlLnNldEl0ZW0oJ29wZW5tcnM6dmlzaXRTdG9yZVN0YXRlJywgSlNPTi5zdHJpbmdpZnkodmFsdWUpKTtcbn1cbmZ1bmN0aW9uIGdldFZpc2l0U2Vzc2lvblN0b3JhZ2UoKSB7XG4gICAgdHJ5IHtcbiAgICAgICAgcmV0dXJuIEpTT04ucGFyc2Uoc2Vzc2lvblN0b3JhZ2UuZ2V0SXRlbSgnb3Blbm1yczp2aXNpdFN0b3JlU3RhdGUnKSB8fCAnbnVsbCcpO1xuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgcmV0dXJuIG51bGw7XG4gICAgfVxufVxuZXhwb3J0IGZ1bmN0aW9uIHNhdmVWaXNpdChwYXlsb2FkLCBhYm9ydENvbnRyb2xsZXIpIHtcbiAgICByZXR1cm4gb3Blbm1yc0ZldGNoKGAke3Jlc3RCYXNlVXJsfS92aXNpdGAsIHtcbiAgICAgICAgc2lnbmFsOiBhYm9ydENvbnRyb2xsZXIuc2lnbmFsLFxuICAgICAgICBtZXRob2Q6ICdQT1NUJyxcbiAgICAgICAgaGVhZGVyczoge1xuICAgICAgICAgICAgJ0NvbnRlbnQtdHlwZSc6ICdhcHBsaWNhdGlvbi9qc29uJ1xuICAgICAgICB9LFxuICAgICAgICBib2R5OiBwYXlsb2FkXG4gICAgfSk7XG59XG5leHBvcnQgZnVuY3Rpb24gdXBkYXRlVmlzaXQodXVpZCwgcGF5bG9hZCwgYWJvcnRDb250cm9sbGVyKSB7XG4gICAgcmV0dXJuIG9wZW5tcnNGZXRjaChgJHtyZXN0QmFzZVVybH0vdmlzaXQvJHt1dWlkfWAsIHtcbiAgICAgICAgc2lnbmFsOiBhYm9ydENvbnRyb2xsZXIuc2lnbmFsLFxuICAgICAgICBtZXRob2Q6ICdQT1NUJyxcbiAgICAgICAgaGVhZGVyczoge1xuICAgICAgICAgICAgJ0NvbnRlbnQtdHlwZSc6ICdhcHBsaWNhdGlvbi9qc29uJ1xuICAgICAgICB9LFxuICAgICAgICBib2R5OiBwYXlsb2FkXG4gICAgfSk7XG59XG4vKipcbiAqIEBkZXByZWNhdGVkIFVzZSB0aGUgYHVzZVZpc2l0YCBob29rIGluc3RlYWQuXG4gKi8gZXhwb3J0IGZ1bmN0aW9uIGdldFZpc2l0c0ZvclBhdGllbnQocGF0aWVudFV1aWQsIGFib3J0Q29udHJvbGxlciwgdikge1xuICAgIGNvbnN0IGN1c3RvbSA9IHYgPz8gZGVmYXVsdFZpc2l0Q3VzdG9tUmVwcmVzZW50YXRpb247XG4gICAgcmV0dXJuIG9wZW5tcnNGZXRjaChgJHtyZXN0QmFzZVVybH0vdmlzaXQ/cGF0aWVudD0ke3BhdGllbnRVdWlkfSZ2PSR7Y3VzdG9tfWAsIHtcbiAgICAgICAgc2lnbmFsOiBhYm9ydENvbnRyb2xsZXIuc2lnbmFsLFxuICAgICAgICBtZXRob2Q6ICdHRVQnLFxuICAgICAgICBoZWFkZXJzOiB7XG4gICAgICAgICAgICAnQ29udGVudC10eXBlJzogJ2FwcGxpY2F0aW9uL2pzb24nXG4gICAgICAgIH1cbiAgICB9KTtcbn1cbi8qKiBAZGVwcmVjYXRlZCAqLyBleHBvcnQgY29uc3QgZ2V0U3RhcnRlZFZpc2l0ID0gbmV3IEJlaGF2aW9yU3ViamVjdChudWxsKTtcbiJdLCJuYW1lcyI6WyJvcGVubXJzRmV0Y2giLCJyZXN0QmFzZVVybCIsImdldEdsb2JhbFN0b3JlIiwiQmVoYXZpb3JTdWJqZWN0IiwiVmlzaXRNb2RlIiwiVmlzaXRTdGF0dXMiLCJkZWZhdWx0VmlzaXRDdXN0b21SZXByZXNlbnRhdGlvbiIsImluaXRpYWxTdGF0ZSIsImdldFZpc2l0U2Vzc2lvblN0b3JhZ2UiLCJwYXRpZW50VXVpZCIsIm1hbnVhbGx5U2V0VmlzaXRVdWlkIiwibXV0YXRlVmlzaXRDYWxsYmFja3MiLCJnZXRWaXNpdFN0b3JlIiwic2V0Q3VycmVudFZpc2l0IiwidmlzaXRVdWlkIiwic2V0U3RhdGUiLCJzdWJzY3JpYmUiLCJzdGF0ZSIsInNldFZpc2l0U2Vzc2lvblN0b3JhZ2UiLCJ2YWx1ZSIsInNlc3Npb25TdG9yYWdlIiwic2V0SXRlbSIsIkpTT04iLCJzdHJpbmdpZnkiLCJwYXJzZSIsImdldEl0ZW0iLCJlIiwic2F2ZVZpc2l0IiwicGF5bG9hZCIsImFib3J0Q29udHJvbGxlciIsInNpZ25hbCIsIm1ldGhvZCIsImhlYWRlcnMiLCJib2R5IiwidXBkYXRlVmlzaXQiLCJ1dWlkIiwiZ2V0VmlzaXRzRm9yUGF0aWVudCIsInYiLCJjdXN0b20iLCJnZXRTdGFydGVkVmlzaXQiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///../../framework/esm-emr-api/dist/visit-utils.js\n");
408
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ VisitMode: () => (/* binding */ VisitMode),\n/* harmony export */ VisitStatus: () => (/* binding */ VisitStatus),\n/* harmony export */ defaultVisitCustomRepresentation: () => (/* binding */ defaultVisitCustomRepresentation),\n/* harmony export */ getStartedVisit: () => (/* binding */ getStartedVisit),\n/* harmony export */ getVisitStore: () => (/* binding */ getVisitStore),\n/* harmony export */ getVisitsForPatient: () => (/* binding */ getVisitsForPatient),\n/* harmony export */ saveVisit: () => (/* binding */ saveVisit),\n/* harmony export */ setCurrentVisit: () => (/* binding */ setCurrentVisit),\n/* harmony export */ updateVisit: () => (/* binding */ updateVisit)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-api */ \"../../framework/esm-api/dist/index.js\");\n/* harmony import */ var _openmrs_esm_state__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-state */ \"../../framework/esm-state/dist/index.js\");\n/* harmony import */ var rxjs__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! rxjs */ \"webpack/sharing/consume/default/rxjs/rxjs\");\n/** @module @category API */ \n\n\nvar VisitMode = /*#__PURE__*/ function(VisitMode) {\n VisitMode[\"NEWVISIT\"] = \"startVisit\";\n VisitMode[\"EDITVISIT\"] = \"editVisit\";\n VisitMode[\"LOADING\"] = \"loadingVisit\";\n return VisitMode;\n}({});\nvar VisitStatus = /*#__PURE__*/ function(VisitStatus) {\n VisitStatus[\"NOTSTARTED\"] = \"notStarted\";\n VisitStatus[\"ONGOING\"] = \"ongoing\";\n return VisitStatus;\n}({});\n/**\n * The default custom representation string for fetching visit data from the REST API.\n * This representation includes comprehensive visit details such as encounters, patient,\n * visit type, attributes, and location information.\n */ const defaultVisitCustomRepresentation = 'custom:(uuid,display,voided,indication,startDatetime,stopDatetime,' + 'encounters:(uuid,display,encounterDatetime,' + 'form:(uuid,name),location:ref,' + 'encounterType:ref,' + 'encounterProviders:(uuid,display,' + 'provider:(uuid,display))),' + 'patient:(uuid,display),' + 'visitType:(uuid,name,display),' + 'attributes:(uuid,display,attributeType:(name,datatypeClassname,uuid),value),' + 'location:(uuid,name,display))';\nconst initialState = getVisitSessionStorage() || {\n patientUuid: null,\n manuallySetVisitUuid: null,\n mutateVisitCallbacks: {}\n};\n/**\n * Returns the global visit store that manages the current visit state. The store\n * contains information about the current patient's visit and provides methods\n * for subscribing to visit state changes.\n *\n * @returns The global visit store instance.\n *\n * @example\n * ```ts\n * import { getVisitStore } from '@openmrs/esm-framework';\n * const store = getVisitStore();\n * const unsubscribe = store.subscribe((state) => {\n * console.log('Current patient:', state.patientUuid);\n * });\n * ```\n */ function getVisitStore() {\n return (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_1__.getGlobalStore)('visit', initialState);\n}\n/**\n * Sets the current visit for a patient in the global visit store. This is used\n * to manually specify which visit should be considered \"active\" for the given patient.\n *\n * @param patientUuid The UUID of the patient.\n * @param visitUuid The UUID of the visit to set as the current visit.\n *\n * @example\n * ```ts\n * import { setCurrentVisit } from '@openmrs/esm-framework';\n * setCurrentVisit('patient-uuid', 'visit-uuid');\n * ```\n */ function setCurrentVisit(patientUuid, visitUuid) {\n getVisitStore().setState({\n patientUuid,\n manuallySetVisitUuid: visitUuid\n });\n}\ngetVisitStore().subscribe((state)=>{\n setVisitSessionStorage(state);\n});\nfunction setVisitSessionStorage(value) {\n sessionStorage.setItem('openmrs:visitStoreState', JSON.stringify(value));\n}\nfunction getVisitSessionStorage() {\n try {\n return JSON.parse(sessionStorage.getItem('openmrs:visitStoreState') || 'null');\n } catch (e) {\n return null;\n }\n}\n/**\n * Creates a new visit by sending a POST request to the OpenMRS REST API.\n *\n * @param payload The visit data to create, including patient UUID, visit type,\n * start datetime, and other visit attributes.\n * @param abortController An AbortController to allow cancellation of the request.\n * @returns A Promise that resolves with the FetchResponse containing the created Visit.\n *\n * @example\n * ```ts\n * import { saveVisit } from '@openmrs/esm-framework';\n * const abortController = new AbortController();\n * const response = await saveVisit({\n * patient: 'patient-uuid',\n * visitType: 'visit-type-uuid',\n * startDatetime: new Date().toISOString()\n * }, abortController);\n * ```\n */ function saveVisit(payload, abortController) {\n return (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.openmrsFetch)(`${_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.restBaseUrl}/visit`, {\n signal: abortController.signal,\n method: 'POST',\n headers: {\n 'Content-type': 'application/json'\n },\n body: payload\n });\n}\n/**\n * Updates an existing visit by sending a POST request to the OpenMRS REST API.\n *\n * @param uuid The UUID of the visit to update.\n * @param payload The visit data to update, such as stop datetime or attributes.\n * @param abortController An AbortController to allow cancellation of the request.\n * @returns A Promise that resolves with the FetchResponse containing the updated Visit.\n *\n * @example\n * ```ts\n * import { updateVisit } from '@openmrs/esm-framework';\n * const abortController = new AbortController();\n * const response = await updateVisit('visit-uuid', {\n * stopDatetime: new Date().toISOString()\n * }, abortController);\n * ```\n */ function updateVisit(uuid, payload, abortController) {\n return (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.openmrsFetch)(`${_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.restBaseUrl}/visit/${uuid}`, {\n signal: abortController.signal,\n method: 'POST',\n headers: {\n 'Content-type': 'application/json'\n },\n body: payload\n });\n}\n/**\n * @deprecated Use the `useVisit` hook instead.\n */ function getVisitsForPatient(patientUuid, abortController, v) {\n const custom = v ?? defaultVisitCustomRepresentation;\n return (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.openmrsFetch)(`${_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.restBaseUrl}/visit?patient=${patientUuid}&v=${custom}`, {\n signal: abortController.signal,\n method: 'GET',\n headers: {\n 'Content-type': 'application/json'\n }\n });\n}\n/** @deprecated */ const getStartedVisit = new rxjs__WEBPACK_IMPORTED_MODULE_2__.BehaviorSubject(null);\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-emr-api/dist/visit-utils.js","mappings":";;;;;;;;;;;;;;;AAAA,0BAA0B,GAAgE;AACtC;AACb;AAChC,IAAII,YAAY,WAAW,GAAG,SAASA,SAAS;IACnDA,SAAS,CAAC,WAAW,GAAG;IACxBA,SAAS,CAAC,YAAY,GAAG;IACzBA,SAAS,CAAC,UAAU,GAAG;IACvB,OAAOA;AACX,EAAE,CAAC,GAAG;AACC,IAAIC,cAAc,WAAW,GAAG,SAASA,WAAW;IACvDA,WAAW,CAAC,aAAa,GAAG;IAC5BA,WAAW,CAAC,UAAU,GAAG;IACzB,OAAOA;AACX,EAAE,CAAC,GAAG;AACN;;;;CAIC,GAAU,MAAMC,mCAAmC,uEAAuE,gDAAgD,mCAAmC,uBAAuB,sCAAsC,+BAA+B,4BAA4B,mCAAmC,iFAAiF,gCAAgC;AAC1d,MAAMC,eAAeC,4BAA4B;IAC7CC,aAAa;IACbC,sBAAsB;IACtBC,sBAAsB,CAAC;AAC3B;AACA;;;;;;;;;;;;;;;CAeC,GAAU,SAASC;IAChB,OAAOV,kEAAcA,CAAC,SAASK;AACnC;AACA;;;;;;;;;;;;CAYC,GAAU,SAASM,gBAAgBJ,WAAW,EAAEK,SAAS;IACtDF,gBAAgBG,QAAQ,CAAC;QACrBN;QACAC,sBAAsBI;IAC1B;AACJ;AACAF,gBAAgBI,SAAS,CAAC,CAACC;IACvBC,uBAAuBD;AAC3B;AACA,SAASC,uBAAuBC,KAAK;IACjCC,eAAeC,OAAO,CAAC,2BAA2BC,KAAKC,SAAS,CAACJ;AACrE;AACA,SAASX;IACL,IAAI;QACA,OAAOc,KAAKE,KAAK,CAACJ,eAAeK,OAAO,CAAC,8BAA8B;IAC3E,EAAE,OAAOC,GAAG;QACR,OAAO;IACX;AACJ;AACA;;;;;;;;;;;;;;;;;;CAkBC,GAAU,SAASC,UAAUC,OAAO,EAAEC,eAAe;IAClD,OAAO7B,8DAAYA,CAAC,GAAGC,yDAAWA,CAAC,MAAM,CAAC,EAAE;QACxC6B,QAAQD,gBAAgBC,MAAM;QAC9BC,QAAQ;QACRC,SAAS;YACL,gBAAgB;QACpB;QACAC,MAAML;IACV;AACJ;AACA;;;;;;;;;;;;;;;;CAgBC,GAAU,SAASM,YAAYC,IAAI,EAAEP,OAAO,EAAEC,eAAe;IAC1D,OAAO7B,8DAAYA,CAAC,GAAGC,yDAAWA,CAAC,OAAO,EAAEkC,MAAM,EAAE;QAChDL,QAAQD,gBAAgBC,MAAM;QAC9BC,QAAQ;QACRC,SAAS;YACL,gBAAgB;QACpB;QACAC,MAAML;IACV;AACJ;AACA;;CAEC,GAAU,SAASQ,oBAAoB3B,WAAW,EAAEoB,eAAe,EAAEQ,CAAC;IACnE,MAAMC,SAASD,KAAK/B;IACpB,OAAON,8DAAYA,CAAC,GAAGC,yDAAWA,CAAC,eAAe,EAAEQ,YAAY,GAAG,EAAE6B,QAAQ,EAAE;QAC3ER,QAAQD,gBAAgBC,MAAM;QAC9BC,QAAQ;QACRC,SAAS;YACL,gBAAgB;QACpB;IACJ;AACJ;AACA,gBAAgB,GAAU,MAAMO,kBAAkB,IAAIpC,iDAAeA,CAAC,MAAM","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-emr-api/dist/visit-utils.js?6de8"],"sourcesContent":["/** @module @category API */ import { openmrsFetch, restBaseUrl } from \"@openmrs/esm-api\";\nimport { getGlobalStore } from \"@openmrs/esm-state\";\nimport { BehaviorSubject } from \"rxjs\";\nexport var VisitMode = /*#__PURE__*/ function(VisitMode) {\n    VisitMode[\"NEWVISIT\"] = \"startVisit\";\n    VisitMode[\"EDITVISIT\"] = \"editVisit\";\n    VisitMode[\"LOADING\"] = \"loadingVisit\";\n    return VisitMode;\n}({});\nexport var VisitStatus = /*#__PURE__*/ function(VisitStatus) {\n    VisitStatus[\"NOTSTARTED\"] = \"notStarted\";\n    VisitStatus[\"ONGOING\"] = \"ongoing\";\n    return VisitStatus;\n}({});\n/**\n * The default custom representation string for fetching visit data from the REST API.\n * This representation includes comprehensive visit details such as encounters, patient,\n * visit type, attributes, and location information.\n */ export const defaultVisitCustomRepresentation = 'custom:(uuid,display,voided,indication,startDatetime,stopDatetime,' + 'encounters:(uuid,display,encounterDatetime,' + 'form:(uuid,name),location:ref,' + 'encounterType:ref,' + 'encounterProviders:(uuid,display,' + 'provider:(uuid,display))),' + 'patient:(uuid,display),' + 'visitType:(uuid,name,display),' + 'attributes:(uuid,display,attributeType:(name,datatypeClassname,uuid),value),' + 'location:(uuid,name,display))';\nconst initialState = getVisitSessionStorage() || {\n    patientUuid: null,\n    manuallySetVisitUuid: null,\n    mutateVisitCallbacks: {}\n};\n/**\n * Returns the global visit store that manages the current visit state. The store\n * contains information about the current patient's visit and provides methods\n * for subscribing to visit state changes.\n *\n * @returns The global visit store instance.\n *\n * @example\n * ```ts\n * import { getVisitStore } from '@openmrs/esm-framework';\n * const store = getVisitStore();\n * const unsubscribe = store.subscribe((state) => {\n *   console.log('Current patient:', state.patientUuid);\n * });\n * ```\n */ export function getVisitStore() {\n    return getGlobalStore('visit', initialState);\n}\n/**\n * Sets the current visit for a patient in the global visit store. This is used\n * to manually specify which visit should be considered \"active\" for the given patient.\n *\n * @param patientUuid The UUID of the patient.\n * @param visitUuid The UUID of the visit to set as the current visit.\n *\n * @example\n * ```ts\n * import { setCurrentVisit } from '@openmrs/esm-framework';\n * setCurrentVisit('patient-uuid', 'visit-uuid');\n * ```\n */ export function setCurrentVisit(patientUuid, visitUuid) {\n    getVisitStore().setState({\n        patientUuid,\n        manuallySetVisitUuid: visitUuid\n    });\n}\ngetVisitStore().subscribe((state)=>{\n    setVisitSessionStorage(state);\n});\nfunction setVisitSessionStorage(value) {\n    sessionStorage.setItem('openmrs:visitStoreState', JSON.stringify(value));\n}\nfunction getVisitSessionStorage() {\n    try {\n        return JSON.parse(sessionStorage.getItem('openmrs:visitStoreState') || 'null');\n    } catch (e) {\n        return null;\n    }\n}\n/**\n * Creates a new visit by sending a POST request to the OpenMRS REST API.\n *\n * @param payload The visit data to create, including patient UUID, visit type,\n *   start datetime, and other visit attributes.\n * @param abortController An AbortController to allow cancellation of the request.\n * @returns A Promise that resolves with the FetchResponse containing the created Visit.\n *\n * @example\n * ```ts\n * import { saveVisit } from '@openmrs/esm-framework';\n * const abortController = new AbortController();\n * const response = await saveVisit({\n *   patient: 'patient-uuid',\n *   visitType: 'visit-type-uuid',\n *   startDatetime: new Date().toISOString()\n * }, abortController);\n * ```\n */ export function saveVisit(payload, abortController) {\n    return openmrsFetch(`${restBaseUrl}/visit`, {\n        signal: abortController.signal,\n        method: 'POST',\n        headers: {\n            'Content-type': 'application/json'\n        },\n        body: payload\n    });\n}\n/**\n * Updates an existing visit by sending a POST request to the OpenMRS REST API.\n *\n * @param uuid The UUID of the visit to update.\n * @param payload The visit data to update, such as stop datetime or attributes.\n * @param abortController An AbortController to allow cancellation of the request.\n * @returns A Promise that resolves with the FetchResponse containing the updated Visit.\n *\n * @example\n * ```ts\n * import { updateVisit } from '@openmrs/esm-framework';\n * const abortController = new AbortController();\n * const response = await updateVisit('visit-uuid', {\n *   stopDatetime: new Date().toISOString()\n * }, abortController);\n * ```\n */ export function updateVisit(uuid, payload, abortController) {\n    return openmrsFetch(`${restBaseUrl}/visit/${uuid}`, {\n        signal: abortController.signal,\n        method: 'POST',\n        headers: {\n            'Content-type': 'application/json'\n        },\n        body: payload\n    });\n}\n/**\n * @deprecated Use the `useVisit` hook instead.\n */ export function getVisitsForPatient(patientUuid, abortController, v) {\n    const custom = v ?? defaultVisitCustomRepresentation;\n    return openmrsFetch(`${restBaseUrl}/visit?patient=${patientUuid}&v=${custom}`, {\n        signal: abortController.signal,\n        method: 'GET',\n        headers: {\n            'Content-type': 'application/json'\n        }\n    });\n}\n/** @deprecated */ export const getStartedVisit = new BehaviorSubject(null);\n"],"names":["openmrsFetch","restBaseUrl","getGlobalStore","BehaviorSubject","VisitMode","VisitStatus","defaultVisitCustomRepresentation","initialState","getVisitSessionStorage","patientUuid","manuallySetVisitUuid","mutateVisitCallbacks","getVisitStore","setCurrentVisit","visitUuid","setState","subscribe","state","setVisitSessionStorage","value","sessionStorage","setItem","JSON","stringify","parse","getItem","e","saveVisit","payload","abortController","signal","method","headers","body","updateVisit","uuid","getVisitsForPatient","v","custom","getStartedVisit"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-emr-api/dist/visit-utils.js\n");
409
409
 
410
410
  /***/ }),
411
411
 
@@ -415,7 +415,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
415
415
  \********************************************************/
416
416
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
417
417
 
418
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ createErrorHandler: () => (/* binding */ createErrorHandler),\n/* harmony export */ reportError: () => (/* binding */ reportError)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-globals */ \"../../framework/esm-globals/dist/index.js\");\n/** @module @category Error Handling */ \nwindow.onerror = function(error) {\n console.error('Unexpected error: ', error);\n (0,_openmrs_esm_globals__WEBPACK_IMPORTED_MODULE_0__.dispatchToastShown)({\n description: error ?? 'Oops! An unexpected error occurred.',\n kind: 'error',\n title: 'Error'\n });\n return false;\n};\nwindow.onunhandledrejection = function(event) {\n console.error('Unhandled rejection: ', event.reason);\n (0,_openmrs_esm_globals__WEBPACK_IMPORTED_MODULE_0__.dispatchToastShown)({\n description: event.reason ?? 'Oops! An unhandled promise rejection occurred.',\n kind: 'error',\n title: 'Error'\n });\n};\nfunction reportError(err) {\n const error = ensureErrorObject(err);\n setTimeout(()=>{\n throw error;\n });\n}\nfunction createErrorHandler() {\n const outgoingErr = Error();\n return (incomingErr)=>{\n const finalErr = ensureErrorObject(incomingErr);\n finalErr.stack += `\\nAsync stacktrace:\\n${outgoingErr.stack}`;\n reportError(incomingErr);\n };\n}\nfunction ensureErrorObject(thing) {\n let message;\n if (thing instanceof Error) {\n return thing;\n } else if (thing === null) {\n return Error(`'null' was thrown as an error`);\n } else if (typeof thing === 'object') {\n try {\n message = `Object thrown as error: ${JSON.stringify(thing)}`;\n } catch (e) {\n message = `Object thrown as error with the following properties: ${Object.keys(thing)}`;\n }\n return Error(message);\n } else if (thing === undefined) {\n return Error(`'undefined' was thrown as an error`);\n } else {\n return Error(thing.toString());\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1lcnJvci1oYW5kbGluZy9kaXN0L2luZGV4LmpzIiwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLHFDQUFxQyxHQUE2RDtBQUNsR0MsT0FBT0MsT0FBTyxHQUFHLFNBQVNDLEtBQUs7SUFDM0JDLFFBQVFELEtBQUssQ0FBQyxzQkFBc0JBO0lBQ3BDSCx3RUFBa0JBLENBQUM7UUFDZkssYUFBYUYsU0FBUztRQUN0QkcsTUFBTTtRQUNOQyxPQUFPO0lBQ1g7SUFDQSxPQUFPO0FBQ1g7QUFDQU4sT0FBT08sb0JBQW9CLEdBQUcsU0FBU0MsS0FBSztJQUN4Q0wsUUFBUUQsS0FBSyxDQUFDLHlCQUF5Qk0sTUFBTUMsTUFBTTtJQUNuRFYsd0VBQWtCQSxDQUFDO1FBQ2ZLLGFBQWFJLE1BQU1DLE1BQU0sSUFBSTtRQUM3QkosTUFBTTtRQUNOQyxPQUFPO0lBQ1g7QUFDSjtBQUNPLFNBQVNJLFlBQVlDLEdBQUc7SUFDM0IsTUFBTVQsUUFBUVUsa0JBQWtCRDtJQUNoQ0UsV0FBVztRQUNQLE1BQU1YO0lBQ1Y7QUFDSjtBQUNPLFNBQVNZO0lBQ1osTUFBTUMsY0FBY0M7SUFDcEIsT0FBTyxDQUFDQztRQUNKLE1BQU1DLFdBQVdOLGtCQUFrQks7UUFDbkNDLFNBQVNDLEtBQUssSUFBSSxDQUFDLHFCQUFxQixFQUFFSixZQUFZSSxLQUFLLEVBQUU7UUFDN0RULFlBQVlPO0lBQ2hCO0FBQ0o7QUFDQSxTQUFTTCxrQkFBa0JRLEtBQUs7SUFDNUIsSUFBSUM7SUFDSixJQUFJRCxpQkFBaUJKLE9BQU87UUFDeEIsT0FBT0k7SUFDWCxPQUFPLElBQUlBLFVBQVUsTUFBTTtRQUN2QixPQUFPSixNQUFNLENBQUMsNkJBQTZCLENBQUM7SUFDaEQsT0FBTyxJQUFJLE9BQU9JLFVBQVUsVUFBVTtRQUNsQyxJQUFJO1lBQ0FDLFVBQVUsQ0FBQyx3QkFBd0IsRUFBRUMsS0FBS0MsU0FBUyxDQUFDSCxRQUFRO1FBQ2hFLEVBQUUsT0FBT0ksR0FBRztZQUNSSCxVQUFVLENBQUMsc0RBQXNELEVBQUVJLE9BQU9DLElBQUksQ0FBQ04sUUFBUTtRQUMzRjtRQUNBLE9BQU9KLE1BQU1LO0lBQ2pCLE9BQU8sSUFBSUQsVUFBVU8sV0FBVztRQUM1QixPQUFPWCxNQUFNLENBQUMsa0NBQWtDLENBQUM7SUFDckQsT0FBTztRQUNILE9BQU9BLE1BQU1JLE1BQU1RLFFBQVE7SUFDL0I7QUFDSiIsInNvdXJjZXMiOlsid2VicGFjazovL0BvcGVubXJzL2VzbS1hcHAtc2hlbGwvLi4vLi4vZnJhbWV3b3JrL2VzbS1lcnJvci1oYW5kbGluZy9kaXN0L2luZGV4LmpzPzhlMmIiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBtb2R1bGUgQGNhdGVnb3J5IEVycm9yIEhhbmRsaW5nICovIGltcG9ydCB7IGRpc3BhdGNoVG9hc3RTaG93biB9IGZyb20gXCJAb3Blbm1ycy9lc20tZ2xvYmFsc1wiO1xud2luZG93Lm9uZXJyb3IgPSBmdW5jdGlvbihlcnJvcikge1xuICAgIGNvbnNvbGUuZXJyb3IoJ1VuZXhwZWN0ZWQgZXJyb3I6ICcsIGVycm9yKTtcbiAgICBkaXNwYXRjaFRvYXN0U2hvd24oe1xuICAgICAgICBkZXNjcmlwdGlvbjogZXJyb3IgPz8gJ09vcHMhIEFuIHVuZXhwZWN0ZWQgZXJyb3Igb2NjdXJyZWQuJyxcbiAgICAgICAga2luZDogJ2Vycm9yJyxcbiAgICAgICAgdGl0bGU6ICdFcnJvcidcbiAgICB9KTtcbiAgICByZXR1cm4gZmFsc2U7XG59O1xud2luZG93Lm9udW5oYW5kbGVkcmVqZWN0aW9uID0gZnVuY3Rpb24oZXZlbnQpIHtcbiAgICBjb25zb2xlLmVycm9yKCdVbmhhbmRsZWQgcmVqZWN0aW9uOiAnLCBldmVudC5yZWFzb24pO1xuICAgIGRpc3BhdGNoVG9hc3RTaG93bih7XG4gICAgICAgIGRlc2NyaXB0aW9uOiBldmVudC5yZWFzb24gPz8gJ09vcHMhIEFuIHVuaGFuZGxlZCBwcm9taXNlIHJlamVjdGlvbiBvY2N1cnJlZC4nLFxuICAgICAgICBraW5kOiAnZXJyb3InLFxuICAgICAgICB0aXRsZTogJ0Vycm9yJ1xuICAgIH0pO1xufTtcbmV4cG9ydCBmdW5jdGlvbiByZXBvcnRFcnJvcihlcnIpIHtcbiAgICBjb25zdCBlcnJvciA9IGVuc3VyZUVycm9yT2JqZWN0KGVycik7XG4gICAgc2V0VGltZW91dCgoKT0+e1xuICAgICAgICB0aHJvdyBlcnJvcjtcbiAgICB9KTtcbn1cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVFcnJvckhhbmRsZXIoKSB7XG4gICAgY29uc3Qgb3V0Z29pbmdFcnIgPSBFcnJvcigpO1xuICAgIHJldHVybiAoaW5jb21pbmdFcnIpPT57XG4gICAgICAgIGNvbnN0IGZpbmFsRXJyID0gZW5zdXJlRXJyb3JPYmplY3QoaW5jb21pbmdFcnIpO1xuICAgICAgICBmaW5hbEVyci5zdGFjayArPSBgXFxuQXN5bmMgc3RhY2t0cmFjZTpcXG4ke291dGdvaW5nRXJyLnN0YWNrfWA7XG4gICAgICAgIHJlcG9ydEVycm9yKGluY29taW5nRXJyKTtcbiAgICB9O1xufVxuZnVuY3Rpb24gZW5zdXJlRXJyb3JPYmplY3QodGhpbmcpIHtcbiAgICBsZXQgbWVzc2FnZTtcbiAgICBpZiAodGhpbmcgaW5zdGFuY2VvZiBFcnJvcikge1xuICAgICAgICByZXR1cm4gdGhpbmc7XG4gICAgfSBlbHNlIGlmICh0aGluZyA9PT0gbnVsbCkge1xuICAgICAgICByZXR1cm4gRXJyb3IoYCdudWxsJyB3YXMgdGhyb3duIGFzIGFuIGVycm9yYCk7XG4gICAgfSBlbHNlIGlmICh0eXBlb2YgdGhpbmcgPT09ICdvYmplY3QnKSB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgICBtZXNzYWdlID0gYE9iamVjdCB0aHJvd24gYXMgZXJyb3I6ICR7SlNPTi5zdHJpbmdpZnkodGhpbmcpfWA7XG4gICAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgICAgIG1lc3NhZ2UgPSBgT2JqZWN0IHRocm93biBhcyBlcnJvciB3aXRoIHRoZSBmb2xsb3dpbmcgcHJvcGVydGllczogJHtPYmplY3Qua2V5cyh0aGluZyl9YDtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gRXJyb3IobWVzc2FnZSk7XG4gICAgfSBlbHNlIGlmICh0aGluZyA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAgIHJldHVybiBFcnJvcihgJ3VuZGVmaW5lZCcgd2FzIHRocm93biBhcyBhbiBlcnJvcmApO1xuICAgIH0gZWxzZSB7XG4gICAgICAgIHJldHVybiBFcnJvcih0aGluZy50b1N0cmluZygpKTtcbiAgICB9XG59XG4iXSwibmFtZXMiOlsiZGlzcGF0Y2hUb2FzdFNob3duIiwid2luZG93Iiwib25lcnJvciIsImVycm9yIiwiY29uc29sZSIsImRlc2NyaXB0aW9uIiwia2luZCIsInRpdGxlIiwib251bmhhbmRsZWRyZWplY3Rpb24iLCJldmVudCIsInJlYXNvbiIsInJlcG9ydEVycm9yIiwiZXJyIiwiZW5zdXJlRXJyb3JPYmplY3QiLCJzZXRUaW1lb3V0IiwiY3JlYXRlRXJyb3JIYW5kbGVyIiwib3V0Z29pbmdFcnIiLCJFcnJvciIsImluY29taW5nRXJyIiwiZmluYWxFcnIiLCJzdGFjayIsInRoaW5nIiwibWVzc2FnZSIsIkpTT04iLCJzdHJpbmdpZnkiLCJlIiwiT2JqZWN0Iiwia2V5cyIsInVuZGVmaW5lZCIsInRvU3RyaW5nIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///../../framework/esm-error-handling/dist/index.js\n");
418
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ createErrorHandler: () => (/* binding */ createErrorHandler),\n/* harmony export */ reportError: () => (/* binding */ reportError)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-globals */ \"../../framework/esm-globals/dist/index.js\");\n/** @module @category Error Handling */ \nwindow.onerror = function(error) {\n console.error('Unexpected error: ', error);\n (0,_openmrs_esm_globals__WEBPACK_IMPORTED_MODULE_0__.dispatchToastShown)({\n description: error ?? 'Oops! An unexpected error occurred.',\n kind: 'error',\n title: 'Error'\n });\n return false;\n};\nwindow.onunhandledrejection = function(event) {\n console.error('Unhandled rejection: ', event.reason);\n (0,_openmrs_esm_globals__WEBPACK_IMPORTED_MODULE_0__.dispatchToastShown)({\n description: event.reason ?? 'Oops! An unhandled promise rejection occurred.',\n kind: 'error',\n title: 'Error'\n });\n};\n/**\n * Reports an error to the global error handler. The error will be displayed\n * to the user as a toast notification. This function ensures the error is\n * converted to an Error object if it isn't already one.\n *\n * The error is thrown asynchronously (via setTimeout) to ensure it's caught\n * by the global window.onerror handler.\n *\n * @param err The error to report. Can be an Error object, string, or any other value.\n *\n * @example\n * ```ts\n * import { reportError } from '@openmrs/esm-framework';\n * try {\n * await riskyOperation();\n * } catch (error) {\n * reportError(error);\n * }\n * ```\n */ function reportError(err) {\n const error = ensureErrorObject(err);\n setTimeout(()=>{\n throw error;\n });\n}\n/**\n * Creates an error handler function that captures the current stack trace at\n * the time of creation. When the returned handler is invoked with an error,\n * it appends the captured stack trace to provide better debugging information\n * for asynchronous operations.\n *\n * This is particularly useful for handling errors in Promise chains or\n * callback-based APIs where the original call site would otherwise be lost.\n *\n * @returns A function that accepts an error and reports it with an enhanced stack trace.\n *\n * @example\n * ```ts\n * import { createErrorHandler } from '@openmrs/esm-framework';\n * const handleError = createErrorHandler();\n * someAsyncOperation()\n * .then(processResult)\n * .catch(handleError);\n * ```\n */ function createErrorHandler() {\n const outgoingErr = Error();\n return (incomingErr)=>{\n const finalErr = ensureErrorObject(incomingErr);\n finalErr.stack += `\\nAsync stacktrace:\\n${outgoingErr.stack}`;\n reportError(incomingErr);\n };\n}\nfunction ensureErrorObject(thing) {\n let message;\n if (thing instanceof Error) {\n return thing;\n } else if (thing === null) {\n return Error(`'null' was thrown as an error`);\n } else if (typeof thing === 'object') {\n try {\n message = `Object thrown as error: ${JSON.stringify(thing)}`;\n } catch (e) {\n message = `Object thrown as error with the following properties: ${Object.keys(thing)}`;\n }\n return Error(message);\n } else if (thing === undefined) {\n return Error(`'undefined' was thrown as an error`);\n } else {\n return Error(thing.toString());\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1lcnJvci1oYW5kbGluZy9kaXN0L2luZGV4LmpzIiwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLHFDQUFxQyxHQUE2RDtBQUNsR0MsT0FBT0MsT0FBTyxHQUFHLFNBQVNDLEtBQUs7SUFDM0JDLFFBQVFELEtBQUssQ0FBQyxzQkFBc0JBO0lBQ3BDSCx3RUFBa0JBLENBQUM7UUFDZkssYUFBYUYsU0FBUztRQUN0QkcsTUFBTTtRQUNOQyxPQUFPO0lBQ1g7SUFDQSxPQUFPO0FBQ1g7QUFDQU4sT0FBT08sb0JBQW9CLEdBQUcsU0FBU0MsS0FBSztJQUN4Q0wsUUFBUUQsS0FBSyxDQUFDLHlCQUF5Qk0sTUFBTUMsTUFBTTtJQUNuRFYsd0VBQWtCQSxDQUFDO1FBQ2ZLLGFBQWFJLE1BQU1DLE1BQU0sSUFBSTtRQUM3QkosTUFBTTtRQUNOQyxPQUFPO0lBQ1g7QUFDSjtBQUNBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7O0NBbUJDLEdBQVUsU0FBU0ksWUFBWUMsR0FBRztJQUMvQixNQUFNVCxRQUFRVSxrQkFBa0JEO0lBQ2hDRSxXQUFXO1FBQ1AsTUFBTVg7SUFDVjtBQUNKO0FBQ0E7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Q0FtQkMsR0FBVSxTQUFTWTtJQUNoQixNQUFNQyxjQUFjQztJQUNwQixPQUFPLENBQUNDO1FBQ0osTUFBTUMsV0FBV04sa0JBQWtCSztRQUNuQ0MsU0FBU0MsS0FBSyxJQUFJLENBQUMscUJBQXFCLEVBQUVKLFlBQVlJLEtBQUssRUFBRTtRQUM3RFQsWUFBWU87SUFDaEI7QUFDSjtBQUNBLFNBQVNMLGtCQUFrQlEsS0FBSztJQUM1QixJQUFJQztJQUNKLElBQUlELGlCQUFpQkosT0FBTztRQUN4QixPQUFPSTtJQUNYLE9BQU8sSUFBSUEsVUFBVSxNQUFNO1FBQ3ZCLE9BQU9KLE1BQU0sQ0FBQyw2QkFBNkIsQ0FBQztJQUNoRCxPQUFPLElBQUksT0FBT0ksVUFBVSxVQUFVO1FBQ2xDLElBQUk7WUFDQUMsVUFBVSxDQUFDLHdCQUF3QixFQUFFQyxLQUFLQyxTQUFTLENBQUNILFFBQVE7UUFDaEUsRUFBRSxPQUFPSSxHQUFHO1lBQ1JILFVBQVUsQ0FBQyxzREFBc0QsRUFBRUksT0FBT0MsSUFBSSxDQUFDTixRQUFRO1FBQzNGO1FBQ0EsT0FBT0osTUFBTUs7SUFDakIsT0FBTyxJQUFJRCxVQUFVTyxXQUFXO1FBQzVCLE9BQU9YLE1BQU0sQ0FBQyxrQ0FBa0MsQ0FBQztJQUNyRCxPQUFPO1FBQ0gsT0FBT0EsTUFBTUksTUFBTVEsUUFBUTtJQUMvQjtBQUNKIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQG9wZW5tcnMvZXNtLWFwcC1zaGVsbC8uLi8uLi9mcmFtZXdvcmsvZXNtLWVycm9yLWhhbmRsaW5nL2Rpc3QvaW5kZXguanM/OGUyYiJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQG1vZHVsZSBAY2F0ZWdvcnkgRXJyb3IgSGFuZGxpbmcgKi8gaW1wb3J0IHsgZGlzcGF0Y2hUb2FzdFNob3duIH0gZnJvbSBcIkBvcGVubXJzL2VzbS1nbG9iYWxzXCI7XG53aW5kb3cub25lcnJvciA9IGZ1bmN0aW9uKGVycm9yKSB7XG4gICAgY29uc29sZS5lcnJvcignVW5leHBlY3RlZCBlcnJvcjogJywgZXJyb3IpO1xuICAgIGRpc3BhdGNoVG9hc3RTaG93bih7XG4gICAgICAgIGRlc2NyaXB0aW9uOiBlcnJvciA/PyAnT29wcyEgQW4gdW5leHBlY3RlZCBlcnJvciBvY2N1cnJlZC4nLFxuICAgICAgICBraW5kOiAnZXJyb3InLFxuICAgICAgICB0aXRsZTogJ0Vycm9yJ1xuICAgIH0pO1xuICAgIHJldHVybiBmYWxzZTtcbn07XG53aW5kb3cub251bmhhbmRsZWRyZWplY3Rpb24gPSBmdW5jdGlvbihldmVudCkge1xuICAgIGNvbnNvbGUuZXJyb3IoJ1VuaGFuZGxlZCByZWplY3Rpb246ICcsIGV2ZW50LnJlYXNvbik7XG4gICAgZGlzcGF0Y2hUb2FzdFNob3duKHtcbiAgICAgICAgZGVzY3JpcHRpb246IGV2ZW50LnJlYXNvbiA/PyAnT29wcyEgQW4gdW5oYW5kbGVkIHByb21pc2UgcmVqZWN0aW9uIG9jY3VycmVkLicsXG4gICAgICAgIGtpbmQ6ICdlcnJvcicsXG4gICAgICAgIHRpdGxlOiAnRXJyb3InXG4gICAgfSk7XG59O1xuLyoqXG4gKiBSZXBvcnRzIGFuIGVycm9yIHRvIHRoZSBnbG9iYWwgZXJyb3IgaGFuZGxlci4gVGhlIGVycm9yIHdpbGwgYmUgZGlzcGxheWVkXG4gKiB0byB0aGUgdXNlciBhcyBhIHRvYXN0IG5vdGlmaWNhdGlvbi4gVGhpcyBmdW5jdGlvbiBlbnN1cmVzIHRoZSBlcnJvciBpc1xuICogY29udmVydGVkIHRvIGFuIEVycm9yIG9iamVjdCBpZiBpdCBpc24ndCBhbHJlYWR5IG9uZS5cbiAqXG4gKiBUaGUgZXJyb3IgaXMgdGhyb3duIGFzeW5jaHJvbm91c2x5ICh2aWEgc2V0VGltZW91dCkgdG8gZW5zdXJlIGl0J3MgY2F1Z2h0XG4gKiBieSB0aGUgZ2xvYmFsIHdpbmRvdy5vbmVycm9yIGhhbmRsZXIuXG4gKlxuICogQHBhcmFtIGVyciBUaGUgZXJyb3IgdG8gcmVwb3J0LiBDYW4gYmUgYW4gRXJyb3Igb2JqZWN0LCBzdHJpbmcsIG9yIGFueSBvdGhlciB2YWx1ZS5cbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHNcbiAqIGltcG9ydCB7IHJlcG9ydEVycm9yIH0gZnJvbSAnQG9wZW5tcnMvZXNtLWZyYW1ld29yayc7XG4gKiB0cnkge1xuICogICBhd2FpdCByaXNreU9wZXJhdGlvbigpO1xuICogfSBjYXRjaCAoZXJyb3IpIHtcbiAqICAgcmVwb3J0RXJyb3IoZXJyb3IpO1xuICogfVxuICogYGBgXG4gKi8gZXhwb3J0IGZ1bmN0aW9uIHJlcG9ydEVycm9yKGVycikge1xuICAgIGNvbnN0IGVycm9yID0gZW5zdXJlRXJyb3JPYmplY3QoZXJyKTtcbiAgICBzZXRUaW1lb3V0KCgpPT57XG4gICAgICAgIHRocm93IGVycm9yO1xuICAgIH0pO1xufVxuLyoqXG4gKiBDcmVhdGVzIGFuIGVycm9yIGhhbmRsZXIgZnVuY3Rpb24gdGhhdCBjYXB0dXJlcyB0aGUgY3VycmVudCBzdGFjayB0cmFjZSBhdFxuICogdGhlIHRpbWUgb2YgY3JlYXRpb24uIFdoZW4gdGhlIHJldHVybmVkIGhhbmRsZXIgaXMgaW52b2tlZCB3aXRoIGFuIGVycm9yLFxuICogaXQgYXBwZW5kcyB0aGUgY2FwdHVyZWQgc3RhY2sgdHJhY2UgdG8gcHJvdmlkZSBiZXR0ZXIgZGVidWdnaW5nIGluZm9ybWF0aW9uXG4gKiBmb3IgYXN5bmNocm9ub3VzIG9wZXJhdGlvbnMuXG4gKlxuICogVGhpcyBpcyBwYXJ0aWN1bGFybHkgdXNlZnVsIGZvciBoYW5kbGluZyBlcnJvcnMgaW4gUHJvbWlzZSBjaGFpbnMgb3JcbiAqIGNhbGxiYWNrLWJhc2VkIEFQSXMgd2hlcmUgdGhlIG9yaWdpbmFsIGNhbGwgc2l0ZSB3b3VsZCBvdGhlcndpc2UgYmUgbG9zdC5cbiAqXG4gKiBAcmV0dXJucyBBIGZ1bmN0aW9uIHRoYXQgYWNjZXB0cyBhbiBlcnJvciBhbmQgcmVwb3J0cyBpdCB3aXRoIGFuIGVuaGFuY2VkIHN0YWNrIHRyYWNlLlxuICpcbiAqIEBleGFtcGxlXG4gKiBgYGB0c1xuICogaW1wb3J0IHsgY3JlYXRlRXJyb3JIYW5kbGVyIH0gZnJvbSAnQG9wZW5tcnMvZXNtLWZyYW1ld29yayc7XG4gKiBjb25zdCBoYW5kbGVFcnJvciA9IGNyZWF0ZUVycm9ySGFuZGxlcigpO1xuICogc29tZUFzeW5jT3BlcmF0aW9uKClcbiAqICAgLnRoZW4ocHJvY2Vzc1Jlc3VsdClcbiAqICAgLmNhdGNoKGhhbmRsZUVycm9yKTtcbiAqIGBgYFxuICovIGV4cG9ydCBmdW5jdGlvbiBjcmVhdGVFcnJvckhhbmRsZXIoKSB7XG4gICAgY29uc3Qgb3V0Z29pbmdFcnIgPSBFcnJvcigpO1xuICAgIHJldHVybiAoaW5jb21pbmdFcnIpPT57XG4gICAgICAgIGNvbnN0IGZpbmFsRXJyID0gZW5zdXJlRXJyb3JPYmplY3QoaW5jb21pbmdFcnIpO1xuICAgICAgICBmaW5hbEVyci5zdGFjayArPSBgXFxuQXN5bmMgc3RhY2t0cmFjZTpcXG4ke291dGdvaW5nRXJyLnN0YWNrfWA7XG4gICAgICAgIHJlcG9ydEVycm9yKGluY29taW5nRXJyKTtcbiAgICB9O1xufVxuZnVuY3Rpb24gZW5zdXJlRXJyb3JPYmplY3QodGhpbmcpIHtcbiAgICBsZXQgbWVzc2FnZTtcbiAgICBpZiAodGhpbmcgaW5zdGFuY2VvZiBFcnJvcikge1xuICAgICAgICByZXR1cm4gdGhpbmc7XG4gICAgfSBlbHNlIGlmICh0aGluZyA9PT0gbnVsbCkge1xuICAgICAgICByZXR1cm4gRXJyb3IoYCdudWxsJyB3YXMgdGhyb3duIGFzIGFuIGVycm9yYCk7XG4gICAgfSBlbHNlIGlmICh0eXBlb2YgdGhpbmcgPT09ICdvYmplY3QnKSB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgICBtZXNzYWdlID0gYE9iamVjdCB0aHJvd24gYXMgZXJyb3I6ICR7SlNPTi5zdHJpbmdpZnkodGhpbmcpfWA7XG4gICAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgICAgIG1lc3NhZ2UgPSBgT2JqZWN0IHRocm93biBhcyBlcnJvciB3aXRoIHRoZSBmb2xsb3dpbmcgcHJvcGVydGllczogJHtPYmplY3Qua2V5cyh0aGluZyl9YDtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gRXJyb3IobWVzc2FnZSk7XG4gICAgfSBlbHNlIGlmICh0aGluZyA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAgIHJldHVybiBFcnJvcihgJ3VuZGVmaW5lZCcgd2FzIHRocm93biBhcyBhbiBlcnJvcmApO1xuICAgIH0gZWxzZSB7XG4gICAgICAgIHJldHVybiBFcnJvcih0aGluZy50b1N0cmluZygpKTtcbiAgICB9XG59XG4iXSwibmFtZXMiOlsiZGlzcGF0Y2hUb2FzdFNob3duIiwid2luZG93Iiwib25lcnJvciIsImVycm9yIiwiY29uc29sZSIsImRlc2NyaXB0aW9uIiwia2luZCIsInRpdGxlIiwib251bmhhbmRsZWRyZWplY3Rpb24iLCJldmVudCIsInJlYXNvbiIsInJlcG9ydEVycm9yIiwiZXJyIiwiZW5zdXJlRXJyb3JPYmplY3QiLCJzZXRUaW1lb3V0IiwiY3JlYXRlRXJyb3JIYW5kbGVyIiwib3V0Z29pbmdFcnIiLCJFcnJvciIsImluY29taW5nRXJyIiwiZmluYWxFcnIiLCJzdGFjayIsInRoaW5nIiwibWVzc2FnZSIsIkpTT04iLCJzdHJpbmdpZnkiLCJlIiwiT2JqZWN0Iiwia2V5cyIsInVuZGVmaW5lZCIsInRvU3RyaW5nIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///../../framework/esm-error-handling/dist/index.js\n");
419
419
 
420
420
  /***/ }),
421
421
 
@@ -445,7 +445,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
445
445
  \*********************************************************/
446
446
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
447
447
 
448
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ attach: () => (/* binding */ attach),\n/* harmony export */ detach: () => (/* binding */ detach),\n/* harmony export */ detachAll: () => (/* binding */ detachAll),\n/* harmony export */ getAssignedExtensions: () => (/* binding */ getAssignedExtensions),\n/* harmony export */ getExtensionNameFromId: () => (/* binding */ getExtensionNameFromId),\n/* harmony export */ getExtensionRegistration: () => (/* binding */ getExtensionRegistration),\n/* harmony export */ getExtensionRegistrationFrom: () => (/* binding */ getExtensionRegistrationFrom),\n/* harmony export */ registerExtension: () => (/* binding */ registerExtension),\n/* harmony export */ registerExtensionSlot: () => (/* binding */ registerExtensionSlot),\n/* harmony export */ reset: () => (/* binding */ reset),\n/* harmony export */ updateExtensionSlotState: () => (/* binding */ updateExtensionSlotState)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-api */ \"../../framework/esm-api/dist/index.js\");\n/* harmony import */ var _openmrs_esm_config__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-config */ \"../../framework/esm-config/dist/index.js\");\n/* harmony import */ var _openmrs_esm_expression_evaluator__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! @openmrs/esm-expression-evaluator */ \"../../framework/esm-expression-evaluator/dist/evaluator.js\");\n/* harmony import */ var _openmrs_esm_feature_flags__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @openmrs/esm-feature-flags */ \"../../framework/esm-feature-flags/dist/index.js\");\n/* harmony import */ var _openmrs_esm_globals__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @openmrs/esm-globals */ \"../../framework/esm-globals/dist/index.js\");\n/* harmony import */ var _openmrs_esm_utils__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! @openmrs/esm-utils */ \"../../framework/esm-utils/dist/is-online.js\");\n/* harmony import */ var lodash_es__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! lodash-es */ \"../../../node_modules/lodash-es/isEqual.js\");\n/* harmony import */ var lodash_es__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! lodash-es */ \"../../../node_modules/lodash-es/merge.js\");\n/* harmony import */ var _helpers_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./helpers.js */ \"../../framework/esm-extensions/dist/helpers.js\");\n/* harmony import */ var _store_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./store.js */ \"../../framework/esm-extensions/dist/store.js\");\n/** @module @category Extension */ /*\n * We have the following extension modes:\n *\n * - attached (set via code in form of: attach, detach, ...)\n * - configured (set via configuration in form of: added, removed, ...)\n * - assigned (computed from attached and configured)\n * - connected (computed from assigned using connectivity and online / offline)\n */ \n\n\n\n\n\n\n\n\nconst extensionInternalStore = (0,_store_js__WEBPACK_IMPORTED_MODULE_5__.getExtensionInternalStore)();\nconst extensionStore = (0,_store_js__WEBPACK_IMPORTED_MODULE_5__.getExtensionStore)();\nconst slotsConfigStore = (0,_openmrs_esm_config__WEBPACK_IMPORTED_MODULE_1__.getExtensionSlotsConfigStore)();\nconst extensionsConfigStore = (0,_openmrs_esm_config__WEBPACK_IMPORTED_MODULE_1__.getExtensionsConfigStore)();\n// Keep the output store updated\nfunction updateExtensionOutputStore(internalState, extensionSlotConfigs, extensionsConfigStore, featureFlagStore, sessionStore) {\n const slots = {};\n const isOnline = (0,_openmrs_esm_utils__WEBPACK_IMPORTED_MODULE_6__.isOnline)();\n const enabledFeatureFlags = Object.entries(featureFlagStore.flags).filter(([, { enabled }])=>enabled).map(([name])=>name);\n for (let [slotName, slot] of Object.entries(internalState.slots)){\n const { config } = (0,_openmrs_esm_config__WEBPACK_IMPORTED_MODULE_1__.getExtensionSlotConfigFromStore)(extensionSlotConfigs, slot.name);\n const assignedExtensions = getAssignedExtensionsFromSlotData(slotName, internalState, config, extensionsConfigStore, enabledFeatureFlags, isOnline, sessionStore.session);\n slots[slotName] = {\n moduleName: slot.moduleName,\n assignedExtensions\n };\n }\n if (!(0,lodash_es__WEBPACK_IMPORTED_MODULE_7__[\"default\"])(extensionStore.getState().slots, slots)) {\n extensionStore.setState({\n slots\n });\n }\n}\nextensionInternalStore.subscribe((internalStore)=>{\n updateExtensionOutputStore(internalStore, slotsConfigStore.getState(), extensionsConfigStore.getState(), _openmrs_esm_feature_flags__WEBPACK_IMPORTED_MODULE_2__.featureFlagsStore.getState(), _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.sessionStore.getState());\n});\nslotsConfigStore.subscribe((slotConfigs)=>{\n updateExtensionOutputStore(extensionInternalStore.getState(), slotConfigs, extensionsConfigStore.getState(), _openmrs_esm_feature_flags__WEBPACK_IMPORTED_MODULE_2__.featureFlagsStore.getState(), _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.sessionStore.getState());\n});\nextensionsConfigStore.subscribe((extensionConfigs)=>{\n updateExtensionOutputStore(extensionInternalStore.getState(), slotsConfigStore.getState(), extensionConfigs, _openmrs_esm_feature_flags__WEBPACK_IMPORTED_MODULE_2__.featureFlagsStore.getState(), _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.sessionStore.getState());\n});\n_openmrs_esm_feature_flags__WEBPACK_IMPORTED_MODULE_2__.featureFlagsStore.subscribe((featureFlagStore)=>{\n updateExtensionOutputStore(extensionInternalStore.getState(), slotsConfigStore.getState(), extensionsConfigStore.getState(), featureFlagStore, _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.sessionStore.getState());\n});\n_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.sessionStore.subscribe((session)=>{\n updateExtensionOutputStore(extensionInternalStore.getState(), slotsConfigStore.getState(), extensionsConfigStore.getState(), _openmrs_esm_feature_flags__WEBPACK_IMPORTED_MODULE_2__.featureFlagsStore.getState(), session);\n});\nfunction updateOutputStoreToCurrent() {\n updateExtensionOutputStore(extensionInternalStore.getState(), slotsConfigStore.getState(), extensionsConfigStore.getState(), _openmrs_esm_feature_flags__WEBPACK_IMPORTED_MODULE_2__.featureFlagsStore.getState(), _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.sessionStore.getState());\n}\nupdateOutputStoreToCurrent();\n(0,_openmrs_esm_globals__WEBPACK_IMPORTED_MODULE_3__.subscribeConnectivityChanged)(updateOutputStoreToCurrent);\nfunction createNewExtensionSlotInfo(slotName, moduleName, state) {\n return {\n moduleName,\n name: slotName,\n attachedIds: [],\n config: null,\n state\n };\n}\n/**\n * Given an extension ID, which is a string uniquely identifying\n * an instance of an extension within an extension slot, this\n * returns the extension name.\n *\n * @example\n * ```js\n * getExtensionNameFromId(\"foo#bar\")\n * --> \"foo\"\n * getExtensionNameFromId(\"baz\")\n * --> \"baz\"\n * ```\n */ function getExtensionNameFromId(extensionId) {\n const [extensionName] = extensionId.split('#');\n return extensionName;\n}\nfunction getExtensionRegistrationFrom(state, extensionId) {\n const name = getExtensionNameFromId(extensionId);\n return state.extensions[name];\n}\nfunction getExtensionRegistration(extensionId) {\n const state = extensionInternalStore.getState();\n return getExtensionRegistrationFrom(state, extensionId);\n}\n/**\n * Extensions must be registered in order to be rendered.\n * This is handled by the app shell, when extensions are provided\n * via the `routes.json` file and registered through `registerApp()`.\n * @internal\n */ const registerExtension = (extensionRegistration)=>extensionInternalStore.setState((state)=>{\n state.extensions[extensionRegistration.name] = {\n ...extensionRegistration,\n instances: []\n };\n return state;\n });\n/**\n * Attach an extension to an extension slot.\n *\n * This will cause the extension to be rendered into the specified\n * extension slot, unless it is removed by configuration. Using\n * `attach` is an alternative to specifying the `slot` or `slots`\n * in the extension declaration.\n *\n * It is particularly useful when creating a slot into which\n * you want to render an existing extension. This enables you\n * to do so without modifying the extension's declaration, which\n * may be impractical or inappropriate, for example if you are\n * writing a module for a specific implementation.\n *\n * @param slotName a name uniquely identifying the slot\n * @param extensionId an extension name, with an optional #-suffix\n * to distinguish it from other instances of the same extension\n * attached to the same slot.\n */ function attach(slotName, extensionId) {\n (0,_store_js__WEBPACK_IMPORTED_MODULE_5__.updateInternalExtensionStore)((state)=>{\n const existingSlot = state.slots[slotName];\n if (!existingSlot) {\n return {\n ...state,\n slots: {\n ...state.slots,\n [slotName]: {\n ...createNewExtensionSlotInfo(slotName),\n attachedIds: [\n extensionId\n ]\n }\n }\n };\n } else {\n return {\n ...state,\n slots: {\n ...state.slots,\n [slotName]: {\n ...existingSlot,\n attachedIds: [\n ...existingSlot.attachedIds,\n extensionId\n ]\n }\n }\n };\n }\n });\n}\n/**\n * @deprecated Avoid using this. Extension attachments should be considered declarative.\n */ function detach(extensionSlotName, extensionId) {\n (0,_store_js__WEBPACK_IMPORTED_MODULE_5__.updateInternalExtensionStore)((state)=>{\n const existingSlot = state.slots[extensionSlotName];\n if (existingSlot && existingSlot.attachedIds.includes(extensionId)) {\n return {\n ...state,\n slots: {\n ...state.slots,\n [extensionSlotName]: {\n ...existingSlot,\n attachedIds: existingSlot.attachedIds.filter((id)=>id !== extensionId)\n }\n }\n };\n } else {\n return state;\n }\n });\n}\n/**\n * @deprecated Avoid using this. Extension attachments should be considered declarative.\n */ function detachAll(extensionSlotName) {\n (0,_store_js__WEBPACK_IMPORTED_MODULE_5__.updateInternalExtensionStore)((state)=>{\n const existingSlot = state.slots[extensionSlotName];\n if (existingSlot) {\n return {\n ...state,\n slots: {\n ...state.slots,\n [extensionSlotName]: {\n ...existingSlot,\n attachedIds: []\n }\n }\n };\n } else {\n return state;\n }\n });\n}\n/**\n * Get an order index for the extension. This will\n * come from either its configured order, its registered order\n * parameter, or the order in which it happened to be attached.\n */ function getOrder(extensionId, configuredOrder, registeredOrderIndex, attachedOrder) {\n const configuredIndex = configuredOrder.indexOf(extensionId);\n if (configuredIndex !== -1) {\n return configuredIndex;\n } else if (registeredOrderIndex !== undefined) {\n // extensions that don't have a configured order should appear after those that do\n return 1000 + registeredOrderIndex;\n } else {\n const assignedIndex = attachedOrder.indexOf(extensionId);\n if (assignedIndex !== -1) {\n // extensions that have neither a configured nor registered order should appear\n // after all others\n return 2000 + assignedIndex;\n } else {\n return -1;\n }\n }\n}\nfunction getAssignedExtensionsFromSlotData(slotName, internalState, config, extensionConfigStoreState, enabledFeatureFlags, isOnline, session) {\n const attachedIds = internalState.slots[slotName].attachedIds;\n const assignedIds = calculateAssignedIds(config, attachedIds);\n const extensions = [];\n // Create context once for all extensions in this slot\n const slotState = internalState.slots[slotName]?.state;\n const expressionContext = slotState && typeof slotState === 'object' ? {\n session,\n ...slotState\n } : {\n session\n };\n for (let id of assignedIds){\n const { config: rawExtensionConfig } = (0,_openmrs_esm_config__WEBPACK_IMPORTED_MODULE_1__.getExtensionConfigFromStore)(extensionConfigStoreState, slotName, id);\n const rawExtensionSlotExtensionConfig = (0,_openmrs_esm_config__WEBPACK_IMPORTED_MODULE_1__.getExtensionConfigFromExtensionSlotStore)(config, slotName, id);\n const extensionConfig = (0,lodash_es__WEBPACK_IMPORTED_MODULE_8__[\"default\"])(rawExtensionConfig, rawExtensionSlotExtensionConfig);\n const name = getExtensionNameFromId(id);\n const extension = internalState.extensions[name];\n // if the extension has not been registered yet, do not include it\n if (extension) {\n const requiredPrivileges = extensionConfig?.['Display conditions']?.privileges ?? extension.privileges ?? [];\n if (requiredPrivileges && (typeof requiredPrivileges === 'string' || Array.isArray(requiredPrivileges) && requiredPrivileges.length > 0)) {\n if (!session?.user) {\n continue;\n }\n if (!(0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.userHasAccess)(requiredPrivileges, session.user)) {\n continue;\n }\n }\n const displayConditionExpression = extensionConfig?.['Display conditions']?.expression || extension.displayExpression;\n if (displayConditionExpression !== undefined && typeof displayConditionExpression === 'string' && displayConditionExpression.trim().length > 0) {\n try {\n if (!(0,_openmrs_esm_expression_evaluator__WEBPACK_IMPORTED_MODULE_9__.evaluateAsBoolean)(displayConditionExpression, expressionContext)) {\n continue;\n }\n } catch (e) {\n console.error(`Error while evaluating expression '${displayConditionExpression}' for extension ${name} in slot ${slotName}`, e);\n continue;\n }\n }\n if (extension.featureFlag && !enabledFeatureFlags.includes(extension.featureFlag)) {\n continue;\n }\n if (window.offlineEnabled && !(0,_helpers_js__WEBPACK_IMPORTED_MODULE_4__.checkStatusFor)(isOnline, extension.online, extension.offline)) {\n continue;\n }\n extensions.push({\n id,\n name,\n moduleName: extension.moduleName,\n config: extensionConfig,\n featureFlag: extension.featureFlag,\n meta: extension.meta,\n online: extensionConfig?.['Display conditions']?.online ?? extension.online ?? true,\n offline: extensionConfig?.['Display conditions']?.offline ?? extension.offline ?? false\n });\n }\n }\n return extensions;\n}\n/**\n * Gets the list of extensions assigned to a given slot\n *\n * @param slotName The slot to load the assigned extensions for\n * @returns An array of extensions assigned to the named slot\n */ function getAssignedExtensions(slotName) {\n const internalState = extensionInternalStore.getState();\n const { config: slotConfig } = (0,_openmrs_esm_config__WEBPACK_IMPORTED_MODULE_1__.getExtensionSlotConfig)(slotName);\n const extensionStoreState = extensionsConfigStore.getState();\n const featureFlagState = _openmrs_esm_feature_flags__WEBPACK_IMPORTED_MODULE_2__.featureFlagsStore.getState();\n const sessionState = _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.sessionStore.getState();\n const isOnline = (0,_openmrs_esm_utils__WEBPACK_IMPORTED_MODULE_6__.isOnline)();\n const enabledFeatureFlags = Object.entries(featureFlagState.flags).filter(([, { enabled }])=>enabled).map(([name])=>name);\n return getAssignedExtensionsFromSlotData(slotName, internalState, slotConfig, extensionStoreState, enabledFeatureFlags, isOnline, sessionState.session);\n}\nfunction calculateAssignedIds(config, attachedIds) {\n const addedIds = config.add || [];\n const removedIds = config.remove || [];\n const idOrder = config.order || [];\n const { extensions } = extensionInternalStore.getState();\n return [\n ...attachedIds,\n ...addedIds\n ].filter((id)=>!removedIds.includes(id)).sort((idA, idB)=>{\n const ai = getOrder(idA, idOrder, extensions[getExtensionNameFromId(idA)]?.order, attachedIds);\n const bi = getOrder(idB, idOrder, extensions[getExtensionNameFromId(idB)]?.order, attachedIds);\n if (bi === -1) {\n return -1;\n } else if (ai === -1) {\n return 1;\n } else {\n return ai - bi;\n }\n });\n}\n/**\n * Used by by extension slots at mount time.\n *\n * @param moduleName The name of the module that contains the extension slot\n * @param slotName The extension slot name that is actually used\n * @param state Optional custom state for the slot, which will be stored in the extension store.\n * @internal\n */ const registerExtensionSlot = (moduleName, slotName, state)=>extensionInternalStore.setState((currentState)=>{\n const existingModuleName = currentState.slots[slotName]?.moduleName;\n if (existingModuleName && existingModuleName != moduleName) {\n console.warn(`An extension slot with the name '${slotName}' already exists. Refusing to register the same slot name twice (in \"registerExtensionSlot\"). The existing one is from module ${existingModuleName}.`);\n return currentState;\n }\n if (existingModuleName && existingModuleName == moduleName) {\n // Re-rendering an existing slot\n return currentState;\n }\n if (currentState.slots[slotName]) {\n return {\n ...currentState,\n slots: {\n ...currentState.slots,\n [slotName]: {\n ...currentState.slots[slotName],\n moduleName,\n state\n }\n }\n };\n }\n const slot = createNewExtensionSlotInfo(slotName, moduleName, state);\n return {\n ...currentState,\n slots: {\n ...currentState.slots,\n [slotName]: {\n ...slot\n }\n }\n };\n });\n/**\n * Used by extension slots to update the copy of the state for the extension slot\n *\n * @param slotName The name of the slot with state to update\n * @param state A copy of the new state\n * @param partial Whether this should be applied as a partial\n */ function updateExtensionSlotState(slotName, state, partial = false) {\n extensionInternalStore.setState((currentState)=>{\n const newState = partial ? (0,lodash_es__WEBPACK_IMPORTED_MODULE_8__[\"default\"])(currentState.slots[slotName].state, state) : state;\n return {\n ...currentState,\n slots: {\n ...currentState.slots,\n [slotName]: {\n ...currentState.slots[slotName],\n state: newState\n }\n }\n };\n });\n}\n/**\n * @internal\n * Just for testing.\n */ const reset = ()=>extensionStore.setState(()=>{\n return {\n slots: {},\n extensions: {}\n };\n });\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-extensions/dist/extensions.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA,gCAAgC,GAAG;;;;;;;CAOlC,GAAkE;AAC0J;AACvJ;AACP;AACK;AACR;AACjB;AACG;AAC0D;AACxG,MAAMmB,yBAAyBH,oEAAyBA;AACxD,MAAMI,iBAAiBH,4DAAiBA;AACxC,MAAMI,mBAAmBf,iFAA4BA;AACrD,MAAMgB,wBAAwBf,6EAAwBA;AACtD,gCAAgC;AAChC,SAASgB,2BAA2BC,aAAa,EAAEC,oBAAoB,EAAEH,qBAAqB,EAAEI,gBAAgB,EAAE1B,YAAY;IAC1H,MAAM2B,QAAQ,CAAC;IACf,MAAMhB,WAAWC,4DAAUA;IAC3B,MAAMgB,sBAAsBC,OAAOC,OAAO,CAACJ,iBAAiBK,KAAK,EAAEC,MAAM,CAAC,CAAC,GAAG,EAAEC,OAAO,EAAE,CAAC,GAAGA,SAASC,GAAG,CAAC,CAAC,CAACC,KAAK,GAAGA;IACpH,KAAK,IAAI,CAACC,UAAUC,KAAK,IAAIR,OAAOC,OAAO,CAACN,cAAcG,KAAK,EAAE;QAC7D,MAAM,EAAEW,MAAM,EAAE,GAAGjC,oFAA+BA,CAACoB,sBAAsBY,KAAKF,IAAI;QAClF,MAAMI,qBAAqBC,kCAAkCJ,UAAUZ,eAAec,QAAQhB,uBAAuBM,qBAAqBjB,UAAUX,aAAayC,OAAO;QACxKd,KAAK,CAACS,SAAS,GAAG;YACdM,YAAYL,KAAKK,UAAU;YAC3BH;QACJ;IACJ;IACA,IAAI,CAAC1B,qDAAOA,CAACO,eAAeuB,QAAQ,GAAGhB,KAAK,EAAEA,QAAQ;QAClDP,eAAewB,QAAQ,CAAC;YACpBjB;QACJ;IACJ;AACJ;AACAR,uBAAuB0B,SAAS,CAAC,CAACC;IAC9BvB,2BAA2BuB,eAAezB,iBAAiBsB,QAAQ,IAAIrB,sBAAsBqB,QAAQ,IAAIlC,yEAAiBA,CAACkC,QAAQ,IAAI3C,0DAAYA,CAAC2C,QAAQ;AAChK;AACAtB,iBAAiBwB,SAAS,CAAC,CAACE;IACxBxB,2BAA2BJ,uBAAuBwB,QAAQ,IAAII,aAAazB,sBAAsBqB,QAAQ,IAAIlC,yEAAiBA,CAACkC,QAAQ,IAAI3C,0DAAYA,CAAC2C,QAAQ;AACpK;AACArB,sBAAsBuB,SAAS,CAAC,CAACG;IAC7BzB,2BAA2BJ,uBAAuBwB,QAAQ,IAAItB,iBAAiBsB,QAAQ,IAAIK,kBAAkBvC,yEAAiBA,CAACkC,QAAQ,IAAI3C,0DAAYA,CAAC2C,QAAQ;AACpK;AACAlC,yEAAiBA,CAACoC,SAAS,CAAC,CAACnB;IACzBH,2BAA2BJ,uBAAuBwB,QAAQ,IAAItB,iBAAiBsB,QAAQ,IAAIrB,sBAAsBqB,QAAQ,IAAIjB,kBAAkB1B,0DAAYA,CAAC2C,QAAQ;AACxK;AACA3C,0DAAYA,CAAC6C,SAAS,CAAC,CAACJ;IACpBlB,2BAA2BJ,uBAAuBwB,QAAQ,IAAItB,iBAAiBsB,QAAQ,IAAIrB,sBAAsBqB,QAAQ,IAAIlC,yEAAiBA,CAACkC,QAAQ,IAAIF;AAC/J;AACA,SAASQ;IACL1B,2BAA2BJ,uBAAuBwB,QAAQ,IAAItB,iBAAiBsB,QAAQ,IAAIrB,sBAAsBqB,QAAQ,IAAIlC,yEAAiBA,CAACkC,QAAQ,IAAI3C,0DAAYA,CAAC2C,QAAQ;AACpL;AACAM;AACAvC,kFAA4BA,CAACuC;AAC7B,SAASC,2BAA2Bd,QAAQ,EAAEM,UAAU,EAAES,KAAK;IAC3D,OAAO;QACHT;QACAP,MAAMC;QACNgB,aAAa,EAAE;QACfd,QAAQ;QACRa;IACJ;AACJ;AACA;;;;;;;;;;;;CAYC,GAAU,SAASE,uBAAuBC,WAAW;IAClD,MAAM,CAACC,cAAc,GAAGD,YAAYE,KAAK,CAAC;IAC1C,OAAOD;AACX;AACO,SAASE,6BAA6BN,KAAK,EAAEG,WAAW;IAC3D,MAAMnB,OAAOkB,uBAAuBC;IACpC,OAAOH,MAAMO,UAAU,CAACvB,KAAK;AACjC;AACO,SAASwB,yBAAyBL,WAAW;IAChD,MAAMH,QAAQhC,uBAAuBwB,QAAQ;IAC7C,OAAOc,6BAA6BN,OAAOG;AAC/C;AACA;;;;;CAKC,GAAU,MAAMM,oBAAoB,CAACC,wBAAwB1C,uBAAuByB,QAAQ,CAAC,CAACO;QACvFA,MAAMO,UAAU,CAACG,sBAAsB1B,IAAI,CAAC,GAAG;YAC3C,GAAG0B,qBAAqB;YACxBC,WAAW,EAAE;QACjB;QACA,OAAOX;IACX,GAAG;AACP;;;;;;;;;;;;;;;;;;CAkBC,GAAU,SAASY,OAAO3B,QAAQ,EAAEkB,WAAW;IAC5CpC,uEAA4BA,CAAC,CAACiC;QAC1B,MAAMa,eAAeb,MAAMxB,KAAK,CAACS,SAAS;QAC1C,IAAI,CAAC4B,cAAc;YACf,OAAO;gBACH,GAAGb,KAAK;gBACRxB,OAAO;oBACH,GAAGwB,MAAMxB,KAAK;oBACd,CAACS,SAAS,EAAE;wBACR,GAAGc,2BAA2Bd,SAAS;wBACvCgB,aAAa;4BACTE;yBACH;oBACL;gBACJ;YACJ;QACJ,OAAO;YACH,OAAO;gBACH,GAAGH,KAAK;gBACRxB,OAAO;oBACH,GAAGwB,MAAMxB,KAAK;oBACd,CAACS,SAAS,EAAE;wBACR,GAAG4B,YAAY;wBACfZ,aAAa;+BACNY,aAAaZ,WAAW;4BAC3BE;yBACH;oBACL;gBACJ;YACJ;QACJ;IACJ;AACJ;AACA;;CAEC,GAAU,SAASW,OAAOC,iBAAiB,EAAEZ,WAAW;IACrDpC,uEAA4BA,CAAC,CAACiC;QAC1B,MAAMa,eAAeb,MAAMxB,KAAK,CAACuC,kBAAkB;QACnD,IAAIF,gBAAgBA,aAAaZ,WAAW,CAACe,QAAQ,CAACb,cAAc;YAChE,OAAO;gBACH,GAAGH,KAAK;gBACRxB,OAAO;oBACH,GAAGwB,MAAMxB,KAAK;oBACd,CAACuC,kBAAkB,EAAE;wBACjB,GAAGF,YAAY;wBACfZ,aAAaY,aAAaZ,WAAW,CAACpB,MAAM,CAAC,CAACoC,KAAKA,OAAOd;oBAC9D;gBACJ;YACJ;QACJ,OAAO;YACH,OAAOH;QACX;IACJ;AACJ;AACA;;CAEC,GAAU,SAASkB,UAAUH,iBAAiB;IAC3ChD,uEAA4BA,CAAC,CAACiC;QAC1B,MAAMa,eAAeb,MAAMxB,KAAK,CAACuC,kBAAkB;QACnD,IAAIF,cAAc;YACd,OAAO;gBACH,GAAGb,KAAK;gBACRxB,OAAO;oBACH,GAAGwB,MAAMxB,KAAK;oBACd,CAACuC,kBAAkB,EAAE;wBACjB,GAAGF,YAAY;wBACfZ,aAAa,EAAE;oBACnB;gBACJ;YACJ;QACJ,OAAO;YACH,OAAOD;QACX;IACJ;AACJ;AACA;;;;CAIC,GAAG,SAASmB,SAAShB,WAAW,EAAEiB,eAAe,EAAEC,oBAAoB,EAAEC,aAAa;IACnF,MAAMC,kBAAkBH,gBAAgBI,OAAO,CAACrB;IAChD,IAAIoB,oBAAoB,CAAC,GAAG;QACxB,OAAOA;IACX,OAAO,IAAIF,yBAAyBI,WAAW;QAC3C,kFAAkF;QAClF,OAAO,OAAOJ;IAClB,OAAO;QACH,MAAMK,gBAAgBJ,cAAcE,OAAO,CAACrB;QAC5C,IAAIuB,kBAAkB,CAAC,GAAG;YACtB,+EAA+E;YAC/E,mBAAmB;YACnB,OAAO,OAAOA;QAClB,OAAO;YACH,OAAO,CAAC;QACZ;IACJ;AACJ;AACA,SAASrC,kCAAkCJ,QAAQ,EAAEZ,aAAa,EAAEc,MAAM,EAAEwC,yBAAyB,EAAElD,mBAAmB,EAAEjB,QAAQ,EAAE8B,OAAO;IACzI,MAAMW,cAAc5B,cAAcG,KAAK,CAACS,SAAS,CAACgB,WAAW;IAC7D,MAAM2B,cAAcC,qBAAqB1C,QAAQc;IACjD,MAAMM,aAAa,EAAE;IACrB,sDAAsD;IACtD,MAAMuB,YAAYzD,cAAcG,KAAK,CAACS,SAAS,EAAEe;IACjD,MAAM+B,oBAAoBD,aAAa,OAAOA,cAAc,WAAW;QACnExC;QACA,GAAGwC,SAAS;IAChB,IAAI;QACAxC;IACJ;IACA,KAAK,IAAI2B,MAAMW,YAAY;QACvB,MAAM,EAAEzC,QAAQ6C,kBAAkB,EAAE,GAAGhF,gFAA2BA,CAAC2E,2BAA2B1C,UAAUgC;QACxG,MAAMgB,kCAAkClF,6FAAwCA,CAACoC,QAAQF,UAAUgC;QACnG,MAAMiB,kBAAkBvE,qDAAKA,CAACqE,oBAAoBC;QAClD,MAAMjD,OAAOkB,uBAAuBe;QACpC,MAAMkB,YAAY9D,cAAckC,UAAU,CAACvB,KAAK;QAChD,kEAAkE;QAClE,IAAImD,WAAW;YACX,MAAMC,qBAAqBF,iBAAiB,CAAC,qBAAqB,EAAEG,cAAcF,UAAUE,UAAU,IAAI,EAAE;YAC5G,IAAID,sBAAuB,QAAOA,uBAAuB,YAAYE,MAAMC,OAAO,CAACH,uBAAuBA,mBAAmBI,MAAM,GAAG,IAAI;gBACtI,IAAI,CAAClD,SAASmD,MAAM;oBAChB;gBACJ;gBACA,IAAI,CAAC3F,+DAAaA,CAACsF,oBAAoB9C,QAAQmD,IAAI,GAAG;oBAClD;gBACJ;YACJ;YACA,MAAMC,6BAA6BR,iBAAiB,CAAC,qBAAqB,EAAES,cAAcR,UAAUS,iBAAiB;YACrH,IAAIF,+BAA+BjB,aAAa,OAAOiB,+BAA+B,YAAYA,2BAA2BG,IAAI,GAAGL,MAAM,GAAG,GAAG;gBAC5I,IAAI;oBACA,IAAI,CAACnF,oFAAiBA,CAACqF,4BAA4BX,oBAAoB;wBACnE;oBACJ;gBACJ,EAAE,OAAOe,GAAG;oBACRC,QAAQC,KAAK,CAAC,CAAC,mCAAmC,EAAEN,2BAA2B,gBAAgB,EAAE1D,KAAK,SAAS,EAAEC,UAAU,EAAE6D;oBAC7H;gBACJ;YACJ;YACA,IAAIX,UAAUc,WAAW,IAAI,CAACxE,oBAAoBuC,QAAQ,CAACmB,UAAUc,WAAW,GAAG;gBAC/E;YACJ;YACA,IAAIC,OAAOC,cAAc,IAAI,CAACvF,2DAAcA,CAACJ,UAAU2E,UAAUiB,MAAM,EAAEjB,UAAUkB,OAAO,GAAG;gBACzF;YACJ;YACA9C,WAAW+C,IAAI,CAAC;gBACZrC;gBACAjC;gBACAO,YAAY4C,UAAU5C,UAAU;gBAChCJ,QAAQ+C;gBACRe,aAAad,UAAUc,WAAW;gBAClCM,MAAMpB,UAAUoB,IAAI;gBACpBH,QAAQlB,iBAAiB,CAAC,qBAAqB,EAAEkB,UAAUjB,UAAUiB,MAAM,IAAI;gBAC/EC,SAASnB,iBAAiB,CAAC,qBAAqB,EAAEmB,WAAWlB,UAAUkB,OAAO,IAAI;YACtF;QACJ;IACJ;IACA,OAAO9C;AACX;AACA;;;;;CAKC,GAAU,SAASiD,sBAAsBvE,QAAQ;IAC9C,MAAMZ,gBAAgBL,uBAAuBwB,QAAQ;IACrD,MAAM,EAAEL,QAAQsE,UAAU,EAAE,GAAGxG,2EAAsBA,CAACgC;IACtD,MAAMyE,sBAAsBvF,sBAAsBqB,QAAQ;IAC1D,MAAMmE,mBAAmBrG,yEAAiBA,CAACkC,QAAQ;IACnD,MAAMoE,eAAe/G,0DAAYA,CAAC2C,QAAQ;IAC1C,MAAMhC,WAAWC,4DAAUA;IAC3B,MAAMgB,sBAAsBC,OAAOC,OAAO,CAACgF,iBAAiB/E,KAAK,EAAEC,MAAM,CAAC,CAAC,GAAG,EAAEC,OAAO,EAAE,CAAC,GAAGA,SAASC,GAAG,CAAC,CAAC,CAACC,KAAK,GAAGA;IACpH,OAAOK,kCAAkCJ,UAAUZ,eAAeoF,YAAYC,qBAAqBjF,qBAAqBjB,UAAUoG,aAAatE,OAAO;AAC1J;AACA,SAASuC,qBAAqB1C,MAAM,EAAEc,WAAW;IAC7C,MAAM4D,WAAW1E,OAAO2E,GAAG,IAAI,EAAE;IACjC,MAAMC,aAAa5E,OAAO6E,MAAM,IAAI,EAAE;IACtC,MAAMC,UAAU9E,OAAO+E,KAAK,IAAI,EAAE;IAClC,MAAM,EAAE3D,UAAU,EAAE,GAAGvC,uBAAuBwB,QAAQ;IACtD,OAAO;WACAS;WACA4D;KACN,CAAChF,MAAM,CAAC,CAACoC,KAAK,CAAC8C,WAAW/C,QAAQ,CAACC,KAAKkD,IAAI,CAAC,CAACC,KAAKC;QAChD,MAAMC,KAAKnD,SAASiD,KAAKH,SAAS1D,UAAU,CAACL,uBAAuBkE,KAAK,EAAEF,OAAOjE;QAClF,MAAMsE,KAAKpD,SAASkD,KAAKJ,SAAS1D,UAAU,CAACL,uBAAuBmE,KAAK,EAAEH,OAAOjE;QAClF,IAAIsE,OAAO,CAAC,GAAG;YACX,OAAO,CAAC;QACZ,OAAO,IAAID,OAAO,CAAC,GAAG;YAClB,OAAO;QACX,OAAO;YACH,OAAOA,KAAKC;QAChB;IACJ;AACJ;AACA;;;;;;;CAOC,GAAU,MAAMC,wBAAwB,CAACjF,YAAYN,UAAUe,QAAQhC,uBAAuByB,QAAQ,CAAC,CAACgF;QACjG,MAAMC,qBAAqBD,aAAajG,KAAK,CAACS,SAAS,EAAEM;QACzD,IAAImF,sBAAsBA,sBAAsBnF,YAAY;YACxDwD,QAAQ4B,IAAI,CAAC,CAAC,iCAAiC,EAAE1F,SAAS,8HAA8H,EAAEyF,mBAAmB,CAAC,CAAC;YAC/M,OAAOD;QACX;QACA,IAAIC,sBAAsBA,sBAAsBnF,YAAY;YACxD,gCAAgC;YAChC,OAAOkF;QACX;QACA,IAAIA,aAAajG,KAAK,CAACS,SAAS,EAAE;YAC9B,OAAO;gBACH,GAAGwF,YAAY;gBACfjG,OAAO;oBACH,GAAGiG,aAAajG,KAAK;oBACrB,CAACS,SAAS,EAAE;wBACR,GAAGwF,aAAajG,KAAK,CAACS,SAAS;wBAC/BM;wBACAS;oBACJ;gBACJ;YACJ;QACJ;QACA,MAAMd,OAAOa,2BAA2Bd,UAAUM,YAAYS;QAC9D,OAAO;YACH,GAAGyE,YAAY;YACfjG,OAAO;gBACH,GAAGiG,aAAajG,KAAK;gBACrB,CAACS,SAAS,EAAE;oBACR,GAAGC,IAAI;gBACX;YACJ;QACJ;IACJ,GAAG;AACP;;;;;;CAMC,GAAU,SAAS0F,yBAAyB3F,QAAQ,EAAEe,KAAK,EAAE6E,UAAU,KAAK;IACzE7G,uBAAuByB,QAAQ,CAAC,CAACgF;QAC7B,MAAMK,WAAWD,UAAUlH,qDAAKA,CAAC8G,aAAajG,KAAK,CAACS,SAAS,CAACe,KAAK,EAAEA,SAASA;QAC9E,OAAO;YACH,GAAGyE,YAAY;YACfjG,OAAO;gBACH,GAAGiG,aAAajG,KAAK;gBACrB,CAACS,SAAS,EAAE;oBACR,GAAGwF,aAAajG,KAAK,CAACS,SAAS;oBAC/Be,OAAO8E;gBACX;YACJ;QACJ;IACJ;AACJ;AACA;;;CAGC,GAAU,MAAMC,QAAQ,IAAI9G,eAAewB,QAAQ,CAAC;QAC7C,OAAO;YACHjB,OAAO,CAAC;YACR+B,YAAY,CAAC;QACjB;IACJ,GAAG","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-extensions/dist/extensions.js?c0e7"],"sourcesContent":["/** @module @category Extension */ /*\n * We have the following extension modes:\n *\n * - attached (set via code in form of: attach, detach, ...)\n * - configured (set via configuration in form of: added, removed, ...)\n * - assigned (computed from attached and configured)\n * - connected (computed from assigned using connectivity and online / offline)\n */ import { sessionStore, userHasAccess } from \"@openmrs/esm-api\";\nimport { getExtensionConfigFromExtensionSlotStore, getExtensionConfigFromStore, getExtensionSlotConfig, getExtensionSlotConfigFromStore, getExtensionSlotsConfigStore, getExtensionsConfigStore } from \"@openmrs/esm-config\";\nimport { evaluateAsBoolean } from \"@openmrs/esm-expression-evaluator\";\nimport { featureFlagsStore } from \"@openmrs/esm-feature-flags\";\nimport { subscribeConnectivityChanged } from \"@openmrs/esm-globals\";\nimport { isOnline as isOnlineFn } from \"@openmrs/esm-utils\";\nimport { isEqual, merge } from \"lodash-es\";\nimport { checkStatusFor } from \"./helpers.js\";\nimport { getExtensionInternalStore, getExtensionStore, updateInternalExtensionStore } from \"./store.js\";\nconst extensionInternalStore = getExtensionInternalStore();\nconst extensionStore = getExtensionStore();\nconst slotsConfigStore = getExtensionSlotsConfigStore();\nconst extensionsConfigStore = getExtensionsConfigStore();\n// Keep the output store updated\nfunction updateExtensionOutputStore(internalState, extensionSlotConfigs, extensionsConfigStore, featureFlagStore, sessionStore) {\n    const slots = {};\n    const isOnline = isOnlineFn();\n    const enabledFeatureFlags = Object.entries(featureFlagStore.flags).filter(([, { enabled }])=>enabled).map(([name])=>name);\n    for (let [slotName, slot] of Object.entries(internalState.slots)){\n        const { config } = getExtensionSlotConfigFromStore(extensionSlotConfigs, slot.name);\n        const assignedExtensions = getAssignedExtensionsFromSlotData(slotName, internalState, config, extensionsConfigStore, enabledFeatureFlags, isOnline, sessionStore.session);\n        slots[slotName] = {\n            moduleName: slot.moduleName,\n            assignedExtensions\n        };\n    }\n    if (!isEqual(extensionStore.getState().slots, slots)) {\n        extensionStore.setState({\n            slots\n        });\n    }\n}\nextensionInternalStore.subscribe((internalStore)=>{\n    updateExtensionOutputStore(internalStore, slotsConfigStore.getState(), extensionsConfigStore.getState(), featureFlagsStore.getState(), sessionStore.getState());\n});\nslotsConfigStore.subscribe((slotConfigs)=>{\n    updateExtensionOutputStore(extensionInternalStore.getState(), slotConfigs, extensionsConfigStore.getState(), featureFlagsStore.getState(), sessionStore.getState());\n});\nextensionsConfigStore.subscribe((extensionConfigs)=>{\n    updateExtensionOutputStore(extensionInternalStore.getState(), slotsConfigStore.getState(), extensionConfigs, featureFlagsStore.getState(), sessionStore.getState());\n});\nfeatureFlagsStore.subscribe((featureFlagStore)=>{\n    updateExtensionOutputStore(extensionInternalStore.getState(), slotsConfigStore.getState(), extensionsConfigStore.getState(), featureFlagStore, sessionStore.getState());\n});\nsessionStore.subscribe((session)=>{\n    updateExtensionOutputStore(extensionInternalStore.getState(), slotsConfigStore.getState(), extensionsConfigStore.getState(), featureFlagsStore.getState(), session);\n});\nfunction updateOutputStoreToCurrent() {\n    updateExtensionOutputStore(extensionInternalStore.getState(), slotsConfigStore.getState(), extensionsConfigStore.getState(), featureFlagsStore.getState(), sessionStore.getState());\n}\nupdateOutputStoreToCurrent();\nsubscribeConnectivityChanged(updateOutputStoreToCurrent);\nfunction createNewExtensionSlotInfo(slotName, moduleName, state) {\n    return {\n        moduleName,\n        name: slotName,\n        attachedIds: [],\n        config: null,\n        state\n    };\n}\n/**\n * Given an extension ID, which is a string uniquely identifying\n * an instance of an extension within an extension slot, this\n * returns the extension name.\n *\n * @example\n * ```js\n * getExtensionNameFromId(\"foo#bar\")\n *  --> \"foo\"\n * getExtensionNameFromId(\"baz\")\n *  --> \"baz\"\n * ```\n */ export function getExtensionNameFromId(extensionId) {\n    const [extensionName] = extensionId.split('#');\n    return extensionName;\n}\nexport function getExtensionRegistrationFrom(state, extensionId) {\n    const name = getExtensionNameFromId(extensionId);\n    return state.extensions[name];\n}\nexport function getExtensionRegistration(extensionId) {\n    const state = extensionInternalStore.getState();\n    return getExtensionRegistrationFrom(state, extensionId);\n}\n/**\n * Extensions must be registered in order to be rendered.\n * This is handled by the app shell, when extensions are provided\n * via the `routes.json` file and registered through `registerApp()`.\n * @internal\n */ export const registerExtension = (extensionRegistration)=>extensionInternalStore.setState((state)=>{\n        state.extensions[extensionRegistration.name] = {\n            ...extensionRegistration,\n            instances: []\n        };\n        return state;\n    });\n/**\n * Attach an extension to an extension slot.\n *\n * This will cause the extension to be rendered into the specified\n * extension slot, unless it is removed by configuration. Using\n * `attach` is an alternative to specifying the `slot` or `slots`\n * in the extension declaration.\n *\n * It is particularly useful when creating a slot into which\n * you want to render an existing extension. This enables you\n * to do so without modifying the extension's declaration, which\n * may be impractical or inappropriate, for example if you are\n * writing a module for a specific implementation.\n *\n * @param slotName a name uniquely identifying the slot\n * @param extensionId an extension name, with an optional #-suffix\n *    to distinguish it from other instances of the same extension\n *    attached to the same slot.\n */ export function attach(slotName, extensionId) {\n    updateInternalExtensionStore((state)=>{\n        const existingSlot = state.slots[slotName];\n        if (!existingSlot) {\n            return {\n                ...state,\n                slots: {\n                    ...state.slots,\n                    [slotName]: {\n                        ...createNewExtensionSlotInfo(slotName),\n                        attachedIds: [\n                            extensionId\n                        ]\n                    }\n                }\n            };\n        } else {\n            return {\n                ...state,\n                slots: {\n                    ...state.slots,\n                    [slotName]: {\n                        ...existingSlot,\n                        attachedIds: [\n                            ...existingSlot.attachedIds,\n                            extensionId\n                        ]\n                    }\n                }\n            };\n        }\n    });\n}\n/**\n * @deprecated Avoid using this. Extension attachments should be considered declarative.\n */ export function detach(extensionSlotName, extensionId) {\n    updateInternalExtensionStore((state)=>{\n        const existingSlot = state.slots[extensionSlotName];\n        if (existingSlot && existingSlot.attachedIds.includes(extensionId)) {\n            return {\n                ...state,\n                slots: {\n                    ...state.slots,\n                    [extensionSlotName]: {\n                        ...existingSlot,\n                        attachedIds: existingSlot.attachedIds.filter((id)=>id !== extensionId)\n                    }\n                }\n            };\n        } else {\n            return state;\n        }\n    });\n}\n/**\n * @deprecated Avoid using this. Extension attachments should be considered declarative.\n */ export function detachAll(extensionSlotName) {\n    updateInternalExtensionStore((state)=>{\n        const existingSlot = state.slots[extensionSlotName];\n        if (existingSlot) {\n            return {\n                ...state,\n                slots: {\n                    ...state.slots,\n                    [extensionSlotName]: {\n                        ...existingSlot,\n                        attachedIds: []\n                    }\n                }\n            };\n        } else {\n            return state;\n        }\n    });\n}\n/**\n * Get an order index for the extension. This will\n * come from either its configured order, its registered order\n * parameter, or the order in which it happened to be attached.\n */ function getOrder(extensionId, configuredOrder, registeredOrderIndex, attachedOrder) {\n    const configuredIndex = configuredOrder.indexOf(extensionId);\n    if (configuredIndex !== -1) {\n        return configuredIndex;\n    } else if (registeredOrderIndex !== undefined) {\n        // extensions that don't have a configured order should appear after those that do\n        return 1000 + registeredOrderIndex;\n    } else {\n        const assignedIndex = attachedOrder.indexOf(extensionId);\n        if (assignedIndex !== -1) {\n            // extensions that have neither a configured nor registered order should appear\n            // after all others\n            return 2000 + assignedIndex;\n        } else {\n            return -1;\n        }\n    }\n}\nfunction getAssignedExtensionsFromSlotData(slotName, internalState, config, extensionConfigStoreState, enabledFeatureFlags, isOnline, session) {\n    const attachedIds = internalState.slots[slotName].attachedIds;\n    const assignedIds = calculateAssignedIds(config, attachedIds);\n    const extensions = [];\n    // Create context once for all extensions in this slot\n    const slotState = internalState.slots[slotName]?.state;\n    const expressionContext = slotState && typeof slotState === 'object' ? {\n        session,\n        ...slotState\n    } : {\n        session\n    };\n    for (let id of assignedIds){\n        const { config: rawExtensionConfig } = getExtensionConfigFromStore(extensionConfigStoreState, slotName, id);\n        const rawExtensionSlotExtensionConfig = getExtensionConfigFromExtensionSlotStore(config, slotName, id);\n        const extensionConfig = merge(rawExtensionConfig, rawExtensionSlotExtensionConfig);\n        const name = getExtensionNameFromId(id);\n        const extension = internalState.extensions[name];\n        // if the extension has not been registered yet, do not include it\n        if (extension) {\n            const requiredPrivileges = extensionConfig?.['Display conditions']?.privileges ?? extension.privileges ?? [];\n            if (requiredPrivileges && (typeof requiredPrivileges === 'string' || Array.isArray(requiredPrivileges) && requiredPrivileges.length > 0)) {\n                if (!session?.user) {\n                    continue;\n                }\n                if (!userHasAccess(requiredPrivileges, session.user)) {\n                    continue;\n                }\n            }\n            const displayConditionExpression = extensionConfig?.['Display conditions']?.expression || extension.displayExpression;\n            if (displayConditionExpression !== undefined && typeof displayConditionExpression === 'string' && displayConditionExpression.trim().length > 0) {\n                try {\n                    if (!evaluateAsBoolean(displayConditionExpression, expressionContext)) {\n                        continue;\n                    }\n                } catch (e) {\n                    console.error(`Error while evaluating expression '${displayConditionExpression}' for extension ${name} in slot ${slotName}`, e);\n                    continue;\n                }\n            }\n            if (extension.featureFlag && !enabledFeatureFlags.includes(extension.featureFlag)) {\n                continue;\n            }\n            if (window.offlineEnabled && !checkStatusFor(isOnline, extension.online, extension.offline)) {\n                continue;\n            }\n            extensions.push({\n                id,\n                name,\n                moduleName: extension.moduleName,\n                config: extensionConfig,\n                featureFlag: extension.featureFlag,\n                meta: extension.meta,\n                online: extensionConfig?.['Display conditions']?.online ?? extension.online ?? true,\n                offline: extensionConfig?.['Display conditions']?.offline ?? extension.offline ?? false\n            });\n        }\n    }\n    return extensions;\n}\n/**\n * Gets the list of extensions assigned to a given slot\n *\n * @param slotName The slot to load the assigned extensions for\n * @returns An array of extensions assigned to the named slot\n */ export function getAssignedExtensions(slotName) {\n    const internalState = extensionInternalStore.getState();\n    const { config: slotConfig } = getExtensionSlotConfig(slotName);\n    const extensionStoreState = extensionsConfigStore.getState();\n    const featureFlagState = featureFlagsStore.getState();\n    const sessionState = sessionStore.getState();\n    const isOnline = isOnlineFn();\n    const enabledFeatureFlags = Object.entries(featureFlagState.flags).filter(([, { enabled }])=>enabled).map(([name])=>name);\n    return getAssignedExtensionsFromSlotData(slotName, internalState, slotConfig, extensionStoreState, enabledFeatureFlags, isOnline, sessionState.session);\n}\nfunction calculateAssignedIds(config, attachedIds) {\n    const addedIds = config.add || [];\n    const removedIds = config.remove || [];\n    const idOrder = config.order || [];\n    const { extensions } = extensionInternalStore.getState();\n    return [\n        ...attachedIds,\n        ...addedIds\n    ].filter((id)=>!removedIds.includes(id)).sort((idA, idB)=>{\n        const ai = getOrder(idA, idOrder, extensions[getExtensionNameFromId(idA)]?.order, attachedIds);\n        const bi = getOrder(idB, idOrder, extensions[getExtensionNameFromId(idB)]?.order, attachedIds);\n        if (bi === -1) {\n            return -1;\n        } else if (ai === -1) {\n            return 1;\n        } else {\n            return ai - bi;\n        }\n    });\n}\n/**\n * Used by by extension slots at mount time.\n *\n * @param moduleName The name of the module that contains the extension slot\n * @param slotName The extension slot name that is actually used\n * @param state Optional custom state for the slot, which will be stored in the extension store.\n * @internal\n */ export const registerExtensionSlot = (moduleName, slotName, state)=>extensionInternalStore.setState((currentState)=>{\n        const existingModuleName = currentState.slots[slotName]?.moduleName;\n        if (existingModuleName && existingModuleName != moduleName) {\n            console.warn(`An extension slot with the name '${slotName}' already exists. Refusing to register the same slot name twice (in \"registerExtensionSlot\"). The existing one is from module ${existingModuleName}.`);\n            return currentState;\n        }\n        if (existingModuleName && existingModuleName == moduleName) {\n            // Re-rendering an existing slot\n            return currentState;\n        }\n        if (currentState.slots[slotName]) {\n            return {\n                ...currentState,\n                slots: {\n                    ...currentState.slots,\n                    [slotName]: {\n                        ...currentState.slots[slotName],\n                        moduleName,\n                        state\n                    }\n                }\n            };\n        }\n        const slot = createNewExtensionSlotInfo(slotName, moduleName, state);\n        return {\n            ...currentState,\n            slots: {\n                ...currentState.slots,\n                [slotName]: {\n                    ...slot\n                }\n            }\n        };\n    });\n/**\n * Used by extension slots to update the copy of the state for the extension slot\n *\n * @param slotName The name of the slot with state to update\n * @param state A copy of the new state\n * @param partial Whether this should be applied as a partial\n */ export function updateExtensionSlotState(slotName, state, partial = false) {\n    extensionInternalStore.setState((currentState)=>{\n        const newState = partial ? merge(currentState.slots[slotName].state, state) : state;\n        return {\n            ...currentState,\n            slots: {\n                ...currentState.slots,\n                [slotName]: {\n                    ...currentState.slots[slotName],\n                    state: newState\n                }\n            }\n        };\n    });\n}\n/**\n * @internal\n * Just for testing.\n */ export const reset = ()=>extensionStore.setState(()=>{\n        return {\n            slots: {},\n            extensions: {}\n        };\n    });\n"],"names":["sessionStore","userHasAccess","getExtensionConfigFromExtensionSlotStore","getExtensionConfigFromStore","getExtensionSlotConfig","getExtensionSlotConfigFromStore","getExtensionSlotsConfigStore","getExtensionsConfigStore","evaluateAsBoolean","featureFlagsStore","subscribeConnectivityChanged","isOnline","isOnlineFn","isEqual","merge","checkStatusFor","getExtensionInternalStore","getExtensionStore","updateInternalExtensionStore","extensionInternalStore","extensionStore","slotsConfigStore","extensionsConfigStore","updateExtensionOutputStore","internalState","extensionSlotConfigs","featureFlagStore","slots","enabledFeatureFlags","Object","entries","flags","filter","enabled","map","name","slotName","slot","config","assignedExtensions","getAssignedExtensionsFromSlotData","session","moduleName","getState","setState","subscribe","internalStore","slotConfigs","extensionConfigs","updateOutputStoreToCurrent","createNewExtensionSlotInfo","state","attachedIds","getExtensionNameFromId","extensionId","extensionName","split","getExtensionRegistrationFrom","extensions","getExtensionRegistration","registerExtension","extensionRegistration","instances","attach","existingSlot","detach","extensionSlotName","includes","id","detachAll","getOrder","configuredOrder","registeredOrderIndex","attachedOrder","configuredIndex","indexOf","undefined","assignedIndex","extensionConfigStoreState","assignedIds","calculateAssignedIds","slotState","expressionContext","rawExtensionConfig","rawExtensionSlotExtensionConfig","extensionConfig","extension","requiredPrivileges","privileges","Array","isArray","length","user","displayConditionExpression","expression","displayExpression","trim","e","console","error","featureFlag","window","offlineEnabled","online","offline","push","meta","getAssignedExtensions","slotConfig","extensionStoreState","featureFlagState","sessionState","addedIds","add","removedIds","remove","idOrder","order","sort","idA","idB","ai","bi","registerExtensionSlot","currentState","existingModuleName","warn","updateExtensionSlotState","partial","newState","reset"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-extensions/dist/extensions.js\n");
448
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ attach: () => (/* binding */ attach),\n/* harmony export */ detach: () => (/* binding */ detach),\n/* harmony export */ detachAll: () => (/* binding */ detachAll),\n/* harmony export */ getAssignedExtensions: () => (/* binding */ getAssignedExtensions),\n/* harmony export */ getExtensionNameFromId: () => (/* binding */ getExtensionNameFromId),\n/* harmony export */ getExtensionRegistration: () => (/* binding */ getExtensionRegistration),\n/* harmony export */ getExtensionRegistrationFrom: () => (/* binding */ getExtensionRegistrationFrom),\n/* harmony export */ registerExtension: () => (/* binding */ registerExtension),\n/* harmony export */ registerExtensionSlot: () => (/* binding */ registerExtensionSlot),\n/* harmony export */ reset: () => (/* binding */ reset),\n/* harmony export */ updateExtensionSlotState: () => (/* binding */ updateExtensionSlotState)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-api */ \"../../framework/esm-api/dist/index.js\");\n/* harmony import */ var _openmrs_esm_config__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-config */ \"../../framework/esm-config/dist/index.js\");\n/* harmony import */ var _openmrs_esm_expression_evaluator__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! @openmrs/esm-expression-evaluator */ \"../../framework/esm-expression-evaluator/dist/evaluator.js\");\n/* harmony import */ var _openmrs_esm_feature_flags__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @openmrs/esm-feature-flags */ \"../../framework/esm-feature-flags/dist/index.js\");\n/* harmony import */ var _openmrs_esm_globals__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @openmrs/esm-globals */ \"../../framework/esm-globals/dist/index.js\");\n/* harmony import */ var _openmrs_esm_utils__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! @openmrs/esm-utils */ \"../../framework/esm-utils/dist/is-online.js\");\n/* harmony import */ var lodash_es__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! lodash-es */ \"../../../node_modules/lodash-es/isEqual.js\");\n/* harmony import */ var lodash_es__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! lodash-es */ \"../../../node_modules/lodash-es/merge.js\");\n/* harmony import */ var _helpers_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./helpers.js */ \"../../framework/esm-extensions/dist/helpers.js\");\n/* harmony import */ var _store_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./store.js */ \"../../framework/esm-extensions/dist/store.js\");\n/** @module @category Extension */ /*\n * We have the following extension modes:\n *\n * - attached (set via code in form of: attach, detach, ...)\n * - configured (set via configuration in form of: added, removed, ...)\n * - assigned (computed from attached and configured)\n * - connected (computed from assigned using connectivity and online / offline)\n */ \n\n\n\n\n\n\n\n\nconst extensionInternalStore = (0,_store_js__WEBPACK_IMPORTED_MODULE_5__.getExtensionInternalStore)();\nconst extensionStore = (0,_store_js__WEBPACK_IMPORTED_MODULE_5__.getExtensionStore)();\nconst slotsConfigStore = (0,_openmrs_esm_config__WEBPACK_IMPORTED_MODULE_1__.getExtensionSlotsConfigStore)();\nconst extensionsConfigStore = (0,_openmrs_esm_config__WEBPACK_IMPORTED_MODULE_1__.getExtensionsConfigStore)();\n// Keep the output store updated\nfunction updateExtensionOutputStore(internalState, extensionSlotConfigs, extensionsConfigStore, featureFlagStore, sessionStore) {\n const slots = {};\n const isOnline = (0,_openmrs_esm_utils__WEBPACK_IMPORTED_MODULE_6__.isOnline)();\n const enabledFeatureFlags = Object.entries(featureFlagStore.flags).filter(([, { enabled }])=>enabled).map(([name])=>name);\n for (let [slotName, slot] of Object.entries(internalState.slots)){\n const { config } = (0,_openmrs_esm_config__WEBPACK_IMPORTED_MODULE_1__.getExtensionSlotConfigFromStore)(extensionSlotConfigs, slot.name);\n const assignedExtensions = getAssignedExtensionsFromSlotData(slotName, internalState, config, extensionsConfigStore, enabledFeatureFlags, isOnline, sessionStore.session);\n slots[slotName] = {\n moduleName: slot.moduleName,\n assignedExtensions\n };\n }\n if (!(0,lodash_es__WEBPACK_IMPORTED_MODULE_7__[\"default\"])(extensionStore.getState().slots, slots)) {\n extensionStore.setState({\n slots\n });\n }\n}\nextensionInternalStore.subscribe((internalStore)=>{\n updateExtensionOutputStore(internalStore, slotsConfigStore.getState(), extensionsConfigStore.getState(), _openmrs_esm_feature_flags__WEBPACK_IMPORTED_MODULE_2__.featureFlagsStore.getState(), _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.sessionStore.getState());\n});\nslotsConfigStore.subscribe((slotConfigs)=>{\n updateExtensionOutputStore(extensionInternalStore.getState(), slotConfigs, extensionsConfigStore.getState(), _openmrs_esm_feature_flags__WEBPACK_IMPORTED_MODULE_2__.featureFlagsStore.getState(), _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.sessionStore.getState());\n});\nextensionsConfigStore.subscribe((extensionConfigs)=>{\n updateExtensionOutputStore(extensionInternalStore.getState(), slotsConfigStore.getState(), extensionConfigs, _openmrs_esm_feature_flags__WEBPACK_IMPORTED_MODULE_2__.featureFlagsStore.getState(), _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.sessionStore.getState());\n});\n_openmrs_esm_feature_flags__WEBPACK_IMPORTED_MODULE_2__.featureFlagsStore.subscribe((featureFlagStore)=>{\n updateExtensionOutputStore(extensionInternalStore.getState(), slotsConfigStore.getState(), extensionsConfigStore.getState(), featureFlagStore, _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.sessionStore.getState());\n});\n_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.sessionStore.subscribe((session)=>{\n updateExtensionOutputStore(extensionInternalStore.getState(), slotsConfigStore.getState(), extensionsConfigStore.getState(), _openmrs_esm_feature_flags__WEBPACK_IMPORTED_MODULE_2__.featureFlagsStore.getState(), session);\n});\nfunction updateOutputStoreToCurrent() {\n updateExtensionOutputStore(extensionInternalStore.getState(), slotsConfigStore.getState(), extensionsConfigStore.getState(), _openmrs_esm_feature_flags__WEBPACK_IMPORTED_MODULE_2__.featureFlagsStore.getState(), _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.sessionStore.getState());\n}\nupdateOutputStoreToCurrent();\n(0,_openmrs_esm_globals__WEBPACK_IMPORTED_MODULE_3__.subscribeConnectivityChanged)(updateOutputStoreToCurrent);\nfunction createNewExtensionSlotInfo(slotName, moduleName, state) {\n return {\n moduleName,\n name: slotName,\n attachedIds: [],\n config: null,\n state\n };\n}\n/**\n * Given an extension ID, which is a string uniquely identifying\n * an instance of an extension within an extension slot, this\n * returns the extension name.\n *\n * @example\n * ```js\n * getExtensionNameFromId(\"foo#bar\")\n * --> \"foo\"\n * getExtensionNameFromId(\"baz\")\n * --> \"baz\"\n * ```\n */ function getExtensionNameFromId(extensionId) {\n const [extensionName] = extensionId.split('#');\n return extensionName;\n}\nfunction getExtensionRegistrationFrom(state, extensionId) {\n const name = getExtensionNameFromId(extensionId);\n return state.extensions[name];\n}\nfunction getExtensionRegistration(extensionId) {\n const state = extensionInternalStore.getState();\n return getExtensionRegistrationFrom(state, extensionId);\n}\n/**\n * Extensions must be registered in order to be rendered.\n * This is handled by the app shell, when extensions are provided\n * via the `routes.json` file and registered through `registerApp()`.\n * @internal\n */ const registerExtension = (extensionRegistration)=>extensionInternalStore.setState((state)=>{\n state.extensions[extensionRegistration.name] = {\n ...extensionRegistration,\n instances: []\n };\n return state;\n });\n/**\n * Attach an extension to an extension slot.\n *\n * This will cause the extension to be rendered into the specified\n * extension slot, unless it is removed by configuration. Using\n * `attach` is an alternative to specifying the `slot` or `slots`\n * in the extension declaration.\n *\n * It is particularly useful when creating a slot into which\n * you want to render an existing extension. This enables you\n * to do so without modifying the extension's declaration, which\n * may be impractical or inappropriate, for example if you are\n * writing a module for a specific implementation.\n *\n * @param slotName a name uniquely identifying the slot\n * @param extensionId an extension name, with an optional #-suffix\n * to distinguish it from other instances of the same extension\n * attached to the same slot.\n */ function attach(slotName, extensionId) {\n (0,_store_js__WEBPACK_IMPORTED_MODULE_5__.updateInternalExtensionStore)((state)=>{\n const existingSlot = state.slots[slotName];\n if (!existingSlot) {\n return {\n ...state,\n slots: {\n ...state.slots,\n [slotName]: {\n ...createNewExtensionSlotInfo(slotName),\n attachedIds: [\n extensionId\n ]\n }\n }\n };\n } else {\n return {\n ...state,\n slots: {\n ...state.slots,\n [slotName]: {\n ...existingSlot,\n attachedIds: [\n ...existingSlot.attachedIds,\n extensionId\n ]\n }\n }\n };\n }\n });\n}\n/**\n * Detaches an extension from an extension slot.\n *\n * @param extensionSlotName The name of the extension slot to detach from.\n * @param extensionId The ID of the extension to detach.\n *\n * @deprecated Avoid using this. Extension attachments should be considered declarative.\n */ function detach(extensionSlotName, extensionId) {\n (0,_store_js__WEBPACK_IMPORTED_MODULE_5__.updateInternalExtensionStore)((state)=>{\n const existingSlot = state.slots[extensionSlotName];\n if (existingSlot && existingSlot.attachedIds.includes(extensionId)) {\n return {\n ...state,\n slots: {\n ...state.slots,\n [extensionSlotName]: {\n ...existingSlot,\n attachedIds: existingSlot.attachedIds.filter((id)=>id !== extensionId)\n }\n }\n };\n } else {\n return state;\n }\n });\n}\n/**\n * Detaches all extensions from an extension slot.\n *\n * @param extensionSlotName The name of the extension slot to clear.\n *\n * @deprecated Avoid using this. Extension attachments should be considered declarative.\n */ function detachAll(extensionSlotName) {\n (0,_store_js__WEBPACK_IMPORTED_MODULE_5__.updateInternalExtensionStore)((state)=>{\n const existingSlot = state.slots[extensionSlotName];\n if (existingSlot) {\n return {\n ...state,\n slots: {\n ...state.slots,\n [extensionSlotName]: {\n ...existingSlot,\n attachedIds: []\n }\n }\n };\n } else {\n return state;\n }\n });\n}\n/**\n * Get an order index for the extension. This will\n * come from either its configured order, its registered order\n * parameter, or the order in which it happened to be attached.\n */ function getOrder(extensionId, configuredOrder, registeredOrderIndex, attachedOrder) {\n const configuredIndex = configuredOrder.indexOf(extensionId);\n if (configuredIndex !== -1) {\n return configuredIndex;\n } else if (registeredOrderIndex !== undefined) {\n // extensions that don't have a configured order should appear after those that do\n return 1000 + registeredOrderIndex;\n } else {\n const assignedIndex = attachedOrder.indexOf(extensionId);\n if (assignedIndex !== -1) {\n // extensions that have neither a configured nor registered order should appear\n // after all others\n return 2000 + assignedIndex;\n } else {\n return -1;\n }\n }\n}\nfunction getAssignedExtensionsFromSlotData(slotName, internalState, config, extensionConfigStoreState, enabledFeatureFlags, isOnline, session) {\n const attachedIds = internalState.slots[slotName].attachedIds;\n const assignedIds = calculateAssignedIds(config, attachedIds);\n const extensions = [];\n // Create context once for all extensions in this slot\n const slotState = internalState.slots[slotName]?.state;\n const expressionContext = slotState && typeof slotState === 'object' ? {\n session,\n ...slotState\n } : {\n session\n };\n for (let id of assignedIds){\n const { config: rawExtensionConfig } = (0,_openmrs_esm_config__WEBPACK_IMPORTED_MODULE_1__.getExtensionConfigFromStore)(extensionConfigStoreState, slotName, id);\n const rawExtensionSlotExtensionConfig = (0,_openmrs_esm_config__WEBPACK_IMPORTED_MODULE_1__.getExtensionConfigFromExtensionSlotStore)(config, slotName, id);\n const extensionConfig = (0,lodash_es__WEBPACK_IMPORTED_MODULE_8__[\"default\"])(rawExtensionConfig, rawExtensionSlotExtensionConfig);\n const name = getExtensionNameFromId(id);\n const extension = internalState.extensions[name];\n // if the extension has not been registered yet, do not include it\n if (extension) {\n const requiredPrivileges = extensionConfig?.['Display conditions']?.privileges ?? extension.privileges ?? [];\n if (requiredPrivileges && (typeof requiredPrivileges === 'string' || Array.isArray(requiredPrivileges) && requiredPrivileges.length > 0)) {\n if (!session?.user) {\n continue;\n }\n if (!(0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.userHasAccess)(requiredPrivileges, session.user)) {\n continue;\n }\n }\n const displayConditionExpression = extensionConfig?.['Display conditions']?.expression || extension.displayExpression;\n if (displayConditionExpression !== undefined && typeof displayConditionExpression === 'string' && displayConditionExpression.trim().length > 0) {\n try {\n if (!(0,_openmrs_esm_expression_evaluator__WEBPACK_IMPORTED_MODULE_9__.evaluateAsBoolean)(displayConditionExpression, expressionContext)) {\n continue;\n }\n } catch (e) {\n console.error(`Error while evaluating expression '${displayConditionExpression}' for extension ${name} in slot ${slotName}`, e);\n continue;\n }\n }\n if (extension.featureFlag && !enabledFeatureFlags.includes(extension.featureFlag)) {\n continue;\n }\n if (window.offlineEnabled && !(0,_helpers_js__WEBPACK_IMPORTED_MODULE_4__.checkStatusFor)(isOnline, extension.online, extension.offline)) {\n continue;\n }\n extensions.push({\n id,\n name,\n moduleName: extension.moduleName,\n config: extensionConfig,\n featureFlag: extension.featureFlag,\n meta: extension.meta,\n online: extensionConfig?.['Display conditions']?.online ?? extension.online ?? true,\n offline: extensionConfig?.['Display conditions']?.offline ?? extension.offline ?? false\n });\n }\n }\n return extensions;\n}\n/**\n * Gets the list of extensions assigned to a given slot\n *\n * @param slotName The slot to load the assigned extensions for\n * @returns An array of extensions assigned to the named slot\n */ function getAssignedExtensions(slotName) {\n const internalState = extensionInternalStore.getState();\n const { config: slotConfig } = (0,_openmrs_esm_config__WEBPACK_IMPORTED_MODULE_1__.getExtensionSlotConfig)(slotName);\n const extensionStoreState = extensionsConfigStore.getState();\n const featureFlagState = _openmrs_esm_feature_flags__WEBPACK_IMPORTED_MODULE_2__.featureFlagsStore.getState();\n const sessionState = _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.sessionStore.getState();\n const isOnline = (0,_openmrs_esm_utils__WEBPACK_IMPORTED_MODULE_6__.isOnline)();\n const enabledFeatureFlags = Object.entries(featureFlagState.flags).filter(([, { enabled }])=>enabled).map(([name])=>name);\n return getAssignedExtensionsFromSlotData(slotName, internalState, slotConfig, extensionStoreState, enabledFeatureFlags, isOnline, sessionState.session);\n}\nfunction calculateAssignedIds(config, attachedIds) {\n const addedIds = config.add || [];\n const removedIds = config.remove || [];\n const idOrder = config.order || [];\n const { extensions } = extensionInternalStore.getState();\n return [\n ...attachedIds,\n ...addedIds\n ].filter((id)=>!removedIds.includes(id)).sort((idA, idB)=>{\n const ai = getOrder(idA, idOrder, extensions[getExtensionNameFromId(idA)]?.order, attachedIds);\n const bi = getOrder(idB, idOrder, extensions[getExtensionNameFromId(idB)]?.order, attachedIds);\n if (bi === -1) {\n return -1;\n } else if (ai === -1) {\n return 1;\n } else {\n return ai - bi;\n }\n });\n}\n/**\n * Used by by extension slots at mount time.\n *\n * @param moduleName The name of the module that contains the extension slot\n * @param slotName The extension slot name that is actually used\n * @param state Optional custom state for the slot, which will be stored in the extension store.\n * @internal\n */ const registerExtensionSlot = (moduleName, slotName, state)=>extensionInternalStore.setState((currentState)=>{\n const existingModuleName = currentState.slots[slotName]?.moduleName;\n if (existingModuleName && existingModuleName != moduleName) {\n console.warn(`An extension slot with the name '${slotName}' already exists. Refusing to register the same slot name twice (in \"registerExtensionSlot\"). The existing one is from module ${existingModuleName}.`);\n return currentState;\n }\n if (existingModuleName && existingModuleName == moduleName) {\n // Re-rendering an existing slot\n return currentState;\n }\n if (currentState.slots[slotName]) {\n return {\n ...currentState,\n slots: {\n ...currentState.slots,\n [slotName]: {\n ...currentState.slots[slotName],\n moduleName,\n state\n }\n }\n };\n }\n const slot = createNewExtensionSlotInfo(slotName, moduleName, state);\n return {\n ...currentState,\n slots: {\n ...currentState.slots,\n [slotName]: {\n ...slot\n }\n }\n };\n });\n/**\n * Used by extension slots to update the copy of the state for the extension slot\n *\n * @param slotName The name of the slot with state to update\n * @param state A copy of the new state\n * @param partial Whether this should be applied as a partial\n */ function updateExtensionSlotState(slotName, state, partial = false) {\n extensionInternalStore.setState((currentState)=>{\n const newState = partial ? (0,lodash_es__WEBPACK_IMPORTED_MODULE_8__[\"default\"])(currentState.slots[slotName].state, state) : state;\n return {\n ...currentState,\n slots: {\n ...currentState.slots,\n [slotName]: {\n ...currentState.slots[slotName],\n state: newState\n }\n }\n };\n });\n}\n/**\n * @internal\n * Just for testing.\n */ const reset = ()=>extensionStore.setState(()=>{\n return {\n slots: {},\n extensions: {}\n };\n });\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-extensions/dist/extensions.js","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-extensions/dist/extensions.js?c0e7"],"sourcesContent":["/** @module @category Extension */ /*\n * We have the following extension modes:\n *\n * - attached (set via code in form of: attach, detach, ...)\n * - configured (set via configuration in form of: added, removed, ...)\n * - assigned (computed from attached and configured)\n * - connected (computed from assigned using connectivity and online / offline)\n */ import { sessionStore, userHasAccess } from \"@openmrs/esm-api\";\nimport { getExtensionConfigFromExtensionSlotStore, getExtensionConfigFromStore, getExtensionSlotConfig, getExtensionSlotConfigFromStore, getExtensionSlotsConfigStore, getExtensionsConfigStore } from \"@openmrs/esm-config\";\nimport { evaluateAsBoolean } from \"@openmrs/esm-expression-evaluator\";\nimport { featureFlagsStore } from \"@openmrs/esm-feature-flags\";\nimport { subscribeConnectivityChanged } from \"@openmrs/esm-globals\";\nimport { isOnline as isOnlineFn } from \"@openmrs/esm-utils\";\nimport { isEqual, merge } from \"lodash-es\";\nimport { checkStatusFor } from \"./helpers.js\";\nimport { getExtensionInternalStore, getExtensionStore, updateInternalExtensionStore } from \"./store.js\";\nconst extensionInternalStore = getExtensionInternalStore();\nconst extensionStore = getExtensionStore();\nconst slotsConfigStore = getExtensionSlotsConfigStore();\nconst extensionsConfigStore = getExtensionsConfigStore();\n// Keep the output store updated\nfunction updateExtensionOutputStore(internalState, extensionSlotConfigs, extensionsConfigStore, featureFlagStore, sessionStore) {\n    const slots = {};\n    const isOnline = isOnlineFn();\n    const enabledFeatureFlags = Object.entries(featureFlagStore.flags).filter(([, { enabled }])=>enabled).map(([name])=>name);\n    for (let [slotName, slot] of Object.entries(internalState.slots)){\n        const { config } = getExtensionSlotConfigFromStore(extensionSlotConfigs, slot.name);\n        const assignedExtensions = getAssignedExtensionsFromSlotData(slotName, internalState, config, extensionsConfigStore, enabledFeatureFlags, isOnline, sessionStore.session);\n        slots[slotName] = {\n            moduleName: slot.moduleName,\n            assignedExtensions\n        };\n    }\n    if (!isEqual(extensionStore.getState().slots, slots)) {\n        extensionStore.setState({\n            slots\n        });\n    }\n}\nextensionInternalStore.subscribe((internalStore)=>{\n    updateExtensionOutputStore(internalStore, slotsConfigStore.getState(), extensionsConfigStore.getState(), featureFlagsStore.getState(), sessionStore.getState());\n});\nslotsConfigStore.subscribe((slotConfigs)=>{\n    updateExtensionOutputStore(extensionInternalStore.getState(), slotConfigs, extensionsConfigStore.getState(), featureFlagsStore.getState(), sessionStore.getState());\n});\nextensionsConfigStore.subscribe((extensionConfigs)=>{\n    updateExtensionOutputStore(extensionInternalStore.getState(), slotsConfigStore.getState(), extensionConfigs, featureFlagsStore.getState(), sessionStore.getState());\n});\nfeatureFlagsStore.subscribe((featureFlagStore)=>{\n    updateExtensionOutputStore(extensionInternalStore.getState(), slotsConfigStore.getState(), extensionsConfigStore.getState(), featureFlagStore, sessionStore.getState());\n});\nsessionStore.subscribe((session)=>{\n    updateExtensionOutputStore(extensionInternalStore.getState(), slotsConfigStore.getState(), extensionsConfigStore.getState(), featureFlagsStore.getState(), session);\n});\nfunction updateOutputStoreToCurrent() {\n    updateExtensionOutputStore(extensionInternalStore.getState(), slotsConfigStore.getState(), extensionsConfigStore.getState(), featureFlagsStore.getState(), sessionStore.getState());\n}\nupdateOutputStoreToCurrent();\nsubscribeConnectivityChanged(updateOutputStoreToCurrent);\nfunction createNewExtensionSlotInfo(slotName, moduleName, state) {\n    return {\n        moduleName,\n        name: slotName,\n        attachedIds: [],\n        config: null,\n        state\n    };\n}\n/**\n * Given an extension ID, which is a string uniquely identifying\n * an instance of an extension within an extension slot, this\n * returns the extension name.\n *\n * @example\n * ```js\n * getExtensionNameFromId(\"foo#bar\")\n *  --> \"foo\"\n * getExtensionNameFromId(\"baz\")\n *  --> \"baz\"\n * ```\n */ export function getExtensionNameFromId(extensionId) {\n    const [extensionName] = extensionId.split('#');\n    return extensionName;\n}\nexport function getExtensionRegistrationFrom(state, extensionId) {\n    const name = getExtensionNameFromId(extensionId);\n    return state.extensions[name];\n}\nexport function getExtensionRegistration(extensionId) {\n    const state = extensionInternalStore.getState();\n    return getExtensionRegistrationFrom(state, extensionId);\n}\n/**\n * Extensions must be registered in order to be rendered.\n * This is handled by the app shell, when extensions are provided\n * via the `routes.json` file and registered through `registerApp()`.\n * @internal\n */ export const registerExtension = (extensionRegistration)=>extensionInternalStore.setState((state)=>{\n        state.extensions[extensionRegistration.name] = {\n            ...extensionRegistration,\n            instances: []\n        };\n        return state;\n    });\n/**\n * Attach an extension to an extension slot.\n *\n * This will cause the extension to be rendered into the specified\n * extension slot, unless it is removed by configuration. Using\n * `attach` is an alternative to specifying the `slot` or `slots`\n * in the extension declaration.\n *\n * It is particularly useful when creating a slot into which\n * you want to render an existing extension. This enables you\n * to do so without modifying the extension's declaration, which\n * may be impractical or inappropriate, for example if you are\n * writing a module for a specific implementation.\n *\n * @param slotName a name uniquely identifying the slot\n * @param extensionId an extension name, with an optional #-suffix\n *    to distinguish it from other instances of the same extension\n *    attached to the same slot.\n */ export function attach(slotName, extensionId) {\n    updateInternalExtensionStore((state)=>{\n        const existingSlot = state.slots[slotName];\n        if (!existingSlot) {\n            return {\n                ...state,\n                slots: {\n                    ...state.slots,\n                    [slotName]: {\n                        ...createNewExtensionSlotInfo(slotName),\n                        attachedIds: [\n                            extensionId\n                        ]\n                    }\n                }\n            };\n        } else {\n            return {\n                ...state,\n                slots: {\n                    ...state.slots,\n                    [slotName]: {\n                        ...existingSlot,\n                        attachedIds: [\n                            ...existingSlot.attachedIds,\n                            extensionId\n                        ]\n                    }\n                }\n            };\n        }\n    });\n}\n/**\n * Detaches an extension from an extension slot.\n *\n * @param extensionSlotName The name of the extension slot to detach from.\n * @param extensionId The ID of the extension to detach.\n *\n * @deprecated Avoid using this. Extension attachments should be considered declarative.\n */ export function detach(extensionSlotName, extensionId) {\n    updateInternalExtensionStore((state)=>{\n        const existingSlot = state.slots[extensionSlotName];\n        if (existingSlot && existingSlot.attachedIds.includes(extensionId)) {\n            return {\n                ...state,\n                slots: {\n                    ...state.slots,\n                    [extensionSlotName]: {\n                        ...existingSlot,\n                        attachedIds: existingSlot.attachedIds.filter((id)=>id !== extensionId)\n                    }\n                }\n            };\n        } else {\n            return state;\n        }\n    });\n}\n/**\n * Detaches all extensions from an extension slot.\n *\n * @param extensionSlotName The name of the extension slot to clear.\n *\n * @deprecated Avoid using this. Extension attachments should be considered declarative.\n */ export function detachAll(extensionSlotName) {\n    updateInternalExtensionStore((state)=>{\n        const existingSlot = state.slots[extensionSlotName];\n        if (existingSlot) {\n            return {\n                ...state,\n                slots: {\n                    ...state.slots,\n                    [extensionSlotName]: {\n                        ...existingSlot,\n                        attachedIds: []\n                    }\n                }\n            };\n        } else {\n            return state;\n        }\n    });\n}\n/**\n * Get an order index for the extension. This will\n * come from either its configured order, its registered order\n * parameter, or the order in which it happened to be attached.\n */ function getOrder(extensionId, configuredOrder, registeredOrderIndex, attachedOrder) {\n    const configuredIndex = configuredOrder.indexOf(extensionId);\n    if (configuredIndex !== -1) {\n        return configuredIndex;\n    } else if (registeredOrderIndex !== undefined) {\n        // extensions that don't have a configured order should appear after those that do\n        return 1000 + registeredOrderIndex;\n    } else {\n        const assignedIndex = attachedOrder.indexOf(extensionId);\n        if (assignedIndex !== -1) {\n            // extensions that have neither a configured nor registered order should appear\n            // after all others\n            return 2000 + assignedIndex;\n        } else {\n            return -1;\n        }\n    }\n}\nfunction getAssignedExtensionsFromSlotData(slotName, internalState, config, extensionConfigStoreState, enabledFeatureFlags, isOnline, session) {\n    const attachedIds = internalState.slots[slotName].attachedIds;\n    const assignedIds = calculateAssignedIds(config, attachedIds);\n    const extensions = [];\n    // Create context once for all extensions in this slot\n    const slotState = internalState.slots[slotName]?.state;\n    const expressionContext = slotState && typeof slotState === 'object' ? {\n        session,\n        ...slotState\n    } : {\n        session\n    };\n    for (let id of assignedIds){\n        const { config: rawExtensionConfig } = getExtensionConfigFromStore(extensionConfigStoreState, slotName, id);\n        const rawExtensionSlotExtensionConfig = getExtensionConfigFromExtensionSlotStore(config, slotName, id);\n        const extensionConfig = merge(rawExtensionConfig, rawExtensionSlotExtensionConfig);\n        const name = getExtensionNameFromId(id);\n        const extension = internalState.extensions[name];\n        // if the extension has not been registered yet, do not include it\n        if (extension) {\n            const requiredPrivileges = extensionConfig?.['Display conditions']?.privileges ?? extension.privileges ?? [];\n            if (requiredPrivileges && (typeof requiredPrivileges === 'string' || Array.isArray(requiredPrivileges) && requiredPrivileges.length > 0)) {\n                if (!session?.user) {\n                    continue;\n                }\n                if (!userHasAccess(requiredPrivileges, session.user)) {\n                    continue;\n                }\n            }\n            const displayConditionExpression = extensionConfig?.['Display conditions']?.expression || extension.displayExpression;\n            if (displayConditionExpression !== undefined && typeof displayConditionExpression === 'string' && displayConditionExpression.trim().length > 0) {\n                try {\n                    if (!evaluateAsBoolean(displayConditionExpression, expressionContext)) {\n                        continue;\n                    }\n                } catch (e) {\n                    console.error(`Error while evaluating expression '${displayConditionExpression}' for extension ${name} in slot ${slotName}`, e);\n                    continue;\n                }\n            }\n            if (extension.featureFlag && !enabledFeatureFlags.includes(extension.featureFlag)) {\n                continue;\n            }\n            if (window.offlineEnabled && !checkStatusFor(isOnline, extension.online, extension.offline)) {\n                continue;\n            }\n            extensions.push({\n                id,\n                name,\n                moduleName: extension.moduleName,\n                config: extensionConfig,\n                featureFlag: extension.featureFlag,\n                meta: extension.meta,\n                online: extensionConfig?.['Display conditions']?.online ?? extension.online ?? true,\n                offline: extensionConfig?.['Display conditions']?.offline ?? extension.offline ?? false\n            });\n        }\n    }\n    return extensions;\n}\n/**\n * Gets the list of extensions assigned to a given slot\n *\n * @param slotName The slot to load the assigned extensions for\n * @returns An array of extensions assigned to the named slot\n */ export function getAssignedExtensions(slotName) {\n    const internalState = extensionInternalStore.getState();\n    const { config: slotConfig } = getExtensionSlotConfig(slotName);\n    const extensionStoreState = extensionsConfigStore.getState();\n    const featureFlagState = featureFlagsStore.getState();\n    const sessionState = sessionStore.getState();\n    const isOnline = isOnlineFn();\n    const enabledFeatureFlags = Object.entries(featureFlagState.flags).filter(([, { enabled }])=>enabled).map(([name])=>name);\n    return getAssignedExtensionsFromSlotData(slotName, internalState, slotConfig, extensionStoreState, enabledFeatureFlags, isOnline, sessionState.session);\n}\nfunction calculateAssignedIds(config, attachedIds) {\n    const addedIds = config.add || [];\n    const removedIds = config.remove || [];\n    const idOrder = config.order || [];\n    const { extensions } = extensionInternalStore.getState();\n    return [\n        ...attachedIds,\n        ...addedIds\n    ].filter((id)=>!removedIds.includes(id)).sort((idA, idB)=>{\n        const ai = getOrder(idA, idOrder, extensions[getExtensionNameFromId(idA)]?.order, attachedIds);\n        const bi = getOrder(idB, idOrder, extensions[getExtensionNameFromId(idB)]?.order, attachedIds);\n        if (bi === -1) {\n            return -1;\n        } else if (ai === -1) {\n            return 1;\n        } else {\n            return ai - bi;\n        }\n    });\n}\n/**\n * Used by by extension slots at mount time.\n *\n * @param moduleName The name of the module that contains the extension slot\n * @param slotName The extension slot name that is actually used\n * @param state Optional custom state for the slot, which will be stored in the extension store.\n * @internal\n */ export const registerExtensionSlot = (moduleName, slotName, state)=>extensionInternalStore.setState((currentState)=>{\n        const existingModuleName = currentState.slots[slotName]?.moduleName;\n        if (existingModuleName && existingModuleName != moduleName) {\n            console.warn(`An extension slot with the name '${slotName}' already exists. Refusing to register the same slot name twice (in \"registerExtensionSlot\"). The existing one is from module ${existingModuleName}.`);\n            return currentState;\n        }\n        if (existingModuleName && existingModuleName == moduleName) {\n            // Re-rendering an existing slot\n            return currentState;\n        }\n        if (currentState.slots[slotName]) {\n            return {\n                ...currentState,\n                slots: {\n                    ...currentState.slots,\n                    [slotName]: {\n                        ...currentState.slots[slotName],\n                        moduleName,\n                        state\n                    }\n                }\n            };\n        }\n        const slot = createNewExtensionSlotInfo(slotName, moduleName, state);\n        return {\n            ...currentState,\n            slots: {\n                ...currentState.slots,\n                [slotName]: {\n                    ...slot\n                }\n            }\n        };\n    });\n/**\n * Used by extension slots to update the copy of the state for the extension slot\n *\n * @param slotName The name of the slot with state to update\n * @param state A copy of the new state\n * @param partial Whether this should be applied as a partial\n */ export function updateExtensionSlotState(slotName, state, partial = false) {\n    extensionInternalStore.setState((currentState)=>{\n        const newState = partial ? merge(currentState.slots[slotName].state, state) : state;\n        return {\n            ...currentState,\n            slots: {\n                ...currentState.slots,\n                [slotName]: {\n                    ...currentState.slots[slotName],\n                    state: newState\n                }\n            }\n        };\n    });\n}\n/**\n * @internal\n * Just for testing.\n */ export const reset = ()=>extensionStore.setState(()=>{\n        return {\n            slots: {},\n            extensions: {}\n        };\n    });\n"],"names":["sessionStore","userHasAccess","getExtensionConfigFromExtensionSlotStore","getExtensionConfigFromStore","getExtensionSlotConfig","getExtensionSlotConfigFromStore","getExtensionSlotsConfigStore","getExtensionsConfigStore","evaluateAsBoolean","featureFlagsStore","subscribeConnectivityChanged","isOnline","isOnlineFn","isEqual","merge","checkStatusFor","getExtensionInternalStore","getExtensionStore","updateInternalExtensionStore","extensionInternalStore","extensionStore","slotsConfigStore","extensionsConfigStore","updateExtensionOutputStore","internalState","extensionSlotConfigs","featureFlagStore","slots","enabledFeatureFlags","Object","entries","flags","filter","enabled","map","name","slotName","slot","config","assignedExtensions","getAssignedExtensionsFromSlotData","session","moduleName","getState","setState","subscribe","internalStore","slotConfigs","extensionConfigs","updateOutputStoreToCurrent","createNewExtensionSlotInfo","state","attachedIds","getExtensionNameFromId","extensionId","extensionName","split","getExtensionRegistrationFrom","extensions","getExtensionRegistration","registerExtension","extensionRegistration","instances","attach","existingSlot","detach","extensionSlotName","includes","id","detachAll","getOrder","configuredOrder","registeredOrderIndex","attachedOrder","configuredIndex","indexOf","undefined","assignedIndex","extensionConfigStoreState","assignedIds","calculateAssignedIds","slotState","expressionContext","rawExtensionConfig","rawExtensionSlotExtensionConfig","extensionConfig","extension","requiredPrivileges","privileges","Array","isArray","length","user","displayConditionExpression","expression","displayExpression","trim","e","console","error","featureFlag","window","offlineEnabled","online","offline","push","meta","getAssignedExtensions","slotConfig","extensionStoreState","featureFlagState","sessionState","addedIds","add","removedIds","remove","idOrder","order","sort","idA","idB","ai","bi","registerExtensionSlot","currentState","existingModuleName","warn","updateExtensionSlotState","partial","newState","reset"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-extensions/dist/extensions.js\n");
449
449
 
450
450
  /***/ }),
451
451
 
@@ -545,7 +545,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
545
545
  \***************************************************************/
546
546
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
547
547
 
548
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ cleanupObsoleteFeatureFlags: () => (/* binding */ cleanupObsoleteFeatureFlags),\n/* harmony export */ featureFlagsStore: () => (/* binding */ featureFlagsStore),\n/* harmony export */ getFeatureFlag: () => (/* binding */ getFeatureFlag),\n/* harmony export */ registerFeatureFlag: () => (/* binding */ registerFeatureFlag),\n/* harmony export */ setFeatureFlag: () => (/* binding */ setFeatureFlag),\n/* harmony export */ subscribeToFeatureFlag: () => (/* binding */ subscribeToFeatureFlag)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-state */ \"../../framework/esm-state/dist/index.js\");\n/** @module @category Feature Flags */ \nconst initialFeatureFlags = {\n flags: getFeatureFlagsFromLocalStorage()\n};\n/** @internal */ const featureFlagsStore = (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__.getGlobalStore)('feature-flags', initialFeatureFlags);\nfeatureFlagsStore.subscribe((state)=>{\n for (const [flagName, flag] of Object.entries(state.flags)){\n localStorage.setItem(`openmrs:feature-flag:${flagName}`, flag.enabled.toString());\n localStorage.setItem(`openmrs:feature-flag-meta:${flagName}`, JSON.stringify({\n label: flag.label,\n description: flag.description\n }));\n }\n});\nfunction getFeatureFlagsFromLocalStorage() {\n const flags = {};\n for (const key of Object.keys(localStorage)){\n if (key.startsWith('openmrs:feature-flag:')) {\n const flagName = key.replace('openmrs:feature-flag:', '');\n const meta = JSON.parse(localStorage.getItem(`openmrs:feature-flag-meta:${flagName}`) || '{}');\n flags[flagName] = {\n enabled: localStorage.getItem(key) === 'true',\n ...meta\n };\n }\n }\n return flags;\n}\n/**\n * This function creates a feature flag. Call it in top-level code anywhere. It will\n * not reset whether the flag is enabled or not, so it's safe to call it multiple times.\n * Once a feature flag is created, it will appear with a toggle in the Implementer Tools.\n * It can then be used to turn on or off features in the code.\n *\n * @param flagName A code-friendly name for the flag, which will be used to reference it in code\n * @param label A human-friendly name which will be displayed in the Implementer Tools\n * @param description An explanation of what the flag does, which will be displayed in the Implementer Tools\n */ function registerFeatureFlag(flagName, label, description) {\n featureFlagsStore.setState((state)=>({\n flags: {\n ...state.flags,\n [flagName]: {\n enabled: state.flags[flagName]?.enabled ?? false,\n label,\n description\n }\n }\n }));\n}\n/**\n * This function removes feature flags from local storage that no longer exist in the current state.\n */ function cleanupObsoleteFeatureFlags() {\n const flags = featureFlagsStore.getState().flags;\n Object.keys(localStorage).filter((key)=>key.startsWith('openmrs:feature-flag:')).forEach((key)=>{\n const flagName = key.replace('openmrs:feature-flag:', '');\n if (!flags[flagName]) {\n localStorage.removeItem(key);\n localStorage.removeItem(`openmrs:feature-flag-meta:${flagName}`);\n }\n });\n}\n/** Use this function to access the current value of the feature flag\n *\n * If you are using React, use `useFeatureFlag` instead.\n */ function getFeatureFlag(flagName) {\n return featureFlagsStore.getState().flags[flagName].enabled;\n}\n/** Use this function to subscribe to the value of the feature flag\n *\n * If you are using React, use `useFeatureFlag` instead.\n */ function subscribeToFeatureFlag(flagName, callback) {\n featureFlagsStore.subscribe((state)=>{\n callback(state.flags[flagName].enabled);\n });\n}\n/** @internal for Implementer Tools */ function setFeatureFlag(flagName, value) {\n featureFlagsStore.setState((state)=>({\n flags: {\n ...state.flags,\n [flagName]: {\n ...state.flags[flagName],\n enabled: value\n }\n }\n }));\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-feature-flags/dist/feature-flags.js","mappings":";;;;;;;;;;AAAA,oCAAoC,GAAuD;AAC3F,MAAMC,sBAAsB;IACxBC,OAAOC;AACX;AACA,cAAc,GAAU,MAAMC,oBAAoBJ,kEAAcA,CAAC,iBAAiBC,qBAAqB;AACvGG,kBAAkBC,SAAS,CAAC,CAACC;IACzB,KAAK,MAAM,CAACC,UAAUC,KAAK,IAAIC,OAAOC,OAAO,CAACJ,MAAMJ,KAAK,EAAE;QACvDS,aAAaC,OAAO,CAAC,CAAC,qBAAqB,EAAEL,UAAU,EAAEC,KAAKK,OAAO,CAACC,QAAQ;QAC9EH,aAAaC,OAAO,CAAC,CAAC,0BAA0B,EAAEL,UAAU,EAAEQ,KAAKC,SAAS,CAAC;YACzEC,OAAOT,KAAKS,KAAK;YACjBC,aAAaV,KAAKU,WAAW;QACjC;IACJ;AACJ;AACA,SAASf;IACL,MAAMD,QAAQ,CAAC;IACf,KAAK,MAAMiB,OAAOV,OAAOW,IAAI,CAACT,cAAc;QACxC,IAAIQ,IAAIE,UAAU,CAAC,0BAA0B;YACzC,MAAMd,WAAWY,IAAIG,OAAO,CAAC,yBAAyB;YACtD,MAAMC,OAAOR,KAAKS,KAAK,CAACb,aAAac,OAAO,CAAC,CAAC,0BAA0B,EAAElB,UAAU,KAAK;YACzFL,KAAK,CAACK,SAAS,GAAG;gBACdM,SAASF,aAAac,OAAO,CAACN,SAAS;gBACvC,GAAGI,IAAI;YACX;QACJ;IACJ;IACA,OAAOrB;AACX;AACA;;;;;;;;;CASC,GAAU,SAASwB,oBAAoBnB,QAAQ,EAAEU,KAAK,EAAEC,WAAW;IAChEd,kBAAkBuB,QAAQ,CAAC,CAACrB,QAAS;YAC7BJ,OAAO;gBACH,GAAGI,MAAMJ,KAAK;gBACd,CAACK,SAAS,EAAE;oBACRM,SAASP,MAAMJ,KAAK,CAACK,SAAS,EAAEM,WAAW;oBAC3CI;oBACAC;gBACJ;YACJ;QACJ;AACR;AACA;;CAEC,GAAU,SAASU;IAChB,MAAM1B,QAAQE,kBAAkByB,QAAQ,GAAG3B,KAAK;IAChDO,OAAOW,IAAI,CAACT,cAAcmB,MAAM,CAAC,CAACX,MAAMA,IAAIE,UAAU,CAAC,0BAA0BU,OAAO,CAAC,CAACZ;QACtF,MAAMZ,WAAWY,IAAIG,OAAO,CAAC,yBAAyB;QACtD,IAAI,CAACpB,KAAK,CAACK,SAAS,EAAE;YAClBI,aAAaqB,UAAU,CAACb;YACxBR,aAAaqB,UAAU,CAAC,CAAC,0BAA0B,EAAEzB,UAAU;QACnE;IACJ;AACJ;AACA;;;CAGC,GAAU,SAAS0B,eAAe1B,QAAQ;IACvC,OAAOH,kBAAkByB,QAAQ,GAAG3B,KAAK,CAACK,SAAS,CAACM,OAAO;AAC/D;AACA;;;CAGC,GAAU,SAASqB,uBAAuB3B,QAAQ,EAAE4B,QAAQ;IACzD/B,kBAAkBC,SAAS,CAAC,CAACC;QACzB6B,SAAS7B,MAAMJ,KAAK,CAACK,SAAS,CAACM,OAAO;IAC1C;AACJ;AACA,oCAAoC,GAAU,SAASuB,eAAe7B,QAAQ,EAAE8B,KAAK;IACjFjC,kBAAkBuB,QAAQ,CAAC,CAACrB,QAAS;YAC7BJ,OAAO;gBACH,GAAGI,MAAMJ,KAAK;gBACd,CAACK,SAAS,EAAE;oBACR,GAAGD,MAAMJ,KAAK,CAACK,SAAS;oBACxBM,SAASwB;gBACb;YACJ;QACJ;AACR","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-feature-flags/dist/feature-flags.js?7117"],"sourcesContent":["/** @module @category Feature Flags */ import { getGlobalStore } from \"@openmrs/esm-state\";\nconst initialFeatureFlags = {\n    flags: getFeatureFlagsFromLocalStorage()\n};\n/** @internal */ export const featureFlagsStore = getGlobalStore('feature-flags', initialFeatureFlags);\nfeatureFlagsStore.subscribe((state)=>{\n    for (const [flagName, flag] of Object.entries(state.flags)){\n        localStorage.setItem(`openmrs:feature-flag:${flagName}`, flag.enabled.toString());\n        localStorage.setItem(`openmrs:feature-flag-meta:${flagName}`, JSON.stringify({\n            label: flag.label,\n            description: flag.description\n        }));\n    }\n});\nfunction getFeatureFlagsFromLocalStorage() {\n    const flags = {};\n    for (const key of Object.keys(localStorage)){\n        if (key.startsWith('openmrs:feature-flag:')) {\n            const flagName = key.replace('openmrs:feature-flag:', '');\n            const meta = JSON.parse(localStorage.getItem(`openmrs:feature-flag-meta:${flagName}`) || '{}');\n            flags[flagName] = {\n                enabled: localStorage.getItem(key) === 'true',\n                ...meta\n            };\n        }\n    }\n    return flags;\n}\n/**\n * This function creates a feature flag. Call it in top-level code anywhere. It will\n * not reset whether the flag is enabled or not, so it's safe to call it multiple times.\n * Once a feature flag is created, it will appear with a toggle in the Implementer Tools.\n * It can then be used to turn on or off features in the code.\n *\n * @param flagName A code-friendly name for the flag, which will be used to reference it in code\n * @param label A human-friendly name which will be displayed in the Implementer Tools\n * @param description An explanation of what the flag does, which will be displayed in the Implementer Tools\n */ export function registerFeatureFlag(flagName, label, description) {\n    featureFlagsStore.setState((state)=>({\n            flags: {\n                ...state.flags,\n                [flagName]: {\n                    enabled: state.flags[flagName]?.enabled ?? false,\n                    label,\n                    description\n                }\n            }\n        }));\n}\n/**\n * This function removes feature flags from local storage that no longer exist in the current state.\n */ export function cleanupObsoleteFeatureFlags() {\n    const flags = featureFlagsStore.getState().flags;\n    Object.keys(localStorage).filter((key)=>key.startsWith('openmrs:feature-flag:')).forEach((key)=>{\n        const flagName = key.replace('openmrs:feature-flag:', '');\n        if (!flags[flagName]) {\n            localStorage.removeItem(key);\n            localStorage.removeItem(`openmrs:feature-flag-meta:${flagName}`);\n        }\n    });\n}\n/** Use this function to access the current value of the feature flag\n *\n * If you are using React, use `useFeatureFlag` instead.\n */ export function getFeatureFlag(flagName) {\n    return featureFlagsStore.getState().flags[flagName].enabled;\n}\n/** Use this function to subscribe to the value of the feature flag\n *\n * If you are using React, use `useFeatureFlag` instead.\n */ export function subscribeToFeatureFlag(flagName, callback) {\n    featureFlagsStore.subscribe((state)=>{\n        callback(state.flags[flagName].enabled);\n    });\n}\n/** @internal for Implementer Tools */ export function setFeatureFlag(flagName, value) {\n    featureFlagsStore.setState((state)=>({\n            flags: {\n                ...state.flags,\n                [flagName]: {\n                    ...state.flags[flagName],\n                    enabled: value\n                }\n            }\n        }));\n}\n"],"names":["getGlobalStore","initialFeatureFlags","flags","getFeatureFlagsFromLocalStorage","featureFlagsStore","subscribe","state","flagName","flag","Object","entries","localStorage","setItem","enabled","toString","JSON","stringify","label","description","key","keys","startsWith","replace","meta","parse","getItem","registerFeatureFlag","setState","cleanupObsoleteFeatureFlags","getState","filter","forEach","removeItem","getFeatureFlag","subscribeToFeatureFlag","callback","setFeatureFlag","value"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-feature-flags/dist/feature-flags.js\n");
548
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ cleanupObsoleteFeatureFlags: () => (/* binding */ cleanupObsoleteFeatureFlags),\n/* harmony export */ featureFlagsStore: () => (/* binding */ featureFlagsStore),\n/* harmony export */ getFeatureFlag: () => (/* binding */ getFeatureFlag),\n/* harmony export */ registerFeatureFlag: () => (/* binding */ registerFeatureFlag),\n/* harmony export */ setFeatureFlag: () => (/* binding */ setFeatureFlag),\n/* harmony export */ subscribeToFeatureFlag: () => (/* binding */ subscribeToFeatureFlag)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-state */ \"../../framework/esm-state/dist/index.js\");\n/** @module @category Feature Flags */ \nconst initialFeatureFlags = {\n flags: getFeatureFlagsFromLocalStorage()\n};\n/** @internal */ const featureFlagsStore = (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_0__.getGlobalStore)('feature-flags', initialFeatureFlags);\nfeatureFlagsStore.subscribe((state)=>{\n for (const [flagName, flag] of Object.entries(state.flags)){\n localStorage.setItem(`openmrs:feature-flag:${flagName}`, flag.enabled.toString());\n localStorage.setItem(`openmrs:feature-flag-meta:${flagName}`, JSON.stringify({\n label: flag.label,\n description: flag.description\n }));\n }\n});\nfunction getFeatureFlagsFromLocalStorage() {\n const flags = {};\n for (const key of Object.keys(localStorage)){\n if (key.startsWith('openmrs:feature-flag:')) {\n const flagName = key.replace('openmrs:feature-flag:', '');\n const meta = JSON.parse(localStorage.getItem(`openmrs:feature-flag-meta:${flagName}`) || '{}');\n flags[flagName] = {\n enabled: localStorage.getItem(key) === 'true',\n ...meta\n };\n }\n }\n return flags;\n}\n/**\n * This function creates a feature flag. Call it in top-level code anywhere. It will\n * not reset whether the flag is enabled or not, so it's safe to call it multiple times.\n * Once a feature flag is created, it will appear with a toggle in the Implementer Tools.\n * It can then be used to turn on or off features in the code.\n *\n * @param flagName A code-friendly name for the flag, which will be used to reference it in code\n * @param label A human-friendly name which will be displayed in the Implementer Tools\n * @param description An explanation of what the flag does, which will be displayed in the Implementer Tools\n */ function registerFeatureFlag(flagName, label, description) {\n featureFlagsStore.setState((state)=>({\n flags: {\n ...state.flags,\n [flagName]: {\n enabled: state.flags[flagName]?.enabled ?? false,\n label,\n description\n }\n }\n }));\n}\n/**\n * This function removes feature flags from local storage that no longer exist in the current state.\n */ function cleanupObsoleteFeatureFlags() {\n const flags = featureFlagsStore.getState().flags;\n Object.keys(localStorage).filter((key)=>key.startsWith('openmrs:feature-flag:')).forEach((key)=>{\n const flagName = key.replace('openmrs:feature-flag:', '');\n if (!flags[flagName]) {\n localStorage.removeItem(key);\n localStorage.removeItem(`openmrs:feature-flag-meta:${flagName}`);\n }\n });\n}\n/**\n * Use this function to access the current value of the feature flag.\n *\n * If you are using React, use `useFeatureFlag` instead.\n *\n * @param flagName The name of the feature flag to check.\n * @returns `true` if the feature flag is enabled, `false` otherwise.\n */ function getFeatureFlag(flagName) {\n return featureFlagsStore.getState().flags[flagName].enabled;\n}\n/**\n * Use this function to subscribe to the value of the feature flag.\n * The callback will be invoked immediately with the current value and\n * again whenever the flag value changes.\n *\n * If you are using React, use `useFeatureFlag` instead.\n *\n * @param flagName The name of the feature flag to subscribe to.\n * @param callback A function that will be called with the current flag value.\n */ function subscribeToFeatureFlag(flagName, callback) {\n featureFlagsStore.subscribe((state)=>{\n callback(state.flags[flagName].enabled);\n });\n}\n/** @internal for Implementer Tools */ function setFeatureFlag(flagName, value) {\n featureFlagsStore.setState((state)=>({\n flags: {\n ...state.flags,\n [flagName]: {\n ...state.flags[flagName],\n enabled: value\n }\n }\n }));\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-feature-flags/dist/feature-flags.js","mappings":";;;;;;;;;;AAAA,oCAAoC,GAAuD;AAC3F,MAAMC,sBAAsB;IACxBC,OAAOC;AACX;AACA,cAAc,GAAU,MAAMC,oBAAoBJ,kEAAcA,CAAC,iBAAiBC,qBAAqB;AACvGG,kBAAkBC,SAAS,CAAC,CAACC;IACzB,KAAK,MAAM,CAACC,UAAUC,KAAK,IAAIC,OAAOC,OAAO,CAACJ,MAAMJ,KAAK,EAAE;QACvDS,aAAaC,OAAO,CAAC,CAAC,qBAAqB,EAAEL,UAAU,EAAEC,KAAKK,OAAO,CAACC,QAAQ;QAC9EH,aAAaC,OAAO,CAAC,CAAC,0BAA0B,EAAEL,UAAU,EAAEQ,KAAKC,SAAS,CAAC;YACzEC,OAAOT,KAAKS,KAAK;YACjBC,aAAaV,KAAKU,WAAW;QACjC;IACJ;AACJ;AACA,SAASf;IACL,MAAMD,QAAQ,CAAC;IACf,KAAK,MAAMiB,OAAOV,OAAOW,IAAI,CAACT,cAAc;QACxC,IAAIQ,IAAIE,UAAU,CAAC,0BAA0B;YACzC,MAAMd,WAAWY,IAAIG,OAAO,CAAC,yBAAyB;YACtD,MAAMC,OAAOR,KAAKS,KAAK,CAACb,aAAac,OAAO,CAAC,CAAC,0BAA0B,EAAElB,UAAU,KAAK;YACzFL,KAAK,CAACK,SAAS,GAAG;gBACdM,SAASF,aAAac,OAAO,CAACN,SAAS;gBACvC,GAAGI,IAAI;YACX;QACJ;IACJ;IACA,OAAOrB;AACX;AACA;;;;;;;;;CASC,GAAU,SAASwB,oBAAoBnB,QAAQ,EAAEU,KAAK,EAAEC,WAAW;IAChEd,kBAAkBuB,QAAQ,CAAC,CAACrB,QAAS;YAC7BJ,OAAO;gBACH,GAAGI,MAAMJ,KAAK;gBACd,CAACK,SAAS,EAAE;oBACRM,SAASP,MAAMJ,KAAK,CAACK,SAAS,EAAEM,WAAW;oBAC3CI;oBACAC;gBACJ;YACJ;QACJ;AACR;AACA;;CAEC,GAAU,SAASU;IAChB,MAAM1B,QAAQE,kBAAkByB,QAAQ,GAAG3B,KAAK;IAChDO,OAAOW,IAAI,CAACT,cAAcmB,MAAM,CAAC,CAACX,MAAMA,IAAIE,UAAU,CAAC,0BAA0BU,OAAO,CAAC,CAACZ;QACtF,MAAMZ,WAAWY,IAAIG,OAAO,CAAC,yBAAyB;QACtD,IAAI,CAACpB,KAAK,CAACK,SAAS,EAAE;YAClBI,aAAaqB,UAAU,CAACb;YACxBR,aAAaqB,UAAU,CAAC,CAAC,0BAA0B,EAAEzB,UAAU;QACnE;IACJ;AACJ;AACA;;;;;;;CAOC,GAAU,SAAS0B,eAAe1B,QAAQ;IACvC,OAAOH,kBAAkByB,QAAQ,GAAG3B,KAAK,CAACK,SAAS,CAACM,OAAO;AAC/D;AACA;;;;;;;;;CASC,GAAU,SAASqB,uBAAuB3B,QAAQ,EAAE4B,QAAQ;IACzD/B,kBAAkBC,SAAS,CAAC,CAACC;QACzB6B,SAAS7B,MAAMJ,KAAK,CAACK,SAAS,CAACM,OAAO;IAC1C;AACJ;AACA,oCAAoC,GAAU,SAASuB,eAAe7B,QAAQ,EAAE8B,KAAK;IACjFjC,kBAAkBuB,QAAQ,CAAC,CAACrB,QAAS;YAC7BJ,OAAO;gBACH,GAAGI,MAAMJ,KAAK;gBACd,CAACK,SAAS,EAAE;oBACR,GAAGD,MAAMJ,KAAK,CAACK,SAAS;oBACxBM,SAASwB;gBACb;YACJ;QACJ;AACR","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-feature-flags/dist/feature-flags.js?7117"],"sourcesContent":["/** @module @category Feature Flags */ import { getGlobalStore } from \"@openmrs/esm-state\";\nconst initialFeatureFlags = {\n    flags: getFeatureFlagsFromLocalStorage()\n};\n/** @internal */ export const featureFlagsStore = getGlobalStore('feature-flags', initialFeatureFlags);\nfeatureFlagsStore.subscribe((state)=>{\n    for (const [flagName, flag] of Object.entries(state.flags)){\n        localStorage.setItem(`openmrs:feature-flag:${flagName}`, flag.enabled.toString());\n        localStorage.setItem(`openmrs:feature-flag-meta:${flagName}`, JSON.stringify({\n            label: flag.label,\n            description: flag.description\n        }));\n    }\n});\nfunction getFeatureFlagsFromLocalStorage() {\n    const flags = {};\n    for (const key of Object.keys(localStorage)){\n        if (key.startsWith('openmrs:feature-flag:')) {\n            const flagName = key.replace('openmrs:feature-flag:', '');\n            const meta = JSON.parse(localStorage.getItem(`openmrs:feature-flag-meta:${flagName}`) || '{}');\n            flags[flagName] = {\n                enabled: localStorage.getItem(key) === 'true',\n                ...meta\n            };\n        }\n    }\n    return flags;\n}\n/**\n * This function creates a feature flag. Call it in top-level code anywhere. It will\n * not reset whether the flag is enabled or not, so it's safe to call it multiple times.\n * Once a feature flag is created, it will appear with a toggle in the Implementer Tools.\n * It can then be used to turn on or off features in the code.\n *\n * @param flagName A code-friendly name for the flag, which will be used to reference it in code\n * @param label A human-friendly name which will be displayed in the Implementer Tools\n * @param description An explanation of what the flag does, which will be displayed in the Implementer Tools\n */ export function registerFeatureFlag(flagName, label, description) {\n    featureFlagsStore.setState((state)=>({\n            flags: {\n                ...state.flags,\n                [flagName]: {\n                    enabled: state.flags[flagName]?.enabled ?? false,\n                    label,\n                    description\n                }\n            }\n        }));\n}\n/**\n * This function removes feature flags from local storage that no longer exist in the current state.\n */ export function cleanupObsoleteFeatureFlags() {\n    const flags = featureFlagsStore.getState().flags;\n    Object.keys(localStorage).filter((key)=>key.startsWith('openmrs:feature-flag:')).forEach((key)=>{\n        const flagName = key.replace('openmrs:feature-flag:', '');\n        if (!flags[flagName]) {\n            localStorage.removeItem(key);\n            localStorage.removeItem(`openmrs:feature-flag-meta:${flagName}`);\n        }\n    });\n}\n/**\n * Use this function to access the current value of the feature flag.\n *\n * If you are using React, use `useFeatureFlag` instead.\n *\n * @param flagName The name of the feature flag to check.\n * @returns `true` if the feature flag is enabled, `false` otherwise.\n */ export function getFeatureFlag(flagName) {\n    return featureFlagsStore.getState().flags[flagName].enabled;\n}\n/**\n * Use this function to subscribe to the value of the feature flag.\n * The callback will be invoked immediately with the current value and\n * again whenever the flag value changes.\n *\n * If you are using React, use `useFeatureFlag` instead.\n *\n * @param flagName The name of the feature flag to subscribe to.\n * @param callback A function that will be called with the current flag value.\n */ export function subscribeToFeatureFlag(flagName, callback) {\n    featureFlagsStore.subscribe((state)=>{\n        callback(state.flags[flagName].enabled);\n    });\n}\n/** @internal for Implementer Tools */ export function setFeatureFlag(flagName, value) {\n    featureFlagsStore.setState((state)=>({\n            flags: {\n                ...state.flags,\n                [flagName]: {\n                    ...state.flags[flagName],\n                    enabled: value\n                }\n            }\n        }));\n}\n"],"names":["getGlobalStore","initialFeatureFlags","flags","getFeatureFlagsFromLocalStorage","featureFlagsStore","subscribe","state","flagName","flag","Object","entries","localStorage","setItem","enabled","toString","JSON","stringify","label","description","key","keys","startsWith","replace","meta","parse","getItem","registerFeatureFlag","setState","cleanupObsoleteFeatureFlags","getState","filter","forEach","removeItem","getFeatureFlag","subscribeToFeatureFlag","callback","setFeatureFlag","value"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-feature-flags/dist/feature-flags.js\n");
549
549
 
550
550
  /***/ }),
551
551
 
@@ -635,7 +635,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
635
635
  \****************************************************************************/
636
636
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
637
637
 
638
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ interpolateString: () => (/* binding */ interpolateString),\n/* harmony export */ interpolateUrl: () => (/* binding */ interpolateUrl)\n/* harmony export */ });\n/** @module @category Navigation */ function trimTrailingSlash(str) {\n return str.replace(/\\/$/, '');\n}\n/**\n * Interpolates a string with openmrsBase and openmrsSpaBase.\n *\n * Useful for accepting `${openmrsBase}` or `${openmrsSpaBase}`plus additional template\n * parameters in configurable URLs.\n *\n * Example usage:\n * ```js\n * interpolateUrl(\"test ${openmrsBase} ${openmrsSpaBase} ok\");\n * // will return \"test /openmrs /openmrs/spa ok\"\n *\n * interpolateUrl(\"${openmrsSpaBase}/patient/${patientUuid}\", {\n * patientUuid: \"4fcb7185-c6c9-450f-8828-ccae9436bd82\",\n * }); // will return \"/openmrs/spa/patient/4fcb7185-c6c9-450f-8828-ccae9436bd82\"\n * ```\n *\n * This can be used in conjunction with the `navigate` function like so\n * ```js\n * navigate({\n * to: interpolateUrl(\n * \"${openmrsSpaBase}/patient/${patientUuid}\",\n * { patientUuid: patient.uuid }\n * )\n * }); // will navigate to \"/openmrs/spa/patient/4fcb7185-c6c9-450f-8828-ccae9436bd82\"\n * ```\n *\n * @param template A string to interpolate\n * @param additionalParams Additional values to interpolate into the string template\n */ function interpolateUrl(template, additionalParams) {\n const openmrsSpaBase = trimTrailingSlash(window.getOpenmrsSpaBase());\n return interpolateString(template, {\n openmrsBase: window.openmrsBase,\n openmrsSpaBase: openmrsSpaBase,\n ...additionalParams\n }).replace(/^\\/\\//, '/'); // remove extra initial slash if present\n}\n/**\n * Interpolates values of `params` into the `template` string.\n *\n * Example usage:\n * ```js\n * interpolateString(\"test ${one} ${two} 3\", {\n * one: \"1\",\n * two: \"2\",\n * }); // will return \"test 1 2 3\"\n * interpolateString(\"test ok\", { one: \"1\", two: \"2\" }) // will return \"test ok\"\n * ```\n *\n * @param template With optional params wrapped in `${ }`\n * @param params Values to interpolate into the string template\n */ function interpolateString(template, params) {\n const names = Object.keys(params);\n return names.reduce((prev, curr)=>prev.split('${' + curr + '}').join(params[curr]), template);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1uYXZpZ2F0aW9uL2Rpc3QvbmF2aWdhdGlvbi9pbnRlcnBvbGF0ZS1zdHJpbmcuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxpQ0FBaUMsR0FBRyxTQUFTQSxrQkFBa0JDLEdBQUc7SUFDOUQsT0FBT0EsSUFBSUMsT0FBTyxDQUFDLE9BQU87QUFDOUI7QUFDQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztDQTRCQyxHQUFVLFNBQVNDLGVBQWVDLFFBQVEsRUFBRUMsZ0JBQWdCO0lBQ3pELE1BQU1DLGlCQUFpQk4sa0JBQWtCTyxPQUFPQyxpQkFBaUI7SUFDakUsT0FBT0Msa0JBQWtCTCxVQUFVO1FBQy9CTSxhQUFhSCxPQUFPRyxXQUFXO1FBQy9CSixnQkFBZ0JBO1FBQ2hCLEdBQUdELGdCQUFnQjtJQUN2QixHQUFHSCxPQUFPLENBQUMsU0FBUyxNQUFNLHdDQUF3QztBQUN0RTtBQUNBOzs7Ozs7Ozs7Ozs7OztDQWNDLEdBQVUsU0FBU08sa0JBQWtCTCxRQUFRLEVBQUVPLE1BQU07SUFDbEQsTUFBTUMsUUFBUUMsT0FBT0MsSUFBSSxDQUFDSDtJQUMxQixPQUFPQyxNQUFNRyxNQUFNLENBQUMsQ0FBQ0MsTUFBTUMsT0FBT0QsS0FBS0UsS0FBSyxDQUFDLE9BQU9ELE9BQU8sS0FBS0UsSUFBSSxDQUFDUixNQUFNLENBQUNNLEtBQUssR0FBR2I7QUFDeEYiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tbmF2aWdhdGlvbi9kaXN0L25hdmlnYXRpb24vaW50ZXJwb2xhdGUtc3RyaW5nLmpzP2IwZWEiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBtb2R1bGUgQGNhdGVnb3J5IE5hdmlnYXRpb24gKi8gZnVuY3Rpb24gdHJpbVRyYWlsaW5nU2xhc2goc3RyKSB7XG4gICAgcmV0dXJuIHN0ci5yZXBsYWNlKC9cXC8kLywgJycpO1xufVxuLyoqXG4gKiBJbnRlcnBvbGF0ZXMgYSBzdHJpbmcgd2l0aCBvcGVubXJzQmFzZSBhbmQgb3Blbm1yc1NwYUJhc2UuXG4gKlxuICogVXNlZnVsIGZvciBhY2NlcHRpbmcgYCR7b3Blbm1yc0Jhc2V9YCBvciBgJHtvcGVubXJzU3BhQmFzZX1gcGx1cyBhZGRpdGlvbmFsIHRlbXBsYXRlXG4gKiBwYXJhbWV0ZXJzIGluIGNvbmZpZ3VyYWJsZSBVUkxzLlxuICpcbiAqIEV4YW1wbGUgdXNhZ2U6XG4gKiBgYGBqc1xuICogaW50ZXJwb2xhdGVVcmwoXCJ0ZXN0ICR7b3Blbm1yc0Jhc2V9ICR7b3Blbm1yc1NwYUJhc2V9IG9rXCIpO1xuICogICAgLy8gd2lsbCByZXR1cm4gXCJ0ZXN0IC9vcGVubXJzIC9vcGVubXJzL3NwYSBva1wiXG4gKlxuICogaW50ZXJwb2xhdGVVcmwoXCIke29wZW5tcnNTcGFCYXNlfS9wYXRpZW50LyR7cGF0aWVudFV1aWR9XCIsIHtcbiAqICAgIHBhdGllbnRVdWlkOiBcIjRmY2I3MTg1LWM2YzktNDUwZi04ODI4LWNjYWU5NDM2YmQ4MlwiLFxuICogfSk7IC8vIHdpbGwgcmV0dXJuIFwiL29wZW5tcnMvc3BhL3BhdGllbnQvNGZjYjcxODUtYzZjOS00NTBmLTg4MjgtY2NhZTk0MzZiZDgyXCJcbiAqIGBgYFxuICpcbiAqIFRoaXMgY2FuIGJlIHVzZWQgaW4gY29uanVuY3Rpb24gd2l0aCB0aGUgYG5hdmlnYXRlYCBmdW5jdGlvbiBsaWtlIHNvXG4gKiBgYGBqc1xuICogbmF2aWdhdGUoe1xuICogIHRvOiBpbnRlcnBvbGF0ZVVybChcbiAqICAgIFwiJHtvcGVubXJzU3BhQmFzZX0vcGF0aWVudC8ke3BhdGllbnRVdWlkfVwiLFxuICogICAgeyBwYXRpZW50VXVpZDogcGF0aWVudC51dWlkIH1cbiAqICApXG4gKiB9KTsgLy8gd2lsbCBuYXZpZ2F0ZSB0byBcIi9vcGVubXJzL3NwYS9wYXRpZW50LzRmY2I3MTg1LWM2YzktNDUwZi04ODI4LWNjYWU5NDM2YmQ4MlwiXG4gKiBgYGBcbiAqXG4gKiBAcGFyYW0gdGVtcGxhdGUgQSBzdHJpbmcgdG8gaW50ZXJwb2xhdGVcbiAqIEBwYXJhbSBhZGRpdGlvbmFsUGFyYW1zIEFkZGl0aW9uYWwgdmFsdWVzIHRvIGludGVycG9sYXRlIGludG8gdGhlIHN0cmluZyB0ZW1wbGF0ZVxuICovIGV4cG9ydCBmdW5jdGlvbiBpbnRlcnBvbGF0ZVVybCh0ZW1wbGF0ZSwgYWRkaXRpb25hbFBhcmFtcykge1xuICAgIGNvbnN0IG9wZW5tcnNTcGFCYXNlID0gdHJpbVRyYWlsaW5nU2xhc2god2luZG93LmdldE9wZW5tcnNTcGFCYXNlKCkpO1xuICAgIHJldHVybiBpbnRlcnBvbGF0ZVN0cmluZyh0ZW1wbGF0ZSwge1xuICAgICAgICBvcGVubXJzQmFzZTogd2luZG93Lm9wZW5tcnNCYXNlLFxuICAgICAgICBvcGVubXJzU3BhQmFzZTogb3Blbm1yc1NwYUJhc2UsXG4gICAgICAgIC4uLmFkZGl0aW9uYWxQYXJhbXNcbiAgICB9KS5yZXBsYWNlKC9eXFwvXFwvLywgJy8nKTsgLy8gcmVtb3ZlIGV4dHJhIGluaXRpYWwgc2xhc2ggaWYgcHJlc2VudFxufVxuLyoqXG4gKiBJbnRlcnBvbGF0ZXMgdmFsdWVzIG9mIGBwYXJhbXNgIGludG8gdGhlIGB0ZW1wbGF0ZWAgc3RyaW5nLlxuICpcbiAqIEV4YW1wbGUgdXNhZ2U6XG4gKiBgYGBqc1xuICogaW50ZXJwb2xhdGVTdHJpbmcoXCJ0ZXN0ICR7b25lfSAke3R3b30gM1wiLCB7XG4gKiAgICBvbmU6IFwiMVwiLFxuICogICAgdHdvOiBcIjJcIixcbiAqIH0pOyAvLyB3aWxsIHJldHVybiBcInRlc3QgMSAyIDNcIlxuICogaW50ZXJwb2xhdGVTdHJpbmcoXCJ0ZXN0IG9rXCIsIHsgb25lOiBcIjFcIiwgdHdvOiBcIjJcIiB9KSAvLyB3aWxsIHJldHVybiBcInRlc3Qgb2tcIlxuICogYGBgXG4gKlxuICogQHBhcmFtIHRlbXBsYXRlIFdpdGggb3B0aW9uYWwgcGFyYW1zIHdyYXBwZWQgaW4gYCR7IH1gXG4gKiBAcGFyYW0gcGFyYW1zIFZhbHVlcyB0byBpbnRlcnBvbGF0ZSBpbnRvIHRoZSBzdHJpbmcgdGVtcGxhdGVcbiAqLyBleHBvcnQgZnVuY3Rpb24gaW50ZXJwb2xhdGVTdHJpbmcodGVtcGxhdGUsIHBhcmFtcykge1xuICAgIGNvbnN0IG5hbWVzID0gT2JqZWN0LmtleXMocGFyYW1zKTtcbiAgICByZXR1cm4gbmFtZXMucmVkdWNlKChwcmV2LCBjdXJyKT0+cHJldi5zcGxpdCgnJHsnICsgY3VyciArICd9Jykuam9pbihwYXJhbXNbY3Vycl0pLCB0ZW1wbGF0ZSk7XG59XG4iXSwibmFtZXMiOlsidHJpbVRyYWlsaW5nU2xhc2giLCJzdHIiLCJyZXBsYWNlIiwiaW50ZXJwb2xhdGVVcmwiLCJ0ZW1wbGF0ZSIsImFkZGl0aW9uYWxQYXJhbXMiLCJvcGVubXJzU3BhQmFzZSIsIndpbmRvdyIsImdldE9wZW5tcnNTcGFCYXNlIiwiaW50ZXJwb2xhdGVTdHJpbmciLCJvcGVubXJzQmFzZSIsInBhcmFtcyIsIm5hbWVzIiwiT2JqZWN0Iiwia2V5cyIsInJlZHVjZSIsInByZXYiLCJjdXJyIiwic3BsaXQiLCJqb2luIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///../../framework/esm-navigation/dist/navigation/interpolate-string.js\n");
638
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ interpolateString: () => (/* binding */ interpolateString),\n/* harmony export */ interpolateUrl: () => (/* binding */ interpolateUrl)\n/* harmony export */ });\n/** @module @category Navigation */ function trimTrailingSlash(str) {\n return str.replace(/\\/$/, '');\n}\n/**\n * Interpolates a string with openmrsBase and openmrsSpaBase.\n *\n * Useful for accepting `${openmrsBase}` or `${openmrsSpaBase}`plus additional template\n * parameters in configurable URLs.\n *\n * Example usage:\n * ```js\n * interpolateUrl(\"test ${openmrsBase} ${openmrsSpaBase} ok\");\n * // will return \"test /openmrs /openmrs/spa ok\"\n *\n * interpolateUrl(\"${openmrsSpaBase}/patient/${patientUuid}\", {\n * patientUuid: \"4fcb7185-c6c9-450f-8828-ccae9436bd82\",\n * }); // will return \"/openmrs/spa/patient/4fcb7185-c6c9-450f-8828-ccae9436bd82\"\n * ```\n *\n * This can be used in conjunction with the `navigate` function like so\n * ```js\n * navigate({\n * to: interpolateUrl(\n * \"${openmrsSpaBase}/patient/${patientUuid}\",\n * { patientUuid: patient.uuid }\n * )\n * }); // will navigate to \"/openmrs/spa/patient/4fcb7185-c6c9-450f-8828-ccae9436bd82\"\n * ```\n *\n * @param template A string to interpolate\n * @param additionalParams Additional values to interpolate into the string template\n * @returns The interpolated string with all template parameters replaced.\n */ function interpolateUrl(template, additionalParams) {\n const openmrsSpaBase = trimTrailingSlash(window.getOpenmrsSpaBase());\n return interpolateString(template, {\n openmrsBase: window.openmrsBase,\n openmrsSpaBase: openmrsSpaBase,\n ...additionalParams\n }).replace(/^\\/\\//, '/'); // remove extra initial slash if present\n}\n/**\n * Interpolates values of `params` into the `template` string.\n *\n * Example usage:\n * ```js\n * interpolateString(\"test ${one} ${two} 3\", {\n * one: \"1\",\n * two: \"2\",\n * }); // will return \"test 1 2 3\"\n * interpolateString(\"test ok\", { one: \"1\", two: \"2\" }) // will return \"test ok\"\n * ```\n *\n * @param template With optional params wrapped in `${ }`\n * @param params Values to interpolate into the string template\n * @returns The template string with all parameter placeholders replaced by their values.\n */ function interpolateString(template, params) {\n const names = Object.keys(params);\n return names.reduce((prev, curr)=>prev.split('${' + curr + '}').join(params[curr]), template);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1uYXZpZ2F0aW9uL2Rpc3QvbmF2aWdhdGlvbi9pbnRlcnBvbGF0ZS1zdHJpbmcuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxpQ0FBaUMsR0FBRyxTQUFTQSxrQkFBa0JDLEdBQUc7SUFDOUQsT0FBT0EsSUFBSUMsT0FBTyxDQUFDLE9BQU87QUFDOUI7QUFDQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Q0E2QkMsR0FBVSxTQUFTQyxlQUFlQyxRQUFRLEVBQUVDLGdCQUFnQjtJQUN6RCxNQUFNQyxpQkFBaUJOLGtCQUFrQk8sT0FBT0MsaUJBQWlCO0lBQ2pFLE9BQU9DLGtCQUFrQkwsVUFBVTtRQUMvQk0sYUFBYUgsT0FBT0csV0FBVztRQUMvQkosZ0JBQWdCQTtRQUNoQixHQUFHRCxnQkFBZ0I7SUFDdkIsR0FBR0gsT0FBTyxDQUFDLFNBQVMsTUFBTSx3Q0FBd0M7QUFDdEU7QUFDQTs7Ozs7Ozs7Ozs7Ozs7O0NBZUMsR0FBVSxTQUFTTyxrQkFBa0JMLFFBQVEsRUFBRU8sTUFBTTtJQUNsRCxNQUFNQyxRQUFRQyxPQUFPQyxJQUFJLENBQUNIO0lBQzFCLE9BQU9DLE1BQU1HLE1BQU0sQ0FBQyxDQUFDQyxNQUFNQyxPQUFPRCxLQUFLRSxLQUFLLENBQUMsT0FBT0QsT0FBTyxLQUFLRSxJQUFJLENBQUNSLE1BQU0sQ0FBQ00sS0FBSyxHQUFHYjtBQUN4RiIsInNvdXJjZXMiOlsid2VicGFjazovL0BvcGVubXJzL2VzbS1hcHAtc2hlbGwvLi4vLi4vZnJhbWV3b3JrL2VzbS1uYXZpZ2F0aW9uL2Rpc3QvbmF2aWdhdGlvbi9pbnRlcnBvbGF0ZS1zdHJpbmcuanM/YjBlYSJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQG1vZHVsZSBAY2F0ZWdvcnkgTmF2aWdhdGlvbiAqLyBmdW5jdGlvbiB0cmltVHJhaWxpbmdTbGFzaChzdHIpIHtcbiAgICByZXR1cm4gc3RyLnJlcGxhY2UoL1xcLyQvLCAnJyk7XG59XG4vKipcbiAqIEludGVycG9sYXRlcyBhIHN0cmluZyB3aXRoIG9wZW5tcnNCYXNlIGFuZCBvcGVubXJzU3BhQmFzZS5cbiAqXG4gKiBVc2VmdWwgZm9yIGFjY2VwdGluZyBgJHtvcGVubXJzQmFzZX1gIG9yIGAke29wZW5tcnNTcGFCYXNlfWBwbHVzIGFkZGl0aW9uYWwgdGVtcGxhdGVcbiAqIHBhcmFtZXRlcnMgaW4gY29uZmlndXJhYmxlIFVSTHMuXG4gKlxuICogRXhhbXBsZSB1c2FnZTpcbiAqIGBgYGpzXG4gKiBpbnRlcnBvbGF0ZVVybChcInRlc3QgJHtvcGVubXJzQmFzZX0gJHtvcGVubXJzU3BhQmFzZX0gb2tcIik7XG4gKiAgICAvLyB3aWxsIHJldHVybiBcInRlc3QgL29wZW5tcnMgL29wZW5tcnMvc3BhIG9rXCJcbiAqXG4gKiBpbnRlcnBvbGF0ZVVybChcIiR7b3Blbm1yc1NwYUJhc2V9L3BhdGllbnQvJHtwYXRpZW50VXVpZH1cIiwge1xuICogICAgcGF0aWVudFV1aWQ6IFwiNGZjYjcxODUtYzZjOS00NTBmLTg4MjgtY2NhZTk0MzZiZDgyXCIsXG4gKiB9KTsgLy8gd2lsbCByZXR1cm4gXCIvb3Blbm1ycy9zcGEvcGF0aWVudC80ZmNiNzE4NS1jNmM5LTQ1MGYtODgyOC1jY2FlOTQzNmJkODJcIlxuICogYGBgXG4gKlxuICogVGhpcyBjYW4gYmUgdXNlZCBpbiBjb25qdW5jdGlvbiB3aXRoIHRoZSBgbmF2aWdhdGVgIGZ1bmN0aW9uIGxpa2Ugc29cbiAqIGBgYGpzXG4gKiBuYXZpZ2F0ZSh7XG4gKiAgdG86IGludGVycG9sYXRlVXJsKFxuICogICAgXCIke29wZW5tcnNTcGFCYXNlfS9wYXRpZW50LyR7cGF0aWVudFV1aWR9XCIsXG4gKiAgICB7IHBhdGllbnRVdWlkOiBwYXRpZW50LnV1aWQgfVxuICogIClcbiAqIH0pOyAvLyB3aWxsIG5hdmlnYXRlIHRvIFwiL29wZW5tcnMvc3BhL3BhdGllbnQvNGZjYjcxODUtYzZjOS00NTBmLTg4MjgtY2NhZTk0MzZiZDgyXCJcbiAqIGBgYFxuICpcbiAqIEBwYXJhbSB0ZW1wbGF0ZSBBIHN0cmluZyB0byBpbnRlcnBvbGF0ZVxuICogQHBhcmFtIGFkZGl0aW9uYWxQYXJhbXMgQWRkaXRpb25hbCB2YWx1ZXMgdG8gaW50ZXJwb2xhdGUgaW50byB0aGUgc3RyaW5nIHRlbXBsYXRlXG4gKiBAcmV0dXJucyBUaGUgaW50ZXJwb2xhdGVkIHN0cmluZyB3aXRoIGFsbCB0ZW1wbGF0ZSBwYXJhbWV0ZXJzIHJlcGxhY2VkLlxuICovIGV4cG9ydCBmdW5jdGlvbiBpbnRlcnBvbGF0ZVVybCh0ZW1wbGF0ZSwgYWRkaXRpb25hbFBhcmFtcykge1xuICAgIGNvbnN0IG9wZW5tcnNTcGFCYXNlID0gdHJpbVRyYWlsaW5nU2xhc2god2luZG93LmdldE9wZW5tcnNTcGFCYXNlKCkpO1xuICAgIHJldHVybiBpbnRlcnBvbGF0ZVN0cmluZyh0ZW1wbGF0ZSwge1xuICAgICAgICBvcGVubXJzQmFzZTogd2luZG93Lm9wZW5tcnNCYXNlLFxuICAgICAgICBvcGVubXJzU3BhQmFzZTogb3Blbm1yc1NwYUJhc2UsXG4gICAgICAgIC4uLmFkZGl0aW9uYWxQYXJhbXNcbiAgICB9KS5yZXBsYWNlKC9eXFwvXFwvLywgJy8nKTsgLy8gcmVtb3ZlIGV4dHJhIGluaXRpYWwgc2xhc2ggaWYgcHJlc2VudFxufVxuLyoqXG4gKiBJbnRlcnBvbGF0ZXMgdmFsdWVzIG9mIGBwYXJhbXNgIGludG8gdGhlIGB0ZW1wbGF0ZWAgc3RyaW5nLlxuICpcbiAqIEV4YW1wbGUgdXNhZ2U6XG4gKiBgYGBqc1xuICogaW50ZXJwb2xhdGVTdHJpbmcoXCJ0ZXN0ICR7b25lfSAke3R3b30gM1wiLCB7XG4gKiAgICBvbmU6IFwiMVwiLFxuICogICAgdHdvOiBcIjJcIixcbiAqIH0pOyAvLyB3aWxsIHJldHVybiBcInRlc3QgMSAyIDNcIlxuICogaW50ZXJwb2xhdGVTdHJpbmcoXCJ0ZXN0IG9rXCIsIHsgb25lOiBcIjFcIiwgdHdvOiBcIjJcIiB9KSAvLyB3aWxsIHJldHVybiBcInRlc3Qgb2tcIlxuICogYGBgXG4gKlxuICogQHBhcmFtIHRlbXBsYXRlIFdpdGggb3B0aW9uYWwgcGFyYW1zIHdyYXBwZWQgaW4gYCR7IH1gXG4gKiBAcGFyYW0gcGFyYW1zIFZhbHVlcyB0byBpbnRlcnBvbGF0ZSBpbnRvIHRoZSBzdHJpbmcgdGVtcGxhdGVcbiAqIEByZXR1cm5zIFRoZSB0ZW1wbGF0ZSBzdHJpbmcgd2l0aCBhbGwgcGFyYW1ldGVyIHBsYWNlaG9sZGVycyByZXBsYWNlZCBieSB0aGVpciB2YWx1ZXMuXG4gKi8gZXhwb3J0IGZ1bmN0aW9uIGludGVycG9sYXRlU3RyaW5nKHRlbXBsYXRlLCBwYXJhbXMpIHtcbiAgICBjb25zdCBuYW1lcyA9IE9iamVjdC5rZXlzKHBhcmFtcyk7XG4gICAgcmV0dXJuIG5hbWVzLnJlZHVjZSgocHJldiwgY3Vycik9PnByZXYuc3BsaXQoJyR7JyArIGN1cnIgKyAnfScpLmpvaW4ocGFyYW1zW2N1cnJdKSwgdGVtcGxhdGUpO1xufVxuIl0sIm5hbWVzIjpbInRyaW1UcmFpbGluZ1NsYXNoIiwic3RyIiwicmVwbGFjZSIsImludGVycG9sYXRlVXJsIiwidGVtcGxhdGUiLCJhZGRpdGlvbmFsUGFyYW1zIiwib3Blbm1yc1NwYUJhc2UiLCJ3aW5kb3ciLCJnZXRPcGVubXJzU3BhQmFzZSIsImludGVycG9sYXRlU3RyaW5nIiwib3Blbm1yc0Jhc2UiLCJwYXJhbXMiLCJuYW1lcyIsIk9iamVjdCIsImtleXMiLCJyZWR1Y2UiLCJwcmV2IiwiY3VyciIsInNwbGl0Iiwiam9pbiJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///../../framework/esm-navigation/dist/navigation/interpolate-string.js\n");
639
639
 
640
640
  /***/ }),
641
641
 
@@ -775,7 +775,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
775
775
  \****************************************************************/
776
776
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
777
777
 
778
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ ConfigurableLink: () => (/* binding */ ConfigurableLink)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var _openmrs_esm_navigation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-navigation */ \"../../framework/esm-navigation/dist/index.js\");\n/** @module @category Navigation */ \n\nfunction handleClick(event, to, templateParams, onBeforeNavigate) {\n // Left click without modifiers (normal navigation)\n if (event.button === 0 && !event.ctrlKey && !event.shiftKey && !event.altKey && !event.metaKey) {\n event.preventDefault();\n onBeforeNavigate?.(event);\n (0,_openmrs_esm_navigation__WEBPACK_IMPORTED_MODULE_1__.navigate)({\n to,\n templateParams\n });\n }\n // Left click with Ctrl key (or Cmd key on Mac) - Open in new tab\n if (event.button === 0 && (event.ctrlKey || event.metaKey)) {\n onBeforeNavigate?.(event);\n }\n // Left click with Shift key - Open in new window\n if (event.button === 0 && event.shiftKey) {\n onBeforeNavigate?.(event);\n }\n // Middle click - Open in new background tab\n if (event.button === 1) {\n onBeforeNavigate?.(event);\n }\n}\n/**\n * A React link component which calls [[navigate]] when clicked\n */ function ConfigurableLink({ to, templateParams, onBeforeNavigate, children, ...otherProps }) {\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(()=>{\n if (otherProps.href) {\n console.warn(`ConfigurableLink does not support the href prop. Use the 'to' prop instead. The provided href value is '${otherProps.href}'`);\n }\n if (otherProps.onClick) {\n console.warn(`ConfigurableLink does not support the onClick prop. Use the 'onBeforeNavigate' prop instead. The 'to' prop of the offending link is ${to}`);\n }\n }, []);\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(\"a\", {\n onClick: (event)=>handleClick(event, to, templateParams, onBeforeNavigate),\n href: (0,_openmrs_esm_navigation__WEBPACK_IMPORTED_MODULE_1__.interpolateUrl)(to, templateParams),\n ...otherProps\n }, children);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L0NvbmZpZ3VyYWJsZUxpbmsuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsaUNBQWlDLEdBQTRDO0FBQ1Y7QUFDbkUsU0FBU0ksWUFBWUMsS0FBSyxFQUFFQyxFQUFFLEVBQUVDLGNBQWMsRUFBRUMsZ0JBQWdCO0lBQzVELG1EQUFtRDtJQUNuRCxJQUFJSCxNQUFNSSxNQUFNLEtBQUssS0FBSyxDQUFDSixNQUFNSyxPQUFPLElBQUksQ0FBQ0wsTUFBTU0sUUFBUSxJQUFJLENBQUNOLE1BQU1PLE1BQU0sSUFBSSxDQUFDUCxNQUFNUSxPQUFPLEVBQUU7UUFDNUZSLE1BQU1TLGNBQWM7UUFDcEJOLG1CQUFtQkg7UUFDbkJILGlFQUFRQSxDQUFDO1lBQ0xJO1lBQ0FDO1FBQ0o7SUFDSjtJQUNBLGlFQUFpRTtJQUNqRSxJQUFJRixNQUFNSSxNQUFNLEtBQUssS0FBTUosQ0FBQUEsTUFBTUssT0FBTyxJQUFJTCxNQUFNUSxPQUFPLEdBQUc7UUFDeERMLG1CQUFtQkg7SUFDdkI7SUFDQSxpREFBaUQ7SUFDakQsSUFBSUEsTUFBTUksTUFBTSxLQUFLLEtBQUtKLE1BQU1NLFFBQVEsRUFBRTtRQUN0Q0gsbUJBQW1CSDtJQUN2QjtJQUNBLDRDQUE0QztJQUM1QyxJQUFJQSxNQUFNSSxNQUFNLEtBQUssR0FBRztRQUNwQkQsbUJBQW1CSDtJQUN2QjtBQUNKO0FBQ0E7O0NBRUMsR0FBVSxTQUFTVSxpQkFBaUIsRUFBRVQsRUFBRSxFQUFFQyxjQUFjLEVBQUVDLGdCQUFnQixFQUFFUSxRQUFRLEVBQUUsR0FBR0MsWUFBWTtJQUNsR2hCLGdEQUFTQSxDQUFDO1FBQ04sSUFBSWdCLFdBQVdDLElBQUksRUFBRTtZQUNqQkMsUUFBUUMsSUFBSSxDQUFDLENBQUMsd0dBQXdHLEVBQUVILFdBQVdDLElBQUksQ0FBQyxDQUFDLENBQUM7UUFDOUk7UUFDQSxJQUFJRCxXQUFXSSxPQUFPLEVBQUU7WUFDcEJGLFFBQVFDLElBQUksQ0FBQyxDQUFDLG9JQUFvSSxFQUFFZCxJQUFJO1FBQzVKO0lBQ0osR0FBRyxFQUFFO0lBQ0wsT0FBTyxXQUFXLEdBQUdOLGdEQUFtQixDQUFDLEtBQUs7UUFDMUNxQixTQUFTLENBQUNoQixRQUFRRCxZQUFZQyxPQUFPQyxJQUFJQyxnQkFBZ0JDO1FBQ3pEVSxNQUFNZix1RUFBY0EsQ0FBQ0csSUFBSUM7UUFDekIsR0FBR1UsVUFBVTtJQUNqQixHQUFHRDtBQUNQIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQG9wZW5tcnMvZXNtLWFwcC1zaGVsbC8uLi8uLi9mcmFtZXdvcmsvZXNtLXJlYWN0LXV0aWxzL2Rpc3QvQ29uZmlndXJhYmxlTGluay5qcz8wMDNiIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBAbW9kdWxlIEBjYXRlZ29yeSBOYXZpZ2F0aW9uICovIGltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7IG5hdmlnYXRlLCBpbnRlcnBvbGF0ZVVybCB9IGZyb20gXCJAb3Blbm1ycy9lc20tbmF2aWdhdGlvblwiO1xuZnVuY3Rpb24gaGFuZGxlQ2xpY2soZXZlbnQsIHRvLCB0ZW1wbGF0ZVBhcmFtcywgb25CZWZvcmVOYXZpZ2F0ZSkge1xuICAgIC8vIExlZnQgY2xpY2sgd2l0aG91dCBtb2RpZmllcnMgKG5vcm1hbCBuYXZpZ2F0aW9uKVxuICAgIGlmIChldmVudC5idXR0b24gPT09IDAgJiYgIWV2ZW50LmN0cmxLZXkgJiYgIWV2ZW50LnNoaWZ0S2V5ICYmICFldmVudC5hbHRLZXkgJiYgIWV2ZW50Lm1ldGFLZXkpIHtcbiAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgb25CZWZvcmVOYXZpZ2F0ZT8uKGV2ZW50KTtcbiAgICAgICAgbmF2aWdhdGUoe1xuICAgICAgICAgICAgdG8sXG4gICAgICAgICAgICB0ZW1wbGF0ZVBhcmFtc1xuICAgICAgICB9KTtcbiAgICB9XG4gICAgLy8gTGVmdCBjbGljayB3aXRoIEN0cmwga2V5IChvciBDbWQga2V5IG9uIE1hYykgLSBPcGVuIGluIG5ldyB0YWJcbiAgICBpZiAoZXZlbnQuYnV0dG9uID09PSAwICYmIChldmVudC5jdHJsS2V5IHx8IGV2ZW50Lm1ldGFLZXkpKSB7XG4gICAgICAgIG9uQmVmb3JlTmF2aWdhdGU/LihldmVudCk7XG4gICAgfVxuICAgIC8vIExlZnQgY2xpY2sgd2l0aCBTaGlmdCBrZXkgLSBPcGVuIGluIG5ldyB3aW5kb3dcbiAgICBpZiAoZXZlbnQuYnV0dG9uID09PSAwICYmIGV2ZW50LnNoaWZ0S2V5KSB7XG4gICAgICAgIG9uQmVmb3JlTmF2aWdhdGU/LihldmVudCk7XG4gICAgfVxuICAgIC8vIE1pZGRsZSBjbGljayAtIE9wZW4gaW4gbmV3IGJhY2tncm91bmQgdGFiXG4gICAgaWYgKGV2ZW50LmJ1dHRvbiA9PT0gMSkge1xuICAgICAgICBvbkJlZm9yZU5hdmlnYXRlPy4oZXZlbnQpO1xuICAgIH1cbn1cbi8qKlxuICogQSBSZWFjdCBsaW5rIGNvbXBvbmVudCB3aGljaCBjYWxscyBbW25hdmlnYXRlXV0gd2hlbiBjbGlja2VkXG4gKi8gZXhwb3J0IGZ1bmN0aW9uIENvbmZpZ3VyYWJsZUxpbmsoeyB0bywgdGVtcGxhdGVQYXJhbXMsIG9uQmVmb3JlTmF2aWdhdGUsIGNoaWxkcmVuLCAuLi5vdGhlclByb3BzIH0pIHtcbiAgICB1c2VFZmZlY3QoKCk9PntcbiAgICAgICAgaWYgKG90aGVyUHJvcHMuaHJlZikge1xuICAgICAgICAgICAgY29uc29sZS53YXJuKGBDb25maWd1cmFibGVMaW5rIGRvZXMgbm90IHN1cHBvcnQgdGhlIGhyZWYgcHJvcC4gVXNlIHRoZSAndG8nIHByb3AgaW5zdGVhZC4gVGhlIHByb3ZpZGVkIGhyZWYgdmFsdWUgaXMgJyR7b3RoZXJQcm9wcy5ocmVmfSdgKTtcbiAgICAgICAgfVxuICAgICAgICBpZiAob3RoZXJQcm9wcy5vbkNsaWNrKSB7XG4gICAgICAgICAgICBjb25zb2xlLndhcm4oYENvbmZpZ3VyYWJsZUxpbmsgZG9lcyBub3Qgc3VwcG9ydCB0aGUgb25DbGljayBwcm9wLiBVc2UgdGhlICdvbkJlZm9yZU5hdmlnYXRlJyBwcm9wIGluc3RlYWQuIFRoZSAndG8nIHByb3Agb2YgdGhlIG9mZmVuZGluZyBsaW5rIGlzICR7dG99YCk7XG4gICAgICAgIH1cbiAgICB9LCBbXSk7XG4gICAgcmV0dXJuIC8qI19fUFVSRV9fKi8gUmVhY3QuY3JlYXRlRWxlbWVudChcImFcIiwge1xuICAgICAgICBvbkNsaWNrOiAoZXZlbnQpPT5oYW5kbGVDbGljayhldmVudCwgdG8sIHRlbXBsYXRlUGFyYW1zLCBvbkJlZm9yZU5hdmlnYXRlKSxcbiAgICAgICAgaHJlZjogaW50ZXJwb2xhdGVVcmwodG8sIHRlbXBsYXRlUGFyYW1zKSxcbiAgICAgICAgLi4ub3RoZXJQcm9wc1xuICAgIH0sIGNoaWxkcmVuKTtcbn1cbiJdLCJuYW1lcyI6WyJSZWFjdCIsInVzZUVmZmVjdCIsIm5hdmlnYXRlIiwiaW50ZXJwb2xhdGVVcmwiLCJoYW5kbGVDbGljayIsImV2ZW50IiwidG8iLCJ0ZW1wbGF0ZVBhcmFtcyIsIm9uQmVmb3JlTmF2aWdhdGUiLCJidXR0b24iLCJjdHJsS2V5Iiwic2hpZnRLZXkiLCJhbHRLZXkiLCJtZXRhS2V5IiwicHJldmVudERlZmF1bHQiLCJDb25maWd1cmFibGVMaW5rIiwiY2hpbGRyZW4iLCJvdGhlclByb3BzIiwiaHJlZiIsImNvbnNvbGUiLCJ3YXJuIiwib25DbGljayIsImNyZWF0ZUVsZW1lbnQiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/ConfigurableLink.js\n");
778
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ ConfigurableLink: () => (/* binding */ ConfigurableLink)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var _openmrs_esm_navigation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-navigation */ \"../../framework/esm-navigation/dist/index.js\");\n/** @module @category Navigation */ \n\nfunction handleClick(event, to, templateParams, onBeforeNavigate) {\n // Left click without modifiers (normal navigation)\n if (event.button === 0 && !event.ctrlKey && !event.shiftKey && !event.altKey && !event.metaKey) {\n event.preventDefault();\n onBeforeNavigate?.(event);\n (0,_openmrs_esm_navigation__WEBPACK_IMPORTED_MODULE_1__.navigate)({\n to,\n templateParams\n });\n }\n // Left click with Ctrl key (or Cmd key on Mac) - Open in new tab\n if (event.button === 0 && (event.ctrlKey || event.metaKey)) {\n onBeforeNavigate?.(event);\n }\n // Left click with Shift key - Open in new window\n if (event.button === 0 && event.shiftKey) {\n onBeforeNavigate?.(event);\n }\n // Middle click - Open in new background tab\n if (event.button === 1) {\n onBeforeNavigate?.(event);\n }\n}\n/**\n * A React link component which calls {@link navigate} when clicked\n */ function ConfigurableLink({ to, templateParams, onBeforeNavigate, children, ...otherProps }) {\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(()=>{\n if (otherProps.href) {\n console.warn(`ConfigurableLink does not support the href prop. Use the 'to' prop instead. The provided href value is '${otherProps.href}'`);\n }\n if (otherProps.onClick) {\n console.warn(`ConfigurableLink does not support the onClick prop. Use the 'onBeforeNavigate' prop instead. The 'to' prop of the offending link is ${to}`);\n }\n }, []);\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(\"a\", {\n onClick: (event)=>handleClick(event, to, templateParams, onBeforeNavigate),\n href: (0,_openmrs_esm_navigation__WEBPACK_IMPORTED_MODULE_1__.interpolateUrl)(to, templateParams),\n ...otherProps\n }, children);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L0NvbmZpZ3VyYWJsZUxpbmsuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsaUNBQWlDLEdBQTRDO0FBQ1Y7QUFDbkUsU0FBU0ksWUFBWUMsS0FBSyxFQUFFQyxFQUFFLEVBQUVDLGNBQWMsRUFBRUMsZ0JBQWdCO0lBQzVELG1EQUFtRDtJQUNuRCxJQUFJSCxNQUFNSSxNQUFNLEtBQUssS0FBSyxDQUFDSixNQUFNSyxPQUFPLElBQUksQ0FBQ0wsTUFBTU0sUUFBUSxJQUFJLENBQUNOLE1BQU1PLE1BQU0sSUFBSSxDQUFDUCxNQUFNUSxPQUFPLEVBQUU7UUFDNUZSLE1BQU1TLGNBQWM7UUFDcEJOLG1CQUFtQkg7UUFDbkJILGlFQUFRQSxDQUFDO1lBQ0xJO1lBQ0FDO1FBQ0o7SUFDSjtJQUNBLGlFQUFpRTtJQUNqRSxJQUFJRixNQUFNSSxNQUFNLEtBQUssS0FBTUosQ0FBQUEsTUFBTUssT0FBTyxJQUFJTCxNQUFNUSxPQUFPLEdBQUc7UUFDeERMLG1CQUFtQkg7SUFDdkI7SUFDQSxpREFBaUQ7SUFDakQsSUFBSUEsTUFBTUksTUFBTSxLQUFLLEtBQUtKLE1BQU1NLFFBQVEsRUFBRTtRQUN0Q0gsbUJBQW1CSDtJQUN2QjtJQUNBLDRDQUE0QztJQUM1QyxJQUFJQSxNQUFNSSxNQUFNLEtBQUssR0FBRztRQUNwQkQsbUJBQW1CSDtJQUN2QjtBQUNKO0FBQ0E7O0NBRUMsR0FBVSxTQUFTVSxpQkFBaUIsRUFBRVQsRUFBRSxFQUFFQyxjQUFjLEVBQUVDLGdCQUFnQixFQUFFUSxRQUFRLEVBQUUsR0FBR0MsWUFBWTtJQUNsR2hCLGdEQUFTQSxDQUFDO1FBQ04sSUFBSWdCLFdBQVdDLElBQUksRUFBRTtZQUNqQkMsUUFBUUMsSUFBSSxDQUFDLENBQUMsd0dBQXdHLEVBQUVILFdBQVdDLElBQUksQ0FBQyxDQUFDLENBQUM7UUFDOUk7UUFDQSxJQUFJRCxXQUFXSSxPQUFPLEVBQUU7WUFDcEJGLFFBQVFDLElBQUksQ0FBQyxDQUFDLG9JQUFvSSxFQUFFZCxJQUFJO1FBQzVKO0lBQ0osR0FBRyxFQUFFO0lBQ0wsT0FBTyxXQUFXLEdBQUdOLGdEQUFtQixDQUFDLEtBQUs7UUFDMUNxQixTQUFTLENBQUNoQixRQUFRRCxZQUFZQyxPQUFPQyxJQUFJQyxnQkFBZ0JDO1FBQ3pEVSxNQUFNZix1RUFBY0EsQ0FBQ0csSUFBSUM7UUFDekIsR0FBR1UsVUFBVTtJQUNqQixHQUFHRDtBQUNQIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQG9wZW5tcnMvZXNtLWFwcC1zaGVsbC8uLi8uLi9mcmFtZXdvcmsvZXNtLXJlYWN0LXV0aWxzL2Rpc3QvQ29uZmlndXJhYmxlTGluay5qcz8wMDNiIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBAbW9kdWxlIEBjYXRlZ29yeSBOYXZpZ2F0aW9uICovIGltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7IG5hdmlnYXRlLCBpbnRlcnBvbGF0ZVVybCB9IGZyb20gXCJAb3Blbm1ycy9lc20tbmF2aWdhdGlvblwiO1xuZnVuY3Rpb24gaGFuZGxlQ2xpY2soZXZlbnQsIHRvLCB0ZW1wbGF0ZVBhcmFtcywgb25CZWZvcmVOYXZpZ2F0ZSkge1xuICAgIC8vIExlZnQgY2xpY2sgd2l0aG91dCBtb2RpZmllcnMgKG5vcm1hbCBuYXZpZ2F0aW9uKVxuICAgIGlmIChldmVudC5idXR0b24gPT09IDAgJiYgIWV2ZW50LmN0cmxLZXkgJiYgIWV2ZW50LnNoaWZ0S2V5ICYmICFldmVudC5hbHRLZXkgJiYgIWV2ZW50Lm1ldGFLZXkpIHtcbiAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgb25CZWZvcmVOYXZpZ2F0ZT8uKGV2ZW50KTtcbiAgICAgICAgbmF2aWdhdGUoe1xuICAgICAgICAgICAgdG8sXG4gICAgICAgICAgICB0ZW1wbGF0ZVBhcmFtc1xuICAgICAgICB9KTtcbiAgICB9XG4gICAgLy8gTGVmdCBjbGljayB3aXRoIEN0cmwga2V5IChvciBDbWQga2V5IG9uIE1hYykgLSBPcGVuIGluIG5ldyB0YWJcbiAgICBpZiAoZXZlbnQuYnV0dG9uID09PSAwICYmIChldmVudC5jdHJsS2V5IHx8IGV2ZW50Lm1ldGFLZXkpKSB7XG4gICAgICAgIG9uQmVmb3JlTmF2aWdhdGU/LihldmVudCk7XG4gICAgfVxuICAgIC8vIExlZnQgY2xpY2sgd2l0aCBTaGlmdCBrZXkgLSBPcGVuIGluIG5ldyB3aW5kb3dcbiAgICBpZiAoZXZlbnQuYnV0dG9uID09PSAwICYmIGV2ZW50LnNoaWZ0S2V5KSB7XG4gICAgICAgIG9uQmVmb3JlTmF2aWdhdGU/LihldmVudCk7XG4gICAgfVxuICAgIC8vIE1pZGRsZSBjbGljayAtIE9wZW4gaW4gbmV3IGJhY2tncm91bmQgdGFiXG4gICAgaWYgKGV2ZW50LmJ1dHRvbiA9PT0gMSkge1xuICAgICAgICBvbkJlZm9yZU5hdmlnYXRlPy4oZXZlbnQpO1xuICAgIH1cbn1cbi8qKlxuICogQSBSZWFjdCBsaW5rIGNvbXBvbmVudCB3aGljaCBjYWxscyB7QGxpbmsgbmF2aWdhdGV9IHdoZW4gY2xpY2tlZFxuICovIGV4cG9ydCBmdW5jdGlvbiBDb25maWd1cmFibGVMaW5rKHsgdG8sIHRlbXBsYXRlUGFyYW1zLCBvbkJlZm9yZU5hdmlnYXRlLCBjaGlsZHJlbiwgLi4ub3RoZXJQcm9wcyB9KSB7XG4gICAgdXNlRWZmZWN0KCgpPT57XG4gICAgICAgIGlmIChvdGhlclByb3BzLmhyZWYpIHtcbiAgICAgICAgICAgIGNvbnNvbGUud2FybihgQ29uZmlndXJhYmxlTGluayBkb2VzIG5vdCBzdXBwb3J0IHRoZSBocmVmIHByb3AuIFVzZSB0aGUgJ3RvJyBwcm9wIGluc3RlYWQuIFRoZSBwcm92aWRlZCBocmVmIHZhbHVlIGlzICcke290aGVyUHJvcHMuaHJlZn0nYCk7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKG90aGVyUHJvcHMub25DbGljaykge1xuICAgICAgICAgICAgY29uc29sZS53YXJuKGBDb25maWd1cmFibGVMaW5rIGRvZXMgbm90IHN1cHBvcnQgdGhlIG9uQ2xpY2sgcHJvcC4gVXNlIHRoZSAnb25CZWZvcmVOYXZpZ2F0ZScgcHJvcCBpbnN0ZWFkLiBUaGUgJ3RvJyBwcm9wIG9mIHRoZSBvZmZlbmRpbmcgbGluayBpcyAke3RvfWApO1xuICAgICAgICB9XG4gICAgfSwgW10pO1xuICAgIHJldHVybiAvKiNfX1BVUkVfXyovIFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJhXCIsIHtcbiAgICAgICAgb25DbGljazogKGV2ZW50KT0+aGFuZGxlQ2xpY2soZXZlbnQsIHRvLCB0ZW1wbGF0ZVBhcmFtcywgb25CZWZvcmVOYXZpZ2F0ZSksXG4gICAgICAgIGhyZWY6IGludGVycG9sYXRlVXJsKHRvLCB0ZW1wbGF0ZVBhcmFtcyksXG4gICAgICAgIC4uLm90aGVyUHJvcHNcbiAgICB9LCBjaGlsZHJlbik7XG59XG4iXSwibmFtZXMiOlsiUmVhY3QiLCJ1c2VFZmZlY3QiLCJuYXZpZ2F0ZSIsImludGVycG9sYXRlVXJsIiwiaGFuZGxlQ2xpY2siLCJldmVudCIsInRvIiwidGVtcGxhdGVQYXJhbXMiLCJvbkJlZm9yZU5hdmlnYXRlIiwiYnV0dG9uIiwiY3RybEtleSIsInNoaWZ0S2V5IiwiYWx0S2V5IiwibWV0YUtleSIsInByZXZlbnREZWZhdWx0IiwiQ29uZmlndXJhYmxlTGluayIsImNoaWxkcmVuIiwib3RoZXJQcm9wcyIsImhyZWYiLCJjb25zb2xlIiwid2FybiIsIm9uQ2xpY2siLCJjcmVhdGVFbGVtZW50Il0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/ConfigurableLink.js\n");
779
779
 
780
780
  /***/ }),
781
781
 
@@ -835,7 +835,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
835
835
  \************************************************************/
836
836
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
837
837
 
838
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ getAsyncExtensionLifecycle: () => (/* binding */ getAsyncExtensionLifecycle),\n/* harmony export */ getAsyncLifecycle: () => (/* binding */ getAsyncLifecycle),\n/* harmony export */ getLifecycle: () => (/* binding */ getLifecycle),\n/* harmony export */ getSyncLifecycle: () => (/* binding */ getSyncLifecycle)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var react_dom_client__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react-dom/client */ \"../../../node_modules/react-dom/client.js\");\n/* harmony import */ var single_spa_react__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! single-spa-react */ \"../../../node_modules/single-spa-react/lib/esm/single-spa-react.js\");\n/* harmony import */ var _openmrsComponentDecorator_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./openmrsComponentDecorator.js */ \"../../framework/esm-react-utils/dist/openmrsComponentDecorator.js\");\n/** @module @category Framework */ \n\n\n\nfunction getLifecycle(Component, options) {\n return (0,single_spa_react__WEBPACK_IMPORTED_MODULE_2__[\"default\"])({\n React: react__WEBPACK_IMPORTED_MODULE_0__,\n ReactDOMClient: react_dom_client__WEBPACK_IMPORTED_MODULE_1__,\n rootComponent: (0,_openmrsComponentDecorator_js__WEBPACK_IMPORTED_MODULE_3__.openmrsComponentDecorator)(options)(Component)\n });\n}\nfunction getAsyncLifecycle(lazy, options) {\n return ()=>lazy().then(({ default: Component })=>getLifecycle(Component, options));\n}\nfunction getSyncLifecycle(Component, options) {\n return ()=>Promise.resolve(getLifecycle(Component, options));\n}\n/**\n * @deprecated Use getAsyncLifecycle instead.\n */ const getAsyncExtensionLifecycle = getAsyncLifecycle;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L2dldExpZmVjeWNsZS5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUFBLGdDQUFnQyxHQUE2QjtBQUNmO0FBQ0E7QUFDNkI7QUFDcEUsU0FBU0ksYUFBYUMsU0FBUyxFQUFFQyxPQUFPO0lBQzNDLE9BQU9KLDREQUFjQSxDQUFDO1FBQ2xCRixLQUFLQSxvQ0FBQUE7UUFDTEMsY0FBY0EsK0NBQUFBO1FBQ2RNLGVBQWVKLHdGQUF5QkEsQ0FBQ0csU0FBU0Q7SUFDdEQ7QUFDSjtBQUNPLFNBQVNHLGtCQUFrQkMsSUFBSSxFQUFFSCxPQUFPO0lBQzNDLE9BQU8sSUFBSUcsT0FBT0MsSUFBSSxDQUFDLENBQUMsRUFBRUMsU0FBU04sU0FBUyxFQUFFLEdBQUdELGFBQWFDLFdBQVdDO0FBQzdFO0FBQ08sU0FBU00saUJBQWlCUCxTQUFTLEVBQUVDLE9BQU87SUFDL0MsT0FBTyxJQUFJTyxRQUFRQyxPQUFPLENBQUNWLGFBQWFDLFdBQVdDO0FBQ3ZEO0FBQ0E7O0NBRUMsR0FBVSxNQUFNUyw2QkFBNkJQLGtCQUFrQiIsInNvdXJjZXMiOlsid2VicGFjazovL0BvcGVubXJzL2VzbS1hcHAtc2hlbGwvLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L2dldExpZmVjeWNsZS5qcz9mN2NhIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBAbW9kdWxlIEBjYXRlZ29yeSBGcmFtZXdvcmsgKi8gaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0RE9NQ2xpZW50IGZyb20gXCJyZWFjdC1kb20vY2xpZW50XCI7XG5pbXBvcnQgc2luZ2xlU3BhUmVhY3QgZnJvbSBcInNpbmdsZS1zcGEtcmVhY3RcIjtcbmltcG9ydCB7IG9wZW5tcnNDb21wb25lbnREZWNvcmF0b3IgfSBmcm9tIFwiLi9vcGVubXJzQ29tcG9uZW50RGVjb3JhdG9yLmpzXCI7XG5leHBvcnQgZnVuY3Rpb24gZ2V0TGlmZWN5Y2xlKENvbXBvbmVudCwgb3B0aW9ucykge1xuICAgIHJldHVybiBzaW5nbGVTcGFSZWFjdCh7XG4gICAgICAgIFJlYWN0LFxuICAgICAgICBSZWFjdERPTUNsaWVudCxcbiAgICAgICAgcm9vdENvbXBvbmVudDogb3Blbm1yc0NvbXBvbmVudERlY29yYXRvcihvcHRpb25zKShDb21wb25lbnQpXG4gICAgfSk7XG59XG5leHBvcnQgZnVuY3Rpb24gZ2V0QXN5bmNMaWZlY3ljbGUobGF6eSwgb3B0aW9ucykge1xuICAgIHJldHVybiAoKT0+bGF6eSgpLnRoZW4oKHsgZGVmYXVsdDogQ29tcG9uZW50IH0pPT5nZXRMaWZlY3ljbGUoQ29tcG9uZW50LCBvcHRpb25zKSk7XG59XG5leHBvcnQgZnVuY3Rpb24gZ2V0U3luY0xpZmVjeWNsZShDb21wb25lbnQsIG9wdGlvbnMpIHtcbiAgICByZXR1cm4gKCk9PlByb21pc2UucmVzb2x2ZShnZXRMaWZlY3ljbGUoQ29tcG9uZW50LCBvcHRpb25zKSk7XG59XG4vKipcbiAqIEBkZXByZWNhdGVkIFVzZSBnZXRBc3luY0xpZmVjeWNsZSBpbnN0ZWFkLlxuICovIGV4cG9ydCBjb25zdCBnZXRBc3luY0V4dGVuc2lvbkxpZmVjeWNsZSA9IGdldEFzeW5jTGlmZWN5Y2xlO1xuIl0sIm5hbWVzIjpbIlJlYWN0IiwiUmVhY3RET01DbGllbnQiLCJzaW5nbGVTcGFSZWFjdCIsIm9wZW5tcnNDb21wb25lbnREZWNvcmF0b3IiLCJnZXRMaWZlY3ljbGUiLCJDb21wb25lbnQiLCJvcHRpb25zIiwicm9vdENvbXBvbmVudCIsImdldEFzeW5jTGlmZWN5Y2xlIiwibGF6eSIsInRoZW4iLCJkZWZhdWx0IiwiZ2V0U3luY0xpZmVjeWNsZSIsIlByb21pc2UiLCJyZXNvbHZlIiwiZ2V0QXN5bmNFeHRlbnNpb25MaWZlY3ljbGUiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/getLifecycle.js\n");
838
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ getAsyncExtensionLifecycle: () => (/* binding */ getAsyncExtensionLifecycle),\n/* harmony export */ getAsyncLifecycle: () => (/* binding */ getAsyncLifecycle),\n/* harmony export */ getLifecycle: () => (/* binding */ getLifecycle),\n/* harmony export */ getSyncLifecycle: () => (/* binding */ getSyncLifecycle)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var react_dom_client__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react-dom/client */ \"../../../node_modules/react-dom/client.js\");\n/* harmony import */ var single_spa_react__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! single-spa-react */ \"../../../node_modules/single-spa-react/lib/esm/single-spa-react.js\");\n/* harmony import */ var _openmrsComponentDecorator_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./openmrsComponentDecorator.js */ \"../../framework/esm-react-utils/dist/openmrsComponentDecorator.js\");\n/** @module @category Framework */ \n\n\n\n/**\n * Creates a single-spa lifecycle object for a React component. The component is\n * wrapped with the OpenMRS component decorator which provides standard functionality\n * like error boundaries, configuration, and extension support.\n *\n * @param Component The React component to create a lifecycle for.\n * @param options Configuration options for the OpenMRS component decorator.\n * @returns A single-spa lifecycle object with bootstrap, mount, and unmount functions.\n *\n * @example\n * ```ts\n * import { getLifecycle } from '@openmrs/esm-framework';\n * import MyComponent from './MyComponent';\n * export const lifecycle = getLifecycle(MyComponent, { featureName: 'my-feature', moduleName: '@openmrs/esm-my-app' });\n * ```\n */ function getLifecycle(Component, options) {\n return (0,single_spa_react__WEBPACK_IMPORTED_MODULE_2__[\"default\"])({\n React: react__WEBPACK_IMPORTED_MODULE_0__,\n ReactDOMClient: react_dom_client__WEBPACK_IMPORTED_MODULE_1__,\n rootComponent: (0,_openmrsComponentDecorator_js__WEBPACK_IMPORTED_MODULE_3__.openmrsComponentDecorator)(options)(Component)\n });\n}\n/**\n * Creates a lazy-loading single-spa lifecycle for a React component. The component\n * is loaded asynchronously via dynamic import only when it's needed, which helps\n * reduce initial bundle size. This is the recommended way to define lifecycles\n * for most modules.\n *\n * @param lazy A function that returns a Promise resolving to a module with the\n * component as its default export (i.e., a dynamic import).\n * @param options Configuration options for the OpenMRS component decorator.\n * @returns A function that returns a Promise resolving to a single-spa lifecycle object.\n *\n * @example\n * ```ts\n * import { getAsyncLifecycle } from '@openmrs/esm-framework';\n * const options = { featureName: 'my-feature', moduleName: '@openmrs/esm-my-app' };\n * export const root = getAsyncLifecycle(() => import('./root.component'), options);\n * ```\n */ function getAsyncLifecycle(lazy, options) {\n return ()=>lazy().then(({ default: Component })=>getLifecycle(Component, options));\n}\n/**\n * Creates a single-spa lifecycle for a React component that is already loaded.\n * Unlike {@link getAsyncLifecycle}, this wraps a synchronously-available component\n * in a Promise to match the expected lifecycle interface. Use this when the\n * component doesn't need lazy loading.\n *\n * @param Component The React component to create a lifecycle for.\n * @param options Configuration options for the OpenMRS component decorator.\n * @returns A function that returns a Promise resolving to a single-spa lifecycle object.\n *\n * @example\n * ```ts\n * import { getSyncLifecycle } from '@openmrs/esm-framework';\n * import MyComponent from './MyComponent';\n * const options = { featureName: 'my-feature', moduleName: '@openmrs/esm-my-app' };\n * export const myExtension = getSyncLifecycle(MyComponent, options);\n * ```\n */ function getSyncLifecycle(Component, options) {\n return ()=>Promise.resolve(getLifecycle(Component, options));\n}\n/**\n * @deprecated Use getAsyncLifecycle instead.\n */ const getAsyncExtensionLifecycle = getAsyncLifecycle;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L2dldExpZmVjeWNsZS5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUFBLGdDQUFnQyxHQUE2QjtBQUNmO0FBQ0E7QUFDNkI7QUFDM0U7Ozs7Ozs7Ozs7Ozs7OztDQWVDLEdBQVUsU0FBU0ksYUFBYUMsU0FBUyxFQUFFQyxPQUFPO0lBQy9DLE9BQU9KLDREQUFjQSxDQUFDO1FBQ2xCRixLQUFLQSxvQ0FBQUE7UUFDTEMsY0FBY0EsK0NBQUFBO1FBQ2RNLGVBQWVKLHdGQUF5QkEsQ0FBQ0csU0FBU0Q7SUFDdEQ7QUFDSjtBQUNBOzs7Ozs7Ozs7Ozs7Ozs7OztDQWlCQyxHQUFVLFNBQVNHLGtCQUFrQkMsSUFBSSxFQUFFSCxPQUFPO0lBQy9DLE9BQU8sSUFBSUcsT0FBT0MsSUFBSSxDQUFDLENBQUMsRUFBRUMsU0FBU04sU0FBUyxFQUFFLEdBQUdELGFBQWFDLFdBQVdDO0FBQzdFO0FBQ0E7Ozs7Ozs7Ozs7Ozs7Ozs7O0NBaUJDLEdBQVUsU0FBU00saUJBQWlCUCxTQUFTLEVBQUVDLE9BQU87SUFDbkQsT0FBTyxJQUFJTyxRQUFRQyxPQUFPLENBQUNWLGFBQWFDLFdBQVdDO0FBQ3ZEO0FBQ0E7O0NBRUMsR0FBVSxNQUFNUyw2QkFBNkJQLGtCQUFrQiIsInNvdXJjZXMiOlsid2VicGFjazovL0BvcGVubXJzL2VzbS1hcHAtc2hlbGwvLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L2dldExpZmVjeWNsZS5qcz9mN2NhIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBAbW9kdWxlIEBjYXRlZ29yeSBGcmFtZXdvcmsgKi8gaW1wb3J0IFJlYWN0IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IFJlYWN0RE9NQ2xpZW50IGZyb20gXCJyZWFjdC1kb20vY2xpZW50XCI7XG5pbXBvcnQgc2luZ2xlU3BhUmVhY3QgZnJvbSBcInNpbmdsZS1zcGEtcmVhY3RcIjtcbmltcG9ydCB7IG9wZW5tcnNDb21wb25lbnREZWNvcmF0b3IgfSBmcm9tIFwiLi9vcGVubXJzQ29tcG9uZW50RGVjb3JhdG9yLmpzXCI7XG4vKipcbiAqIENyZWF0ZXMgYSBzaW5nbGUtc3BhIGxpZmVjeWNsZSBvYmplY3QgZm9yIGEgUmVhY3QgY29tcG9uZW50LiBUaGUgY29tcG9uZW50IGlzXG4gKiB3cmFwcGVkIHdpdGggdGhlIE9wZW5NUlMgY29tcG9uZW50IGRlY29yYXRvciB3aGljaCBwcm92aWRlcyBzdGFuZGFyZCBmdW5jdGlvbmFsaXR5XG4gKiBsaWtlIGVycm9yIGJvdW5kYXJpZXMsIGNvbmZpZ3VyYXRpb24sIGFuZCBleHRlbnNpb24gc3VwcG9ydC5cbiAqXG4gKiBAcGFyYW0gQ29tcG9uZW50IFRoZSBSZWFjdCBjb21wb25lbnQgdG8gY3JlYXRlIGEgbGlmZWN5Y2xlIGZvci5cbiAqIEBwYXJhbSBvcHRpb25zIENvbmZpZ3VyYXRpb24gb3B0aW9ucyBmb3IgdGhlIE9wZW5NUlMgY29tcG9uZW50IGRlY29yYXRvci5cbiAqIEByZXR1cm5zIEEgc2luZ2xlLXNwYSBsaWZlY3ljbGUgb2JqZWN0IHdpdGggYm9vdHN0cmFwLCBtb3VudCwgYW5kIHVubW91bnQgZnVuY3Rpb25zLlxuICpcbiAqIEBleGFtcGxlXG4gKiBgYGB0c1xuICogaW1wb3J0IHsgZ2V0TGlmZWN5Y2xlIH0gZnJvbSAnQG9wZW5tcnMvZXNtLWZyYW1ld29yayc7XG4gKiBpbXBvcnQgTXlDb21wb25lbnQgZnJvbSAnLi9NeUNvbXBvbmVudCc7XG4gKiBleHBvcnQgY29uc3QgbGlmZWN5Y2xlID0gZ2V0TGlmZWN5Y2xlKE15Q29tcG9uZW50LCB7IGZlYXR1cmVOYW1lOiAnbXktZmVhdHVyZScsIG1vZHVsZU5hbWU6ICdAb3Blbm1ycy9lc20tbXktYXBwJyB9KTtcbiAqIGBgYFxuICovIGV4cG9ydCBmdW5jdGlvbiBnZXRMaWZlY3ljbGUoQ29tcG9uZW50LCBvcHRpb25zKSB7XG4gICAgcmV0dXJuIHNpbmdsZVNwYVJlYWN0KHtcbiAgICAgICAgUmVhY3QsXG4gICAgICAgIFJlYWN0RE9NQ2xpZW50LFxuICAgICAgICByb290Q29tcG9uZW50OiBvcGVubXJzQ29tcG9uZW50RGVjb3JhdG9yKG9wdGlvbnMpKENvbXBvbmVudClcbiAgICB9KTtcbn1cbi8qKlxuICogQ3JlYXRlcyBhIGxhenktbG9hZGluZyBzaW5nbGUtc3BhIGxpZmVjeWNsZSBmb3IgYSBSZWFjdCBjb21wb25lbnQuIFRoZSBjb21wb25lbnRcbiAqIGlzIGxvYWRlZCBhc3luY2hyb25vdXNseSB2aWEgZHluYW1pYyBpbXBvcnQgb25seSB3aGVuIGl0J3MgbmVlZGVkLCB3aGljaCBoZWxwc1xuICogcmVkdWNlIGluaXRpYWwgYnVuZGxlIHNpemUuIFRoaXMgaXMgdGhlIHJlY29tbWVuZGVkIHdheSB0byBkZWZpbmUgbGlmZWN5Y2xlc1xuICogZm9yIG1vc3QgbW9kdWxlcy5cbiAqXG4gKiBAcGFyYW0gbGF6eSBBIGZ1bmN0aW9uIHRoYXQgcmV0dXJucyBhIFByb21pc2UgcmVzb2x2aW5nIHRvIGEgbW9kdWxlIHdpdGggdGhlXG4gKiAgIGNvbXBvbmVudCBhcyBpdHMgZGVmYXVsdCBleHBvcnQgKGkuZS4sIGEgZHluYW1pYyBpbXBvcnQpLlxuICogQHBhcmFtIG9wdGlvbnMgQ29uZmlndXJhdGlvbiBvcHRpb25zIGZvciB0aGUgT3Blbk1SUyBjb21wb25lbnQgZGVjb3JhdG9yLlxuICogQHJldHVybnMgQSBmdW5jdGlvbiB0aGF0IHJldHVybnMgYSBQcm9taXNlIHJlc29sdmluZyB0byBhIHNpbmdsZS1zcGEgbGlmZWN5Y2xlIG9iamVjdC5cbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHNcbiAqIGltcG9ydCB7IGdldEFzeW5jTGlmZWN5Y2xlIH0gZnJvbSAnQG9wZW5tcnMvZXNtLWZyYW1ld29yayc7XG4gKiBjb25zdCBvcHRpb25zID0geyBmZWF0dXJlTmFtZTogJ215LWZlYXR1cmUnLCBtb2R1bGVOYW1lOiAnQG9wZW5tcnMvZXNtLW15LWFwcCcgfTtcbiAqIGV4cG9ydCBjb25zdCByb290ID0gZ2V0QXN5bmNMaWZlY3ljbGUoKCkgPT4gaW1wb3J0KCcuL3Jvb3QuY29tcG9uZW50JyksIG9wdGlvbnMpO1xuICogYGBgXG4gKi8gZXhwb3J0IGZ1bmN0aW9uIGdldEFzeW5jTGlmZWN5Y2xlKGxhenksIG9wdGlvbnMpIHtcbiAgICByZXR1cm4gKCk9PmxhenkoKS50aGVuKCh7IGRlZmF1bHQ6IENvbXBvbmVudCB9KT0+Z2V0TGlmZWN5Y2xlKENvbXBvbmVudCwgb3B0aW9ucykpO1xufVxuLyoqXG4gKiBDcmVhdGVzIGEgc2luZ2xlLXNwYSBsaWZlY3ljbGUgZm9yIGEgUmVhY3QgY29tcG9uZW50IHRoYXQgaXMgYWxyZWFkeSBsb2FkZWQuXG4gKiBVbmxpa2Uge0BsaW5rIGdldEFzeW5jTGlmZWN5Y2xlfSwgdGhpcyB3cmFwcyBhIHN5bmNocm9ub3VzbHktYXZhaWxhYmxlIGNvbXBvbmVudFxuICogaW4gYSBQcm9taXNlIHRvIG1hdGNoIHRoZSBleHBlY3RlZCBsaWZlY3ljbGUgaW50ZXJmYWNlLiBVc2UgdGhpcyB3aGVuIHRoZVxuICogY29tcG9uZW50IGRvZXNuJ3QgbmVlZCBsYXp5IGxvYWRpbmcuXG4gKlxuICogQHBhcmFtIENvbXBvbmVudCBUaGUgUmVhY3QgY29tcG9uZW50IHRvIGNyZWF0ZSBhIGxpZmVjeWNsZSBmb3IuXG4gKiBAcGFyYW0gb3B0aW9ucyBDb25maWd1cmF0aW9uIG9wdGlvbnMgZm9yIHRoZSBPcGVuTVJTIGNvbXBvbmVudCBkZWNvcmF0b3IuXG4gKiBAcmV0dXJucyBBIGZ1bmN0aW9uIHRoYXQgcmV0dXJucyBhIFByb21pc2UgcmVzb2x2aW5nIHRvIGEgc2luZ2xlLXNwYSBsaWZlY3ljbGUgb2JqZWN0LlxuICpcbiAqIEBleGFtcGxlXG4gKiBgYGB0c1xuICogaW1wb3J0IHsgZ2V0U3luY0xpZmVjeWNsZSB9IGZyb20gJ0BvcGVubXJzL2VzbS1mcmFtZXdvcmsnO1xuICogaW1wb3J0IE15Q29tcG9uZW50IGZyb20gJy4vTXlDb21wb25lbnQnO1xuICogY29uc3Qgb3B0aW9ucyA9IHsgZmVhdHVyZU5hbWU6ICdteS1mZWF0dXJlJywgbW9kdWxlTmFtZTogJ0BvcGVubXJzL2VzbS1teS1hcHAnIH07XG4gKiBleHBvcnQgY29uc3QgbXlFeHRlbnNpb24gPSBnZXRTeW5jTGlmZWN5Y2xlKE15Q29tcG9uZW50LCBvcHRpb25zKTtcbiAqIGBgYFxuICovIGV4cG9ydCBmdW5jdGlvbiBnZXRTeW5jTGlmZWN5Y2xlKENvbXBvbmVudCwgb3B0aW9ucykge1xuICAgIHJldHVybiAoKT0+UHJvbWlzZS5yZXNvbHZlKGdldExpZmVjeWNsZShDb21wb25lbnQsIG9wdGlvbnMpKTtcbn1cbi8qKlxuICogQGRlcHJlY2F0ZWQgVXNlIGdldEFzeW5jTGlmZWN5Y2xlIGluc3RlYWQuXG4gKi8gZXhwb3J0IGNvbnN0IGdldEFzeW5jRXh0ZW5zaW9uTGlmZWN5Y2xlID0gZ2V0QXN5bmNMaWZlY3ljbGU7XG4iXSwibmFtZXMiOlsiUmVhY3QiLCJSZWFjdERPTUNsaWVudCIsInNpbmdsZVNwYVJlYWN0Iiwib3Blbm1yc0NvbXBvbmVudERlY29yYXRvciIsImdldExpZmVjeWNsZSIsIkNvbXBvbmVudCIsIm9wdGlvbnMiLCJyb290Q29tcG9uZW50IiwiZ2V0QXN5bmNMaWZlY3ljbGUiLCJsYXp5IiwidGhlbiIsImRlZmF1bHQiLCJnZXRTeW5jTGlmZWN5Y2xlIiwiUHJvbWlzZSIsInJlc29sdmUiLCJnZXRBc3luY0V4dGVuc2lvbkxpZmVjeWNsZSJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/getLifecycle.js\n");
839
839
 
840
840
  /***/ }),
841
841
 
@@ -905,7 +905,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
905
905
  \**************************************************************/
906
906
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
907
907
 
908
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ useAttachments: () => (/* binding */ useAttachments)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var swr__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! swr */ \"../../../node_modules/swr/dist/core/index.mjs\");\n/* harmony import */ var _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @openmrs/esm-api */ \"../../framework/esm-api/dist/index.js\");\n/* harmony import */ var _openmrs_esm_emr_api__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @openmrs/esm-emr-api */ \"../../framework/esm-emr-api/dist/index.js\");\n/** @module @category API */ \n\n\n\nfunction useAttachments(patientUuid, includeEncounterless) {\n const { data, error, mutate, isLoading, isValidating } = (0,swr__WEBPACK_IMPORTED_MODULE_1__[\"default\"])(`${_openmrs_esm_emr_api__WEBPACK_IMPORTED_MODULE_3__.attachmentUrl}?patient=${patientUuid}&includeEncounterless=${includeEncounterless}`, _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_2__.openmrsFetch);\n const results = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(()=>({\n isLoading,\n data: data?.data.results ?? [],\n error,\n mutate,\n isValidating\n }), [\n data,\n error,\n isLoading,\n isValidating,\n mutate\n ]);\n return results;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZUF0dGFjaG1lbnRzLmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUEsMEJBQTBCLEdBQW1DO0FBQ3BDO0FBQ3VCO0FBQ0s7QUFDOUMsU0FBU0ksZUFBZUMsV0FBVyxFQUFFQyxvQkFBb0I7SUFDNUQsTUFBTSxFQUFFQyxJQUFJLEVBQUVDLEtBQUssRUFBRUMsTUFBTSxFQUFFQyxTQUFTLEVBQUVDLFlBQVksRUFBRSxHQUFHViwrQ0FBTUEsQ0FBQyxHQUFHRSwrREFBYUEsQ0FBQyxTQUFTLEVBQUVFLFlBQVksc0JBQXNCLEVBQUVDLHNCQUFzQixFQUFFSiwwREFBWUE7SUFDcEssTUFBTVUsVUFBVVosOENBQU9BLENBQUMsSUFBSztZQUNyQlU7WUFDQUgsTUFBTUEsTUFBTUEsS0FBS0ssV0FBVyxFQUFFO1lBQzlCSjtZQUNBQztZQUNBRTtRQUNKLElBQUk7UUFDSko7UUFDQUM7UUFDQUU7UUFDQUM7UUFDQUY7S0FDSDtJQUNELE9BQU9HO0FBQ1giLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tcmVhY3QtdXRpbHMvZGlzdC91c2VBdHRhY2htZW50cy5qcz80OGM0Il0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBAbW9kdWxlIEBjYXRlZ29yeSBBUEkgKi8gaW1wb3J0IHsgdXNlTWVtbyB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHVzZVNXUiBmcm9tIFwic3dyXCI7XG5pbXBvcnQgeyBvcGVubXJzRmV0Y2ggfSBmcm9tIFwiQG9wZW5tcnMvZXNtLWFwaVwiO1xuaW1wb3J0IHsgYXR0YWNobWVudFVybCB9IGZyb20gXCJAb3Blbm1ycy9lc20tZW1yLWFwaVwiO1xuZXhwb3J0IGZ1bmN0aW9uIHVzZUF0dGFjaG1lbnRzKHBhdGllbnRVdWlkLCBpbmNsdWRlRW5jb3VudGVybGVzcykge1xuICAgIGNvbnN0IHsgZGF0YSwgZXJyb3IsIG11dGF0ZSwgaXNMb2FkaW5nLCBpc1ZhbGlkYXRpbmcgfSA9IHVzZVNXUihgJHthdHRhY2htZW50VXJsfT9wYXRpZW50PSR7cGF0aWVudFV1aWR9JmluY2x1ZGVFbmNvdW50ZXJsZXNzPSR7aW5jbHVkZUVuY291bnRlcmxlc3N9YCwgb3Blbm1yc0ZldGNoKTtcbiAgICBjb25zdCByZXN1bHRzID0gdXNlTWVtbygoKT0+KHtcbiAgICAgICAgICAgIGlzTG9hZGluZyxcbiAgICAgICAgICAgIGRhdGE6IGRhdGE/LmRhdGEucmVzdWx0cyA/PyBbXSxcbiAgICAgICAgICAgIGVycm9yLFxuICAgICAgICAgICAgbXV0YXRlLFxuICAgICAgICAgICAgaXNWYWxpZGF0aW5nXG4gICAgICAgIH0pLCBbXG4gICAgICAgIGRhdGEsXG4gICAgICAgIGVycm9yLFxuICAgICAgICBpc0xvYWRpbmcsXG4gICAgICAgIGlzVmFsaWRhdGluZyxcbiAgICAgICAgbXV0YXRlXG4gICAgXSk7XG4gICAgcmV0dXJuIHJlc3VsdHM7XG59XG4iXSwibmFtZXMiOlsidXNlTWVtbyIsInVzZVNXUiIsIm9wZW5tcnNGZXRjaCIsImF0dGFjaG1lbnRVcmwiLCJ1c2VBdHRhY2htZW50cyIsInBhdGllbnRVdWlkIiwiaW5jbHVkZUVuY291bnRlcmxlc3MiLCJkYXRhIiwiZXJyb3IiLCJtdXRhdGUiLCJpc0xvYWRpbmciLCJpc1ZhbGlkYXRpbmciLCJyZXN1bHRzIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/useAttachments.js\n");
908
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ useAttachments: () => (/* binding */ useAttachments)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var swr__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! swr */ \"../../../node_modules/swr/dist/core/index.mjs\");\n/* harmony import */ var _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @openmrs/esm-api */ \"../../framework/esm-api/dist/index.js\");\n/* harmony import */ var _openmrs_esm_emr_api__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @openmrs/esm-emr-api */ \"../../framework/esm-emr-api/dist/index.js\");\n/** @module @category API */ \n\n\n\n/**\n * A React hook that fetches attachments for a patient using SWR for caching\n * and automatic revalidation.\n *\n * @param patientUuid The UUID of the patient whose attachments should be fetched.\n * @param includeEncounterless Whether to include attachments that are not\n * associated with any encounter.\n * @returns An object containing:\n * - `data`: Array of attachment objects (empty array while loading)\n * - `isLoading`: Whether the initial fetch is in progress\n * - `isValidating`: Whether any request (initial or revalidation) is in progress\n * - `error`: Any error that occurred during fetching\n * - `mutate`: Function to trigger a revalidation of the data\n *\n * @example\n * ```tsx\n * import { useAttachments } from '@openmrs/esm-framework';\n * function PatientAttachments({ patientUuid }) {\n * const { data, isLoading, error } = useAttachments(patientUuid, true);\n * if (isLoading) return <span>Loading...</span>;\n * if (error) return <span>Error loading attachments</span>;\n * return <AttachmentList attachments={data} />;\n * }\n * ```\n */ function useAttachments(patientUuid, includeEncounterless) {\n const { data, error, mutate, isLoading, isValidating } = (0,swr__WEBPACK_IMPORTED_MODULE_1__[\"default\"])(`${_openmrs_esm_emr_api__WEBPACK_IMPORTED_MODULE_3__.attachmentUrl}?patient=${patientUuid}&includeEncounterless=${includeEncounterless}`, _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_2__.openmrsFetch);\n const results = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(()=>({\n isLoading,\n data: data?.data.results ?? [],\n error,\n mutate,\n isValidating\n }), [\n data,\n error,\n isLoading,\n isValidating,\n mutate\n ]);\n return results;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZUF0dGFjaG1lbnRzLmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUEsMEJBQTBCLEdBQW1DO0FBQ3BDO0FBQ3VCO0FBQ0s7QUFDckQ7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztDQXdCQyxHQUFVLFNBQVNJLGVBQWVDLFdBQVcsRUFBRUMsb0JBQW9CO0lBQ2hFLE1BQU0sRUFBRUMsSUFBSSxFQUFFQyxLQUFLLEVBQUVDLE1BQU0sRUFBRUMsU0FBUyxFQUFFQyxZQUFZLEVBQUUsR0FBR1YsK0NBQU1BLENBQUMsR0FBR0UsK0RBQWFBLENBQUMsU0FBUyxFQUFFRSxZQUFZLHNCQUFzQixFQUFFQyxzQkFBc0IsRUFBRUosMERBQVlBO0lBQ3BLLE1BQU1VLFVBQVVaLDhDQUFPQSxDQUFDLElBQUs7WUFDckJVO1lBQ0FILE1BQU1BLE1BQU1BLEtBQUtLLFdBQVcsRUFBRTtZQUM5Qko7WUFDQUM7WUFDQUU7UUFDSixJQUFJO1FBQ0pKO1FBQ0FDO1FBQ0FFO1FBQ0FDO1FBQ0FGO0tBQ0g7SUFDRCxPQUFPRztBQUNYIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQG9wZW5tcnMvZXNtLWFwcC1zaGVsbC8uLi8uLi9mcmFtZXdvcmsvZXNtLXJlYWN0LXV0aWxzL2Rpc3QvdXNlQXR0YWNobWVudHMuanM/NDhjNCJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQG1vZHVsZSBAY2F0ZWdvcnkgQVBJICovIGltcG9ydCB7IHVzZU1lbW8gfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB1c2VTV1IgZnJvbSBcInN3clwiO1xuaW1wb3J0IHsgb3Blbm1yc0ZldGNoIH0gZnJvbSBcIkBvcGVubXJzL2VzbS1hcGlcIjtcbmltcG9ydCB7IGF0dGFjaG1lbnRVcmwgfSBmcm9tIFwiQG9wZW5tcnMvZXNtLWVtci1hcGlcIjtcbi8qKlxuICogQSBSZWFjdCBob29rIHRoYXQgZmV0Y2hlcyBhdHRhY2htZW50cyBmb3IgYSBwYXRpZW50IHVzaW5nIFNXUiBmb3IgY2FjaGluZ1xuICogYW5kIGF1dG9tYXRpYyByZXZhbGlkYXRpb24uXG4gKlxuICogQHBhcmFtIHBhdGllbnRVdWlkIFRoZSBVVUlEIG9mIHRoZSBwYXRpZW50IHdob3NlIGF0dGFjaG1lbnRzIHNob3VsZCBiZSBmZXRjaGVkLlxuICogQHBhcmFtIGluY2x1ZGVFbmNvdW50ZXJsZXNzIFdoZXRoZXIgdG8gaW5jbHVkZSBhdHRhY2htZW50cyB0aGF0IGFyZSBub3RcbiAqICAgYXNzb2NpYXRlZCB3aXRoIGFueSBlbmNvdW50ZXIuXG4gKiBAcmV0dXJucyBBbiBvYmplY3QgY29udGFpbmluZzpcbiAqICAgLSBgZGF0YWA6IEFycmF5IG9mIGF0dGFjaG1lbnQgb2JqZWN0cyAoZW1wdHkgYXJyYXkgd2hpbGUgbG9hZGluZylcbiAqICAgLSBgaXNMb2FkaW5nYDogV2hldGhlciB0aGUgaW5pdGlhbCBmZXRjaCBpcyBpbiBwcm9ncmVzc1xuICogICAtIGBpc1ZhbGlkYXRpbmdgOiBXaGV0aGVyIGFueSByZXF1ZXN0IChpbml0aWFsIG9yIHJldmFsaWRhdGlvbikgaXMgaW4gcHJvZ3Jlc3NcbiAqICAgLSBgZXJyb3JgOiBBbnkgZXJyb3IgdGhhdCBvY2N1cnJlZCBkdXJpbmcgZmV0Y2hpbmdcbiAqICAgLSBgbXV0YXRlYDogRnVuY3Rpb24gdG8gdHJpZ2dlciBhIHJldmFsaWRhdGlvbiBvZiB0aGUgZGF0YVxuICpcbiAqIEBleGFtcGxlXG4gKiBgYGB0c3hcbiAqIGltcG9ydCB7IHVzZUF0dGFjaG1lbnRzIH0gZnJvbSAnQG9wZW5tcnMvZXNtLWZyYW1ld29yayc7XG4gKiBmdW5jdGlvbiBQYXRpZW50QXR0YWNobWVudHMoeyBwYXRpZW50VXVpZCB9KSB7XG4gKiAgIGNvbnN0IHsgZGF0YSwgaXNMb2FkaW5nLCBlcnJvciB9ID0gdXNlQXR0YWNobWVudHMocGF0aWVudFV1aWQsIHRydWUpO1xuICogICBpZiAoaXNMb2FkaW5nKSByZXR1cm4gPHNwYW4+TG9hZGluZy4uLjwvc3Bhbj47XG4gKiAgIGlmIChlcnJvcikgcmV0dXJuIDxzcGFuPkVycm9yIGxvYWRpbmcgYXR0YWNobWVudHM8L3NwYW4+O1xuICogICByZXR1cm4gPEF0dGFjaG1lbnRMaXN0IGF0dGFjaG1lbnRzPXtkYXRhfSAvPjtcbiAqIH1cbiAqIGBgYFxuICovIGV4cG9ydCBmdW5jdGlvbiB1c2VBdHRhY2htZW50cyhwYXRpZW50VXVpZCwgaW5jbHVkZUVuY291bnRlcmxlc3MpIHtcbiAgICBjb25zdCB7IGRhdGEsIGVycm9yLCBtdXRhdGUsIGlzTG9hZGluZywgaXNWYWxpZGF0aW5nIH0gPSB1c2VTV1IoYCR7YXR0YWNobWVudFVybH0/cGF0aWVudD0ke3BhdGllbnRVdWlkfSZpbmNsdWRlRW5jb3VudGVybGVzcz0ke2luY2x1ZGVFbmNvdW50ZXJsZXNzfWAsIG9wZW5tcnNGZXRjaCk7XG4gICAgY29uc3QgcmVzdWx0cyA9IHVzZU1lbW8oKCk9Pih7XG4gICAgICAgICAgICBpc0xvYWRpbmcsXG4gICAgICAgICAgICBkYXRhOiBkYXRhPy5kYXRhLnJlc3VsdHMgPz8gW10sXG4gICAgICAgICAgICBlcnJvcixcbiAgICAgICAgICAgIG11dGF0ZSxcbiAgICAgICAgICAgIGlzVmFsaWRhdGluZ1xuICAgICAgICB9KSwgW1xuICAgICAgICBkYXRhLFxuICAgICAgICBlcnJvcixcbiAgICAgICAgaXNMb2FkaW5nLFxuICAgICAgICBpc1ZhbGlkYXRpbmcsXG4gICAgICAgIG11dGF0ZVxuICAgIF0pO1xuICAgIHJldHVybiByZXN1bHRzO1xufVxuIl0sIm5hbWVzIjpbInVzZU1lbW8iLCJ1c2VTV1IiLCJvcGVubXJzRmV0Y2giLCJhdHRhY2htZW50VXJsIiwidXNlQXR0YWNobWVudHMiLCJwYXRpZW50VXVpZCIsImluY2x1ZGVFbmNvdW50ZXJsZXNzIiwiZGF0YSIsImVycm9yIiwibXV0YXRlIiwiaXNMb2FkaW5nIiwiaXNWYWxpZGF0aW5nIiwicmVzdWx0cyJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/useAttachments.js\n");
909
909
 
910
910
  /***/ }),
911
911
 
@@ -915,7 +915,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
915
915
  \*****************************************************************/
916
916
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
917
917
 
918
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ useBodyScrollLock: () => (/* binding */ useBodyScrollLock)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/** @module @category UI */ \nfunction useBodyScrollLock(active) {\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(()=>{\n if (active) {\n const original = window.getComputedStyle(document.body).overflow;\n document.body.style.overflow = 'hidden';\n return ()=>{\n document.body.style.overflow = original;\n };\n }\n }, [\n active\n ]);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZUJvZHlTY3JvbGxMb2NrLmpzIiwibWFwcGluZ3MiOiI7Ozs7O0FBQUEseUJBQXlCLEdBQXFDO0FBQ3ZELFNBQVNDLGtCQUFrQkMsTUFBTTtJQUNwQ0YsZ0RBQVNBLENBQUM7UUFDTixJQUFJRSxRQUFRO1lBQ1IsTUFBTUMsV0FBV0MsT0FBT0MsZ0JBQWdCLENBQUNDLFNBQVNDLElBQUksRUFBRUMsUUFBUTtZQUNoRUYsU0FBU0MsSUFBSSxDQUFDRSxLQUFLLENBQUNELFFBQVEsR0FBRztZQUMvQixPQUFPO2dCQUNIRixTQUFTQyxJQUFJLENBQUNFLEtBQUssQ0FBQ0QsUUFBUSxHQUFHTDtZQUNuQztRQUNKO0lBQ0osR0FBRztRQUNDRDtLQUNIO0FBQ0wiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tcmVhY3QtdXRpbHMvZGlzdC91c2VCb2R5U2Nyb2xsTG9jay5qcz80NWUyIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBAbW9kdWxlIEBjYXRlZ29yeSBVSSAqLyBpbXBvcnQgeyB1c2VFZmZlY3QgfSBmcm9tIFwicmVhY3RcIjtcbmV4cG9ydCBmdW5jdGlvbiB1c2VCb2R5U2Nyb2xsTG9jayhhY3RpdmUpIHtcbiAgICB1c2VFZmZlY3QoKCk9PntcbiAgICAgICAgaWYgKGFjdGl2ZSkge1xuICAgICAgICAgICAgY29uc3Qgb3JpZ2luYWwgPSB3aW5kb3cuZ2V0Q29tcHV0ZWRTdHlsZShkb2N1bWVudC5ib2R5KS5vdmVyZmxvdztcbiAgICAgICAgICAgIGRvY3VtZW50LmJvZHkuc3R5bGUub3ZlcmZsb3cgPSAnaGlkZGVuJztcbiAgICAgICAgICAgIHJldHVybiAoKT0+e1xuICAgICAgICAgICAgICAgIGRvY3VtZW50LmJvZHkuc3R5bGUub3ZlcmZsb3cgPSBvcmlnaW5hbDtcbiAgICAgICAgICAgIH07XG4gICAgICAgIH1cbiAgICB9LCBbXG4gICAgICAgIGFjdGl2ZVxuICAgIF0pO1xufVxuIl0sIm5hbWVzIjpbInVzZUVmZmVjdCIsInVzZUJvZHlTY3JvbGxMb2NrIiwiYWN0aXZlIiwib3JpZ2luYWwiLCJ3aW5kb3ciLCJnZXRDb21wdXRlZFN0eWxlIiwiZG9jdW1lbnQiLCJib2R5Iiwib3ZlcmZsb3ciLCJzdHlsZSJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/useBodyScrollLock.js\n");
918
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ useBodyScrollLock: () => (/* binding */ useBodyScrollLock)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/** @module @category UI */ \n/**\n * A React hook that prevents scrolling on the document body when active.\n * Useful for modals, overlays, or any full-screen UI that should prevent\n * background scrolling. The original overflow style is restored when the\n * hook becomes inactive or the component unmounts.\n *\n * @param active Whether to lock the body scroll. When `true`, sets\n * `document.body.style.overflow` to 'hidden'.\n *\n * @example\n * ```tsx\n * import { useBodyScrollLock } from '@openmrs/esm-framework';\n * function Modal({ isOpen }) {\n * useBodyScrollLock(isOpen);\n * return isOpen ? <div className=\"modal\">...</div> : null;\n * }\n * ```\n */ function useBodyScrollLock(active) {\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(()=>{\n if (active) {\n const original = window.getComputedStyle(document.body).overflow;\n document.body.style.overflow = 'hidden';\n return ()=>{\n document.body.style.overflow = original;\n };\n }\n }, [\n active\n ]);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZUJvZHlTY3JvbGxMb2NrLmpzIiwibWFwcGluZ3MiOiI7Ozs7O0FBQUEseUJBQXlCLEdBQXFDO0FBQzlEOzs7Ozs7Ozs7Ozs7Ozs7OztDQWlCQyxHQUFVLFNBQVNDLGtCQUFrQkMsTUFBTTtJQUN4Q0YsZ0RBQVNBLENBQUM7UUFDTixJQUFJRSxRQUFRO1lBQ1IsTUFBTUMsV0FBV0MsT0FBT0MsZ0JBQWdCLENBQUNDLFNBQVNDLElBQUksRUFBRUMsUUFBUTtZQUNoRUYsU0FBU0MsSUFBSSxDQUFDRSxLQUFLLENBQUNELFFBQVEsR0FBRztZQUMvQixPQUFPO2dCQUNIRixTQUFTQyxJQUFJLENBQUNFLEtBQUssQ0FBQ0QsUUFBUSxHQUFHTDtZQUNuQztRQUNKO0lBQ0osR0FBRztRQUNDRDtLQUNIO0FBQ0wiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tcmVhY3QtdXRpbHMvZGlzdC91c2VCb2R5U2Nyb2xsTG9jay5qcz80NWUyIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBAbW9kdWxlIEBjYXRlZ29yeSBVSSAqLyBpbXBvcnQgeyB1c2VFZmZlY3QgfSBmcm9tIFwicmVhY3RcIjtcbi8qKlxuICogQSBSZWFjdCBob29rIHRoYXQgcHJldmVudHMgc2Nyb2xsaW5nIG9uIHRoZSBkb2N1bWVudCBib2R5IHdoZW4gYWN0aXZlLlxuICogVXNlZnVsIGZvciBtb2RhbHMsIG92ZXJsYXlzLCBvciBhbnkgZnVsbC1zY3JlZW4gVUkgdGhhdCBzaG91bGQgcHJldmVudFxuICogYmFja2dyb3VuZCBzY3JvbGxpbmcuIFRoZSBvcmlnaW5hbCBvdmVyZmxvdyBzdHlsZSBpcyByZXN0b3JlZCB3aGVuIHRoZVxuICogaG9vayBiZWNvbWVzIGluYWN0aXZlIG9yIHRoZSBjb21wb25lbnQgdW5tb3VudHMuXG4gKlxuICogQHBhcmFtIGFjdGl2ZSBXaGV0aGVyIHRvIGxvY2sgdGhlIGJvZHkgc2Nyb2xsLiBXaGVuIGB0cnVlYCwgc2V0c1xuICogICBgZG9jdW1lbnQuYm9keS5zdHlsZS5vdmVyZmxvd2AgdG8gJ2hpZGRlbicuXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHRzeFxuICogaW1wb3J0IHsgdXNlQm9keVNjcm9sbExvY2sgfSBmcm9tICdAb3Blbm1ycy9lc20tZnJhbWV3b3JrJztcbiAqIGZ1bmN0aW9uIE1vZGFsKHsgaXNPcGVuIH0pIHtcbiAqICAgdXNlQm9keVNjcm9sbExvY2soaXNPcGVuKTtcbiAqICAgcmV0dXJuIGlzT3BlbiA/IDxkaXYgY2xhc3NOYW1lPVwibW9kYWxcIj4uLi48L2Rpdj4gOiBudWxsO1xuICogfVxuICogYGBgXG4gKi8gZXhwb3J0IGZ1bmN0aW9uIHVzZUJvZHlTY3JvbGxMb2NrKGFjdGl2ZSkge1xuICAgIHVzZUVmZmVjdCgoKT0+e1xuICAgICAgICBpZiAoYWN0aXZlKSB7XG4gICAgICAgICAgICBjb25zdCBvcmlnaW5hbCA9IHdpbmRvdy5nZXRDb21wdXRlZFN0eWxlKGRvY3VtZW50LmJvZHkpLm92ZXJmbG93O1xuICAgICAgICAgICAgZG9jdW1lbnQuYm9keS5zdHlsZS5vdmVyZmxvdyA9ICdoaWRkZW4nO1xuICAgICAgICAgICAgcmV0dXJuICgpPT57XG4gICAgICAgICAgICAgICAgZG9jdW1lbnQuYm9keS5zdHlsZS5vdmVyZmxvdyA9IG9yaWdpbmFsO1xuICAgICAgICAgICAgfTtcbiAgICAgICAgfVxuICAgIH0sIFtcbiAgICAgICAgYWN0aXZlXG4gICAgXSk7XG59XG4iXSwibmFtZXMiOlsidXNlRWZmZWN0IiwidXNlQm9keVNjcm9sbExvY2siLCJhY3RpdmUiLCJvcmlnaW5hbCIsIndpbmRvdyIsImdldENvbXB1dGVkU3R5bGUiLCJkb2N1bWVudCIsImJvZHkiLCJvdmVyZmxvdyIsInN0eWxlIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/useBodyScrollLock.js\n");
919
919
 
920
920
  /***/ }),
921
921
 
@@ -945,7 +945,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
945
945
  \***************************************************************/
946
946
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
947
947
 
948
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ useConnectivity: () => (/* binding */ useConnectivity)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-globals */ \"../../framework/esm-globals/dist/index.js\");\n/* harmony import */ var _openmrs_esm_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @openmrs/esm-utils */ \"../../framework/esm-utils/dist/is-online.js\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/** @module @category Offline */ \n\n\nfunction useConnectivity() {\n let [isOnline, setIsOnline] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)((0,_openmrs_esm_utils__WEBPACK_IMPORTED_MODULE_2__.isOnline)());\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(()=>(0,_openmrs_esm_globals__WEBPACK_IMPORTED_MODULE_0__.subscribeConnectivityChanged)(({ online })=>setIsOnline(online)), []);\n return isOnline;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZUNvbm5lY3Rpdml0eS5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUEsOEJBQThCLEdBQXVFO0FBQ3pDO0FBQ2hCO0FBQ3JDLFNBQVNLO0lBQ1osSUFBSSxDQUFDSixVQUFVSyxZQUFZLEdBQUdGLCtDQUFRQSxDQUFDRiw0REFBVUE7SUFDakRDLGdEQUFTQSxDQUFDLElBQUlILGtGQUE0QkEsQ0FBQyxDQUFDLEVBQUVPLE1BQU0sRUFBRSxHQUFHRCxZQUFZQyxVQUFVLEVBQUU7SUFDakYsT0FBT047QUFDWCIsInNvdXJjZXMiOlsid2VicGFjazovL0BvcGVubXJzL2VzbS1hcHAtc2hlbGwvLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZUNvbm5lY3Rpdml0eS5qcz9lOWQ4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBAbW9kdWxlIEBjYXRlZ29yeSBPZmZsaW5lICovIGltcG9ydCB7IHN1YnNjcmliZUNvbm5lY3Rpdml0eUNoYW5nZWQgfSBmcm9tIFwiQG9wZW5tcnMvZXNtLWdsb2JhbHNcIjtcbmltcG9ydCB7IGlzT25saW5lIGFzIGlzT25saW5lRm4gfSBmcm9tIFwiQG9wZW5tcnMvZXNtLXV0aWxzXCI7XG5pbXBvcnQgeyB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSBcInJlYWN0XCI7XG5leHBvcnQgZnVuY3Rpb24gdXNlQ29ubmVjdGl2aXR5KCkge1xuICAgIGxldCBbaXNPbmxpbmUsIHNldElzT25saW5lXSA9IHVzZVN0YXRlKGlzT25saW5lRm4oKSk7XG4gICAgdXNlRWZmZWN0KCgpPT5zdWJzY3JpYmVDb25uZWN0aXZpdHlDaGFuZ2VkKCh7IG9ubGluZSB9KT0+c2V0SXNPbmxpbmUob25saW5lKSksIFtdKTtcbiAgICByZXR1cm4gaXNPbmxpbmU7XG59XG4iXSwibmFtZXMiOlsic3Vic2NyaWJlQ29ubmVjdGl2aXR5Q2hhbmdlZCIsImlzT25saW5lIiwiaXNPbmxpbmVGbiIsInVzZUVmZmVjdCIsInVzZVN0YXRlIiwidXNlQ29ubmVjdGl2aXR5Iiwic2V0SXNPbmxpbmUiLCJvbmxpbmUiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/useConnectivity.js\n");
948
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ useConnectivity: () => (/* binding */ useConnectivity)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-globals */ \"../../framework/esm-globals/dist/index.js\");\n/* harmony import */ var _openmrs_esm_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @openmrs/esm-utils */ \"../../framework/esm-utils/dist/is-online.js\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/** @module @category Offline */ \n\n\n/**\n * A React hook that returns the current online/offline status and automatically\n * updates when connectivity changes. Useful for showing offline indicators or\n * conditionally rendering UI based on network availability.\n *\n * @returns `true` if the browser is online, `false` if offline.\n *\n * @example\n * ```tsx\n * import { useConnectivity } from '@openmrs/esm-framework';\n * function NetworkStatus() {\n * const isOnline = useConnectivity();\n * return <span>{isOnline ? 'Online' : 'Offline'}</span>;\n * }\n * ```\n */ function useConnectivity() {\n let [isOnline, setIsOnline] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)((0,_openmrs_esm_utils__WEBPACK_IMPORTED_MODULE_2__.isOnline)());\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(()=>(0,_openmrs_esm_globals__WEBPACK_IMPORTED_MODULE_0__.subscribeConnectivityChanged)(({ online })=>setIsOnline(online)), []);\n return isOnline;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZUNvbm5lY3Rpdml0eS5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUEsOEJBQThCLEdBQXVFO0FBQ3pDO0FBQ2hCO0FBQzVDOzs7Ozs7Ozs7Ozs7Ozs7Q0FlQyxHQUFVLFNBQVNLO0lBQ2hCLElBQUksQ0FBQ0osVUFBVUssWUFBWSxHQUFHRiwrQ0FBUUEsQ0FBQ0YsNERBQVVBO0lBQ2pEQyxnREFBU0EsQ0FBQyxJQUFJSCxrRkFBNEJBLENBQUMsQ0FBQyxFQUFFTyxNQUFNLEVBQUUsR0FBR0QsWUFBWUMsVUFBVSxFQUFFO0lBQ2pGLE9BQU9OO0FBQ1giLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tcmVhY3QtdXRpbHMvZGlzdC91c2VDb25uZWN0aXZpdHkuanM/ZTlkOCJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQG1vZHVsZSBAY2F0ZWdvcnkgT2ZmbGluZSAqLyBpbXBvcnQgeyBzdWJzY3JpYmVDb25uZWN0aXZpdHlDaGFuZ2VkIH0gZnJvbSBcIkBvcGVubXJzL2VzbS1nbG9iYWxzXCI7XG5pbXBvcnQgeyBpc09ubGluZSBhcyBpc09ubGluZUZuIH0gZnJvbSBcIkBvcGVubXJzL2VzbS11dGlsc1wiO1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gXCJyZWFjdFwiO1xuLyoqXG4gKiBBIFJlYWN0IGhvb2sgdGhhdCByZXR1cm5zIHRoZSBjdXJyZW50IG9ubGluZS9vZmZsaW5lIHN0YXR1cyBhbmQgYXV0b21hdGljYWxseVxuICogdXBkYXRlcyB3aGVuIGNvbm5lY3Rpdml0eSBjaGFuZ2VzLiBVc2VmdWwgZm9yIHNob3dpbmcgb2ZmbGluZSBpbmRpY2F0b3JzIG9yXG4gKiBjb25kaXRpb25hbGx5IHJlbmRlcmluZyBVSSBiYXNlZCBvbiBuZXR3b3JrIGF2YWlsYWJpbGl0eS5cbiAqXG4gKiBAcmV0dXJucyBgdHJ1ZWAgaWYgdGhlIGJyb3dzZXIgaXMgb25saW5lLCBgZmFsc2VgIGlmIG9mZmxpbmUuXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHRzeFxuICogaW1wb3J0IHsgdXNlQ29ubmVjdGl2aXR5IH0gZnJvbSAnQG9wZW5tcnMvZXNtLWZyYW1ld29yayc7XG4gKiBmdW5jdGlvbiBOZXR3b3JrU3RhdHVzKCkge1xuICogICBjb25zdCBpc09ubGluZSA9IHVzZUNvbm5lY3Rpdml0eSgpO1xuICogICByZXR1cm4gPHNwYW4+e2lzT25saW5lID8gJ09ubGluZScgOiAnT2ZmbGluZSd9PC9zcGFuPjtcbiAqIH1cbiAqIGBgYFxuICovIGV4cG9ydCBmdW5jdGlvbiB1c2VDb25uZWN0aXZpdHkoKSB7XG4gICAgbGV0IFtpc09ubGluZSwgc2V0SXNPbmxpbmVdID0gdXNlU3RhdGUoaXNPbmxpbmVGbigpKTtcbiAgICB1c2VFZmZlY3QoKCk9PnN1YnNjcmliZUNvbm5lY3Rpdml0eUNoYW5nZWQoKHsgb25saW5lIH0pPT5zZXRJc09ubGluZShvbmxpbmUpKSwgW10pO1xuICAgIHJldHVybiBpc09ubGluZTtcbn1cbiJdLCJuYW1lcyI6WyJzdWJzY3JpYmVDb25uZWN0aXZpdHlDaGFuZ2VkIiwiaXNPbmxpbmUiLCJpc09ubGluZUZuIiwidXNlRWZmZWN0IiwidXNlU3RhdGUiLCJ1c2VDb25uZWN0aXZpdHkiLCJzZXRJc09ubGluZSIsIm9ubGluZSJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/useConnectivity.js\n");
949
949
 
950
950
  /***/ }),
951
951
 
@@ -1095,7 +1095,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
1095
1095
  \**********************************************************/
1096
1096
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
1097
1097
 
1098
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ useLeftNav: () => (/* binding */ useLeftNav)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var _openmrs_esm_extensions__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-extensions */ \"../../framework/esm-extensions/dist/index.js\");\n/* harmony import */ var _ComponentContext_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./ComponentContext.js */ \"../../framework/esm-react-utils/dist/ComponentContext.js\");\n\n\n\nfunction useLeftNav(params) {\n const componentContext = (0,react__WEBPACK_IMPORTED_MODULE_0__.useContext)(_ComponentContext_js__WEBPACK_IMPORTED_MODULE_2__.ComponentContext);\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(()=>{\n if (componentContext && componentContext.moduleName) {\n params.componentContext = componentContext;\n }\n (0,_openmrs_esm_extensions__WEBPACK_IMPORTED_MODULE_1__.setLeftNav)(params);\n return ()=>{\n (0,_openmrs_esm_extensions__WEBPACK_IMPORTED_MODULE_1__.unsetLeftNav)(params.name);\n };\n }, [\n componentContext,\n params\n ]);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZUxlZnROYXYuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUE4QztBQUNxQjtBQUNWO0FBQ2xELFNBQVNLLFdBQVdDLE1BQU07SUFDN0IsTUFBTUMsbUJBQW1CUCxpREFBVUEsQ0FBQ0ksa0VBQWdCQTtJQUNwREgsZ0RBQVNBLENBQUM7UUFDTixJQUFJTSxvQkFBb0JBLGlCQUFpQkMsVUFBVSxFQUFFO1lBQ2pERixPQUFPQyxnQkFBZ0IsR0FBR0E7UUFDOUI7UUFDQUwsbUVBQVVBLENBQUNJO1FBQ1gsT0FBTztZQUNISCxxRUFBWUEsQ0FBQ0csT0FBT0csSUFBSTtRQUM1QjtJQUNKLEdBQUc7UUFDQ0Y7UUFDQUQ7S0FDSDtBQUNMIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQG9wZW5tcnMvZXNtLWFwcC1zaGVsbC8uLi8uLi9mcmFtZXdvcmsvZXNtLXJlYWN0LXV0aWxzL2Rpc3QvdXNlTGVmdE5hdi5qcz9jYTJjIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHVzZUNvbnRleHQsIHVzZUVmZmVjdCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHsgc2V0TGVmdE5hdiwgdW5zZXRMZWZ0TmF2IH0gZnJvbSBcIkBvcGVubXJzL2VzbS1leHRlbnNpb25zXCI7XG5pbXBvcnQgeyBDb21wb25lbnRDb250ZXh0IH0gZnJvbSBcIi4vQ29tcG9uZW50Q29udGV4dC5qc1wiO1xuZXhwb3J0IGZ1bmN0aW9uIHVzZUxlZnROYXYocGFyYW1zKSB7XG4gICAgY29uc3QgY29tcG9uZW50Q29udGV4dCA9IHVzZUNvbnRleHQoQ29tcG9uZW50Q29udGV4dCk7XG4gICAgdXNlRWZmZWN0KCgpPT57XG4gICAgICAgIGlmIChjb21wb25lbnRDb250ZXh0ICYmIGNvbXBvbmVudENvbnRleHQubW9kdWxlTmFtZSkge1xuICAgICAgICAgICAgcGFyYW1zLmNvbXBvbmVudENvbnRleHQgPSBjb21wb25lbnRDb250ZXh0O1xuICAgICAgICB9XG4gICAgICAgIHNldExlZnROYXYocGFyYW1zKTtcbiAgICAgICAgcmV0dXJuICgpPT57XG4gICAgICAgICAgICB1bnNldExlZnROYXYocGFyYW1zLm5hbWUpO1xuICAgICAgICB9O1xuICAgIH0sIFtcbiAgICAgICAgY29tcG9uZW50Q29udGV4dCxcbiAgICAgICAgcGFyYW1zXG4gICAgXSk7XG59XG4iXSwibmFtZXMiOlsidXNlQ29udGV4dCIsInVzZUVmZmVjdCIsInNldExlZnROYXYiLCJ1bnNldExlZnROYXYiLCJDb21wb25lbnRDb250ZXh0IiwidXNlTGVmdE5hdiIsInBhcmFtcyIsImNvbXBvbmVudENvbnRleHQiLCJtb2R1bGVOYW1lIiwibmFtZSJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/useLeftNav.js\n");
1098
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ useLeftNav: () => (/* binding */ useLeftNav)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var _openmrs_esm_extensions__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-extensions */ \"../../framework/esm-extensions/dist/index.js\");\n/* harmony import */ var _ComponentContext_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./ComponentContext.js */ \"../../framework/esm-react-utils/dist/ComponentContext.js\");\n/** @module @category UI */ \n\n\n/**\n * A React hook that registers a left navigation menu for the current component.\n * The navigation is automatically registered when the component mounts and\n * unregistered when it unmounts.\n *\n * **Important:** This hook should only be used in \"page\" components, not in\n * \"extension\" components. Extensions should not control the left navigation.\n *\n * @param params Configuration parameters for the left navigation, excluding the\n * module name which is automatically determined from the component context.\n *\n * @example\n * ```tsx\n * import { useLeftNav } from '@openmrs/esm-framework';\n * function MyPageComponent() {\n * useLeftNav({ name: 'my-nav', slots: ['nav-slot-1', 'nav-slot-2'] });\n * return <div>My Page</div>;\n * }\n * ```\n */ function useLeftNav(params) {\n const componentContext = (0,react__WEBPACK_IMPORTED_MODULE_0__.useContext)(_ComponentContext_js__WEBPACK_IMPORTED_MODULE_2__.ComponentContext);\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(()=>{\n if (componentContext && componentContext.moduleName) {\n params.componentContext = componentContext;\n }\n (0,_openmrs_esm_extensions__WEBPACK_IMPORTED_MODULE_1__.setLeftNav)(params);\n return ()=>{\n (0,_openmrs_esm_extensions__WEBPACK_IMPORTED_MODULE_1__.unsetLeftNav)(params.name);\n };\n }, [\n componentContext,\n params\n ]);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZUxlZnROYXYuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBLHlCQUF5QixHQUFpRDtBQUNQO0FBQ1Y7QUFDekQ7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Q0FtQkMsR0FBVSxTQUFTSyxXQUFXQyxNQUFNO0lBQ2pDLE1BQU1DLG1CQUFtQlAsaURBQVVBLENBQUNJLGtFQUFnQkE7SUFDcERILGdEQUFTQSxDQUFDO1FBQ04sSUFBSU0sb0JBQW9CQSxpQkFBaUJDLFVBQVUsRUFBRTtZQUNqREYsT0FBT0MsZ0JBQWdCLEdBQUdBO1FBQzlCO1FBQ0FMLG1FQUFVQSxDQUFDSTtRQUNYLE9BQU87WUFDSEgscUVBQVlBLENBQUNHLE9BQU9HLElBQUk7UUFDNUI7SUFDSixHQUFHO1FBQ0NGO1FBQ0FEO0tBQ0g7QUFDTCIsInNvdXJjZXMiOlsid2VicGFjazovL0BvcGVubXJzL2VzbS1hcHAtc2hlbGwvLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZUxlZnROYXYuanM/Y2EyYyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQG1vZHVsZSBAY2F0ZWdvcnkgVUkgKi8gaW1wb3J0IHsgdXNlQ29udGV4dCwgdXNlRWZmZWN0IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgeyBzZXRMZWZ0TmF2LCB1bnNldExlZnROYXYgfSBmcm9tIFwiQG9wZW5tcnMvZXNtLWV4dGVuc2lvbnNcIjtcbmltcG9ydCB7IENvbXBvbmVudENvbnRleHQgfSBmcm9tIFwiLi9Db21wb25lbnRDb250ZXh0LmpzXCI7XG4vKipcbiAqIEEgUmVhY3QgaG9vayB0aGF0IHJlZ2lzdGVycyBhIGxlZnQgbmF2aWdhdGlvbiBtZW51IGZvciB0aGUgY3VycmVudCBjb21wb25lbnQuXG4gKiBUaGUgbmF2aWdhdGlvbiBpcyBhdXRvbWF0aWNhbGx5IHJlZ2lzdGVyZWQgd2hlbiB0aGUgY29tcG9uZW50IG1vdW50cyBhbmRcbiAqIHVucmVnaXN0ZXJlZCB3aGVuIGl0IHVubW91bnRzLlxuICpcbiAqICoqSW1wb3J0YW50OioqIFRoaXMgaG9vayBzaG91bGQgb25seSBiZSB1c2VkIGluIFwicGFnZVwiIGNvbXBvbmVudHMsIG5vdCBpblxuICogXCJleHRlbnNpb25cIiBjb21wb25lbnRzLiBFeHRlbnNpb25zIHNob3VsZCBub3QgY29udHJvbCB0aGUgbGVmdCBuYXZpZ2F0aW9uLlxuICpcbiAqIEBwYXJhbSBwYXJhbXMgQ29uZmlndXJhdGlvbiBwYXJhbWV0ZXJzIGZvciB0aGUgbGVmdCBuYXZpZ2F0aW9uLCBleGNsdWRpbmcgdGhlXG4gKiAgIG1vZHVsZSBuYW1lIHdoaWNoIGlzIGF1dG9tYXRpY2FsbHkgZGV0ZXJtaW5lZCBmcm9tIHRoZSBjb21wb25lbnQgY29udGV4dC5cbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHN4XG4gKiBpbXBvcnQgeyB1c2VMZWZ0TmF2IH0gZnJvbSAnQG9wZW5tcnMvZXNtLWZyYW1ld29yayc7XG4gKiBmdW5jdGlvbiBNeVBhZ2VDb21wb25lbnQoKSB7XG4gKiAgIHVzZUxlZnROYXYoeyBuYW1lOiAnbXktbmF2Jywgc2xvdHM6IFsnbmF2LXNsb3QtMScsICduYXYtc2xvdC0yJ10gfSk7XG4gKiAgIHJldHVybiA8ZGl2Pk15IFBhZ2U8L2Rpdj47XG4gKiB9XG4gKiBgYGBcbiAqLyBleHBvcnQgZnVuY3Rpb24gdXNlTGVmdE5hdihwYXJhbXMpIHtcbiAgICBjb25zdCBjb21wb25lbnRDb250ZXh0ID0gdXNlQ29udGV4dChDb21wb25lbnRDb250ZXh0KTtcbiAgICB1c2VFZmZlY3QoKCk9PntcbiAgICAgICAgaWYgKGNvbXBvbmVudENvbnRleHQgJiYgY29tcG9uZW50Q29udGV4dC5tb2R1bGVOYW1lKSB7XG4gICAgICAgICAgICBwYXJhbXMuY29tcG9uZW50Q29udGV4dCA9IGNvbXBvbmVudENvbnRleHQ7XG4gICAgICAgIH1cbiAgICAgICAgc2V0TGVmdE5hdihwYXJhbXMpO1xuICAgICAgICByZXR1cm4gKCk9PntcbiAgICAgICAgICAgIHVuc2V0TGVmdE5hdihwYXJhbXMubmFtZSk7XG4gICAgICAgIH07XG4gICAgfSwgW1xuICAgICAgICBjb21wb25lbnRDb250ZXh0LFxuICAgICAgICBwYXJhbXNcbiAgICBdKTtcbn1cbiJdLCJuYW1lcyI6WyJ1c2VDb250ZXh0IiwidXNlRWZmZWN0Iiwic2V0TGVmdE5hdiIsInVuc2V0TGVmdE5hdiIsIkNvbXBvbmVudENvbnRleHQiLCJ1c2VMZWZ0TmF2IiwicGFyYW1zIiwiY29tcG9uZW50Q29udGV4dCIsIm1vZHVsZU5hbWUiLCJuYW1lIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/useLeftNav.js\n");
1099
1099
 
1100
1100
  /***/ }),
1101
1101
 
@@ -1105,7 +1105,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
1105
1105
  \***************************************************************/
1106
1106
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
1107
1107
 
1108
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ useLeftNavStore: () => (/* binding */ useLeftNavStore)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_extensions__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-extensions */ \"../../framework/esm-extensions/dist/index.js\");\n/* harmony import */ var _useStore_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./useStore.js */ \"../../framework/esm-react-utils/dist/useStore.js\");\n\n\nfunction useLeftNavStore() {\n return (0,_useStore_js__WEBPACK_IMPORTED_MODULE_1__.useStore)(_openmrs_esm_extensions__WEBPACK_IMPORTED_MODULE_0__.leftNavStore);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZUxlZnROYXZTdG9yZS5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7QUFBdUQ7QUFDZDtBQUNsQyxTQUFTRTtJQUNaLE9BQU9ELHNEQUFRQSxDQUFDRCxpRUFBWUE7QUFDaEMiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tcmVhY3QtdXRpbHMvZGlzdC91c2VMZWZ0TmF2U3RvcmUuanM/ZDJlOSJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBsZWZ0TmF2U3RvcmUgfSBmcm9tIFwiQG9wZW5tcnMvZXNtLWV4dGVuc2lvbnNcIjtcbmltcG9ydCB7IHVzZVN0b3JlIH0gZnJvbSBcIi4vdXNlU3RvcmUuanNcIjtcbmV4cG9ydCBmdW5jdGlvbiB1c2VMZWZ0TmF2U3RvcmUoKSB7XG4gICAgcmV0dXJuIHVzZVN0b3JlKGxlZnROYXZTdG9yZSk7XG59XG4iXSwibmFtZXMiOlsibGVmdE5hdlN0b3JlIiwidXNlU3RvcmUiLCJ1c2VMZWZ0TmF2U3RvcmUiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/useLeftNavStore.js\n");
1108
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ useLeftNavStore: () => (/* binding */ useLeftNavStore)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_extensions__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-extensions */ \"../../framework/esm-extensions/dist/index.js\");\n/* harmony import */ var _useStore_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./useStore.js */ \"../../framework/esm-react-utils/dist/useStore.js\");\n/** @module @category UI */ \n\n/**\n * A React hook that provides access to the left navigation store state.\n * The component will re-render whenever the left navigation state changes.\n *\n * @returns The current state of the left navigation store.\n *\n * @example\n * ```tsx\n * import { useLeftNavStore } from '@openmrs/esm-framework';\n * function MyComponent() {\n * const leftNavState = useLeftNavStore();\n * return <div>Current nav: {leftNavState.activeNavName}</div>;\n * }\n * ```\n */ function useLeftNavStore() {\n return (0,_useStore_js__WEBPACK_IMPORTED_MODULE_1__.useStore)(_openmrs_esm_extensions__WEBPACK_IMPORTED_MODULE_0__.leftNavStore);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZUxlZnROYXZTdG9yZS5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSx5QkFBeUIsR0FBMEQ7QUFDMUM7QUFDekM7Ozs7Ozs7Ozs7Ozs7O0NBY0MsR0FBVSxTQUFTRTtJQUNoQixPQUFPRCxzREFBUUEsQ0FBQ0QsaUVBQVlBO0FBQ2hDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQG9wZW5tcnMvZXNtLWFwcC1zaGVsbC8uLi8uLi9mcmFtZXdvcmsvZXNtLXJlYWN0LXV0aWxzL2Rpc3QvdXNlTGVmdE5hdlN0b3JlLmpzP2QyZTkiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBtb2R1bGUgQGNhdGVnb3J5IFVJICovIGltcG9ydCB7IGxlZnROYXZTdG9yZSB9IGZyb20gXCJAb3Blbm1ycy9lc20tZXh0ZW5zaW9uc1wiO1xuaW1wb3J0IHsgdXNlU3RvcmUgfSBmcm9tIFwiLi91c2VTdG9yZS5qc1wiO1xuLyoqXG4gKiBBIFJlYWN0IGhvb2sgdGhhdCBwcm92aWRlcyBhY2Nlc3MgdG8gdGhlIGxlZnQgbmF2aWdhdGlvbiBzdG9yZSBzdGF0ZS5cbiAqIFRoZSBjb21wb25lbnQgd2lsbCByZS1yZW5kZXIgd2hlbmV2ZXIgdGhlIGxlZnQgbmF2aWdhdGlvbiBzdGF0ZSBjaGFuZ2VzLlxuICpcbiAqIEByZXR1cm5zIFRoZSBjdXJyZW50IHN0YXRlIG9mIHRoZSBsZWZ0IG5hdmlnYXRpb24gc3RvcmUuXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHRzeFxuICogaW1wb3J0IHsgdXNlTGVmdE5hdlN0b3JlIH0gZnJvbSAnQG9wZW5tcnMvZXNtLWZyYW1ld29yayc7XG4gKiBmdW5jdGlvbiBNeUNvbXBvbmVudCgpIHtcbiAqICAgY29uc3QgbGVmdE5hdlN0YXRlID0gdXNlTGVmdE5hdlN0b3JlKCk7XG4gKiAgIHJldHVybiA8ZGl2PkN1cnJlbnQgbmF2OiB7bGVmdE5hdlN0YXRlLmFjdGl2ZU5hdk5hbWV9PC9kaXY+O1xuICogfVxuICogYGBgXG4gKi8gZXhwb3J0IGZ1bmN0aW9uIHVzZUxlZnROYXZTdG9yZSgpIHtcbiAgICByZXR1cm4gdXNlU3RvcmUobGVmdE5hdlN0b3JlKTtcbn1cbiJdLCJuYW1lcyI6WyJsZWZ0TmF2U3RvcmUiLCJ1c2VTdG9yZSIsInVzZUxlZnROYXZTdG9yZSJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/useLeftNavStore.js\n");
1109
1109
 
1110
1110
  /***/ }),
1111
1111
 
@@ -1115,7 +1115,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
1115
1115
  \************************************************************/
1116
1116
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
1117
1117
 
1118
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ useLocations: () => (/* binding */ useLocations)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var _openmrs_esm_emr_api__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-emr-api */ \"../../framework/esm-emr-api/dist/index.js\");\n/** @module @category API */ \n\nfunction useLocations(tagUuidOrName = null, query = null) {\n const [locations, setLocations] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)([]);\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(()=>{\n const locationSub = (0,_openmrs_esm_emr_api__WEBPACK_IMPORTED_MODULE_1__.getLocations)(tagUuidOrName, query).subscribe((locations)=>{\n setLocations(locations);\n }, (error)=>{\n console.error(error);\n });\n return ()=>locationSub.unsubscribe();\n }, [\n tagUuidOrName,\n query\n ]);\n return locations;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZUxvY2F0aW9ucy5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSwwQkFBMEIsR0FBK0M7QUFDckI7QUFDN0MsU0FBU0csYUFBYUMsZ0JBQWdCLElBQUksRUFBRUMsUUFBUSxJQUFJO0lBQzNELE1BQU0sQ0FBQ0MsV0FBV0MsYUFBYSxHQUFHUCwrQ0FBUUEsQ0FBQyxFQUFFO0lBQzdDQyxnREFBU0EsQ0FBQztRQUNOLE1BQU1PLGNBQWNOLGtFQUFZQSxDQUFDRSxlQUFlQyxPQUFPSSxTQUFTLENBQUMsQ0FBQ0g7WUFDOURDLGFBQWFEO1FBQ2pCLEdBQUcsQ0FBQ0k7WUFDQUMsUUFBUUQsS0FBSyxDQUFDQTtRQUNsQjtRQUNBLE9BQU8sSUFBSUYsWUFBWUksV0FBVztJQUN0QyxHQUFHO1FBQ0NSO1FBQ0FDO0tBQ0g7SUFDRCxPQUFPQztBQUNYIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQG9wZW5tcnMvZXNtLWFwcC1zaGVsbC8uLi8uLi9mcmFtZXdvcmsvZXNtLXJlYWN0LXV0aWxzL2Rpc3QvdXNlTG9jYXRpb25zLmpzP2JiZGYiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBtb2R1bGUgQGNhdGVnb3J5IEFQSSAqLyBpbXBvcnQgeyB1c2VTdGF0ZSwgdXNlRWZmZWN0IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgeyBnZXRMb2NhdGlvbnMgfSBmcm9tIFwiQG9wZW5tcnMvZXNtLWVtci1hcGlcIjtcbmV4cG9ydCBmdW5jdGlvbiB1c2VMb2NhdGlvbnModGFnVXVpZE9yTmFtZSA9IG51bGwsIHF1ZXJ5ID0gbnVsbCkge1xuICAgIGNvbnN0IFtsb2NhdGlvbnMsIHNldExvY2F0aW9uc10gPSB1c2VTdGF0ZShbXSk7XG4gICAgdXNlRWZmZWN0KCgpPT57XG4gICAgICAgIGNvbnN0IGxvY2F0aW9uU3ViID0gZ2V0TG9jYXRpb25zKHRhZ1V1aWRPck5hbWUsIHF1ZXJ5KS5zdWJzY3JpYmUoKGxvY2F0aW9ucyk9PntcbiAgICAgICAgICAgIHNldExvY2F0aW9ucyhsb2NhdGlvbnMpO1xuICAgICAgICB9LCAoZXJyb3IpPT57XG4gICAgICAgICAgICBjb25zb2xlLmVycm9yKGVycm9yKTtcbiAgICAgICAgfSk7XG4gICAgICAgIHJldHVybiAoKT0+bG9jYXRpb25TdWIudW5zdWJzY3JpYmUoKTtcbiAgICB9LCBbXG4gICAgICAgIHRhZ1V1aWRPck5hbWUsXG4gICAgICAgIHF1ZXJ5XG4gICAgXSk7XG4gICAgcmV0dXJuIGxvY2F0aW9ucztcbn1cbiJdLCJuYW1lcyI6WyJ1c2VTdGF0ZSIsInVzZUVmZmVjdCIsImdldExvY2F0aW9ucyIsInVzZUxvY2F0aW9ucyIsInRhZ1V1aWRPck5hbWUiLCJxdWVyeSIsImxvY2F0aW9ucyIsInNldExvY2F0aW9ucyIsImxvY2F0aW9uU3ViIiwic3Vic2NyaWJlIiwiZXJyb3IiLCJjb25zb2xlIiwidW5zdWJzY3JpYmUiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/useLocations.js\n");
1118
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ useLocations: () => (/* binding */ useLocations)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var _openmrs_esm_emr_api__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-emr-api */ \"../../framework/esm-emr-api/dist/index.js\");\n/** @module @category API */ \n\n/**\n * A React hook that fetches and returns locations from the OpenMRS server.\n * Locations can be filtered by a tag UUID/name and/or a search query string.\n *\n * @param tagUuidOrName Optional tag UUID or name to filter locations by.\n * Pass `null` to not filter by tag.\n * @param query Optional search query string to filter locations. Pass `null`\n * to not filter by query.\n * @returns An array of Location objects. Returns an empty array while loading\n * or if an error occurs.\n *\n * @example\n * ```tsx\n * import { useLocations } from '@openmrs/esm-framework';\n * function LocationList() {\n * const locations = useLocations('Login Location');\n * return (\n * <ul>\n * {locations.map((loc) => <li key={loc.uuid}>{loc.display}</li>)}\n * </ul>\n * );\n * }\n * ```\n */ function useLocations(tagUuidOrName = null, query = null) {\n const [locations, setLocations] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)([]);\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(()=>{\n const locationSub = (0,_openmrs_esm_emr_api__WEBPACK_IMPORTED_MODULE_1__.getLocations)(tagUuidOrName, query).subscribe((locations)=>{\n setLocations(locations);\n }, (error)=>{\n console.error(error);\n });\n return ()=>locationSub.unsubscribe();\n }, [\n tagUuidOrName,\n query\n ]);\n return locations;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZUxvY2F0aW9ucy5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSwwQkFBMEIsR0FBK0M7QUFDckI7QUFDcEQ7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0NBdUJDLEdBQVUsU0FBU0csYUFBYUMsZ0JBQWdCLElBQUksRUFBRUMsUUFBUSxJQUFJO0lBQy9ELE1BQU0sQ0FBQ0MsV0FBV0MsYUFBYSxHQUFHUCwrQ0FBUUEsQ0FBQyxFQUFFO0lBQzdDQyxnREFBU0EsQ0FBQztRQUNOLE1BQU1PLGNBQWNOLGtFQUFZQSxDQUFDRSxlQUFlQyxPQUFPSSxTQUFTLENBQUMsQ0FBQ0g7WUFDOURDLGFBQWFEO1FBQ2pCLEdBQUcsQ0FBQ0k7WUFDQUMsUUFBUUQsS0FBSyxDQUFDQTtRQUNsQjtRQUNBLE9BQU8sSUFBSUYsWUFBWUksV0FBVztJQUN0QyxHQUFHO1FBQ0NSO1FBQ0FDO0tBQ0g7SUFDRCxPQUFPQztBQUNYIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQG9wZW5tcnMvZXNtLWFwcC1zaGVsbC8uLi8uLi9mcmFtZXdvcmsvZXNtLXJlYWN0LXV0aWxzL2Rpc3QvdXNlTG9jYXRpb25zLmpzP2JiZGYiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBtb2R1bGUgQGNhdGVnb3J5IEFQSSAqLyBpbXBvcnQgeyB1c2VTdGF0ZSwgdXNlRWZmZWN0IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgeyBnZXRMb2NhdGlvbnMgfSBmcm9tIFwiQG9wZW5tcnMvZXNtLWVtci1hcGlcIjtcbi8qKlxuICogQSBSZWFjdCBob29rIHRoYXQgZmV0Y2hlcyBhbmQgcmV0dXJucyBsb2NhdGlvbnMgZnJvbSB0aGUgT3Blbk1SUyBzZXJ2ZXIuXG4gKiBMb2NhdGlvbnMgY2FuIGJlIGZpbHRlcmVkIGJ5IGEgdGFnIFVVSUQvbmFtZSBhbmQvb3IgYSBzZWFyY2ggcXVlcnkgc3RyaW5nLlxuICpcbiAqIEBwYXJhbSB0YWdVdWlkT3JOYW1lIE9wdGlvbmFsIHRhZyBVVUlEIG9yIG5hbWUgdG8gZmlsdGVyIGxvY2F0aW9ucyBieS5cbiAqICAgUGFzcyBgbnVsbGAgdG8gbm90IGZpbHRlciBieSB0YWcuXG4gKiBAcGFyYW0gcXVlcnkgT3B0aW9uYWwgc2VhcmNoIHF1ZXJ5IHN0cmluZyB0byBmaWx0ZXIgbG9jYXRpb25zLiBQYXNzIGBudWxsYFxuICogICB0byBub3QgZmlsdGVyIGJ5IHF1ZXJ5LlxuICogQHJldHVybnMgQW4gYXJyYXkgb2YgTG9jYXRpb24gb2JqZWN0cy4gUmV0dXJucyBhbiBlbXB0eSBhcnJheSB3aGlsZSBsb2FkaW5nXG4gKiAgIG9yIGlmIGFuIGVycm9yIG9jY3Vycy5cbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHN4XG4gKiBpbXBvcnQgeyB1c2VMb2NhdGlvbnMgfSBmcm9tICdAb3Blbm1ycy9lc20tZnJhbWV3b3JrJztcbiAqIGZ1bmN0aW9uIExvY2F0aW9uTGlzdCgpIHtcbiAqICAgY29uc3QgbG9jYXRpb25zID0gdXNlTG9jYXRpb25zKCdMb2dpbiBMb2NhdGlvbicpO1xuICogICByZXR1cm4gKFxuICogICAgIDx1bD5cbiAqICAgICAgIHtsb2NhdGlvbnMubWFwKChsb2MpID0+IDxsaSBrZXk9e2xvYy51dWlkfT57bG9jLmRpc3BsYXl9PC9saT4pfVxuICogICAgIDwvdWw+XG4gKiAgICk7XG4gKiB9XG4gKiBgYGBcbiAqLyBleHBvcnQgZnVuY3Rpb24gdXNlTG9jYXRpb25zKHRhZ1V1aWRPck5hbWUgPSBudWxsLCBxdWVyeSA9IG51bGwpIHtcbiAgICBjb25zdCBbbG9jYXRpb25zLCBzZXRMb2NhdGlvbnNdID0gdXNlU3RhdGUoW10pO1xuICAgIHVzZUVmZmVjdCgoKT0+e1xuICAgICAgICBjb25zdCBsb2NhdGlvblN1YiA9IGdldExvY2F0aW9ucyh0YWdVdWlkT3JOYW1lLCBxdWVyeSkuc3Vic2NyaWJlKChsb2NhdGlvbnMpPT57XG4gICAgICAgICAgICBzZXRMb2NhdGlvbnMobG9jYXRpb25zKTtcbiAgICAgICAgfSwgKGVycm9yKT0+e1xuICAgICAgICAgICAgY29uc29sZS5lcnJvcihlcnJvcik7XG4gICAgICAgIH0pO1xuICAgICAgICByZXR1cm4gKCk9PmxvY2F0aW9uU3ViLnVuc3Vic2NyaWJlKCk7XG4gICAgfSwgW1xuICAgICAgICB0YWdVdWlkT3JOYW1lLFxuICAgICAgICBxdWVyeVxuICAgIF0pO1xuICAgIHJldHVybiBsb2NhdGlvbnM7XG59XG4iXSwibmFtZXMiOlsidXNlU3RhdGUiLCJ1c2VFZmZlY3QiLCJnZXRMb2NhdGlvbnMiLCJ1c2VMb2NhdGlvbnMiLCJ0YWdVdWlkT3JOYW1lIiwicXVlcnkiLCJsb2NhdGlvbnMiLCJzZXRMb2NhdGlvbnMiLCJsb2NhdGlvblN1YiIsInN1YnNjcmliZSIsImVycm9yIiwiY29uc29sZSIsInVuc3Vic2NyaWJlIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/useLocations.js\n");
1119
1119
 
1120
1120
  /***/ }),
1121
1121
 
@@ -1125,7 +1125,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
1125
1125
  \*****************************************************************/
1126
1126
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
1127
1127
 
1128
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ useOnClickOutside: () => (/* binding */ useOnClickOutside)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/** @module @category UI */ \nfunction useOnClickOutside(handler, active = true) {\n const ref = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(null);\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(()=>{\n const listener = (event)=>{\n if (!active || !ref.current || !event.target || !(event.target instanceof Node)) {\n return;\n }\n if (ref.current.contains(event.target)) {\n return;\n }\n handler(event);\n };\n window.addEventListener(`mousedown`, listener);\n window.addEventListener(`touchstart`, listener);\n return ()=>{\n window.removeEventListener(`mousedown`, listener);\n window.removeEventListener(`touchstart`, listener);\n };\n }, [\n handler,\n active\n ]);\n return ref;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZU9uQ2xpY2tPdXRzaWRlLmpzIiwibWFwcGluZ3MiOiI7Ozs7O0FBQUEseUJBQXlCLEdBQTZDO0FBQy9ELFNBQVNFLGtCQUFrQkMsT0FBTyxFQUFFQyxTQUFTLElBQUk7SUFDcEQsTUFBTUMsTUFBTUwsNkNBQU1BLENBQUM7SUFDbkJDLGdEQUFTQSxDQUFDO1FBQ04sTUFBTUssV0FBVyxDQUFDQztZQUNkLElBQUksQ0FBQ0gsVUFBVSxDQUFDQyxJQUFJRyxPQUFPLElBQUksQ0FBQ0QsTUFBTUUsTUFBTSxJQUFJLENBQUVGLENBQUFBLE1BQU1FLE1BQU0sWUFBWUMsSUFBRyxHQUFJO2dCQUM3RTtZQUNKO1lBQ0EsSUFBSUwsSUFBSUcsT0FBTyxDQUFDRyxRQUFRLENBQUNKLE1BQU1FLE1BQU0sR0FBRztnQkFDcEM7WUFDSjtZQUNBTixRQUFRSTtRQUNaO1FBQ0FLLE9BQU9DLGdCQUFnQixDQUFDLENBQUMsU0FBUyxDQUFDLEVBQUVQO1FBQ3JDTSxPQUFPQyxnQkFBZ0IsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxFQUFFUDtRQUN0QyxPQUFPO1lBQ0hNLE9BQU9FLG1CQUFtQixDQUFDLENBQUMsU0FBUyxDQUFDLEVBQUVSO1lBQ3hDTSxPQUFPRSxtQkFBbUIsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxFQUFFUjtRQUM3QztJQUNKLEdBQUc7UUFDQ0g7UUFDQUM7S0FDSDtJQUNELE9BQU9DO0FBQ1giLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tcmVhY3QtdXRpbHMvZGlzdC91c2VPbkNsaWNrT3V0c2lkZS5qcz83Mzc0Il0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBAbW9kdWxlIEBjYXRlZ29yeSBVSSAqLyBpbXBvcnQgeyB1c2VSZWYsIHVzZUVmZmVjdCB9IGZyb20gXCJyZWFjdFwiO1xuZXhwb3J0IGZ1bmN0aW9uIHVzZU9uQ2xpY2tPdXRzaWRlKGhhbmRsZXIsIGFjdGl2ZSA9IHRydWUpIHtcbiAgICBjb25zdCByZWYgPSB1c2VSZWYobnVsbCk7XG4gICAgdXNlRWZmZWN0KCgpPT57XG4gICAgICAgIGNvbnN0IGxpc3RlbmVyID0gKGV2ZW50KT0+e1xuICAgICAgICAgICAgaWYgKCFhY3RpdmUgfHwgIXJlZi5jdXJyZW50IHx8ICFldmVudC50YXJnZXQgfHwgIShldmVudC50YXJnZXQgaW5zdGFuY2VvZiBOb2RlKSkge1xuICAgICAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGlmIChyZWYuY3VycmVudC5jb250YWlucyhldmVudC50YXJnZXQpKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgaGFuZGxlcihldmVudCk7XG4gICAgICAgIH07XG4gICAgICAgIHdpbmRvdy5hZGRFdmVudExpc3RlbmVyKGBtb3VzZWRvd25gLCBsaXN0ZW5lcik7XG4gICAgICAgIHdpbmRvdy5hZGRFdmVudExpc3RlbmVyKGB0b3VjaHN0YXJ0YCwgbGlzdGVuZXIpO1xuICAgICAgICByZXR1cm4gKCk9PntcbiAgICAgICAgICAgIHdpbmRvdy5yZW1vdmVFdmVudExpc3RlbmVyKGBtb3VzZWRvd25gLCBsaXN0ZW5lcik7XG4gICAgICAgICAgICB3aW5kb3cucmVtb3ZlRXZlbnRMaXN0ZW5lcihgdG91Y2hzdGFydGAsIGxpc3RlbmVyKTtcbiAgICAgICAgfTtcbiAgICB9LCBbXG4gICAgICAgIGhhbmRsZXIsXG4gICAgICAgIGFjdGl2ZVxuICAgIF0pO1xuICAgIHJldHVybiByZWY7XG59XG4iXSwibmFtZXMiOlsidXNlUmVmIiwidXNlRWZmZWN0IiwidXNlT25DbGlja091dHNpZGUiLCJoYW5kbGVyIiwiYWN0aXZlIiwicmVmIiwibGlzdGVuZXIiLCJldmVudCIsImN1cnJlbnQiLCJ0YXJnZXQiLCJOb2RlIiwiY29udGFpbnMiLCJ3aW5kb3ciLCJhZGRFdmVudExpc3RlbmVyIiwicmVtb3ZlRXZlbnRMaXN0ZW5lciJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/useOnClickOutside.js\n");
1128
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ useOnClickOutside: () => (/* binding */ useOnClickOutside)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/** @module @category UI */ \n/**\n * A React hook that detects clicks outside of a referenced element. Useful for\n * implementing dropdown menus, modals, or any component that should close when\n * clicking outside of it.\n *\n * @typeParam T The type of HTML element the ref will be attached to.\n * @param handler A callback function invoked when a click occurs outside the\n * referenced element.\n * @param active Whether the outside click detection is active. Defaults to `true`.\n * Set to `false` to temporarily disable the detection.\n * @returns A React ref object to attach to the element you want to detect\n * outside clicks for.\n *\n * @example\n * ```tsx\n * import { useOnClickOutside } from '@openmrs/esm-framework';\n * function Dropdown() {\n * const [isOpen, setIsOpen] = useState(false);\n * const ref = useOnClickOutside<HTMLDivElement>(() => setIsOpen(false), isOpen);\n * return (\n * <div ref={ref}>\n * {isOpen && <ul>...</ul>}\n * </div>\n * );\n * }\n * ```\n */ function useOnClickOutside(handler, active = true) {\n const ref = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(null);\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(()=>{\n const listener = (event)=>{\n if (!active || !ref.current || !event.target || !(event.target instanceof Node)) {\n return;\n }\n if (ref.current.contains(event.target)) {\n return;\n }\n handler(event);\n };\n window.addEventListener(`mousedown`, listener);\n window.addEventListener(`touchstart`, listener);\n return ()=>{\n window.removeEventListener(`mousedown`, listener);\n window.removeEventListener(`touchstart`, listener);\n };\n }, [\n handler,\n active\n ]);\n return ref;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZU9uQ2xpY2tPdXRzaWRlLmpzIiwibWFwcGluZ3MiOiI7Ozs7O0FBQUEseUJBQXlCLEdBQTZDO0FBQ3RFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztDQTBCQyxHQUFVLFNBQVNFLGtCQUFrQkMsT0FBTyxFQUFFQyxTQUFTLElBQUk7SUFDeEQsTUFBTUMsTUFBTUwsNkNBQU1BLENBQUM7SUFDbkJDLGdEQUFTQSxDQUFDO1FBQ04sTUFBTUssV0FBVyxDQUFDQztZQUNkLElBQUksQ0FBQ0gsVUFBVSxDQUFDQyxJQUFJRyxPQUFPLElBQUksQ0FBQ0QsTUFBTUUsTUFBTSxJQUFJLENBQUVGLENBQUFBLE1BQU1FLE1BQU0sWUFBWUMsSUFBRyxHQUFJO2dCQUM3RTtZQUNKO1lBQ0EsSUFBSUwsSUFBSUcsT0FBTyxDQUFDRyxRQUFRLENBQUNKLE1BQU1FLE1BQU0sR0FBRztnQkFDcEM7WUFDSjtZQUNBTixRQUFRSTtRQUNaO1FBQ0FLLE9BQU9DLGdCQUFnQixDQUFDLENBQUMsU0FBUyxDQUFDLEVBQUVQO1FBQ3JDTSxPQUFPQyxnQkFBZ0IsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxFQUFFUDtRQUN0QyxPQUFPO1lBQ0hNLE9BQU9FLG1CQUFtQixDQUFDLENBQUMsU0FBUyxDQUFDLEVBQUVSO1lBQ3hDTSxPQUFPRSxtQkFBbUIsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxFQUFFUjtRQUM3QztJQUNKLEdBQUc7UUFDQ0g7UUFDQUM7S0FDSDtJQUNELE9BQU9DO0FBQ1giLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tcmVhY3QtdXRpbHMvZGlzdC91c2VPbkNsaWNrT3V0c2lkZS5qcz83Mzc0Il0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBAbW9kdWxlIEBjYXRlZ29yeSBVSSAqLyBpbXBvcnQgeyB1c2VSZWYsIHVzZUVmZmVjdCB9IGZyb20gXCJyZWFjdFwiO1xuLyoqXG4gKiBBIFJlYWN0IGhvb2sgdGhhdCBkZXRlY3RzIGNsaWNrcyBvdXRzaWRlIG9mIGEgcmVmZXJlbmNlZCBlbGVtZW50LiBVc2VmdWwgZm9yXG4gKiBpbXBsZW1lbnRpbmcgZHJvcGRvd24gbWVudXMsIG1vZGFscywgb3IgYW55IGNvbXBvbmVudCB0aGF0IHNob3VsZCBjbG9zZSB3aGVuXG4gKiBjbGlja2luZyBvdXRzaWRlIG9mIGl0LlxuICpcbiAqIEB0eXBlUGFyYW0gVCBUaGUgdHlwZSBvZiBIVE1MIGVsZW1lbnQgdGhlIHJlZiB3aWxsIGJlIGF0dGFjaGVkIHRvLlxuICogQHBhcmFtIGhhbmRsZXIgQSBjYWxsYmFjayBmdW5jdGlvbiBpbnZva2VkIHdoZW4gYSBjbGljayBvY2N1cnMgb3V0c2lkZSB0aGVcbiAqICAgcmVmZXJlbmNlZCBlbGVtZW50LlxuICogQHBhcmFtIGFjdGl2ZSBXaGV0aGVyIHRoZSBvdXRzaWRlIGNsaWNrIGRldGVjdGlvbiBpcyBhY3RpdmUuIERlZmF1bHRzIHRvIGB0cnVlYC5cbiAqICAgU2V0IHRvIGBmYWxzZWAgdG8gdGVtcG9yYXJpbHkgZGlzYWJsZSB0aGUgZGV0ZWN0aW9uLlxuICogQHJldHVybnMgQSBSZWFjdCByZWYgb2JqZWN0IHRvIGF0dGFjaCB0byB0aGUgZWxlbWVudCB5b3Ugd2FudCB0byBkZXRlY3RcbiAqICAgb3V0c2lkZSBjbGlja3MgZm9yLlxuICpcbiAqIEBleGFtcGxlXG4gKiBgYGB0c3hcbiAqIGltcG9ydCB7IHVzZU9uQ2xpY2tPdXRzaWRlIH0gZnJvbSAnQG9wZW5tcnMvZXNtLWZyYW1ld29yayc7XG4gKiBmdW5jdGlvbiBEcm9wZG93bigpIHtcbiAqICAgY29uc3QgW2lzT3Blbiwgc2V0SXNPcGVuXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAqICAgY29uc3QgcmVmID0gdXNlT25DbGlja091dHNpZGU8SFRNTERpdkVsZW1lbnQ+KCgpID0+IHNldElzT3BlbihmYWxzZSksIGlzT3Blbik7XG4gKiAgIHJldHVybiAoXG4gKiAgICAgPGRpdiByZWY9e3JlZn0+XG4gKiAgICAgICB7aXNPcGVuICYmIDx1bD4uLi48L3VsPn1cbiAqICAgICA8L2Rpdj5cbiAqICAgKTtcbiAqIH1cbiAqIGBgYFxuICovIGV4cG9ydCBmdW5jdGlvbiB1c2VPbkNsaWNrT3V0c2lkZShoYW5kbGVyLCBhY3RpdmUgPSB0cnVlKSB7XG4gICAgY29uc3QgcmVmID0gdXNlUmVmKG51bGwpO1xuICAgIHVzZUVmZmVjdCgoKT0+e1xuICAgICAgICBjb25zdCBsaXN0ZW5lciA9IChldmVudCk9PntcbiAgICAgICAgICAgIGlmICghYWN0aXZlIHx8ICFyZWYuY3VycmVudCB8fCAhZXZlbnQudGFyZ2V0IHx8ICEoZXZlbnQudGFyZ2V0IGluc3RhbmNlb2YgTm9kZSkpIHtcbiAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBpZiAocmVmLmN1cnJlbnQuY29udGFpbnMoZXZlbnQudGFyZ2V0KSkge1xuICAgICAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGhhbmRsZXIoZXZlbnQpO1xuICAgICAgICB9O1xuICAgICAgICB3aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcihgbW91c2Vkb3duYCwgbGlzdGVuZXIpO1xuICAgICAgICB3aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcihgdG91Y2hzdGFydGAsIGxpc3RlbmVyKTtcbiAgICAgICAgcmV0dXJuICgpPT57XG4gICAgICAgICAgICB3aW5kb3cucmVtb3ZlRXZlbnRMaXN0ZW5lcihgbW91c2Vkb3duYCwgbGlzdGVuZXIpO1xuICAgICAgICAgICAgd2luZG93LnJlbW92ZUV2ZW50TGlzdGVuZXIoYHRvdWNoc3RhcnRgLCBsaXN0ZW5lcik7XG4gICAgICAgIH07XG4gICAgfSwgW1xuICAgICAgICBoYW5kbGVyLFxuICAgICAgICBhY3RpdmVcbiAgICBdKTtcbiAgICByZXR1cm4gcmVmO1xufVxuIl0sIm5hbWVzIjpbInVzZVJlZiIsInVzZUVmZmVjdCIsInVzZU9uQ2xpY2tPdXRzaWRlIiwiaGFuZGxlciIsImFjdGl2ZSIsInJlZiIsImxpc3RlbmVyIiwiZXZlbnQiLCJjdXJyZW50IiwidGFyZ2V0IiwiTm9kZSIsImNvbnRhaW5zIiwid2luZG93IiwiYWRkRXZlbnRMaXN0ZW5lciIsInJlbW92ZUV2ZW50TGlzdGVuZXIiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/useOnClickOutside.js\n");
1129
1129
 
1130
1130
  /***/ }),
1131
1131
 
@@ -1205,7 +1205,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
1205
1205
  \**********************************************************/
1206
1206
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
1207
1207
 
1208
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ usePatient: () => (/* binding */ usePatient)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var swr__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! swr */ \"../../../node_modules/swr/dist/core/index.mjs\");\n/* harmony import */ var _openmrs_esm_emr_api__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @openmrs/esm-emr-api */ \"../../framework/esm-emr-api/dist/index.js\");\n/** @module @category API */ \n\n\nfunction getPatientUuidFromUrl() {\n const match = /\\/patient\\/([a-zA-Z0-9\\-]+)\\/?/.exec(location.pathname);\n return match && match[1];\n}\n/**\n * This React hook returns a patient object. If the `patientUuid` is provided\n * as a parameter, then the patient for that UUID is returned. If the parameter\n * is not provided, the patient UUID is obtained from the current route, and\n * a route listener is set up to update the patient whenever the route changes.\n */ function usePatient(patientUuid) {\n const [currentPatientUuid, setCurrentPatientUuid] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(patientUuid ?? getPatientUuidFromUrl());\n const { data: patient, error, isValidating } = (0,swr__WEBPACK_IMPORTED_MODULE_1__[\"default\"])(currentPatientUuid ? [\n 'patient',\n currentPatientUuid\n ] : null, ()=>(0,_openmrs_esm_emr_api__WEBPACK_IMPORTED_MODULE_2__.fetchCurrentPatient)(currentPatientUuid, {}));\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(()=>{\n const handleRouteUpdate = ()=>{\n const newPatientUuid = getPatientUuidFromUrl();\n if (newPatientUuid !== currentPatientUuid) {\n setCurrentPatientUuid(newPatientUuid);\n }\n };\n window.addEventListener('single-spa:routing-event', handleRouteUpdate);\n return ()=>window.removeEventListener('single-spa:routing-event', handleRouteUpdate);\n }, [\n currentPatientUuid\n ]);\n return (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(()=>({\n isLoading: isValidating && !error && !patient,\n patient,\n patientUuid: currentPatientUuid,\n error\n }), [\n isValidating,\n error,\n patient,\n currentPatientUuid\n ]);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZVBhdGllbnQuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBLDBCQUEwQixHQUF3RDtBQUN6RDtBQUNrQztBQUMzRCxTQUFTSztJQUNMLE1BQU1DLFFBQVEsaUNBQWlDQyxJQUFJLENBQUNDLFNBQVNDLFFBQVE7SUFDckUsT0FBT0gsU0FBU0EsS0FBSyxDQUFDLEVBQUU7QUFDNUI7QUFDQTs7Ozs7Q0FLQyxHQUFVLFNBQVNJLFdBQVdDLFdBQVc7SUFDdEMsTUFBTSxDQUFDQyxvQkFBb0JDLHNCQUFzQixHQUFHWCwrQ0FBUUEsQ0FBQ1MsZUFBZU47SUFDNUUsTUFBTSxFQUFFUyxNQUFNQyxPQUFPLEVBQUVDLEtBQUssRUFBRUMsWUFBWSxFQUFFLEdBQUdkLCtDQUFNQSxDQUFDUyxxQkFBcUI7UUFDdkU7UUFDQUE7S0FDSCxHQUFHLE1BQU0sSUFBSVIseUVBQW1CQSxDQUFDUSxvQkFBb0IsQ0FBQztJQUN2RFosZ0RBQVNBLENBQUM7UUFDTixNQUFNa0Isb0JBQW9CO1lBQ3RCLE1BQU1DLGlCQUFpQmQ7WUFDdkIsSUFBSWMsbUJBQW1CUCxvQkFBb0I7Z0JBQ3ZDQyxzQkFBc0JNO1lBQzFCO1FBQ0o7UUFDQUMsT0FBT0MsZ0JBQWdCLENBQUMsNEJBQTRCSDtRQUNwRCxPQUFPLElBQUlFLE9BQU9FLG1CQUFtQixDQUFDLDRCQUE0Qko7SUFDdEUsR0FBRztRQUNDTjtLQUNIO0lBQ0QsT0FBT1gsOENBQU9BLENBQUMsSUFBSztZQUNac0IsV0FBV04sZ0JBQWdCLENBQUNELFNBQVMsQ0FBQ0Q7WUFDdENBO1lBQ0FKLGFBQWFDO1lBQ2JJO1FBQ0osSUFBSTtRQUNKQztRQUNBRDtRQUNBRDtRQUNBSDtLQUNIO0FBQ0wiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tcmVhY3QtdXRpbHMvZGlzdC91c2VQYXRpZW50LmpzPzY0ZTQiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBtb2R1bGUgQGNhdGVnb3J5IEFQSSAqLyBpbXBvcnQgeyB1c2VFZmZlY3QsIHVzZU1lbW8sIHVzZVN0YXRlIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdXNlU1dSIGZyb20gXCJzd3JcIjtcbmltcG9ydCB7IGZldGNoQ3VycmVudFBhdGllbnQgfSBmcm9tIFwiQG9wZW5tcnMvZXNtLWVtci1hcGlcIjtcbmZ1bmN0aW9uIGdldFBhdGllbnRVdWlkRnJvbVVybCgpIHtcbiAgICBjb25zdCBtYXRjaCA9IC9cXC9wYXRpZW50XFwvKFthLXpBLVowLTlcXC1dKylcXC8/Ly5leGVjKGxvY2F0aW9uLnBhdGhuYW1lKTtcbiAgICByZXR1cm4gbWF0Y2ggJiYgbWF0Y2hbMV07XG59XG4vKipcbiAqIFRoaXMgUmVhY3QgaG9vayByZXR1cm5zIGEgcGF0aWVudCBvYmplY3QuIElmIHRoZSBgcGF0aWVudFV1aWRgIGlzIHByb3ZpZGVkXG4gKiBhcyBhIHBhcmFtZXRlciwgdGhlbiB0aGUgcGF0aWVudCBmb3IgdGhhdCBVVUlEIGlzIHJldHVybmVkLiBJZiB0aGUgcGFyYW1ldGVyXG4gKiBpcyBub3QgcHJvdmlkZWQsIHRoZSBwYXRpZW50IFVVSUQgaXMgb2J0YWluZWQgZnJvbSB0aGUgY3VycmVudCByb3V0ZSwgYW5kXG4gKiBhIHJvdXRlIGxpc3RlbmVyIGlzIHNldCB1cCB0byB1cGRhdGUgdGhlIHBhdGllbnQgd2hlbmV2ZXIgdGhlIHJvdXRlIGNoYW5nZXMuXG4gKi8gZXhwb3J0IGZ1bmN0aW9uIHVzZVBhdGllbnQocGF0aWVudFV1aWQpIHtcbiAgICBjb25zdCBbY3VycmVudFBhdGllbnRVdWlkLCBzZXRDdXJyZW50UGF0aWVudFV1aWRdID0gdXNlU3RhdGUocGF0aWVudFV1aWQgPz8gZ2V0UGF0aWVudFV1aWRGcm9tVXJsKCkpO1xuICAgIGNvbnN0IHsgZGF0YTogcGF0aWVudCwgZXJyb3IsIGlzVmFsaWRhdGluZyB9ID0gdXNlU1dSKGN1cnJlbnRQYXRpZW50VXVpZCA/IFtcbiAgICAgICAgJ3BhdGllbnQnLFxuICAgICAgICBjdXJyZW50UGF0aWVudFV1aWRcbiAgICBdIDogbnVsbCwgKCk9PmZldGNoQ3VycmVudFBhdGllbnQoY3VycmVudFBhdGllbnRVdWlkLCB7fSkpO1xuICAgIHVzZUVmZmVjdCgoKT0+e1xuICAgICAgICBjb25zdCBoYW5kbGVSb3V0ZVVwZGF0ZSA9ICgpPT57XG4gICAgICAgICAgICBjb25zdCBuZXdQYXRpZW50VXVpZCA9IGdldFBhdGllbnRVdWlkRnJvbVVybCgpO1xuICAgICAgICAgICAgaWYgKG5ld1BhdGllbnRVdWlkICE9PSBjdXJyZW50UGF0aWVudFV1aWQpIHtcbiAgICAgICAgICAgICAgICBzZXRDdXJyZW50UGF0aWVudFV1aWQobmV3UGF0aWVudFV1aWQpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9O1xuICAgICAgICB3aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcignc2luZ2xlLXNwYTpyb3V0aW5nLWV2ZW50JywgaGFuZGxlUm91dGVVcGRhdGUpO1xuICAgICAgICByZXR1cm4gKCk9PndpbmRvdy5yZW1vdmVFdmVudExpc3RlbmVyKCdzaW5nbGUtc3BhOnJvdXRpbmctZXZlbnQnLCBoYW5kbGVSb3V0ZVVwZGF0ZSk7XG4gICAgfSwgW1xuICAgICAgICBjdXJyZW50UGF0aWVudFV1aWRcbiAgICBdKTtcbiAgICByZXR1cm4gdXNlTWVtbygoKT0+KHtcbiAgICAgICAgICAgIGlzTG9hZGluZzogaXNWYWxpZGF0aW5nICYmICFlcnJvciAmJiAhcGF0aWVudCxcbiAgICAgICAgICAgIHBhdGllbnQsXG4gICAgICAgICAgICBwYXRpZW50VXVpZDogY3VycmVudFBhdGllbnRVdWlkLFxuICAgICAgICAgICAgZXJyb3JcbiAgICAgICAgfSksIFtcbiAgICAgICAgaXNWYWxpZGF0aW5nLFxuICAgICAgICBlcnJvcixcbiAgICAgICAgcGF0aWVudCxcbiAgICAgICAgY3VycmVudFBhdGllbnRVdWlkXG4gICAgXSk7XG59XG4iXSwibmFtZXMiOlsidXNlRWZmZWN0IiwidXNlTWVtbyIsInVzZVN0YXRlIiwidXNlU1dSIiwiZmV0Y2hDdXJyZW50UGF0aWVudCIsImdldFBhdGllbnRVdWlkRnJvbVVybCIsIm1hdGNoIiwiZXhlYyIsImxvY2F0aW9uIiwicGF0aG5hbWUiLCJ1c2VQYXRpZW50IiwicGF0aWVudFV1aWQiLCJjdXJyZW50UGF0aWVudFV1aWQiLCJzZXRDdXJyZW50UGF0aWVudFV1aWQiLCJkYXRhIiwicGF0aWVudCIsImVycm9yIiwiaXNWYWxpZGF0aW5nIiwiaGFuZGxlUm91dGVVcGRhdGUiLCJuZXdQYXRpZW50VXVpZCIsIndpbmRvdyIsImFkZEV2ZW50TGlzdGVuZXIiLCJyZW1vdmVFdmVudExpc3RlbmVyIiwiaXNMb2FkaW5nIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/usePatient.js\n");
1208
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ usePatient: () => (/* binding */ usePatient)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var swr__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! swr */ \"../../../node_modules/swr/dist/core/index.mjs\");\n/* harmony import */ var _openmrs_esm_emr_api__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @openmrs/esm-emr-api */ \"../../framework/esm-emr-api/dist/index.js\");\n/** @module @category API */ \n\n\nfunction getPatientUuidFromUrl() {\n const match = /\\/patient\\/([a-zA-Z0-9\\-]+)\\/?/.exec(location.pathname);\n return match && match[1];\n}\n/**\n * This React hook returns a patient object. If the `patientUuid` is provided\n * as a parameter, then the patient for that UUID is returned. If the parameter\n * is not provided, the patient UUID is obtained from the current route, and\n * a route listener is set up to update the patient whenever the route changes.\n *\n * @param patientUuid Optional UUID of the patient to fetch. If not provided,\n * the UUID is extracted from the current URL path.\n * @returns An object containing the patient data, loading state, current patient UUID, and any error.\n *\n */ function usePatient(patientUuid) {\n const [currentPatientUuid, setCurrentPatientUuid] = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(patientUuid ?? getPatientUuidFromUrl());\n const { data: patient, error, isValidating } = (0,swr__WEBPACK_IMPORTED_MODULE_1__[\"default\"])(currentPatientUuid ? [\n 'patient',\n currentPatientUuid\n ] : null, ()=>(0,_openmrs_esm_emr_api__WEBPACK_IMPORTED_MODULE_2__.fetchCurrentPatient)(currentPatientUuid, {}));\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(()=>{\n const handleRouteUpdate = ()=>{\n const newPatientUuid = getPatientUuidFromUrl();\n if (newPatientUuid !== currentPatientUuid) {\n setCurrentPatientUuid(newPatientUuid);\n }\n };\n window.addEventListener('single-spa:routing-event', handleRouteUpdate);\n return ()=>window.removeEventListener('single-spa:routing-event', handleRouteUpdate);\n }, [\n currentPatientUuid\n ]);\n return (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(()=>({\n isLoading: isValidating && !error && !patient,\n patient,\n patientUuid: currentPatientUuid,\n error\n }), [\n isValidating,\n error,\n patient,\n currentPatientUuid\n ]);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZVBhdGllbnQuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBLDBCQUEwQixHQUF3RDtBQUN6RDtBQUNrQztBQUMzRCxTQUFTSztJQUNMLE1BQU1DLFFBQVEsaUNBQWlDQyxJQUFJLENBQUNDLFNBQVNDLFFBQVE7SUFDckUsT0FBT0gsU0FBU0EsS0FBSyxDQUFDLEVBQUU7QUFDNUI7QUFDQTs7Ozs7Ozs7OztDQVVDLEdBQVUsU0FBU0ksV0FBV0MsV0FBVztJQUN0QyxNQUFNLENBQUNDLG9CQUFvQkMsc0JBQXNCLEdBQUdYLCtDQUFRQSxDQUFDUyxlQUFlTjtJQUM1RSxNQUFNLEVBQUVTLE1BQU1DLE9BQU8sRUFBRUMsS0FBSyxFQUFFQyxZQUFZLEVBQUUsR0FBR2QsK0NBQU1BLENBQUNTLHFCQUFxQjtRQUN2RTtRQUNBQTtLQUNILEdBQUcsTUFBTSxJQUFJUix5RUFBbUJBLENBQUNRLG9CQUFvQixDQUFDO0lBQ3ZEWixnREFBU0EsQ0FBQztRQUNOLE1BQU1rQixvQkFBb0I7WUFDdEIsTUFBTUMsaUJBQWlCZDtZQUN2QixJQUFJYyxtQkFBbUJQLG9CQUFvQjtnQkFDdkNDLHNCQUFzQk07WUFDMUI7UUFDSjtRQUNBQyxPQUFPQyxnQkFBZ0IsQ0FBQyw0QkFBNEJIO1FBQ3BELE9BQU8sSUFBSUUsT0FBT0UsbUJBQW1CLENBQUMsNEJBQTRCSjtJQUN0RSxHQUFHO1FBQ0NOO0tBQ0g7SUFDRCxPQUFPWCw4Q0FBT0EsQ0FBQyxJQUFLO1lBQ1pzQixXQUFXTixnQkFBZ0IsQ0FBQ0QsU0FBUyxDQUFDRDtZQUN0Q0E7WUFDQUosYUFBYUM7WUFDYkk7UUFDSixJQUFJO1FBQ0pDO1FBQ0FEO1FBQ0FEO1FBQ0FIO0tBQ0g7QUFDTCIsInNvdXJjZXMiOlsid2VicGFjazovL0BvcGVubXJzL2VzbS1hcHAtc2hlbGwvLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZVBhdGllbnQuanM/NjRlNCJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQG1vZHVsZSBAY2F0ZWdvcnkgQVBJICovIGltcG9ydCB7IHVzZUVmZmVjdCwgdXNlTWVtbywgdXNlU3RhdGUgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB1c2VTV1IgZnJvbSBcInN3clwiO1xuaW1wb3J0IHsgZmV0Y2hDdXJyZW50UGF0aWVudCB9IGZyb20gXCJAb3Blbm1ycy9lc20tZW1yLWFwaVwiO1xuZnVuY3Rpb24gZ2V0UGF0aWVudFV1aWRGcm9tVXJsKCkge1xuICAgIGNvbnN0IG1hdGNoID0gL1xcL3BhdGllbnRcXC8oW2EtekEtWjAtOVxcLV0rKVxcLz8vLmV4ZWMobG9jYXRpb24ucGF0aG5hbWUpO1xuICAgIHJldHVybiBtYXRjaCAmJiBtYXRjaFsxXTtcbn1cbi8qKlxuICogVGhpcyBSZWFjdCBob29rIHJldHVybnMgYSBwYXRpZW50IG9iamVjdC4gSWYgdGhlIGBwYXRpZW50VXVpZGAgaXMgcHJvdmlkZWRcbiAqIGFzIGEgcGFyYW1ldGVyLCB0aGVuIHRoZSBwYXRpZW50IGZvciB0aGF0IFVVSUQgaXMgcmV0dXJuZWQuIElmIHRoZSBwYXJhbWV0ZXJcbiAqIGlzIG5vdCBwcm92aWRlZCwgdGhlIHBhdGllbnQgVVVJRCBpcyBvYnRhaW5lZCBmcm9tIHRoZSBjdXJyZW50IHJvdXRlLCBhbmRcbiAqIGEgcm91dGUgbGlzdGVuZXIgaXMgc2V0IHVwIHRvIHVwZGF0ZSB0aGUgcGF0aWVudCB3aGVuZXZlciB0aGUgcm91dGUgY2hhbmdlcy5cbiAqXG4gKiBAcGFyYW0gcGF0aWVudFV1aWQgT3B0aW9uYWwgVVVJRCBvZiB0aGUgcGF0aWVudCB0byBmZXRjaC4gSWYgbm90IHByb3ZpZGVkLFxuICogICB0aGUgVVVJRCBpcyBleHRyYWN0ZWQgZnJvbSB0aGUgY3VycmVudCBVUkwgcGF0aC5cbiAqIEByZXR1cm5zIEFuIG9iamVjdCBjb250YWluaW5nIHRoZSBwYXRpZW50IGRhdGEsIGxvYWRpbmcgc3RhdGUsIGN1cnJlbnQgcGF0aWVudCBVVUlELCBhbmQgYW55IGVycm9yLlxuICpcbiAqLyBleHBvcnQgZnVuY3Rpb24gdXNlUGF0aWVudChwYXRpZW50VXVpZCkge1xuICAgIGNvbnN0IFtjdXJyZW50UGF0aWVudFV1aWQsIHNldEN1cnJlbnRQYXRpZW50VXVpZF0gPSB1c2VTdGF0ZShwYXRpZW50VXVpZCA/PyBnZXRQYXRpZW50VXVpZEZyb21VcmwoKSk7XG4gICAgY29uc3QgeyBkYXRhOiBwYXRpZW50LCBlcnJvciwgaXNWYWxpZGF0aW5nIH0gPSB1c2VTV1IoY3VycmVudFBhdGllbnRVdWlkID8gW1xuICAgICAgICAncGF0aWVudCcsXG4gICAgICAgIGN1cnJlbnRQYXRpZW50VXVpZFxuICAgIF0gOiBudWxsLCAoKT0+ZmV0Y2hDdXJyZW50UGF0aWVudChjdXJyZW50UGF0aWVudFV1aWQsIHt9KSk7XG4gICAgdXNlRWZmZWN0KCgpPT57XG4gICAgICAgIGNvbnN0IGhhbmRsZVJvdXRlVXBkYXRlID0gKCk9PntcbiAgICAgICAgICAgIGNvbnN0IG5ld1BhdGllbnRVdWlkID0gZ2V0UGF0aWVudFV1aWRGcm9tVXJsKCk7XG4gICAgICAgICAgICBpZiAobmV3UGF0aWVudFV1aWQgIT09IGN1cnJlbnRQYXRpZW50VXVpZCkge1xuICAgICAgICAgICAgICAgIHNldEN1cnJlbnRQYXRpZW50VXVpZChuZXdQYXRpZW50VXVpZCk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH07XG4gICAgICAgIHdpbmRvdy5hZGRFdmVudExpc3RlbmVyKCdzaW5nbGUtc3BhOnJvdXRpbmctZXZlbnQnLCBoYW5kbGVSb3V0ZVVwZGF0ZSk7XG4gICAgICAgIHJldHVybiAoKT0+d2luZG93LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ3NpbmdsZS1zcGE6cm91dGluZy1ldmVudCcsIGhhbmRsZVJvdXRlVXBkYXRlKTtcbiAgICB9LCBbXG4gICAgICAgIGN1cnJlbnRQYXRpZW50VXVpZFxuICAgIF0pO1xuICAgIHJldHVybiB1c2VNZW1vKCgpPT4oe1xuICAgICAgICAgICAgaXNMb2FkaW5nOiBpc1ZhbGlkYXRpbmcgJiYgIWVycm9yICYmICFwYXRpZW50LFxuICAgICAgICAgICAgcGF0aWVudCxcbiAgICAgICAgICAgIHBhdGllbnRVdWlkOiBjdXJyZW50UGF0aWVudFV1aWQsXG4gICAgICAgICAgICBlcnJvclxuICAgICAgICB9KSwgW1xuICAgICAgICBpc1ZhbGlkYXRpbmcsXG4gICAgICAgIGVycm9yLFxuICAgICAgICBwYXRpZW50LFxuICAgICAgICBjdXJyZW50UGF0aWVudFV1aWRcbiAgICBdKTtcbn1cbiJdLCJuYW1lcyI6WyJ1c2VFZmZlY3QiLCJ1c2VNZW1vIiwidXNlU3RhdGUiLCJ1c2VTV1IiLCJmZXRjaEN1cnJlbnRQYXRpZW50IiwiZ2V0UGF0aWVudFV1aWRGcm9tVXJsIiwibWF0Y2giLCJleGVjIiwibG9jYXRpb24iLCJwYXRobmFtZSIsInVzZVBhdGllbnQiLCJwYXRpZW50VXVpZCIsImN1cnJlbnRQYXRpZW50VXVpZCIsInNldEN1cnJlbnRQYXRpZW50VXVpZCIsImRhdGEiLCJwYXRpZW50IiwiZXJyb3IiLCJpc1ZhbGlkYXRpbmciLCJoYW5kbGVSb3V0ZVVwZGF0ZSIsIm5ld1BhdGllbnRVdWlkIiwid2luZG93IiwiYWRkRXZlbnRMaXN0ZW5lciIsInJlbW92ZUV2ZW50TGlzdGVuZXIiLCJpc0xvYWRpbmciXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/usePatient.js\n");
1209
1209
 
1210
1210
  /***/ }),
1211
1211
 
@@ -1215,7 +1215,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
1215
1215
  \****************************************************************************/
1216
1216
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
1217
1217
 
1218
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ usePrimaryIdentifierCode: () => (/* binding */ usePrimaryIdentifierCode)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var swr__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! swr */ \"../../../node_modules/swr/dist/core/index.mjs\");\n/* harmony import */ var _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @openmrs/esm-api */ \"../../framework/esm-api/dist/index.js\");\n/** @module @category API */ \n\n\nfunction usePrimaryIdentifierCode() {\n const url = `${_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_2__.restBaseUrl}/metadatamapping/termmapping?v=custom:(metadataUuid)&code=emr.primaryIdentifierType`;\n const { data, error, isLoading } = (0,swr__WEBPACK_IMPORTED_MODULE_1__[\"default\"])(url, _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_2__.openmrsFetch);\n const results = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(()=>({\n primaryIdentifierCode: data?.data?.results[0]?.metadataUuid,\n isLoading,\n error\n }), [\n data,\n error,\n isLoading\n ]);\n return results;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZVByaW1hcnlJZGVudGlmaWVyUmVzb3VyY2UuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBLDBCQUEwQixHQUFtQztBQUNwQztBQUNvQztBQUN0RCxTQUFTSTtJQUNaLE1BQU1DLE1BQU0sR0FBR0YseURBQVdBLENBQUMsbUZBQW1GLENBQUM7SUFDL0csTUFBTSxFQUFFRyxJQUFJLEVBQUVDLEtBQUssRUFBRUMsU0FBUyxFQUFFLEdBQUdQLCtDQUFNQSxDQUFDSSxLQUFLSCwwREFBWUE7SUFDM0QsTUFBTU8sVUFBVVQsOENBQU9BLENBQUMsSUFBSztZQUNyQlUsdUJBQXVCSixNQUFNQSxNQUFNRyxPQUFPLENBQUMsRUFBRSxFQUFFRTtZQUMvQ0g7WUFDQUQ7UUFDSixJQUFJO1FBQ0pEO1FBQ0FDO1FBQ0FDO0tBQ0g7SUFDRCxPQUFPQztBQUNYIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQG9wZW5tcnMvZXNtLWFwcC1zaGVsbC8uLi8uLi9mcmFtZXdvcmsvZXNtLXJlYWN0LXV0aWxzL2Rpc3QvdXNlUHJpbWFyeUlkZW50aWZpZXJSZXNvdXJjZS5qcz84MzY5Il0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBAbW9kdWxlIEBjYXRlZ29yeSBBUEkgKi8gaW1wb3J0IHsgdXNlTWVtbyB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHVzZVNXUiBmcm9tIFwic3dyXCI7XG5pbXBvcnQgeyBvcGVubXJzRmV0Y2gsIHJlc3RCYXNlVXJsIH0gZnJvbSBcIkBvcGVubXJzL2VzbS1hcGlcIjtcbmV4cG9ydCBmdW5jdGlvbiB1c2VQcmltYXJ5SWRlbnRpZmllckNvZGUoKSB7XG4gICAgY29uc3QgdXJsID0gYCR7cmVzdEJhc2VVcmx9L21ldGFkYXRhbWFwcGluZy90ZXJtbWFwcGluZz92PWN1c3RvbToobWV0YWRhdGFVdWlkKSZjb2RlPWVtci5wcmltYXJ5SWRlbnRpZmllclR5cGVgO1xuICAgIGNvbnN0IHsgZGF0YSwgZXJyb3IsIGlzTG9hZGluZyB9ID0gdXNlU1dSKHVybCwgb3Blbm1yc0ZldGNoKTtcbiAgICBjb25zdCByZXN1bHRzID0gdXNlTWVtbygoKT0+KHtcbiAgICAgICAgICAgIHByaW1hcnlJZGVudGlmaWVyQ29kZTogZGF0YT8uZGF0YT8ucmVzdWx0c1swXT8ubWV0YWRhdGFVdWlkLFxuICAgICAgICAgICAgaXNMb2FkaW5nLFxuICAgICAgICAgICAgZXJyb3JcbiAgICAgICAgfSksIFtcbiAgICAgICAgZGF0YSxcbiAgICAgICAgZXJyb3IsXG4gICAgICAgIGlzTG9hZGluZ1xuICAgIF0pO1xuICAgIHJldHVybiByZXN1bHRzO1xufVxuIl0sIm5hbWVzIjpbInVzZU1lbW8iLCJ1c2VTV1IiLCJvcGVubXJzRmV0Y2giLCJyZXN0QmFzZVVybCIsInVzZVByaW1hcnlJZGVudGlmaWVyQ29kZSIsInVybCIsImRhdGEiLCJlcnJvciIsImlzTG9hZGluZyIsInJlc3VsdHMiLCJwcmltYXJ5SWRlbnRpZmllckNvZGUiLCJtZXRhZGF0YVV1aWQiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/usePrimaryIdentifierResource.js\n");
1218
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ usePrimaryIdentifierCode: () => (/* binding */ usePrimaryIdentifierCode)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var swr__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! swr */ \"../../../node_modules/swr/dist/core/index.mjs\");\n/* harmony import */ var _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @openmrs/esm-api */ \"../../framework/esm-api/dist/index.js\");\n/** @module @category API */ \n\n\n/**\n * A React hook that retrieves the UUID of the primary patient identifier type\n * from the metadata mapping configuration. This identifier type is commonly used\n * to display the main identifier for a patient, such as their medical record number.\n *\n * @returns An object containing the primary identifier type UUID, loading state, and any error.\n *\n */ function usePrimaryIdentifierCode() {\n const url = `${_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_2__.restBaseUrl}/metadatamapping/termmapping?v=custom:(metadataUuid)&code=emr.primaryIdentifierType`;\n const { data, error, isLoading } = (0,swr__WEBPACK_IMPORTED_MODULE_1__[\"default\"])(url, _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_2__.openmrsFetch);\n const results = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(()=>({\n primaryIdentifierCode: data?.data?.results[0]?.metadataUuid,\n isLoading,\n error\n }), [\n data,\n error,\n isLoading\n ]);\n return results;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZVByaW1hcnlJZGVudGlmaWVyUmVzb3VyY2UuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBLDBCQUEwQixHQUFtQztBQUNwQztBQUNvQztBQUM3RDs7Ozs7OztDQU9DLEdBQVUsU0FBU0k7SUFDaEIsTUFBTUMsTUFBTSxHQUFHRix5REFBV0EsQ0FBQyxtRkFBbUYsQ0FBQztJQUMvRyxNQUFNLEVBQUVHLElBQUksRUFBRUMsS0FBSyxFQUFFQyxTQUFTLEVBQUUsR0FBR1AsK0NBQU1BLENBQUNJLEtBQUtILDBEQUFZQTtJQUMzRCxNQUFNTyxVQUFVVCw4Q0FBT0EsQ0FBQyxJQUFLO1lBQ3JCVSx1QkFBdUJKLE1BQU1BLE1BQU1HLE9BQU8sQ0FBQyxFQUFFLEVBQUVFO1lBQy9DSDtZQUNBRDtRQUNKLElBQUk7UUFDSkQ7UUFDQUM7UUFDQUM7S0FDSDtJQUNELE9BQU9DO0FBQ1giLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tcmVhY3QtdXRpbHMvZGlzdC91c2VQcmltYXJ5SWRlbnRpZmllclJlc291cmNlLmpzPzgzNjkiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBtb2R1bGUgQGNhdGVnb3J5IEFQSSAqLyBpbXBvcnQgeyB1c2VNZW1vIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdXNlU1dSIGZyb20gXCJzd3JcIjtcbmltcG9ydCB7IG9wZW5tcnNGZXRjaCwgcmVzdEJhc2VVcmwgfSBmcm9tIFwiQG9wZW5tcnMvZXNtLWFwaVwiO1xuLyoqXG4gKiBBIFJlYWN0IGhvb2sgdGhhdCByZXRyaWV2ZXMgdGhlIFVVSUQgb2YgdGhlIHByaW1hcnkgcGF0aWVudCBpZGVudGlmaWVyIHR5cGVcbiAqIGZyb20gdGhlIG1ldGFkYXRhIG1hcHBpbmcgY29uZmlndXJhdGlvbi4gVGhpcyBpZGVudGlmaWVyIHR5cGUgaXMgY29tbW9ubHkgdXNlZFxuICogdG8gZGlzcGxheSB0aGUgbWFpbiBpZGVudGlmaWVyIGZvciBhIHBhdGllbnQsIHN1Y2ggYXMgdGhlaXIgbWVkaWNhbCByZWNvcmQgbnVtYmVyLlxuICpcbiAqIEByZXR1cm5zIEFuIG9iamVjdCBjb250YWluaW5nIHRoZSBwcmltYXJ5IGlkZW50aWZpZXIgdHlwZSBVVUlELCBsb2FkaW5nIHN0YXRlLCBhbmQgYW55IGVycm9yLlxuICpcbiAqLyBleHBvcnQgZnVuY3Rpb24gdXNlUHJpbWFyeUlkZW50aWZpZXJDb2RlKCkge1xuICAgIGNvbnN0IHVybCA9IGAke3Jlc3RCYXNlVXJsfS9tZXRhZGF0YW1hcHBpbmcvdGVybW1hcHBpbmc/dj1jdXN0b206KG1ldGFkYXRhVXVpZCkmY29kZT1lbXIucHJpbWFyeUlkZW50aWZpZXJUeXBlYDtcbiAgICBjb25zdCB7IGRhdGEsIGVycm9yLCBpc0xvYWRpbmcgfSA9IHVzZVNXUih1cmwsIG9wZW5tcnNGZXRjaCk7XG4gICAgY29uc3QgcmVzdWx0cyA9IHVzZU1lbW8oKCk9Pih7XG4gICAgICAgICAgICBwcmltYXJ5SWRlbnRpZmllckNvZGU6IGRhdGE/LmRhdGE/LnJlc3VsdHNbMF0/Lm1ldGFkYXRhVXVpZCxcbiAgICAgICAgICAgIGlzTG9hZGluZyxcbiAgICAgICAgICAgIGVycm9yXG4gICAgICAgIH0pLCBbXG4gICAgICAgIGRhdGEsXG4gICAgICAgIGVycm9yLFxuICAgICAgICBpc0xvYWRpbmdcbiAgICBdKTtcbiAgICByZXR1cm4gcmVzdWx0cztcbn1cbiJdLCJuYW1lcyI6WyJ1c2VNZW1vIiwidXNlU1dSIiwib3Blbm1yc0ZldGNoIiwicmVzdEJhc2VVcmwiLCJ1c2VQcmltYXJ5SWRlbnRpZmllckNvZGUiLCJ1cmwiLCJkYXRhIiwiZXJyb3IiLCJpc0xvYWRpbmciLCJyZXN1bHRzIiwicHJpbWFyeUlkZW50aWZpZXJDb2RlIiwibWV0YWRhdGFVdWlkIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/usePrimaryIdentifierResource.js\n");
1219
1219
 
1220
1220
  /***/ }),
1221
1221
 
@@ -1275,7 +1275,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
1275
1275
  \*************************************************************/
1276
1276
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
1277
1277
 
1278
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ useVisitTypes: () => (/* binding */ useVisitTypes)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_emr_api__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-emr-api */ \"../../framework/esm-emr-api/dist/index.js\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/** @module @category API */ \n\nfunction useVisitTypes() {\n const [visitTypes, setVisitTypes] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)([]);\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(()=>{\n const visitTypesSub = (0,_openmrs_esm_emr_api__WEBPACK_IMPORTED_MODULE_0__.getVisitTypes)().subscribe((visitTypes)=>{\n setVisitTypes(visitTypes);\n }, (error)=>console.error(error));\n return ()=>visitTypesSub.unsubscribe();\n }, []);\n return visitTypes;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZVZpc2l0VHlwZXMuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsMEJBQTBCLEdBQXdEO0FBQ3RDO0FBQ3JDLFNBQVNHO0lBQ1osTUFBTSxDQUFDQyxZQUFZQyxjQUFjLEdBQUdILCtDQUFRQSxDQUFDLEVBQUU7SUFDL0NELGdEQUFTQSxDQUFDO1FBQ04sTUFBTUssZ0JBQWdCTixtRUFBYUEsR0FBR08sU0FBUyxDQUFDLENBQUNIO1lBQzdDQyxjQUFjRDtRQUNsQixHQUFHLENBQUNJLFFBQVFDLFFBQVFELEtBQUssQ0FBQ0E7UUFDMUIsT0FBTyxJQUFJRixjQUFjSSxXQUFXO0lBQ3hDLEdBQUcsRUFBRTtJQUNMLE9BQU9OO0FBQ1giLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tcmVhY3QtdXRpbHMvZGlzdC91c2VWaXNpdFR5cGVzLmpzPzZmZGMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBtb2R1bGUgQGNhdGVnb3J5IEFQSSAqLyBpbXBvcnQgeyBnZXRWaXNpdFR5cGVzIH0gZnJvbSBcIkBvcGVubXJzL2VzbS1lbXItYXBpXCI7XG5pbXBvcnQgeyB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSBcInJlYWN0XCI7XG5leHBvcnQgZnVuY3Rpb24gdXNlVmlzaXRUeXBlcygpIHtcbiAgICBjb25zdCBbdmlzaXRUeXBlcywgc2V0VmlzaXRUeXBlc10gPSB1c2VTdGF0ZShbXSk7XG4gICAgdXNlRWZmZWN0KCgpPT57XG4gICAgICAgIGNvbnN0IHZpc2l0VHlwZXNTdWIgPSBnZXRWaXNpdFR5cGVzKCkuc3Vic2NyaWJlKCh2aXNpdFR5cGVzKT0+e1xuICAgICAgICAgICAgc2V0VmlzaXRUeXBlcyh2aXNpdFR5cGVzKTtcbiAgICAgICAgfSwgKGVycm9yKT0+Y29uc29sZS5lcnJvcihlcnJvcikpO1xuICAgICAgICByZXR1cm4gKCk9PnZpc2l0VHlwZXNTdWIudW5zdWJzY3JpYmUoKTtcbiAgICB9LCBbXSk7XG4gICAgcmV0dXJuIHZpc2l0VHlwZXM7XG59XG4iXSwibmFtZXMiOlsiZ2V0VmlzaXRUeXBlcyIsInVzZUVmZmVjdCIsInVzZVN0YXRlIiwidXNlVmlzaXRUeXBlcyIsInZpc2l0VHlwZXMiLCJzZXRWaXNpdFR5cGVzIiwidmlzaXRUeXBlc1N1YiIsInN1YnNjcmliZSIsImVycm9yIiwiY29uc29sZSIsInVuc3Vic2NyaWJlIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/useVisitTypes.js\n");
1278
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ useVisitTypes: () => (/* binding */ useVisitTypes)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_emr_api__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-emr-api */ \"../../framework/esm-emr-api/dist/index.js\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/** @module @category API */ \n\n/**\n * A React hook that fetches and returns all available visit types from the\n * OpenMRS server. The data is fetched once when the component mounts.\n *\n * @returns An array of VisitType objects. Returns an empty array while loading\n * or if an error occurs.\n *\n * @example\n * ```tsx\n * import { useVisitTypes } from '@openmrs/esm-framework';\n * function VisitTypeSelector() {\n * const visitTypes = useVisitTypes();\n * return (\n * <select>\n * {visitTypes.map((vt) => (\n * <option key={vt.uuid} value={vt.uuid}>{vt.display}</option>\n * ))}\n * </select>\n * );\n * }\n * ```\n */ function useVisitTypes() {\n const [visitTypes, setVisitTypes] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)([]);\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(()=>{\n const visitTypesSub = (0,_openmrs_esm_emr_api__WEBPACK_IMPORTED_MODULE_0__.getVisitTypes)().subscribe((visitTypes)=>{\n setVisitTypes(visitTypes);\n }, (error)=>console.error(error));\n return ()=>visitTypesSub.unsubscribe();\n }, []);\n return visitTypes;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZVZpc2l0VHlwZXMuanMiLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsMEJBQTBCLEdBQXdEO0FBQ3RDO0FBQzVDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Q0FxQkMsR0FBVSxTQUFTRztJQUNoQixNQUFNLENBQUNDLFlBQVlDLGNBQWMsR0FBR0gsK0NBQVFBLENBQUMsRUFBRTtJQUMvQ0QsZ0RBQVNBLENBQUM7UUFDTixNQUFNSyxnQkFBZ0JOLG1FQUFhQSxHQUFHTyxTQUFTLENBQUMsQ0FBQ0g7WUFDN0NDLGNBQWNEO1FBQ2xCLEdBQUcsQ0FBQ0ksUUFBUUMsUUFBUUQsS0FBSyxDQUFDQTtRQUMxQixPQUFPLElBQUlGLGNBQWNJLFdBQVc7SUFDeEMsR0FBRyxFQUFFO0lBQ0wsT0FBT047QUFDWCIsInNvdXJjZXMiOlsid2VicGFjazovL0BvcGVubXJzL2VzbS1hcHAtc2hlbGwvLi4vLi4vZnJhbWV3b3JrL2VzbS1yZWFjdC11dGlscy9kaXN0L3VzZVZpc2l0VHlwZXMuanM/NmZkYyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQG1vZHVsZSBAY2F0ZWdvcnkgQVBJICovIGltcG9ydCB7IGdldFZpc2l0VHlwZXMgfSBmcm9tIFwiQG9wZW5tcnMvZXNtLWVtci1hcGlcIjtcbmltcG9ydCB7IHVzZUVmZmVjdCwgdXNlU3RhdGUgfSBmcm9tIFwicmVhY3RcIjtcbi8qKlxuICogQSBSZWFjdCBob29rIHRoYXQgZmV0Y2hlcyBhbmQgcmV0dXJucyBhbGwgYXZhaWxhYmxlIHZpc2l0IHR5cGVzIGZyb20gdGhlXG4gKiBPcGVuTVJTIHNlcnZlci4gVGhlIGRhdGEgaXMgZmV0Y2hlZCBvbmNlIHdoZW4gdGhlIGNvbXBvbmVudCBtb3VudHMuXG4gKlxuICogQHJldHVybnMgQW4gYXJyYXkgb2YgVmlzaXRUeXBlIG9iamVjdHMuIFJldHVybnMgYW4gZW1wdHkgYXJyYXkgd2hpbGUgbG9hZGluZ1xuICogICBvciBpZiBhbiBlcnJvciBvY2N1cnMuXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHRzeFxuICogaW1wb3J0IHsgdXNlVmlzaXRUeXBlcyB9IGZyb20gJ0BvcGVubXJzL2VzbS1mcmFtZXdvcmsnO1xuICogZnVuY3Rpb24gVmlzaXRUeXBlU2VsZWN0b3IoKSB7XG4gKiAgIGNvbnN0IHZpc2l0VHlwZXMgPSB1c2VWaXNpdFR5cGVzKCk7XG4gKiAgIHJldHVybiAoXG4gKiAgICAgPHNlbGVjdD5cbiAqICAgICAgIHt2aXNpdFR5cGVzLm1hcCgodnQpID0+IChcbiAqICAgICAgICAgPG9wdGlvbiBrZXk9e3Z0LnV1aWR9IHZhbHVlPXt2dC51dWlkfT57dnQuZGlzcGxheX08L29wdGlvbj5cbiAqICAgICAgICkpfVxuICogICAgIDwvc2VsZWN0PlxuICogICApO1xuICogfVxuICogYGBgXG4gKi8gZXhwb3J0IGZ1bmN0aW9uIHVzZVZpc2l0VHlwZXMoKSB7XG4gICAgY29uc3QgW3Zpc2l0VHlwZXMsIHNldFZpc2l0VHlwZXNdID0gdXNlU3RhdGUoW10pO1xuICAgIHVzZUVmZmVjdCgoKT0+e1xuICAgICAgICBjb25zdCB2aXNpdFR5cGVzU3ViID0gZ2V0VmlzaXRUeXBlcygpLnN1YnNjcmliZSgodmlzaXRUeXBlcyk9PntcbiAgICAgICAgICAgIHNldFZpc2l0VHlwZXModmlzaXRUeXBlcyk7XG4gICAgICAgIH0sIChlcnJvcik9PmNvbnNvbGUuZXJyb3IoZXJyb3IpKTtcbiAgICAgICAgcmV0dXJuICgpPT52aXNpdFR5cGVzU3ViLnVuc3Vic2NyaWJlKCk7XG4gICAgfSwgW10pO1xuICAgIHJldHVybiB2aXNpdFR5cGVzO1xufVxuIl0sIm5hbWVzIjpbImdldFZpc2l0VHlwZXMiLCJ1c2VFZmZlY3QiLCJ1c2VTdGF0ZSIsInVzZVZpc2l0VHlwZXMiLCJ2aXNpdFR5cGVzIiwic2V0VmlzaXRUeXBlcyIsInZpc2l0VHlwZXNTdWIiLCJzdWJzY3JpYmUiLCJlcnJvciIsImNvbnNvbGUiLCJ1bnN1YnNjcmliZSJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/useVisitTypes.js\n");
1279
1279
 
1280
1280
  /***/ }),
1281
1281
 
@@ -1315,7 +1315,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
1315
1315
  \******************************************************/
1316
1316
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
1317
1317
 
1318
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ getCoreTranslation: () => (/* binding */ getCoreTranslation),\n/* harmony export */ translateFrom: () => (/* binding */ translateFrom)\n/* harmony export */ });\n/* harmony import */ var _translations_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./translations.js */ \"../../framework/esm-translations/dist/translations.js\");\n/* harmony import */ var i18next__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! i18next */ \"webpack/sharing/consume/default/i18next/i18next\");\n/** @module @category Translation */ \n\nconst i18n = i18next__WEBPACK_IMPORTED_MODULE_1__[\"default\"] || i18next__WEBPACK_IMPORTED_MODULE_1__;\ni18n.on('initialized', function() {\n window.i18next.loadNamespaces([\n 'core'\n ]);\n});\n/**\n * This function is for getting a translation from a specific module. Use this only if the\n * translation is neither in the app making the call, nor in the core translations.\n * This function is useful, for example, in libraries that are used by multiple apps, since libraries can't\n * define their own translations.\n *\n * Translations within the current app should be accessed with the i18next API, using\n * `useTranslation` and `t` as usual. Core translations should be accessed with the\n * [[getCoreTranslation]] function.\n *\n * IMPORTANT: This function creates a hidden dependency on the module. Worse yet, it creates\n * a dependency specifically on that module's translation keys, which are often regarded as\n * \"implementation details\" and therefore may be volatile. Also note that this function DOES NOT\n * load the module's translations if they have not already been loaded via `useTranslation`.\n * **This function should therefore be avoided when possible.**\n *\n * @param moduleName The module to get the translation from, e.g. '@openmrs/esm-login-app'\n * @param key The i18next translation key\n * @param fallback Fallback text for if the lookup fails\n * @param options Options object passed to the i18next `t` function. See https://www.i18next.com/translation-function/essentials#overview-options\n * for more information. `ns` and `defaultValue` are already set and may not be used.\n * @returns The translated text as a string\n */ function translateFrom(moduleName, key, fallback, options) {\n return i18n.t(key, {\n ns: moduleName,\n defaultValue: fallback,\n ...options\n });\n}\n/**\n * Use this function to obtain a translation from the core translations. This is a way to avoid having\n * to define common translations in your app, and to ensure that translations are consistent across\n * different apps. This function is also used to obtain translations in the framework and app shell.\n *\n * The complete set of core translations is available on the `CoreTranslationKey` type. Providing an\n * invalid key to this function will result in a type error.\n *\n * @param options Object passed to the i18next `t` function. See https://www.i18next.com/translation-function/essentials#overview-options\n * for more information. `ns` and `defaultValue` are already set and may not be used.\n */ function getCoreTranslation(key, defaultText, options) {\n if (!_translations_js__WEBPACK_IMPORTED_MODULE_0__.coreTranslations[key]) {\n console.error(`O3 Core Translations does not provide key '${key}'. The key itself is being rendered as text.`);\n return key;\n }\n return translateFrom('core', key, defaultText ?? _translations_js__WEBPACK_IMPORTED_MODULE_0__.coreTranslations[key], options);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS10cmFuc2xhdGlvbnMvZGlzdC9pbmRleC5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUEsa0NBQWtDLEdBQXdEO0FBQzlEO0FBQzVCLE1BQU1FLE9BQU9ELCtDQUFhLElBQUlBLG9DQUFLQTtBQUNuQ0MsS0FBS0UsRUFBRSxDQUFDLGVBQWU7SUFDbkJDLE9BQU9DLE9BQU8sQ0FBQ0MsY0FBYyxDQUFDO1FBQzFCO0tBQ0g7QUFDTDtBQUNBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0NBc0JDLEdBQVUsU0FBU0MsY0FBY0MsVUFBVSxFQUFFQyxHQUFHLEVBQUVDLFFBQVEsRUFBRUMsT0FBTztJQUNoRSxPQUFPVixLQUFLVyxDQUFDLENBQUNILEtBQUs7UUFDZkksSUFBSUw7UUFDSk0sY0FBY0o7UUFDZCxHQUFHQyxPQUFPO0lBQ2Q7QUFDSjtBQUNBOzs7Ozs7Ozs7O0NBVUMsR0FBVSxTQUFTSSxtQkFBbUJOLEdBQUcsRUFBRU8sV0FBVyxFQUFFTCxPQUFPO0lBQzVELElBQUksQ0FBQ1osOERBQWdCLENBQUNVLElBQUksRUFBRTtRQUN4QlEsUUFBUUMsS0FBSyxDQUFDLENBQUMsMkNBQTJDLEVBQUVULElBQUksNENBQTRDLENBQUM7UUFDN0csT0FBT0E7SUFDWDtJQUNBLE9BQU9GLGNBQWMsUUFBUUUsS0FBS08sZUFBZWpCLDhEQUFnQixDQUFDVSxJQUFJLEVBQUVFO0FBQzVFIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQG9wZW5tcnMvZXNtLWFwcC1zaGVsbC8uLi8uLi9mcmFtZXdvcmsvZXNtLXRyYW5zbGF0aW9ucy9kaXN0L2luZGV4LmpzPzU5YTYiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBtb2R1bGUgQGNhdGVnb3J5IFRyYW5zbGF0aW9uICovIGltcG9ydCB7IGNvcmVUcmFuc2xhdGlvbnMgfSBmcm9tIFwiLi90cmFuc2xhdGlvbnMuanNcIjtcbmltcG9ydCBfaTE4biBmcm9tIFwiaTE4bmV4dFwiO1xuY29uc3QgaTE4biA9IF9pMThuLmRlZmF1bHQgfHwgX2kxOG47XG5pMThuLm9uKCdpbml0aWFsaXplZCcsIGZ1bmN0aW9uKCkge1xuICAgIHdpbmRvdy5pMThuZXh0LmxvYWROYW1lc3BhY2VzKFtcbiAgICAgICAgJ2NvcmUnXG4gICAgXSk7XG59KTtcbi8qKlxuICogVGhpcyBmdW5jdGlvbiBpcyBmb3IgZ2V0dGluZyBhIHRyYW5zbGF0aW9uIGZyb20gYSBzcGVjaWZpYyBtb2R1bGUuIFVzZSB0aGlzIG9ubHkgaWYgdGhlXG4gKiB0cmFuc2xhdGlvbiBpcyBuZWl0aGVyIGluIHRoZSBhcHAgbWFraW5nIHRoZSBjYWxsLCBub3IgaW4gdGhlIGNvcmUgdHJhbnNsYXRpb25zLlxuICogVGhpcyBmdW5jdGlvbiBpcyB1c2VmdWwsIGZvciBleGFtcGxlLCBpbiBsaWJyYXJpZXMgdGhhdCBhcmUgdXNlZCBieSBtdWx0aXBsZSBhcHBzLCBzaW5jZSBsaWJyYXJpZXMgY2FuJ3RcbiAqIGRlZmluZSB0aGVpciBvd24gdHJhbnNsYXRpb25zLlxuICpcbiAqIFRyYW5zbGF0aW9ucyB3aXRoaW4gdGhlIGN1cnJlbnQgYXBwIHNob3VsZCBiZSBhY2Nlc3NlZCB3aXRoIHRoZSBpMThuZXh0IEFQSSwgdXNpbmdcbiAqIGB1c2VUcmFuc2xhdGlvbmAgYW5kIGB0YCBhcyB1c3VhbC4gQ29yZSB0cmFuc2xhdGlvbnMgc2hvdWxkIGJlIGFjY2Vzc2VkIHdpdGggdGhlXG4gKiBbW2dldENvcmVUcmFuc2xhdGlvbl1dIGZ1bmN0aW9uLlxuICpcbiAqIElNUE9SVEFOVDogVGhpcyBmdW5jdGlvbiBjcmVhdGVzIGEgaGlkZGVuIGRlcGVuZGVuY3kgb24gdGhlIG1vZHVsZS4gV29yc2UgeWV0LCBpdCBjcmVhdGVzXG4gKiBhIGRlcGVuZGVuY3kgc3BlY2lmaWNhbGx5IG9uIHRoYXQgbW9kdWxlJ3MgdHJhbnNsYXRpb24ga2V5cywgd2hpY2ggYXJlIG9mdGVuIHJlZ2FyZGVkIGFzXG4gKiBcImltcGxlbWVudGF0aW9uIGRldGFpbHNcIiBhbmQgdGhlcmVmb3JlIG1heSBiZSB2b2xhdGlsZS4gQWxzbyBub3RlIHRoYXQgdGhpcyBmdW5jdGlvbiBET0VTIE5PVFxuICogbG9hZCB0aGUgbW9kdWxlJ3MgdHJhbnNsYXRpb25zIGlmIHRoZXkgaGF2ZSBub3QgYWxyZWFkeSBiZWVuIGxvYWRlZCB2aWEgYHVzZVRyYW5zbGF0aW9uYC5cbiAqICoqVGhpcyBmdW5jdGlvbiBzaG91bGQgdGhlcmVmb3JlIGJlIGF2b2lkZWQgd2hlbiBwb3NzaWJsZS4qKlxuICpcbiAqIEBwYXJhbSBtb2R1bGVOYW1lIFRoZSBtb2R1bGUgdG8gZ2V0IHRoZSB0cmFuc2xhdGlvbiBmcm9tLCBlLmcuICdAb3Blbm1ycy9lc20tbG9naW4tYXBwJ1xuICogQHBhcmFtIGtleSBUaGUgaTE4bmV4dCB0cmFuc2xhdGlvbiBrZXlcbiAqIEBwYXJhbSBmYWxsYmFjayBGYWxsYmFjayB0ZXh0IGZvciBpZiB0aGUgbG9va3VwIGZhaWxzXG4gKiBAcGFyYW0gb3B0aW9ucyBPcHRpb25zIG9iamVjdCBwYXNzZWQgdG8gdGhlIGkxOG5leHQgYHRgIGZ1bmN0aW9uLiBTZWUgaHR0cHM6Ly93d3cuaTE4bmV4dC5jb20vdHJhbnNsYXRpb24tZnVuY3Rpb24vZXNzZW50aWFscyNvdmVydmlldy1vcHRpb25zXG4gKiAgICAgICAgICAgIGZvciBtb3JlIGluZm9ybWF0aW9uLiBgbnNgIGFuZCBgZGVmYXVsdFZhbHVlYCBhcmUgYWxyZWFkeSBzZXQgYW5kIG1heSBub3QgYmUgdXNlZC5cbiAqIEByZXR1cm5zIFRoZSB0cmFuc2xhdGVkIHRleHQgYXMgYSBzdHJpbmdcbiAqLyBleHBvcnQgZnVuY3Rpb24gdHJhbnNsYXRlRnJvbShtb2R1bGVOYW1lLCBrZXksIGZhbGxiYWNrLCBvcHRpb25zKSB7XG4gICAgcmV0dXJuIGkxOG4udChrZXksIHtcbiAgICAgICAgbnM6IG1vZHVsZU5hbWUsXG4gICAgICAgIGRlZmF1bHRWYWx1ZTogZmFsbGJhY2ssXG4gICAgICAgIC4uLm9wdGlvbnNcbiAgICB9KTtcbn1cbi8qKlxuICogVXNlIHRoaXMgZnVuY3Rpb24gdG8gb2J0YWluIGEgdHJhbnNsYXRpb24gZnJvbSB0aGUgY29yZSB0cmFuc2xhdGlvbnMuIFRoaXMgaXMgYSB3YXkgdG8gYXZvaWQgaGF2aW5nXG4gKiB0byBkZWZpbmUgY29tbW9uIHRyYW5zbGF0aW9ucyBpbiB5b3VyIGFwcCwgYW5kIHRvIGVuc3VyZSB0aGF0IHRyYW5zbGF0aW9ucyBhcmUgY29uc2lzdGVudCBhY3Jvc3NcbiAqIGRpZmZlcmVudCBhcHBzLiBUaGlzIGZ1bmN0aW9uIGlzIGFsc28gdXNlZCB0byBvYnRhaW4gdHJhbnNsYXRpb25zIGluIHRoZSBmcmFtZXdvcmsgYW5kIGFwcCBzaGVsbC5cbiAqXG4gKiBUaGUgY29tcGxldGUgc2V0IG9mIGNvcmUgdHJhbnNsYXRpb25zIGlzIGF2YWlsYWJsZSBvbiB0aGUgYENvcmVUcmFuc2xhdGlvbktleWAgdHlwZS4gUHJvdmlkaW5nIGFuXG4gKiBpbnZhbGlkIGtleSB0byB0aGlzIGZ1bmN0aW9uIHdpbGwgcmVzdWx0IGluIGEgdHlwZSBlcnJvci5cbiAqXG4gKiBAcGFyYW0gb3B0aW9ucyBPYmplY3QgcGFzc2VkIHRvIHRoZSBpMThuZXh0IGB0YCBmdW5jdGlvbi4gU2VlIGh0dHBzOi8vd3d3LmkxOG5leHQuY29tL3RyYW5zbGF0aW9uLWZ1bmN0aW9uL2Vzc2VudGlhbHMjb3ZlcnZpZXctb3B0aW9uc1xuICogICAgICAgICAgIGZvciBtb3JlIGluZm9ybWF0aW9uLiBgbnNgIGFuZCBgZGVmYXVsdFZhbHVlYCBhcmUgYWxyZWFkeSBzZXQgYW5kIG1heSBub3QgYmUgdXNlZC5cbiAqLyBleHBvcnQgZnVuY3Rpb24gZ2V0Q29yZVRyYW5zbGF0aW9uKGtleSwgZGVmYXVsdFRleHQsIG9wdGlvbnMpIHtcbiAgICBpZiAoIWNvcmVUcmFuc2xhdGlvbnNba2V5XSkge1xuICAgICAgICBjb25zb2xlLmVycm9yKGBPMyBDb3JlIFRyYW5zbGF0aW9ucyBkb2VzIG5vdCBwcm92aWRlIGtleSAnJHtrZXl9Jy4gVGhlIGtleSBpdHNlbGYgaXMgYmVpbmcgcmVuZGVyZWQgYXMgdGV4dC5gKTtcbiAgICAgICAgcmV0dXJuIGtleTtcbiAgICB9XG4gICAgcmV0dXJuIHRyYW5zbGF0ZUZyb20oJ2NvcmUnLCBrZXksIGRlZmF1bHRUZXh0ID8/IGNvcmVUcmFuc2xhdGlvbnNba2V5XSwgb3B0aW9ucyk7XG59XG4iXSwibmFtZXMiOlsiY29yZVRyYW5zbGF0aW9ucyIsIl9pMThuIiwiaTE4biIsImRlZmF1bHQiLCJvbiIsIndpbmRvdyIsImkxOG5leHQiLCJsb2FkTmFtZXNwYWNlcyIsInRyYW5zbGF0ZUZyb20iLCJtb2R1bGVOYW1lIiwia2V5IiwiZmFsbGJhY2siLCJvcHRpb25zIiwidCIsIm5zIiwiZGVmYXVsdFZhbHVlIiwiZ2V0Q29yZVRyYW5zbGF0aW9uIiwiZGVmYXVsdFRleHQiLCJjb25zb2xlIiwiZXJyb3IiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///../../framework/esm-translations/dist/index.js\n");
1318
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ getCoreTranslation: () => (/* binding */ getCoreTranslation),\n/* harmony export */ translateFrom: () => (/* binding */ translateFrom)\n/* harmony export */ });\n/* harmony import */ var _translations_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./translations.js */ \"../../framework/esm-translations/dist/translations.js\");\n/* harmony import */ var i18next__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! i18next */ \"webpack/sharing/consume/default/i18next/i18next\");\n/** @module @category Translation */ \n\nconst i18n = i18next__WEBPACK_IMPORTED_MODULE_1__[\"default\"] || i18next__WEBPACK_IMPORTED_MODULE_1__;\ni18n.on('initialized', function() {\n window.i18next.loadNamespaces([\n 'core'\n ]);\n});\n/**\n * This function is for getting a translation from a specific module. Use this only if the\n * translation is neither in the app making the call, nor in the core translations.\n * This function is useful, for example, in libraries that are used by multiple apps, since libraries can't\n * define their own translations.\n *\n * Translations within the current app should be accessed with the i18next API, using\n * `useTranslation` and `t` as usual. Core translations should be accessed with the\n * [[getCoreTranslation]] function.\n *\n * IMPORTANT: This function creates a hidden dependency on the module. Worse yet, it creates\n * a dependency specifically on that module's translation keys, which are often regarded as\n * \"implementation details\" and therefore may be volatile. Also note that this function DOES NOT\n * load the module's translations if they have not already been loaded via `useTranslation`.\n * **This function should therefore be avoided when possible.**\n *\n * @param moduleName The module to get the translation from, e.g. '@openmrs/esm-login-app'\n * @param key The i18next translation key\n * @param fallback Fallback text for if the lookup fails\n * @param options Options object passed to the i18next `t` function. See https://www.i18next.com/translation-function/essentials#overview-options\n * for more information. `ns` and `defaultValue` are already set and may not be used.\n * @returns The translated text as a string\n */ function translateFrom(moduleName, key, fallback, options) {\n return i18n.t(key, {\n ns: moduleName,\n defaultValue: fallback,\n ...options\n });\n}\n/**\n * Use this function to obtain a translation from the core translations. This is a way to avoid having\n * to define common translations in your app, and to ensure that translations are consistent across\n * different apps. This function is also used to obtain translations in the framework and app shell.\n *\n * The complete set of core translations is available on the `CoreTranslationKey` type. Providing an\n * invalid key to this function will result in a type error.\n *\n * @param key The translation key from the set of core translations.\n * @param defaultText Optional fallback text if the translation is not found.\n * @param options Object passed to the i18next `t` function. See https://www.i18next.com/translation-function/essentials#overview-options\n * for more information. `ns` and `defaultValue` are already set and may not be used.\n * @returns The translated string.\n */ function getCoreTranslation(key, defaultText, options) {\n if (!_translations_js__WEBPACK_IMPORTED_MODULE_0__.coreTranslations[key]) {\n console.error(`O3 Core Translations does not provide key '${key}'. The key itself is being rendered as text.`);\n return key;\n }\n return translateFrom('core', key, defaultText ?? _translations_js__WEBPACK_IMPORTED_MODULE_0__.coreTranslations[key], options);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS10cmFuc2xhdGlvbnMvZGlzdC9pbmRleC5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUEsa0NBQWtDLEdBQXdEO0FBQzlEO0FBQzVCLE1BQU1FLE9BQU9ELCtDQUFhLElBQUlBLG9DQUFLQTtBQUNuQ0MsS0FBS0UsRUFBRSxDQUFDLGVBQWU7SUFDbkJDLE9BQU9DLE9BQU8sQ0FBQ0MsY0FBYyxDQUFDO1FBQzFCO0tBQ0g7QUFDTDtBQUNBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0NBc0JDLEdBQVUsU0FBU0MsY0FBY0MsVUFBVSxFQUFFQyxHQUFHLEVBQUVDLFFBQVEsRUFBRUMsT0FBTztJQUNoRSxPQUFPVixLQUFLVyxDQUFDLENBQUNILEtBQUs7UUFDZkksSUFBSUw7UUFDSk0sY0FBY0o7UUFDZCxHQUFHQyxPQUFPO0lBQ2Q7QUFDSjtBQUNBOzs7Ozs7Ozs7Ozs7O0NBYUMsR0FBVSxTQUFTSSxtQkFBbUJOLEdBQUcsRUFBRU8sV0FBVyxFQUFFTCxPQUFPO0lBQzVELElBQUksQ0FBQ1osOERBQWdCLENBQUNVLElBQUksRUFBRTtRQUN4QlEsUUFBUUMsS0FBSyxDQUFDLENBQUMsMkNBQTJDLEVBQUVULElBQUksNENBQTRDLENBQUM7UUFDN0csT0FBT0E7SUFDWDtJQUNBLE9BQU9GLGNBQWMsUUFBUUUsS0FBS08sZUFBZWpCLDhEQUFnQixDQUFDVSxJQUFJLEVBQUVFO0FBQzVFIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQG9wZW5tcnMvZXNtLWFwcC1zaGVsbC8uLi8uLi9mcmFtZXdvcmsvZXNtLXRyYW5zbGF0aW9ucy9kaXN0L2luZGV4LmpzPzU5YTYiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBtb2R1bGUgQGNhdGVnb3J5IFRyYW5zbGF0aW9uICovIGltcG9ydCB7IGNvcmVUcmFuc2xhdGlvbnMgfSBmcm9tIFwiLi90cmFuc2xhdGlvbnMuanNcIjtcbmltcG9ydCBfaTE4biBmcm9tIFwiaTE4bmV4dFwiO1xuY29uc3QgaTE4biA9IF9pMThuLmRlZmF1bHQgfHwgX2kxOG47XG5pMThuLm9uKCdpbml0aWFsaXplZCcsIGZ1bmN0aW9uKCkge1xuICAgIHdpbmRvdy5pMThuZXh0LmxvYWROYW1lc3BhY2VzKFtcbiAgICAgICAgJ2NvcmUnXG4gICAgXSk7XG59KTtcbi8qKlxuICogVGhpcyBmdW5jdGlvbiBpcyBmb3IgZ2V0dGluZyBhIHRyYW5zbGF0aW9uIGZyb20gYSBzcGVjaWZpYyBtb2R1bGUuIFVzZSB0aGlzIG9ubHkgaWYgdGhlXG4gKiB0cmFuc2xhdGlvbiBpcyBuZWl0aGVyIGluIHRoZSBhcHAgbWFraW5nIHRoZSBjYWxsLCBub3IgaW4gdGhlIGNvcmUgdHJhbnNsYXRpb25zLlxuICogVGhpcyBmdW5jdGlvbiBpcyB1c2VmdWwsIGZvciBleGFtcGxlLCBpbiBsaWJyYXJpZXMgdGhhdCBhcmUgdXNlZCBieSBtdWx0aXBsZSBhcHBzLCBzaW5jZSBsaWJyYXJpZXMgY2FuJ3RcbiAqIGRlZmluZSB0aGVpciBvd24gdHJhbnNsYXRpb25zLlxuICpcbiAqIFRyYW5zbGF0aW9ucyB3aXRoaW4gdGhlIGN1cnJlbnQgYXBwIHNob3VsZCBiZSBhY2Nlc3NlZCB3aXRoIHRoZSBpMThuZXh0IEFQSSwgdXNpbmdcbiAqIGB1c2VUcmFuc2xhdGlvbmAgYW5kIGB0YCBhcyB1c3VhbC4gQ29yZSB0cmFuc2xhdGlvbnMgc2hvdWxkIGJlIGFjY2Vzc2VkIHdpdGggdGhlXG4gKiBbW2dldENvcmVUcmFuc2xhdGlvbl1dIGZ1bmN0aW9uLlxuICpcbiAqIElNUE9SVEFOVDogVGhpcyBmdW5jdGlvbiBjcmVhdGVzIGEgaGlkZGVuIGRlcGVuZGVuY3kgb24gdGhlIG1vZHVsZS4gV29yc2UgeWV0LCBpdCBjcmVhdGVzXG4gKiBhIGRlcGVuZGVuY3kgc3BlY2lmaWNhbGx5IG9uIHRoYXQgbW9kdWxlJ3MgdHJhbnNsYXRpb24ga2V5cywgd2hpY2ggYXJlIG9mdGVuIHJlZ2FyZGVkIGFzXG4gKiBcImltcGxlbWVudGF0aW9uIGRldGFpbHNcIiBhbmQgdGhlcmVmb3JlIG1heSBiZSB2b2xhdGlsZS4gQWxzbyBub3RlIHRoYXQgdGhpcyBmdW5jdGlvbiBET0VTIE5PVFxuICogbG9hZCB0aGUgbW9kdWxlJ3MgdHJhbnNsYXRpb25zIGlmIHRoZXkgaGF2ZSBub3QgYWxyZWFkeSBiZWVuIGxvYWRlZCB2aWEgYHVzZVRyYW5zbGF0aW9uYC5cbiAqICoqVGhpcyBmdW5jdGlvbiBzaG91bGQgdGhlcmVmb3JlIGJlIGF2b2lkZWQgd2hlbiBwb3NzaWJsZS4qKlxuICpcbiAqIEBwYXJhbSBtb2R1bGVOYW1lIFRoZSBtb2R1bGUgdG8gZ2V0IHRoZSB0cmFuc2xhdGlvbiBmcm9tLCBlLmcuICdAb3Blbm1ycy9lc20tbG9naW4tYXBwJ1xuICogQHBhcmFtIGtleSBUaGUgaTE4bmV4dCB0cmFuc2xhdGlvbiBrZXlcbiAqIEBwYXJhbSBmYWxsYmFjayBGYWxsYmFjayB0ZXh0IGZvciBpZiB0aGUgbG9va3VwIGZhaWxzXG4gKiBAcGFyYW0gb3B0aW9ucyBPcHRpb25zIG9iamVjdCBwYXNzZWQgdG8gdGhlIGkxOG5leHQgYHRgIGZ1bmN0aW9uLiBTZWUgaHR0cHM6Ly93d3cuaTE4bmV4dC5jb20vdHJhbnNsYXRpb24tZnVuY3Rpb24vZXNzZW50aWFscyNvdmVydmlldy1vcHRpb25zXG4gKiAgICAgICAgICAgIGZvciBtb3JlIGluZm9ybWF0aW9uLiBgbnNgIGFuZCBgZGVmYXVsdFZhbHVlYCBhcmUgYWxyZWFkeSBzZXQgYW5kIG1heSBub3QgYmUgdXNlZC5cbiAqIEByZXR1cm5zIFRoZSB0cmFuc2xhdGVkIHRleHQgYXMgYSBzdHJpbmdcbiAqLyBleHBvcnQgZnVuY3Rpb24gdHJhbnNsYXRlRnJvbShtb2R1bGVOYW1lLCBrZXksIGZhbGxiYWNrLCBvcHRpb25zKSB7XG4gICAgcmV0dXJuIGkxOG4udChrZXksIHtcbiAgICAgICAgbnM6IG1vZHVsZU5hbWUsXG4gICAgICAgIGRlZmF1bHRWYWx1ZTogZmFsbGJhY2ssXG4gICAgICAgIC4uLm9wdGlvbnNcbiAgICB9KTtcbn1cbi8qKlxuICogVXNlIHRoaXMgZnVuY3Rpb24gdG8gb2J0YWluIGEgdHJhbnNsYXRpb24gZnJvbSB0aGUgY29yZSB0cmFuc2xhdGlvbnMuIFRoaXMgaXMgYSB3YXkgdG8gYXZvaWQgaGF2aW5nXG4gKiB0byBkZWZpbmUgY29tbW9uIHRyYW5zbGF0aW9ucyBpbiB5b3VyIGFwcCwgYW5kIHRvIGVuc3VyZSB0aGF0IHRyYW5zbGF0aW9ucyBhcmUgY29uc2lzdGVudCBhY3Jvc3NcbiAqIGRpZmZlcmVudCBhcHBzLiBUaGlzIGZ1bmN0aW9uIGlzIGFsc28gdXNlZCB0byBvYnRhaW4gdHJhbnNsYXRpb25zIGluIHRoZSBmcmFtZXdvcmsgYW5kIGFwcCBzaGVsbC5cbiAqXG4gKiBUaGUgY29tcGxldGUgc2V0IG9mIGNvcmUgdHJhbnNsYXRpb25zIGlzIGF2YWlsYWJsZSBvbiB0aGUgYENvcmVUcmFuc2xhdGlvbktleWAgdHlwZS4gUHJvdmlkaW5nIGFuXG4gKiBpbnZhbGlkIGtleSB0byB0aGlzIGZ1bmN0aW9uIHdpbGwgcmVzdWx0IGluIGEgdHlwZSBlcnJvci5cbiAqXG4gKiBAcGFyYW0ga2V5IFRoZSB0cmFuc2xhdGlvbiBrZXkgZnJvbSB0aGUgc2V0IG9mIGNvcmUgdHJhbnNsYXRpb25zLlxuICogQHBhcmFtIGRlZmF1bHRUZXh0IE9wdGlvbmFsIGZhbGxiYWNrIHRleHQgaWYgdGhlIHRyYW5zbGF0aW9uIGlzIG5vdCBmb3VuZC5cbiAqIEBwYXJhbSBvcHRpb25zIE9iamVjdCBwYXNzZWQgdG8gdGhlIGkxOG5leHQgYHRgIGZ1bmN0aW9uLiBTZWUgaHR0cHM6Ly93d3cuaTE4bmV4dC5jb20vdHJhbnNsYXRpb24tZnVuY3Rpb24vZXNzZW50aWFscyNvdmVydmlldy1vcHRpb25zXG4gKiAgICAgICAgICAgZm9yIG1vcmUgaW5mb3JtYXRpb24uIGBuc2AgYW5kIGBkZWZhdWx0VmFsdWVgIGFyZSBhbHJlYWR5IHNldCBhbmQgbWF5IG5vdCBiZSB1c2VkLlxuICogQHJldHVybnMgVGhlIHRyYW5zbGF0ZWQgc3RyaW5nLlxuICovIGV4cG9ydCBmdW5jdGlvbiBnZXRDb3JlVHJhbnNsYXRpb24oa2V5LCBkZWZhdWx0VGV4dCwgb3B0aW9ucykge1xuICAgIGlmICghY29yZVRyYW5zbGF0aW9uc1trZXldKSB7XG4gICAgICAgIGNvbnNvbGUuZXJyb3IoYE8zIENvcmUgVHJhbnNsYXRpb25zIGRvZXMgbm90IHByb3ZpZGUga2V5ICcke2tleX0nLiBUaGUga2V5IGl0c2VsZiBpcyBiZWluZyByZW5kZXJlZCBhcyB0ZXh0LmApO1xuICAgICAgICByZXR1cm4ga2V5O1xuICAgIH1cbiAgICByZXR1cm4gdHJhbnNsYXRlRnJvbSgnY29yZScsIGtleSwgZGVmYXVsdFRleHQgPz8gY29yZVRyYW5zbGF0aW9uc1trZXldLCBvcHRpb25zKTtcbn1cbiJdLCJuYW1lcyI6WyJjb3JlVHJhbnNsYXRpb25zIiwiX2kxOG4iLCJpMThuIiwiZGVmYXVsdCIsIm9uIiwid2luZG93IiwiaTE4bmV4dCIsImxvYWROYW1lc3BhY2VzIiwidHJhbnNsYXRlRnJvbSIsIm1vZHVsZU5hbWUiLCJrZXkiLCJmYWxsYmFjayIsIm9wdGlvbnMiLCJ0IiwibnMiLCJkZWZhdWx0VmFsdWUiLCJnZXRDb3JlVHJhbnNsYXRpb24iLCJkZWZhdWx0VGV4dCIsImNvbnNvbGUiLCJlcnJvciJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///../../framework/esm-translations/dist/index.js\n");
1319
1319
 
1320
1320
  /***/ }),
1321
1321
 
@@ -1335,7 +1335,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
1335
1335
  \***************************************************/
1336
1336
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
1337
1337
 
1338
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ isOnline: () => (/* binding */ isOnline)\n/* harmony export */ });\nfunction isOnline(online) {\n return window.offlineEnabled ? online ?? navigator.onLine : true;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS11dGlscy9kaXN0L2lzLW9ubGluZS5qcyIsIm1hcHBpbmdzIjoiOzs7O0FBQU8sU0FBU0EsU0FBU0MsTUFBTTtJQUMzQixPQUFPQyxPQUFPQyxjQUFjLEdBQUdGLFVBQVVHLFVBQVVDLE1BQU0sR0FBRztBQUNoRSIsInNvdXJjZXMiOlsid2VicGFjazovL0BvcGVubXJzL2VzbS1hcHAtc2hlbGwvLi4vLi4vZnJhbWV3b3JrL2VzbS11dGlscy9kaXN0L2lzLW9ubGluZS5qcz8wZmY1Il0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBmdW5jdGlvbiBpc09ubGluZShvbmxpbmUpIHtcbiAgICByZXR1cm4gd2luZG93Lm9mZmxpbmVFbmFibGVkID8gb25saW5lID8/IG5hdmlnYXRvci5vbkxpbmUgOiB0cnVlO1xufVxuIl0sIm5hbWVzIjpbImlzT25saW5lIiwib25saW5lIiwid2luZG93Iiwib2ZmbGluZUVuYWJsZWQiLCJuYXZpZ2F0b3IiLCJvbkxpbmUiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///../../framework/esm-utils/dist/is-online.js\n");
1338
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ isOnline: () => (/* binding */ isOnline)\n/* harmony export */ });\n/**\n * Determines if the application should behave as if it is online.\n * When offline mode is enabled (`window.offlineEnabled`), this returns the\n * provided `online` parameter or falls back to `navigator.onLine`.\n * When offline mode is disabled, this always returns `true`.\n *\n * @param online Optional override for the online status. If provided and offline\n * mode is enabled, this value is returned directly.\n * @returns `true` if the application should behave as online, `false` otherwise.\n *\n * @category Utility\n */ function isOnline(online) {\n return window.offlineEnabled ? online ?? navigator.onLine : true;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS11dGlscy9kaXN0L2lzLW9ubGluZS5qcyIsIm1hcHBpbmdzIjoiOzs7O0FBQUE7Ozs7Ozs7Ozs7O0NBV0MsR0FBVSxTQUFTQSxTQUFTQyxNQUFNO0lBQy9CLE9BQU9DLE9BQU9DLGNBQWMsR0FBR0YsVUFBVUcsVUFBVUMsTUFBTSxHQUFHO0FBQ2hFIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQG9wZW5tcnMvZXNtLWFwcC1zaGVsbC8uLi8uLi9mcmFtZXdvcmsvZXNtLXV0aWxzL2Rpc3QvaXMtb25saW5lLmpzPzBmZjUiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBEZXRlcm1pbmVzIGlmIHRoZSBhcHBsaWNhdGlvbiBzaG91bGQgYmVoYXZlIGFzIGlmIGl0IGlzIG9ubGluZS5cbiAqIFdoZW4gb2ZmbGluZSBtb2RlIGlzIGVuYWJsZWQgKGB3aW5kb3cub2ZmbGluZUVuYWJsZWRgKSwgdGhpcyByZXR1cm5zIHRoZVxuICogcHJvdmlkZWQgYG9ubGluZWAgcGFyYW1ldGVyIG9yIGZhbGxzIGJhY2sgdG8gYG5hdmlnYXRvci5vbkxpbmVgLlxuICogV2hlbiBvZmZsaW5lIG1vZGUgaXMgZGlzYWJsZWQsIHRoaXMgYWx3YXlzIHJldHVybnMgYHRydWVgLlxuICpcbiAqIEBwYXJhbSBvbmxpbmUgT3B0aW9uYWwgb3ZlcnJpZGUgZm9yIHRoZSBvbmxpbmUgc3RhdHVzLiBJZiBwcm92aWRlZCBhbmQgb2ZmbGluZVxuICogICBtb2RlIGlzIGVuYWJsZWQsIHRoaXMgdmFsdWUgaXMgcmV0dXJuZWQgZGlyZWN0bHkuXG4gKiBAcmV0dXJucyBgdHJ1ZWAgaWYgdGhlIGFwcGxpY2F0aW9uIHNob3VsZCBiZWhhdmUgYXMgb25saW5lLCBgZmFsc2VgIG90aGVyd2lzZS5cbiAqXG4gKiBAY2F0ZWdvcnkgVXRpbGl0eVxuICovIGV4cG9ydCBmdW5jdGlvbiBpc09ubGluZShvbmxpbmUpIHtcbiAgICByZXR1cm4gd2luZG93Lm9mZmxpbmVFbmFibGVkID8gb25saW5lID8/IG5hdmlnYXRvci5vbkxpbmUgOiB0cnVlO1xufVxuIl0sIm5hbWVzIjpbImlzT25saW5lIiwib25saW5lIiwid2luZG93Iiwib2ZmbGluZUVuYWJsZWQiLCJuYXZpZ2F0b3IiLCJvbkxpbmUiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///../../framework/esm-utils/dist/is-online.js\n");
1339
1339
 
1340
1340
  /***/ }),
1341
1341