@openmrs/esm-app-shell 8.0.1-pre.3331 → 8.0.1-pre.3349

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 (171) hide show
  1. package/.turbo/turbo-build.log +11 -13
  2. package/dist/{b12e3025071aa50e.js.map → 18821cd9b4faaa77.js.map} +1 -1
  3. package/dist/{546c6bfce53cd9de.js → 86ad42432ebd7435.js} +1 -1
  4. package/dist/a48ac555f9c8f4b1.js +1 -0
  5. package/dist/{de6eff539629b20c.js.map → dba4329a5f923cfd.js.map} +1 -1
  6. package/dist/index.html +1 -1
  7. package/dist/{openmrs.68b79c078fc8efc7.js → openmrs.fc321a65c26e79f8.js} +1 -1
  8. package/dist/{openmrs.68b79c078fc8efc7.js.map → openmrs.fc321a65c26e79f8.js.map} +1 -1
  9. package/dist/service-worker.js +1 -1
  10. package/lib/3e16b91f3a85e08c.js +22 -0
  11. package/lib/{b0c4fd2f830ff03f.js → 7b7cacfbf9fb1472.js} +2 -2
  12. package/lib/{e7716cbca8f87729.js → d8be2a4a8de86aa7.js} +1 -1
  13. package/lib/esm-devtools-app/main.js +1 -1
  14. package/lib/esm-devtools-app/openmrs-esm-devtools-app.js +1 -1
  15. package/lib/esm-devtools-app/openmrs-esm-devtools-app.js.buildmanifest.json +3 -3
  16. package/lib/esm-devtools-app/routes.json +1 -1
  17. package/lib/esm-help-menu-app/108.js +1 -0
  18. package/lib/esm-help-menu-app/108.js.map +1 -0
  19. package/lib/esm-help-menu-app/11.js +1 -0
  20. package/lib/esm-help-menu-app/11.js.map +1 -0
  21. package/lib/esm-help-menu-app/248.js +1 -0
  22. package/lib/esm-help-menu-app/248.js.map +1 -0
  23. package/lib/esm-help-menu-app/322.js +1 -0
  24. package/lib/esm-help-menu-app/322.js.map +1 -0
  25. package/lib/esm-help-menu-app/326.js +2 -0
  26. package/lib/esm-help-menu-app/326.js.map +1 -0
  27. package/lib/esm-help-menu-app/380.js +1 -0
  28. package/lib/esm-help-menu-app/380.js.map +1 -0
  29. package/lib/esm-help-menu-app/555.js +1 -0
  30. package/lib/esm-help-menu-app/555.js.map +1 -0
  31. package/lib/esm-help-menu-app/556.js +2 -0
  32. package/lib/{esm-offline-tools-app/9346.js.LICENSE.txt → esm-help-menu-app/556.js.LICENSE.txt} +10 -0
  33. package/lib/esm-help-menu-app/556.js.map +1 -0
  34. package/lib/esm-help-menu-app/623.js +2 -0
  35. package/lib/esm-help-menu-app/623.js.map +1 -0
  36. package/lib/esm-help-menu-app/660.js +2 -0
  37. package/lib/esm-help-menu-app/660.js.map +1 -0
  38. package/lib/esm-help-menu-app/770.js +2 -0
  39. package/lib/esm-help-menu-app/770.js.map +1 -0
  40. package/lib/esm-help-menu-app/802.js +1 -0
  41. package/lib/esm-help-menu-app/802.js.map +1 -0
  42. package/lib/esm-help-menu-app/90.js +1 -0
  43. package/lib/esm-help-menu-app/90.js.map +1 -0
  44. package/lib/esm-help-menu-app/932.js +2 -0
  45. package/lib/esm-help-menu-app/932.js.map +1 -0
  46. package/lib/esm-help-menu-app/main.js +1 -0
  47. package/lib/esm-help-menu-app/main.js.map +1 -0
  48. package/lib/esm-help-menu-app/openmrs-esm-help-menu-app.js +1 -0
  49. package/lib/esm-help-menu-app/openmrs-esm-help-menu-app.js.buildmanifest.json +464 -0
  50. package/lib/esm-help-menu-app/openmrs-esm-help-menu-app.js.map +1 -0
  51. package/lib/esm-help-menu-app/routes.json +1 -0
  52. package/lib/esm-implementer-tools-app/9538.js +1 -1
  53. package/lib/esm-implementer-tools-app/main.js +1 -1
  54. package/lib/esm-implementer-tools-app/openmrs-esm-implementer-tools-app.js +1 -1
  55. package/lib/esm-implementer-tools-app/openmrs-esm-implementer-tools-app.js.buildmanifest.json +6 -6
  56. package/lib/esm-implementer-tools-app/routes.json +1 -1
  57. package/lib/esm-login-app/9182.js +1 -1
  58. package/lib/esm-login-app/main.js +1 -1
  59. package/lib/esm-login-app/main.js.map +1 -1
  60. package/lib/esm-login-app/openmrs-esm-login-app.js +1 -1
  61. package/lib/esm-login-app/openmrs-esm-login-app.js.buildmanifest.json +6 -6
  62. package/lib/esm-login-app/openmrs-esm-login-app.js.map +1 -1
  63. package/lib/esm-login-app/routes.json +1 -1
  64. package/lib/esm-primary-navigation-app/9538.js +1 -1
  65. package/lib/esm-primary-navigation-app/main.js +1 -1
  66. package/lib/esm-primary-navigation-app/openmrs-esm-primary-navigation-app.js +1 -1
  67. package/lib/esm-primary-navigation-app/openmrs-esm-primary-navigation-app.js.buildmanifest.json +6 -6
  68. package/lib/esm-primary-navigation-app/routes.json +1 -1
  69. package/lib/index.html +2 -2
  70. package/lib/openmrs.js +6 -6
  71. package/lib/service-worker.js +1 -1
  72. package/package.json +3 -3
  73. package/dist/5e8aea2775453e88.js +0 -1
  74. package/lib/a45dcb6da2ee08e1.js +0 -22
  75. package/lib/esm-offline-tools-app/1119.js +0 -1
  76. package/lib/esm-offline-tools-app/1185.js +0 -1
  77. package/lib/esm-offline-tools-app/1185.js.map +0 -1
  78. package/lib/esm-offline-tools-app/1197.js +0 -1
  79. package/lib/esm-offline-tools-app/1405.js +0 -1
  80. package/lib/esm-offline-tools-app/1405.js.map +0 -1
  81. package/lib/esm-offline-tools-app/1584c81d564cacde.svg +0 -8
  82. package/lib/esm-offline-tools-app/2146.js +0 -1
  83. package/lib/esm-offline-tools-app/2500.js +0 -1
  84. package/lib/esm-offline-tools-app/2500.js.map +0 -1
  85. package/lib/esm-offline-tools-app/2690.js +0 -1
  86. package/lib/esm-offline-tools-app/3099.js +0 -1
  87. package/lib/esm-offline-tools-app/3389.js +0 -2
  88. package/lib/esm-offline-tools-app/3389.js.map +0 -1
  89. package/lib/esm-offline-tools-app/3584.js +0 -1
  90. package/lib/esm-offline-tools-app/3709.js +0 -1
  91. package/lib/esm-offline-tools-app/3709.js.map +0 -1
  92. package/lib/esm-offline-tools-app/4055.js +0 -1
  93. package/lib/esm-offline-tools-app/4132.js +0 -1
  94. package/lib/esm-offline-tools-app/4300.js +0 -1
  95. package/lib/esm-offline-tools-app/4335.js +0 -1
  96. package/lib/esm-offline-tools-app/4618.js +0 -1
  97. package/lib/esm-offline-tools-app/4652.js +0 -1
  98. package/lib/esm-offline-tools-app/4944.js +0 -1
  99. package/lib/esm-offline-tools-app/5173.js +0 -1
  100. package/lib/esm-offline-tools-app/5241.js +0 -1
  101. package/lib/esm-offline-tools-app/5442.js +0 -1
  102. package/lib/esm-offline-tools-app/5623.js +0 -2
  103. package/lib/esm-offline-tools-app/5623.js.map +0 -1
  104. package/lib/esm-offline-tools-app/5661.js +0 -1
  105. package/lib/esm-offline-tools-app/5725.js +0 -2
  106. package/lib/esm-offline-tools-app/5725.js.LICENSE.txt +0 -9
  107. package/lib/esm-offline-tools-app/5725.js.map +0 -1
  108. package/lib/esm-offline-tools-app/5770.js +0 -2
  109. package/lib/esm-offline-tools-app/5770.js.map +0 -1
  110. package/lib/esm-offline-tools-app/6022.js +0 -1
  111. package/lib/esm-offline-tools-app/6090.js +0 -2
  112. package/lib/esm-offline-tools-app/6090.js.LICENSE.txt +0 -9
  113. package/lib/esm-offline-tools-app/6090.js.map +0 -1
  114. package/lib/esm-offline-tools-app/6224.js +0 -1
  115. package/lib/esm-offline-tools-app/6224.js.map +0 -1
  116. package/lib/esm-offline-tools-app/6248.js +0 -1
  117. package/lib/esm-offline-tools-app/6248.js.map +0 -1
  118. package/lib/esm-offline-tools-app/6252.js +0 -1
  119. package/lib/esm-offline-tools-app/6252.js.map +0 -1
  120. package/lib/esm-offline-tools-app/6269.js +0 -2
  121. package/lib/esm-offline-tools-app/6269.js.LICENSE.txt +0 -9
  122. package/lib/esm-offline-tools-app/6269.js.map +0 -1
  123. package/lib/esm-offline-tools-app/6326.js +0 -2
  124. package/lib/esm-offline-tools-app/6326.js.map +0 -1
  125. package/lib/esm-offline-tools-app/6408.js +0 -2
  126. package/lib/esm-offline-tools-app/6408.js.LICENSE.txt +0 -32
  127. package/lib/esm-offline-tools-app/6408.js.map +0 -1
  128. package/lib/esm-offline-tools-app/6468.js +0 -1
  129. package/lib/esm-offline-tools-app/6679.js +0 -1
  130. package/lib/esm-offline-tools-app/6840.js +0 -1
  131. package/lib/esm-offline-tools-app/6859.js +0 -1
  132. package/lib/esm-offline-tools-app/7097.js +0 -1
  133. package/lib/esm-offline-tools-app/7159.js +0 -1
  134. package/lib/esm-offline-tools-app/723.js +0 -1
  135. package/lib/esm-offline-tools-app/7380.js +0 -1
  136. package/lib/esm-offline-tools-app/7380.js.map +0 -1
  137. package/lib/esm-offline-tools-app/7617.js +0 -1
  138. package/lib/esm-offline-tools-app/795.js +0 -1
  139. package/lib/esm-offline-tools-app/8163.js +0 -1
  140. package/lib/esm-offline-tools-app/8349.js +0 -1
  141. package/lib/esm-offline-tools-app/8618.js +0 -1
  142. package/lib/esm-offline-tools-app/8650.js +0 -1
  143. package/lib/esm-offline-tools-app/8650.js.map +0 -1
  144. package/lib/esm-offline-tools-app/890.js +0 -1
  145. package/lib/esm-offline-tools-app/9214.js +0 -1
  146. package/lib/esm-offline-tools-app/9346.js +0 -2
  147. package/lib/esm-offline-tools-app/9346.js.map +0 -1
  148. package/lib/esm-offline-tools-app/9538.js +0 -1
  149. package/lib/esm-offline-tools-app/9569.js +0 -1
  150. package/lib/esm-offline-tools-app/9825.js +0 -2
  151. package/lib/esm-offline-tools-app/9825.js.map +0 -1
  152. package/lib/esm-offline-tools-app/986.js +0 -1
  153. package/lib/esm-offline-tools-app/9879.js +0 -1
  154. package/lib/esm-offline-tools-app/9895.js +0 -1
  155. package/lib/esm-offline-tools-app/9900.js +0 -1
  156. package/lib/esm-offline-tools-app/9913.js +0 -1
  157. package/lib/esm-offline-tools-app/main.js +0 -2
  158. package/lib/esm-offline-tools-app/main.js.LICENSE.txt +0 -15
  159. package/lib/esm-offline-tools-app/main.js.map +0 -1
  160. package/lib/esm-offline-tools-app/openmrs-esm-offline-tools-app.js +0 -1
  161. package/lib/esm-offline-tools-app/openmrs-esm-offline-tools-app.js.buildmanifest.json +0 -1518
  162. package/lib/esm-offline-tools-app/openmrs-esm-offline-tools-app.js.map +0 -1
  163. package/lib/esm-offline-tools-app/routes.json +0 -1
  164. /package/dist/{b12e3025071aa50e.js → 18821cd9b4faaa77.js} +0 -0
  165. /package/dist/{de6eff539629b20c.js → dba4329a5f923cfd.js} +0 -0
  166. /package/lib/{4e8f2e9f00a52bcc.js → 6976c18a7cf00d61.js} +0 -0
  167. /package/lib/{esm-offline-tools-app/6326.js.LICENSE.txt → esm-help-menu-app/326.js.LICENSE.txt} +0 -0
  168. /package/lib/{esm-offline-tools-app/5623.js.LICENSE.txt → esm-help-menu-app/623.js.LICENSE.txt} +0 -0
  169. /package/lib/{esm-offline-tools-app/5770.js.LICENSE.txt → esm-help-menu-app/660.js.LICENSE.txt} +0 -0
  170. /package/lib/{esm-offline-tools-app/3389.js.LICENSE.txt → esm-help-menu-app/770.js.LICENSE.txt} +0 -0
  171. /package/lib/{esm-offline-tools-app/9825.js.LICENSE.txt → esm-help-menu-app/932.js.LICENSE.txt} +0 -0
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ /*
3
+ * ATTENTION: An "eval-source-map" devtool has been used.
4
+ * This devtool is neither made for production nor for readable output files.
5
+ * It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
6
+ * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
7
+ * or disable the default devtool with "devtool: false".
8
+ * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
9
+ */
10
+ (self["webpackChunk_openmrs_esm_app_shell"] = self["webpackChunk_openmrs_esm_app_shell"] || []).push([["framework_esm-translations_translations_en_json"],{
11
+
12
+ /***/ "../../framework/esm-translations/translations/en.json":
13
+ /*!*************************************************************!*\
14
+ !*** ../../framework/esm-translations/translations/en.json ***!
15
+ \*************************************************************/
16
+ /***/ ((module) => {
17
+
18
+ module.exports = /*#__PURE__*/JSON.parse('{"actions":"Actions","address":"Address","address1":"Address line 1","address2":"Address line 2","address3":"Address line 3","address4":"Address line 4","address5":"Address line 5","address6":"Address line 6","age":"Age","cancel":"Cancel","change":"Change","city":"City","cityVillage":"City","Clinic":"Clinic","close":"Close","closeAllOpenedWorkspaces":"Discard changes in {{count}} workspaces","closingAllWorkspacesPromptBody":"There may be unsaved changes in the following workspaces. Do you want to discard changes in the following workspaces? {{workspaceNames}}","closingAllWorkspacesPromptTitle":"You have unsaved changes","confirm":"Confirm","contactAdministratorIfIssuePersists":"Contact your system administrator if the problem persists.","contactDetails":"Contact Details","country":"Country","countyDistrict":"District","delete":"Delete","discard":"Discard","district":"District","edit":"Edit","error":"Error","errorCopy":"Sorry, there was a problem displaying this information. You can try to reload this page, or contact the site administrator and quote the error code above.","female":"Female","hide":"Hide","loading":"Loading","male":"Male","maximize":"Maximize","minimize":"Minimize","openAnyway":"Open Anyway","other":"Other","patientIdentifierSticker":"Patient identifier sticker","patientLists":"Patient Lists","postalCode":"Postal code","print":"Print","printError":"Print error","printErrorExplainer":"An error occurred in {{errorLocation}}","printIdentifierSticker":"Print identifier sticker","printing":"Printing","relationships":"Relationships","resetOverrides":"Reset overrides","save":"Save","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.","scriptLoadingFailed":"Error: Script failed to load","seeMoreLists":"See {{count}} more lists","sex":"Sex","showLess":"Show less","showMore":"Show more","state":"State","stateProvince":"State","toggleDevTools":"Toggle dev tools","unknown":"Unknown","unsavedChangesInOpenedWorkspace":"You may have unsaved changes in the opened workspace. Do you want to discard these changes?","unsavedChangesInWorkspace":"There may be unsaved changes in \\"{{workspaceName}}\\". Please save them before opening another workspace.","unsavedChangesTitleText":"Unsaved changes","workspaceHeader":"Workspace header"}');
19
+
20
+ /***/ })
21
+
22
+ }]);
@@ -2195,7 +2195,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
2195
2195
  \*******************************************************************/
2196
2196
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
2197
2197
 
2198
- 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");
2198
+ 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 type { StoreApi } from 'zustand/vanilla';\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';\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");
2199
2199
 
2200
2200
  /***/ }),
2201
2201
 
@@ -2215,7 +2215,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
2215
2215
  \*************************************************************/
2216
2216
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
2217
2217
 
2218
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ coreTranslations: () => (/* binding */ coreTranslations)\n/* harmony export */ });\n/** Please keep these alphabetized */ const addressFields = {\n address1: 'Address line 1',\n address2: 'Address line 2',\n address3: 'Address line 3',\n address4: 'Address line 4',\n address5: 'Address line 5',\n address6: 'Address line 6',\n city: 'City',\n cityVillage: 'City',\n country: 'Country',\n countyDistrict: 'District',\n district: 'District',\n postalCode: 'Postal code',\n state: 'State',\n stateProvince: 'State'\n};\nconst workspaceTranslations = {\n closeAllOpenedWorkspaces: 'Discard changes in {{count}} workspaces',\n closingAllWorkspacesPromptBody: 'There may be unsaved changes in the following workspaces. Do you want to discard changes in the following workspaces? {{workspaceNames}}',\n closingAllWorkspacesPromptTitle: 'You have unsaved changes',\n discard: 'Discard',\n hide: 'Hide',\n maximize: 'Maximize',\n minimize: 'Minimize',\n openAnyway: 'Open anyway',\n unsavedChangesInOpenedWorkspace: `You may have unsaved changes in the opened workspace. Do you want to discard these changes?`,\n unsavedChangesInWorkspace: 'There may be unsaved changes in \"{{workspaceName}}\". Please save them before opening another workspace.',\n unsavedChangesTitleText: 'Unsaved changes',\n workspaceHeader: 'Workspace header'\n};\nconst coreTranslations = {\n ...addressFields,\n ...workspaceTranslations,\n actions: 'Actions',\n address: 'Address',\n age: 'Age',\n cancel: 'Cancel',\n change: 'Change',\n // Default value for the implementationName config property\n Clinic: 'Clinic',\n close: 'Close',\n confirm: 'Confirm',\n contactAdministratorIfIssuePersists: 'Contact your system administrator if the problem persists.',\n contactDetails: 'Contact details',\n delete: 'Delete',\n edit: 'Edit',\n error: 'Error',\n errorCopy: 'Sorry, there was a problem displaying this information. You can try to reload this page, or contact the site administrator and quote the error code above.',\n female: 'Female',\n loading: 'Loading',\n male: 'Male',\n other: 'Other',\n patientIdentifierSticker: 'Patient identifier sticker',\n patientLists: 'Patient lists',\n print: 'Print',\n printError: 'Print error',\n printErrorExplainer: 'An error occurred in {{errorLocation}}',\n printIdentifierSticker: 'Print identifier sticker',\n printing: 'Printing',\n relationships: 'Relationships',\n resetOverrides: 'Reset overrides',\n save: 'Save',\n scriptLoadingFailed: 'Error: Script failed to load',\n 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 seeMoreLists: 'See {{count}} more lists',\n sex: 'Sex',\n showLess: 'Show less',\n showMore: 'Show more',\n toggleDevTools: 'Toggle dev tools',\n unknown: 'Unknown'\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS10cmFuc2xhdGlvbnMvZGlzdC90cmFuc2xhdGlvbnMuanMiLCJtYXBwaW5ncyI6Ijs7OztBQUFBLG1DQUFtQyxHQUFHLE1BQU1BLGdCQUFnQjtJQUN4REMsVUFBVTtJQUNWQyxVQUFVO0lBQ1ZDLFVBQVU7SUFDVkMsVUFBVTtJQUNWQyxVQUFVO0lBQ1ZDLFVBQVU7SUFDVkMsTUFBTTtJQUNOQyxhQUFhO0lBQ2JDLFNBQVM7SUFDVEMsZ0JBQWdCO0lBQ2hCQyxVQUFVO0lBQ1ZDLFlBQVk7SUFDWkMsT0FBTztJQUNQQyxlQUFlO0FBQ25CO0FBQ0EsTUFBTUMsd0JBQXdCO0lBQzFCQywwQkFBMEI7SUFDMUJDLGdDQUFnQztJQUNoQ0MsaUNBQWlDO0lBQ2pDQyxTQUFTO0lBQ1RDLE1BQU07SUFDTkMsVUFBVTtJQUNWQyxVQUFVO0lBQ1ZDLFlBQVk7SUFDWkMsaUNBQWlDLENBQUMsMkZBQTJGLENBQUM7SUFDOUhDLDJCQUEyQjtJQUMzQkMseUJBQXlCO0lBQ3pCQyxpQkFBaUI7QUFDckI7QUFDTyxNQUFNQyxtQkFBbUI7SUFDNUIsR0FBRzVCLGFBQWE7SUFDaEIsR0FBR2UscUJBQXFCO0lBQ3hCYyxTQUFTO0lBQ1RDLFNBQVM7SUFDVEMsS0FBSztJQUNMQyxRQUFRO0lBQ1JDLFFBQVE7SUFDUiwyREFBMkQ7SUFDM0RDLFFBQVE7SUFDUkMsT0FBTztJQUNQQyxTQUFTO0lBQ1RDLHFDQUFxQztJQUNyQ0MsZ0JBQWdCO0lBQ2hCQyxRQUFRO0lBQ1JDLE1BQU07SUFDTkMsT0FBTztJQUNQQyxXQUFXO0lBQ1hDLFFBQVE7SUFDUkMsU0FBUztJQUNUQyxNQUFNO0lBQ05DLE9BQU87SUFDUEMsMEJBQTBCO0lBQzFCQyxjQUFjO0lBQ2RDLE9BQU87SUFDUEMsWUFBWTtJQUNaQyxxQkFBcUI7SUFDckJDLHdCQUF3QjtJQUN4QkMsVUFBVTtJQUNWQyxlQUFlO0lBQ2ZDLGdCQUFnQjtJQUNoQkMsTUFBTTtJQUNOQyxxQkFBcUI7SUFDckJDLG9CQUFvQjtJQUNwQkMsY0FBYztJQUNkQyxLQUFLO0lBQ0xDLFVBQVU7SUFDVkMsVUFBVTtJQUNWQyxnQkFBZ0I7SUFDaEJDLFNBQVM7QUFDYixFQUFFIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vQG9wZW5tcnMvZXNtLWFwcC1zaGVsbC8uLi8uLi9mcmFtZXdvcmsvZXNtLXRyYW5zbGF0aW9ucy9kaXN0L3RyYW5zbGF0aW9ucy5qcz9iMjljIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKiBQbGVhc2Uga2VlcCB0aGVzZSBhbHBoYWJldGl6ZWQgKi8gY29uc3QgYWRkcmVzc0ZpZWxkcyA9IHtcbiAgICBhZGRyZXNzMTogJ0FkZHJlc3MgbGluZSAxJyxcbiAgICBhZGRyZXNzMjogJ0FkZHJlc3MgbGluZSAyJyxcbiAgICBhZGRyZXNzMzogJ0FkZHJlc3MgbGluZSAzJyxcbiAgICBhZGRyZXNzNDogJ0FkZHJlc3MgbGluZSA0JyxcbiAgICBhZGRyZXNzNTogJ0FkZHJlc3MgbGluZSA1JyxcbiAgICBhZGRyZXNzNjogJ0FkZHJlc3MgbGluZSA2JyxcbiAgICBjaXR5OiAnQ2l0eScsXG4gICAgY2l0eVZpbGxhZ2U6ICdDaXR5JyxcbiAgICBjb3VudHJ5OiAnQ291bnRyeScsXG4gICAgY291bnR5RGlzdHJpY3Q6ICdEaXN0cmljdCcsXG4gICAgZGlzdHJpY3Q6ICdEaXN0cmljdCcsXG4gICAgcG9zdGFsQ29kZTogJ1Bvc3RhbCBjb2RlJyxcbiAgICBzdGF0ZTogJ1N0YXRlJyxcbiAgICBzdGF0ZVByb3ZpbmNlOiAnU3RhdGUnXG59O1xuY29uc3Qgd29ya3NwYWNlVHJhbnNsYXRpb25zID0ge1xuICAgIGNsb3NlQWxsT3BlbmVkV29ya3NwYWNlczogJ0Rpc2NhcmQgY2hhbmdlcyBpbiB7e2NvdW50fX0gd29ya3NwYWNlcycsXG4gICAgY2xvc2luZ0FsbFdvcmtzcGFjZXNQcm9tcHRCb2R5OiAnVGhlcmUgbWF5IGJlIHVuc2F2ZWQgY2hhbmdlcyBpbiB0aGUgZm9sbG93aW5nIHdvcmtzcGFjZXMuIERvIHlvdSB3YW50IHRvIGRpc2NhcmQgY2hhbmdlcyBpbiB0aGUgZm9sbG93aW5nIHdvcmtzcGFjZXM/IHt7d29ya3NwYWNlTmFtZXN9fScsXG4gICAgY2xvc2luZ0FsbFdvcmtzcGFjZXNQcm9tcHRUaXRsZTogJ1lvdSBoYXZlIHVuc2F2ZWQgY2hhbmdlcycsXG4gICAgZGlzY2FyZDogJ0Rpc2NhcmQnLFxuICAgIGhpZGU6ICdIaWRlJyxcbiAgICBtYXhpbWl6ZTogJ01heGltaXplJyxcbiAgICBtaW5pbWl6ZTogJ01pbmltaXplJyxcbiAgICBvcGVuQW55d2F5OiAnT3BlbiBhbnl3YXknLFxuICAgIHVuc2F2ZWRDaGFuZ2VzSW5PcGVuZWRXb3Jrc3BhY2U6IGBZb3UgbWF5IGhhdmUgdW5zYXZlZCBjaGFuZ2VzIGluIHRoZSBvcGVuZWQgd29ya3NwYWNlLiBEbyB5b3Ugd2FudCB0byBkaXNjYXJkIHRoZXNlIGNoYW5nZXM/YCxcbiAgICB1bnNhdmVkQ2hhbmdlc0luV29ya3NwYWNlOiAnVGhlcmUgbWF5IGJlIHVuc2F2ZWQgY2hhbmdlcyBpbiBcInt7d29ya3NwYWNlTmFtZX19XCIuIFBsZWFzZSBzYXZlIHRoZW0gYmVmb3JlIG9wZW5pbmcgYW5vdGhlciB3b3Jrc3BhY2UuJyxcbiAgICB1bnNhdmVkQ2hhbmdlc1RpdGxlVGV4dDogJ1Vuc2F2ZWQgY2hhbmdlcycsXG4gICAgd29ya3NwYWNlSGVhZGVyOiAnV29ya3NwYWNlIGhlYWRlcidcbn07XG5leHBvcnQgY29uc3QgY29yZVRyYW5zbGF0aW9ucyA9IHtcbiAgICAuLi5hZGRyZXNzRmllbGRzLFxuICAgIC4uLndvcmtzcGFjZVRyYW5zbGF0aW9ucyxcbiAgICBhY3Rpb25zOiAnQWN0aW9ucycsXG4gICAgYWRkcmVzczogJ0FkZHJlc3MnLFxuICAgIGFnZTogJ0FnZScsXG4gICAgY2FuY2VsOiAnQ2FuY2VsJyxcbiAgICBjaGFuZ2U6ICdDaGFuZ2UnLFxuICAgIC8vIERlZmF1bHQgdmFsdWUgZm9yIHRoZSBpbXBsZW1lbnRhdGlvbk5hbWUgY29uZmlnIHByb3BlcnR5XG4gICAgQ2xpbmljOiAnQ2xpbmljJyxcbiAgICBjbG9zZTogJ0Nsb3NlJyxcbiAgICBjb25maXJtOiAnQ29uZmlybScsXG4gICAgY29udGFjdEFkbWluaXN0cmF0b3JJZklzc3VlUGVyc2lzdHM6ICdDb250YWN0IHlvdXIgc3lzdGVtIGFkbWluaXN0cmF0b3IgaWYgdGhlIHByb2JsZW0gcGVyc2lzdHMuJyxcbiAgICBjb250YWN0RGV0YWlsczogJ0NvbnRhY3QgZGV0YWlscycsXG4gICAgZGVsZXRlOiAnRGVsZXRlJyxcbiAgICBlZGl0OiAnRWRpdCcsXG4gICAgZXJyb3I6ICdFcnJvcicsXG4gICAgZXJyb3JDb3B5OiAnU29ycnksIHRoZXJlIHdhcyBhIHByb2JsZW0gZGlzcGxheWluZyB0aGlzIGluZm9ybWF0aW9uLiBZb3UgY2FuIHRyeSB0byByZWxvYWQgdGhpcyBwYWdlLCBvciBjb250YWN0IHRoZSBzaXRlIGFkbWluaXN0cmF0b3IgYW5kIHF1b3RlIHRoZSBlcnJvciBjb2RlIGFib3ZlLicsXG4gICAgZmVtYWxlOiAnRmVtYWxlJyxcbiAgICBsb2FkaW5nOiAnTG9hZGluZycsXG4gICAgbWFsZTogJ01hbGUnLFxuICAgIG90aGVyOiAnT3RoZXInLFxuICAgIHBhdGllbnRJZGVudGlmaWVyU3RpY2tlcjogJ1BhdGllbnQgaWRlbnRpZmllciBzdGlja2VyJyxcbiAgICBwYXRpZW50TGlzdHM6ICdQYXRpZW50IGxpc3RzJyxcbiAgICBwcmludDogJ1ByaW50JyxcbiAgICBwcmludEVycm9yOiAnUHJpbnQgZXJyb3InLFxuICAgIHByaW50RXJyb3JFeHBsYWluZXI6ICdBbiBlcnJvciBvY2N1cnJlZCBpbiB7e2Vycm9yTG9jYXRpb259fScsXG4gICAgcHJpbnRJZGVudGlmaWVyU3RpY2tlcjogJ1ByaW50IGlkZW50aWZpZXIgc3RpY2tlcicsXG4gICAgcHJpbnRpbmc6ICdQcmludGluZycsXG4gICAgcmVsYXRpb25zaGlwczogJ1JlbGF0aW9uc2hpcHMnLFxuICAgIHJlc2V0T3ZlcnJpZGVzOiAnUmVzZXQgb3ZlcnJpZGVzJyxcbiAgICBzYXZlOiAnU2F2ZScsXG4gICAgc2NyaXB0TG9hZGluZ0ZhaWxlZDogJ0Vycm9yOiBTY3JpcHQgZmFpbGVkIHRvIGxvYWQnLFxuICAgIHNjcmlwdExvYWRpbmdFcnJvcjogJ0ZhaWxlZCB0byBsb2FkIG92ZXJyaWRkZW4gc2NyaXB0IGZyb20ge3t1cmx9fS4gUGxlYXNlIGNoZWNrIHRoYXQgdGhlIGJ1bmRsZWQgc2NyaXB0IGlzIGF2YWlsYWJsZSBhdCB0aGUgZXhwZWN0ZWQgVVJMLiBDbGljayB0aGUgYnV0dG9uIGJlbG93IHRvIHJlc2V0IGFsbCBpbXBvcnQgbWFwIG92ZXJyaWRlcy4nLFxuICAgIHNlZU1vcmVMaXN0czogJ1NlZSB7e2NvdW50fX0gbW9yZSBsaXN0cycsXG4gICAgc2V4OiAnU2V4JyxcbiAgICBzaG93TGVzczogJ1Nob3cgbGVzcycsXG4gICAgc2hvd01vcmU6ICdTaG93IG1vcmUnLFxuICAgIHRvZ2dsZURldlRvb2xzOiAnVG9nZ2xlIGRldiB0b29scycsXG4gICAgdW5rbm93bjogJ1Vua25vd24nXG59O1xuIl0sIm5hbWVzIjpbImFkZHJlc3NGaWVsZHMiLCJhZGRyZXNzMSIsImFkZHJlc3MyIiwiYWRkcmVzczMiLCJhZGRyZXNzNCIsImFkZHJlc3M1IiwiYWRkcmVzczYiLCJjaXR5IiwiY2l0eVZpbGxhZ2UiLCJjb3VudHJ5IiwiY291bnR5RGlzdHJpY3QiLCJkaXN0cmljdCIsInBvc3RhbENvZGUiLCJzdGF0ZSIsInN0YXRlUHJvdmluY2UiLCJ3b3Jrc3BhY2VUcmFuc2xhdGlvbnMiLCJjbG9zZUFsbE9wZW5lZFdvcmtzcGFjZXMiLCJjbG9zaW5nQWxsV29ya3NwYWNlc1Byb21wdEJvZHkiLCJjbG9zaW5nQWxsV29ya3NwYWNlc1Byb21wdFRpdGxlIiwiZGlzY2FyZCIsImhpZGUiLCJtYXhpbWl6ZSIsIm1pbmltaXplIiwib3BlbkFueXdheSIsInVuc2F2ZWRDaGFuZ2VzSW5PcGVuZWRXb3Jrc3BhY2UiLCJ1bnNhdmVkQ2hhbmdlc0luV29ya3NwYWNlIiwidW5zYXZlZENoYW5nZXNUaXRsZVRleHQiLCJ3b3Jrc3BhY2VIZWFkZXIiLCJjb3JlVHJhbnNsYXRpb25zIiwiYWN0aW9ucyIsImFkZHJlc3MiLCJhZ2UiLCJjYW5jZWwiLCJjaGFuZ2UiLCJDbGluaWMiLCJjbG9zZSIsImNvbmZpcm0iLCJjb250YWN0QWRtaW5pc3RyYXRvcklmSXNzdWVQZXJzaXN0cyIsImNvbnRhY3REZXRhaWxzIiwiZGVsZXRlIiwiZWRpdCIsImVycm9yIiwiZXJyb3JDb3B5IiwiZmVtYWxlIiwibG9hZGluZyIsIm1hbGUiLCJvdGhlciIsInBhdGllbnRJZGVudGlmaWVyU3RpY2tlciIsInBhdGllbnRMaXN0cyIsInByaW50IiwicHJpbnRFcnJvciIsInByaW50RXJyb3JFeHBsYWluZXIiLCJwcmludElkZW50aWZpZXJTdGlja2VyIiwicHJpbnRpbmciLCJyZWxhdGlvbnNoaXBzIiwicmVzZXRPdmVycmlkZXMiLCJzYXZlIiwic2NyaXB0TG9hZGluZ0ZhaWxlZCIsInNjcmlwdExvYWRpbmdFcnJvciIsInNlZU1vcmVMaXN0cyIsInNleCIsInNob3dMZXNzIiwic2hvd01vcmUiLCJ0b2dnbGVEZXZUb29scyIsInVua25vd24iXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///../../framework/esm-translations/dist/translations.js\n");
2218
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ coreTranslations: () => (/* binding */ coreTranslations)\n/* harmony export */ });\n/** Please keep these alphabetized */ const addressFields = {\n address1: 'Address line 1',\n address2: 'Address line 2',\n address3: 'Address line 3',\n address4: 'Address line 4',\n address5: 'Address line 5',\n address6: 'Address line 6',\n city: 'City',\n cityVillage: 'City',\n country: 'Country',\n countyDistrict: 'District',\n district: 'District',\n postalCode: 'Postal code',\n state: 'State',\n stateProvince: 'State'\n};\nconst workspaceTranslations = {\n closeAllOpenedWorkspaces: 'Discard changes in {{count}} workspaces',\n closingAllWorkspacesPromptBody: 'There may be unsaved changes in the following workspaces. Do you want to discard changes in the following workspaces? {{workspaceNames}}',\n closingAllWorkspacesPromptTitle: 'You have unsaved changes',\n discard: 'Discard',\n hide: 'Hide',\n maximize: 'Maximize',\n minimize: 'Minimize',\n openAnyway: 'Open anyway',\n unsavedChangesInOpenedWorkspace: 'You may have unsaved changes in the opened workspace. Do you want to discard these changes?',\n unsavedChangesInWorkspace: 'There may be unsaved changes in \"{{workspaceName}}\". Please save them before opening another workspace.',\n unsavedChangesTitleText: 'Unsaved changes',\n workspaceHeader: 'Workspace header'\n};\nconst coreTranslations = {\n ...addressFields,\n ...workspaceTranslations,\n actions: 'Actions',\n address: 'Address',\n age: 'Age',\n cancel: 'Cancel',\n change: 'Change',\n // Default value for the implementationName config property\n Clinic: 'Clinic',\n close: 'Close',\n confirm: 'Confirm',\n contactAdministratorIfIssuePersists: 'Contact your system administrator if the problem persists.',\n contactDetails: 'Contact details',\n delete: 'Delete',\n edit: 'Edit',\n error: 'Error',\n errorCopy: 'Sorry, there was a problem displaying this information. You can try to reload this page, or contact the site administrator and quote the error code above.',\n female: 'Female',\n loading: 'Loading',\n male: 'Male',\n other: 'Other',\n patientIdentifierSticker: 'Patient identifier sticker',\n patientLists: 'Patient lists',\n print: 'Print',\n printError: 'Print error',\n printErrorExplainer: 'An error occurred in {{errorLocation}}',\n printIdentifierSticker: 'Print identifier sticker',\n printing: 'Printing',\n relationships: 'Relationships',\n resetOverrides: 'Reset overrides',\n save: 'Save',\n scriptLoadingFailed: 'Error: Script failed to load',\n 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 seeMoreLists: 'See {{count}} more lists',\n sex: 'Sex',\n showLess: 'Show less',\n showMore: 'Show more',\n toggleDevTools: 'Toggle dev tools',\n unknown: 'Unknown'\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS10cmFuc2xhdGlvbnMvZGlzdC90cmFuc2xhdGlvbnMuanMiLCJtYXBwaW5ncyI6Ijs7OztBQUFBLG1DQUFtQyxHQUFHLE1BQU1BLGdCQUFnQjtJQUN4REMsVUFBVTtJQUNWQyxVQUFVO0lBQ1ZDLFVBQVU7SUFDVkMsVUFBVTtJQUNWQyxVQUFVO0lBQ1ZDLFVBQVU7SUFDVkMsTUFBTTtJQUNOQyxhQUFhO0lBQ2JDLFNBQVM7SUFDVEMsZ0JBQWdCO0lBQ2hCQyxVQUFVO0lBQ1ZDLFlBQVk7SUFDWkMsT0FBTztJQUNQQyxlQUFlO0FBQ25CO0FBQ0EsTUFBTUMsd0JBQXdCO0lBQzFCQywwQkFBMEI7SUFDMUJDLGdDQUFnQztJQUNoQ0MsaUNBQWlDO0lBQ2pDQyxTQUFTO0lBQ1RDLE1BQU07SUFDTkMsVUFBVTtJQUNWQyxVQUFVO0lBQ1ZDLFlBQVk7SUFDWkMsaUNBQWlDO0lBQ2pDQywyQkFBMkI7SUFDM0JDLHlCQUF5QjtJQUN6QkMsaUJBQWlCO0FBQ3JCO0FBQ08sTUFBTUMsbUJBQW1CO0lBQzVCLEdBQUc1QixhQUFhO0lBQ2hCLEdBQUdlLHFCQUFxQjtJQUN4QmMsU0FBUztJQUNUQyxTQUFTO0lBQ1RDLEtBQUs7SUFDTEMsUUFBUTtJQUNSQyxRQUFRO0lBQ1IsMkRBQTJEO0lBQzNEQyxRQUFRO0lBQ1JDLE9BQU87SUFDUEMsU0FBUztJQUNUQyxxQ0FBcUM7SUFDckNDLGdCQUFnQjtJQUNoQkMsUUFBUTtJQUNSQyxNQUFNO0lBQ05DLE9BQU87SUFDUEMsV0FBVztJQUNYQyxRQUFRO0lBQ1JDLFNBQVM7SUFDVEMsTUFBTTtJQUNOQyxPQUFPO0lBQ1BDLDBCQUEwQjtJQUMxQkMsY0FBYztJQUNkQyxPQUFPO0lBQ1BDLFlBQVk7SUFDWkMscUJBQXFCO0lBQ3JCQyx3QkFBd0I7SUFDeEJDLFVBQVU7SUFDVkMsZUFBZTtJQUNmQyxnQkFBZ0I7SUFDaEJDLE1BQU07SUFDTkMscUJBQXFCO0lBQ3JCQyxvQkFBb0I7SUFDcEJDLGNBQWM7SUFDZEMsS0FBSztJQUNMQyxVQUFVO0lBQ1ZDLFVBQVU7SUFDVkMsZ0JBQWdCO0lBQ2hCQyxTQUFTO0FBQ2IsRUFBRSIsInNvdXJjZXMiOlsid2VicGFjazovL0BvcGVubXJzL2VzbS1hcHAtc2hlbGwvLi4vLi4vZnJhbWV3b3JrL2VzbS10cmFuc2xhdGlvbnMvZGlzdC90cmFuc2xhdGlvbnMuanM/YjI5YyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogUGxlYXNlIGtlZXAgdGhlc2UgYWxwaGFiZXRpemVkICovIGNvbnN0IGFkZHJlc3NGaWVsZHMgPSB7XG4gICAgYWRkcmVzczE6ICdBZGRyZXNzIGxpbmUgMScsXG4gICAgYWRkcmVzczI6ICdBZGRyZXNzIGxpbmUgMicsXG4gICAgYWRkcmVzczM6ICdBZGRyZXNzIGxpbmUgMycsXG4gICAgYWRkcmVzczQ6ICdBZGRyZXNzIGxpbmUgNCcsXG4gICAgYWRkcmVzczU6ICdBZGRyZXNzIGxpbmUgNScsXG4gICAgYWRkcmVzczY6ICdBZGRyZXNzIGxpbmUgNicsXG4gICAgY2l0eTogJ0NpdHknLFxuICAgIGNpdHlWaWxsYWdlOiAnQ2l0eScsXG4gICAgY291bnRyeTogJ0NvdW50cnknLFxuICAgIGNvdW50eURpc3RyaWN0OiAnRGlzdHJpY3QnLFxuICAgIGRpc3RyaWN0OiAnRGlzdHJpY3QnLFxuICAgIHBvc3RhbENvZGU6ICdQb3N0YWwgY29kZScsXG4gICAgc3RhdGU6ICdTdGF0ZScsXG4gICAgc3RhdGVQcm92aW5jZTogJ1N0YXRlJ1xufTtcbmNvbnN0IHdvcmtzcGFjZVRyYW5zbGF0aW9ucyA9IHtcbiAgICBjbG9zZUFsbE9wZW5lZFdvcmtzcGFjZXM6ICdEaXNjYXJkIGNoYW5nZXMgaW4ge3tjb3VudH19IHdvcmtzcGFjZXMnLFxuICAgIGNsb3NpbmdBbGxXb3Jrc3BhY2VzUHJvbXB0Qm9keTogJ1RoZXJlIG1heSBiZSB1bnNhdmVkIGNoYW5nZXMgaW4gdGhlIGZvbGxvd2luZyB3b3Jrc3BhY2VzLiBEbyB5b3Ugd2FudCB0byBkaXNjYXJkIGNoYW5nZXMgaW4gdGhlIGZvbGxvd2luZyB3b3Jrc3BhY2VzPyB7e3dvcmtzcGFjZU5hbWVzfX0nLFxuICAgIGNsb3NpbmdBbGxXb3Jrc3BhY2VzUHJvbXB0VGl0bGU6ICdZb3UgaGF2ZSB1bnNhdmVkIGNoYW5nZXMnLFxuICAgIGRpc2NhcmQ6ICdEaXNjYXJkJyxcbiAgICBoaWRlOiAnSGlkZScsXG4gICAgbWF4aW1pemU6ICdNYXhpbWl6ZScsXG4gICAgbWluaW1pemU6ICdNaW5pbWl6ZScsXG4gICAgb3BlbkFueXdheTogJ09wZW4gYW55d2F5JyxcbiAgICB1bnNhdmVkQ2hhbmdlc0luT3BlbmVkV29ya3NwYWNlOiAnWW91IG1heSBoYXZlIHVuc2F2ZWQgY2hhbmdlcyBpbiB0aGUgb3BlbmVkIHdvcmtzcGFjZS4gRG8geW91IHdhbnQgdG8gZGlzY2FyZCB0aGVzZSBjaGFuZ2VzPycsXG4gICAgdW5zYXZlZENoYW5nZXNJbldvcmtzcGFjZTogJ1RoZXJlIG1heSBiZSB1bnNhdmVkIGNoYW5nZXMgaW4gXCJ7e3dvcmtzcGFjZU5hbWV9fVwiLiBQbGVhc2Ugc2F2ZSB0aGVtIGJlZm9yZSBvcGVuaW5nIGFub3RoZXIgd29ya3NwYWNlLicsXG4gICAgdW5zYXZlZENoYW5nZXNUaXRsZVRleHQ6ICdVbnNhdmVkIGNoYW5nZXMnLFxuICAgIHdvcmtzcGFjZUhlYWRlcjogJ1dvcmtzcGFjZSBoZWFkZXInXG59O1xuZXhwb3J0IGNvbnN0IGNvcmVUcmFuc2xhdGlvbnMgPSB7XG4gICAgLi4uYWRkcmVzc0ZpZWxkcyxcbiAgICAuLi53b3Jrc3BhY2VUcmFuc2xhdGlvbnMsXG4gICAgYWN0aW9uczogJ0FjdGlvbnMnLFxuICAgIGFkZHJlc3M6ICdBZGRyZXNzJyxcbiAgICBhZ2U6ICdBZ2UnLFxuICAgIGNhbmNlbDogJ0NhbmNlbCcsXG4gICAgY2hhbmdlOiAnQ2hhbmdlJyxcbiAgICAvLyBEZWZhdWx0IHZhbHVlIGZvciB0aGUgaW1wbGVtZW50YXRpb25OYW1lIGNvbmZpZyBwcm9wZXJ0eVxuICAgIENsaW5pYzogJ0NsaW5pYycsXG4gICAgY2xvc2U6ICdDbG9zZScsXG4gICAgY29uZmlybTogJ0NvbmZpcm0nLFxuICAgIGNvbnRhY3RBZG1pbmlzdHJhdG9ySWZJc3N1ZVBlcnNpc3RzOiAnQ29udGFjdCB5b3VyIHN5c3RlbSBhZG1pbmlzdHJhdG9yIGlmIHRoZSBwcm9ibGVtIHBlcnNpc3RzLicsXG4gICAgY29udGFjdERldGFpbHM6ICdDb250YWN0IGRldGFpbHMnLFxuICAgIGRlbGV0ZTogJ0RlbGV0ZScsXG4gICAgZWRpdDogJ0VkaXQnLFxuICAgIGVycm9yOiAnRXJyb3InLFxuICAgIGVycm9yQ29weTogJ1NvcnJ5LCB0aGVyZSB3YXMgYSBwcm9ibGVtIGRpc3BsYXlpbmcgdGhpcyBpbmZvcm1hdGlvbi4gWW91IGNhbiB0cnkgdG8gcmVsb2FkIHRoaXMgcGFnZSwgb3IgY29udGFjdCB0aGUgc2l0ZSBhZG1pbmlzdHJhdG9yIGFuZCBxdW90ZSB0aGUgZXJyb3IgY29kZSBhYm92ZS4nLFxuICAgIGZlbWFsZTogJ0ZlbWFsZScsXG4gICAgbG9hZGluZzogJ0xvYWRpbmcnLFxuICAgIG1hbGU6ICdNYWxlJyxcbiAgICBvdGhlcjogJ090aGVyJyxcbiAgICBwYXRpZW50SWRlbnRpZmllclN0aWNrZXI6ICdQYXRpZW50IGlkZW50aWZpZXIgc3RpY2tlcicsXG4gICAgcGF0aWVudExpc3RzOiAnUGF0aWVudCBsaXN0cycsXG4gICAgcHJpbnQ6ICdQcmludCcsXG4gICAgcHJpbnRFcnJvcjogJ1ByaW50IGVycm9yJyxcbiAgICBwcmludEVycm9yRXhwbGFpbmVyOiAnQW4gZXJyb3Igb2NjdXJyZWQgaW4ge3tlcnJvckxvY2F0aW9ufX0nLFxuICAgIHByaW50SWRlbnRpZmllclN0aWNrZXI6ICdQcmludCBpZGVudGlmaWVyIHN0aWNrZXInLFxuICAgIHByaW50aW5nOiAnUHJpbnRpbmcnLFxuICAgIHJlbGF0aW9uc2hpcHM6ICdSZWxhdGlvbnNoaXBzJyxcbiAgICByZXNldE92ZXJyaWRlczogJ1Jlc2V0IG92ZXJyaWRlcycsXG4gICAgc2F2ZTogJ1NhdmUnLFxuICAgIHNjcmlwdExvYWRpbmdGYWlsZWQ6ICdFcnJvcjogU2NyaXB0IGZhaWxlZCB0byBsb2FkJyxcbiAgICBzY3JpcHRMb2FkaW5nRXJyb3I6ICdGYWlsZWQgdG8gbG9hZCBvdmVycmlkZGVuIHNjcmlwdCBmcm9tIHt7dXJsfX0uIFBsZWFzZSBjaGVjayB0aGF0IHRoZSBidW5kbGVkIHNjcmlwdCBpcyBhdmFpbGFibGUgYXQgdGhlIGV4cGVjdGVkIFVSTC4gQ2xpY2sgdGhlIGJ1dHRvbiBiZWxvdyB0byByZXNldCBhbGwgaW1wb3J0IG1hcCBvdmVycmlkZXMuJyxcbiAgICBzZWVNb3JlTGlzdHM6ICdTZWUge3tjb3VudH19IG1vcmUgbGlzdHMnLFxuICAgIHNleDogJ1NleCcsXG4gICAgc2hvd0xlc3M6ICdTaG93IGxlc3MnLFxuICAgIHNob3dNb3JlOiAnU2hvdyBtb3JlJyxcbiAgICB0b2dnbGVEZXZUb29sczogJ1RvZ2dsZSBkZXYgdG9vbHMnLFxuICAgIHVua25vd246ICdVbmtub3duJ1xufTtcbiJdLCJuYW1lcyI6WyJhZGRyZXNzRmllbGRzIiwiYWRkcmVzczEiLCJhZGRyZXNzMiIsImFkZHJlc3MzIiwiYWRkcmVzczQiLCJhZGRyZXNzNSIsImFkZHJlc3M2IiwiY2l0eSIsImNpdHlWaWxsYWdlIiwiY291bnRyeSIsImNvdW50eURpc3RyaWN0IiwiZGlzdHJpY3QiLCJwb3N0YWxDb2RlIiwic3RhdGUiLCJzdGF0ZVByb3ZpbmNlIiwid29ya3NwYWNlVHJhbnNsYXRpb25zIiwiY2xvc2VBbGxPcGVuZWRXb3Jrc3BhY2VzIiwiY2xvc2luZ0FsbFdvcmtzcGFjZXNQcm9tcHRCb2R5IiwiY2xvc2luZ0FsbFdvcmtzcGFjZXNQcm9tcHRUaXRsZSIsImRpc2NhcmQiLCJoaWRlIiwibWF4aW1pemUiLCJtaW5pbWl6ZSIsIm9wZW5Bbnl3YXkiLCJ1bnNhdmVkQ2hhbmdlc0luT3BlbmVkV29ya3NwYWNlIiwidW5zYXZlZENoYW5nZXNJbldvcmtzcGFjZSIsInVuc2F2ZWRDaGFuZ2VzVGl0bGVUZXh0Iiwid29ya3NwYWNlSGVhZGVyIiwiY29yZVRyYW5zbGF0aW9ucyIsImFjdGlvbnMiLCJhZGRyZXNzIiwiYWdlIiwiY2FuY2VsIiwiY2hhbmdlIiwiQ2xpbmljIiwiY2xvc2UiLCJjb25maXJtIiwiY29udGFjdEFkbWluaXN0cmF0b3JJZklzc3VlUGVyc2lzdHMiLCJjb250YWN0RGV0YWlscyIsImRlbGV0ZSIsImVkaXQiLCJlcnJvciIsImVycm9yQ29weSIsImZlbWFsZSIsImxvYWRpbmciLCJtYWxlIiwib3RoZXIiLCJwYXRpZW50SWRlbnRpZmllclN0aWNrZXIiLCJwYXRpZW50TGlzdHMiLCJwcmludCIsInByaW50RXJyb3IiLCJwcmludEVycm9yRXhwbGFpbmVyIiwicHJpbnRJZGVudGlmaWVyU3RpY2tlciIsInByaW50aW5nIiwicmVsYXRpb25zaGlwcyIsInJlc2V0T3ZlcnJpZGVzIiwic2F2ZSIsInNjcmlwdExvYWRpbmdGYWlsZWQiLCJzY3JpcHRMb2FkaW5nRXJyb3IiLCJzZWVNb3JlTGlzdHMiLCJzZXgiLCJzaG93TGVzcyIsInNob3dNb3JlIiwidG9nZ2xlRGV2VG9vbHMiLCJ1bmtub3duIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///../../framework/esm-translations/dist/translations.js\n");
2219
2219
 
2220
2220
  /***/ }),
2221
2221
 
@@ -15,7 +15,7 @@
15
15
  \*************************************************************/
16
16
  /***/ ((module) => {
17
17
 
18
- module.exports = /*#__PURE__*/JSON.parse('{"actions":"Actions","address":"Adresse","address1":"Adresse: ligne 1","address2":"Adresse: ligne 2","address3":"Adresse : ligne 3","address4":"Adresse : ligne 4","address5":"Adresse : ligne 5","address6":"Adresse : ligne 6","age":"Âge","cancel":"Annuler","change":"Modifier","city":"Ville","cityVillage":"Ville","Clinic":"Clinique","close":"Fermer","closeAllOpenedWorkspaces":"Annuler les modifications dans les {{count}} espaces de travail ","closingAllWorkspacesPromptBody":"Il y a des modifications non enregistrées dans les espaces de travail suivants. Voulez-vous annuler les modifications ? {{workspaceNames}}","closingAllWorkspacesPromptTitle":"Vous avez des modifications non enregistrées","confirm":"Valider","contactAdministratorIfIssuePersists":"Si le problème persiste, veuillez contacter votre administrateur système.","contactDetails":"Coordonnées","country":"Pays","countyDistrict":"District","delete":"Supprimer","discard":"Annuler","district":"District","edit":"Modifier","error":"Erreur","errorCopy":"Désolé, il y a eu un problème lors de l\'affichage de cette information. Vous pouvez essayer de rafraîchir cette page ou contacter l\'administrateur du site en mentionnant le code d\'erreur ci-dessus.","female":"Femme","hide":"Cacher","loading":"Chargement","male":"Homme","maximize":"Agrandir","minimize":"Réduire","openAnyway":"Ouvrir malgré tout","other":"Autre","patientIdentifierSticker":"Etiquette d\'identification","patientLists":"Listes","postalCode":"Code postal","print":"Imprimer","printError":"Erreur d\'impression","printErrorExplainer":"Une erreur s\'est produite dans {{errorLocation}}","printIdentifierSticker":"Imprimer l\'etiquette d\'identification","printing":"Impression en cours","relationships":"Relations et liens de parenté","resetOverrides":"Réinitialiser les modifications","save":"Enregistrer","scriptLoadingError":"Échec du chargement du script depuis {{url}}. Veuillez vérifier que le script est disponible à l\'URL spécifiée. Cliquez sur le bouton ci-dessous pour réinitialiser l\'import map","scriptLoadingFailed":"Erreur : Le chargement du script a échoué","seeMoreLists":"Voir {{count}} listes de plus","sex":"Sexe","showLess":"Afficher moins","showMore":"Afficher plus","state":"État","stateProvince":"État","toggleDevTools":"Toggle dev tools","unknown":"Inconnu","unsavedChangesInWorkspace":"Il se peut que des modifications non enregistrées aient été apportées à « {{NomEspace}} ». Veuillez les enregistrer avant d\'ouvrir un autre espace de travail.","unsavedChangesTitleText":"Modifications non enregistrés","workspaceHeader":"En-tête de l\'espace de travail"}');
18
+ module.exports = /*#__PURE__*/JSON.parse('{"actions":"Actions","address":"Adresse","address1":"Adresse: ligne 1","address2":"Adresse: ligne 2","address3":"Adresse : ligne 3","address4":"Adresse : ligne 4","address5":"Adresse : ligne 5","address6":"Adresse : ligne 6","age":"Âge","cancel":"Annuler","change":"Modifier","city":"Ville","cityVillage":"Ville","Clinic":"Clinique","close":"Fermer","closeAllOpenedWorkspaces":"Annuler les modifications dans les {{count}} espaces de travail ","closingAllWorkspacesPromptBody":"Il y a des modifications non enregistrées dans les espaces de travail suivants. Voulez-vous annuler les modifications ? {{workspaceNames}}","closingAllWorkspacesPromptTitle":"Vous avez des modifications non enregistrées","confirm":"Valider","contactAdministratorIfIssuePersists":"Si le problème persiste, veuillez contacter votre administrateur système.","contactDetails":"Coordonnées","country":"Pays","countyDistrict":"District","delete":"Supprimer","discard":"Annuler","district":"District","edit":"Modifier","error":"Erreur","errorCopy":"Désolé, il y a eu un problème lors de l\'affichage de cette information. Vous pouvez essayer de rafraîchir cette page ou contacter l\'administrateur du site en mentionnant le code d\'erreur ci-dessus.","female":"Femme","hide":"Cacher","loading":"Chargement","male":"Homme","maximize":"Agrandir","minimize":"Réduire","openAnyway":"Ouvrir malgré tout","other":"Autre","patientIdentifierSticker":"Etiquette d\'identification","patientLists":"Listes","postalCode":"Code postal","print":"Imprimer","printError":"Erreur d\'impression","printErrorExplainer":"Une erreur s\'est produite dans {{errorLocation}}","printIdentifierSticker":"Imprimer l\'etiquette d\'identification","printing":"Impression en cours","relationships":"Relations et liens de parenté","resetOverrides":"Réinitialiser les modifications","save":"Enregistrer","scriptLoadingError":"Échec du chargement du script depuis {{url}}. Veuillez vérifier que le script est disponible à l\'URL spécifiée. Cliquez sur le bouton ci-dessous pour réinitialiser l\'import map","scriptLoadingFailed":"Erreur : Le chargement du script a échoué","seeMoreLists":"Voir {{count}} listes de plus","sex":"Sexe","showLess":"Afficher moins","showMore":"Afficher plus","state":"État","stateProvince":"État","toggleDevTools":"Toggle dev tools","unknown":"Inconnu","unsavedChangesInWorkspace":"Il se peut que des modifications non enregistrées aient été apportées à « {{NomEspace}} ». Veuillez les enregistrer avant d\'ouvrir un autre espace de travail.","unsavedChangesTitleText":"Modifications non enregistrées","workspaceHeader":"En-tête de l\'espace de travail"}');
19
19
 
20
20
  /***/ })
21
21
 
@@ -1 +1 @@
1
- (()=>{"use strict";var e,r,t,o,n={16929:(e,r,t)=>{var o=t(19287),n={featureName:"devtools",moduleName:"@openmrs/esm-devtools-app"};(0,o.getAsyncLifecycle)((function(){return Promise.all([t.e(796),t.e(277),t.e(357),t.e(180)]).then(t.bind(t,26180))}),n),(0,o.getAsyncLifecycle)((function(){return Promise.all([t.e(796),t.e(277),t.e(357),t.e(907)]).then(t.bind(t,81907))}),n)}},a={};function i(e){var r=a[e];if(void 0!==r)return r.exports;var t=a[e]={id:e,exports:{}};return n[e].call(t.exports,t,t.exports,i),t.exports}i.m=n,i.c=a,i.n=e=>{var r=e&&e.__esModule?()=>e.default:()=>e;return i.d(r,{a:r}),r},r=Object.getPrototypeOf?e=>Object.getPrototypeOf(e):e=>e.__proto__,i.t=function(t,o){if(1&o&&(t=this(t)),8&o)return t;if("object"==typeof t&&t){if(4&o&&t.__esModule)return t;if(16&o&&"function"==typeof t.then)return t}var n=Object.create(null);i.r(n);var a={};e=e||[null,r({}),r([]),r(r)];for(var l=2&o&&t;"object"==typeof l&&!~e.indexOf(l);l=r(l))Object.getOwnPropertyNames(l).forEach((e=>a[e]=()=>t[e]));return a.default=()=>t,i.d(n,a),n},i.d=(e,r)=>{for(var t in r)i.o(r,t)&&!i.o(e,t)&&Object.defineProperty(e,t,{enumerable:!0,get:r[t]})},i.f={},i.e=e=>Promise.all(Object.keys(i.f).reduce(((r,t)=>(i.f[t](e,r),r)),[])),i.u=e=>e+".js",i.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),i.o=(e,r)=>Object.prototype.hasOwnProperty.call(e,r),t={},o="@openmrs/esm-devtools-app:",i.l=(e,r,n,a)=>{if(t[e])t[e].push(r);else{var l,u;if(void 0!==n)for(var s=document.getElementsByTagName("script"),f=0;f<s.length;f++){var p=s[f];if(p.getAttribute("src")==e||p.getAttribute("data-webpack")==o+n){l=p;break}}l||(u=!0,(l=document.createElement("script")).charset="utf-8",l.timeout=120,i.nc&&l.setAttribute("nonce",i.nc),l.setAttribute("data-webpack",o+n),l.src=e),t[e]=[r];var c=(r,o)=>{l.onerror=l.onload=null,clearTimeout(d);var n=t[e];if(delete t[e],l.parentNode&&l.parentNode.removeChild(l),n&&n.forEach((e=>e(o))),r)return r(o)},d=setTimeout(c.bind(null,void 0,{type:"timeout",target:l}),12e4);l.onerror=c.bind(null,l.onerror),l.onload=c.bind(null,l.onload),u&&document.head.appendChild(l)}},i.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},(()=>{i.S={};var e={},r={};i.I=(t,o)=>{o||(o=[]);var n=r[t];if(n||(n=r[t]={}),!(o.indexOf(n)>=0)){if(o.push(n),e[t])return e[t];i.o(i.S,t)||(i.S[t]={});var a=i.S[t],l="@openmrs/esm-devtools-app",u=(e,r,t,o)=>{var n=a[e]=a[e]||{},i=n[r];(!i||!i.loaded&&(!o!=!i.eager?o:l>i.from))&&(n[r]={get:t,from:l,eager:!!o})},s=[];return"default"===t&&(u("@carbon/react","1.83.0",(()=>Promise.all([i.e(932),i.e(769),i.e(796),i.e(420)]).then((()=>()=>i(80769))))),u("@openmrs/esm-framework","8.0.1-pre.3331",(()=>Promise.all([i.e(932),i.e(718),i.e(796),i.e(420),i.e(277),i.e(380),i.e(287)]).then((()=>()=>i(27380))))),u("react-dom","18.2.0",(()=>Promise.all([i.e(623),i.e(796)]).then((()=>()=>i(35623))))),u("react-i18next","11.18.6",(()=>Promise.all([i.e(248),i.e(796)]).then((()=>()=>i(36248))))),u("react","18.2.0",(()=>i.e(326).then((()=>()=>i(86326))))),u("rxjs","6.6.7",(()=>i.e(770).then((()=>()=>i(85770)))))),e[t]=s.length?Promise.all(s).then((()=>e[t]=1)):1}}})(),(()=>{var e;i.g.importScripts&&(e=i.g.location+"");var r=i.g.document;if(!e&&r&&(r.currentScript&&"SCRIPT"===r.currentScript.tagName.toUpperCase()&&(e=r.currentScript.src),!e)){var t=r.getElementsByTagName("script");if(t.length)for(var o=t.length-1;o>-1&&(!e||!/^http(s?):/.test(e));)e=t[o--].src}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/^blob:/,"").replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),i.p=e})(),(()=>{var e=e=>{var r=e=>e.split(".").map((e=>+e==e?+e:e)),t=/^([^-+]+)?(?:-([^+]+))?(?:\+(.+))?$/.exec(e),o=t[1]?r(t[1]):[];return t[2]&&(o.length++,o.push.apply(o,r(t[2]))),t[3]&&(o.push([]),o.push.apply(o,r(t[3]))),o},r=e=>{var t=e[0],o="";if(1===e.length)return"*";if(t+.5){o+=0==t?">=":-1==t?"<":1==t?"^":2==t?"~":t>0?"=":"!=";for(var n=1,a=1;a<e.length;a++)n--,o+="u"==(typeof(l=e[a]))[0]?"-":(n>0?".":"")+(n=2,l);return o}var i=[];for(a=1;a<e.length;a++){var l=e[a];i.push(0===l?"not("+u()+")":1===l?"("+u()+" || "+u()+")":2===l?i.pop()+" "+i.pop():r(l))}return u();function u(){return i.pop().replace(/^\((.+)\)$/,"$1")}},t=(r,o)=>{if(0 in r){o=e(o);var n=r[0],a=n<0;a&&(n=-n-1);for(var i=0,l=1,u=!0;;l++,i++){var s,f,p=l<r.length?(typeof r[l])[0]:"";if(i>=o.length||"o"==(f=(typeof(s=o[i]))[0]))return!u||("u"==p?l>n&&!a:""==p!=a);if("u"==f){if(!u||"u"!=p)return!1}else if(u)if(p==f)if(l<=n){if(s!=r[l])return!1}else{if(a?s>r[l]:s<r[l])return!1;s!=r[l]&&(u=!1)}else if("s"!=p&&"n"!=p){if(a||l<=n)return!1;u=!1,l--}else{if(l<=n||f<p!=a)return!1;u=!1}else"s"!=p&&"n"!=p&&(u=!1,l--)}}var c=[],d=c.pop.bind(c);for(i=1;i<r.length;i++){var h=r[i];c.push(1==h?d()|d():2==h?d()&d():h?t(h,o):!d())}return!!d()},o=(e,r)=>e&&i.o(e,r),n=e=>(e.loaded=1,e.get()),a=(r,t,o)=>{var n=o?(e=>Object.keys(e).reduce(((r,t)=>(e[t].eager&&(r[t]=e[t]),r)),{}))(r[t]):r[t];return Object.keys(n).reduce(((r,t)=>!r||!n[r].loaded&&((r,t)=>{r=e(r),t=e(t);for(var o=0;;){if(o>=r.length)return o<t.length&&"u"!=(typeof t[o])[0];var n=r[o],a=(typeof n)[0];if(o>=t.length)return"u"==a;var i=t[o],l=(typeof i)[0];if(a!=l)return"o"==a&&"n"==l||"s"==l||"u"==a;if("o"!=a&&"u"!=a&&n!=i)return n<i;o++}})(r,t)?t:r),0)},l=e=>function(r,t,o,n,a){var l=i.I(r);return l&&l.then&&!o?l.then(e.bind(e,r,i.S[r],t,!1,n,a)):e(r,i.S[r],t,o,n,a)},u=(e,r,t)=>t?t():((e,r)=>(e=>{throw new Error(e)})("Shared module "+r+" doesn't exist in shared scope "+e))(e,r),s=l(((e,r,t,i,l)=>{if(!o(r,t))return u(e,t,l);var s=a(r,t,i);return n(r[t][s])})),f=l(((e,i,l,s,f,p)=>{if(!o(i,l))return u(e,l,p);var c,d=a(i,l,s);return t(f,d)||(c=((e,t,o,n)=>"Unsatisfied version "+o+" from "+(o&&e[t][o].from)+" of shared singleton module "+t+" (required "+r(n)+")")(i,l,d,f),"undefined"!=typeof console&&console.warn&&console.warn(c)),n(i[l][d])})),p={},c={19287:()=>f("default","@openmrs/esm-framework",!1,[0],(()=>Promise.all([i.e(932),i.e(718),i.e(796),i.e(420),i.e(277),i.e(380)]).then((()=>()=>i(27380))))),20796:()=>f("default","react",!1,[1,18],(()=>i.e(326).then((()=>()=>i(86326))))),11555:()=>f("default","react-i18next",!1,[1,11],(()=>i.e(248).then((()=>()=>i(36248))))),95315:()=>f("default","@carbon/react",!1,[1,1],(()=>Promise.all([i.e(932),i.e(769),i.e(420)]).then((()=>()=>i(80769))))),14357:()=>s("default","@openmrs/esm-framework/src/internal",!1,(()=>Promise.all([i.e(932),i.e(718),i.e(420),i.e(380)]).then((()=>()=>i(27380))))),91420:()=>f("default","react-dom",!1,[1,18],(()=>i.e(623).then((()=>()=>i(35623))))),87633:()=>f("default","rxjs",!1,[1,6],(()=>i.e(770).then((()=>()=>i(85770)))))};[19287].forEach((e=>{i.m[e]=r=>{p[e]=0,delete i.c[e];var t=c[e]();if("function"!=typeof t)throw new Error("Shared module is not available for eager consumption: "+e);r.exports=t()}}));var d={277:[11555,95315],287:[19287],357:[14357],380:[87633],420:[91420],792:[19287],796:[20796]},h={};i.f.consumes=(e,r)=>{i.o(d,e)&&d[e].forEach((e=>{if(i.o(p,e))return r.push(p[e]);if(!h[e]){var t=r=>{p[e]=0,i.m[e]=t=>{delete i.c[e],t.exports=r()}};h[e]=!0;var o=r=>{delete p[e],i.m[e]=t=>{throw delete i.c[e],r}};try{var n=c[e]();n.then?r.push(p[e]=n.then(t).catch(o)):t(n)}catch(e){o(e)}}}))}})(),(()=>{var e={287:0,792:0,929:0};i.f.j=(r,t)=>{var o=i.o(e,r)?e[r]:void 0;if(0!==o)if(o)t.push(o[2]);else if(/^((27|28|35)7|420|796)$/.test(r))e[r]=0;else{var n=new Promise(((t,n)=>o=e[r]=[t,n]));t.push(o[2]=n);var a=i.p+i.u(r),l=new Error;i.l(a,(t=>{if(i.o(e,r)&&(0!==(o=e[r])&&(e[r]=void 0),o)){var n=t&&("load"===t.type?"missing":t.type),a=t&&t.target&&t.target.src;l.message="Loading chunk "+r+" failed.\n("+n+": "+a+")",l.name="ChunkLoadError",l.type=n,l.request=a,o[1](l)}}),"chunk-"+r,r)}};var r=(r,t)=>{var o,n,[a,l,u]=t,s=0;if(a.some((r=>0!==e[r]))){for(o in l)i.o(l,o)&&(i.m[o]=l[o]);u&&u(i)}for(r&&r(t);s<a.length;s++)n=a[s],i.o(e,n)&&e[n]&&e[n][0](),e[n]=0},t=globalThis.webpackChunk_openmrs_esm_devtools_app=globalThis.webpackChunk_openmrs_esm_devtools_app||[];t.forEach(r.bind(null,0)),t.push=r.bind(null,t.push.bind(t))})(),i.nc=void 0,i(16929)})();
1
+ (()=>{"use strict";var e,r,t,o,n={16929:(e,r,t)=>{var o=t(19287),n={featureName:"devtools",moduleName:"@openmrs/esm-devtools-app"};(0,o.getAsyncLifecycle)((function(){return Promise.all([t.e(796),t.e(277),t.e(357),t.e(180)]).then(t.bind(t,26180))}),n),(0,o.getAsyncLifecycle)((function(){return Promise.all([t.e(796),t.e(277),t.e(357),t.e(907)]).then(t.bind(t,81907))}),n)}},a={};function i(e){var r=a[e];if(void 0!==r)return r.exports;var t=a[e]={id:e,exports:{}};return n[e].call(t.exports,t,t.exports,i),t.exports}i.m=n,i.c=a,i.n=e=>{var r=e&&e.__esModule?()=>e.default:()=>e;return i.d(r,{a:r}),r},r=Object.getPrototypeOf?e=>Object.getPrototypeOf(e):e=>e.__proto__,i.t=function(t,o){if(1&o&&(t=this(t)),8&o)return t;if("object"==typeof t&&t){if(4&o&&t.__esModule)return t;if(16&o&&"function"==typeof t.then)return t}var n=Object.create(null);i.r(n);var a={};e=e||[null,r({}),r([]),r(r)];for(var l=2&o&&t;"object"==typeof l&&!~e.indexOf(l);l=r(l))Object.getOwnPropertyNames(l).forEach((e=>a[e]=()=>t[e]));return a.default=()=>t,i.d(n,a),n},i.d=(e,r)=>{for(var t in r)i.o(r,t)&&!i.o(e,t)&&Object.defineProperty(e,t,{enumerable:!0,get:r[t]})},i.f={},i.e=e=>Promise.all(Object.keys(i.f).reduce(((r,t)=>(i.f[t](e,r),r)),[])),i.u=e=>e+".js",i.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}}(),i.o=(e,r)=>Object.prototype.hasOwnProperty.call(e,r),t={},o="@openmrs/esm-devtools-app:",i.l=(e,r,n,a)=>{if(t[e])t[e].push(r);else{var l,u;if(void 0!==n)for(var s=document.getElementsByTagName("script"),f=0;f<s.length;f++){var p=s[f];if(p.getAttribute("src")==e||p.getAttribute("data-webpack")==o+n){l=p;break}}l||(u=!0,(l=document.createElement("script")).charset="utf-8",l.timeout=120,i.nc&&l.setAttribute("nonce",i.nc),l.setAttribute("data-webpack",o+n),l.src=e),t[e]=[r];var c=(r,o)=>{l.onerror=l.onload=null,clearTimeout(d);var n=t[e];if(delete t[e],l.parentNode&&l.parentNode.removeChild(l),n&&n.forEach((e=>e(o))),r)return r(o)},d=setTimeout(c.bind(null,void 0,{type:"timeout",target:l}),12e4);l.onerror=c.bind(null,l.onerror),l.onload=c.bind(null,l.onload),u&&document.head.appendChild(l)}},i.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},(()=>{i.S={};var e={},r={};i.I=(t,o)=>{o||(o=[]);var n=r[t];if(n||(n=r[t]={}),!(o.indexOf(n)>=0)){if(o.push(n),e[t])return e[t];i.o(i.S,t)||(i.S[t]={});var a=i.S[t],l="@openmrs/esm-devtools-app",u=(e,r,t,o)=>{var n=a[e]=a[e]||{},i=n[r];(!i||!i.loaded&&(!o!=!i.eager?o:l>i.from))&&(n[r]={get:t,from:l,eager:!!o})},s=[];return"default"===t&&(u("@carbon/react","1.83.0",(()=>Promise.all([i.e(932),i.e(769),i.e(796),i.e(420)]).then((()=>()=>i(80769))))),u("@openmrs/esm-framework","8.0.1-pre.3349",(()=>Promise.all([i.e(932),i.e(718),i.e(796),i.e(420),i.e(277),i.e(380),i.e(287)]).then((()=>()=>i(27380))))),u("react-dom","18.2.0",(()=>Promise.all([i.e(623),i.e(796)]).then((()=>()=>i(35623))))),u("react-i18next","11.18.6",(()=>Promise.all([i.e(248),i.e(796)]).then((()=>()=>i(36248))))),u("react","18.2.0",(()=>i.e(326).then((()=>()=>i(86326))))),u("rxjs","6.6.7",(()=>i.e(770).then((()=>()=>i(85770)))))),e[t]=s.length?Promise.all(s).then((()=>e[t]=1)):1}}})(),(()=>{var e;i.g.importScripts&&(e=i.g.location+"");var r=i.g.document;if(!e&&r&&(r.currentScript&&"SCRIPT"===r.currentScript.tagName.toUpperCase()&&(e=r.currentScript.src),!e)){var t=r.getElementsByTagName("script");if(t.length)for(var o=t.length-1;o>-1&&(!e||!/^http(s?):/.test(e));)e=t[o--].src}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/^blob:/,"").replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),i.p=e})(),(()=>{var e=e=>{var r=e=>e.split(".").map((e=>+e==e?+e:e)),t=/^([^-+]+)?(?:-([^+]+))?(?:\+(.+))?$/.exec(e),o=t[1]?r(t[1]):[];return t[2]&&(o.length++,o.push.apply(o,r(t[2]))),t[3]&&(o.push([]),o.push.apply(o,r(t[3]))),o},r=e=>{var t=e[0],o="";if(1===e.length)return"*";if(t+.5){o+=0==t?">=":-1==t?"<":1==t?"^":2==t?"~":t>0?"=":"!=";for(var n=1,a=1;a<e.length;a++)n--,o+="u"==(typeof(l=e[a]))[0]?"-":(n>0?".":"")+(n=2,l);return o}var i=[];for(a=1;a<e.length;a++){var l=e[a];i.push(0===l?"not("+u()+")":1===l?"("+u()+" || "+u()+")":2===l?i.pop()+" "+i.pop():r(l))}return u();function u(){return i.pop().replace(/^\((.+)\)$/,"$1")}},t=(r,o)=>{if(0 in r){o=e(o);var n=r[0],a=n<0;a&&(n=-n-1);for(var i=0,l=1,u=!0;;l++,i++){var s,f,p=l<r.length?(typeof r[l])[0]:"";if(i>=o.length||"o"==(f=(typeof(s=o[i]))[0]))return!u||("u"==p?l>n&&!a:""==p!=a);if("u"==f){if(!u||"u"!=p)return!1}else if(u)if(p==f)if(l<=n){if(s!=r[l])return!1}else{if(a?s>r[l]:s<r[l])return!1;s!=r[l]&&(u=!1)}else if("s"!=p&&"n"!=p){if(a||l<=n)return!1;u=!1,l--}else{if(l<=n||f<p!=a)return!1;u=!1}else"s"!=p&&"n"!=p&&(u=!1,l--)}}var c=[],d=c.pop.bind(c);for(i=1;i<r.length;i++){var h=r[i];c.push(1==h?d()|d():2==h?d()&d():h?t(h,o):!d())}return!!d()},o=(e,r)=>e&&i.o(e,r),n=e=>(e.loaded=1,e.get()),a=(r,t,o)=>{var n=o?(e=>Object.keys(e).reduce(((r,t)=>(e[t].eager&&(r[t]=e[t]),r)),{}))(r[t]):r[t];return Object.keys(n).reduce(((r,t)=>!r||!n[r].loaded&&((r,t)=>{r=e(r),t=e(t);for(var o=0;;){if(o>=r.length)return o<t.length&&"u"!=(typeof t[o])[0];var n=r[o],a=(typeof n)[0];if(o>=t.length)return"u"==a;var i=t[o],l=(typeof i)[0];if(a!=l)return"o"==a&&"n"==l||"s"==l||"u"==a;if("o"!=a&&"u"!=a&&n!=i)return n<i;o++}})(r,t)?t:r),0)},l=e=>function(r,t,o,n,a){var l=i.I(r);return l&&l.then&&!o?l.then(e.bind(e,r,i.S[r],t,!1,n,a)):e(r,i.S[r],t,o,n,a)},u=(e,r,t)=>t?t():((e,r)=>(e=>{throw new Error(e)})("Shared module "+r+" doesn't exist in shared scope "+e))(e,r),s=l(((e,r,t,i,l)=>{if(!o(r,t))return u(e,t,l);var s=a(r,t,i);return n(r[t][s])})),f=l(((e,i,l,s,f,p)=>{if(!o(i,l))return u(e,l,p);var c,d=a(i,l,s);return t(f,d)||(c=((e,t,o,n)=>"Unsatisfied version "+o+" from "+(o&&e[t][o].from)+" of shared singleton module "+t+" (required "+r(n)+")")(i,l,d,f),"undefined"!=typeof console&&console.warn&&console.warn(c)),n(i[l][d])})),p={},c={19287:()=>f("default","@openmrs/esm-framework",!1,[0],(()=>Promise.all([i.e(932),i.e(718),i.e(796),i.e(420),i.e(277),i.e(380)]).then((()=>()=>i(27380))))),20796:()=>f("default","react",!1,[1,18],(()=>i.e(326).then((()=>()=>i(86326))))),11555:()=>f("default","react-i18next",!1,[1,11],(()=>i.e(248).then((()=>()=>i(36248))))),95315:()=>f("default","@carbon/react",!1,[1,1],(()=>Promise.all([i.e(932),i.e(769),i.e(420)]).then((()=>()=>i(80769))))),14357:()=>s("default","@openmrs/esm-framework/src/internal",!1,(()=>Promise.all([i.e(932),i.e(718),i.e(420),i.e(380)]).then((()=>()=>i(27380))))),91420:()=>f("default","react-dom",!1,[1,18],(()=>i.e(623).then((()=>()=>i(35623))))),87633:()=>f("default","rxjs",!1,[1,6],(()=>i.e(770).then((()=>()=>i(85770)))))};[19287].forEach((e=>{i.m[e]=r=>{p[e]=0,delete i.c[e];var t=c[e]();if("function"!=typeof t)throw new Error("Shared module is not available for eager consumption: "+e);r.exports=t()}}));var d={277:[11555,95315],287:[19287],357:[14357],380:[87633],420:[91420],792:[19287],796:[20796]},h={};i.f.consumes=(e,r)=>{i.o(d,e)&&d[e].forEach((e=>{if(i.o(p,e))return r.push(p[e]);if(!h[e]){var t=r=>{p[e]=0,i.m[e]=t=>{delete i.c[e],t.exports=r()}};h[e]=!0;var o=r=>{delete p[e],i.m[e]=t=>{throw delete i.c[e],r}};try{var n=c[e]();n.then?r.push(p[e]=n.then(t).catch(o)):t(n)}catch(e){o(e)}}}))}})(),(()=>{var e={287:0,792:0,929:0};i.f.j=(r,t)=>{var o=i.o(e,r)?e[r]:void 0;if(0!==o)if(o)t.push(o[2]);else if(/^((27|28|35)7|420|796)$/.test(r))e[r]=0;else{var n=new Promise(((t,n)=>o=e[r]=[t,n]));t.push(o[2]=n);var a=i.p+i.u(r),l=new Error;i.l(a,(t=>{if(i.o(e,r)&&(0!==(o=e[r])&&(e[r]=void 0),o)){var n=t&&("load"===t.type?"missing":t.type),a=t&&t.target&&t.target.src;l.message="Loading chunk "+r+" failed.\n("+n+": "+a+")",l.name="ChunkLoadError",l.type=n,l.request=a,o[1](l)}}),"chunk-"+r,r)}};var r=(r,t)=>{var o,n,[a,l,u]=t,s=0;if(a.some((r=>0!==e[r]))){for(o in l)i.o(l,o)&&(i.m[o]=l[o]);u&&u(i)}for(r&&r(t);s<a.length;s++)n=a[s],i.o(e,n)&&e[n]&&e[n][0](),e[n]=0},t=globalThis.webpackChunk_openmrs_esm_devtools_app=globalThis.webpackChunk_openmrs_esm_devtools_app||[];t.forEach(r.bind(null,0)),t.push=r.bind(null,t.push.bind(t))})(),i.nc=void 0,i(16929)})();