@openmrs/esm-app-shell 6.3.1-pre.3105 → 6.3.1-pre.3119

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 (91) hide show
  1. package/.turbo/turbo-build.log +8 -8
  2. package/dist/1aeb256985e33864.js +1 -0
  3. package/dist/1aeb256985e33864.js.map +1 -0
  4. package/dist/f1bf92ff5d8517a7.js.map +1 -0
  5. package/dist/index.html +1 -1
  6. package/dist/{openmrs.10f6e2cb10b05c80.js → openmrs.e1b0b176bb0e5d2d.js} +1 -1
  7. package/dist/{openmrs.10f6e2cb10b05c80.js.map → openmrs.e1b0b176bb0e5d2d.js.map} +1 -1
  8. package/dist/service-worker.js +1 -1
  9. package/lib/{54e8981b7823f373.js → 0b8132da55d43cec.js} +8 -8
  10. package/lib/25718c5560d56ff1.js +112 -0
  11. package/lib/esm-devtools-app/180.js +2 -0
  12. package/lib/esm-devtools-app/180.js.LICENSE.txt +5 -0
  13. package/lib/esm-devtools-app/180.js.map +1 -0
  14. package/lib/esm-devtools-app/248.js +1 -0
  15. package/lib/esm-devtools-app/248.js.map +1 -0
  16. package/lib/esm-devtools-app/326.js +2 -0
  17. package/lib/esm-devtools-app/326.js.LICENSE.txt +9 -0
  18. package/lib/esm-devtools-app/326.js.map +1 -0
  19. package/lib/esm-devtools-app/623.js +2 -0
  20. package/lib/esm-devtools-app/623.js.LICENSE.txt +19 -0
  21. package/lib/esm-devtools-app/623.js.map +1 -0
  22. package/lib/esm-devtools-app/731.js +2 -0
  23. package/lib/esm-devtools-app/731.js.LICENSE.txt +24 -0
  24. package/lib/esm-devtools-app/731.js.map +1 -0
  25. package/lib/esm-devtools-app/769.js +2 -0
  26. package/lib/esm-devtools-app/769.js.LICENSE.txt +39 -0
  27. package/lib/esm-devtools-app/769.js.map +1 -0
  28. package/lib/esm-devtools-app/770.js +2 -0
  29. package/lib/esm-devtools-app/770.js.LICENSE.txt +14 -0
  30. package/lib/esm-devtools-app/770.js.map +1 -0
  31. package/lib/esm-devtools-app/810.js +1 -0
  32. package/lib/esm-devtools-app/810.js.map +1 -0
  33. package/lib/esm-devtools-app/907.js +1 -0
  34. package/lib/esm-devtools-app/907.js.map +1 -0
  35. package/lib/esm-devtools-app/929.js +1 -0
  36. package/lib/esm-devtools-app/929.js.map +1 -0
  37. package/lib/esm-devtools-app/932.js +2 -0
  38. package/lib/esm-devtools-app/932.js.LICENSE.txt +5 -0
  39. package/lib/esm-devtools-app/932.js.map +1 -0
  40. package/lib/esm-devtools-app/main.js +1 -0
  41. package/lib/esm-devtools-app/main.js.map +1 -0
  42. package/lib/esm-devtools-app/openmrs-esm-devtools-app.js +1 -0
  43. package/lib/esm-devtools-app/openmrs-esm-devtools-app.js.buildmanifest.json +447 -0
  44. package/lib/esm-devtools-app/openmrs-esm-devtools-app.js.map +1 -0
  45. package/lib/esm-devtools-app/routes.json +1 -0
  46. package/lib/esm-help-menu-app/810.js +1 -1
  47. package/lib/esm-help-menu-app/810.js.map +1 -1
  48. package/lib/esm-help-menu-app/main.js +1 -1
  49. package/lib/esm-help-menu-app/openmrs-esm-help-menu-app.js +1 -1
  50. package/lib/esm-help-menu-app/openmrs-esm-help-menu-app.js.buildmanifest.json +5 -5
  51. package/lib/esm-help-menu-app/routes.json +1 -1
  52. package/lib/esm-implementer-tools-app/3150.js.map +1 -1
  53. package/lib/esm-implementer-tools-app/4810.js +1 -1
  54. package/lib/esm-implementer-tools-app/4810.js.map +1 -1
  55. package/lib/esm-implementer-tools-app/main.js +1 -1
  56. package/lib/esm-implementer-tools-app/openmrs-esm-implementer-tools-app.js +1 -1
  57. package/lib/esm-implementer-tools-app/openmrs-esm-implementer-tools-app.js.buildmanifest.json +6 -6
  58. package/lib/esm-implementer-tools-app/routes.json +1 -1
  59. package/lib/esm-login-app/5906.js +2 -2
  60. package/lib/esm-login-app/5906.js.map +1 -1
  61. package/lib/esm-login-app/main.js +1 -1
  62. package/lib/esm-login-app/main.js.map +1 -1
  63. package/lib/esm-login-app/openmrs-esm-login-app.js +2 -2
  64. package/lib/esm-login-app/openmrs-esm-login-app.js.buildmanifest.json +5 -5
  65. package/lib/esm-login-app/openmrs-esm-login-app.js.map +1 -1
  66. package/lib/esm-login-app/routes.json +1 -1
  67. package/lib/esm-offline-tools-app/4810.js +1 -1
  68. package/lib/esm-offline-tools-app/4810.js.map +1 -1
  69. package/lib/esm-offline-tools-app/main.js +1 -1
  70. package/lib/esm-offline-tools-app/openmrs-esm-offline-tools-app.js +1 -1
  71. package/lib/esm-offline-tools-app/openmrs-esm-offline-tools-app.js.buildmanifest.json +5 -5
  72. package/lib/esm-offline-tools-app/routes.json +1 -1
  73. package/lib/esm-primary-navigation-app/1404.js.map +1 -1
  74. package/lib/esm-primary-navigation-app/2395.js +1 -1
  75. package/lib/esm-primary-navigation-app/2395.js.map +1 -1
  76. package/lib/esm-primary-navigation-app/3758.js.map +1 -1
  77. package/lib/esm-primary-navigation-app/8577.js.map +1 -1
  78. package/lib/esm-primary-navigation-app/main.js +1 -1
  79. package/lib/esm-primary-navigation-app/main.js.map +1 -1
  80. package/lib/esm-primary-navigation-app/openmrs-esm-primary-navigation-app.js +1 -1
  81. package/lib/esm-primary-navigation-app/openmrs-esm-primary-navigation-app.js.buildmanifest.json +12 -12
  82. package/lib/esm-primary-navigation-app/routes.json +1 -1
  83. package/lib/index.html +2 -2
  84. package/lib/openmrs.js +4 -4
  85. package/lib/service-worker.js +1 -1
  86. package/package.json +3 -3
  87. package/dist/1d86aa5e7b7a2d81.js +0 -1
  88. package/dist/1d86aa5e7b7a2d81.js.map +0 -1
  89. package/dist/6b8a9c458e21b16e.js.map +0 -1
  90. package/lib/db1303a22cb3a6d3.js +0 -112
  91. /package/dist/{6b8a9c458e21b16e.js → f1bf92ff5d8517a7.js} +0 -0
@@ -195,7 +195,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
195
195
  \****************************************************/
196
196
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
197
197
 
198
- 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.user?.userProperties?.defaultLocale ?? data.locale;\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 unsubscribe && unsubscribe();\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.user?.userProperties?.defaultLocale ?? data.locale;\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                unsubscribe && unsubscribe();\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");
198
+ 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.user?.userProperties?.defaultLocale ?? data.locale;\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.user?.userProperties?.defaultLocale ?? data.locale;\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");
199
199
 
200
200
  /***/ }),
201
201
 
@@ -305,7 +305,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n\n//# sourceURL=[module]\n//#
305
305
  \***********************************************************/
306
306
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
307
307
 
308
- eval("__webpack_require__.r(__webpack_exports__);\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1hcGkvZGlzdC90eXBlcy91c2VyLXJlc291cmNlLmpzIiwibWFwcGluZ3MiOiI7QUFBVyIsInNvdXJjZXMiOlsid2VicGFjazovL0BvcGVubXJzL2VzbS1hcHAtc2hlbGwvLi4vLi4vZnJhbWV3b3JrL2VzbS1hcGkvZGlzdC90eXBlcy91c2VyLXJlc291cmNlLmpzPzg3MjQiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgfTtcbiJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///../../framework/esm-api/dist/types/user-resource.js\n");
308
+ eval("__webpack_require__.r(__webpack_exports__);\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1hcGkvZGlzdC90eXBlcy91c2VyLXJlc291cmNlLmpzIiwibWFwcGluZ3MiOiI7QUFBQSxtRUFBbUU7QUFDeEQiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tYXBpL2Rpc3QvdHlwZXMvdXNlci1yZXNvdXJjZS5qcz84NzI0Il0sInNvdXJjZXNDb250ZW50IjpbIi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZW1wdHktb2JqZWN0LXR5cGVcbmV4cG9ydCB7IH07XG4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///../../framework/esm-api/dist/types/user-resource.js\n");
309
309
 
310
310
  /***/ }),
311
311
 
@@ -325,7 +325,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
325
325
  \*******************************************************************/
326
326
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
327
327
 
328
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ getCurrentImportMap: () => (/* binding */ getCurrentImportMap),\n/* harmony export */ importDynamic: () => (/* binding */ importDynamic),\n/* harmony export */ preloadImport: () => (/* binding */ preloadImport),\n/* harmony export */ slugify: () => (/* binding */ slugify)\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_translations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-translations */ \"../../framework/esm-translations/dist/index.js\");\n/** @module @category Dynamic Loading */ \n// hack to make the types defined in esm-globals available here\n\n\n/**\n * @internal\n *\n * Transforms an ESM module name to a valid JS identifier\n *\n * @param name the name of a module\n * @returns An opaque, equivalent JS identifier for the module\n */ function slugify(name) {\n return name.replace(/[\\/\\-@]/g, '_');\n}\n/**\n * Loads the named export from a named package. This might be used like:\n *\n * ```js\n * const { someComponent } = importDynamic(\"@openmrs/esm-template-app\")\n * ```\n *\n * @param jsPackage The package to load the export from.\n * @param share Indicates the name of the shared module; this is an advanced feature if the package you are loading\n * doesn't use the default OpenMRS shared module name \"./start\".\n * @param options Additional options to control loading this script.\n * @param options.importMap The import map to use to load the script. This is useful for situations where you're\n * loading multiple scripts at a time, since it allows the calling code to supply an importMap, saving multiple\n * calls to `getCurrentImportMap()`.\n * @param options.maxLoadingTime A positive integer representing the maximum number of milliseconds to wait for the\n * script to load before the promise returned from this function will be rejected. Defaults to 600,000 milliseconds,\n * i.e., 10 minutes.\n */ async function importDynamic(jsPackage, share = './start', options) {\n // default to 10 minutes\n const maxLoadingTime = !options?.maxLoadingTime || options.maxLoadingTime <= 0 ? 600000 : options.maxLoadingTime;\n let timeout = undefined;\n await Promise.race([\n preloadImport(jsPackage, options?.importMap),\n new Promise((_, reject)=>{\n timeout = setTimeout(()=>{\n reject(new Error(`Could not resolve requested script, ${jsPackage}, within ${humanReadableMs(maxLoadingTime)}.`));\n }, maxLoadingTime);\n })\n ]);\n timeout && clearTimeout(timeout);\n const jsPackageSlug = slugify(jsPackage);\n const container = window[jsPackageSlug];\n if (!isFederatedModule(container)) {\n const error = `The global variable ${jsPackageSlug} does not refer to a federated module`;\n console.error(error);\n throw new Error(error);\n }\n container.init(__webpack_require__.S.default);\n const factory = await container.get(share);\n const module = factory();\n if (!(typeof module === 'object') || module === null) {\n const error = `Container for ${jsPackage} did not return an ESM module as expected`;\n console.error(error);\n throw new Error(error);\n }\n return module;\n}\n/**\n * Utility function to convert milliseconds into human-readable strings with rather absurd\n * levels of precision.\n *\n * @param ms Number of milliseconds\n * @returns A human-readable string useful only for error logging, where we can assume English\n */ function humanReadableMs(ms) {\n if (ms < 1000) {\n return `${ms} milliseconds`;\n } else if (ms < 60000) {\n return `${Math.floor(ms / 1000)} seconds`;\n } else if (ms < 3600000) {\n return `${Math.floor(ms / 60000)} minutes`;\n } else if (ms < 86400000) {\n return `${Math.floor(ms / 3600000)} hours`;\n } else {\n return `${Math.floor(ms / 86400000)} days`;\n }\n}\n/**\n * @internal\n *\n * This internal method is used to ensure that the script belonging\n * to the given package is loaded and added to the head.\n *\n * @param jsPackage The package to load\n * @param importMap The import map to use for loading this package.\n * The main reason for specifying this is to avoid needing to call\n * `getCurrentPageMap()` for every script when bulk loading.\n */ async function preloadImport(jsPackage, importMap) {\n if (typeof jsPackage !== 'string' || jsPackage.trim().length === 0) {\n const error = 'Attempted to call importDynamic() without supplying a package to load';\n console.error(error);\n throw new Error(error);\n }\n const jsPackageSlug = slugify(jsPackage);\n if (!window[jsPackageSlug]) {\n const activeImportMap = importMap ?? await getCurrentImportMap();\n if (!activeImportMap.imports.hasOwnProperty(jsPackage)) {\n const error = `Could not find the package ${jsPackage} defined in the current importmap`;\n console.error(error);\n throw new Error(error);\n }\n let url = activeImportMap.imports[jsPackage];\n if (url.startsWith('./')) {\n url = window.spaBase + url.substring(1);\n }\n const isOverridden = !!window.localStorage.getItem(`import-map-override:${jsPackage}`);\n try {\n return await new Promise((resolve, reject)=>{\n loadScript(url, resolve, reject);\n });\n } catch (err) {\n if (isOverridden) {\n (0,_openmrs_esm_globals__WEBPACK_IMPORTED_MODULE_0__.dispatchToastShown)({\n kind: 'error',\n title: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_1__.getCoreTranslation)('scriptLoadingFailed', 'Error: Script failed to load'),\n description: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_1__.getCoreTranslation)('scriptLoadingError', 'Failed to load overridden script from {{- url}}. Please check that the bundled script is available at the expected URL. Click the button below to reset all import map overrides.', {\n url\n }),\n actionButtonLabel: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_1__.getCoreTranslation)('resetOverrides', 'Reset overrides'),\n onActionButtonClick () {\n window.importMapOverrides.resetOverrides();\n window.location.reload();\n }\n });\n }\n return Promise.reject(err);\n }\n }\n return Promise.resolve();\n}\n/**\n * @internal\n *\n * Used to load the current import map\n *\n * @returns The current page map\n */ async function getCurrentImportMap() {\n return window.importMapOverrides.getCurrentPageMap();\n}\nfunction isFederatedModule(a) {\n return typeof a === 'object' && a !== null && 'init' in a && typeof a['init'] === 'function' && 'get' in a && typeof a['get'] === 'function';\n}\n// internals to track script loading\n// basically, if we're already loading a script, we should wait until the script is loaded\n// we use a global to track this\nconst OPENMRS_SCRIPT_LOADING = Symbol('__openmrs_script_loading');\n/**\n * Appends a `<script>` to the DOM with the given URL.\n */ function loadScript(url, resolve, reject) {\n const scriptElement = document.head.querySelector(`script[src=\"${url}\"]`);\n let scriptLoading = window[OPENMRS_SCRIPT_LOADING];\n if (!scriptLoading) {\n scriptLoading = window[OPENMRS_SCRIPT_LOADING] = new Set([]);\n }\n if (!scriptElement) {\n scriptLoading.add(url);\n const element = document.createElement('script');\n element.src = url;\n element.type = 'text/javascript';\n element.async = true;\n // loadTime() displays an error if a script takes more than 5 seconds to load\n const loadTimeout = setTimeout(()=>{\n console.error(`The script at ${url} did not load within 5 seconds. This may indicate an issue with the imports in the script's entry-point file or with the script's bundler configuration.`);\n }, 5000); // 5 seconds; this is arbitrary\n let loadFn, errFn, finishScriptLoading;\n finishScriptLoading = ()=>{\n clearTimeout(loadTimeout);\n scriptLoading.delete(url);\n loadFn && element.removeEventListener('load', loadFn);\n errFn && element.removeEventListener('error', errFn);\n };\n loadFn = ()=>{\n finishScriptLoading();\n resolve(null);\n };\n errFn = (ev)=>{\n finishScriptLoading();\n const msg = `Failed to load script from ${url}`;\n console.error(msg, ev);\n reject(ev.message ?? msg);\n };\n element.addEventListener('load', loadFn);\n element.addEventListener('error', errFn);\n document.head.appendChild(element);\n } else {\n if (scriptLoading.has(url)) {\n let loadFn, errFn, finishScriptLoading;\n finishScriptLoading = ()=>{\n loadFn && scriptElement.removeEventListener('load', loadFn);\n errFn && scriptElement.removeEventListener('error', errFn);\n };\n loadFn = ()=>{\n finishScriptLoading();\n resolve(null);\n };\n // this errFn does not log anything\n errFn = (ev)=>{\n finishScriptLoading();\n reject(ev.message);\n };\n scriptElement.addEventListener('load', loadFn);\n scriptElement.addEventListener('error', errFn);\n } else {\n console.warn(`Script at ${url} already loaded. Not loading it again.`);\n resolve(null);\n }\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-dynamic-loading/dist/dynamic-loading.js","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-dynamic-loading/dist/dynamic-loading.js?ecdf"],"sourcesContent":["/** @module @category Dynamic Loading */ 'use strict';\n// hack to make the types defined in esm-globals available here\nimport { dispatchToastShown } from \"@openmrs/esm-globals\";\nimport { getCoreTranslation } from \"@openmrs/esm-translations\";\n/**\n * @internal\n *\n * Transforms an ESM module name to a valid JS identifier\n *\n * @param name the name of a module\n * @returns An opaque, equivalent JS identifier for the module\n */ export function slugify(name) {\n    return name.replace(/[\\/\\-@]/g, '_');\n}\n/**\n * Loads the named export from a named package. This might be used like:\n *\n * ```js\n * const { someComponent } = importDynamic(\"@openmrs/esm-template-app\")\n * ```\n *\n * @param jsPackage The package to load the export from.\n * @param share Indicates the name of the shared module; this is an advanced feature if the package you are loading\n *   doesn't use the default OpenMRS shared module name \"./start\".\n * @param options Additional options to control loading this script.\n * @param options.importMap The import map to use to load the script. This is useful for situations where you're\n *   loading multiple scripts at a time, since it allows the calling code to supply an importMap, saving multiple\n *   calls to `getCurrentImportMap()`.\n * @param options.maxLoadingTime A positive integer representing the maximum number of milliseconds to wait for the\n *   script to load before the promise returned from this function will be rejected. Defaults to 600,000 milliseconds,\n *   i.e., 10 minutes.\n */ export async function importDynamic(jsPackage, share = './start', options) {\n    // default to 10 minutes\n    const maxLoadingTime = !options?.maxLoadingTime || options.maxLoadingTime <= 0 ? 600000 : options.maxLoadingTime;\n    let timeout = undefined;\n    await Promise.race([\n        preloadImport(jsPackage, options?.importMap),\n        new Promise((_, reject)=>{\n            timeout = setTimeout(()=>{\n                reject(new Error(`Could not resolve requested script, ${jsPackage}, within ${humanReadableMs(maxLoadingTime)}.`));\n            }, maxLoadingTime);\n        })\n    ]);\n    timeout && clearTimeout(timeout);\n    const jsPackageSlug = slugify(jsPackage);\n    const container = window[jsPackageSlug];\n    if (!isFederatedModule(container)) {\n        const error = `The global variable ${jsPackageSlug} does not refer to a federated module`;\n        console.error(error);\n        throw new Error(error);\n    }\n    container.init(__webpack_share_scopes__.default);\n    const factory = await container.get(share);\n    const module = factory();\n    if (!(typeof module === 'object') || module === null) {\n        const error = `Container for ${jsPackage} did not return an ESM module as expected`;\n        console.error(error);\n        throw new Error(error);\n    }\n    return module;\n}\n/**\n * Utility function to convert milliseconds into human-readable strings with rather absurd\n * levels of precision.\n *\n * @param ms Number of milliseconds\n * @returns A human-readable string useful only for error logging, where we can assume English\n */ function humanReadableMs(ms) {\n    if (ms < 1000) {\n        return `${ms} milliseconds`;\n    } else if (ms < 60000) {\n        return `${Math.floor(ms / 1000)} seconds`;\n    } else if (ms < 3600000) {\n        return `${Math.floor(ms / 60000)} minutes`;\n    } else if (ms < 86400000) {\n        return `${Math.floor(ms / 3600000)} hours`;\n    } else {\n        return `${Math.floor(ms / 86400000)} days`;\n    }\n}\n/**\n * @internal\n *\n * This internal method is used to ensure that the script belonging\n * to the given package is loaded and added to the head.\n *\n * @param jsPackage The package to load\n * @param importMap The import map to use for loading this package.\n *  The main reason for specifying this is to avoid needing to call\n *  `getCurrentPageMap()` for every script when bulk loading.\n */ export async function preloadImport(jsPackage, importMap) {\n    if (typeof jsPackage !== 'string' || jsPackage.trim().length === 0) {\n        const error = 'Attempted to call importDynamic() without supplying a package to load';\n        console.error(error);\n        throw new Error(error);\n    }\n    const jsPackageSlug = slugify(jsPackage);\n    if (!window[jsPackageSlug]) {\n        const activeImportMap = importMap ?? await getCurrentImportMap();\n        if (!activeImportMap.imports.hasOwnProperty(jsPackage)) {\n            const error = `Could not find the package ${jsPackage} defined in the current importmap`;\n            console.error(error);\n            throw new Error(error);\n        }\n        let url = activeImportMap.imports[jsPackage];\n        if (url.startsWith('./')) {\n            url = window.spaBase + url.substring(1);\n        }\n        const isOverridden = !!window.localStorage.getItem(`import-map-override:${jsPackage}`);\n        try {\n            return await new Promise((resolve, reject)=>{\n                loadScript(url, resolve, reject);\n            });\n        } catch (err) {\n            if (isOverridden) {\n                dispatchToastShown({\n                    kind: 'error',\n                    title: getCoreTranslation('scriptLoadingFailed', 'Error: Script failed to load'),\n                    description: getCoreTranslation('scriptLoadingError', 'Failed to load overridden script from {{- url}}. Please check that the bundled script is available at the expected URL. Click the button below to reset all import map overrides.', {\n                        url\n                    }),\n                    actionButtonLabel: getCoreTranslation('resetOverrides', 'Reset overrides'),\n                    onActionButtonClick () {\n                        window.importMapOverrides.resetOverrides();\n                        window.location.reload();\n                    }\n                });\n            }\n            return Promise.reject(err);\n        }\n    }\n    return Promise.resolve();\n}\n/**\n * @internal\n *\n * Used to load the current import map\n *\n * @returns The current page map\n */ export async function getCurrentImportMap() {\n    return window.importMapOverrides.getCurrentPageMap();\n}\nfunction isFederatedModule(a) {\n    return typeof a === 'object' && a !== null && 'init' in a && typeof a['init'] === 'function' && 'get' in a && typeof a['get'] === 'function';\n}\n// internals to track script loading\n// basically, if we're already loading a script, we should wait until the script is loaded\n// we use a global to track this\nconst OPENMRS_SCRIPT_LOADING = Symbol('__openmrs_script_loading');\n/**\n * Appends a `<script>` to the DOM with the given URL.\n */ function loadScript(url, resolve, reject) {\n    const scriptElement = document.head.querySelector(`script[src=\"${url}\"]`);\n    let scriptLoading = window[OPENMRS_SCRIPT_LOADING];\n    if (!scriptLoading) {\n        scriptLoading = window[OPENMRS_SCRIPT_LOADING] = new Set([]);\n    }\n    if (!scriptElement) {\n        scriptLoading.add(url);\n        const element = document.createElement('script');\n        element.src = url;\n        element.type = 'text/javascript';\n        element.async = true;\n        // loadTime() displays an error if a script takes more than 5 seconds to load\n        const loadTimeout = setTimeout(()=>{\n            console.error(`The script at ${url} did not load within 5 seconds. This may indicate an issue with the imports in the script's entry-point file or with the script's bundler configuration.`);\n        }, 5000); // 5 seconds; this is arbitrary\n        let loadFn, errFn, finishScriptLoading;\n        finishScriptLoading = ()=>{\n            clearTimeout(loadTimeout);\n            scriptLoading.delete(url);\n            loadFn && element.removeEventListener('load', loadFn);\n            errFn && element.removeEventListener('error', errFn);\n        };\n        loadFn = ()=>{\n            finishScriptLoading();\n            resolve(null);\n        };\n        errFn = (ev)=>{\n            finishScriptLoading();\n            const msg = `Failed to load script from ${url}`;\n            console.error(msg, ev);\n            reject(ev.message ?? msg);\n        };\n        element.addEventListener('load', loadFn);\n        element.addEventListener('error', errFn);\n        document.head.appendChild(element);\n    } else {\n        if (scriptLoading.has(url)) {\n            let loadFn, errFn, finishScriptLoading;\n            finishScriptLoading = ()=>{\n                loadFn && scriptElement.removeEventListener('load', loadFn);\n                errFn && scriptElement.removeEventListener('error', errFn);\n            };\n            loadFn = ()=>{\n                finishScriptLoading();\n                resolve(null);\n            };\n            // this errFn does not log anything\n            errFn = (ev)=>{\n                finishScriptLoading();\n                reject(ev.message);\n            };\n            scriptElement.addEventListener('load', loadFn);\n            scriptElement.addEventListener('error', errFn);\n        } else {\n            console.warn(`Script at ${url} already loaded. Not loading it again.`);\n            resolve(null);\n        }\n    }\n}\n"],"names":["dispatchToastShown","getCoreTranslation","slugify","name","replace","importDynamic","jsPackage","share","options","maxLoadingTime","timeout","undefined","Promise","race","preloadImport","importMap","_","reject","setTimeout","Error","humanReadableMs","clearTimeout","jsPackageSlug","container","window","isFederatedModule","error","console","init","__webpack_share_scopes__","default","factory","get","module","ms","Math","floor","trim","length","activeImportMap","getCurrentImportMap","imports","hasOwnProperty","url","startsWith","spaBase","substring","isOverridden","localStorage","getItem","resolve","loadScript","err","kind","title","description","actionButtonLabel","onActionButtonClick","importMapOverrides","resetOverrides","location","reload","getCurrentPageMap","a","OPENMRS_SCRIPT_LOADING","Symbol","scriptElement","document","head","querySelector","scriptLoading","Set","add","element","createElement","src","type","async","loadTimeout","loadFn","errFn","finishScriptLoading","delete","removeEventListener","ev","msg","message","addEventListener","appendChild","has","warn"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-dynamic-loading/dist/dynamic-loading.js\n");
328
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ getCurrentImportMap: () => (/* binding */ getCurrentImportMap),\n/* harmony export */ importDynamic: () => (/* binding */ importDynamic),\n/* harmony export */ preloadImport: () => (/* binding */ preloadImport),\n/* harmony export */ slugify: () => (/* binding */ slugify)\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_translations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-translations */ \"../../framework/esm-translations/dist/index.js\");\n/** @module @category Dynamic Loading */ \n// hack to make the types defined in esm-globals available here\n\n\n/**\n * @internal\n *\n * Transforms an ESM module name to a valid JS identifier\n *\n * @param name the name of a module\n * @returns An opaque, equivalent JS identifier for the module\n */ function slugify(name) {\n return name.replace(/[\\/\\-@]/g, '_');\n}\n/**\n * Loads the named export from a named package. This might be used like:\n *\n * ```js\n * const { someComponent } = importDynamic(\"@openmrs/esm-template-app\")\n * ```\n *\n * @param jsPackage The package to load the export from.\n * @param share Indicates the name of the shared module; this is an advanced feature if the package you are loading\n * doesn't use the default OpenMRS shared module name \"./start\".\n * @param options Additional options to control loading this script.\n * @param options.importMap The import map to use to load the script. This is useful for situations where you're\n * loading multiple scripts at a time, since it allows the calling code to supply an importMap, saving multiple\n * calls to `getCurrentImportMap()`.\n * @param options.maxLoadingTime A positive integer representing the maximum number of milliseconds to wait for the\n * script to load before the promise returned from this function will be rejected. Defaults to 600,000 milliseconds,\n * i.e., 10 minutes.\n */ async function importDynamic(jsPackage, share = './start', options) {\n // default to 10 minutes\n const maxLoadingTime = !options?.maxLoadingTime || options.maxLoadingTime <= 0 ? 600000 : options.maxLoadingTime;\n let timeout = undefined;\n await Promise.race([\n preloadImport(jsPackage, options?.importMap),\n new Promise((_, reject)=>{\n timeout = setTimeout(()=>{\n reject(new Error(`Could not resolve requested script, ${jsPackage}, within ${humanReadableMs(maxLoadingTime)}.`));\n }, maxLoadingTime);\n })\n ]);\n if (timeout) {\n clearTimeout(timeout);\n }\n const jsPackageSlug = slugify(jsPackage);\n const container = window[jsPackageSlug];\n if (!isFederatedModule(container)) {\n const error = `The global variable ${jsPackageSlug} does not refer to a federated module`;\n console.error(error);\n throw new Error(error);\n }\n container.init(__webpack_require__.S.default);\n const factory = await container.get(share);\n const module = factory();\n if (!(typeof module === 'object') || module === null) {\n const error = `Container for ${jsPackage} did not return an ESM module as expected`;\n console.error(error);\n throw new Error(error);\n }\n return module;\n}\n/**\n * Utility function to convert milliseconds into human-readable strings with rather absurd\n * levels of precision.\n *\n * @param ms Number of milliseconds\n * @returns A human-readable string useful only for error logging, where we can assume English\n */ function humanReadableMs(ms) {\n if (ms < 1000) {\n return `${ms} milliseconds`;\n } else if (ms < 60000) {\n return `${Math.floor(ms / 1000)} seconds`;\n } else if (ms < 3600000) {\n return `${Math.floor(ms / 60000)} minutes`;\n } else if (ms < 86400000) {\n return `${Math.floor(ms / 3600000)} hours`;\n } else {\n return `${Math.floor(ms / 86400000)} days`;\n }\n}\n/**\n * @internal\n *\n * This internal method is used to ensure that the script belonging\n * to the given package is loaded and added to the head.\n *\n * @param jsPackage The package to load\n * @param importMap The import map to use for loading this package.\n * The main reason for specifying this is to avoid needing to call\n * `getCurrentPageMap()` for every script when bulk loading.\n */ async function preloadImport(jsPackage, importMap) {\n if (typeof jsPackage !== 'string' || jsPackage.trim().length === 0) {\n const error = 'Attempted to call importDynamic() without supplying a package to load';\n console.error(error);\n throw new Error(error);\n }\n const jsPackageSlug = slugify(jsPackage);\n if (!window[jsPackageSlug]) {\n const activeImportMap = importMap ?? await getCurrentImportMap();\n if (!activeImportMap.imports.hasOwnProperty(jsPackage)) {\n const error = `Could not find the package ${jsPackage} defined in the current importmap`;\n console.error(error);\n throw new Error(error);\n }\n let url = activeImportMap.imports[jsPackage];\n if (url.startsWith('./')) {\n url = window.spaBase + url.substring(1);\n }\n const isOverridden = !!window.localStorage.getItem(`import-map-override:${jsPackage}`);\n try {\n return await new Promise((resolve, reject)=>{\n loadScript(url, resolve, reject);\n });\n } catch (err) {\n if (isOverridden) {\n (0,_openmrs_esm_globals__WEBPACK_IMPORTED_MODULE_0__.dispatchToastShown)({\n kind: 'error',\n title: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_1__.getCoreTranslation)('scriptLoadingFailed', 'Error: Script failed to load'),\n description: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_1__.getCoreTranslation)('scriptLoadingError', 'Failed to load overridden script from {{- url}}. Please check that the bundled script is available at the expected URL. Click the button below to reset all import map overrides.', {\n url\n }),\n actionButtonLabel: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_1__.getCoreTranslation)('resetOverrides', 'Reset overrides'),\n onActionButtonClick () {\n window.importMapOverrides.resetOverrides();\n window.location.reload();\n }\n });\n }\n return Promise.reject(err);\n }\n }\n return Promise.resolve();\n}\n/**\n * @internal\n *\n * Used to load the current import map\n *\n * @returns The current page map\n */ async function getCurrentImportMap() {\n return window.importMapOverrides.getCurrentPageMap();\n}\nfunction isFederatedModule(a) {\n return typeof a === 'object' && a !== null && 'init' in a && typeof a['init'] === 'function' && 'get' in a && typeof a['get'] === 'function';\n}\n// internals to track script loading\n// basically, if we're already loading a script, we should wait until the script is loaded\n// we use a global to track this\nconst OPENMRS_SCRIPT_LOADING = Symbol('__openmrs_script_loading');\n/**\n * Appends a `<script>` to the DOM with the given URL.\n */ function loadScript(url, resolve, reject) {\n const scriptElement = document.head.querySelector(`script[src=\"${url}\"]`);\n let scriptLoading = window[OPENMRS_SCRIPT_LOADING];\n if (!scriptLoading) {\n scriptLoading = window[OPENMRS_SCRIPT_LOADING] = new Set([]);\n }\n if (!scriptElement) {\n scriptLoading.add(url);\n const element = document.createElement('script');\n element.src = url;\n element.type = 'text/javascript';\n element.async = true;\n // loadTime() displays an error if a script takes more than 5 seconds to load\n const loadTimeout = setTimeout(()=>{\n console.error(`The script at ${url} did not load within 5 seconds. This may indicate an issue with the imports in the script's entry-point file or with the script's bundler configuration.`);\n }, 5000); // 5 seconds; this is arbitrary\n let loadFn, errFn, finishScriptLoading;\n finishScriptLoading = ()=>{\n clearTimeout(loadTimeout);\n scriptLoading.delete(url);\n if (loadFn) {\n element.removeEventListener('load', loadFn);\n }\n if (errFn) {\n element.removeEventListener('error', errFn);\n }\n };\n loadFn = ()=>{\n finishScriptLoading();\n resolve(null);\n };\n errFn = (ev)=>{\n finishScriptLoading();\n const msg = `Failed to load script from ${url}`;\n console.error(msg, ev);\n reject(ev.message ?? msg);\n };\n element.addEventListener('load', loadFn);\n element.addEventListener('error', errFn);\n document.head.appendChild(element);\n } else {\n if (scriptLoading.has(url)) {\n let loadFn, errFn, finishScriptLoading;\n finishScriptLoading = ()=>{\n if (loadFn) {\n scriptElement.removeEventListener('load', loadFn);\n }\n if (errFn) {\n scriptElement.removeEventListener('error', errFn);\n }\n };\n loadFn = ()=>{\n finishScriptLoading();\n resolve(null);\n };\n // this errFn does not log anything\n errFn = (ev)=>{\n finishScriptLoading();\n reject(ev.message);\n };\n scriptElement.addEventListener('load', loadFn);\n scriptElement.addEventListener('error', errFn);\n } else {\n console.warn(`Script at ${url} already loaded. Not loading it again.`);\n resolve(null);\n }\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-dynamic-loading/dist/dynamic-loading.js","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-dynamic-loading/dist/dynamic-loading.js?ecdf"],"sourcesContent":["/** @module @category Dynamic Loading */ 'use strict';\n// hack to make the types defined in esm-globals available here\nimport { dispatchToastShown } from \"@openmrs/esm-globals\";\nimport { getCoreTranslation } from \"@openmrs/esm-translations\";\n/**\n * @internal\n *\n * Transforms an ESM module name to a valid JS identifier\n *\n * @param name the name of a module\n * @returns An opaque, equivalent JS identifier for the module\n */ export function slugify(name) {\n    return name.replace(/[\\/\\-@]/g, '_');\n}\n/**\n * Loads the named export from a named package. This might be used like:\n *\n * ```js\n * const { someComponent } = importDynamic(\"@openmrs/esm-template-app\")\n * ```\n *\n * @param jsPackage The package to load the export from.\n * @param share Indicates the name of the shared module; this is an advanced feature if the package you are loading\n *   doesn't use the default OpenMRS shared module name \"./start\".\n * @param options Additional options to control loading this script.\n * @param options.importMap The import map to use to load the script. This is useful for situations where you're\n *   loading multiple scripts at a time, since it allows the calling code to supply an importMap, saving multiple\n *   calls to `getCurrentImportMap()`.\n * @param options.maxLoadingTime A positive integer representing the maximum number of milliseconds to wait for the\n *   script to load before the promise returned from this function will be rejected. Defaults to 600,000 milliseconds,\n *   i.e., 10 minutes.\n */ export async function importDynamic(jsPackage, share = './start', options) {\n    // default to 10 minutes\n    const maxLoadingTime = !options?.maxLoadingTime || options.maxLoadingTime <= 0 ? 600000 : options.maxLoadingTime;\n    let timeout = undefined;\n    await Promise.race([\n        preloadImport(jsPackage, options?.importMap),\n        new Promise((_, reject)=>{\n            timeout = setTimeout(()=>{\n                reject(new Error(`Could not resolve requested script, ${jsPackage}, within ${humanReadableMs(maxLoadingTime)}.`));\n            }, maxLoadingTime);\n        })\n    ]);\n    if (timeout) {\n        clearTimeout(timeout);\n    }\n    const jsPackageSlug = slugify(jsPackage);\n    const container = window[jsPackageSlug];\n    if (!isFederatedModule(container)) {\n        const error = `The global variable ${jsPackageSlug} does not refer to a federated module`;\n        console.error(error);\n        throw new Error(error);\n    }\n    container.init(__webpack_share_scopes__.default);\n    const factory = await container.get(share);\n    const module = factory();\n    if (!(typeof module === 'object') || module === null) {\n        const error = `Container for ${jsPackage} did not return an ESM module as expected`;\n        console.error(error);\n        throw new Error(error);\n    }\n    return module;\n}\n/**\n * Utility function to convert milliseconds into human-readable strings with rather absurd\n * levels of precision.\n *\n * @param ms Number of milliseconds\n * @returns A human-readable string useful only for error logging, where we can assume English\n */ function humanReadableMs(ms) {\n    if (ms < 1000) {\n        return `${ms} milliseconds`;\n    } else if (ms < 60000) {\n        return `${Math.floor(ms / 1000)} seconds`;\n    } else if (ms < 3600000) {\n        return `${Math.floor(ms / 60000)} minutes`;\n    } else if (ms < 86400000) {\n        return `${Math.floor(ms / 3600000)} hours`;\n    } else {\n        return `${Math.floor(ms / 86400000)} days`;\n    }\n}\n/**\n * @internal\n *\n * This internal method is used to ensure that the script belonging\n * to the given package is loaded and added to the head.\n *\n * @param jsPackage The package to load\n * @param importMap The import map to use for loading this package.\n *  The main reason for specifying this is to avoid needing to call\n *  `getCurrentPageMap()` for every script when bulk loading.\n */ export async function preloadImport(jsPackage, importMap) {\n    if (typeof jsPackage !== 'string' || jsPackage.trim().length === 0) {\n        const error = 'Attempted to call importDynamic() without supplying a package to load';\n        console.error(error);\n        throw new Error(error);\n    }\n    const jsPackageSlug = slugify(jsPackage);\n    if (!window[jsPackageSlug]) {\n        const activeImportMap = importMap ?? await getCurrentImportMap();\n        if (!activeImportMap.imports.hasOwnProperty(jsPackage)) {\n            const error = `Could not find the package ${jsPackage} defined in the current importmap`;\n            console.error(error);\n            throw new Error(error);\n        }\n        let url = activeImportMap.imports[jsPackage];\n        if (url.startsWith('./')) {\n            url = window.spaBase + url.substring(1);\n        }\n        const isOverridden = !!window.localStorage.getItem(`import-map-override:${jsPackage}`);\n        try {\n            return await new Promise((resolve, reject)=>{\n                loadScript(url, resolve, reject);\n            });\n        } catch (err) {\n            if (isOverridden) {\n                dispatchToastShown({\n                    kind: 'error',\n                    title: getCoreTranslation('scriptLoadingFailed', 'Error: Script failed to load'),\n                    description: getCoreTranslation('scriptLoadingError', 'Failed to load overridden script from {{- url}}. Please check that the bundled script is available at the expected URL. Click the button below to reset all import map overrides.', {\n                        url\n                    }),\n                    actionButtonLabel: getCoreTranslation('resetOverrides', 'Reset overrides'),\n                    onActionButtonClick () {\n                        window.importMapOverrides.resetOverrides();\n                        window.location.reload();\n                    }\n                });\n            }\n            return Promise.reject(err);\n        }\n    }\n    return Promise.resolve();\n}\n/**\n * @internal\n *\n * Used to load the current import map\n *\n * @returns The current page map\n */ export async function getCurrentImportMap() {\n    return window.importMapOverrides.getCurrentPageMap();\n}\nfunction isFederatedModule(a) {\n    return typeof a === 'object' && a !== null && 'init' in a && typeof a['init'] === 'function' && 'get' in a && typeof a['get'] === 'function';\n}\n// internals to track script loading\n// basically, if we're already loading a script, we should wait until the script is loaded\n// we use a global to track this\nconst OPENMRS_SCRIPT_LOADING = Symbol('__openmrs_script_loading');\n/**\n * Appends a `<script>` to the DOM with the given URL.\n */ function loadScript(url, resolve, reject) {\n    const scriptElement = document.head.querySelector(`script[src=\"${url}\"]`);\n    let scriptLoading = window[OPENMRS_SCRIPT_LOADING];\n    if (!scriptLoading) {\n        scriptLoading = window[OPENMRS_SCRIPT_LOADING] = new Set([]);\n    }\n    if (!scriptElement) {\n        scriptLoading.add(url);\n        const element = document.createElement('script');\n        element.src = url;\n        element.type = 'text/javascript';\n        element.async = true;\n        // loadTime() displays an error if a script takes more than 5 seconds to load\n        const loadTimeout = setTimeout(()=>{\n            console.error(`The script at ${url} did not load within 5 seconds. This may indicate an issue with the imports in the script's entry-point file or with the script's bundler configuration.`);\n        }, 5000); // 5 seconds; this is arbitrary\n        let loadFn, errFn, finishScriptLoading;\n        finishScriptLoading = ()=>{\n            clearTimeout(loadTimeout);\n            scriptLoading.delete(url);\n            if (loadFn) {\n                element.removeEventListener('load', loadFn);\n            }\n            if (errFn) {\n                element.removeEventListener('error', errFn);\n            }\n        };\n        loadFn = ()=>{\n            finishScriptLoading();\n            resolve(null);\n        };\n        errFn = (ev)=>{\n            finishScriptLoading();\n            const msg = `Failed to load script from ${url}`;\n            console.error(msg, ev);\n            reject(ev.message ?? msg);\n        };\n        element.addEventListener('load', loadFn);\n        element.addEventListener('error', errFn);\n        document.head.appendChild(element);\n    } else {\n        if (scriptLoading.has(url)) {\n            let loadFn, errFn, finishScriptLoading;\n            finishScriptLoading = ()=>{\n                if (loadFn) {\n                    scriptElement.removeEventListener('load', loadFn);\n                }\n                if (errFn) {\n                    scriptElement.removeEventListener('error', errFn);\n                }\n            };\n            loadFn = ()=>{\n                finishScriptLoading();\n                resolve(null);\n            };\n            // this errFn does not log anything\n            errFn = (ev)=>{\n                finishScriptLoading();\n                reject(ev.message);\n            };\n            scriptElement.addEventListener('load', loadFn);\n            scriptElement.addEventListener('error', errFn);\n        } else {\n            console.warn(`Script at ${url} already loaded. Not loading it again.`);\n            resolve(null);\n        }\n    }\n}\n"],"names":["dispatchToastShown","getCoreTranslation","slugify","name","replace","importDynamic","jsPackage","share","options","maxLoadingTime","timeout","undefined","Promise","race","preloadImport","importMap","_","reject","setTimeout","Error","humanReadableMs","clearTimeout","jsPackageSlug","container","window","isFederatedModule","error","console","init","__webpack_share_scopes__","default","factory","get","module","ms","Math","floor","trim","length","activeImportMap","getCurrentImportMap","imports","hasOwnProperty","url","startsWith","spaBase","substring","isOverridden","localStorage","getItem","resolve","loadScript","err","kind","title","description","actionButtonLabel","onActionButtonClick","importMapOverrides","resetOverrides","location","reload","getCurrentPageMap","a","OPENMRS_SCRIPT_LOADING","Symbol","scriptElement","document","head","querySelector","scriptLoading","Set","add","element","createElement","src","type","async","loadTimeout","loadFn","errFn","finishScriptLoading","delete","removeEventListener","ev","msg","message","addEventListener","appendChild","has","warn"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-dynamic-loading/dist/dynamic-loading.js\n");
329
329
 
330
330
  /***/ }),
331
331
 
@@ -1305,7 +1305,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
1305
1305
  \**********************************************************/
1306
1306
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
1307
1307
 
1308
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ __cleanup: () => (/* binding */ __cleanup),\n/* harmony export */ useSession: () => (/* binding */ useSession)\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 react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/** @module @category API */ \n\nlet promise;\n/**\n * Gets the current user session information. Returns an object with\n * property `authenticated` == `false` if the user is not logged in.\n *\n * Uses Suspense. This hook will always either return a Session object\n * or throw for Suspense. It will never return `null`/`undefined`.\n *\n * @returns Current user session information\n */ function useSession() {\n // We have two separate variables for the session.\n //\n // `session` is a temporary variable, which starts as `null` every time this\n // hook is executed. It is important that we can set and return this\n // variable synchronously, because every time we `throw` for Suspense, this\n // hook will unmount and a new instance will be created, destroying whatever\n // state existed. Thus, if this hook were to try to always set and return\n // `stateSession`, it would cause an infinite loop:\n // 1. instance A mounts\n // 2. instance A receives value, calls `setStateSession`\n // 3. instance A throws\n // 4. instance A unmounts\n // 5. instance B mounts\n // ...\n // What would happen if we moved `session` to the module scope, so that it\n // could be re-used across instances of this hook? Then we would have no way\n // to tell whether the session was fresh.\n //\n // `stateSession` is React state, which is needed to update components using\n // this hook when the session changes.\n const unsubscribe = (0,react__WEBPACK_IMPORTED_MODULE_1__.useRef)();\n const [stateSession, setStateSession] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)(null);\n let session = null;\n if (!stateSession) {\n if (!promise) {\n // If we haven't created a promise to throw yet, do that.\n // current-user.ts handles the initial session fetch as soon as `getSessionStore()`\n // is called. We just need to call it and set up a listener for when session data\n // is loaded. As soon as we have the initial session data, we remove this initial\n // store subscription so we can set up the \"ongoing\" one later.\n promise = new Promise((resolve)=>{\n const handleNewSession = ({ loaded, session: newSession })=>{\n if (loaded) {\n resolve(newSession);\n session = newSession;\n unsubscribe.current && unsubscribe.current();\n unsubscribe.current = undefined;\n }\n };\n handleNewSession((0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.getSessionStore)().getState());\n if (!session) {\n unsubscribe.current = (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.getSessionStore)().subscribe(handleNewSession);\n }\n });\n } else {\n // However, if we have created a promise to throw, but there's no `stateSession`\n // yet, then it's probably just this hook's first render. Check to see if\n // there's already a session that we can return.\n const currentState = (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.getSessionStore)().getState();\n if (currentState.loaded) {\n session = currentState.session;\n }\n }\n // If the session got set synchronously in the above block, then we can just\n // return it rather than throwing. Otherwise, throw for Suspense.\n if (session) {\n setStateSession(session);\n } else {\n throw promise;\n }\n }\n // Once this hook is established (no longer throwing and getting re-created)\n // we need to set up a subscription that will update its value the good\n // old-fashioned React way. We are re-using the `unsubscribe` ref from the\n // initial subscription, which should have been vacated by the first time we\n // get here.\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(()=>{\n if (!unsubscribe.current) {\n unsubscribe.current = (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.getSessionStore)().subscribe(({ loaded, session: newSession })=>{\n if (loaded) {\n session = newSession;\n setStateSession(newSession);\n }\n });\n }\n return ()=>{\n unsubscribe.current && unsubscribe.current();\n unsubscribe.current = undefined;\n };\n }, []);\n const result = stateSession || session;\n if (!result) {\n if (promise) {\n console.warn('useSession is in an unexpected state. Attempting to recover.');\n throw promise;\n } else {\n throw Error('useSession is in an invalid state.');\n }\n }\n return result;\n}\n/**\n * For testing.\n */ function __cleanup() {\n promise = undefined;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-react-utils/dist/useSession.js","mappings":";;;;;;;AAAA,0BAA0B,GAAsD;AAC5B;AACpD,IAAII;AACJ;;;;;;;;CAQC,GAAU,SAASC;IAChB,kDAAkD;IAClD,EAAE;IACF,4EAA4E;IAC5E,oEAAoE;IACpE,2EAA2E;IAC3E,4EAA4E;IAC5E,yEAAyE;IACzE,mDAAmD;IACnD,yBAAyB;IACzB,0DAA0D;IAC1D,yBAAyB;IACzB,2BAA2B;IAC3B,yBAAyB;IACzB,QAAQ;IACR,0EAA0E;IAC1E,4EAA4E;IAC5E,yCAAyC;IACzC,EAAE;IACF,4EAA4E;IAC5E,sCAAsC;IACtC,MAAMC,cAAcH,6CAAMA;IAC1B,MAAM,CAACI,cAAcC,gBAAgB,GAAGP,+CAAQA,CAAC;IACjD,IAAIQ,UAAU;IACd,IAAI,CAACF,cAAc;QACf,IAAI,CAACH,SAAS;YACV,yDAAyD;YACzD,mFAAmF;YACnF,iFAAiF;YACjF,iFAAiF;YACjF,+DAA+D;YAC/DA,UAAU,IAAIM,QAAQ,CAACC;gBACnB,MAAMC,mBAAmB,CAAC,EAAEC,MAAM,EAAEJ,SAASK,UAAU,EAAE;oBACrD,IAAID,QAAQ;wBACRF,QAAQG;wBACRL,UAAUK;wBACVR,YAAYS,OAAO,IAAIT,YAAYS,OAAO;wBAC1CT,YAAYS,OAAO,GAAGC;oBAC1B;gBACJ;gBACAJ,iBAAiBZ,iEAAeA,GAAGiB,QAAQ;gBAC3C,IAAI,CAACR,SAAS;oBACVH,YAAYS,OAAO,GAAGf,iEAAeA,GAAGkB,SAAS,CAACN;gBACtD;YACJ;QACJ,OAAO;YACH,gFAAgF;YAChF,yEAAyE;YACzE,gDAAgD;YAChD,MAAMO,eAAenB,iEAAeA,GAAGiB,QAAQ;YAC/C,IAAIE,aAAaN,MAAM,EAAE;gBACrBJ,UAAUU,aAAaV,OAAO;YAClC;QACJ;QACA,4EAA4E;QAC5E,iEAAiE;QACjE,IAAIA,SAAS;YACTD,gBAAgBC;QACpB,OAAO;YACH,MAAML;QACV;IACJ;IACA,4EAA4E;IAC5E,uEAAuE;IACvE,0EAA0E;IAC1E,4EAA4E;IAC5E,YAAY;IACZF,gDAASA,CAAC;QACN,IAAI,CAACI,YAAYS,OAAO,EAAE;YACtBT,YAAYS,OAAO,GAAGf,iEAAeA,GAAGkB,SAAS,CAAC,CAAC,EAAEL,MAAM,EAAEJ,SAASK,UAAU,EAAE;gBAC9E,IAAID,QAAQ;oBACRJ,UAAUK;oBACVN,gBAAgBM;gBACpB;YACJ;QACJ;QACA,OAAO;YACHR,YAAYS,OAAO,IAAIT,YAAYS,OAAO;YAC1CT,YAAYS,OAAO,GAAGC;QAC1B;IACJ,GAAG,EAAE;IACL,MAAMI,SAASb,gBAAgBE;IAC/B,IAAI,CAACW,QAAQ;QACT,IAAIhB,SAAS;YACTiB,QAAQC,IAAI,CAAC;YACb,MAAMlB;QACV,OAAO;YACH,MAAMmB,MAAM;QAChB;IACJ;IACA,OAAOH;AACX;AACA;;CAEC,GAAU,SAASI;IAChBpB,UAAUY;AACd","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-react-utils/dist/useSession.js?400d"],"sourcesContent":["/** @module @category API */ import { getSessionStore } from \"@openmrs/esm-api\";\nimport { useState, useEffect, useRef } from \"react\";\nlet promise;\n/**\n * Gets the current user session information. Returns an object with\n * property `authenticated` == `false` if the user is not logged in.\n *\n * Uses Suspense. This hook will always either return a Session object\n * or throw for Suspense. It will never return `null`/`undefined`.\n *\n * @returns Current user session information\n */ export function useSession() {\n    // We have two separate variables for the session.\n    //\n    // `session` is a temporary variable, which starts as `null` every time this\n    // hook is executed. It is important that we can set and return this\n    // variable synchronously, because every time we `throw` for Suspense, this\n    // hook will unmount and a new instance will be created, destroying whatever\n    // state existed. Thus, if this hook were to try to always set and return\n    // `stateSession`, it would cause an infinite loop:\n    //   1. instance A mounts\n    //   2. instance A receives value, calls `setStateSession`\n    //   3. instance A throws\n    //   4. instance A unmounts\n    //   5. instance B mounts\n    //   ...\n    // What would happen if we moved `session` to the module scope, so that it\n    // could be re-used across instances of this hook? Then we would have no way\n    // to tell whether the session was fresh.\n    //\n    // `stateSession` is React state, which is needed to update components using\n    // this hook when the session changes.\n    const unsubscribe = useRef();\n    const [stateSession, setStateSession] = useState(null);\n    let session = null;\n    if (!stateSession) {\n        if (!promise) {\n            // If we haven't created a promise to throw yet, do that.\n            // current-user.ts handles the initial session fetch as soon as `getSessionStore()`\n            // is called. We just need to call it and set up a listener for when session data\n            // is loaded. As soon as we have the initial session data, we remove this initial\n            // store subscription so we can set up the \"ongoing\" one later.\n            promise = new Promise((resolve)=>{\n                const handleNewSession = ({ loaded, session: newSession })=>{\n                    if (loaded) {\n                        resolve(newSession);\n                        session = newSession;\n                        unsubscribe.current && unsubscribe.current();\n                        unsubscribe.current = undefined;\n                    }\n                };\n                handleNewSession(getSessionStore().getState());\n                if (!session) {\n                    unsubscribe.current = getSessionStore().subscribe(handleNewSession);\n                }\n            });\n        } else {\n            // However, if we have created a promise to throw, but there's no `stateSession`\n            // yet, then it's probably just this hook's first render. Check to see if\n            // there's already a session that we can return.\n            const currentState = getSessionStore().getState();\n            if (currentState.loaded) {\n                session = currentState.session;\n            }\n        }\n        // If the session got set synchronously in the above block, then we can just\n        // return it rather than throwing. Otherwise, throw for Suspense.\n        if (session) {\n            setStateSession(session);\n        } else {\n            throw promise;\n        }\n    }\n    // Once this hook is established (no longer throwing and getting re-created)\n    // we need to set up a subscription that will update its value the good\n    // old-fashioned React way. We are re-using the `unsubscribe` ref from the\n    // initial subscription, which should have been vacated by the first time we\n    // get here.\n    useEffect(()=>{\n        if (!unsubscribe.current) {\n            unsubscribe.current = getSessionStore().subscribe(({ loaded, session: newSession })=>{\n                if (loaded) {\n                    session = newSession;\n                    setStateSession(newSession);\n                }\n            });\n        }\n        return ()=>{\n            unsubscribe.current && unsubscribe.current();\n            unsubscribe.current = undefined;\n        };\n    }, []);\n    const result = stateSession || session;\n    if (!result) {\n        if (promise) {\n            console.warn('useSession is in an unexpected state. Attempting to recover.');\n            throw promise;\n        } else {\n            throw Error('useSession is in an invalid state.');\n        }\n    }\n    return result;\n}\n/**\n * For testing.\n */ export function __cleanup() {\n    promise = undefined;\n}\n"],"names":["getSessionStore","useState","useEffect","useRef","promise","useSession","unsubscribe","stateSession","setStateSession","session","Promise","resolve","handleNewSession","loaded","newSession","current","undefined","getState","subscribe","currentState","result","console","warn","Error","__cleanup"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/useSession.js\n");
1308
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ __cleanup: () => (/* binding */ __cleanup),\n/* harmony export */ useSession: () => (/* binding */ useSession)\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 react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/** @module @category API */ \n\nlet promise;\n/**\n * Gets the current user session information. Returns an object with\n * property `authenticated` == `false` if the user is not logged in.\n *\n * Uses Suspense. This hook will always either return a Session object\n * or throw for Suspense. It will never return `null`/`undefined`.\n *\n * @returns Current user session information\n */ function useSession() {\n // We have two separate variables for the session.\n //\n // `session` is a temporary variable, which starts as `null` every time this\n // hook is executed. It is important that we can set and return this\n // variable synchronously, because every time we `throw` for Suspense, this\n // hook will unmount and a new instance will be created, destroying whatever\n // state existed. Thus, if this hook were to try to always set and return\n // `stateSession`, it would cause an infinite loop:\n // 1. instance A mounts\n // 2. instance A receives value, calls `setStateSession`\n // 3. instance A throws\n // 4. instance A unmounts\n // 5. instance B mounts\n // ...\n // What would happen if we moved `session` to the module scope, so that it\n // could be re-used across instances of this hook? Then we would have no way\n // to tell whether the session was fresh.\n //\n // `stateSession` is React state, which is needed to update components using\n // this hook when the session changes.\n const unsubscribe = (0,react__WEBPACK_IMPORTED_MODULE_1__.useRef)();\n const [stateSession, setStateSession] = (0,react__WEBPACK_IMPORTED_MODULE_1__.useState)(null);\n let session = null;\n if (!stateSession) {\n if (!promise) {\n // If we haven't created a promise to throw yet, do that.\n // current-user.ts handles the initial session fetch as soon as `getSessionStore()`\n // is called. We just need to call it and set up a listener for when session data\n // is loaded. As soon as we have the initial session data, we remove this initial\n // store subscription so we can set up the \"ongoing\" one later.\n promise = new Promise((resolve)=>{\n const handleNewSession = ({ loaded, session: newSession })=>{\n if (loaded) {\n resolve(newSession);\n session = newSession;\n if (unsubscribe.current) {\n unsubscribe.current();\n unsubscribe.current = undefined;\n }\n }\n };\n handleNewSession((0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.getSessionStore)().getState());\n if (!session) {\n unsubscribe.current = (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.getSessionStore)().subscribe(handleNewSession);\n }\n });\n } else {\n // However, if we have created a promise to throw, but there's no `stateSession`\n // yet, then it's probably just this hook's first render. Check to see if\n // there's already a session that we can return.\n const currentState = (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.getSessionStore)().getState();\n if (currentState.loaded) {\n session = currentState.session;\n }\n }\n // If the session got set synchronously in the above block, then we can just\n // return it rather than throwing. Otherwise, throw for Suspense.\n if (session) {\n setStateSession(session);\n } else {\n throw promise;\n }\n }\n // Once this hook is established (no longer throwing and getting re-created)\n // we need to set up a subscription that will update its value the good\n // old-fashioned React way. We are re-using the `unsubscribe` ref from the\n // initial subscription, which should have been vacated by the first time we\n // get here.\n (0,react__WEBPACK_IMPORTED_MODULE_1__.useEffect)(()=>{\n if (!unsubscribe.current) {\n unsubscribe.current = (0,_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_0__.getSessionStore)().subscribe(({ loaded, session: newSession })=>{\n if (loaded) {\n session = newSession;\n setStateSession(newSession);\n }\n });\n }\n return ()=>{\n if (unsubscribe.current) {\n unsubscribe.current();\n unsubscribe.current = undefined;\n }\n };\n }, []);\n const result = stateSession || session;\n if (!result) {\n if (promise) {\n console.warn('useSession is in an unexpected state. Attempting to recover.');\n throw promise;\n } else {\n throw Error('useSession is in an invalid state.');\n }\n }\n return result;\n}\n/**\n * For testing.\n */ function __cleanup() {\n promise = undefined;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-react-utils/dist/useSession.js","mappings":";;;;;;;AAAA,0BAA0B,GAAsD;AAC5B;AACpD,IAAII;AACJ;;;;;;;;CAQC,GAAU,SAASC;IAChB,kDAAkD;IAClD,EAAE;IACF,4EAA4E;IAC5E,oEAAoE;IACpE,2EAA2E;IAC3E,4EAA4E;IAC5E,yEAAyE;IACzE,mDAAmD;IACnD,yBAAyB;IACzB,0DAA0D;IAC1D,yBAAyB;IACzB,2BAA2B;IAC3B,yBAAyB;IACzB,QAAQ;IACR,0EAA0E;IAC1E,4EAA4E;IAC5E,yCAAyC;IACzC,EAAE;IACF,4EAA4E;IAC5E,sCAAsC;IACtC,MAAMC,cAAcH,6CAAMA;IAC1B,MAAM,CAACI,cAAcC,gBAAgB,GAAGP,+CAAQA,CAAC;IACjD,IAAIQ,UAAU;IACd,IAAI,CAACF,cAAc;QACf,IAAI,CAACH,SAAS;YACV,yDAAyD;YACzD,mFAAmF;YACnF,iFAAiF;YACjF,iFAAiF;YACjF,+DAA+D;YAC/DA,UAAU,IAAIM,QAAQ,CAACC;gBACnB,MAAMC,mBAAmB,CAAC,EAAEC,MAAM,EAAEJ,SAASK,UAAU,EAAE;oBACrD,IAAID,QAAQ;wBACRF,QAAQG;wBACRL,UAAUK;wBACV,IAAIR,YAAYS,OAAO,EAAE;4BACrBT,YAAYS,OAAO;4BACnBT,YAAYS,OAAO,GAAGC;wBAC1B;oBACJ;gBACJ;gBACAJ,iBAAiBZ,iEAAeA,GAAGiB,QAAQ;gBAC3C,IAAI,CAACR,SAAS;oBACVH,YAAYS,OAAO,GAAGf,iEAAeA,GAAGkB,SAAS,CAACN;gBACtD;YACJ;QACJ,OAAO;YACH,gFAAgF;YAChF,yEAAyE;YACzE,gDAAgD;YAChD,MAAMO,eAAenB,iEAAeA,GAAGiB,QAAQ;YAC/C,IAAIE,aAAaN,MAAM,EAAE;gBACrBJ,UAAUU,aAAaV,OAAO;YAClC;QACJ;QACA,4EAA4E;QAC5E,iEAAiE;QACjE,IAAIA,SAAS;YACTD,gBAAgBC;QACpB,OAAO;YACH,MAAML;QACV;IACJ;IACA,4EAA4E;IAC5E,uEAAuE;IACvE,0EAA0E;IAC1E,4EAA4E;IAC5E,YAAY;IACZF,gDAASA,CAAC;QACN,IAAI,CAACI,YAAYS,OAAO,EAAE;YACtBT,YAAYS,OAAO,GAAGf,iEAAeA,GAAGkB,SAAS,CAAC,CAAC,EAAEL,MAAM,EAAEJ,SAASK,UAAU,EAAE;gBAC9E,IAAID,QAAQ;oBACRJ,UAAUK;oBACVN,gBAAgBM;gBACpB;YACJ;QACJ;QACA,OAAO;YACH,IAAIR,YAAYS,OAAO,EAAE;gBACrBT,YAAYS,OAAO;gBACnBT,YAAYS,OAAO,GAAGC;YAC1B;QACJ;IACJ,GAAG,EAAE;IACL,MAAMI,SAASb,gBAAgBE;IAC/B,IAAI,CAACW,QAAQ;QACT,IAAIhB,SAAS;YACTiB,QAAQC,IAAI,CAAC;YACb,MAAMlB;QACV,OAAO;YACH,MAAMmB,MAAM;QAChB;IACJ;IACA,OAAOH;AACX;AACA;;CAEC,GAAU,SAASI;IAChBpB,UAAUY;AACd","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-react-utils/dist/useSession.js?400d"],"sourcesContent":["/** @module @category API */ import { getSessionStore } from \"@openmrs/esm-api\";\nimport { useState, useEffect, useRef } from \"react\";\nlet promise;\n/**\n * Gets the current user session information. Returns an object with\n * property `authenticated` == `false` if the user is not logged in.\n *\n * Uses Suspense. This hook will always either return a Session object\n * or throw for Suspense. It will never return `null`/`undefined`.\n *\n * @returns Current user session information\n */ export function useSession() {\n    // We have two separate variables for the session.\n    //\n    // `session` is a temporary variable, which starts as `null` every time this\n    // hook is executed. It is important that we can set and return this\n    // variable synchronously, because every time we `throw` for Suspense, this\n    // hook will unmount and a new instance will be created, destroying whatever\n    // state existed. Thus, if this hook were to try to always set and return\n    // `stateSession`, it would cause an infinite loop:\n    //   1. instance A mounts\n    //   2. instance A receives value, calls `setStateSession`\n    //   3. instance A throws\n    //   4. instance A unmounts\n    //   5. instance B mounts\n    //   ...\n    // What would happen if we moved `session` to the module scope, so that it\n    // could be re-used across instances of this hook? Then we would have no way\n    // to tell whether the session was fresh.\n    //\n    // `stateSession` is React state, which is needed to update components using\n    // this hook when the session changes.\n    const unsubscribe = useRef();\n    const [stateSession, setStateSession] = useState(null);\n    let session = null;\n    if (!stateSession) {\n        if (!promise) {\n            // If we haven't created a promise to throw yet, do that.\n            // current-user.ts handles the initial session fetch as soon as `getSessionStore()`\n            // is called. We just need to call it and set up a listener for when session data\n            // is loaded. As soon as we have the initial session data, we remove this initial\n            // store subscription so we can set up the \"ongoing\" one later.\n            promise = new Promise((resolve)=>{\n                const handleNewSession = ({ loaded, session: newSession })=>{\n                    if (loaded) {\n                        resolve(newSession);\n                        session = newSession;\n                        if (unsubscribe.current) {\n                            unsubscribe.current();\n                            unsubscribe.current = undefined;\n                        }\n                    }\n                };\n                handleNewSession(getSessionStore().getState());\n                if (!session) {\n                    unsubscribe.current = getSessionStore().subscribe(handleNewSession);\n                }\n            });\n        } else {\n            // However, if we have created a promise to throw, but there's no `stateSession`\n            // yet, then it's probably just this hook's first render. Check to see if\n            // there's already a session that we can return.\n            const currentState = getSessionStore().getState();\n            if (currentState.loaded) {\n                session = currentState.session;\n            }\n        }\n        // If the session got set synchronously in the above block, then we can just\n        // return it rather than throwing. Otherwise, throw for Suspense.\n        if (session) {\n            setStateSession(session);\n        } else {\n            throw promise;\n        }\n    }\n    // Once this hook is established (no longer throwing and getting re-created)\n    // we need to set up a subscription that will update its value the good\n    // old-fashioned React way. We are re-using the `unsubscribe` ref from the\n    // initial subscription, which should have been vacated by the first time we\n    // get here.\n    useEffect(()=>{\n        if (!unsubscribe.current) {\n            unsubscribe.current = getSessionStore().subscribe(({ loaded, session: newSession })=>{\n                if (loaded) {\n                    session = newSession;\n                    setStateSession(newSession);\n                }\n            });\n        }\n        return ()=>{\n            if (unsubscribe.current) {\n                unsubscribe.current();\n                unsubscribe.current = undefined;\n            }\n        };\n    }, []);\n    const result = stateSession || session;\n    if (!result) {\n        if (promise) {\n            console.warn('useSession is in an unexpected state. Attempting to recover.');\n            throw promise;\n        } else {\n            throw Error('useSession is in an invalid state.');\n        }\n    }\n    return result;\n}\n/**\n * For testing.\n */ export function __cleanup() {\n    promise = undefined;\n}\n"],"names":["getSessionStore","useState","useEffect","useRef","promise","useSession","unsubscribe","stateSession","setStateSession","session","Promise","resolve","handleNewSession","loaded","newSession","current","undefined","getState","subscribe","currentState","result","console","warn","Error","__cleanup"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-react-utils/dist/useSession.js\n");
1309
1309
 
1310
1310
  /***/ }),
1311
1311
 
@@ -1665,7 +1665,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
1665
1665
  \**********************************************************************************************/
1666
1666
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
1667
1667
 
1668
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ ActionableNotificationComponent: () => (/* binding */ ActionableNotificationComponent)\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__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @carbon/react */ \"webpack/sharing/consume/default/@carbon/react/@carbon/react\");\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_carbon_react__WEBPACK_IMPORTED_MODULE_1__);\nfunction _array_like_to_array(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];\n return arr2;\n}\nfunction _array_with_holes(arr) {\n if (Array.isArray(arr)) return arr;\n}\nfunction _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}\nfunction _iterable_to_array_limit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n var _s, _e;\n try {\n for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){\n _arr.push(_s.value);\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally{\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally{\n if (_d) throw _e;\n }\n }\n return _arr;\n}\nfunction _non_iterable_rest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nfunction _object_spread(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = arguments[i] != null ? arguments[i] : {};\n var ownKeys = Object.keys(source);\n if (typeof Object.getOwnPropertySymbols === \"function\") {\n ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {\n return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n }));\n }\n ownKeys.forEach(function(key) {\n _define_property(target, key, source[key]);\n });\n }\n return target;\n}\nfunction _object_without_properties(source, excluded) {\n if (source == null) return {};\n var target = _object_without_properties_loose(source, excluded);\n var key, i;\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n for(i = 0; i < sourceSymbolKeys.length; i++){\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n return target;\n}\nfunction _object_without_properties_loose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for(i = 0; i < sourceKeys.length; i++){\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}\nfunction _sliced_to_array(arr, i) {\n return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();\n}\nfunction _unsupported_iterable_to_array(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _array_like_to_array(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(n);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);\n}\n\n\nvar ActionableNotificationComponent = function(param) {\n var notification = param.notification;\n var actionButtonLabel = notification.actionButtonLabel, _notification_onActionButtonClick = notification.onActionButtonClick, onActionButtonClick = _notification_onActionButtonClick === void 0 ? function() {} : _notification_onActionButtonClick, subtitle = notification.subtitle, kind = notification.kind, title = notification.title, critical = notification.critical, progressActionLabel = notification.progressActionLabel, id = notification.id, props = _object_without_properties(notification, [\n \"actionButtonLabel\",\n \"onActionButtonClick\",\n \"subtitle\",\n \"kind\",\n \"title\",\n \"critical\",\n \"progressActionLabel\",\n \"id\"\n ]);\n var _useState = _sliced_to_array((0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(actionButtonLabel), 2), actionText = _useState[0], setActionText = _useState[1];\n var handleActionClick = function() {\n onActionButtonClick();\n progressActionLabel && setActionText(progressActionLabel);\n };\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_1__.ActionableNotification, _object_spread({\n kind: kind || 'info',\n actionButtonLabel: actionText,\n ariaLabel: \"Closes actionable notification\",\n onActionButtonClick: handleActionClick,\n statusIconDescription: \"Actionable notification\",\n subtitle: subtitle,\n title: title,\n lowContrast: critical,\n inline: true\n }, props));\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1zdHlsZWd1aWRlL3NyYy9ub3RpZmljYXRpb25zL2FjdGlvbmFibGUtbm90aWZpY2F0aW9uLmNvbXBvbmVudC50c3giLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUF3QztBQUNlO0FBd0JoRCxJQUFNRyxrQ0FBeUU7UUFBR0MscUJBQUFBO0lBQ3ZGLElBQ0VDLG9CQVNFRCxhQVRGQyx1REFTRUQsYUFSRkUscUJBQUFBLHFFQUFzQixZQUFPLHVDQUM3QkMsV0FPRUgsYUFQRkcsVUFDQUMsT0FNRUosYUFORkksTUFDQUMsUUFLRUwsYUFMRkssT0FDQUMsV0FJRU4sYUFKRk0sVUFDQUMsc0JBR0VQLGFBSEZPLHFCQUNBQyxLQUVFUixhQUZGUSxJQUNHQyxtQ0FDRFQ7UUFURkM7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUM7O0lBSUYsSUFBb0NYLDZCQUFBQSwrQ0FBUUEsQ0FBQ0ksd0JBQXRDUyxhQUE2QmIsY0FBakJjLGdCQUFpQmQ7SUFFcEMsSUFBTWUsb0JBQW9CO1FBQ3hCVjtRQUNBSyx1QkFBdUJJLGNBQWNKO0lBQ3ZDO0lBRUEscUJBQ0UsMkRBQUNULGlFQUFzQkE7UUFDckJNLE1BQU0sUUFBd0M7UUFDOUNILG1CQUFtQlM7UUFDbkJHLFdBQVU7UUFDVlgscUJBQXFCVTtRQUNyQkUsdUJBQXNCO1FBQ3RCWCxVQUFVQTtRQUNWRSxPQUFPQTtRQUNQVSxhQUFhVDtRQUNiVSxRQUFBQTtPQUNJUDtBQUdWLEVBQUUiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tc3R5bGVndWlkZS9zcmMvbm90aWZpY2F0aW9ucy9hY3Rpb25hYmxlLW5vdGlmaWNhdGlvbi5jb21wb25lbnQudHN4PzcwZDYiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgQWN0aW9uYWJsZU5vdGlmaWNhdGlvbiB9IGZyb20gJ0BjYXJib24vcmVhY3QnO1xuLyoqIEBtb2R1bGUgQGNhdGVnb3J5IFVJICovXG5cbmV4cG9ydCBpbnRlcmZhY2UgQWN0aW9uYWJsZU5vdGlmaWNhdGlvblByb3BzIHtcbiAgbm90aWZpY2F0aW9uOiBBY3Rpb25hYmxlTm90aWZpY2F0aW9uTWV0YTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBY3Rpb25hYmxlTm90aWZpY2F0aW9uRGVzY3JpcHRvciB7XG4gIGFjdGlvbkJ1dHRvbkxhYmVsOiBzdHJpbmc7XG4gIG9uQWN0aW9uQnV0dG9uQ2xpY2s6ICgpID0+IHZvaWQ7XG4gIG9uQ2xvc2U/OiAoKSA9PiB2b2lkO1xuICBzdWJ0aXRsZTogc3RyaW5nO1xuICB0aXRsZT86IHN0cmluZztcbiAga2luZD86IEFjdGlvbmFibGVOb3RpZmljYXRpb25UeXBlIHwgc3RyaW5nO1xuICBjcml0aWNhbD86IGJvb2xlYW47XG4gIHByb2dyZXNzQWN0aW9uTGFiZWw/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWN0aW9uYWJsZU5vdGlmaWNhdGlvbk1ldGEgZXh0ZW5kcyBBY3Rpb25hYmxlTm90aWZpY2F0aW9uRGVzY3JpcHRvciB7XG4gIGlkOiBudW1iZXI7XG59XG5cbmV4cG9ydCB0eXBlIEFjdGlvbmFibGVOb3RpZmljYXRpb25UeXBlID0gJ2Vycm9yJyB8ICdpbmZvJyB8ICdpbmZvLXNxdWFyZScgfCAnc3VjY2VzcycgfCAnd2FybmluZycgfCAnd2FybmluZy1hbHQnO1xuXG5leHBvcnQgY29uc3QgQWN0aW9uYWJsZU5vdGlmaWNhdGlvbkNvbXBvbmVudDogUmVhY3QuRkM8QWN0aW9uYWJsZU5vdGlmaWNhdGlvblByb3BzPiA9ICh7IG5vdGlmaWNhdGlvbiB9KSA9PiB7XG4gIGNvbnN0IHtcbiAgICBhY3Rpb25CdXR0b25MYWJlbCxcbiAgICBvbkFjdGlvbkJ1dHRvbkNsaWNrID0gKCkgPT4ge30sXG4gICAgc3VidGl0bGUsXG4gICAga2luZCxcbiAgICB0aXRsZSxcbiAgICBjcml0aWNhbCxcbiAgICBwcm9ncmVzc0FjdGlvbkxhYmVsLFxuICAgIGlkLFxuICAgIC4uLnByb3BzXG4gIH0gPSBub3RpZmljYXRpb247XG5cbiAgY29uc3QgW2FjdGlvblRleHQsIHNldEFjdGlvblRleHRdID0gdXNlU3RhdGUoYWN0aW9uQnV0dG9uTGFiZWwpO1xuXG4gIGNvbnN0IGhhbmRsZUFjdGlvbkNsaWNrID0gKCkgPT4ge1xuICAgIG9uQWN0aW9uQnV0dG9uQ2xpY2soKTtcbiAgICBwcm9ncmVzc0FjdGlvbkxhYmVsICYmIHNldEFjdGlvblRleHQocHJvZ3Jlc3NBY3Rpb25MYWJlbCk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8QWN0aW9uYWJsZU5vdGlmaWNhdGlvblxuICAgICAga2luZD17KGtpbmQgYXMgQWN0aW9uYWJsZU5vdGlmaWNhdGlvblR5cGUpIHx8ICdpbmZvJ31cbiAgICAgIGFjdGlvbkJ1dHRvbkxhYmVsPXthY3Rpb25UZXh0fVxuICAgICAgYXJpYUxhYmVsPVwiQ2xvc2VzIGFjdGlvbmFibGUgbm90aWZpY2F0aW9uXCJcbiAgICAgIG9uQWN0aW9uQnV0dG9uQ2xpY2s9e2hhbmRsZUFjdGlvbkNsaWNrfVxuICAgICAgc3RhdHVzSWNvbkRlc2NyaXB0aW9uPVwiQWN0aW9uYWJsZSBub3RpZmljYXRpb25cIlxuICAgICAgc3VidGl0bGU9e3N1YnRpdGxlfVxuICAgICAgdGl0bGU9e3RpdGxlfVxuICAgICAgbG93Q29udHJhc3Q9e2NyaXRpY2FsfVxuICAgICAgaW5saW5lXG4gICAgICB7Li4ucHJvcHN9XG4gICAgLz5cbiAgKTtcbn07XG4iXSwibmFtZXMiOlsiUmVhY3QiLCJ1c2VTdGF0ZSIsIkFjdGlvbmFibGVOb3RpZmljYXRpb24iLCJBY3Rpb25hYmxlTm90aWZpY2F0aW9uQ29tcG9uZW50Iiwibm90aWZpY2F0aW9uIiwiYWN0aW9uQnV0dG9uTGFiZWwiLCJvbkFjdGlvbkJ1dHRvbkNsaWNrIiwic3VidGl0bGUiLCJraW5kIiwidGl0bGUiLCJjcml0aWNhbCIsInByb2dyZXNzQWN0aW9uTGFiZWwiLCJpZCIsInByb3BzIiwiYWN0aW9uVGV4dCIsInNldEFjdGlvblRleHQiLCJoYW5kbGVBY3Rpb25DbGljayIsImFyaWFMYWJlbCIsInN0YXR1c0ljb25EZXNjcmlwdGlvbiIsImxvd0NvbnRyYXN0IiwiaW5saW5lIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/src/notifications/actionable-notification.component.tsx\n");
1668
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ ActionableNotificationComponent: () => (/* binding */ ActionableNotificationComponent)\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__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @carbon/react */ \"webpack/sharing/consume/default/@carbon/react/@carbon/react\");\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_carbon_react__WEBPACK_IMPORTED_MODULE_1__);\nfunction _array_like_to_array(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];\n return arr2;\n}\nfunction _array_with_holes(arr) {\n if (Array.isArray(arr)) return arr;\n}\nfunction _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}\nfunction _iterable_to_array_limit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n var _s, _e;\n try {\n for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){\n _arr.push(_s.value);\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally{\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally{\n if (_d) throw _e;\n }\n }\n return _arr;\n}\nfunction _non_iterable_rest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nfunction _object_spread(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = arguments[i] != null ? arguments[i] : {};\n var ownKeys = Object.keys(source);\n if (typeof Object.getOwnPropertySymbols === \"function\") {\n ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {\n return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n }));\n }\n ownKeys.forEach(function(key) {\n _define_property(target, key, source[key]);\n });\n }\n return target;\n}\nfunction _object_without_properties(source, excluded) {\n if (source == null) return {};\n var target = _object_without_properties_loose(source, excluded);\n var key, i;\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n for(i = 0; i < sourceSymbolKeys.length; i++){\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n return target;\n}\nfunction _object_without_properties_loose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for(i = 0; i < sourceKeys.length; i++){\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}\nfunction _sliced_to_array(arr, i) {\n return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();\n}\nfunction _unsupported_iterable_to_array(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _array_like_to_array(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(n);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);\n}\n\n\nvar ActionableNotificationComponent = function(param) {\n var notification = param.notification;\n var actionButtonLabel = notification.actionButtonLabel, _notification_onActionButtonClick = notification.onActionButtonClick, onActionButtonClick = _notification_onActionButtonClick === void 0 ? function() {} : _notification_onActionButtonClick, subtitle = notification.subtitle, kind = notification.kind, title = notification.title, critical = notification.critical, progressActionLabel = notification.progressActionLabel, id = notification.id, props = _object_without_properties(notification, [\n \"actionButtonLabel\",\n \"onActionButtonClick\",\n \"subtitle\",\n \"kind\",\n \"title\",\n \"critical\",\n \"progressActionLabel\",\n \"id\"\n ]);\n var _useState = _sliced_to_array((0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(actionButtonLabel), 2), actionText = _useState[0], setActionText = _useState[1];\n var handleActionClick = function() {\n onActionButtonClick();\n if (progressActionLabel) {\n setActionText(progressActionLabel);\n }\n };\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_1__.ActionableNotification, _object_spread({\n kind: kind || 'info',\n actionButtonLabel: actionText,\n ariaLabel: \"Closes actionable notification\",\n onActionButtonClick: handleActionClick,\n statusIconDescription: \"Actionable notification\",\n subtitle: subtitle,\n title: title,\n lowContrast: critical,\n inline: true\n }, props));\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1zdHlsZWd1aWRlL3NyYy9ub3RpZmljYXRpb25zL2FjdGlvbmFibGUtbm90aWZpY2F0aW9uLmNvbXBvbmVudC50c3giLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUF3QztBQUNlO0FBd0JoRCxJQUFNRyxrQ0FBeUU7UUFBR0MscUJBQUFBO0lBQ3ZGLElBQ0VDLG9CQVNFRCxhQVRGQyx1REFTRUQsYUFSRkUscUJBQUFBLHFFQUFzQixZQUFPLHVDQUM3QkMsV0FPRUgsYUFQRkcsVUFDQUMsT0FNRUosYUFORkksTUFDQUMsUUFLRUwsYUFMRkssT0FDQUMsV0FJRU4sYUFKRk0sVUFDQUMsc0JBR0VQLGFBSEZPLHFCQUNBQyxLQUVFUixhQUZGUSxJQUNHQyxtQ0FDRFQ7UUFURkM7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUM7O0lBSUYsSUFBb0NYLDZCQUFBQSwrQ0FBUUEsQ0FBQ0ksd0JBQXRDUyxhQUE2QmIsY0FBakJjLGdCQUFpQmQ7SUFFcEMsSUFBTWUsb0JBQW9CO1FBQ3hCVjtRQUNBLElBQUlLLHFCQUFxQjtZQUN2QkksY0FBY0o7UUFDaEI7SUFDRjtJQUVBLHFCQUNFLDJEQUFDVCxpRUFBc0JBO1FBQ3JCTSxNQUFNLFFBQXdDO1FBQzlDSCxtQkFBbUJTO1FBQ25CRyxXQUFVO1FBQ1ZYLHFCQUFxQlU7UUFDckJFLHVCQUFzQjtRQUN0QlgsVUFBVUE7UUFDVkUsT0FBT0E7UUFDUFUsYUFBYVQ7UUFDYlUsUUFBQUE7T0FDSVA7QUFHVixFQUFFIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQG9wZW5tcnMvZXNtLWFwcC1zaGVsbC8uLi8uLi9mcmFtZXdvcmsvZXNtLXN0eWxlZ3VpZGUvc3JjL25vdGlmaWNhdGlvbnMvYWN0aW9uYWJsZS1ub3RpZmljYXRpb24uY29tcG9uZW50LnRzeD83MGQ2Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IEFjdGlvbmFibGVOb3RpZmljYXRpb24gfSBmcm9tICdAY2FyYm9uL3JlYWN0Jztcbi8qKiBAbW9kdWxlIEBjYXRlZ29yeSBVSSAqL1xuXG5leHBvcnQgaW50ZXJmYWNlIEFjdGlvbmFibGVOb3RpZmljYXRpb25Qcm9wcyB7XG4gIG5vdGlmaWNhdGlvbjogQWN0aW9uYWJsZU5vdGlmaWNhdGlvbk1ldGE7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWN0aW9uYWJsZU5vdGlmaWNhdGlvbkRlc2NyaXB0b3Ige1xuICBhY3Rpb25CdXR0b25MYWJlbDogc3RyaW5nO1xuICBvbkFjdGlvbkJ1dHRvbkNsaWNrKCk6IHZvaWQ7XG4gIG9uQ2xvc2U/KCk6IHZvaWQ7XG4gIHN1YnRpdGxlOiBzdHJpbmc7XG4gIHRpdGxlPzogc3RyaW5nO1xuICBraW5kPzogQWN0aW9uYWJsZU5vdGlmaWNhdGlvblR5cGUgfCBzdHJpbmc7XG4gIGNyaXRpY2FsPzogYm9vbGVhbjtcbiAgcHJvZ3Jlc3NBY3Rpb25MYWJlbD86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBY3Rpb25hYmxlTm90aWZpY2F0aW9uTWV0YSBleHRlbmRzIEFjdGlvbmFibGVOb3RpZmljYXRpb25EZXNjcmlwdG9yIHtcbiAgaWQ6IG51bWJlcjtcbn1cblxuZXhwb3J0IHR5cGUgQWN0aW9uYWJsZU5vdGlmaWNhdGlvblR5cGUgPSAnZXJyb3InIHwgJ2luZm8nIHwgJ2luZm8tc3F1YXJlJyB8ICdzdWNjZXNzJyB8ICd3YXJuaW5nJyB8ICd3YXJuaW5nLWFsdCc7XG5cbmV4cG9ydCBjb25zdCBBY3Rpb25hYmxlTm90aWZpY2F0aW9uQ29tcG9uZW50OiBSZWFjdC5GQzxBY3Rpb25hYmxlTm90aWZpY2F0aW9uUHJvcHM+ID0gKHsgbm90aWZpY2F0aW9uIH0pID0+IHtcbiAgY29uc3Qge1xuICAgIGFjdGlvbkJ1dHRvbkxhYmVsLFxuICAgIG9uQWN0aW9uQnV0dG9uQ2xpY2sgPSAoKSA9PiB7fSxcbiAgICBzdWJ0aXRsZSxcbiAgICBraW5kLFxuICAgIHRpdGxlLFxuICAgIGNyaXRpY2FsLFxuICAgIHByb2dyZXNzQWN0aW9uTGFiZWwsXG4gICAgaWQsXG4gICAgLi4ucHJvcHNcbiAgfSA9IG5vdGlmaWNhdGlvbjtcblxuICBjb25zdCBbYWN0aW9uVGV4dCwgc2V0QWN0aW9uVGV4dF0gPSB1c2VTdGF0ZShhY3Rpb25CdXR0b25MYWJlbCk7XG5cbiAgY29uc3QgaGFuZGxlQWN0aW9uQ2xpY2sgPSAoKSA9PiB7XG4gICAgb25BY3Rpb25CdXR0b25DbGljaygpO1xuICAgIGlmIChwcm9ncmVzc0FjdGlvbkxhYmVsKSB7XG4gICAgICBzZXRBY3Rpb25UZXh0KHByb2dyZXNzQWN0aW9uTGFiZWwpO1xuICAgIH1cbiAgfTtcblxuICByZXR1cm4gKFxuICAgIDxBY3Rpb25hYmxlTm90aWZpY2F0aW9uXG4gICAgICBraW5kPXsoa2luZCBhcyBBY3Rpb25hYmxlTm90aWZpY2F0aW9uVHlwZSkgfHwgJ2luZm8nfVxuICAgICAgYWN0aW9uQnV0dG9uTGFiZWw9e2FjdGlvblRleHR9XG4gICAgICBhcmlhTGFiZWw9XCJDbG9zZXMgYWN0aW9uYWJsZSBub3RpZmljYXRpb25cIlxuICAgICAgb25BY3Rpb25CdXR0b25DbGljaz17aGFuZGxlQWN0aW9uQ2xpY2t9XG4gICAgICBzdGF0dXNJY29uRGVzY3JpcHRpb249XCJBY3Rpb25hYmxlIG5vdGlmaWNhdGlvblwiXG4gICAgICBzdWJ0aXRsZT17c3VidGl0bGV9XG4gICAgICB0aXRsZT17dGl0bGV9XG4gICAgICBsb3dDb250cmFzdD17Y3JpdGljYWx9XG4gICAgICBpbmxpbmVcbiAgICAgIHsuLi5wcm9wc31cbiAgICAvPlxuICApO1xufTtcbiJdLCJuYW1lcyI6WyJSZWFjdCIsInVzZVN0YXRlIiwiQWN0aW9uYWJsZU5vdGlmaWNhdGlvbiIsIkFjdGlvbmFibGVOb3RpZmljYXRpb25Db21wb25lbnQiLCJub3RpZmljYXRpb24iLCJhY3Rpb25CdXR0b25MYWJlbCIsIm9uQWN0aW9uQnV0dG9uQ2xpY2siLCJzdWJ0aXRsZSIsImtpbmQiLCJ0aXRsZSIsImNyaXRpY2FsIiwicHJvZ3Jlc3NBY3Rpb25MYWJlbCIsImlkIiwicHJvcHMiLCJhY3Rpb25UZXh0Iiwic2V0QWN0aW9uVGV4dCIsImhhbmRsZUFjdGlvbkNsaWNrIiwiYXJpYUxhYmVsIiwic3RhdHVzSWNvbkRlc2NyaXB0aW9uIiwibG93Q29udHJhc3QiLCJpbmxpbmUiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/src/notifications/actionable-notification.component.tsx\n");
1669
1669
 
1670
1670
  /***/ }),
1671
1671
 
@@ -1985,7 +1985,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
1985
1985
  \***************************************************************************/
1986
1986
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
1987
1987
 
1988
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Snackbar: () => (/* binding */ Snackbar)\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__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! classnames */ \"../../../node_modules/classnames/index.js\");\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @carbon/react */ \"webpack/sharing/consume/default/@carbon/react/@carbon/react\");\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_carbon_react__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _snackbar_module_scss__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./snackbar.module.scss */ \"../../framework/esm-styleguide/src/snackbars/snackbar.module.scss\");\n/** @module @category UI */ function _array_like_to_array(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];\n return arr2;\n}\nfunction _array_with_holes(arr) {\n if (Array.isArray(arr)) return arr;\n}\nfunction _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}\nfunction _iterable_to_array_limit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n var _s, _e;\n try {\n for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){\n _arr.push(_s.value);\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally{\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally{\n if (_d) throw _e;\n }\n }\n return _arr;\n}\nfunction _non_iterable_rest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nfunction _object_spread(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = arguments[i] != null ? arguments[i] : {};\n var ownKeys = Object.keys(source);\n if (typeof Object.getOwnPropertySymbols === \"function\") {\n ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {\n return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n }));\n }\n ownKeys.forEach(function(key) {\n _define_property(target, key, source[key]);\n });\n }\n return target;\n}\nfunction _object_without_properties(source, excluded) {\n if (source == null) return {};\n var target = _object_without_properties_loose(source, excluded);\n var key, i;\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n for(i = 0; i < sourceSymbolKeys.length; i++){\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n return target;\n}\nfunction _object_without_properties_loose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for(i = 0; i < sourceKeys.length; i++){\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}\nfunction _sliced_to_array(arr, i) {\n return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();\n}\nfunction _unsupported_iterable_to_array(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _array_like_to_array(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(n);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);\n}\n\n\n\n\nvar Snackbar = function(param) {\n var snackbar = param.snackbar, removeSnackBarFromDom = param.closeSnackbar;\n var _snackbar_actionButtonLabel = snackbar.actionButtonLabel, actionButtonLabel = _snackbar_actionButtonLabel === void 0 ? '' : _snackbar_actionButtonLabel, _snackbar_kind = snackbar.kind, kind = _snackbar_kind === void 0 ? 'success' : _snackbar_kind, _snackbar_onActionButtonClick = snackbar.onActionButtonClick, onActionButtonClick = _snackbar_onActionButtonClick === void 0 ? function() {} : _snackbar_onActionButtonClick, _snackbar_isLowContrast = snackbar.isLowContrast, isLowContrast = _snackbar_isLowContrast === void 0 ? kind !== 'error' : _snackbar_isLowContrast, progressActionLabel = snackbar.progressActionLabel, _snackbar_subtitle = snackbar.subtitle, subtitle = _snackbar_subtitle === void 0 ? '' : _snackbar_subtitle, _snackbar_timeoutInMs = snackbar.timeoutInMs, timeoutInMs = _snackbar_timeoutInMs === void 0 ? 5000 : _snackbar_timeoutInMs, _snackbar_autoClose = snackbar.autoClose, autoClose = _snackbar_autoClose === void 0 ? kind !== 'error' : _snackbar_autoClose, title = snackbar.title, id = snackbar.id, props = _object_without_properties(snackbar, [\n \"actionButtonLabel\",\n \"kind\",\n \"onActionButtonClick\",\n \"isLowContrast\",\n \"progressActionLabel\",\n \"subtitle\",\n \"timeoutInMs\",\n \"autoClose\",\n \"title\",\n \"id\"\n ]);\n var _useState = _sliced_to_array((0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(actionButtonLabel), 2), actionText = _useState[0], setActionText = _useState[1];\n var _useState1 = _sliced_to_array((0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(true), 2), applyAnimation = _useState1[0], setApplyAnimation = _useState1[1];\n var _useState2 = _sliced_to_array((0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(false), 2), isClosing = _useState2[0], setIsClosing = _useState2[1];\n var closeSnackbar = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function() {\n // This is to add a slide out animation before closing the snackbar\n // The animation lasts for 250ms, thus the timeout\n setTimeout(removeSnackBarFromDom, 250);\n }, [\n removeSnackBarFromDom\n ]);\n var onCloseSnackbar = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function() {\n setIsClosing(true);\n closeSnackbar();\n }, [\n closeSnackbar\n ]);\n var handleActionClick = function() {\n onActionButtonClick();\n onCloseSnackbar();\n progressActionLabel && setActionText(progressActionLabel);\n };\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function() {\n if (autoClose) {\n var timeoutId = setTimeout(onCloseSnackbar, timeoutInMs);\n return function() {\n return clearTimeout(timeoutId);\n };\n }\n }, [\n timeoutInMs,\n autoClose,\n onCloseSnackbar\n ]);\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function() {\n setApplyAnimation(false);\n window.setTimeout(function() {\n setApplyAnimation(true);\n }, 0);\n }, []);\n var _obj;\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_2__.ActionableNotification, _object_spread({\n actionButtonLabel: actionText,\n \"aria-label\": \"Close snackbar\",\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(_snackbar_module_scss__WEBPACK_IMPORTED_MODULE_3__[\"default\"].slideIn, (_obj = {}, _define_property(_obj, _snackbar_module_scss__WEBPACK_IMPORTED_MODULE_3__[\"default\"].animated, applyAnimation), _define_property(_obj, _snackbar_module_scss__WEBPACK_IMPORTED_MODULE_3__[\"default\"].slideOut, isClosing), _obj)),\n inline: true,\n kind: kind,\n lowContrast: isLowContrast,\n onActionButtonClick: handleActionClick,\n onClose: closeSnackbar,\n statusIconDescription: \"Snackbar notification\",\n subtitle: subtitle,\n title: title\n }, props));\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1zdHlsZWd1aWRlL3NyYy9zbmFja2JhcnMvc25hY2tiYXIuY29tcG9uZW50LnRzeCIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUFBLHlCQUF5Qjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFDdUM7QUFDNUI7QUFDbUI7QUFDWDtBQTBCckMsSUFBTU8sV0FBb0M7UUFBR0MsaUJBQUFBLFVBQVVDLDhCQUFBQTtJQUM1RCxrQ0FZSUQsU0FYRkcsbUJBQUFBLDZEQUFvQixtREFXbEJILFNBVkZJLE1BQUFBLG1DQUFPLDREQVVMSixTQVRGSyxxQkFBQUEsaUVBQXNCLFlBQU8sNkRBUzNCTCxTQVJGTSxlQUFBQSxxREFBZ0JGLFNBQVMsbUNBQ3pCRyxzQkFPRVAsU0FQRk8sMENBT0VQLFNBTkZRLFVBQUFBLDJDQUFXLGlEQU1UUixTQUxGUyxhQUFBQSxpREFBYyxvREFLWlQsU0FKRlUsV0FBQUEsNkNBQVlOLFNBQVMsK0JBQ3JCTyxRQUdFWCxTQUhGVyxPQUNBQyxLQUVFWixTQUZGWSxJQUNHQyxtQ0FDRGI7UUFYRkc7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUM7O0lBSUYsSUFBb0NsQiw2QkFBQUEsK0NBQVFBLENBQUNTLHdCQUF0Q1csYUFBNkJwQixjQUFqQnFCLGdCQUFpQnJCO0lBQ3BDLElBQTRDQSw4QkFBQUEsK0NBQVFBLENBQUMsV0FBOUNzQixpQkFBcUN0QixlQUFyQnVCLG9CQUFxQnZCO0lBQzVDLElBQWtDQSw4QkFBQUEsK0NBQVFBLENBQUMsWUFBcEN3QixZQUEyQnhCLGVBQWhCeUIsZUFBZ0J6QjtJQUVsQyxJQUFNTyxnQkFBZ0JSLGtEQUFXQSxDQUFDO1FBQ2hDLG1FQUFtRTtRQUNuRSxrREFBa0Q7UUFDbEQyQixXQUFXbEIsdUJBQXVCO0lBQ3BDLEdBQUc7UUFBQ0E7S0FBc0I7SUFFMUIsSUFBTW1CLGtCQUFrQjVCLGtEQUFXQSxDQUFDO1FBQ2xDMEIsYUFBYTtRQUNibEI7SUFDRixHQUFHO1FBQUNBO0tBQWM7SUFFbEIsSUFBTXFCLG9CQUFvQjtRQUN4QmpCO1FBQ0FnQjtRQUNBZCx1QkFBdUJRLGNBQWNSO0lBQ3ZDO0lBRUFaLGdEQUFTQSxDQUFDO1FBQ1IsSUFBSWUsV0FBVztZQUNiLElBQU1hLFlBQVlILFdBQVdDLGlCQUFpQlo7WUFDOUMsT0FBTzt1QkFBTWUsYUFBYUQ7O1FBQzVCO0lBQ0YsR0FBRztRQUFDZDtRQUFhQztRQUFXVztLQUFnQjtJQUU1QzFCLGdEQUFTQSxDQUFDO1FBQ1JzQixrQkFBa0I7UUFFbEJRLE9BQU9MLFVBQVUsQ0FBQztZQUNoQkgsa0JBQWtCO1FBQ3BCLEdBQUc7SUFDTCxHQUFHLEVBQUU7UUFNcUM7SUFKMUMscUJBQ0UsMkRBQUNwQixpRUFBc0JBO1FBQ3JCTSxtQkFBbUJXO1FBQ25CWSxjQUFXO1FBQ1hDLFdBQVcvQixpREFBVUEsQ0FBQ0UsNkRBQU1BLENBQUM4QixPQUFPLEdBQUUsV0FDcEMsaUJBRG9DLE1BQ25DOUIsNkRBQU1BLENBQUMrQixRQUFRLEVBQUdiLGlCQUNuQixpQkFGb0MsTUFFbkNsQiw2REFBTUEsQ0FBQ2dDLFFBQVEsRUFBR1osWUFGaUI7UUFJdENhLFFBQUFBO1FBQ0EzQixNQUFNQTtRQUNONEIsYUFBYTFCO1FBQ2JELHFCQUFxQmlCO1FBQ3JCVyxTQUFTaEM7UUFDVGlDLHVCQUFzQjtRQUN0QjFCLFVBQVVBO1FBQ1ZHLE9BQU9BO09BQ0hFO0FBR1YsRUFBRSIsInNvdXJjZXMiOlsid2VicGFjazovL0BvcGVubXJzL2VzbS1hcHAtc2hlbGwvLi4vLi4vZnJhbWV3b3JrL2VzbS1zdHlsZWd1aWRlL3NyYy9zbmFja2JhcnMvc25hY2tiYXIuY29tcG9uZW50LnRzeD85NDJhIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBAbW9kdWxlIEBjYXRlZ29yeSBVSSAqL1xuaW1wb3J0IFJlYWN0LCB7IHVzZUNhbGxiYWNrLCB1c2VTdGF0ZSwgdXNlRWZmZWN0IH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IGNsYXNzbmFtZXMgZnJvbSAnY2xhc3NuYW1lcyc7XG5pbXBvcnQgeyBBY3Rpb25hYmxlTm90aWZpY2F0aW9uIH0gZnJvbSAnQGNhcmJvbi9yZWFjdCc7XG5pbXBvcnQgc3R5bGVzIGZyb20gJy4vc25hY2tiYXIubW9kdWxlLnNjc3MnO1xuXG4vLyBEZXNpZ24gZG9jdW1lbnRhdGlvbiBmb3IgU25hY2tiYXJzIGh0dHBzOi8vemVyb2hlaWdodC5jb20vMjNhMDgwZTM4L3AvNjgzNTgwLW5vdGlmaWNhdGlvbnMvdC80NjhiYWZcbmV4cG9ydCBpbnRlcmZhY2UgU25hY2tiYXJQcm9wcyB7XG4gIHNuYWNrYmFyOiBTbmFja2Jhck1ldGE7XG4gIGNsb3NlU25hY2tiYXIoKTogdm9pZDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTbmFja2JhckRlc2NyaXB0b3Ige1xuICBhY3Rpb25CdXR0b25MYWJlbD86IHN0cmluZztcbiAgaXNMb3dDb250cmFzdD86IGJvb2xlYW47XG4gIGtpbmQ/OiBTbmFja2JhclR5cGUgfCBzdHJpbmc7XG4gIG9uQWN0aW9uQnV0dG9uQ2xpY2s/OiAoKSA9PiB2b2lkO1xuICBwcm9ncmVzc0FjdGlvbkxhYmVsPzogc3RyaW5nO1xuICBzdWJ0aXRsZT86IFJlYWN0LlJlYWN0Tm9kZTtcbiAgdGltZW91dEluTXM/OiBudW1iZXI7XG4gIGF1dG9DbG9zZT86IGJvb2xlYW47XG4gIHRpdGxlOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU25hY2tiYXJNZXRhIGV4dGVuZHMgU25hY2tiYXJEZXNjcmlwdG9yIHtcbiAgaWQ6IG51bWJlcjtcbn1cblxuZXhwb3J0IHR5cGUgU25hY2tiYXJUeXBlID0gJ2Vycm9yJyB8ICdpbmZvJyB8ICdpbmZvLXNxdWFyZScgfCAnc3VjY2VzcycgfCAnd2FybmluZycgfCAnd2FybmluZy1hbHQnO1xuXG5leHBvcnQgY29uc3QgU25hY2tiYXI6IFJlYWN0LkZDPFNuYWNrYmFyUHJvcHM+ID0gKHsgc25hY2tiYXIsIGNsb3NlU25hY2tiYXI6IHJlbW92ZVNuYWNrQmFyRnJvbURvbSB9KSA9PiB7XG4gIGNvbnN0IHtcbiAgICBhY3Rpb25CdXR0b25MYWJlbCA9ICcnLFxuICAgIGtpbmQgPSAnc3VjY2VzcycsXG4gICAgb25BY3Rpb25CdXR0b25DbGljayA9ICgpID0+IHt9LFxuICAgIGlzTG93Q29udHJhc3QgPSBraW5kICE9PSAnZXJyb3InLFxuICAgIHByb2dyZXNzQWN0aW9uTGFiZWwsXG4gICAgc3VidGl0bGUgPSAnJyxcbiAgICB0aW1lb3V0SW5NcyA9IDUwMDAsXG4gICAgYXV0b0Nsb3NlID0ga2luZCAhPT0gJ2Vycm9yJyxcbiAgICB0aXRsZSxcbiAgICBpZCxcbiAgICAuLi5wcm9wc1xuICB9ID0gc25hY2tiYXI7XG5cbiAgY29uc3QgW2FjdGlvblRleHQsIHNldEFjdGlvblRleHRdID0gdXNlU3RhdGUoYWN0aW9uQnV0dG9uTGFiZWwpO1xuICBjb25zdCBbYXBwbHlBbmltYXRpb24sIHNldEFwcGx5QW5pbWF0aW9uXSA9IHVzZVN0YXRlKHRydWUpO1xuICBjb25zdCBbaXNDbG9zaW5nLCBzZXRJc0Nsb3NpbmddID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gIGNvbnN0IGNsb3NlU25hY2tiYXIgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgLy8gVGhpcyBpcyB0byBhZGQgYSBzbGlkZSBvdXQgYW5pbWF0aW9uIGJlZm9yZSBjbG9zaW5nIHRoZSBzbmFja2JhclxuICAgIC8vIFRoZSBhbmltYXRpb24gbGFzdHMgZm9yIDI1MG1zLCB0aHVzIHRoZSB0aW1lb3V0XG4gICAgc2V0VGltZW91dChyZW1vdmVTbmFja0JhckZyb21Eb20sIDI1MCk7XG4gIH0sIFtyZW1vdmVTbmFja0JhckZyb21Eb21dKTtcblxuICBjb25zdCBvbkNsb3NlU25hY2tiYXIgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgc2V0SXNDbG9zaW5nKHRydWUpO1xuICAgIGNsb3NlU25hY2tiYXIoKTtcbiAgfSwgW2Nsb3NlU25hY2tiYXJdKTtcblxuICBjb25zdCBoYW5kbGVBY3Rpb25DbGljayA9ICgpID0+IHtcbiAgICBvbkFjdGlvbkJ1dHRvbkNsaWNrKCk7XG4gICAgb25DbG9zZVNuYWNrYmFyKCk7XG4gICAgcHJvZ3Jlc3NBY3Rpb25MYWJlbCAmJiBzZXRBY3Rpb25UZXh0KHByb2dyZXNzQWN0aW9uTGFiZWwpO1xuICB9O1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKGF1dG9DbG9zZSkge1xuICAgICAgY29uc3QgdGltZW91dElkID0gc2V0VGltZW91dChvbkNsb3NlU25hY2tiYXIsIHRpbWVvdXRJbk1zKTtcbiAgICAgIHJldHVybiAoKSA9PiBjbGVhclRpbWVvdXQodGltZW91dElkKTtcbiAgICB9XG4gIH0sIFt0aW1lb3V0SW5NcywgYXV0b0Nsb3NlLCBvbkNsb3NlU25hY2tiYXJdKTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIHNldEFwcGx5QW5pbWF0aW9uKGZhbHNlKTtcblxuICAgIHdpbmRvdy5zZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIHNldEFwcGx5QW5pbWF0aW9uKHRydWUpO1xuICAgIH0sIDApO1xuICB9LCBbXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8QWN0aW9uYWJsZU5vdGlmaWNhdGlvblxuICAgICAgYWN0aW9uQnV0dG9uTGFiZWw9e2FjdGlvblRleHR9XG4gICAgICBhcmlhLWxhYmVsPVwiQ2xvc2Ugc25hY2tiYXJcIlxuICAgICAgY2xhc3NOYW1lPXtjbGFzc25hbWVzKHN0eWxlcy5zbGlkZUluLCB7XG4gICAgICAgIFtzdHlsZXMuYW5pbWF0ZWRdOiBhcHBseUFuaW1hdGlvbixcbiAgICAgICAgW3N0eWxlcy5zbGlkZU91dF06IGlzQ2xvc2luZyxcbiAgICAgIH0pfVxuICAgICAgaW5saW5lXG4gICAgICBraW5kPXtraW5kIGFzIFNuYWNrYmFyVHlwZX1cbiAgICAgIGxvd0NvbnRyYXN0PXtpc0xvd0NvbnRyYXN0fVxuICAgICAgb25BY3Rpb25CdXR0b25DbGljaz17aGFuZGxlQWN0aW9uQ2xpY2t9XG4gICAgICBvbkNsb3NlPXtjbG9zZVNuYWNrYmFyfVxuICAgICAgc3RhdHVzSWNvbkRlc2NyaXB0aW9uPVwiU25hY2tiYXIgbm90aWZpY2F0aW9uXCJcbiAgICAgIHN1YnRpdGxlPXtzdWJ0aXRsZX1cbiAgICAgIHRpdGxlPXt0aXRsZX1cbiAgICAgIHsuLi5wcm9wc31cbiAgICAvPlxuICApO1xufTtcbiJdLCJuYW1lcyI6WyJSZWFjdCIsInVzZUNhbGxiYWNrIiwidXNlU3RhdGUiLCJ1c2VFZmZlY3QiLCJjbGFzc25hbWVzIiwiQWN0aW9uYWJsZU5vdGlmaWNhdGlvbiIsInN0eWxlcyIsIlNuYWNrYmFyIiwic25hY2tiYXIiLCJjbG9zZVNuYWNrYmFyIiwicmVtb3ZlU25hY2tCYXJGcm9tRG9tIiwiYWN0aW9uQnV0dG9uTGFiZWwiLCJraW5kIiwib25BY3Rpb25CdXR0b25DbGljayIsImlzTG93Q29udHJhc3QiLCJwcm9ncmVzc0FjdGlvbkxhYmVsIiwic3VidGl0bGUiLCJ0aW1lb3V0SW5NcyIsImF1dG9DbG9zZSIsInRpdGxlIiwiaWQiLCJwcm9wcyIsImFjdGlvblRleHQiLCJzZXRBY3Rpb25UZXh0IiwiYXBwbHlBbmltYXRpb24iLCJzZXRBcHBseUFuaW1hdGlvbiIsImlzQ2xvc2luZyIsInNldElzQ2xvc2luZyIsInNldFRpbWVvdXQiLCJvbkNsb3NlU25hY2tiYXIiLCJoYW5kbGVBY3Rpb25DbGljayIsInRpbWVvdXRJZCIsImNsZWFyVGltZW91dCIsIndpbmRvdyIsImFyaWEtbGFiZWwiLCJjbGFzc05hbWUiLCJzbGlkZUluIiwiYW5pbWF0ZWQiLCJzbGlkZU91dCIsImlubGluZSIsImxvd0NvbnRyYXN0Iiwib25DbG9zZSIsInN0YXR1c0ljb25EZXNjcmlwdGlvbiJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/src/snackbars/snackbar.component.tsx\n");
1988
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Snackbar: () => (/* binding */ Snackbar)\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__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! classnames */ \"../../../node_modules/classnames/index.js\");\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @carbon/react */ \"webpack/sharing/consume/default/@carbon/react/@carbon/react\");\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_carbon_react__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _snackbar_module_scss__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./snackbar.module.scss */ \"../../framework/esm-styleguide/src/snackbars/snackbar.module.scss\");\n/** @module @category UI */ function _array_like_to_array(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];\n return arr2;\n}\nfunction _array_with_holes(arr) {\n if (Array.isArray(arr)) return arr;\n}\nfunction _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}\nfunction _iterable_to_array_limit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n var _s, _e;\n try {\n for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){\n _arr.push(_s.value);\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally{\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally{\n if (_d) throw _e;\n }\n }\n return _arr;\n}\nfunction _non_iterable_rest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nfunction _object_spread(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = arguments[i] != null ? arguments[i] : {};\n var ownKeys = Object.keys(source);\n if (typeof Object.getOwnPropertySymbols === \"function\") {\n ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {\n return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n }));\n }\n ownKeys.forEach(function(key) {\n _define_property(target, key, source[key]);\n });\n }\n return target;\n}\nfunction _object_without_properties(source, excluded) {\n if (source == null) return {};\n var target = _object_without_properties_loose(source, excluded);\n var key, i;\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n for(i = 0; i < sourceSymbolKeys.length; i++){\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n return target;\n}\nfunction _object_without_properties_loose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for(i = 0; i < sourceKeys.length; i++){\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}\nfunction _sliced_to_array(arr, i) {\n return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();\n}\nfunction _unsupported_iterable_to_array(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _array_like_to_array(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(n);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);\n}\n\n\n\n\nvar Snackbar = function(param) {\n var snackbar = param.snackbar, removeSnackBarFromDom = param.closeSnackbar;\n var _snackbar_actionButtonLabel = snackbar.actionButtonLabel, actionButtonLabel = _snackbar_actionButtonLabel === void 0 ? '' : _snackbar_actionButtonLabel, _snackbar_kind = snackbar.kind, kind = _snackbar_kind === void 0 ? 'success' : _snackbar_kind, _snackbar_onActionButtonClick = snackbar.onActionButtonClick, onActionButtonClick = _snackbar_onActionButtonClick === void 0 ? function() {} : _snackbar_onActionButtonClick, _snackbar_isLowContrast = snackbar.isLowContrast, isLowContrast = _snackbar_isLowContrast === void 0 ? kind !== 'error' : _snackbar_isLowContrast, progressActionLabel = snackbar.progressActionLabel, _snackbar_subtitle = snackbar.subtitle, subtitle = _snackbar_subtitle === void 0 ? '' : _snackbar_subtitle, _snackbar_timeoutInMs = snackbar.timeoutInMs, timeoutInMs = _snackbar_timeoutInMs === void 0 ? 5000 : _snackbar_timeoutInMs, _snackbar_autoClose = snackbar.autoClose, autoClose = _snackbar_autoClose === void 0 ? kind !== 'error' : _snackbar_autoClose, title = snackbar.title, id = snackbar.id, props = _object_without_properties(snackbar, [\n \"actionButtonLabel\",\n \"kind\",\n \"onActionButtonClick\",\n \"isLowContrast\",\n \"progressActionLabel\",\n \"subtitle\",\n \"timeoutInMs\",\n \"autoClose\",\n \"title\",\n \"id\"\n ]);\n var _useState = _sliced_to_array((0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(actionButtonLabel), 2), actionText = _useState[0], setActionText = _useState[1];\n var _useState1 = _sliced_to_array((0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(true), 2), applyAnimation = _useState1[0], setApplyAnimation = _useState1[1];\n var _useState2 = _sliced_to_array((0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(false), 2), isClosing = _useState2[0], setIsClosing = _useState2[1];\n var closeSnackbar = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function() {\n // This is to add a slide out animation before closing the snackbar\n // The animation lasts for 250ms, thus the timeout\n setTimeout(removeSnackBarFromDom, 250);\n }, [\n removeSnackBarFromDom\n ]);\n var onCloseSnackbar = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function() {\n setIsClosing(true);\n closeSnackbar();\n }, [\n closeSnackbar\n ]);\n var handleActionClick = function() {\n onActionButtonClick();\n onCloseSnackbar();\n if (progressActionLabel) {\n setActionText(progressActionLabel);\n }\n };\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function() {\n if (autoClose) {\n var timeoutId = setTimeout(onCloseSnackbar, timeoutInMs);\n return function() {\n return clearTimeout(timeoutId);\n };\n }\n }, [\n timeoutInMs,\n autoClose,\n onCloseSnackbar\n ]);\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function() {\n setApplyAnimation(false);\n window.setTimeout(function() {\n setApplyAnimation(true);\n }, 0);\n }, []);\n var _obj;\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_2__.ActionableNotification, _object_spread({\n actionButtonLabel: actionText,\n \"aria-label\": \"Close snackbar\",\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(_snackbar_module_scss__WEBPACK_IMPORTED_MODULE_3__[\"default\"].slideIn, (_obj = {}, _define_property(_obj, _snackbar_module_scss__WEBPACK_IMPORTED_MODULE_3__[\"default\"].animated, applyAnimation), _define_property(_obj, _snackbar_module_scss__WEBPACK_IMPORTED_MODULE_3__[\"default\"].slideOut, isClosing), _obj)),\n inline: true,\n kind: kind,\n lowContrast: isLowContrast,\n onActionButtonClick: handleActionClick,\n onClose: closeSnackbar,\n statusIconDescription: \"Snackbar notification\",\n subtitle: subtitle,\n title: title\n }, props));\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS1zdHlsZWd1aWRlL3NyYy9zbmFja2JhcnMvc25hY2tiYXIuY29tcG9uZW50LnRzeCIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztBQUFBLHlCQUF5Qjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFDdUM7QUFDNUI7QUFDbUI7QUFDWDtBQTBCckMsSUFBTU8sV0FBb0M7UUFBR0MsaUJBQUFBLFVBQVVDLDhCQUFBQTtJQUM1RCxrQ0FZSUQsU0FYRkcsbUJBQUFBLDZEQUFvQixtREFXbEJILFNBVkZJLE1BQUFBLG1DQUFPLDREQVVMSixTQVRGSyxxQkFBQUEsaUVBQXNCLFlBQU8sNkRBUzNCTCxTQVJGTSxlQUFBQSxxREFBZ0JGLFNBQVMsbUNBQ3pCRyxzQkFPRVAsU0FQRk8sMENBT0VQLFNBTkZRLFVBQUFBLDJDQUFXLGlEQU1UUixTQUxGUyxhQUFBQSxpREFBYyxvREFLWlQsU0FKRlUsV0FBQUEsNkNBQVlOLFNBQVMsK0JBQ3JCTyxRQUdFWCxTQUhGVyxPQUNBQyxLQUVFWixTQUZGWSxJQUNHQyxtQ0FDRGI7UUFYRkc7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUM7O0lBSUYsSUFBb0NsQiw2QkFBQUEsK0NBQVFBLENBQUNTLHdCQUF0Q1csYUFBNkJwQixjQUFqQnFCLGdCQUFpQnJCO0lBQ3BDLElBQTRDQSw4QkFBQUEsK0NBQVFBLENBQUMsV0FBOUNzQixpQkFBcUN0QixlQUFyQnVCLG9CQUFxQnZCO0lBQzVDLElBQWtDQSw4QkFBQUEsK0NBQVFBLENBQUMsWUFBcEN3QixZQUEyQnhCLGVBQWhCeUIsZUFBZ0J6QjtJQUVsQyxJQUFNTyxnQkFBZ0JSLGtEQUFXQSxDQUFDO1FBQ2hDLG1FQUFtRTtRQUNuRSxrREFBa0Q7UUFDbEQyQixXQUFXbEIsdUJBQXVCO0lBQ3BDLEdBQUc7UUFBQ0E7S0FBc0I7SUFFMUIsSUFBTW1CLGtCQUFrQjVCLGtEQUFXQSxDQUFDO1FBQ2xDMEIsYUFBYTtRQUNibEI7SUFDRixHQUFHO1FBQUNBO0tBQWM7SUFFbEIsSUFBTXFCLG9CQUFvQjtRQUN4QmpCO1FBQ0FnQjtRQUNBLElBQUlkLHFCQUFxQjtZQUN2QlEsY0FBY1I7UUFDaEI7SUFDRjtJQUVBWixnREFBU0EsQ0FBQztRQUNSLElBQUllLFdBQVc7WUFDYixJQUFNYSxZQUFZSCxXQUFXQyxpQkFBaUJaO1lBQzlDLE9BQU87dUJBQU1lLGFBQWFEOztRQUM1QjtJQUNGLEdBQUc7UUFBQ2Q7UUFBYUM7UUFBV1c7S0FBZ0I7SUFFNUMxQixnREFBU0EsQ0FBQztRQUNSc0Isa0JBQWtCO1FBRWxCUSxPQUFPTCxVQUFVLENBQUM7WUFDaEJILGtCQUFrQjtRQUNwQixHQUFHO0lBQ0wsR0FBRyxFQUFFO1FBTXFDO0lBSjFDLHFCQUNFLDJEQUFDcEIsaUVBQXNCQTtRQUNyQk0sbUJBQW1CVztRQUNuQlksY0FBVztRQUNYQyxXQUFXL0IsaURBQVVBLENBQUNFLDZEQUFNQSxDQUFDOEIsT0FBTyxHQUFFLFdBQ3BDLGlCQURvQyxNQUNuQzlCLDZEQUFNQSxDQUFDK0IsUUFBUSxFQUFHYixpQkFDbkIsaUJBRm9DLE1BRW5DbEIsNkRBQU1BLENBQUNnQyxRQUFRLEVBQUdaLFlBRmlCO1FBSXRDYSxRQUFBQTtRQUNBM0IsTUFBTUE7UUFDTjRCLGFBQWExQjtRQUNiRCxxQkFBcUJpQjtRQUNyQlcsU0FBU2hDO1FBQ1RpQyx1QkFBc0I7UUFDdEIxQixVQUFVQTtRQUNWRyxPQUFPQTtPQUNIRTtBQUdWLEVBQUUiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tc3R5bGVndWlkZS9zcmMvc25hY2tiYXJzL3NuYWNrYmFyLmNvbXBvbmVudC50c3g/OTQyYSJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQG1vZHVsZSBAY2F0ZWdvcnkgVUkgKi9cbmltcG9ydCBSZWFjdCwgeyB1c2VDYWxsYmFjaywgdXNlU3RhdGUsIHVzZUVmZmVjdCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBjbGFzc25hbWVzIGZyb20gJ2NsYXNzbmFtZXMnO1xuaW1wb3J0IHsgQWN0aW9uYWJsZU5vdGlmaWNhdGlvbiB9IGZyb20gJ0BjYXJib24vcmVhY3QnO1xuaW1wb3J0IHN0eWxlcyBmcm9tICcuL3NuYWNrYmFyLm1vZHVsZS5zY3NzJztcblxuLy8gRGVzaWduIGRvY3VtZW50YXRpb24gZm9yIFNuYWNrYmFycyBodHRwczovL3plcm9oZWlnaHQuY29tLzIzYTA4MGUzOC9wLzY4MzU4MC1ub3RpZmljYXRpb25zL3QvNDY4YmFmXG5leHBvcnQgaW50ZXJmYWNlIFNuYWNrYmFyUHJvcHMge1xuICBzbmFja2JhcjogU25hY2tiYXJNZXRhO1xuICBjbG9zZVNuYWNrYmFyKCk6IHZvaWQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU25hY2tiYXJEZXNjcmlwdG9yIHtcbiAgYWN0aW9uQnV0dG9uTGFiZWw/OiBzdHJpbmc7XG4gIGlzTG93Q29udHJhc3Q/OiBib29sZWFuO1xuICBraW5kPzogU25hY2tiYXJUeXBlIHwgc3RyaW5nO1xuICBvbkFjdGlvbkJ1dHRvbkNsaWNrPzogKCkgPT4gdm9pZDtcbiAgcHJvZ3Jlc3NBY3Rpb25MYWJlbD86IHN0cmluZztcbiAgc3VidGl0bGU/OiBSZWFjdC5SZWFjdE5vZGU7XG4gIHRpbWVvdXRJbk1zPzogbnVtYmVyO1xuICBhdXRvQ2xvc2U/OiBib29sZWFuO1xuICB0aXRsZTogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNuYWNrYmFyTWV0YSBleHRlbmRzIFNuYWNrYmFyRGVzY3JpcHRvciB7XG4gIGlkOiBudW1iZXI7XG59XG5cbmV4cG9ydCB0eXBlIFNuYWNrYmFyVHlwZSA9ICdlcnJvcicgfCAnaW5mbycgfCAnaW5mby1zcXVhcmUnIHwgJ3N1Y2Nlc3MnIHwgJ3dhcm5pbmcnIHwgJ3dhcm5pbmctYWx0JztcblxuZXhwb3J0IGNvbnN0IFNuYWNrYmFyOiBSZWFjdC5GQzxTbmFja2JhclByb3BzPiA9ICh7IHNuYWNrYmFyLCBjbG9zZVNuYWNrYmFyOiByZW1vdmVTbmFja0JhckZyb21Eb20gfSkgPT4ge1xuICBjb25zdCB7XG4gICAgYWN0aW9uQnV0dG9uTGFiZWwgPSAnJyxcbiAgICBraW5kID0gJ3N1Y2Nlc3MnLFxuICAgIG9uQWN0aW9uQnV0dG9uQ2xpY2sgPSAoKSA9PiB7fSxcbiAgICBpc0xvd0NvbnRyYXN0ID0ga2luZCAhPT0gJ2Vycm9yJyxcbiAgICBwcm9ncmVzc0FjdGlvbkxhYmVsLFxuICAgIHN1YnRpdGxlID0gJycsXG4gICAgdGltZW91dEluTXMgPSA1MDAwLFxuICAgIGF1dG9DbG9zZSA9IGtpbmQgIT09ICdlcnJvcicsXG4gICAgdGl0bGUsXG4gICAgaWQsXG4gICAgLi4ucHJvcHNcbiAgfSA9IHNuYWNrYmFyO1xuXG4gIGNvbnN0IFthY3Rpb25UZXh0LCBzZXRBY3Rpb25UZXh0XSA9IHVzZVN0YXRlKGFjdGlvbkJ1dHRvbkxhYmVsKTtcbiAgY29uc3QgW2FwcGx5QW5pbWF0aW9uLCBzZXRBcHBseUFuaW1hdGlvbl0gPSB1c2VTdGF0ZSh0cnVlKTtcbiAgY29uc3QgW2lzQ2xvc2luZywgc2V0SXNDbG9zaW5nXSA9IHVzZVN0YXRlKGZhbHNlKTtcblxuICBjb25zdCBjbG9zZVNuYWNrYmFyID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgIC8vIFRoaXMgaXMgdG8gYWRkIGEgc2xpZGUgb3V0IGFuaW1hdGlvbiBiZWZvcmUgY2xvc2luZyB0aGUgc25hY2tiYXJcbiAgICAvLyBUaGUgYW5pbWF0aW9uIGxhc3RzIGZvciAyNTBtcywgdGh1cyB0aGUgdGltZW91dFxuICAgIHNldFRpbWVvdXQocmVtb3ZlU25hY2tCYXJGcm9tRG9tLCAyNTApO1xuICB9LCBbcmVtb3ZlU25hY2tCYXJGcm9tRG9tXSk7XG5cbiAgY29uc3Qgb25DbG9zZVNuYWNrYmFyID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgIHNldElzQ2xvc2luZyh0cnVlKTtcbiAgICBjbG9zZVNuYWNrYmFyKCk7XG4gIH0sIFtjbG9zZVNuYWNrYmFyXSk7XG5cbiAgY29uc3QgaGFuZGxlQWN0aW9uQ2xpY2sgPSAoKSA9PiB7XG4gICAgb25BY3Rpb25CdXR0b25DbGljaygpO1xuICAgIG9uQ2xvc2VTbmFja2JhcigpO1xuICAgIGlmIChwcm9ncmVzc0FjdGlvbkxhYmVsKSB7XG4gICAgICBzZXRBY3Rpb25UZXh0KHByb2dyZXNzQWN0aW9uTGFiZWwpO1xuICAgIH1cbiAgfTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChhdXRvQ2xvc2UpIHtcbiAgICAgIGNvbnN0IHRpbWVvdXRJZCA9IHNldFRpbWVvdXQob25DbG9zZVNuYWNrYmFyLCB0aW1lb3V0SW5Ncyk7XG4gICAgICByZXR1cm4gKCkgPT4gY2xlYXJUaW1lb3V0KHRpbWVvdXRJZCk7XG4gICAgfVxuICB9LCBbdGltZW91dEluTXMsIGF1dG9DbG9zZSwgb25DbG9zZVNuYWNrYmFyXSk7XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBzZXRBcHBseUFuaW1hdGlvbihmYWxzZSk7XG5cbiAgICB3aW5kb3cuc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICBzZXRBcHBseUFuaW1hdGlvbih0cnVlKTtcbiAgICB9LCAwKTtcbiAgfSwgW10pO1xuXG4gIHJldHVybiAoXG4gICAgPEFjdGlvbmFibGVOb3RpZmljYXRpb25cbiAgICAgIGFjdGlvbkJ1dHRvbkxhYmVsPXthY3Rpb25UZXh0fVxuICAgICAgYXJpYS1sYWJlbD1cIkNsb3NlIHNuYWNrYmFyXCJcbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NuYW1lcyhzdHlsZXMuc2xpZGVJbiwge1xuICAgICAgICBbc3R5bGVzLmFuaW1hdGVkXTogYXBwbHlBbmltYXRpb24sXG4gICAgICAgIFtzdHlsZXMuc2xpZGVPdXRdOiBpc0Nsb3NpbmcsXG4gICAgICB9KX1cbiAgICAgIGlubGluZVxuICAgICAga2luZD17a2luZCBhcyBTbmFja2JhclR5cGV9XG4gICAgICBsb3dDb250cmFzdD17aXNMb3dDb250cmFzdH1cbiAgICAgIG9uQWN0aW9uQnV0dG9uQ2xpY2s9e2hhbmRsZUFjdGlvbkNsaWNrfVxuICAgICAgb25DbG9zZT17Y2xvc2VTbmFja2Jhcn1cbiAgICAgIHN0YXR1c0ljb25EZXNjcmlwdGlvbj1cIlNuYWNrYmFyIG5vdGlmaWNhdGlvblwiXG4gICAgICBzdWJ0aXRsZT17c3VidGl0bGV9XG4gICAgICB0aXRsZT17dGl0bGV9XG4gICAgICB7Li4ucHJvcHN9XG4gICAgLz5cbiAgKTtcbn07XG4iXSwibmFtZXMiOlsiUmVhY3QiLCJ1c2VDYWxsYmFjayIsInVzZVN0YXRlIiwidXNlRWZmZWN0IiwiY2xhc3NuYW1lcyIsIkFjdGlvbmFibGVOb3RpZmljYXRpb24iLCJzdHlsZXMiLCJTbmFja2JhciIsInNuYWNrYmFyIiwiY2xvc2VTbmFja2JhciIsInJlbW92ZVNuYWNrQmFyRnJvbURvbSIsImFjdGlvbkJ1dHRvbkxhYmVsIiwia2luZCIsIm9uQWN0aW9uQnV0dG9uQ2xpY2siLCJpc0xvd0NvbnRyYXN0IiwicHJvZ3Jlc3NBY3Rpb25MYWJlbCIsInN1YnRpdGxlIiwidGltZW91dEluTXMiLCJhdXRvQ2xvc2UiLCJ0aXRsZSIsImlkIiwicHJvcHMiLCJhY3Rpb25UZXh0Iiwic2V0QWN0aW9uVGV4dCIsImFwcGx5QW5pbWF0aW9uIiwic2V0QXBwbHlBbmltYXRpb24iLCJpc0Nsb3NpbmciLCJzZXRJc0Nsb3NpbmciLCJzZXRUaW1lb3V0Iiwib25DbG9zZVNuYWNrYmFyIiwiaGFuZGxlQWN0aW9uQ2xpY2siLCJ0aW1lb3V0SWQiLCJjbGVhclRpbWVvdXQiLCJ3aW5kb3ciLCJhcmlhLWxhYmVsIiwiY2xhc3NOYW1lIiwic2xpZGVJbiIsImFuaW1hdGVkIiwic2xpZGVPdXQiLCJpbmxpbmUiLCJsb3dDb250cmFzdCIsIm9uQ2xvc2UiLCJzdGF0dXNJY29uRGVzY3JpcHRpb24iXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/src/snackbars/snackbar.component.tsx\n");
1989
1989
 
1990
1990
  /***/ }),
1991
1991
 
@@ -2075,7 +2075,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
2075
2075
  \*************************************************************************************************/
2076
2076
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
2077
2077
 
2078
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ WorkspaceContainer: () => (/* binding */ WorkspaceContainer)\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__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var react_i18next__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react-i18next */ \"webpack/sharing/consume/default/react-i18next/react-i18next\");\n/* harmony import */ var react_i18next__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react_i18next__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! classnames */ \"../../../node_modules/classnames/index.js\");\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @carbon/react */ \"webpack/sharing/consume/default/@carbon/react/@carbon/react\");\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_carbon_react__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var _carbon_react_icons__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! @carbon/react/icons */ \"../../../node_modules/@carbon/icons-react/es/generated/bucket-11.js\");\n/* harmony import */ var _carbon_react_icons__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! @carbon/react/icons */ \"../../../node_modules/@carbon/icons-react/es/generated/bucket-5.js\");\n/* harmony import */ var _openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @openmrs/esm-react-utils */ \"../../framework/esm-react-utils/dist/index.js\");\n/* harmony import */ var _openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @openmrs/esm-translations */ \"../../framework/esm-translations/dist/index.js\");\n/* harmony import */ var _icons__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../../icons */ \"../../framework/esm-styleguide/src/icons/index.ts\");\n/* harmony import */ var _notification_workspace_notification_component__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../notification/workspace-notification.component */ \"../../framework/esm-styleguide/src/workspaces/notification/workspace-notification.component.tsx\");\n/* harmony import */ var _workspaces__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../workspaces */ \"../../framework/esm-styleguide/src/workspaces/workspaces.ts\");\n/* harmony import */ var _workspace_renderer_component__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./workspace-renderer.component */ \"../../framework/esm-styleguide/src/workspaces/container/workspace-renderer.component.tsx\");\n/* harmony import */ var _action_menu_component__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./action-menu.component */ \"../../framework/esm-styleguide/src/workspaces/container/action-menu.component.tsx\");\n/* harmony import */ var _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./workspace.module.scss */ \"../../framework/esm-styleguide/src/workspaces/container/workspace.module.scss\");\nfunction _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}\nfunction _object_spread(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = arguments[i] != null ? arguments[i] : {};\n var ownKeys = Object.keys(source);\n if (typeof Object.getOwnPropertySymbols === \"function\") {\n ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {\n return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n }));\n }\n ownKeys.forEach(function(key) {\n _define_property(target, key, source[key]);\n });\n }\n return target;\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n/**\n * Use this component to render the [workspace window](https://zeroheight.com/23a080e38/p/483a22-workspace)\n * in an app such as the patient chart, or a workspace overlay in an app such as the clinic dashboard.\n * This allows workspaces to be opened on the page where this component is mounted. This component\n * must not be mounted multiple times on the same page. If there are multiple apps on a page, only\n * one of those apps should use this component—it \"hosts\" the workspaces.\n *\n * Workspaces may be opened with the [[launchWorkspace]] function from `@openmrs/esm-framework`\n * (among other options).\n *\n * The `overlay` prop determines whether the workspace is rendered as an overlay or a window.\n * When a workspace window is opened, the other content on the screen will be pushed to the left.\n * When an overlay is opened, it will cover other content on the screen.\n *\n * The context key is a string that appears in the URL, which defines the pages on which workspaces\n * are valid. If the URL changes in a way such that it no longer contains the context key, then\n * all workspaces will be closed. This ensures that, for example, workspaces on the home page do\n * not stay open when the user transitions to the patient dashboard; and also that workspaces do\n * not stay open when the user navigates to a different patient. The context key must be a valid\n * sub-path of the URL, with no initial or trailing slash. So if the URL is\n * `https://example.com/patient/123/foo`, then `patient` and `patient/123` and `123/foo` are valid\n * context keys, but `patient/12` and `pati` are not.\n *\n * An extension slot is provided in the workspace header. Its name is derived from the `featureName` of\n * the top-level component in which it is defined (feature names are generally provided in the lifecycle\n * functions in an app's `index.ts` file). The slot is named `workspace-header-${featureName}-slot`.\n * For the patient chart, this is `workspace-header-patient-chart-slot`.\n *\n * This component also provides the [Siderail and Bottom Nav](https://zeroheight.com/23a080e38/p/948cf1-siderail-and-bottom-nav/b/86907e).\n * To use this, pass the `showSiderailAndBottomNav` prop. The Siderail is rendered on the right side of the screen\n * on desktop, and the Bottom Nav is rendered at the bottom of the screen on tablet or mobile. The sidebar/bottom-nav\n * menu provides an extension slot, to which buttons are attached as extensions. The slot\n * derives its name from the `featureName` of the top-level component in which this `WorkspaceContainer`\n * appears (feature names are generally provided in the lifecycle functions in an app's `index.ts` file).\n * The slot is named `action-menu-${featureName}-items-slot`. For the patient chart, this is\n * `action-menu-patient-chart-items-slot`.\n *\n * This component also provides everything needed for workspace notifications to be rendered.\n *\n * @param props.contextKey The context key (explained above)\n * @param props.additionalWorkspaceProps Additional props to pass to the workspace. Using this is\n * unusual; you will generally want to pass props to the workspace when you open it, using\n * `launchWorkspace`. Use this only for props that will apply to every workspace launched\n * on the page where this component is mounted.\n */ function WorkspaceContainer(param) {\n var contextKey = param.contextKey, overlay = param.overlay, showSiderailAndBottomNav = param.showSiderailAndBottomNav, additionalWorkspaceProps = param.additionalWorkspaceProps, actionMenuProps = param.actionMenuProps;\n var layout = (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.useLayoutType)();\n var _useWorkspaces = (0,_workspaces__WEBPACK_IMPORTED_MODULE_8__.useWorkspaces)(), workspaces = _useWorkspaces.workspaces, workspaceWindowState = _useWorkspaces.workspaceWindowState, workspaceGroup = _useWorkspaces.workspaceGroup;\n var currentGroupName = workspaceGroup === null || workspaceGroup === void 0 ? void 0 : workspaceGroup.name;\n var activeWorkspace = workspaces[0];\n var isHidden = workspaceWindowState === 'hidden' || activeWorkspace == null;\n var isMaximized = workspaceWindowState === 'maximized';\n var _activeWorkspace_width;\n var width = (_activeWorkspace_width = activeWorkspace === null || activeWorkspace === void 0 ? void 0 : activeWorkspace.width) !== null && _activeWorkspace_width !== void 0 ? _activeWorkspace_width : overlay ? 'wider' : 'narrow';\n var showActionMenu = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function() {\n return showSiderailAndBottomNav || currentGroupName && !isHidden;\n }, [\n currentGroupName,\n isHidden,\n showSiderailAndBottomNav\n ]);\n (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.useBodyScrollLock)(!isHidden && !(0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.isDesktop)(layout));\n var _obj, _obj1;\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement((react__WEBPACK_IMPORTED_MODULE_0___default().Fragment), null, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: showSiderailAndBottomNav ? _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceContainerWithActionMenu : _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceContainerWithoutActionMenu\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"aside\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()(overlay ? _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceOverlayOuterContainer : _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceWindowSpacer, (_obj = {}, _define_property(_obj, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].hiddenRelative, isHidden), _define_property(_obj, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].narrowWorkspace, width === 'narrow'), _define_property(_obj, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].widerWorkspace, width === 'wider'), _define_property(_obj, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].extraWideWorkspace, width === 'extra-wide'), _obj))\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()(_workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceFixedContainer, (_obj1 = {}, _define_property(_obj1, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].maximizedWindow, isMaximized), _define_property(_obj1, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].hiddenFixed, isHidden), _obj1))\n }, workspaces.map(function(workspace, i) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n key: \"workspace-container-\".concat(workspace ? workspace.name : \"empty-\".concat(i)),\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()(_workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceInnerContainer, _define_property({}, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].hiddenExtraWorkspace, i !== 0))\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(react__WEBPACK_IMPORTED_MODULE_0__.Suspense, {\n fallback: null\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(react_i18next__WEBPACK_IMPORTED_MODULE_1__.I18nextProvider, {\n i18n: window.i18next,\n defaultNS: workspace.moduleName\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Workspace, {\n workspaceInstance: workspace,\n additionalWorkspaceProps: additionalWorkspaceProps\n }))));\n }))), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_notification_workspace_notification_component__WEBPACK_IMPORTED_MODULE_7__.WorkspaceNotification, {\n contextKey: contextKey\n })), showActionMenu && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_action_menu_component__WEBPACK_IMPORTED_MODULE_10__[\"default\"], {\n name: currentGroupName,\n isWithinWorkspace: !showSiderailAndBottomNav,\n actionMenuProps: actionMenuProps\n }));\n}\nfunction Workspace(param) {\n var workspaceInstance = param.workspaceInstance, additionalWorkspaceProps = param.additionalWorkspaceProps;\n var t = (0,react_i18next__WEBPACK_IMPORTED_MODULE_1__.useTranslation)().t;\n var layout = (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.useLayoutType)();\n var _useWorkspaces = (0,_workspaces__WEBPACK_IMPORTED_MODULE_8__.useWorkspaces)(), workspaceWindowState = _useWorkspaces.workspaceWindowState, workspaceGroup = _useWorkspaces.workspaceGroup;\n var currentGroupName = workspaceGroup === null || workspaceGroup === void 0 ? void 0 : workspaceGroup.name;\n var isMaximized = workspaceWindowState === 'maximized';\n // Translate the workspace title\n // The workspace title is a translation key whose translation resides in the workspace module.\n // Since the workspace module is not loaded at the time of workspace registration, we need to translate it here\n // when the workspace is actually rendered and the workspace module along with its translations are loaded.\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function() {\n var translatedTitle = t(workspaceInstance.title);\n if (translatedTitle !== workspaceInstance.title) {\n workspaceInstance.setTitle(translatedTitle);\n }\n }, [\n workspaceInstance.title,\n t,\n workspaceInstance.setTitle\n ]);\n // We use the feature name of the app containing the workspace in order to set the extension\n // slot name. We can't use contextKey for this because we don't want the slot name to be\n // different for different patients, but we do want it to be different for different apps.\n var featureName = (0,react__WEBPACK_IMPORTED_MODULE_0__.useContext)(_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.ComponentContext).featureName;\n var toggleWindowState = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function() {\n isMaximized ? (0,_workspaces__WEBPACK_IMPORTED_MODULE_8__.updateWorkspaceWindowState)('normal') : (0,_workspaces__WEBPACK_IMPORTED_MODULE_8__.updateWorkspaceWindowState)('maximized');\n }, [\n isMaximized\n ]);\n var _useMemo = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function() {\n return workspaceInstance !== null && workspaceInstance !== void 0 ? workspaceInstance : {};\n }, [\n workspaceInstance\n ]), _useMemo_canHide = _useMemo.canHide, canHide = _useMemo_canHide === void 0 ? false : _useMemo_canHide, _useMemo_canMaximize = _useMemo.canMaximize, canMaximize = _useMemo_canMaximize === void 0 ? false : _useMemo_canMaximize, _useMemo_currentWorkspaceGroup = _useMemo.currentWorkspaceGroup, currentWorkspaceGroup = _useMemo_currentWorkspaceGroup === void 0 ? '' : _useMemo_currentWorkspaceGroup, closeWorkspace = _useMemo.closeWorkspace;\n var workspaceProps = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function() {\n return _object_spread({}, additionalWorkspaceProps, workspaceInstance === null || workspaceInstance === void 0 ? void 0 : workspaceInstance.additionalProps);\n }, [\n additionalWorkspaceProps,\n workspaceInstance\n ]);\n var _workspaceInstance_titleNode;\n return workspaceInstance && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement((react__WEBPACK_IMPORTED_MODULE_0___default().Fragment), null, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.Header, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('workspaceHeader', 'Workspace Header'),\n className: _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].header\n }, !(0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.isDesktop)(layout) && !canHide && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderMenuButton, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('close', 'Close'),\n renderMenuIcon: /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_icons__WEBPACK_IMPORTED_MODULE_6__.ArrowLeftIcon, null),\n onClick: function() {\n return closeWorkspace();\n }\n }), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderName, {\n prefix: \"\"\n }, (_workspaceInstance_titleNode = workspaceInstance.titleNode) !== null && _workspaceInstance_titleNode !== void 0 ? _workspaceInstance_titleNode : t(workspaceInstance.title)), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].overlayHeaderSpacer\n }), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderGlobalBar, {\n className: _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].headerButtons\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.ExtensionSlot, {\n name: \"workspace-header-group-\".concat(workspaceInstance.currentWorkspaceGroup, \"-slot\"),\n state: workspaceProps\n }), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.ExtensionSlot, {\n name: \"workspace-header-type-\".concat(workspaceInstance.type, \"-slot\"),\n state: workspaceProps\n }), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.ExtensionSlot, {\n name: \"workspace-header-\".concat(featureName, \"-slot\"),\n state: workspaceProps\n }), (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.isDesktop)(layout) && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement((react__WEBPACK_IMPORTED_MODULE_0___default().Fragment), null, (canMaximize || isMaximized) && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderGlobalAction, {\n \"aria-label\": isMaximized ? (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('minimize', 'Minimize') : (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('maximize', 'Maximize'),\n onClick: toggleWindowState\n }, isMaximized ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react_icons__WEBPACK_IMPORTED_MODULE_12__.Minimize, null) : /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react_icons__WEBPACK_IMPORTED_MODULE_12__.Maximize, null)), canHide && !currentGroupName ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderGlobalAction, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('hide', 'Hide'),\n onClick: function() {\n return (0,_workspaces__WEBPACK_IMPORTED_MODULE_8__.updateWorkspaceWindowState)('hidden');\n }\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_icons__WEBPACK_IMPORTED_MODULE_6__.ArrowRightIcon, null)) : /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderGlobalAction, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('close', 'Close'),\n onClick: function() {\n return closeWorkspace === null || closeWorkspace === void 0 ? void 0 : closeWorkspace();\n }\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_icons__WEBPACK_IMPORTED_MODULE_6__.CloseIcon, null))), layout === 'tablet' && canHide && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderGlobalAction, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('close', 'Close'),\n onClick: function() {\n return closeWorkspace === null || closeWorkspace === void 0 ? void 0 : closeWorkspace();\n }\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react_icons__WEBPACK_IMPORTED_MODULE_13__.DownToBottom, null)))), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()(_workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceContent, _define_property({}, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].marginWorkspaceContent, Boolean(currentWorkspaceGroup)))\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_workspace_renderer_component__WEBPACK_IMPORTED_MODULE_9__.WorkspaceRenderer, {\n key: workspaceInstance.name,\n workspace: workspaceInstance,\n additionalPropsFromPage: additionalWorkspaceProps\n })));\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-styleguide/src/workspaces/container/workspace-container.component.tsx","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-styleguide/src/workspaces/container/workspace-container.component.tsx?ea3f"],"sourcesContent":["import React, { type ReactNode, Suspense, useCallback, useContext, useEffect, useMemo } from 'react';\nimport { I18nextProvider, useTranslation } from 'react-i18next';\nimport classNames from 'classnames';\nimport { Header, HeaderGlobalAction, HeaderGlobalBar, HeaderMenuButton, HeaderName } from '@carbon/react';\nimport { DownToBottom, Maximize, Minimize } from '@carbon/react/icons';\nimport { ComponentContext, ExtensionSlot, isDesktop, useBodyScrollLock, useLayoutType } from '@openmrs/esm-react-utils';\nimport { getCoreTranslation } from '@openmrs/esm-translations';\nimport { ArrowLeftIcon, ArrowRightIcon, CloseIcon } from '../../icons';\nimport { WorkspaceNotification } from '../notification/workspace-notification.component';\nimport { type OpenWorkspace, updateWorkspaceWindowState, useWorkspaces } from '../workspaces';\nimport { WorkspaceRenderer } from './workspace-renderer.component';\nimport ActionMenu from './action-menu.component';\nimport styles from './workspace.module.scss';\n\nexport interface WorkspaceContainerProps {\n  contextKey: string;\n  overlay?: boolean;\n  showSiderailAndBottomNav?: boolean;\n  additionalWorkspaceProps?: object;\n  actionMenuProps?: Record<string, unknown>;\n}\n\n/**\n * Use this component to render the [workspace window](https://zeroheight.com/23a080e38/p/483a22-workspace)\n * in an app such as the patient chart, or a workspace overlay in an app such as the clinic dashboard.\n * This allows workspaces to be opened on the page where this component is mounted. This component\n * must not be mounted multiple times on the same page. If there are multiple apps on a page, only\n * one of those apps should use this component—it \"hosts\" the workspaces.\n *\n * Workspaces may be opened with the [[launchWorkspace]] function from `@openmrs/esm-framework`\n * (among other options).\n *\n * The `overlay` prop determines whether the workspace is rendered as an overlay or a window.\n * When a workspace window is opened, the other content on the screen will be pushed to the left.\n * When an overlay is opened, it will cover other content on the screen.\n *\n * The context key is a string that appears in the URL, which defines the pages on which workspaces\n * are valid. If the URL changes in a way such that it no longer contains the context key, then\n * all workspaces will be closed. This ensures that, for example, workspaces on the home page do\n * not stay open when the user transitions to the patient dashboard; and also that workspaces do\n * not stay open when the user navigates to a different patient. The context key must be a valid\n * sub-path of the URL, with no initial or trailing slash. So if the URL is\n * `https://example.com/patient/123/foo`, then `patient` and `patient/123` and `123/foo` are valid\n * context keys, but `patient/12` and `pati` are not.\n *\n * An extension slot is provided in the workspace header. Its name is derived from the `featureName` of\n * the top-level component in which it is defined (feature names are generally provided in the lifecycle\n * functions in an app's `index.ts` file). The slot is named `workspace-header-${featureName}-slot`.\n * For the patient chart, this is `workspace-header-patient-chart-slot`.\n *\n * This component also provides the [Siderail and Bottom Nav](https://zeroheight.com/23a080e38/p/948cf1-siderail-and-bottom-nav/b/86907e).\n * To use this, pass the `showSiderailAndBottomNav` prop. The Siderail is rendered on the right side of the screen\n * on desktop, and the Bottom Nav is rendered at the bottom of the screen on tablet or mobile. The sidebar/bottom-nav\n * menu provides an extension slot, to which buttons are attached as extensions. The slot\n * derives its name from the `featureName` of the top-level component in which this `WorkspaceContainer`\n * appears (feature names are generally provided in the lifecycle functions in an app's `index.ts` file).\n * The slot is named `action-menu-${featureName}-items-slot`. For the patient chart, this is\n * `action-menu-patient-chart-items-slot`.\n *\n * This component also provides everything needed for workspace notifications to be rendered.\n *\n * @param props.contextKey The context key (explained above)\n * @param props.additionalWorkspaceProps Additional props to pass to the workspace. Using this is\n *          unusual; you will generally want to pass props to the workspace when you open it, using\n *          `launchWorkspace`. Use this only for props that will apply to every workspace launched\n *          on the page where this component is mounted.\n */\nexport function WorkspaceContainer({\n  contextKey,\n  overlay,\n  showSiderailAndBottomNav,\n  additionalWorkspaceProps,\n  actionMenuProps,\n}: WorkspaceContainerProps) {\n  const layout = useLayoutType();\n  const { workspaces, workspaceWindowState, workspaceGroup } = useWorkspaces();\n  const currentGroupName = workspaceGroup?.name;\n  const activeWorkspace = workspaces[0];\n  const isHidden = workspaceWindowState === 'hidden' || activeWorkspace == null;\n  const isMaximized = workspaceWindowState === 'maximized';\n  const width = activeWorkspace?.width ?? (overlay ? 'wider' : 'narrow');\n  const showActionMenu = useMemo(\n    () => showSiderailAndBottomNav || (currentGroupName && !isHidden),\n    [currentGroupName, isHidden, showSiderailAndBottomNav],\n  );\n\n  useBodyScrollLock(!isHidden && !isDesktop(layout));\n\n  return (\n    <>\n      <div\n        className={\n          showSiderailAndBottomNav\n            ? styles.workspaceContainerWithActionMenu\n            : styles.workspaceContainerWithoutActionMenu\n        }\n      >\n        <aside\n          className={classNames(overlay ? styles.workspaceOverlayOuterContainer : styles.workspaceWindowSpacer, {\n            [styles.hiddenRelative]: isHidden,\n            [styles.narrowWorkspace]: width === 'narrow',\n            [styles.widerWorkspace]: width === 'wider',\n            [styles.extraWideWorkspace]: width === 'extra-wide',\n          })}\n        >\n          <div\n            className={classNames(styles.workspaceFixedContainer, {\n              [styles.maximizedWindow]: isMaximized,\n              [styles.hiddenFixed]: isHidden,\n            })}\n          >\n            {workspaces.map((workspace, i) => (\n              <div\n                key={`workspace-container-${workspace ? workspace.name : `empty-${i}`}`}\n                className={classNames(styles.workspaceInnerContainer, { [styles.hiddenExtraWorkspace]: i !== 0 })}\n              >\n                <Suspense fallback={null}>\n                  <I18nextProvider i18n={window.i18next} defaultNS={workspace.moduleName}>\n                    <Workspace workspaceInstance={workspace} additionalWorkspaceProps={additionalWorkspaceProps} />\n                  </I18nextProvider>\n                </Suspense>\n              </div>\n            ))}\n          </div>\n        </aside>\n        <WorkspaceNotification contextKey={contextKey} />\n      </div>\n      {showActionMenu && (\n        <ActionMenu\n          name={currentGroupName}\n          isWithinWorkspace={!showSiderailAndBottomNav}\n          actionMenuProps={actionMenuProps}\n        />\n      )}\n    </>\n  );\n}\n\ninterface WorkspaceProps {\n  workspaceInstance: OpenWorkspace;\n  additionalWorkspaceProps?: object;\n}\n\nfunction Workspace({ workspaceInstance, additionalWorkspaceProps }: WorkspaceProps) {\n  const { t } = useTranslation();\n  const layout = useLayoutType();\n  const { workspaceWindowState, workspaceGroup } = useWorkspaces();\n  const currentGroupName = workspaceGroup?.name;\n  const isMaximized = workspaceWindowState === 'maximized';\n\n  // Translate the workspace title\n  // The workspace title is a translation key whose translation resides in the workspace module.\n  // Since the workspace module is not loaded at the time of workspace registration, we need to translate it here\n  // when the workspace is actually rendered and the workspace module along with its translations are loaded.\n  useEffect(() => {\n    const translatedTitle = t(workspaceInstance.title);\n    if (translatedTitle !== workspaceInstance.title) {\n      workspaceInstance.setTitle(translatedTitle);\n    }\n  }, [workspaceInstance.title, t, workspaceInstance.setTitle]);\n\n  // We use the feature name of the app containing the workspace in order to set the extension\n  // slot name. We can't use contextKey for this because we don't want the slot name to be\n  // different for different patients, but we do want it to be different for different apps.\n  const { featureName } = useContext(ComponentContext);\n\n  const toggleWindowState = useCallback(() => {\n    isMaximized ? updateWorkspaceWindowState('normal') : updateWorkspaceWindowState('maximized');\n  }, [isMaximized]);\n\n  const {\n    canHide = false,\n    canMaximize = false,\n    currentWorkspaceGroup = '',\n    closeWorkspace,\n  } = useMemo(() => workspaceInstance ?? ({} as OpenWorkspace), [workspaceInstance]);\n\n  const workspaceProps = useMemo(\n    () => ({\n      ...additionalWorkspaceProps,\n      ...workspaceInstance?.additionalProps,\n    }),\n    [additionalWorkspaceProps, workspaceInstance],\n  );\n\n  return (\n    workspaceInstance && (\n      <>\n        <Header aria-label={getCoreTranslation('workspaceHeader', 'Workspace Header')} className={styles.header}>\n          {!isDesktop(layout) && !canHide && (\n            <HeaderMenuButton\n              aria-label={getCoreTranslation('close', 'Close')}\n              renderMenuIcon={<ArrowLeftIcon />}\n              onClick={() => closeWorkspace()}\n            />\n          )}\n          <HeaderName prefix=\"\">{workspaceInstance.titleNode ?? (t(workspaceInstance.title) as ReactNode)}</HeaderName>\n          <div className={styles.overlayHeaderSpacer} />\n          <HeaderGlobalBar className={styles.headerButtons}>\n            <ExtensionSlot\n              name={`workspace-header-group-${workspaceInstance.currentWorkspaceGroup}-slot`}\n              state={workspaceProps}\n            />\n            <ExtensionSlot name={`workspace-header-type-${workspaceInstance.type}-slot`} state={workspaceProps} />\n            <ExtensionSlot name={`workspace-header-${featureName}-slot`} state={workspaceProps} />\n            {isDesktop(layout) && (\n              <>\n                {(canMaximize || isMaximized) && (\n                  <HeaderGlobalAction\n                    aria-label={\n                      isMaximized\n                        ? getCoreTranslation('minimize', 'Minimize')\n                        : getCoreTranslation('maximize', 'Maximize')\n                    }\n                    onClick={toggleWindowState}\n                  >\n                    {isMaximized ? <Minimize /> : <Maximize />}\n                  </HeaderGlobalAction>\n                )}\n                {canHide && !currentGroupName ? (\n                  <HeaderGlobalAction\n                    aria-label={getCoreTranslation('hide', 'Hide')}\n                    onClick={() => updateWorkspaceWindowState('hidden')}\n                  >\n                    <ArrowRightIcon />\n                  </HeaderGlobalAction>\n                ) : (\n                  <HeaderGlobalAction\n                    aria-label={getCoreTranslation('close', 'Close')}\n                    onClick={() => closeWorkspace?.()}\n                  >\n                    <CloseIcon />\n                  </HeaderGlobalAction>\n                )}\n              </>\n            )}\n            {layout === 'tablet' && canHide && (\n              <HeaderGlobalAction aria-label={getCoreTranslation('close', 'Close')} onClick={() => closeWorkspace?.()}>\n                <DownToBottom />\n              </HeaderGlobalAction>\n            )}\n          </HeaderGlobalBar>\n        </Header>\n        <div\n          className={classNames(styles.workspaceContent, {\n            [styles.marginWorkspaceContent]: Boolean(currentWorkspaceGroup),\n          })}\n        >\n          <WorkspaceRenderer\n            key={workspaceInstance.name}\n            workspace={workspaceInstance}\n            additionalPropsFromPage={additionalWorkspaceProps}\n          />\n        </div>\n      </>\n    )\n  );\n}\n"],"names":["React","Suspense","useCallback","useContext","useEffect","useMemo","I18nextProvider","useTranslation","classNames","Header","HeaderGlobalAction","HeaderGlobalBar","HeaderMenuButton","HeaderName","DownToBottom","Maximize","Minimize","ComponentContext","ExtensionSlot","isDesktop","useBodyScrollLock","useLayoutType","getCoreTranslation","ArrowLeftIcon","ArrowRightIcon","CloseIcon","WorkspaceNotification","updateWorkspaceWindowState","useWorkspaces","WorkspaceRenderer","ActionMenu","styles","WorkspaceContainer","contextKey","overlay","showSiderailAndBottomNav","additionalWorkspaceProps","actionMenuProps","layout","workspaces","workspaceWindowState","workspaceGroup","currentGroupName","name","activeWorkspace","isHidden","isMaximized","width","showActionMenu","div","className","workspaceContainerWithActionMenu","workspaceContainerWithoutActionMenu","aside","workspaceOverlayOuterContainer","workspaceWindowSpacer","hiddenRelative","narrowWorkspace","widerWorkspace","extraWideWorkspace","workspaceFixedContainer","maximizedWindow","hiddenFixed","map","workspace","i","key","workspaceInnerContainer","hiddenExtraWorkspace","fallback","i18n","window","i18next","defaultNS","moduleName","Workspace","workspaceInstance","isWithinWorkspace","t","translatedTitle","title","setTitle","featureName","toggleWindowState","canHide","canMaximize","currentWorkspaceGroup","closeWorkspace","workspaceProps","additionalProps","aria-label","header","renderMenuIcon","onClick","prefix","titleNode","overlayHeaderSpacer","headerButtons","state","type","workspaceContent","marginWorkspaceContent","Boolean","additionalPropsFromPage"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/src/workspaces/container/workspace-container.component.tsx\n");
2078
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ WorkspaceContainer: () => (/* binding */ WorkspaceContainer)\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__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var react_i18next__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react-i18next */ \"webpack/sharing/consume/default/react-i18next/react-i18next\");\n/* harmony import */ var react_i18next__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react_i18next__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! classnames */ \"../../../node_modules/classnames/index.js\");\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @carbon/react */ \"webpack/sharing/consume/default/@carbon/react/@carbon/react\");\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_carbon_react__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var _carbon_react_icons__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! @carbon/react/icons */ \"../../../node_modules/@carbon/icons-react/es/generated/bucket-11.js\");\n/* harmony import */ var _carbon_react_icons__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! @carbon/react/icons */ \"../../../node_modules/@carbon/icons-react/es/generated/bucket-5.js\");\n/* harmony import */ var _openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @openmrs/esm-react-utils */ \"../../framework/esm-react-utils/dist/index.js\");\n/* harmony import */ var _openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @openmrs/esm-translations */ \"../../framework/esm-translations/dist/index.js\");\n/* harmony import */ var _icons__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../../icons */ \"../../framework/esm-styleguide/src/icons/index.ts\");\n/* harmony import */ var _notification_workspace_notification_component__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../notification/workspace-notification.component */ \"../../framework/esm-styleguide/src/workspaces/notification/workspace-notification.component.tsx\");\n/* harmony import */ var _workspaces__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../workspaces */ \"../../framework/esm-styleguide/src/workspaces/workspaces.ts\");\n/* harmony import */ var _workspace_renderer_component__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./workspace-renderer.component */ \"../../framework/esm-styleguide/src/workspaces/container/workspace-renderer.component.tsx\");\n/* harmony import */ var _action_menu_component__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./action-menu.component */ \"../../framework/esm-styleguide/src/workspaces/container/action-menu.component.tsx\");\n/* harmony import */ var _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./workspace.module.scss */ \"../../framework/esm-styleguide/src/workspaces/container/workspace.module.scss\");\nfunction _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}\nfunction _object_spread(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = arguments[i] != null ? arguments[i] : {};\n var ownKeys = Object.keys(source);\n if (typeof Object.getOwnPropertySymbols === \"function\") {\n ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {\n return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n }));\n }\n ownKeys.forEach(function(key) {\n _define_property(target, key, source[key]);\n });\n }\n return target;\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n/**\n * Use this component to render the [workspace window](https://zeroheight.com/23a080e38/p/483a22-workspace)\n * in an app such as the patient chart, or a workspace overlay in an app such as the clinic dashboard.\n * This allows workspaces to be opened on the page where this component is mounted. This component\n * must not be mounted multiple times on the same page. If there are multiple apps on a page, only\n * one of those apps should use this component—it \"hosts\" the workspaces.\n *\n * Workspaces may be opened with the [[launchWorkspace]] function from `@openmrs/esm-framework`\n * (among other options).\n *\n * The `overlay` prop determines whether the workspace is rendered as an overlay or a window.\n * When a workspace window is opened, the other content on the screen will be pushed to the left.\n * When an overlay is opened, it will cover other content on the screen.\n *\n * The context key is a string that appears in the URL, which defines the pages on which workspaces\n * are valid. If the URL changes in a way such that it no longer contains the context key, then\n * all workspaces will be closed. This ensures that, for example, workspaces on the home page do\n * not stay open when the user transitions to the patient dashboard; and also that workspaces do\n * not stay open when the user navigates to a different patient. The context key must be a valid\n * sub-path of the URL, with no initial or trailing slash. So if the URL is\n * `https://example.com/patient/123/foo`, then `patient` and `patient/123` and `123/foo` are valid\n * context keys, but `patient/12` and `pati` are not.\n *\n * An extension slot is provided in the workspace header. Its name is derived from the `featureName` of\n * the top-level component in which it is defined (feature names are generally provided in the lifecycle\n * functions in an app's `index.ts` file). The slot is named `workspace-header-${featureName}-slot`.\n * For the patient chart, this is `workspace-header-patient-chart-slot`.\n *\n * This component also provides the [Siderail and Bottom Nav](https://zeroheight.com/23a080e38/p/948cf1-siderail-and-bottom-nav/b/86907e).\n * To use this, pass the `showSiderailAndBottomNav` prop. The Siderail is rendered on the right side of the screen\n * on desktop, and the Bottom Nav is rendered at the bottom of the screen on tablet or mobile. The sidebar/bottom-nav\n * menu provides an extension slot, to which buttons are attached as extensions. The slot\n * derives its name from the `featureName` of the top-level component in which this `WorkspaceContainer`\n * appears (feature names are generally provided in the lifecycle functions in an app's `index.ts` file).\n * The slot is named `action-menu-${featureName}-items-slot`. For the patient chart, this is\n * `action-menu-patient-chart-items-slot`.\n *\n * This component also provides everything needed for workspace notifications to be rendered.\n *\n * @param props.contextKey The context key (explained above)\n * @param props.additionalWorkspaceProps Additional props to pass to the workspace. Using this is\n * unusual; you will generally want to pass props to the workspace when you open it, using\n * `launchWorkspace`. Use this only for props that will apply to every workspace launched\n * on the page where this component is mounted.\n */ function WorkspaceContainer(param) {\n var contextKey = param.contextKey, overlay = param.overlay, showSiderailAndBottomNav = param.showSiderailAndBottomNav, additionalWorkspaceProps = param.additionalWorkspaceProps, actionMenuProps = param.actionMenuProps;\n var layout = (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.useLayoutType)();\n var _useWorkspaces = (0,_workspaces__WEBPACK_IMPORTED_MODULE_8__.useWorkspaces)(), workspaces = _useWorkspaces.workspaces, workspaceWindowState = _useWorkspaces.workspaceWindowState, workspaceGroup = _useWorkspaces.workspaceGroup;\n var currentGroupName = workspaceGroup === null || workspaceGroup === void 0 ? void 0 : workspaceGroup.name;\n var activeWorkspace = workspaces[0];\n var isHidden = workspaceWindowState === 'hidden' || activeWorkspace == null;\n var isMaximized = workspaceWindowState === 'maximized';\n var _activeWorkspace_width;\n var width = (_activeWorkspace_width = activeWorkspace === null || activeWorkspace === void 0 ? void 0 : activeWorkspace.width) !== null && _activeWorkspace_width !== void 0 ? _activeWorkspace_width : overlay ? 'wider' : 'narrow';\n var showActionMenu = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function() {\n return showSiderailAndBottomNav || currentGroupName && !isHidden;\n }, [\n currentGroupName,\n isHidden,\n showSiderailAndBottomNav\n ]);\n (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.useBodyScrollLock)(!isHidden && !(0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.isDesktop)(layout));\n var _obj, _obj1;\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement((react__WEBPACK_IMPORTED_MODULE_0___default().Fragment), null, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: showSiderailAndBottomNav ? _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceContainerWithActionMenu : _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceContainerWithoutActionMenu\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"aside\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()(overlay ? _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceOverlayOuterContainer : _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceWindowSpacer, (_obj = {}, _define_property(_obj, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].hiddenRelative, isHidden), _define_property(_obj, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].narrowWorkspace, width === 'narrow'), _define_property(_obj, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].widerWorkspace, width === 'wider'), _define_property(_obj, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].extraWideWorkspace, width === 'extra-wide'), _obj))\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()(_workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceFixedContainer, (_obj1 = {}, _define_property(_obj1, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].maximizedWindow, isMaximized), _define_property(_obj1, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].hiddenFixed, isHidden), _obj1))\n }, workspaces.map(function(workspace, i) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n key: \"workspace-container-\".concat(workspace ? workspace.name : \"empty-\".concat(i)),\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()(_workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceInnerContainer, _define_property({}, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].hiddenExtraWorkspace, i !== 0))\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(react__WEBPACK_IMPORTED_MODULE_0__.Suspense, {\n fallback: null\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(react_i18next__WEBPACK_IMPORTED_MODULE_1__.I18nextProvider, {\n i18n: window.i18next,\n defaultNS: workspace.moduleName\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Workspace, {\n workspaceInstance: workspace,\n additionalWorkspaceProps: additionalWorkspaceProps\n }))));\n }))), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_notification_workspace_notification_component__WEBPACK_IMPORTED_MODULE_7__.WorkspaceNotification, {\n contextKey: contextKey\n })), showActionMenu && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_action_menu_component__WEBPACK_IMPORTED_MODULE_10__[\"default\"], {\n name: currentGroupName,\n isWithinWorkspace: !showSiderailAndBottomNav,\n actionMenuProps: actionMenuProps\n }));\n}\nfunction Workspace(param) {\n var workspaceInstance = param.workspaceInstance, additionalWorkspaceProps = param.additionalWorkspaceProps;\n var t = (0,react_i18next__WEBPACK_IMPORTED_MODULE_1__.useTranslation)().t;\n var layout = (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.useLayoutType)();\n var _useWorkspaces = (0,_workspaces__WEBPACK_IMPORTED_MODULE_8__.useWorkspaces)(), workspaceWindowState = _useWorkspaces.workspaceWindowState, workspaceGroup = _useWorkspaces.workspaceGroup;\n var currentGroupName = workspaceGroup === null || workspaceGroup === void 0 ? void 0 : workspaceGroup.name;\n var isMaximized = workspaceWindowState === 'maximized';\n // Translate the workspace title\n // The workspace title is a translation key whose translation resides in the workspace module.\n // Since the workspace module is not loaded at the time of workspace registration, we need to translate it here\n // when the workspace is actually rendered and the workspace module along with its translations are loaded.\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function() {\n var translatedTitle = t(workspaceInstance.title);\n if (translatedTitle !== workspaceInstance.title) {\n workspaceInstance.setTitle(translatedTitle);\n }\n }, [\n workspaceInstance.title,\n t,\n workspaceInstance.setTitle\n ]);\n // We use the feature name of the app containing the workspace in order to set the extension\n // slot name. We can't use contextKey for this because we don't want the slot name to be\n // different for different patients, but we do want it to be different for different apps.\n var featureName = (0,react__WEBPACK_IMPORTED_MODULE_0__.useContext)(_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.ComponentContext).featureName;\n var toggleWindowState = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function() {\n (0,_workspaces__WEBPACK_IMPORTED_MODULE_8__.updateWorkspaceWindowState)(isMaximized ? 'normal' : 'maximized');\n }, [\n isMaximized\n ]);\n var _useMemo = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function() {\n return workspaceInstance !== null && workspaceInstance !== void 0 ? workspaceInstance : {};\n }, [\n workspaceInstance\n ]), _useMemo_canHide = _useMemo.canHide, canHide = _useMemo_canHide === void 0 ? false : _useMemo_canHide, _useMemo_canMaximize = _useMemo.canMaximize, canMaximize = _useMemo_canMaximize === void 0 ? false : _useMemo_canMaximize, _useMemo_currentWorkspaceGroup = _useMemo.currentWorkspaceGroup, currentWorkspaceGroup = _useMemo_currentWorkspaceGroup === void 0 ? '' : _useMemo_currentWorkspaceGroup, closeWorkspace = _useMemo.closeWorkspace;\n var workspaceProps = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function() {\n return _object_spread({}, additionalWorkspaceProps, workspaceInstance === null || workspaceInstance === void 0 ? void 0 : workspaceInstance.additionalProps);\n }, [\n additionalWorkspaceProps,\n workspaceInstance\n ]);\n var _workspaceInstance_titleNode;\n return workspaceInstance && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement((react__WEBPACK_IMPORTED_MODULE_0___default().Fragment), null, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.Header, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('workspaceHeader', 'Workspace Header'),\n className: _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].header\n }, !(0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.isDesktop)(layout) && !canHide && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderMenuButton, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('close', 'Close'),\n renderMenuIcon: /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_icons__WEBPACK_IMPORTED_MODULE_6__.ArrowLeftIcon, null),\n onClick: function() {\n return closeWorkspace();\n }\n }), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderName, {\n prefix: \"\"\n }, (_workspaceInstance_titleNode = workspaceInstance.titleNode) !== null && _workspaceInstance_titleNode !== void 0 ? _workspaceInstance_titleNode : t(workspaceInstance.title)), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].overlayHeaderSpacer\n }), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderGlobalBar, {\n className: _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].headerButtons\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.ExtensionSlot, {\n name: \"workspace-header-group-\".concat(workspaceInstance.currentWorkspaceGroup, \"-slot\"),\n state: workspaceProps\n }), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.ExtensionSlot, {\n name: \"workspace-header-type-\".concat(workspaceInstance.type, \"-slot\"),\n state: workspaceProps\n }), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.ExtensionSlot, {\n name: \"workspace-header-\".concat(featureName, \"-slot\"),\n state: workspaceProps\n }), (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.isDesktop)(layout) && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement((react__WEBPACK_IMPORTED_MODULE_0___default().Fragment), null, (canMaximize || isMaximized) && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderGlobalAction, {\n \"aria-label\": isMaximized ? (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('minimize', 'Minimize') : (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('maximize', 'Maximize'),\n onClick: toggleWindowState\n }, isMaximized ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react_icons__WEBPACK_IMPORTED_MODULE_12__.Minimize, null) : /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react_icons__WEBPACK_IMPORTED_MODULE_12__.Maximize, null)), canHide && !currentGroupName ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderGlobalAction, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('hide', 'Hide'),\n onClick: function() {\n return (0,_workspaces__WEBPACK_IMPORTED_MODULE_8__.updateWorkspaceWindowState)('hidden');\n }\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_icons__WEBPACK_IMPORTED_MODULE_6__.ArrowRightIcon, null)) : /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderGlobalAction, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('close', 'Close'),\n onClick: function() {\n return closeWorkspace === null || closeWorkspace === void 0 ? void 0 : closeWorkspace();\n }\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_icons__WEBPACK_IMPORTED_MODULE_6__.CloseIcon, null))), layout === 'tablet' && canHide && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderGlobalAction, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('close', 'Close'),\n onClick: function() {\n return closeWorkspace === null || closeWorkspace === void 0 ? void 0 : closeWorkspace();\n }\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react_icons__WEBPACK_IMPORTED_MODULE_13__.DownToBottom, null)))), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()(_workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceContent, _define_property({}, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].marginWorkspaceContent, Boolean(currentWorkspaceGroup)))\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_workspace_renderer_component__WEBPACK_IMPORTED_MODULE_9__.WorkspaceRenderer, {\n key: workspaceInstance.name,\n workspace: workspaceInstance,\n additionalPropsFromPage: additionalWorkspaceProps\n })));\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-styleguide/src/workspaces/container/workspace-container.component.tsx","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-styleguide/src/workspaces/container/workspace-container.component.tsx?ea3f"],"sourcesContent":["import React, { type ReactNode, Suspense, useCallback, useContext, useEffect, useMemo } from 'react';\nimport { I18nextProvider, useTranslation } from 'react-i18next';\nimport classNames from 'classnames';\nimport { Header, HeaderGlobalAction, HeaderGlobalBar, HeaderMenuButton, HeaderName } from '@carbon/react';\nimport { DownToBottom, Maximize, Minimize } from '@carbon/react/icons';\nimport { ComponentContext, ExtensionSlot, isDesktop, useBodyScrollLock, useLayoutType } from '@openmrs/esm-react-utils';\nimport { getCoreTranslation } from '@openmrs/esm-translations';\nimport { ArrowLeftIcon, ArrowRightIcon, CloseIcon } from '../../icons';\nimport { WorkspaceNotification } from '../notification/workspace-notification.component';\nimport { type OpenWorkspace, updateWorkspaceWindowState, useWorkspaces } from '../workspaces';\nimport { WorkspaceRenderer } from './workspace-renderer.component';\nimport ActionMenu from './action-menu.component';\nimport styles from './workspace.module.scss';\n\nexport interface WorkspaceContainerProps {\n  contextKey: string;\n  overlay?: boolean;\n  showSiderailAndBottomNav?: boolean;\n  additionalWorkspaceProps?: object;\n  actionMenuProps?: Record<string, unknown>;\n}\n\n/**\n * Use this component to render the [workspace window](https://zeroheight.com/23a080e38/p/483a22-workspace)\n * in an app such as the patient chart, or a workspace overlay in an app such as the clinic dashboard.\n * This allows workspaces to be opened on the page where this component is mounted. This component\n * must not be mounted multiple times on the same page. If there are multiple apps on a page, only\n * one of those apps should use this component—it \"hosts\" the workspaces.\n *\n * Workspaces may be opened with the [[launchWorkspace]] function from `@openmrs/esm-framework`\n * (among other options).\n *\n * The `overlay` prop determines whether the workspace is rendered as an overlay or a window.\n * When a workspace window is opened, the other content on the screen will be pushed to the left.\n * When an overlay is opened, it will cover other content on the screen.\n *\n * The context key is a string that appears in the URL, which defines the pages on which workspaces\n * are valid. If the URL changes in a way such that it no longer contains the context key, then\n * all workspaces will be closed. This ensures that, for example, workspaces on the home page do\n * not stay open when the user transitions to the patient dashboard; and also that workspaces do\n * not stay open when the user navigates to a different patient. The context key must be a valid\n * sub-path of the URL, with no initial or trailing slash. So if the URL is\n * `https://example.com/patient/123/foo`, then `patient` and `patient/123` and `123/foo` are valid\n * context keys, but `patient/12` and `pati` are not.\n *\n * An extension slot is provided in the workspace header. Its name is derived from the `featureName` of\n * the top-level component in which it is defined (feature names are generally provided in the lifecycle\n * functions in an app's `index.ts` file). The slot is named `workspace-header-${featureName}-slot`.\n * For the patient chart, this is `workspace-header-patient-chart-slot`.\n *\n * This component also provides the [Siderail and Bottom Nav](https://zeroheight.com/23a080e38/p/948cf1-siderail-and-bottom-nav/b/86907e).\n * To use this, pass the `showSiderailAndBottomNav` prop. The Siderail is rendered on the right side of the screen\n * on desktop, and the Bottom Nav is rendered at the bottom of the screen on tablet or mobile. The sidebar/bottom-nav\n * menu provides an extension slot, to which buttons are attached as extensions. The slot\n * derives its name from the `featureName` of the top-level component in which this `WorkspaceContainer`\n * appears (feature names are generally provided in the lifecycle functions in an app's `index.ts` file).\n * The slot is named `action-menu-${featureName}-items-slot`. For the patient chart, this is\n * `action-menu-patient-chart-items-slot`.\n *\n * This component also provides everything needed for workspace notifications to be rendered.\n *\n * @param props.contextKey The context key (explained above)\n * @param props.additionalWorkspaceProps Additional props to pass to the workspace. Using this is\n *          unusual; you will generally want to pass props to the workspace when you open it, using\n *          `launchWorkspace`. Use this only for props that will apply to every workspace launched\n *          on the page where this component is mounted.\n */\nexport function WorkspaceContainer({\n  contextKey,\n  overlay,\n  showSiderailAndBottomNav,\n  additionalWorkspaceProps,\n  actionMenuProps,\n}: WorkspaceContainerProps) {\n  const layout = useLayoutType();\n  const { workspaces, workspaceWindowState, workspaceGroup } = useWorkspaces();\n  const currentGroupName = workspaceGroup?.name;\n  const activeWorkspace = workspaces[0];\n  const isHidden = workspaceWindowState === 'hidden' || activeWorkspace == null;\n  const isMaximized = workspaceWindowState === 'maximized';\n  const width = activeWorkspace?.width ?? (overlay ? 'wider' : 'narrow');\n  const showActionMenu = useMemo(\n    () => showSiderailAndBottomNav || (currentGroupName && !isHidden),\n    [currentGroupName, isHidden, showSiderailAndBottomNav],\n  );\n\n  useBodyScrollLock(!isHidden && !isDesktop(layout));\n\n  return (\n    <>\n      <div\n        className={\n          showSiderailAndBottomNav\n            ? styles.workspaceContainerWithActionMenu\n            : styles.workspaceContainerWithoutActionMenu\n        }\n      >\n        <aside\n          className={classNames(overlay ? styles.workspaceOverlayOuterContainer : styles.workspaceWindowSpacer, {\n            [styles.hiddenRelative]: isHidden,\n            [styles.narrowWorkspace]: width === 'narrow',\n            [styles.widerWorkspace]: width === 'wider',\n            [styles.extraWideWorkspace]: width === 'extra-wide',\n          })}\n        >\n          <div\n            className={classNames(styles.workspaceFixedContainer, {\n              [styles.maximizedWindow]: isMaximized,\n              [styles.hiddenFixed]: isHidden,\n            })}\n          >\n            {workspaces.map((workspace, i) => (\n              <div\n                key={`workspace-container-${workspace ? workspace.name : `empty-${i}`}`}\n                className={classNames(styles.workspaceInnerContainer, { [styles.hiddenExtraWorkspace]: i !== 0 })}\n              >\n                <Suspense fallback={null}>\n                  <I18nextProvider i18n={window.i18next} defaultNS={workspace.moduleName}>\n                    <Workspace workspaceInstance={workspace} additionalWorkspaceProps={additionalWorkspaceProps} />\n                  </I18nextProvider>\n                </Suspense>\n              </div>\n            ))}\n          </div>\n        </aside>\n        <WorkspaceNotification contextKey={contextKey} />\n      </div>\n      {showActionMenu && (\n        <ActionMenu\n          name={currentGroupName}\n          isWithinWorkspace={!showSiderailAndBottomNav}\n          actionMenuProps={actionMenuProps}\n        />\n      )}\n    </>\n  );\n}\n\ninterface WorkspaceProps {\n  workspaceInstance: OpenWorkspace;\n  additionalWorkspaceProps?: object;\n}\n\nfunction Workspace({ workspaceInstance, additionalWorkspaceProps }: WorkspaceProps) {\n  const { t } = useTranslation();\n  const layout = useLayoutType();\n  const { workspaceWindowState, workspaceGroup } = useWorkspaces();\n  const currentGroupName = workspaceGroup?.name;\n  const isMaximized = workspaceWindowState === 'maximized';\n\n  // Translate the workspace title\n  // The workspace title is a translation key whose translation resides in the workspace module.\n  // Since the workspace module is not loaded at the time of workspace registration, we need to translate it here\n  // when the workspace is actually rendered and the workspace module along with its translations are loaded.\n  useEffect(() => {\n    const translatedTitle = t(workspaceInstance.title);\n    if (translatedTitle !== workspaceInstance.title) {\n      workspaceInstance.setTitle(translatedTitle);\n    }\n  }, [workspaceInstance.title, t, workspaceInstance.setTitle]);\n\n  // We use the feature name of the app containing the workspace in order to set the extension\n  // slot name. We can't use contextKey for this because we don't want the slot name to be\n  // different for different patients, but we do want it to be different for different apps.\n  const { featureName } = useContext(ComponentContext);\n\n  const toggleWindowState = useCallback(() => {\n    updateWorkspaceWindowState(isMaximized ? 'normal' : 'maximized');\n  }, [isMaximized]);\n\n  const {\n    canHide = false,\n    canMaximize = false,\n    currentWorkspaceGroup = '',\n    closeWorkspace,\n  } = useMemo(() => workspaceInstance ?? ({} as OpenWorkspace), [workspaceInstance]);\n\n  const workspaceProps = useMemo(\n    () => ({\n      ...additionalWorkspaceProps,\n      ...workspaceInstance?.additionalProps,\n    }),\n    [additionalWorkspaceProps, workspaceInstance],\n  );\n\n  return (\n    workspaceInstance && (\n      <>\n        <Header aria-label={getCoreTranslation('workspaceHeader', 'Workspace Header')} className={styles.header}>\n          {!isDesktop(layout) && !canHide && (\n            <HeaderMenuButton\n              aria-label={getCoreTranslation('close', 'Close')}\n              renderMenuIcon={<ArrowLeftIcon />}\n              onClick={() => closeWorkspace()}\n            />\n          )}\n          <HeaderName prefix=\"\">{workspaceInstance.titleNode ?? (t(workspaceInstance.title) as ReactNode)}</HeaderName>\n          <div className={styles.overlayHeaderSpacer} />\n          <HeaderGlobalBar className={styles.headerButtons}>\n            <ExtensionSlot\n              name={`workspace-header-group-${workspaceInstance.currentWorkspaceGroup}-slot`}\n              state={workspaceProps}\n            />\n            <ExtensionSlot name={`workspace-header-type-${workspaceInstance.type}-slot`} state={workspaceProps} />\n            <ExtensionSlot name={`workspace-header-${featureName}-slot`} state={workspaceProps} />\n            {isDesktop(layout) && (\n              <>\n                {(canMaximize || isMaximized) && (\n                  <HeaderGlobalAction\n                    aria-label={\n                      isMaximized\n                        ? getCoreTranslation('minimize', 'Minimize')\n                        : getCoreTranslation('maximize', 'Maximize')\n                    }\n                    onClick={toggleWindowState}\n                  >\n                    {isMaximized ? <Minimize /> : <Maximize />}\n                  </HeaderGlobalAction>\n                )}\n                {canHide && !currentGroupName ? (\n                  <HeaderGlobalAction\n                    aria-label={getCoreTranslation('hide', 'Hide')}\n                    onClick={() => updateWorkspaceWindowState('hidden')}\n                  >\n                    <ArrowRightIcon />\n                  </HeaderGlobalAction>\n                ) : (\n                  <HeaderGlobalAction\n                    aria-label={getCoreTranslation('close', 'Close')}\n                    onClick={() => closeWorkspace?.()}\n                  >\n                    <CloseIcon />\n                  </HeaderGlobalAction>\n                )}\n              </>\n            )}\n            {layout === 'tablet' && canHide && (\n              <HeaderGlobalAction aria-label={getCoreTranslation('close', 'Close')} onClick={() => closeWorkspace?.()}>\n                <DownToBottom />\n              </HeaderGlobalAction>\n            )}\n          </HeaderGlobalBar>\n        </Header>\n        <div\n          className={classNames(styles.workspaceContent, {\n            [styles.marginWorkspaceContent]: Boolean(currentWorkspaceGroup),\n          })}\n        >\n          <WorkspaceRenderer\n            key={workspaceInstance.name}\n            workspace={workspaceInstance}\n            additionalPropsFromPage={additionalWorkspaceProps}\n          />\n        </div>\n      </>\n    )\n  );\n}\n"],"names":["React","Suspense","useCallback","useContext","useEffect","useMemo","I18nextProvider","useTranslation","classNames","Header","HeaderGlobalAction","HeaderGlobalBar","HeaderMenuButton","HeaderName","DownToBottom","Maximize","Minimize","ComponentContext","ExtensionSlot","isDesktop","useBodyScrollLock","useLayoutType","getCoreTranslation","ArrowLeftIcon","ArrowRightIcon","CloseIcon","WorkspaceNotification","updateWorkspaceWindowState","useWorkspaces","WorkspaceRenderer","ActionMenu","styles","WorkspaceContainer","contextKey","overlay","showSiderailAndBottomNav","additionalWorkspaceProps","actionMenuProps","layout","workspaces","workspaceWindowState","workspaceGroup","currentGroupName","name","activeWorkspace","isHidden","isMaximized","width","showActionMenu","div","className","workspaceContainerWithActionMenu","workspaceContainerWithoutActionMenu","aside","workspaceOverlayOuterContainer","workspaceWindowSpacer","hiddenRelative","narrowWorkspace","widerWorkspace","extraWideWorkspace","workspaceFixedContainer","maximizedWindow","hiddenFixed","map","workspace","i","key","workspaceInnerContainer","hiddenExtraWorkspace","fallback","i18n","window","i18next","defaultNS","moduleName","Workspace","workspaceInstance","isWithinWorkspace","t","translatedTitle","title","setTitle","featureName","toggleWindowState","canHide","canMaximize","currentWorkspaceGroup","closeWorkspace","workspaceProps","additionalProps","aria-label","header","renderMenuIcon","onClick","prefix","titleNode","overlayHeaderSpacer","headerButtons","state","type","workspaceContent","marginWorkspaceContent","Boolean","additionalPropsFromPage"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/src/workspaces/container/workspace-container.component.tsx\n");
2079
2079
 
2080
2080
  /***/ }),
2081
2081
 
@@ -2145,7 +2145,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
2145
2145
  \*******************************************************************/
2146
2146
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
2147
2147
 
2148
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ canCloseWorkspaceWithoutPrompting: () => (/* binding */ canCloseWorkspaceWithoutPrompting),\n/* harmony export */ cancelPrompt: () => (/* binding */ cancelPrompt),\n/* harmony export */ changeWorkspaceContext: () => (/* binding */ changeWorkspaceContext),\n/* harmony export */ closeAllWorkspaces: () => (/* binding */ closeAllWorkspaces),\n/* harmony export */ closeWorkspace: () => (/* binding */ closeWorkspace),\n/* harmony export */ getPromptBeforeClosingFcn: () => (/* binding */ getPromptBeforeClosingFcn),\n/* harmony export */ getWorkspaceGroupStore: () => (/* binding */ getWorkspaceGroupStore),\n/* harmony export */ getWorkspaceStore: () => (/* binding */ getWorkspaceStore),\n/* harmony export */ launchWorkspace: () => (/* binding */ launchWorkspace),\n/* harmony export */ launchWorkspaceGroup: () => (/* binding */ launchWorkspaceGroup),\n/* harmony export */ navigateAndLaunchWorkspace: () => (/* binding */ navigateAndLaunchWorkspace),\n/* harmony export */ promptBeforeClosing: () => (/* binding */ promptBeforeClosing),\n/* harmony export */ resetWorkspaceStore: () => (/* binding */ resetWorkspaceStore),\n/* harmony export */ showWorkspacePrompts: () => (/* binding */ showWorkspacePrompts),\n/* harmony export */ updateWorkspaceWindowState: () => (/* binding */ updateWorkspaceWindowState),\n/* harmony export */ useWorkspaces: () => (/* binding */ useWorkspaces),\n/* harmony export */ workspaceStore: () => (/* binding */ workspaceStore)\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__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\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 _openmrs_esm_navigation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @openmrs/esm-navigation */ \"../../framework/esm-navigation/dist/index.js\");\n/* harmony import */ var _openmrs_esm_state__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @openmrs/esm-state */ \"../../framework/esm-state/dist/index.js\");\n/* harmony import */ var _openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @openmrs/esm-translations */ \"../../framework/esm-translations/dist/index.js\");\n/* harmony import */ var _openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @openmrs/esm-react-utils */ \"../../framework/esm-react-utils/dist/index.js\");\n/** @module @category Workspace */ function _array_like_to_array(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];\n return arr2;\n}\nfunction _array_without_holes(arr) {\n if (Array.isArray(arr)) return _array_like_to_array(arr);\n}\nfunction _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}\nfunction _iterable_to_array(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}\nfunction _non_iterable_spread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nfunction _object_spread(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = arguments[i] != null ? arguments[i] : {};\n var ownKeys = Object.keys(source);\n if (typeof Object.getOwnPropertySymbols === \"function\") {\n ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {\n return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n }));\n }\n ownKeys.forEach(function(key) {\n _define_property(target, key, source[key]);\n });\n }\n return target;\n}\nfunction ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n if (enumerableOnly) {\n symbols = symbols.filter(function(sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n });\n }\n keys.push.apply(keys, symbols);\n }\n return keys;\n}\nfunction _object_spread_props(target, source) {\n source = source != null ? source : {};\n if (Object.getOwnPropertyDescriptors) {\n Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));\n } else {\n ownKeys(Object(source)).forEach(function(key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n return target;\n}\nfunction _to_consumable_array(arr) {\n return _array_without_holes(arr) || _iterable_to_array(arr) || _unsupported_iterable_to_array(arr) || _non_iterable_spread();\n}\nfunction _unsupported_iterable_to_array(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _array_like_to_array(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(n);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);\n}\n\n\n\n\n\n\n/**\n *\n * @param name Name of the workspace\n * @param ignoreChanges If set to true, the \"unsaved changes\" modal will never be shown, even if the `promptBeforeClosing` function returns true. The user will not be prompted before closing.\n * @returns true if the workspace can be closed.\n */ function canCloseWorkspaceWithoutPrompting(name) {\n var ignoreChanges = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : false;\n if (ignoreChanges) {\n return true;\n }\n var promptBeforeFn = getPromptBeforeClosingFcn(name);\n return !promptBeforeFn || !promptBeforeFn();\n}\n/**\n * Closes a workspace group and performs cleanup operations.\n *\n * @param groupName - The name of the workspace group to close\n * @param onWorkspaceCloseup - Optional callback function to execute after closing the workspace group\n * @returns void, or exits early if the current workspace group name doesn't match the provided group name\n *\n * @remarks\n * This function performs the following operations:\n * - Validates if the provided group name matches the current workspace group\n * - Closes all workspaces associated with the group\n * - Clears the workspace group store state\n * - Executes cleanup function if defined in the workspace group\n * - Updates the main workspace store to remove the workspace group\n * - Calls the optional closeup callback if provided\n */ function closeWorkspaceGroup(groupName, onWorkspaceCloseup) {\n var _store_getState;\n var store = getWorkspaceStore();\n var currentWorkspaceGroup = (_store_getState = store.getState()) === null || _store_getState === void 0 ? void 0 : _store_getState.workspaceGroup;\n var currentGroupName = currentWorkspaceGroup === null || currentWorkspaceGroup === void 0 ? void 0 : currentWorkspaceGroup.name;\n if (!currentGroupName || groupName !== currentGroupName) {\n return;\n }\n var filter = currentGroupName ? function(workspace) {\n return workspace.currentWorkspaceGroup === currentGroupName;\n } : function() {\n return true;\n };\n closeAllWorkspaces(function() {\n // Clearing the workspace group and respective store if the new workspace is not part of the current group, which is handled in the `launchWorkspace` function.\n var workspaceGroupStore = getWorkspaceGroupStore(groupName);\n if (workspaceGroupStore) {\n workspaceGroupStore.setState({}, true);\n var unsubscribe = workspaceGroupStore.subscribe(function() {});\n unsubscribe();\n }\n if (typeof (currentWorkspaceGroup === null || currentWorkspaceGroup === void 0 ? void 0 : currentWorkspaceGroup.cleanup) === 'function') {\n currentWorkspaceGroup.cleanup();\n }\n store.setState(function(prev) {\n return _object_spread_props(_object_spread({}, prev), {\n workspaceGroup: undefined\n });\n });\n if (typeof onWorkspaceCloseup === 'function') {\n onWorkspaceCloseup();\n }\n }, filter);\n}\n/**\n * Launches a workspace group with the specified name and configuration.\n * If there are any open workspaces, it will first close them before launching the new workspace group.\n *\n * @param groupName - The name of the workspace group to launch\n * @param args - Configuration object for launching the workspace group\n * @param args.state - The initial state for the workspace group\n * @param args.onWorkspaceGroupLaunch - Optional callback function to be executed after the workspace group is launched\n * @param args.workspaceGroupCleanup - Optional cleanup function to be executed when the workspace group is closed\n *\n * @example\n * launchWorkspaceGroup(\"myGroup\", {\n * state: initialState,\n * onWorkspaceGroupLaunch: () => console.log(\"Workspace group launched\"),\n * workspaceGroupCleanup: () => console.log(\"Cleaning up workspace group\")\n * });\n */ function launchWorkspaceGroup(groupName, args) {\n var workspaceGroupRegistration = (0,_openmrs_esm_extensions__WEBPACK_IMPORTED_MODULE_1__.getWorkspaceGroupRegistration)(groupName);\n var state = args.state, onWorkspaceGroupLaunch = args.onWorkspaceGroupLaunch, workspaceGroupCleanup = args.workspaceGroupCleanup, workspaceToLaunch = args.workspaceToLaunch;\n var store = getWorkspaceStore();\n if (store.getState().openWorkspaces.length) {\n var workspaceGroup = store.getState().workspaceGroup;\n if (workspaceGroup) {\n closeWorkspaceGroup(workspaceGroup === null || workspaceGroup === void 0 ? void 0 : workspaceGroup.name, function() {\n launchWorkspaceGroup(groupName, args);\n });\n } else {\n closeAllWorkspaces(function() {\n launchWorkspaceGroup(groupName, args);\n });\n }\n } else {\n store.setState(function(prev) {\n return _object_spread_props(_object_spread({}, prev), {\n workspaceGroup: {\n name: groupName,\n members: workspaceGroupRegistration.members,\n cleanup: workspaceGroupCleanup\n }\n });\n });\n getWorkspaceGroupStore(groupName, state);\n onWorkspaceGroupLaunch === null || onWorkspaceGroupLaunch === void 0 ? void 0 : onWorkspaceGroupLaunch();\n if (workspaceToLaunch) {\n var _workspaceToLaunch_additionalProps;\n launchWorkspace(workspaceToLaunch.name, (_workspaceToLaunch_additionalProps = workspaceToLaunch.additionalProps) !== null && _workspaceToLaunch_additionalProps !== void 0 ? _workspaceToLaunch_additionalProps : {});\n }\n }\n}\nfunction promptBeforeLaunchingWorkspace(workspace, newWorkspaceDetails) {\n var name = newWorkspaceDetails.name, additionalProps = newWorkspaceDetails.additionalProps;\n var newWorkspaceRegistration = (0,_openmrs_esm_extensions__WEBPACK_IMPORTED_MODULE_1__.getWorkspaceRegistration)(name);\n var proceed = function() {\n closeWorkspace(workspace.name, {\n ignoreChanges: true,\n // Calling the launchWorkspace again, since one of the `if` case\n // might resolve, but we need to check all the cases before launching the form.\n onWorkspaceClose: function() {\n return launchWorkspace(name, additionalProps);\n },\n // If the new workspace is of the same sidebar group, then we don't need to clear the workspace group store.\n closeWorkspaceGroup: false\n });\n };\n if (!canCloseWorkspaceWithoutPrompting(workspace.name)) {\n var _workspace_title;\n showWorkspacePrompts('closing-workspace-launching-new-workspace', proceed, (_workspace_title = workspace.title) !== null && _workspace_title !== void 0 ? _workspace_title : workspace.name);\n } else {\n proceed();\n }\n}\n/**\n * This launches a workspace by its name. The workspace must have been registered.\n * Workspaces should be registered in the `routes.json` file.\n *\n * For the workspace to appear, there must be either a `<WorkspaceOverlay />` or\n * a `<WorkspaceWindow />` component rendered.\n *\n * The behavior of this function is as follows:\n *\n * - If no workspaces are open, or if no other workspaces with the same type are open,\n * it will be opened and focused.\n * - If a workspace with the same name is already open, it will be displayed/focused,\n * if it was not already.\n * - If a workspace is launched and a workspace which cannot be hidden is already open,\n * a confirmation modal will pop up warning about closing the currently open workspace.\n * - If another workspace with the same type is open, the workspace will be brought to\n * the front and then a confirmation modal will pop up warning about closing the opened\n * workspace\n *\n * Note that this function just manipulates the workspace store. The UI logic is handled\n * by the components that display workspaces.\n *\n * Additional props can be passed to the workspace component being launched. Passing a\n * prop named `workspaceTitle` will override the title of the workspace.\n *\n * @param name The name of the workspace to launch\n * @param additionalProps Props to pass to the workspace component being launched. Passing\n * a prop named `workspaceTitle` will override the title of the workspace.\n */ function launchWorkspace(name, additionalProps) {\n var _currentWorkspaceGroup_members, _store_getState_workspaceGroup;\n var store = getWorkspaceStore();\n var workspace = (0,_openmrs_esm_extensions__WEBPACK_IMPORTED_MODULE_1__.getWorkspaceRegistration)(name);\n var currentWorkspaceGroup = store.getState().workspaceGroup;\n if (currentWorkspaceGroup && !((_currentWorkspaceGroup_members = currentWorkspaceGroup.members) === null || _currentWorkspaceGroup_members === void 0 ? void 0 : _currentWorkspaceGroup_members.includes(name))) {\n closeWorkspaceGroup(currentWorkspaceGroup.name, function() {\n launchWorkspace(name, additionalProps);\n });\n return;\n }\n var currentGroupName = (_store_getState_workspaceGroup = store.getState().workspaceGroup) === null || _store_getState_workspaceGroup === void 0 ? void 0 : _store_getState_workspaceGroup.name;\n var newWorkspace = _object_spread_props(_object_spread({}, workspace), {\n title: getWorkspaceTitle(workspace, additionalProps),\n closeWorkspace: function() {\n var options = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {};\n return closeWorkspace(name, options);\n },\n closeWorkspaceWithSavedChanges: function(options) {\n return closeWorkspace(name, _object_spread({\n ignoreChanges: true\n }, options));\n },\n promptBeforeClosing: function(testFcn) {\n return promptBeforeClosing(name, testFcn);\n },\n setTitle: function(title, titleNode) {\n newWorkspace.title = title;\n newWorkspace.titleNode = titleNode;\n store.setState(function(state) {\n var openWorkspaces = state.openWorkspaces.map(function(w) {\n return w.name === name ? newWorkspace : w;\n });\n return _object_spread_props(_object_spread({}, state), {\n openWorkspaces: openWorkspaces\n });\n });\n },\n currentWorkspaceGroup: currentGroupName,\n additionalProps: additionalProps !== null && additionalProps !== void 0 ? additionalProps : {}\n });\n if (currentGroupName) {\n getWorkspaceGroupStore(currentGroupName, additionalProps);\n }\n function updateStoreWithNewWorkspace(workspaceToBeAdded, restOfTheWorkspaces) {\n store.setState(function(state) {\n var openWorkspaces = [\n workspaceToBeAdded\n ].concat(_to_consumable_array(restOfTheWorkspaces !== null && restOfTheWorkspaces !== void 0 ? restOfTheWorkspaces : state.openWorkspaces));\n var workspaceWindowState = getUpdatedWorkspaceWindowState(workspaceToBeAdded);\n return _object_spread_props(_object_spread({}, state), {\n openWorkspaces: openWorkspaces,\n workspaceWindowState: workspaceWindowState\n });\n });\n }\n var openWorkspaces = store.getState().openWorkspaces;\n var workspaceIndexInOpenWorkspaces = openWorkspaces.findIndex(function(w) {\n return w.name === name;\n });\n var isWorkspaceAlreadyOpen = workspaceIndexInOpenWorkspaces >= 0;\n var openedWorkspaceWithSameType = openWorkspaces.find(function(w) {\n return w.type == newWorkspace.type;\n });\n if (openWorkspaces.length === 0) {\n updateStoreWithNewWorkspace(newWorkspace);\n } else if (!openWorkspaces[0].canHide && workspaceIndexInOpenWorkspaces !== 0) {\n promptBeforeLaunchingWorkspace(openWorkspaces[0], {\n name: name,\n additionalProps: additionalProps\n });\n } else if (isWorkspaceAlreadyOpen) {\n var openWorkspace = openWorkspaces[workspaceIndexInOpenWorkspaces];\n // Only update the title if it hasn't been set by `setTitle`\n if (openWorkspace.title === getWorkspaceTitle(openWorkspace, openWorkspace.additionalProps)) {\n openWorkspace.title = getWorkspaceTitle(newWorkspace, newWorkspace.additionalProps);\n }\n openWorkspace.additionalProps = newWorkspace.additionalProps;\n var restOfTheWorkspaces = openWorkspaces.filter(function(w) {\n return w.name != name;\n });\n updateStoreWithNewWorkspace(openWorkspaces[workspaceIndexInOpenWorkspaces], restOfTheWorkspaces);\n } else if (openedWorkspaceWithSameType) {\n var restOfTheWorkspaces1 = store.getState().openWorkspaces.filter(function(w) {\n return w.type != newWorkspace.type;\n });\n updateStoreWithNewWorkspace(openedWorkspaceWithSameType, restOfTheWorkspaces1);\n promptBeforeLaunchingWorkspace(openedWorkspaceWithSameType, {\n name: name,\n additionalProps: additionalProps\n });\n } else {\n updateStoreWithNewWorkspace(newWorkspace);\n }\n}\n/**\n * Use this function to navigate to a new page and launch a workspace on that page.\n *\n * @param options.targetUrl: The URL to navigate to. Will be passed to [[navigate]].\n * @param options.contextKey: The context key used by the target page.\n * @param options.workspaceName: The name of the workspace to launch.\n * @param options.additionalProps: Additional props to pass to the workspace component being launched.\n */ function navigateAndLaunchWorkspace(param) {\n var targetUrl = param.targetUrl, contextKey = param.contextKey, workspaceName = param.workspaceName, additionalProps = param.additionalProps;\n changeWorkspaceContext(contextKey);\n launchWorkspace(workspaceName, additionalProps);\n (0,_openmrs_esm_navigation__WEBPACK_IMPORTED_MODULE_2__.navigate)({\n to: targetUrl\n });\n}\nvar promptBeforeClosingFcns = {};\nfunction promptBeforeClosing(workspaceName, testFcn) {\n promptBeforeClosingFcns[workspaceName] = testFcn;\n}\nfunction getPromptBeforeClosingFcn(workspaceName) {\n return promptBeforeClosingFcns[workspaceName];\n}\nfunction cancelPrompt() {\n var store = getWorkspaceStore();\n var state = store.getState();\n store.setState(_object_spread_props(_object_spread({}, state), {\n prompt: null\n }));\n}\nvar defaultOptions = {\n ignoreChanges: false,\n onWorkspaceClose: function() {},\n closeWorkspaceGroup: true\n};\n/**\n * Function to close an opened workspace\n * @param name Workspace registration name\n * @param options Options to close workspace\n */ function closeWorkspace(name) {\n var options = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};\n options = _object_spread({}, defaultOptions, options);\n var store = getWorkspaceStore();\n var updateStoreWithClosedWorkspace = function() {\n var _store_getState_workspaceGroup, _options_onWorkspaceClose;\n var state = store.getState();\n var workspaceToBeClosed = state.openWorkspaces.find(function(w) {\n return w.name === name;\n });\n var newOpenWorkspaces = state.openWorkspaces.filter(function(w) {\n return w.name != name;\n });\n var workspaceGroupName = (_store_getState_workspaceGroup = store.getState().workspaceGroup) === null || _store_getState_workspaceGroup === void 0 ? void 0 : _store_getState_workspaceGroup.name;\n if (workspaceGroupName && options.closeWorkspaceGroup) {\n closeWorkspaceGroup(workspaceGroupName);\n }\n // ensure closed workspace will not prompt\n promptBeforeClosing(name, function() {\n return false;\n });\n store.setState(function(prev) {\n return _object_spread_props(_object_spread({}, prev), {\n prompt: null,\n openWorkspaces: newOpenWorkspaces,\n workspaceWindowState: getUpdatedWorkspaceWindowState(newOpenWorkspaces === null || newOpenWorkspaces === void 0 ? void 0 : newOpenWorkspaces[0])\n });\n });\n options === null || options === void 0 ? void 0 : (_options_onWorkspaceClose = options.onWorkspaceClose) === null || _options_onWorkspaceClose === void 0 ? void 0 : _options_onWorkspaceClose.call(options);\n };\n if (!canCloseWorkspaceWithoutPrompting(name, options === null || options === void 0 ? void 0 : options.ignoreChanges)) {\n var _getWorkspaceRegistration_title;\n var currentName = (_getWorkspaceRegistration_title = (0,_openmrs_esm_extensions__WEBPACK_IMPORTED_MODULE_1__.getWorkspaceRegistration)(name).title) !== null && _getWorkspaceRegistration_title !== void 0 ? _getWorkspaceRegistration_title : name;\n showWorkspacePrompts('closing-workspace', updateStoreWithClosedWorkspace, currentName);\n return false;\n } else {\n updateStoreWithClosedWorkspace();\n return true;\n }\n}\n/**\n * The set of workspaces is specific to a particular page. This function\n * should be used when transitioning to a new page. If the current\n * workspace data is for a different page, the workspace state is cleared.\n *\n * This is called by the workspace components when they mount.\n * @internal\n *\n * @param contextKey An arbitrary key to identify the current page\n */ function changeWorkspaceContext(contextKey) {\n var store = getWorkspaceStore();\n var state = store.getState();\n if (state.context != contextKey) {\n store.setState({\n context: contextKey,\n openWorkspaces: [],\n prompt: null\n });\n }\n}\nvar initialState = {\n context: '',\n openWorkspaces: [],\n prompt: null,\n workspaceWindowState: 'normal',\n workspaceGroup: undefined\n};\nvar workspaceStore = (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_3__.createGlobalStore)('workspace', initialState);\nfunction getWorkspaceStore() {\n return workspaceStore;\n}\nfunction updateWorkspaceWindowState(value) {\n var store = getWorkspaceStore();\n var state = store.getState();\n store.setState(_object_spread_props(_object_spread({}, state), {\n workspaceWindowState: value\n }));\n}\nfunction getUpdatedWorkspaceWindowState(workspaceAtTop) {\n var _workspaceAtTop_preferredWindowSize;\n return (_workspaceAtTop_preferredWindowSize = workspaceAtTop === null || workspaceAtTop === void 0 ? void 0 : workspaceAtTop.preferredWindowSize) !== null && _workspaceAtTop_preferredWindowSize !== void 0 ? _workspaceAtTop_preferredWindowSize : 'normal';\n}\nfunction closeAllWorkspaces() {\n var onClosingWorkspaces = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : function() {}, filter = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : function() {\n return true;\n };\n var store = getWorkspaceStore();\n var canCloseAllWorkspaces = store.getState().openWorkspaces.filter(filter).every(function(param) {\n var name = param.name;\n return canCloseWorkspaceWithoutPrompting(name);\n });\n var updateWorkspaceStore = function() {\n resetWorkspaceStore();\n onClosingWorkspaces === null || onClosingWorkspaces === void 0 ? void 0 : onClosingWorkspaces();\n };\n if (!canCloseAllWorkspaces) {\n showWorkspacePrompts('closing-all-workspaces', updateWorkspaceStore);\n } else {\n updateWorkspaceStore();\n }\n}\nfunction useWorkspaces() {\n var _useStore = (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_5__.useStore)(workspaceStore), workspaceWindowState = _useStore.workspaceWindowState, openWorkspaces = _useStore.openWorkspaces, prompt = _useStore.prompt, workspaceGroup = _useStore.workspaceGroup;\n var memoisedResults = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function() {\n return {\n active: openWorkspaces.length > 0,\n prompt: prompt,\n workspaceWindowState: workspaceWindowState,\n workspaces: openWorkspaces,\n workspaceGroup: workspaceGroup\n };\n }, [\n openWorkspaces,\n workspaceWindowState,\n prompt,\n workspaceGroup\n ]);\n return memoisedResults;\n}\n/**\n * Sets the current prompt according to the prompt type.\n * @param promptType Determines the text and behavior of the prompt\n * @param onConfirmation Function to be called after the user confirms to close the workspace\n * @param workspaceTitle Workspace title to be shown in the prompt\n * @returns\n */ function showWorkspacePrompts(promptType) {\n var onConfirmation = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : function() {}, workspaceTitle = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : '';\n var store = getWorkspaceStore();\n var prompt;\n switch(promptType){\n case 'closing-workspace':\n {\n prompt = {\n title: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('unsavedChangesTitleText', 'Unsaved changes'),\n body: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('unsavedChangesInOpenedWorkspace', \"You may have unsaved changes in the opened workspace. Do you want to discard these changes?\"),\n onConfirm: function() {\n onConfirmation === null || onConfirmation === void 0 ? void 0 : onConfirmation();\n },\n confirmText: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('discard', 'Discard')\n };\n break;\n }\n case 'closing-all-workspaces':\n {\n var workspacesNotClosed = store.getState().openWorkspaces.filter(function(param) {\n var name = param.name;\n return !canCloseWorkspaceWithoutPrompting(name);\n }).map(function(param, indx) {\n var title = param.title;\n return \"\".concat(indx + 1, \". \").concat(title);\n });\n prompt = {\n title: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('closingAllWorkspacesPromptTitle', 'You have unsaved changes'),\n body: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('closingAllWorkspacesPromptBody', 'There may be unsaved changes in the following workspaces. Do you want to discard changes in the following workspaces? {{workspaceNames}}', {\n workspaceNames: workspacesNotClosed.join(',')\n }),\n onConfirm: function() {\n onConfirmation === null || onConfirmation === void 0 ? void 0 : onConfirmation();\n },\n confirmText: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('closeAllOpenedWorkspaces', 'Discard changes in {{count}} workspaces', {\n count: workspacesNotClosed.length\n })\n };\n break;\n }\n case 'closing-workspace-launching-new-workspace':\n {\n prompt = {\n title: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('unsavedChangesTitleText', 'Unsaved changes'),\n body: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('unsavedChangesInWorkspace', 'There may be unsaved changes in \"{{workspaceName}}\". Please save them before opening another workspace.', {\n workspaceName: workspaceTitle\n }),\n onConfirm: function() {\n store.setState(function(state) {\n return _object_spread_props(_object_spread({}, state), {\n prompt: null\n });\n });\n onConfirmation === null || onConfirmation === void 0 ? void 0 : onConfirmation();\n },\n confirmText: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('openAnyway', 'Open anyway')\n };\n break;\n }\n default:\n {\n console.error('Workspace system trying to open unknown prompt type \"'.concat(promptType, '\" in function \"showWorkspacePrompts\"'));\n onConfirmation === null || onConfirmation === void 0 ? void 0 : onConfirmation();\n return;\n }\n }\n store.setState(function(state) {\n return _object_spread_props(_object_spread({}, state), {\n prompt: prompt\n });\n });\n}\nfunction getWorkspaceTitle(workspace, additionalProps) {\n var _additionalProps_workspaceTitle;\n return (_additionalProps_workspaceTitle = additionalProps === null || additionalProps === void 0 ? void 0 : additionalProps['workspaceTitle']) !== null && _additionalProps_workspaceTitle !== void 0 ? _additionalProps_workspaceTitle : workspace.title;\n}\nfunction resetWorkspaceStore() {\n getWorkspaceStore().setState(initialState);\n}\n/**\n * The workspace group store is a store that is specific to the workspace group.\n * If the workspace has its own sidebar, the store will be created.\n * This store can be used to store data that is specific to the workspace group.\n * The store will be same for all the workspaces with same group name.\n *\n * For workspaces launched without a group, the store will be undefined.\n *\n * The store will be cleared when all the workspaces with the store's group name are closed.\n */ function getWorkspaceGroupStore(workspaceGroupName) {\n var additionalProps = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};\n if (!workspaceGroupName || workspaceGroupName === 'default') {\n return undefined;\n }\n var store = (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_3__.getGlobalStore)(workspaceGroupName, {});\n if (additionalProps) {\n store.setState(function(prev) {\n return _object_spread({}, prev, additionalProps);\n });\n }\n return store;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-styleguide/src/workspaces/workspaces.ts","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-styleguide/src/workspaces/workspaces.ts?c15e"],"sourcesContent":["/** @module @category Workspace */\nimport { useMemo, type ReactNode } from 'react';\nimport {\n  getWorkspaceGroupRegistration,\n  getWorkspaceRegistration,\n  type WorkspaceRegistration,\n} from '@openmrs/esm-extensions';\nimport { type WorkspaceWindowState } from '@openmrs/esm-globals';\nimport { navigate } from '@openmrs/esm-navigation';\nimport { getGlobalStore, createGlobalStore } from '@openmrs/esm-state';\nimport { getCoreTranslation } from '@openmrs/esm-translations';\nimport { useStore } from '@openmrs/esm-react-utils';\nimport type { StoreApi } from 'zustand/vanilla';\n\nexport interface CloseWorkspaceOptions {\n  /**\n   * Whether to close the workspace ignoring all the changes present in the workspace.\n   *\n   * If ignoreChanges is true, the user will not be prompted to save changes before closing\n   * even if the `testFcn` passed to `promptBeforeClosing` returns `true`.\n   */\n  ignoreChanges?: boolean;\n  /**\n   * If you want to take an action after the workspace is closed, you can pass your function as\n   * `onWorkspaceClose`. This function will be called only after the workspace is closed, given\n   * that the user might be shown a prompt.\n   * @returns void\n   */\n  onWorkspaceClose?: () => void;\n  /**\n   * Controls whether the workspace group should be closed and store to be\n   * cleared when this workspace is closed.\n   * Defaults to true except when opening a new workspace of the same group.\n   *\n   * @default true\n   */\n  closeWorkspaceGroup?: boolean;\n}\n\n/** The default parameters received by all workspaces */\nexport interface DefaultWorkspaceProps {\n  /**\n   * Call this function to close the workspace. This function will prompt the user\n   * if there are any unsaved changes to workspace.\n   *\n   * You can pass `onWorkspaceClose` function to be called when the workspace is finally\n   * closed, given the user forcefully closes the workspace.\n   */\n  closeWorkspace(closeWorkspaceOptions?: CloseWorkspaceOptions): void;\n  /**\n   * Call this with a no-args function that returns true if the user should be prompted before\n   * this workspace is closed; e.g. if there is unsaved data.\n   */\n  promptBeforeClosing(testFcn: () => boolean): void;\n  /**\n   * Call this function to close the workspace after the form is saved. This function\n   * will directly close the workspace without any prompt\n   */\n  closeWorkspaceWithSavedChanges(closeWorkspaceOptions?: CloseWorkspaceOptions): void;\n  /**\n   * Use this to set the workspace title if it needs to be set dynamically.\n   *\n   * Workspace titles generally are set in the workspace declaration in the routes.json file. They can also\n   * be set by the workspace launcher by passing `workspaceTitle` in the `additionalProps`\n   * parameter of the `launchWorkspace` function. This function is useful when the workspace\n   * title needs to be set dynamically.\n   *\n   * @param title The title to set. If using titleNode, set this to a human-readable string\n   *        which will identify the workspace in notifications and other places.\n   * @param titleNode A React object to put in the workspace header in place of the title. This\n   *        is useful for displaying custom elements in the header. Note that custom header\n   *        elements can also be attached to the workspace header extension slots.\n   */\n  setTitle(title: string, titleNode?: ReactNode): void;\n}\n\nexport interface WorkspaceWindowSize {\n  size: WorkspaceWindowState;\n}\n\nexport interface WorkspaceWindowSizeProviderProps {\n  children?: React.ReactNode;\n}\n\nexport interface WorkspaceWindowSizeContext {\n  windowSize: WorkspaceWindowSize;\n  updateWindowSize?(value: WorkspaceWindowState): any;\n  active: boolean;\n}\n\nexport interface Prompt {\n  title: string;\n  body: string;\n  /** Defaults to \"Confirm\" */\n  confirmText?: string;\n  onConfirm(): void;\n  /** Defaults to \"Cancel\" */\n  cancelText?: string;\n}\n\nexport interface WorkspaceStoreState {\n  context: string | null;\n  openWorkspaces: Array<OpenWorkspace>;\n  prompt: Prompt | null;\n  workspaceWindowState: WorkspaceWindowState;\n  workspaceGroup?: {\n    name: string;\n    members: Array<string>;\n    cleanup?: Function;\n  };\n}\n\nexport interface OpenWorkspace extends WorkspaceRegistration, DefaultWorkspaceProps {\n  additionalProps: object;\n  currentWorkspaceGroup?: string;\n}\n\n/**\n *\n * @param name Name of the workspace\n * @param ignoreChanges If set to true, the \"unsaved changes\" modal will never be shown, even if the `promptBeforeClosing` function returns true. The user will not be prompted before closing.\n * @returns true if the workspace can be closed.\n */\nexport function canCloseWorkspaceWithoutPrompting(name: string, ignoreChanges: boolean = false) {\n  if (ignoreChanges) {\n    return true;\n  }\n  const promptBeforeFn = getPromptBeforeClosingFcn(name);\n  return !promptBeforeFn || !promptBeforeFn();\n}\n\n/**\n * Closes a workspace group and performs cleanup operations.\n *\n * @param groupName - The name of the workspace group to close\n * @param onWorkspaceCloseup - Optional callback function to execute after closing the workspace group\n * @returns void, or exits early if the current workspace group name doesn't match the provided group name\n *\n * @remarks\n * This function performs the following operations:\n * - Validates if the provided group name matches the current workspace group\n * - Closes all workspaces associated with the group\n * - Clears the workspace group store state\n * - Executes cleanup function if defined in the workspace group\n * - Updates the main workspace store to remove the workspace group\n * - Calls the optional closeup callback if provided\n */\nfunction closeWorkspaceGroup(groupName: string, onWorkspaceCloseup?: () => void) {\n  const store = getWorkspaceStore();\n  const currentWorkspaceGroup = store.getState()?.workspaceGroup;\n  const currentGroupName = currentWorkspaceGroup?.name;\n  if (!currentGroupName || groupName !== currentGroupName) {\n    return;\n  }\n  const filter: (workspace: OpenWorkspace) => boolean = currentGroupName\n    ? (workspace) => workspace.currentWorkspaceGroup === currentGroupName\n    : () => true;\n\n  closeAllWorkspaces(() => {\n    // Clearing the workspace group and respective store if the new workspace is not part of the current group, which is handled in the `launchWorkspace` function.\n    const workspaceGroupStore = getWorkspaceGroupStore(groupName);\n    if (workspaceGroupStore) {\n      workspaceGroupStore.setState({}, true);\n      const unsubscribe = workspaceGroupStore.subscribe(() => {});\n      unsubscribe();\n    }\n\n    if (typeof currentWorkspaceGroup?.cleanup === 'function') {\n      currentWorkspaceGroup.cleanup();\n    }\n\n    store.setState((prev) => ({\n      ...prev,\n      workspaceGroup: undefined,\n    }));\n\n    if (typeof onWorkspaceCloseup === 'function') {\n      onWorkspaceCloseup();\n    }\n  }, filter);\n}\n\ninterface LaunchWorkspaceGroupArg {\n  state: object;\n  onWorkspaceGroupLaunch?: Function;\n  workspaceGroupCleanup?: Function;\n  workspaceToLaunch?: {\n    name: string;\n    additionalProps?: object;\n  };\n}\n\n/**\n * Launches a workspace group with the specified name and configuration.\n * If there are any open workspaces, it will first close them before launching the new workspace group.\n *\n * @param groupName - The name of the workspace group to launch\n * @param args - Configuration object for launching the workspace group\n * @param args.state - The initial state for the workspace group\n * @param args.onWorkspaceGroupLaunch - Optional callback function to be executed after the workspace group is launched\n * @param args.workspaceGroupCleanup - Optional cleanup function to be executed when the workspace group is closed\n *\n * @example\n * launchWorkspaceGroup(\"myGroup\", {\n *   state: initialState,\n *   onWorkspaceGroupLaunch: () => console.log(\"Workspace group launched\"),\n *   workspaceGroupCleanup: () => console.log(\"Cleaning up workspace group\")\n * });\n */\nexport function launchWorkspaceGroup(groupName: string, args: LaunchWorkspaceGroupArg) {\n  const workspaceGroupRegistration = getWorkspaceGroupRegistration(groupName);\n  const { state, onWorkspaceGroupLaunch, workspaceGroupCleanup, workspaceToLaunch } = args;\n  const store = getWorkspaceStore();\n  if (store.getState().openWorkspaces.length) {\n    const workspaceGroup = store.getState().workspaceGroup;\n    if (workspaceGroup) {\n      closeWorkspaceGroup(workspaceGroup?.name, () => {\n        launchWorkspaceGroup(groupName, args);\n      });\n    } else {\n      closeAllWorkspaces(() => {\n        launchWorkspaceGroup(groupName, args);\n      });\n    }\n  } else {\n    store.setState((prev) => ({\n      ...prev,\n      workspaceGroup: {\n        name: groupName,\n        members: workspaceGroupRegistration.members,\n        cleanup: workspaceGroupCleanup,\n      },\n    }));\n    getWorkspaceGroupStore(groupName, state);\n    onWorkspaceGroupLaunch?.();\n    if (workspaceToLaunch) {\n      launchWorkspace(workspaceToLaunch.name, workspaceToLaunch.additionalProps ?? {});\n    }\n  }\n}\n\nfunction promptBeforeLaunchingWorkspace(\n  workspace: OpenWorkspace,\n  newWorkspaceDetails: { name: string; additionalProps?: object },\n) {\n  const { name, additionalProps } = newWorkspaceDetails;\n  const newWorkspaceRegistration = getWorkspaceRegistration(name);\n\n  const proceed = () => {\n    closeWorkspace(workspace.name, {\n      ignoreChanges: true,\n      // Calling the launchWorkspace again, since one of the `if` case\n      // might resolve, but we need to check all the cases before launching the form.\n      onWorkspaceClose: () => launchWorkspace(name, additionalProps),\n      // If the new workspace is of the same sidebar group, then we don't need to clear the workspace group store.\n      closeWorkspaceGroup: false,\n    });\n  };\n\n  if (!canCloseWorkspaceWithoutPrompting(workspace.name)) {\n    showWorkspacePrompts('closing-workspace-launching-new-workspace', proceed, workspace.title ?? workspace.name);\n  } else {\n    proceed();\n  }\n}\n\n/**\n * This launches a workspace by its name. The workspace must have been registered.\n * Workspaces should be registered in the `routes.json` file.\n *\n * For the workspace to appear, there must be either a `<WorkspaceOverlay />` or\n * a `<WorkspaceWindow />` component rendered.\n *\n * The behavior of this function is as follows:\n *\n * - If no workspaces are open, or if no other workspaces with the same type are open,\n *   it will be opened and focused.\n * - If a workspace with the same name is already open, it will be displayed/focused,\n *   if it was not already.\n * - If a workspace is launched and a workspace which cannot be hidden is already open,\n *  a confirmation modal will pop up warning about closing the currently open workspace.\n * - If another workspace with the same type is open, the workspace will be brought to\n *   the front and then a confirmation modal will pop up warning about closing the opened\n *   workspace\n *\n * Note that this function just manipulates the workspace store. The UI logic is handled\n * by the components that display workspaces.\n *\n * Additional props can be passed to the workspace component being launched. Passing a\n * prop named `workspaceTitle` will override the title of the workspace.\n *\n * @param name The name of the workspace to launch\n * @param additionalProps Props to pass to the workspace component being launched. Passing\n *          a prop named `workspaceTitle` will override the title of the workspace.\n */\nexport function launchWorkspace<\n  T extends DefaultWorkspaceProps | object = DefaultWorkspaceProps & { [key: string]: any },\n>(name: string, additionalProps?: Omit<T, keyof DefaultWorkspaceProps> & { workspaceTitle?: string }) {\n  const store = getWorkspaceStore();\n  const workspace = getWorkspaceRegistration(name);\n  const currentWorkspaceGroup = store.getState().workspaceGroup;\n\n  if (currentWorkspaceGroup && !currentWorkspaceGroup.members?.includes(name)) {\n    closeWorkspaceGroup(currentWorkspaceGroup.name, () => {\n      launchWorkspace(name, additionalProps);\n    });\n    return;\n  }\n  const currentGroupName = store.getState().workspaceGroup?.name;\n  const newWorkspace: OpenWorkspace = {\n    ...workspace,\n    title: getWorkspaceTitle(workspace, additionalProps),\n    closeWorkspace: (options: CloseWorkspaceOptions = {}) => closeWorkspace(name, options),\n    closeWorkspaceWithSavedChanges: (options: CloseWorkspaceOptions) =>\n      closeWorkspace(name, { ignoreChanges: true, ...options }),\n    promptBeforeClosing: (testFcn) => promptBeforeClosing(name, testFcn),\n    setTitle: (title: string, titleNode: ReactNode) => {\n      newWorkspace.title = title;\n      newWorkspace.titleNode = titleNode;\n      store.setState((state) => {\n        const openWorkspaces = state.openWorkspaces.map((w) => (w.name === name ? newWorkspace : w));\n        return {\n          ...state,\n          openWorkspaces,\n        };\n      });\n    },\n    currentWorkspaceGroup: currentGroupName,\n    additionalProps: additionalProps ?? {},\n  };\n\n  if (currentGroupName) {\n    getWorkspaceGroupStore(currentGroupName, additionalProps);\n  }\n  function updateStoreWithNewWorkspace(workspaceToBeAdded: OpenWorkspace, restOfTheWorkspaces?: Array<OpenWorkspace>) {\n    store.setState((state) => {\n      const openWorkspaces = [workspaceToBeAdded, ...(restOfTheWorkspaces ?? state.openWorkspaces)];\n      let workspaceWindowState = getUpdatedWorkspaceWindowState(workspaceToBeAdded);\n\n      return {\n        ...state,\n        openWorkspaces,\n        workspaceWindowState,\n      };\n    });\n  }\n\n  const openWorkspaces = store.getState().openWorkspaces;\n  const workspaceIndexInOpenWorkspaces = openWorkspaces.findIndex((w) => w.name === name);\n  const isWorkspaceAlreadyOpen = workspaceIndexInOpenWorkspaces >= 0;\n  const openedWorkspaceWithSameType = openWorkspaces.find((w) => w.type == newWorkspace.type);\n\n  if (openWorkspaces.length === 0) {\n    updateStoreWithNewWorkspace(newWorkspace);\n  } else if (!openWorkspaces[0].canHide && workspaceIndexInOpenWorkspaces !== 0) {\n    promptBeforeLaunchingWorkspace(openWorkspaces[0], {\n      name,\n      additionalProps,\n    });\n  } else if (isWorkspaceAlreadyOpen) {\n    const openWorkspace = openWorkspaces[workspaceIndexInOpenWorkspaces];\n    // Only update the title if it hasn't been set by `setTitle`\n    if (openWorkspace.title === getWorkspaceTitle(openWorkspace, openWorkspace.additionalProps)) {\n      openWorkspace.title = getWorkspaceTitle(newWorkspace, newWorkspace.additionalProps);\n    }\n    openWorkspace.additionalProps = newWorkspace.additionalProps;\n    const restOfTheWorkspaces = openWorkspaces.filter((w) => w.name != name);\n    updateStoreWithNewWorkspace(openWorkspaces[workspaceIndexInOpenWorkspaces], restOfTheWorkspaces);\n  } else if (openedWorkspaceWithSameType) {\n    const restOfTheWorkspaces = store.getState().openWorkspaces.filter((w) => w.type != newWorkspace.type);\n    updateStoreWithNewWorkspace(openedWorkspaceWithSameType, restOfTheWorkspaces);\n    promptBeforeLaunchingWorkspace(openedWorkspaceWithSameType, {\n      name,\n      additionalProps,\n    });\n  } else {\n    updateStoreWithNewWorkspace(newWorkspace);\n  }\n}\n\n/**\n * Use this function to navigate to a new page and launch a workspace on that page.\n *\n * @param options.targetUrl: The URL to navigate to. Will be passed to [[navigate]].\n * @param options.contextKey: The context key used by the target page.\n * @param options.workspaceName: The name of the workspace to launch.\n * @param options.additionalProps: Additional props to pass to the workspace component being launched.\n */\nexport function navigateAndLaunchWorkspace({\n  targetUrl,\n  contextKey,\n  workspaceName,\n  additionalProps,\n}: {\n  targetUrl: string;\n  contextKey: string;\n  workspaceName: string;\n  additionalProps?: object;\n}) {\n  changeWorkspaceContext(contextKey);\n  launchWorkspace(workspaceName, additionalProps);\n  navigate({ to: targetUrl });\n}\n\nconst promptBeforeClosingFcns = {};\n\nexport function promptBeforeClosing(workspaceName: string, testFcn: () => boolean) {\n  promptBeforeClosingFcns[workspaceName] = testFcn;\n}\n\nexport function getPromptBeforeClosingFcn(workspaceName: string) {\n  return promptBeforeClosingFcns[workspaceName];\n}\n\nexport function cancelPrompt() {\n  const store = getWorkspaceStore();\n  const state = store.getState();\n  store.setState({ ...state, prompt: null });\n}\n\nconst defaultOptions: CloseWorkspaceOptions = {\n  ignoreChanges: false,\n  onWorkspaceClose: () => {},\n  closeWorkspaceGroup: true,\n};\n\n/**\n * Function to close an opened workspace\n * @param name Workspace registration name\n * @param options Options to close workspace\n */\nexport function closeWorkspace(name: string, options: CloseWorkspaceOptions = {}): boolean {\n  options = { ...defaultOptions, ...options };\n  const store = getWorkspaceStore();\n\n  const updateStoreWithClosedWorkspace = () => {\n    const state = store.getState();\n    const workspaceToBeClosed = state.openWorkspaces.find((w) => w.name === name);\n    const newOpenWorkspaces = state.openWorkspaces.filter((w) => w.name != name);\n\n    const workspaceGroupName = store.getState().workspaceGroup?.name;\n\n    if (workspaceGroupName && options.closeWorkspaceGroup) {\n      closeWorkspaceGroup(workspaceGroupName);\n    }\n\n    // ensure closed workspace will not prompt\n    promptBeforeClosing(name, () => false);\n    store.setState((prev) => ({\n      ...prev,\n      prompt: null,\n      openWorkspaces: newOpenWorkspaces,\n      workspaceWindowState: getUpdatedWorkspaceWindowState(newOpenWorkspaces?.[0]),\n    }));\n\n    options?.onWorkspaceClose?.();\n  };\n\n  if (!canCloseWorkspaceWithoutPrompting(name, options?.ignoreChanges)) {\n    const currentName = getWorkspaceRegistration(name).title ?? name;\n    showWorkspacePrompts('closing-workspace', updateStoreWithClosedWorkspace, currentName);\n    return false;\n  } else {\n    updateStoreWithClosedWorkspace();\n    return true;\n  }\n}\n\n/**\n * The set of workspaces is specific to a particular page. This function\n * should be used when transitioning to a new page. If the current\n * workspace data is for a different page, the workspace state is cleared.\n *\n * This is called by the workspace components when they mount.\n * @internal\n *\n * @param contextKey An arbitrary key to identify the current page\n */\nexport function changeWorkspaceContext(contextKey: string | null) {\n  const store = getWorkspaceStore();\n  const state = store.getState();\n  if (state.context != contextKey) {\n    store.setState({ context: contextKey, openWorkspaces: [], prompt: null });\n  }\n}\n\nconst initialState: WorkspaceStoreState = {\n  context: '',\n  openWorkspaces: [],\n  prompt: null,\n  workspaceWindowState: 'normal',\n  workspaceGroup: undefined,\n};\n\nexport const workspaceStore = createGlobalStore('workspace', initialState);\n\nexport function getWorkspaceStore() {\n  return workspaceStore;\n}\n\nexport function updateWorkspaceWindowState(value: WorkspaceWindowState) {\n  const store = getWorkspaceStore();\n  const state = store.getState();\n  store.setState({ ...state, workspaceWindowState: value });\n}\n\nfunction getUpdatedWorkspaceWindowState(workspaceAtTop: OpenWorkspace) {\n  return workspaceAtTop?.preferredWindowSize ?? 'normal';\n}\nexport function closeAllWorkspaces(\n  onClosingWorkspaces: () => void = () => {},\n  filter: (workspace: OpenWorkspace) => boolean = () => true,\n) {\n  const store = getWorkspaceStore();\n\n  const canCloseAllWorkspaces = store\n    .getState()\n    .openWorkspaces.filter(filter)\n    .every(({ name }) => {\n      return canCloseWorkspaceWithoutPrompting(name);\n    });\n\n  const updateWorkspaceStore = () => {\n    resetWorkspaceStore();\n    onClosingWorkspaces?.();\n  };\n\n  if (!canCloseAllWorkspaces) {\n    showWorkspacePrompts('closing-all-workspaces', updateWorkspaceStore);\n  } else {\n    updateWorkspaceStore();\n  }\n}\n\nexport interface WorkspacesInfo {\n  active: boolean;\n  prompt: Prompt | null;\n  workspaceWindowState: WorkspaceWindowState;\n  workspaces: Array<OpenWorkspace>;\n  workspaceGroup?: WorkspaceStoreState['workspaceGroup'];\n}\n\nexport function useWorkspaces(): WorkspacesInfo {\n  const { workspaceWindowState, openWorkspaces, prompt, workspaceGroup } = useStore(workspaceStore);\n  const memoisedResults: WorkspacesInfo = useMemo(() => {\n    return {\n      active: openWorkspaces.length > 0,\n      prompt,\n      workspaceWindowState,\n      workspaces: openWorkspaces,\n      workspaceGroup,\n    };\n  }, [openWorkspaces, workspaceWindowState, prompt, workspaceGroup]);\n  return memoisedResults;\n}\n\ntype PromptType = 'closing-workspace' | 'closing-all-workspaces' | 'closing-workspace-launching-new-workspace';\n\n/**\n * Sets the current prompt according to the prompt type.\n * @param promptType Determines the text and behavior of the prompt\n * @param onConfirmation Function to be called after the user confirms to close the workspace\n * @param workspaceTitle Workspace title to be shown in the prompt\n * @returns\n */\nexport function showWorkspacePrompts(\n  promptType: PromptType,\n  onConfirmation: () => void = () => {},\n  workspaceTitle: string = '',\n) {\n  const store = getWorkspaceStore();\n\n  let prompt: Prompt;\n  switch (promptType) {\n    case 'closing-workspace': {\n      prompt = {\n        title: getCoreTranslation('unsavedChangesTitleText', 'Unsaved changes'),\n        body: getCoreTranslation(\n          'unsavedChangesInOpenedWorkspace',\n          `You may have unsaved changes in the opened workspace. Do you want to discard these changes?`,\n        ),\n        onConfirm: () => {\n          onConfirmation?.();\n        },\n        confirmText: getCoreTranslation('discard', 'Discard'),\n      };\n      break;\n    }\n\n    case 'closing-all-workspaces': {\n      const workspacesNotClosed = store\n        .getState()\n        .openWorkspaces.filter(({ name }) => !canCloseWorkspaceWithoutPrompting(name))\n        .map(({ title }, indx) => `${indx + 1}. ${title}`);\n\n      prompt = {\n        title: getCoreTranslation('closingAllWorkspacesPromptTitle', 'You have unsaved changes'),\n        body: getCoreTranslation(\n          'closingAllWorkspacesPromptBody',\n          'There may be unsaved changes in the following workspaces. Do you want to discard changes in the following workspaces? {{workspaceNames}}',\n          {\n            workspaceNames: workspacesNotClosed.join(','),\n          },\n        ),\n        onConfirm: () => {\n          onConfirmation?.();\n        },\n        confirmText: getCoreTranslation('closeAllOpenedWorkspaces', 'Discard changes in {{count}} workspaces', {\n          count: workspacesNotClosed.length,\n        }),\n      };\n      break;\n    }\n    case 'closing-workspace-launching-new-workspace': {\n      prompt = {\n        title: getCoreTranslation('unsavedChangesTitleText', 'Unsaved changes'),\n        body: getCoreTranslation(\n          'unsavedChangesInWorkspace',\n          'There may be unsaved changes in \"{{workspaceName}}\". Please save them before opening another workspace.',\n          { workspaceName: workspaceTitle },\n        ),\n        onConfirm: () => {\n          store.setState((state) => ({\n            ...state,\n            prompt: null,\n          }));\n          onConfirmation?.();\n        },\n        confirmText: getCoreTranslation('openAnyway', 'Open anyway'),\n      };\n      break;\n    }\n    default: {\n      console.error(\n        `Workspace system trying to open unknown prompt type \"${promptType}\" in function \"showWorkspacePrompts\"`,\n      );\n      onConfirmation?.();\n      return;\n    }\n  }\n  store.setState((state) => ({ ...state, prompt }));\n}\n\nfunction getWorkspaceTitle(workspace: WorkspaceRegistration, additionalProps?: object) {\n  return additionalProps?.['workspaceTitle'] ?? workspace.title;\n}\n\nexport function resetWorkspaceStore() {\n  getWorkspaceStore().setState(initialState);\n}\n\n/**\n * The workspace group store is a store that is specific to the workspace group.\n * If the workspace has its own sidebar, the store will be created.\n * This store can be used to store data that is specific to the workspace group.\n * The store will be same for all the workspaces with same group name.\n *\n * For workspaces launched without a group, the store will be undefined.\n *\n * The store will be cleared when all the workspaces with the store's group name are closed.\n */\nexport function getWorkspaceGroupStore(\n  workspaceGroupName: string | undefined,\n  additionalProps: object = {},\n): StoreApi<object> | undefined {\n  if (!workspaceGroupName || workspaceGroupName === 'default') {\n    return undefined;\n  }\n  const store = getGlobalStore<object>(workspaceGroupName, {});\n  if (additionalProps) {\n    store.setState((prev) => ({\n      ...prev,\n      ...additionalProps,\n    }));\n  }\n  return store;\n}\n"],"names":["useMemo","getWorkspaceGroupRegistration","getWorkspaceRegistration","navigate","getGlobalStore","createGlobalStore","getCoreTranslation","useStore","canCloseWorkspaceWithoutPrompting","name","ignoreChanges","promptBeforeFn","getPromptBeforeClosingFcn","closeWorkspaceGroup","groupName","onWorkspaceCloseup","store","getWorkspaceStore","currentWorkspaceGroup","getState","workspaceGroup","currentGroupName","filter","workspace","closeAllWorkspaces","workspaceGroupStore","getWorkspaceGroupStore","setState","unsubscribe","subscribe","cleanup","prev","undefined","launchWorkspaceGroup","args","workspaceGroupRegistration","state","onWorkspaceGroupLaunch","workspaceGroupCleanup","workspaceToLaunch","openWorkspaces","length","members","launchWorkspace","additionalProps","promptBeforeLaunchingWorkspace","newWorkspaceDetails","newWorkspaceRegistration","proceed","closeWorkspace","onWorkspaceClose","showWorkspacePrompts","title","includes","newWorkspace","getWorkspaceTitle","options","closeWorkspaceWithSavedChanges","promptBeforeClosing","testFcn","setTitle","titleNode","map","w","updateStoreWithNewWorkspace","workspaceToBeAdded","restOfTheWorkspaces","workspaceWindowState","getUpdatedWorkspaceWindowState","workspaceIndexInOpenWorkspaces","findIndex","isWorkspaceAlreadyOpen","openedWorkspaceWithSameType","find","type","canHide","openWorkspace","navigateAndLaunchWorkspace","targetUrl","contextKey","workspaceName","changeWorkspaceContext","to","promptBeforeClosingFcns","cancelPrompt","prompt","defaultOptions","updateStoreWithClosedWorkspace","workspaceToBeClosed","newOpenWorkspaces","workspaceGroupName","currentName","context","initialState","workspaceStore","updateWorkspaceWindowState","value","workspaceAtTop","preferredWindowSize","onClosingWorkspaces","canCloseAllWorkspaces","every","updateWorkspaceStore","resetWorkspaceStore","useWorkspaces","memoisedResults","active","workspaces","promptType","onConfirmation","workspaceTitle","body","onConfirm","confirmText","workspacesNotClosed","indx","workspaceNames","join","count","console","error"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/src/workspaces/workspaces.ts\n");
2148
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ canCloseWorkspaceWithoutPrompting: () => (/* binding */ canCloseWorkspaceWithoutPrompting),\n/* harmony export */ cancelPrompt: () => (/* binding */ cancelPrompt),\n/* harmony export */ changeWorkspaceContext: () => (/* binding */ changeWorkspaceContext),\n/* harmony export */ closeAllWorkspaces: () => (/* binding */ closeAllWorkspaces),\n/* harmony export */ closeWorkspace: () => (/* binding */ closeWorkspace),\n/* harmony export */ getPromptBeforeClosingFcn: () => (/* binding */ getPromptBeforeClosingFcn),\n/* harmony export */ getWorkspaceGroupStore: () => (/* binding */ getWorkspaceGroupStore),\n/* harmony export */ getWorkspaceStore: () => (/* binding */ getWorkspaceStore),\n/* harmony export */ launchWorkspace: () => (/* binding */ launchWorkspace),\n/* harmony export */ launchWorkspaceGroup: () => (/* binding */ launchWorkspaceGroup),\n/* harmony export */ navigateAndLaunchWorkspace: () => (/* binding */ navigateAndLaunchWorkspace),\n/* harmony export */ promptBeforeClosing: () => (/* binding */ promptBeforeClosing),\n/* harmony export */ resetWorkspaceStore: () => (/* binding */ resetWorkspaceStore),\n/* harmony export */ showWorkspacePrompts: () => (/* binding */ showWorkspacePrompts),\n/* harmony export */ updateWorkspaceWindowState: () => (/* binding */ updateWorkspaceWindowState),\n/* harmony export */ useWorkspaces: () => (/* binding */ useWorkspaces),\n/* harmony export */ workspaceStore: () => (/* binding */ workspaceStore)\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__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\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 _openmrs_esm_navigation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @openmrs/esm-navigation */ \"../../framework/esm-navigation/dist/index.js\");\n/* harmony import */ var _openmrs_esm_state__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @openmrs/esm-state */ \"../../framework/esm-state/dist/index.js\");\n/* harmony import */ var _openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @openmrs/esm-translations */ \"../../framework/esm-translations/dist/index.js\");\n/* harmony import */ var _openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @openmrs/esm-react-utils */ \"../../framework/esm-react-utils/dist/index.js\");\n/** @module @category Workspace */ function _array_like_to_array(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];\n return arr2;\n}\nfunction _array_without_holes(arr) {\n if (Array.isArray(arr)) return _array_like_to_array(arr);\n}\nfunction _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}\nfunction _iterable_to_array(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}\nfunction _non_iterable_spread() {\n throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nfunction _object_spread(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = arguments[i] != null ? arguments[i] : {};\n var ownKeys = Object.keys(source);\n if (typeof Object.getOwnPropertySymbols === \"function\") {\n ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {\n return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n }));\n }\n ownKeys.forEach(function(key) {\n _define_property(target, key, source[key]);\n });\n }\n return target;\n}\nfunction ownKeys(object, enumerableOnly) {\n var keys = Object.keys(object);\n if (Object.getOwnPropertySymbols) {\n var symbols = Object.getOwnPropertySymbols(object);\n if (enumerableOnly) {\n symbols = symbols.filter(function(sym) {\n return Object.getOwnPropertyDescriptor(object, sym).enumerable;\n });\n }\n keys.push.apply(keys, symbols);\n }\n return keys;\n}\nfunction _object_spread_props(target, source) {\n source = source != null ? source : {};\n if (Object.getOwnPropertyDescriptors) {\n Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));\n } else {\n ownKeys(Object(source)).forEach(function(key) {\n Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));\n });\n }\n return target;\n}\nfunction _to_consumable_array(arr) {\n return _array_without_holes(arr) || _iterable_to_array(arr) || _unsupported_iterable_to_array(arr) || _non_iterable_spread();\n}\nfunction _unsupported_iterable_to_array(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _array_like_to_array(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(n);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);\n}\n\n\n\n\n\n\n/**\n *\n * @param name Name of the workspace\n * @param ignoreChanges If set to true, the \"unsaved changes\" modal will never be shown, even if the `promptBeforeClosing` function returns true. The user will not be prompted before closing.\n * @returns true if the workspace can be closed.\n */ function canCloseWorkspaceWithoutPrompting(name) {\n var ignoreChanges = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : false;\n if (ignoreChanges) {\n return true;\n }\n var promptBeforeFn = getPromptBeforeClosingFcn(name);\n return !promptBeforeFn || !promptBeforeFn();\n}\n/**\n * Closes a workspace group and performs cleanup operations.\n *\n * @param groupName - The name of the workspace group to close\n * @param onWorkspaceCloseup - Optional callback function to execute after closing the workspace group\n * @returns void, or exits early if the current workspace group name doesn't match the provided group name\n *\n * @remarks\n * This function performs the following operations:\n * - Validates if the provided group name matches the current workspace group\n * - Closes all workspaces associated with the group\n * - Clears the workspace group store state\n * - Executes cleanup function if defined in the workspace group\n * - Updates the main workspace store to remove the workspace group\n * - Calls the optional closeup callback if provided\n */ function closeWorkspaceGroup(groupName, onWorkspaceCloseup) {\n var _store_getState;\n var store = getWorkspaceStore();\n var currentWorkspaceGroup = (_store_getState = store.getState()) === null || _store_getState === void 0 ? void 0 : _store_getState.workspaceGroup;\n var currentGroupName = currentWorkspaceGroup === null || currentWorkspaceGroup === void 0 ? void 0 : currentWorkspaceGroup.name;\n if (!currentGroupName || groupName !== currentGroupName) {\n return;\n }\n var filter = currentGroupName ? function(workspace) {\n return workspace.currentWorkspaceGroup === currentGroupName;\n } : function() {\n return true;\n };\n closeAllWorkspaces(function() {\n // Clearing the workspace group and respective store if the new workspace is not part of the current group, which is handled in the `launchWorkspace` function.\n var workspaceGroupStore = getWorkspaceGroupStore(groupName);\n if (workspaceGroupStore) {\n workspaceGroupStore.setState({}, true);\n var unsubscribe = workspaceGroupStore.subscribe(function() {});\n unsubscribe();\n }\n if (typeof (currentWorkspaceGroup === null || currentWorkspaceGroup === void 0 ? void 0 : currentWorkspaceGroup.cleanup) === 'function') {\n currentWorkspaceGroup.cleanup();\n }\n store.setState(function(prev) {\n return _object_spread_props(_object_spread({}, prev), {\n workspaceGroup: undefined\n });\n });\n if (typeof onWorkspaceCloseup === 'function') {\n onWorkspaceCloseup();\n }\n }, filter);\n}\n/**\n * Launches a workspace group with the specified name and configuration.\n * If there are any open workspaces, it will first close them before launching the new workspace group.\n *\n * @param groupName - The name of the workspace group to launch\n * @param args - Configuration object for launching the workspace group\n * @param args.state - The initial state for the workspace group\n * @param args.onWorkspaceGroupLaunch - Optional callback function to be executed after the workspace group is launched\n * @param args.workspaceGroupCleanup - Optional cleanup function to be executed when the workspace group is closed\n *\n * @example\n * launchWorkspaceGroup(\"myGroup\", {\n * state: initialState,\n * onWorkspaceGroupLaunch: () => console.log(\"Workspace group launched\"),\n * workspaceGroupCleanup: () => console.log(\"Cleaning up workspace group\")\n * });\n */ function launchWorkspaceGroup(groupName, args) {\n var workspaceGroupRegistration = (0,_openmrs_esm_extensions__WEBPACK_IMPORTED_MODULE_1__.getWorkspaceGroupRegistration)(groupName);\n var state = args.state, onWorkspaceGroupLaunch = args.onWorkspaceGroupLaunch, workspaceGroupCleanup = args.workspaceGroupCleanup, workspaceToLaunch = args.workspaceToLaunch;\n var store = getWorkspaceStore();\n if (store.getState().openWorkspaces.length) {\n var workspaceGroup = store.getState().workspaceGroup;\n if (workspaceGroup) {\n closeWorkspaceGroup(workspaceGroup === null || workspaceGroup === void 0 ? void 0 : workspaceGroup.name, function() {\n launchWorkspaceGroup(groupName, args);\n });\n } else {\n closeAllWorkspaces(function() {\n launchWorkspaceGroup(groupName, args);\n });\n }\n } else {\n store.setState(function(prev) {\n return _object_spread_props(_object_spread({}, prev), {\n workspaceGroup: {\n name: groupName,\n members: workspaceGroupRegistration.members,\n cleanup: workspaceGroupCleanup\n }\n });\n });\n getWorkspaceGroupStore(groupName, state);\n onWorkspaceGroupLaunch === null || onWorkspaceGroupLaunch === void 0 ? void 0 : onWorkspaceGroupLaunch();\n if (workspaceToLaunch) {\n var _workspaceToLaunch_additionalProps;\n launchWorkspace(workspaceToLaunch.name, (_workspaceToLaunch_additionalProps = workspaceToLaunch.additionalProps) !== null && _workspaceToLaunch_additionalProps !== void 0 ? _workspaceToLaunch_additionalProps : {});\n }\n }\n}\nfunction promptBeforeLaunchingWorkspace(workspace, newWorkspaceDetails) {\n var name = newWorkspaceDetails.name, additionalProps = newWorkspaceDetails.additionalProps;\n var newWorkspaceRegistration = (0,_openmrs_esm_extensions__WEBPACK_IMPORTED_MODULE_1__.getWorkspaceRegistration)(name);\n var proceed = function() {\n closeWorkspace(workspace.name, {\n ignoreChanges: true,\n // Calling the launchWorkspace again, since one of the `if` case\n // might resolve, but we need to check all the cases before launching the form.\n onWorkspaceClose: function() {\n return launchWorkspace(name, additionalProps);\n },\n // If the new workspace is of the same sidebar group, then we don't need to clear the workspace group store.\n closeWorkspaceGroup: false\n });\n };\n if (!canCloseWorkspaceWithoutPrompting(workspace.name)) {\n var _workspace_title;\n showWorkspacePrompts('closing-workspace-launching-new-workspace', proceed, (_workspace_title = workspace.title) !== null && _workspace_title !== void 0 ? _workspace_title : workspace.name);\n } else {\n proceed();\n }\n}\n/**\n * This launches a workspace by its name. The workspace must have been registered.\n * Workspaces should be registered in the `routes.json` file.\n *\n * For the workspace to appear, there must be either a `<WorkspaceOverlay />` or\n * a `<WorkspaceWindow />` component rendered.\n *\n * The behavior of this function is as follows:\n *\n * - If no workspaces are open, or if no other workspaces with the same type are open,\n * it will be opened and focused.\n * - If a workspace with the same name is already open, it will be displayed/focused,\n * if it was not already.\n * - If a workspace is launched and a workspace which cannot be hidden is already open,\n * a confirmation modal will pop up warning about closing the currently open workspace.\n * - If another workspace with the same type is open, the workspace will be brought to\n * the front and then a confirmation modal will pop up warning about closing the opened\n * workspace\n *\n * Note that this function just manipulates the workspace store. The UI logic is handled\n * by the components that display workspaces.\n *\n * Additional props can be passed to the workspace component being launched. Passing a\n * prop named `workspaceTitle` will override the title of the workspace.\n *\n * @param name The name of the workspace to launch\n * @param additionalProps Props to pass to the workspace component being launched. Passing\n * a prop named `workspaceTitle` will override the title of the workspace.\n */ function launchWorkspace(name, additionalProps) {\n var _currentWorkspaceGroup_members, _store_getState_workspaceGroup;\n var store = getWorkspaceStore();\n var workspace = (0,_openmrs_esm_extensions__WEBPACK_IMPORTED_MODULE_1__.getWorkspaceRegistration)(name);\n var currentWorkspaceGroup = store.getState().workspaceGroup;\n if (currentWorkspaceGroup && !((_currentWorkspaceGroup_members = currentWorkspaceGroup.members) === null || _currentWorkspaceGroup_members === void 0 ? void 0 : _currentWorkspaceGroup_members.includes(name))) {\n closeWorkspaceGroup(currentWorkspaceGroup.name, function() {\n launchWorkspace(name, additionalProps);\n });\n return;\n }\n var currentGroupName = (_store_getState_workspaceGroup = store.getState().workspaceGroup) === null || _store_getState_workspaceGroup === void 0 ? void 0 : _store_getState_workspaceGroup.name;\n var newWorkspace = _object_spread_props(_object_spread({}, workspace), {\n title: getWorkspaceTitle(workspace, additionalProps),\n closeWorkspace: function() {\n var options = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {};\n return closeWorkspace(name, options);\n },\n closeWorkspaceWithSavedChanges: function(options) {\n return closeWorkspace(name, _object_spread({\n ignoreChanges: true\n }, options));\n },\n promptBeforeClosing: function(testFcn) {\n return promptBeforeClosing(name, testFcn);\n },\n setTitle: function(title, titleNode) {\n newWorkspace.title = title;\n newWorkspace.titleNode = titleNode;\n store.setState(function(state) {\n var openWorkspaces = state.openWorkspaces.map(function(w) {\n return w.name === name ? newWorkspace : w;\n });\n return _object_spread_props(_object_spread({}, state), {\n openWorkspaces: openWorkspaces\n });\n });\n },\n currentWorkspaceGroup: currentGroupName,\n additionalProps: additionalProps !== null && additionalProps !== void 0 ? additionalProps : {}\n });\n if (currentGroupName) {\n getWorkspaceGroupStore(currentGroupName, additionalProps);\n }\n function updateStoreWithNewWorkspace(workspaceToBeAdded, restOfTheWorkspaces) {\n store.setState(function(state) {\n var openWorkspaces = [\n workspaceToBeAdded\n ].concat(_to_consumable_array(restOfTheWorkspaces !== null && restOfTheWorkspaces !== void 0 ? restOfTheWorkspaces : state.openWorkspaces));\n var workspaceWindowState = getUpdatedWorkspaceWindowState(workspaceToBeAdded);\n return _object_spread_props(_object_spread({}, state), {\n openWorkspaces: openWorkspaces,\n workspaceWindowState: workspaceWindowState\n });\n });\n }\n var openWorkspaces = store.getState().openWorkspaces;\n var workspaceIndexInOpenWorkspaces = openWorkspaces.findIndex(function(w) {\n return w.name === name;\n });\n var isWorkspaceAlreadyOpen = workspaceIndexInOpenWorkspaces >= 0;\n var openedWorkspaceWithSameType = openWorkspaces.find(function(w) {\n return w.type == newWorkspace.type;\n });\n if (openWorkspaces.length === 0) {\n updateStoreWithNewWorkspace(newWorkspace);\n } else if (!openWorkspaces[0].canHide && workspaceIndexInOpenWorkspaces !== 0) {\n promptBeforeLaunchingWorkspace(openWorkspaces[0], {\n name: name,\n additionalProps: additionalProps\n });\n } else if (isWorkspaceAlreadyOpen) {\n var openWorkspace = openWorkspaces[workspaceIndexInOpenWorkspaces];\n // Only update the title if it hasn't been set by `setTitle`\n if (openWorkspace.title === getWorkspaceTitle(openWorkspace, openWorkspace.additionalProps)) {\n openWorkspace.title = getWorkspaceTitle(newWorkspace, newWorkspace.additionalProps);\n }\n openWorkspace.additionalProps = newWorkspace.additionalProps;\n var restOfTheWorkspaces = openWorkspaces.filter(function(w) {\n return w.name != name;\n });\n updateStoreWithNewWorkspace(openWorkspaces[workspaceIndexInOpenWorkspaces], restOfTheWorkspaces);\n } else if (openedWorkspaceWithSameType) {\n var restOfTheWorkspaces1 = store.getState().openWorkspaces.filter(function(w) {\n return w.type != newWorkspace.type;\n });\n updateStoreWithNewWorkspace(openedWorkspaceWithSameType, restOfTheWorkspaces1);\n promptBeforeLaunchingWorkspace(openedWorkspaceWithSameType, {\n name: name,\n additionalProps: additionalProps\n });\n } else {\n updateStoreWithNewWorkspace(newWorkspace);\n }\n}\n/**\n * Use this function to navigate to a new page and launch a workspace on that page.\n *\n * @param options.targetUrl: The URL to navigate to. Will be passed to [[navigate]].\n * @param options.contextKey: The context key used by the target page.\n * @param options.workspaceName: The name of the workspace to launch.\n * @param options.additionalProps: Additional props to pass to the workspace component being launched.\n */ function navigateAndLaunchWorkspace(param) {\n var targetUrl = param.targetUrl, contextKey = param.contextKey, workspaceName = param.workspaceName, additionalProps = param.additionalProps;\n changeWorkspaceContext(contextKey);\n launchWorkspace(workspaceName, additionalProps);\n (0,_openmrs_esm_navigation__WEBPACK_IMPORTED_MODULE_2__.navigate)({\n to: targetUrl\n });\n}\nvar promptBeforeClosingFcns = {};\nfunction promptBeforeClosing(workspaceName, testFcn) {\n promptBeforeClosingFcns[workspaceName] = testFcn;\n}\nfunction getPromptBeforeClosingFcn(workspaceName) {\n return promptBeforeClosingFcns[workspaceName];\n}\nfunction cancelPrompt() {\n var store = getWorkspaceStore();\n var state = store.getState();\n store.setState(_object_spread_props(_object_spread({}, state), {\n prompt: null\n }));\n}\nvar defaultOptions = {\n ignoreChanges: false,\n onWorkspaceClose: function() {},\n closeWorkspaceGroup: true\n};\n/**\n * Function to close an opened workspace\n * @param name Workspace registration name\n * @param options Options to close workspace\n */ function closeWorkspace(name) {\n var options = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};\n options = _object_spread({}, defaultOptions, options);\n var store = getWorkspaceStore();\n var updateStoreWithClosedWorkspace = function() {\n var _store_getState_workspaceGroup, _options_onWorkspaceClose;\n var state = store.getState();\n var workspaceToBeClosed = state.openWorkspaces.find(function(w) {\n return w.name === name;\n });\n var newOpenWorkspaces = state.openWorkspaces.filter(function(w) {\n return w.name != name;\n });\n var workspaceGroupName = (_store_getState_workspaceGroup = store.getState().workspaceGroup) === null || _store_getState_workspaceGroup === void 0 ? void 0 : _store_getState_workspaceGroup.name;\n if (workspaceGroupName && options.closeWorkspaceGroup) {\n closeWorkspaceGroup(workspaceGroupName);\n }\n // ensure closed workspace will not prompt\n promptBeforeClosing(name, function() {\n return false;\n });\n store.setState(function(prev) {\n return _object_spread_props(_object_spread({}, prev), {\n prompt: null,\n openWorkspaces: newOpenWorkspaces,\n workspaceWindowState: getUpdatedWorkspaceWindowState(newOpenWorkspaces === null || newOpenWorkspaces === void 0 ? void 0 : newOpenWorkspaces[0])\n });\n });\n options === null || options === void 0 ? void 0 : (_options_onWorkspaceClose = options.onWorkspaceClose) === null || _options_onWorkspaceClose === void 0 ? void 0 : _options_onWorkspaceClose.call(options);\n };\n if (!canCloseWorkspaceWithoutPrompting(name, options === null || options === void 0 ? void 0 : options.ignoreChanges)) {\n var _getWorkspaceRegistration_title;\n var currentName = (_getWorkspaceRegistration_title = (0,_openmrs_esm_extensions__WEBPACK_IMPORTED_MODULE_1__.getWorkspaceRegistration)(name).title) !== null && _getWorkspaceRegistration_title !== void 0 ? _getWorkspaceRegistration_title : name;\n showWorkspacePrompts('closing-workspace', updateStoreWithClosedWorkspace, currentName);\n return false;\n } else {\n updateStoreWithClosedWorkspace();\n return true;\n }\n}\n/**\n * The set of workspaces is specific to a particular page. This function\n * should be used when transitioning to a new page. If the current\n * workspace data is for a different page, the workspace state is cleared.\n *\n * This is called by the workspace components when they mount.\n * @internal\n *\n * @param contextKey An arbitrary key to identify the current page\n */ function changeWorkspaceContext(contextKey) {\n var store = getWorkspaceStore();\n var state = store.getState();\n if (state.context != contextKey) {\n store.setState({\n context: contextKey,\n openWorkspaces: [],\n prompt: null\n });\n }\n}\nvar initialState = {\n context: '',\n openWorkspaces: [],\n prompt: null,\n workspaceWindowState: 'normal',\n workspaceGroup: undefined\n};\nvar workspaceStore = (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_3__.createGlobalStore)('workspace', initialState);\nfunction getWorkspaceStore() {\n return workspaceStore;\n}\nfunction updateWorkspaceWindowState(value) {\n var store = getWorkspaceStore();\n var state = store.getState();\n store.setState(_object_spread_props(_object_spread({}, state), {\n workspaceWindowState: value\n }));\n}\nfunction getUpdatedWorkspaceWindowState(workspaceAtTop) {\n var _workspaceAtTop_preferredWindowSize;\n return (_workspaceAtTop_preferredWindowSize = workspaceAtTop === null || workspaceAtTop === void 0 ? void 0 : workspaceAtTop.preferredWindowSize) !== null && _workspaceAtTop_preferredWindowSize !== void 0 ? _workspaceAtTop_preferredWindowSize : 'normal';\n}\nfunction closeAllWorkspaces() {\n var onClosingWorkspaces = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : function() {}, filter = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : function() {\n return true;\n };\n var store = getWorkspaceStore();\n var canCloseAllWorkspaces = store.getState().openWorkspaces.filter(filter).every(function(param) {\n var name = param.name;\n return canCloseWorkspaceWithoutPrompting(name);\n });\n var updateWorkspaceStore = function() {\n resetWorkspaceStore();\n onClosingWorkspaces === null || onClosingWorkspaces === void 0 ? void 0 : onClosingWorkspaces();\n };\n if (!canCloseAllWorkspaces) {\n showWorkspacePrompts('closing-all-workspaces', updateWorkspaceStore);\n } else {\n updateWorkspaceStore();\n }\n}\nfunction useWorkspaces() {\n var _useStore = (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_5__.useStore)(workspaceStore), workspaceWindowState = _useStore.workspaceWindowState, openWorkspaces = _useStore.openWorkspaces, prompt = _useStore.prompt, workspaceGroup = _useStore.workspaceGroup;\n var memoisedResults = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function() {\n return {\n active: openWorkspaces.length > 0,\n prompt: prompt,\n workspaceWindowState: workspaceWindowState,\n workspaces: openWorkspaces,\n workspaceGroup: workspaceGroup\n };\n }, [\n openWorkspaces,\n workspaceWindowState,\n prompt,\n workspaceGroup\n ]);\n return memoisedResults;\n}\n/**\n * Sets the current prompt according to the prompt type.\n * @param promptType Determines the text and behavior of the prompt\n * @param onConfirmation Function to be called after the user confirms to close the workspace\n * @param workspaceTitle Workspace title to be shown in the prompt\n * @returns\n */ function showWorkspacePrompts(promptType) {\n var onConfirmation = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : function() {}, workspaceTitle = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : '';\n var store = getWorkspaceStore();\n var prompt;\n switch(promptType){\n case 'closing-workspace':\n {\n prompt = {\n title: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('unsavedChangesTitleText', 'Unsaved changes'),\n body: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('unsavedChangesInOpenedWorkspace', \"You may have unsaved changes in the opened workspace. Do you want to discard these changes?\"),\n onConfirm: function() {\n onConfirmation === null || onConfirmation === void 0 ? void 0 : onConfirmation();\n },\n confirmText: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('discard', 'Discard')\n };\n break;\n }\n case 'closing-all-workspaces':\n {\n var workspacesNotClosed = store.getState().openWorkspaces.filter(function(param) {\n var name = param.name;\n return !canCloseWorkspaceWithoutPrompting(name);\n }).map(function(param, indx) {\n var title = param.title;\n return \"\".concat(indx + 1, \". \").concat(title);\n });\n prompt = {\n title: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('closingAllWorkspacesPromptTitle', 'You have unsaved changes'),\n body: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('closingAllWorkspacesPromptBody', 'There may be unsaved changes in the following workspaces. Do you want to discard changes in the following workspaces? {{workspaceNames}}', {\n workspaceNames: workspacesNotClosed.join(',')\n }),\n onConfirm: function() {\n onConfirmation === null || onConfirmation === void 0 ? void 0 : onConfirmation();\n },\n confirmText: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('closeAllOpenedWorkspaces', 'Discard changes in {{count}} workspaces', {\n count: workspacesNotClosed.length\n })\n };\n break;\n }\n case 'closing-workspace-launching-new-workspace':\n {\n prompt = {\n title: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('unsavedChangesTitleText', 'Unsaved changes'),\n body: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('unsavedChangesInWorkspace', 'There may be unsaved changes in \"{{workspaceName}}\". Please save them before opening another workspace.', {\n workspaceName: workspaceTitle\n }),\n onConfirm: function() {\n store.setState(function(state) {\n return _object_spread_props(_object_spread({}, state), {\n prompt: null\n });\n });\n onConfirmation === null || onConfirmation === void 0 ? void 0 : onConfirmation();\n },\n confirmText: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('openAnyway', 'Open anyway')\n };\n break;\n }\n default:\n {\n console.error('Workspace system trying to open unknown prompt type \"'.concat(promptType, '\" in function \"showWorkspacePrompts\"'));\n onConfirmation === null || onConfirmation === void 0 ? void 0 : onConfirmation();\n return;\n }\n }\n store.setState(function(state) {\n return _object_spread_props(_object_spread({}, state), {\n prompt: prompt\n });\n });\n}\nfunction getWorkspaceTitle(workspace, additionalProps) {\n var _additionalProps_workspaceTitle;\n return (_additionalProps_workspaceTitle = additionalProps === null || additionalProps === void 0 ? void 0 : additionalProps['workspaceTitle']) !== null && _additionalProps_workspaceTitle !== void 0 ? _additionalProps_workspaceTitle : workspace.title;\n}\nfunction resetWorkspaceStore() {\n getWorkspaceStore().setState(initialState);\n}\n/**\n * The workspace group store is a store that is specific to the workspace group.\n * If the workspace has its own sidebar, the store will be created.\n * This store can be used to store data that is specific to the workspace group.\n * The store will be same for all the workspaces with same group name.\n *\n * For workspaces launched without a group, the store will be undefined.\n *\n * The store will be cleared when all the workspaces with the store's group name are closed.\n */ function getWorkspaceGroupStore(workspaceGroupName) {\n var additionalProps = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};\n if (!workspaceGroupName || workspaceGroupName === 'default') {\n return undefined;\n }\n var store = (0,_openmrs_esm_state__WEBPACK_IMPORTED_MODULE_3__.getGlobalStore)(workspaceGroupName, {});\n if (additionalProps) {\n store.setState(function(prev) {\n return _object_spread({}, prev, additionalProps);\n });\n }\n return store;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-styleguide/src/workspaces/workspaces.ts","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-styleguide/src/workspaces/workspaces.ts?c15e"],"sourcesContent":["/** @module @category Workspace */\nimport { useMemo, type ReactNode } from 'react';\nimport {\n  getWorkspaceGroupRegistration,\n  getWorkspaceRegistration,\n  type WorkspaceRegistration,\n} from '@openmrs/esm-extensions';\nimport { type WorkspaceWindowState } from '@openmrs/esm-globals';\nimport { navigate } from '@openmrs/esm-navigation';\nimport { getGlobalStore, createGlobalStore } from '@openmrs/esm-state';\nimport { getCoreTranslation } from '@openmrs/esm-translations';\nimport { useStore } from '@openmrs/esm-react-utils';\nimport type { StoreApi } from 'zustand/vanilla';\n\nexport interface CloseWorkspaceOptions {\n  /**\n   * Whether to close the workspace ignoring all the changes present in the workspace.\n   *\n   * If ignoreChanges is true, the user will not be prompted to save changes before closing\n   * even if the `testFcn` passed to `promptBeforeClosing` returns `true`.\n   */\n  ignoreChanges?: boolean;\n  /**\n   * If you want to take an action after the workspace is closed, you can pass your function as\n   * `onWorkspaceClose`. This function will be called only after the workspace is closed, given\n   * that the user might be shown a prompt.\n   * @returns void\n   */\n  onWorkspaceClose?: () => void;\n  /**\n   * Controls whether the workspace group should be closed and store to be\n   * cleared when this workspace is closed.\n   * Defaults to true except when opening a new workspace of the same group.\n   *\n   * @default true\n   */\n  closeWorkspaceGroup?: boolean;\n}\n\n/** The default parameters received by all workspaces */\nexport interface DefaultWorkspaceProps {\n  /**\n   * Call this function to close the workspace. This function will prompt the user\n   * if there are any unsaved changes to workspace.\n   *\n   * You can pass `onWorkspaceClose` function to be called when the workspace is finally\n   * closed, given the user forcefully closes the workspace.\n   */\n  closeWorkspace(closeWorkspaceOptions?: CloseWorkspaceOptions): void;\n  /**\n   * Call this with a no-args function that returns true if the user should be prompted before\n   * this workspace is closed; e.g. if there is unsaved data.\n   */\n  promptBeforeClosing(testFcn: () => boolean): void;\n  /**\n   * Call this function to close the workspace after the form is saved. This function\n   * will directly close the workspace without any prompt\n   */\n  closeWorkspaceWithSavedChanges(closeWorkspaceOptions?: CloseWorkspaceOptions): void;\n  /**\n   * Use this to set the workspace title if it needs to be set dynamically.\n   *\n   * Workspace titles generally are set in the workspace declaration in the routes.json file. They can also\n   * be set by the workspace launcher by passing `workspaceTitle` in the `additionalProps`\n   * parameter of the `launchWorkspace` function. This function is useful when the workspace\n   * title needs to be set dynamically.\n   *\n   * @param title The title to set. If using titleNode, set this to a human-readable string\n   *        which will identify the workspace in notifications and other places.\n   * @param titleNode A React object to put in the workspace header in place of the title. This\n   *        is useful for displaying custom elements in the header. Note that custom header\n   *        elements can also be attached to the workspace header extension slots.\n   */\n  setTitle(title: string, titleNode?: ReactNode): void;\n}\n\nexport interface WorkspaceWindowSize {\n  size: WorkspaceWindowState;\n}\n\nexport interface WorkspaceWindowSizeProviderProps {\n  children?: React.ReactNode;\n}\n\nexport interface WorkspaceWindowSizeContext {\n  windowSize: WorkspaceWindowSize;\n  updateWindowSize?(value: WorkspaceWindowState): any;\n  active: boolean;\n}\n\nexport interface Prompt {\n  title: string;\n  body: string;\n  /** Defaults to \"Confirm\" */\n  confirmText?: string;\n  onConfirm(): void;\n  /** Defaults to \"Cancel\" */\n  cancelText?: string;\n}\n\nexport interface WorkspaceStoreState {\n  context: string | null;\n  openWorkspaces: Array<OpenWorkspace>;\n  prompt: Prompt | null;\n  workspaceWindowState: WorkspaceWindowState;\n  workspaceGroup?: {\n    name: string;\n    members: Array<string>;\n    cleanup?(): void;\n  };\n}\n\nexport interface OpenWorkspace extends WorkspaceRegistration, DefaultWorkspaceProps {\n  additionalProps: object;\n  currentWorkspaceGroup?: string;\n}\n\n/**\n *\n * @param name Name of the workspace\n * @param ignoreChanges If set to true, the \"unsaved changes\" modal will never be shown, even if the `promptBeforeClosing` function returns true. The user will not be prompted before closing.\n * @returns true if the workspace can be closed.\n */\nexport function canCloseWorkspaceWithoutPrompting(name: string, ignoreChanges: boolean = false) {\n  if (ignoreChanges) {\n    return true;\n  }\n  const promptBeforeFn = getPromptBeforeClosingFcn(name);\n  return !promptBeforeFn || !promptBeforeFn();\n}\n\n/**\n * Closes a workspace group and performs cleanup operations.\n *\n * @param groupName - The name of the workspace group to close\n * @param onWorkspaceCloseup - Optional callback function to execute after closing the workspace group\n * @returns void, or exits early if the current workspace group name doesn't match the provided group name\n *\n * @remarks\n * This function performs the following operations:\n * - Validates if the provided group name matches the current workspace group\n * - Closes all workspaces associated with the group\n * - Clears the workspace group store state\n * - Executes cleanup function if defined in the workspace group\n * - Updates the main workspace store to remove the workspace group\n * - Calls the optional closeup callback if provided\n */\nfunction closeWorkspaceGroup(groupName: string, onWorkspaceCloseup?: () => void) {\n  const store = getWorkspaceStore();\n  const currentWorkspaceGroup = store.getState()?.workspaceGroup;\n  const currentGroupName = currentWorkspaceGroup?.name;\n  if (!currentGroupName || groupName !== currentGroupName) {\n    return;\n  }\n  const filter: (workspace: OpenWorkspace) => boolean = currentGroupName\n    ? (workspace) => workspace.currentWorkspaceGroup === currentGroupName\n    : () => true;\n\n  closeAllWorkspaces(() => {\n    // Clearing the workspace group and respective store if the new workspace is not part of the current group, which is handled in the `launchWorkspace` function.\n    const workspaceGroupStore = getWorkspaceGroupStore(groupName);\n    if (workspaceGroupStore) {\n      workspaceGroupStore.setState({}, true);\n      const unsubscribe = workspaceGroupStore.subscribe(() => {});\n      unsubscribe();\n    }\n\n    if (typeof currentWorkspaceGroup?.cleanup === 'function') {\n      currentWorkspaceGroup.cleanup();\n    }\n\n    store.setState((prev) => ({\n      ...prev,\n      workspaceGroup: undefined,\n    }));\n\n    if (typeof onWorkspaceCloseup === 'function') {\n      onWorkspaceCloseup();\n    }\n  }, filter);\n}\n\ninterface LaunchWorkspaceGroupArg {\n  state: Record<string | symbol | number, any>;\n  onWorkspaceGroupLaunch?(): void;\n  workspaceGroupCleanup?(): void;\n  workspaceToLaunch?: {\n    name: string;\n    additionalProps?: Record<string | symbol | number, any>;\n  };\n}\n\n/**\n * Launches a workspace group with the specified name and configuration.\n * If there are any open workspaces, it will first close them before launching the new workspace group.\n *\n * @param groupName - The name of the workspace group to launch\n * @param args - Configuration object for launching the workspace group\n * @param args.state - The initial state for the workspace group\n * @param args.onWorkspaceGroupLaunch - Optional callback function to be executed after the workspace group is launched\n * @param args.workspaceGroupCleanup - Optional cleanup function to be executed when the workspace group is closed\n *\n * @example\n * launchWorkspaceGroup(\"myGroup\", {\n *   state: initialState,\n *   onWorkspaceGroupLaunch: () => console.log(\"Workspace group launched\"),\n *   workspaceGroupCleanup: () => console.log(\"Cleaning up workspace group\")\n * });\n */\nexport function launchWorkspaceGroup(groupName: string, args: LaunchWorkspaceGroupArg) {\n  const workspaceGroupRegistration = getWorkspaceGroupRegistration(groupName);\n  const { state, onWorkspaceGroupLaunch, workspaceGroupCleanup, workspaceToLaunch } = args;\n  const store = getWorkspaceStore();\n  if (store.getState().openWorkspaces.length) {\n    const workspaceGroup = store.getState().workspaceGroup;\n    if (workspaceGroup) {\n      closeWorkspaceGroup(workspaceGroup?.name, () => {\n        launchWorkspaceGroup(groupName, args);\n      });\n    } else {\n      closeAllWorkspaces(() => {\n        launchWorkspaceGroup(groupName, args);\n      });\n    }\n  } else {\n    store.setState((prev) => ({\n      ...prev,\n      workspaceGroup: {\n        name: groupName,\n        members: workspaceGroupRegistration.members,\n        cleanup: workspaceGroupCleanup,\n      },\n    }));\n    getWorkspaceGroupStore(groupName, state);\n    onWorkspaceGroupLaunch?.();\n    if (workspaceToLaunch) {\n      launchWorkspace(workspaceToLaunch.name, workspaceToLaunch.additionalProps ?? {});\n    }\n  }\n}\n\nfunction promptBeforeLaunchingWorkspace(\n  workspace: OpenWorkspace,\n  newWorkspaceDetails: { name: string; additionalProps?: object },\n) {\n  const { name, additionalProps } = newWorkspaceDetails;\n  const newWorkspaceRegistration = getWorkspaceRegistration(name);\n\n  const proceed = () => {\n    closeWorkspace(workspace.name, {\n      ignoreChanges: true,\n      // Calling the launchWorkspace again, since one of the `if` case\n      // might resolve, but we need to check all the cases before launching the form.\n      onWorkspaceClose: () => launchWorkspace(name, additionalProps),\n      // If the new workspace is of the same sidebar group, then we don't need to clear the workspace group store.\n      closeWorkspaceGroup: false,\n    });\n  };\n\n  if (!canCloseWorkspaceWithoutPrompting(workspace.name)) {\n    showWorkspacePrompts('closing-workspace-launching-new-workspace', proceed, workspace.title ?? workspace.name);\n  } else {\n    proceed();\n  }\n}\n\n/**\n * This launches a workspace by its name. The workspace must have been registered.\n * Workspaces should be registered in the `routes.json` file.\n *\n * For the workspace to appear, there must be either a `<WorkspaceOverlay />` or\n * a `<WorkspaceWindow />` component rendered.\n *\n * The behavior of this function is as follows:\n *\n * - If no workspaces are open, or if no other workspaces with the same type are open,\n *   it will be opened and focused.\n * - If a workspace with the same name is already open, it will be displayed/focused,\n *   if it was not already.\n * - If a workspace is launched and a workspace which cannot be hidden is already open,\n *  a confirmation modal will pop up warning about closing the currently open workspace.\n * - If another workspace with the same type is open, the workspace will be brought to\n *   the front and then a confirmation modal will pop up warning about closing the opened\n *   workspace\n *\n * Note that this function just manipulates the workspace store. The UI logic is handled\n * by the components that display workspaces.\n *\n * Additional props can be passed to the workspace component being launched. Passing a\n * prop named `workspaceTitle` will override the title of the workspace.\n *\n * @param name The name of the workspace to launch\n * @param additionalProps Props to pass to the workspace component being launched. Passing\n *          a prop named `workspaceTitle` will override the title of the workspace.\n */\nexport function launchWorkspace<\n  T extends DefaultWorkspaceProps | object = DefaultWorkspaceProps & { [key: string]: any },\n>(name: string, additionalProps?: Omit<T, keyof DefaultWorkspaceProps> & { workspaceTitle?: string }) {\n  const store = getWorkspaceStore();\n  const workspace = getWorkspaceRegistration(name);\n  const currentWorkspaceGroup = store.getState().workspaceGroup;\n\n  if (currentWorkspaceGroup && !currentWorkspaceGroup.members?.includes(name)) {\n    closeWorkspaceGroup(currentWorkspaceGroup.name, () => {\n      launchWorkspace(name, additionalProps);\n    });\n    return;\n  }\n  const currentGroupName = store.getState().workspaceGroup?.name;\n  const newWorkspace: OpenWorkspace = {\n    ...workspace,\n    title: getWorkspaceTitle(workspace, additionalProps),\n    closeWorkspace: (options: CloseWorkspaceOptions = {}) => closeWorkspace(name, options),\n    closeWorkspaceWithSavedChanges: (options: CloseWorkspaceOptions) =>\n      closeWorkspace(name, { ignoreChanges: true, ...options }),\n    promptBeforeClosing: (testFcn) => promptBeforeClosing(name, testFcn),\n    setTitle: (title: string, titleNode: ReactNode) => {\n      newWorkspace.title = title;\n      newWorkspace.titleNode = titleNode;\n      store.setState((state) => {\n        const openWorkspaces = state.openWorkspaces.map((w) => (w.name === name ? newWorkspace : w));\n        return {\n          ...state,\n          openWorkspaces,\n        };\n      });\n    },\n    currentWorkspaceGroup: currentGroupName,\n    additionalProps: additionalProps ?? {},\n  };\n\n  if (currentGroupName) {\n    getWorkspaceGroupStore(currentGroupName, additionalProps);\n  }\n  function updateStoreWithNewWorkspace(workspaceToBeAdded: OpenWorkspace, restOfTheWorkspaces?: Array<OpenWorkspace>) {\n    store.setState((state) => {\n      const openWorkspaces = [workspaceToBeAdded, ...(restOfTheWorkspaces ?? state.openWorkspaces)];\n      let workspaceWindowState = getUpdatedWorkspaceWindowState(workspaceToBeAdded);\n\n      return {\n        ...state,\n        openWorkspaces,\n        workspaceWindowState,\n      };\n    });\n  }\n\n  const openWorkspaces = store.getState().openWorkspaces;\n  const workspaceIndexInOpenWorkspaces = openWorkspaces.findIndex((w) => w.name === name);\n  const isWorkspaceAlreadyOpen = workspaceIndexInOpenWorkspaces >= 0;\n  const openedWorkspaceWithSameType = openWorkspaces.find((w) => w.type == newWorkspace.type);\n\n  if (openWorkspaces.length === 0) {\n    updateStoreWithNewWorkspace(newWorkspace);\n  } else if (!openWorkspaces[0].canHide && workspaceIndexInOpenWorkspaces !== 0) {\n    promptBeforeLaunchingWorkspace(openWorkspaces[0], {\n      name,\n      additionalProps,\n    });\n  } else if (isWorkspaceAlreadyOpen) {\n    const openWorkspace = openWorkspaces[workspaceIndexInOpenWorkspaces];\n    // Only update the title if it hasn't been set by `setTitle`\n    if (openWorkspace.title === getWorkspaceTitle(openWorkspace, openWorkspace.additionalProps)) {\n      openWorkspace.title = getWorkspaceTitle(newWorkspace, newWorkspace.additionalProps);\n    }\n    openWorkspace.additionalProps = newWorkspace.additionalProps;\n    const restOfTheWorkspaces = openWorkspaces.filter((w) => w.name != name);\n    updateStoreWithNewWorkspace(openWorkspaces[workspaceIndexInOpenWorkspaces], restOfTheWorkspaces);\n  } else if (openedWorkspaceWithSameType) {\n    const restOfTheWorkspaces = store.getState().openWorkspaces.filter((w) => w.type != newWorkspace.type);\n    updateStoreWithNewWorkspace(openedWorkspaceWithSameType, restOfTheWorkspaces);\n    promptBeforeLaunchingWorkspace(openedWorkspaceWithSameType, {\n      name,\n      additionalProps,\n    });\n  } else {\n    updateStoreWithNewWorkspace(newWorkspace);\n  }\n}\n\n/**\n * Use this function to navigate to a new page and launch a workspace on that page.\n *\n * @param options.targetUrl: The URL to navigate to. Will be passed to [[navigate]].\n * @param options.contextKey: The context key used by the target page.\n * @param options.workspaceName: The name of the workspace to launch.\n * @param options.additionalProps: Additional props to pass to the workspace component being launched.\n */\nexport function navigateAndLaunchWorkspace({\n  targetUrl,\n  contextKey,\n  workspaceName,\n  additionalProps,\n}: {\n  targetUrl: string;\n  contextKey: string;\n  workspaceName: string;\n  additionalProps?: object;\n}) {\n  changeWorkspaceContext(contextKey);\n  launchWorkspace(workspaceName, additionalProps);\n  navigate({ to: targetUrl });\n}\n\nconst promptBeforeClosingFcns = {};\n\nexport function promptBeforeClosing(workspaceName: string, testFcn: () => boolean) {\n  promptBeforeClosingFcns[workspaceName] = testFcn;\n}\n\nexport function getPromptBeforeClosingFcn(workspaceName: string) {\n  return promptBeforeClosingFcns[workspaceName];\n}\n\nexport function cancelPrompt() {\n  const store = getWorkspaceStore();\n  const state = store.getState();\n  store.setState({ ...state, prompt: null });\n}\n\nconst defaultOptions: CloseWorkspaceOptions = {\n  ignoreChanges: false,\n  onWorkspaceClose: () => {},\n  closeWorkspaceGroup: true,\n};\n\n/**\n * Function to close an opened workspace\n * @param name Workspace registration name\n * @param options Options to close workspace\n */\nexport function closeWorkspace(name: string, options: CloseWorkspaceOptions = {}): boolean {\n  options = { ...defaultOptions, ...options };\n  const store = getWorkspaceStore();\n\n  const updateStoreWithClosedWorkspace = () => {\n    const state = store.getState();\n    const workspaceToBeClosed = state.openWorkspaces.find((w) => w.name === name);\n    const newOpenWorkspaces = state.openWorkspaces.filter((w) => w.name != name);\n\n    const workspaceGroupName = store.getState().workspaceGroup?.name;\n\n    if (workspaceGroupName && options.closeWorkspaceGroup) {\n      closeWorkspaceGroup(workspaceGroupName);\n    }\n\n    // ensure closed workspace will not prompt\n    promptBeforeClosing(name, () => false);\n    store.setState((prev) => ({\n      ...prev,\n      prompt: null,\n      openWorkspaces: newOpenWorkspaces,\n      workspaceWindowState: getUpdatedWorkspaceWindowState(newOpenWorkspaces?.[0]),\n    }));\n\n    options?.onWorkspaceClose?.();\n  };\n\n  if (!canCloseWorkspaceWithoutPrompting(name, options?.ignoreChanges)) {\n    const currentName = getWorkspaceRegistration(name).title ?? name;\n    showWorkspacePrompts('closing-workspace', updateStoreWithClosedWorkspace, currentName);\n    return false;\n  } else {\n    updateStoreWithClosedWorkspace();\n    return true;\n  }\n}\n\n/**\n * The set of workspaces is specific to a particular page. This function\n * should be used when transitioning to a new page. If the current\n * workspace data is for a different page, the workspace state is cleared.\n *\n * This is called by the workspace components when they mount.\n * @internal\n *\n * @param contextKey An arbitrary key to identify the current page\n */\nexport function changeWorkspaceContext(contextKey: string | null) {\n  const store = getWorkspaceStore();\n  const state = store.getState();\n  if (state.context != contextKey) {\n    store.setState({ context: contextKey, openWorkspaces: [], prompt: null });\n  }\n}\n\nconst initialState: WorkspaceStoreState = {\n  context: '',\n  openWorkspaces: [],\n  prompt: null,\n  workspaceWindowState: 'normal',\n  workspaceGroup: undefined,\n};\n\nexport const workspaceStore = createGlobalStore('workspace', initialState);\n\nexport function getWorkspaceStore() {\n  return workspaceStore;\n}\n\nexport function updateWorkspaceWindowState(value: WorkspaceWindowState) {\n  const store = getWorkspaceStore();\n  const state = store.getState();\n  store.setState({ ...state, workspaceWindowState: value });\n}\n\nfunction getUpdatedWorkspaceWindowState(workspaceAtTop: OpenWorkspace) {\n  return workspaceAtTop?.preferredWindowSize ?? 'normal';\n}\nexport function closeAllWorkspaces(\n  onClosingWorkspaces: () => void = () => {},\n  filter: (workspace: OpenWorkspace) => boolean = () => true,\n) {\n  const store = getWorkspaceStore();\n\n  const canCloseAllWorkspaces = store\n    .getState()\n    .openWorkspaces.filter(filter)\n    .every(({ name }) => {\n      return canCloseWorkspaceWithoutPrompting(name);\n    });\n\n  const updateWorkspaceStore = () => {\n    resetWorkspaceStore();\n    onClosingWorkspaces?.();\n  };\n\n  if (!canCloseAllWorkspaces) {\n    showWorkspacePrompts('closing-all-workspaces', updateWorkspaceStore);\n  } else {\n    updateWorkspaceStore();\n  }\n}\n\nexport interface WorkspacesInfo {\n  active: boolean;\n  prompt: Prompt | null;\n  workspaceWindowState: WorkspaceWindowState;\n  workspaces: Array<OpenWorkspace>;\n  workspaceGroup?: WorkspaceStoreState['workspaceGroup'];\n}\n\nexport function useWorkspaces(): WorkspacesInfo {\n  const { workspaceWindowState, openWorkspaces, prompt, workspaceGroup } = useStore(workspaceStore);\n  const memoisedResults: WorkspacesInfo = useMemo(() => {\n    return {\n      active: openWorkspaces.length > 0,\n      prompt,\n      workspaceWindowState,\n      workspaces: openWorkspaces,\n      workspaceGroup,\n    };\n  }, [openWorkspaces, workspaceWindowState, prompt, workspaceGroup]);\n  return memoisedResults;\n}\n\ntype PromptType = 'closing-workspace' | 'closing-all-workspaces' | 'closing-workspace-launching-new-workspace';\n\n/**\n * Sets the current prompt according to the prompt type.\n * @param promptType Determines the text and behavior of the prompt\n * @param onConfirmation Function to be called after the user confirms to close the workspace\n * @param workspaceTitle Workspace title to be shown in the prompt\n * @returns\n */\nexport function showWorkspacePrompts(\n  promptType: PromptType,\n  onConfirmation: () => void = () => {},\n  workspaceTitle: string = '',\n) {\n  const store = getWorkspaceStore();\n\n  let prompt: Prompt;\n  switch (promptType) {\n    case 'closing-workspace': {\n      prompt = {\n        title: getCoreTranslation('unsavedChangesTitleText', 'Unsaved changes'),\n        body: getCoreTranslation(\n          'unsavedChangesInOpenedWorkspace',\n          `You may have unsaved changes in the opened workspace. Do you want to discard these changes?`,\n        ),\n        onConfirm: () => {\n          onConfirmation?.();\n        },\n        confirmText: getCoreTranslation('discard', 'Discard'),\n      };\n      break;\n    }\n\n    case 'closing-all-workspaces': {\n      const workspacesNotClosed = store\n        .getState()\n        .openWorkspaces.filter(({ name }) => !canCloseWorkspaceWithoutPrompting(name))\n        .map(({ title }, indx) => `${indx + 1}. ${title}`);\n\n      prompt = {\n        title: getCoreTranslation('closingAllWorkspacesPromptTitle', 'You have unsaved changes'),\n        body: getCoreTranslation(\n          'closingAllWorkspacesPromptBody',\n          'There may be unsaved changes in the following workspaces. Do you want to discard changes in the following workspaces? {{workspaceNames}}',\n          {\n            workspaceNames: workspacesNotClosed.join(','),\n          },\n        ),\n        onConfirm: () => {\n          onConfirmation?.();\n        },\n        confirmText: getCoreTranslation('closeAllOpenedWorkspaces', 'Discard changes in {{count}} workspaces', {\n          count: workspacesNotClosed.length,\n        }),\n      };\n      break;\n    }\n    case 'closing-workspace-launching-new-workspace': {\n      prompt = {\n        title: getCoreTranslation('unsavedChangesTitleText', 'Unsaved changes'),\n        body: getCoreTranslation(\n          'unsavedChangesInWorkspace',\n          'There may be unsaved changes in \"{{workspaceName}}\". Please save them before opening another workspace.',\n          { workspaceName: workspaceTitle },\n        ),\n        onConfirm: () => {\n          store.setState((state) => ({\n            ...state,\n            prompt: null,\n          }));\n          onConfirmation?.();\n        },\n        confirmText: getCoreTranslation('openAnyway', 'Open anyway'),\n      };\n      break;\n    }\n    default: {\n      console.error(\n        `Workspace system trying to open unknown prompt type \"${promptType}\" in function \"showWorkspacePrompts\"`,\n      );\n      onConfirmation?.();\n      return;\n    }\n  }\n  store.setState((state) => ({ ...state, prompt }));\n}\n\nfunction getWorkspaceTitle(workspace: WorkspaceRegistration, additionalProps?: object) {\n  return additionalProps?.['workspaceTitle'] ?? workspace.title;\n}\n\nexport function resetWorkspaceStore() {\n  getWorkspaceStore().setState(initialState);\n}\n\n/**\n * The workspace group store is a store that is specific to the workspace group.\n * If the workspace has its own sidebar, the store will be created.\n * This store can be used to store data that is specific to the workspace group.\n * The store will be same for all the workspaces with same group name.\n *\n * For workspaces launched without a group, the store will be undefined.\n *\n * The store will be cleared when all the workspaces with the store's group name are closed.\n */\nexport function getWorkspaceGroupStore(\n  workspaceGroupName: string | undefined,\n  additionalProps: object = {},\n): StoreApi<object> | undefined {\n  if (!workspaceGroupName || workspaceGroupName === 'default') {\n    return undefined;\n  }\n  const store = getGlobalStore<object>(workspaceGroupName, {});\n  if (additionalProps) {\n    store.setState((prev) => ({\n      ...prev,\n      ...additionalProps,\n    }));\n  }\n  return store;\n}\n"],"names":["useMemo","getWorkspaceGroupRegistration","getWorkspaceRegistration","navigate","getGlobalStore","createGlobalStore","getCoreTranslation","useStore","canCloseWorkspaceWithoutPrompting","name","ignoreChanges","promptBeforeFn","getPromptBeforeClosingFcn","closeWorkspaceGroup","groupName","onWorkspaceCloseup","store","getWorkspaceStore","currentWorkspaceGroup","getState","workspaceGroup","currentGroupName","filter","workspace","closeAllWorkspaces","workspaceGroupStore","getWorkspaceGroupStore","setState","unsubscribe","subscribe","cleanup","prev","undefined","launchWorkspaceGroup","args","workspaceGroupRegistration","state","onWorkspaceGroupLaunch","workspaceGroupCleanup","workspaceToLaunch","openWorkspaces","length","members","launchWorkspace","additionalProps","promptBeforeLaunchingWorkspace","newWorkspaceDetails","newWorkspaceRegistration","proceed","closeWorkspace","onWorkspaceClose","showWorkspacePrompts","title","includes","newWorkspace","getWorkspaceTitle","options","closeWorkspaceWithSavedChanges","promptBeforeClosing","testFcn","setTitle","titleNode","map","w","updateStoreWithNewWorkspace","workspaceToBeAdded","restOfTheWorkspaces","workspaceWindowState","getUpdatedWorkspaceWindowState","workspaceIndexInOpenWorkspaces","findIndex","isWorkspaceAlreadyOpen","openedWorkspaceWithSameType","find","type","canHide","openWorkspace","navigateAndLaunchWorkspace","targetUrl","contextKey","workspaceName","changeWorkspaceContext","to","promptBeforeClosingFcns","cancelPrompt","prompt","defaultOptions","updateStoreWithClosedWorkspace","workspaceToBeClosed","newOpenWorkspaces","workspaceGroupName","currentName","context","initialState","workspaceStore","updateWorkspaceWindowState","value","workspaceAtTop","preferredWindowSize","onClosingWorkspaces","canCloseAllWorkspaces","every","updateWorkspaceStore","resetWorkspaceStore","useWorkspaces","memoisedResults","active","workspaces","promptType","onConfirmation","workspaceTitle","body","onConfirm","confirmText","workspacesNotClosed","indx","workspaceNames","join","count","console","error"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/src/workspaces/workspaces.ts\n");
2149
2149
 
2150
2150
  /***/ }),
2151
2151