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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (50) hide show
  1. package/.turbo/turbo-build.log +9 -9
  2. package/dist/1aae2824ab4cfb18.js.map +1 -0
  3. package/dist/3a53ffcc01189e32.js.map +1 -0
  4. package/dist/6424d3e282801be1.js.map +1 -0
  5. package/dist/ce6b7df8d10e9ce8.js.map +1 -0
  6. package/dist/index.html +1 -1
  7. package/dist/{openmrs.9d2c16ca3f8dd751.js → openmrs.6e296921eb685274.js} +1 -1
  8. package/dist/{openmrs.9d2c16ca3f8dd751.js.map → openmrs.6e296921eb685274.js.map} +1 -1
  9. package/dist/service-worker.js +1 -1
  10. package/lib/{f6407c15881d934e.js → 5eb49ace081ba40a.js} +29 -29
  11. package/lib/{f6511157fbbd5327.js → a2ed1505d14f2a59.js} +1 -1
  12. package/lib/{3638c8e3f0e987f1.js → d9f2f67efb776126.js} +12 -12
  13. package/lib/esm-help-menu-app/460.js.map +1 -1
  14. package/lib/esm-help-menu-app/main.js +1 -1
  15. package/lib/esm-help-menu-app/openmrs-esm-help-menu-app.js +1 -1
  16. package/lib/esm-help-menu-app/openmrs-esm-help-menu-app.js.buildmanifest.json +5 -5
  17. package/lib/esm-help-menu-app/routes.json +1 -1
  18. package/lib/esm-implementer-tools-app/5460.js.map +1 -1
  19. package/lib/esm-implementer-tools-app/main.js +1 -1
  20. package/lib/esm-implementer-tools-app/openmrs-esm-implementer-tools-app.js +1 -1
  21. package/lib/esm-implementer-tools-app/openmrs-esm-implementer-tools-app.js.buildmanifest.json +5 -5
  22. package/lib/esm-implementer-tools-app/routes.json +1 -1
  23. package/lib/esm-login-app/14.js.map +1 -1
  24. package/lib/esm-login-app/main.js +1 -1
  25. package/lib/esm-login-app/openmrs-esm-login-app.js +1 -1
  26. package/lib/esm-login-app/openmrs-esm-login-app.js.buildmanifest.json +5 -5
  27. package/lib/esm-login-app/routes.json +1 -1
  28. package/lib/esm-offline-tools-app/5460.js.map +1 -1
  29. package/lib/esm-offline-tools-app/main.js +1 -1
  30. package/lib/esm-offline-tools-app/openmrs-esm-offline-tools-app.js +1 -1
  31. package/lib/esm-offline-tools-app/openmrs-esm-offline-tools-app.js.buildmanifest.json +5 -5
  32. package/lib/esm-offline-tools-app/routes.json +1 -1
  33. package/lib/esm-primary-navigation-app/5460.js.map +1 -1
  34. package/lib/esm-primary-navigation-app/main.js +1 -1
  35. package/lib/esm-primary-navigation-app/openmrs-esm-primary-navigation-app.js +1 -1
  36. package/lib/esm-primary-navigation-app/openmrs-esm-primary-navigation-app.js.buildmanifest.json +5 -5
  37. package/lib/esm-primary-navigation-app/routes.json +1 -1
  38. package/lib/{abbcede00223b828.js → fa464755b8e8e50b.js} +3 -3
  39. package/lib/index.html +1 -1
  40. package/lib/openmrs.js +9 -9
  41. package/lib/service-worker.js +1 -1
  42. package/package.json +3 -3
  43. package/dist/1d1bdf194ce3de30.js.map +0 -1
  44. package/dist/22d92f2e1d413f13.js.map +0 -1
  45. package/dist/5916e32850548842.js.map +0 -1
  46. package/dist/cab43002f9e725ab.js.map +0 -1
  47. /package/dist/{1d1bdf194ce3de30.js → 1aae2824ab4cfb18.js} +0 -0
  48. /package/dist/{cab43002f9e725ab.js → 3a53ffcc01189e32.js} +0 -0
  49. /package/dist/{22d92f2e1d413f13.js → 6424d3e282801be1.js} +0 -0
  50. /package/dist/{5916e32850548842.js → ce6b7df8d10e9ce8.js} +0 -0
@@ -265,7 +265,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
265
265
  \*******************************************************************/
266
266
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
267
267
 
268
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ getCurrentImportMap: () => (/* binding */ getCurrentImportMap),\n/* harmony export */ importDynamic: () => (/* binding */ importDynamic),\n/* harmony export */ preloadImport: () => (/* binding */ preloadImport),\n/* harmony export */ slugify: () => (/* binding */ slugify)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-globals */ \"../../framework/esm-globals/dist/index.js\");\n/* harmony import */ var _openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-translations */ \"../../framework/esm-translations/dist/index.js\");\n/** @module @category Dynamic Loading */ \n// hack to make the types defined in esm-globals available here\n\n\n/**\n * @internal\n *\n * Transforms an ESM module name to a valid JS identifier\n *\n * @param name the name of a module\n * @returns An opaque, equivalent JS identifier for the module\n */ function slugify(name) {\n return name.replace(/[\\/\\-@]/g, '_');\n}\n/**\n * Loads the named export from a named package. This might be used like:\n *\n * ```js\n * const { someComponent } = importDynamic(\"@openmrs/esm-template-app\")\n * ```\n *\n * @param jsPackage The package to load the export from.\n * @param share Indicates the name of the shared module; this is an advanced feature if the package you are loading\n * doesn't use the default OpenMRS shared module name \"./start\".\n * @param options Additional options to control loading this script.\n * @param options.importMap The import map to use to load the script. This is useful for situations where you're\n * loading multiple scripts at a time, since it allows the calling code to supply an importMap, saving multiple\n * calls to `getCurrentImportMap()`.\n * @param options.maxLoadingTime A positive integer representing the maximum number of milliseconds to wait for the\n * script to load before the promise returned from this function will be rejected. Defaults to 600,000 milliseconds,\n * i.e., 10 minutes.\n */ async function importDynamic(jsPackage, share = './start', options) {\n // default to 10 minutes\n const maxLoadingTime = !options?.maxLoadingTime || options.maxLoadingTime <= 0 ? 600000 : options.maxLoadingTime;\n let timeout = undefined;\n await Promise.race([\n preloadImport(jsPackage, options?.importMap),\n new Promise((_, reject)=>{\n timeout = setTimeout(()=>{\n reject(new Error(`Could not resolve requested script, ${jsPackage}, within ${humanReadableMs(maxLoadingTime)}.`));\n }, maxLoadingTime);\n })\n ]);\n if (timeout) {\n clearTimeout(timeout);\n }\n const jsPackageSlug = slugify(jsPackage);\n const container = window[jsPackageSlug];\n if (!isFederatedModule(container)) {\n const error = `The global variable ${jsPackageSlug} does not refer to a federated module`;\n console.error(error);\n throw new Error(error);\n }\n container.init(__webpack_require__.S.default);\n const factory = await container.get(share);\n const module = factory();\n if (!(typeof module === 'object') || module === null) {\n const error = `Container for ${jsPackage} did not return an ESM module as expected`;\n console.error(error);\n throw new Error(error);\n }\n return module;\n}\n/**\n * Utility function to convert milliseconds into human-readable strings with rather absurd\n * levels of precision.\n *\n * @param ms Number of milliseconds\n * @returns A human-readable string useful only for error logging, where we can assume English\n */ function humanReadableMs(ms) {\n if (ms < 1000) {\n return `${ms} milliseconds`;\n } else if (ms < 60000) {\n return `${Math.floor(ms / 1000)} seconds`;\n } else if (ms < 3600000) {\n return `${Math.floor(ms / 60000)} minutes`;\n } else if (ms < 86400000) {\n return `${Math.floor(ms / 3600000)} hours`;\n } else {\n return `${Math.floor(ms / 86400000)} days`;\n }\n}\n/**\n * @internal\n *\n * This internal method is used to ensure that the script belonging\n * to the given package is loaded and added to the head.\n *\n * @param jsPackage The package to load\n * @param importMap The import map to use for loading this package.\n * The main reason for specifying this is to avoid needing to call\n * `getCurrentPageMap()` for every script when bulk loading.\n */ async function preloadImport(jsPackage, importMap) {\n if (typeof jsPackage !== 'string' || jsPackage.trim().length === 0) {\n const error = 'Attempted to call importDynamic() without supplying a package to load';\n console.error(error);\n throw new Error(error);\n }\n const jsPackageSlug = slugify(jsPackage);\n if (!window[jsPackageSlug]) {\n const activeImportMap = importMap ?? await getCurrentImportMap();\n if (!activeImportMap.imports.hasOwnProperty(jsPackage)) {\n const error = `Could not find the package ${jsPackage} defined in the current importmap`;\n console.error(error);\n throw new Error(error);\n }\n let url = activeImportMap.imports[jsPackage];\n if (url.startsWith('./')) {\n url = window.spaBase + url.substring(1);\n }\n const isOverridden = !!window.localStorage.getItem(`import-map-override:${jsPackage}`);\n try {\n return await new Promise((resolve, reject)=>{\n loadScript(url, resolve, reject);\n });\n } catch (err) {\n if (isOverridden) {\n (0,_openmrs_esm_globals__WEBPACK_IMPORTED_MODULE_0__.dispatchToastShown)({\n kind: 'error',\n title: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_1__.getCoreTranslation)('scriptLoadingFailed', 'Error: Script failed to load'),\n description: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_1__.getCoreTranslation)('scriptLoadingError', 'Failed to load overridden script from {{- url}}. Please check that the bundled script is available at the expected URL. Click the button below to reset all import map overrides.', {\n url\n }),\n actionButtonLabel: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_1__.getCoreTranslation)('resetOverrides', 'Reset overrides'),\n onActionButtonClick () {\n window.importMapOverrides.resetOverrides();\n window.location.reload();\n }\n });\n }\n return Promise.reject(err);\n }\n }\n return Promise.resolve();\n}\n/**\n * @internal\n *\n * Used to load the current import map\n *\n * @returns The current page map\n */ async function getCurrentImportMap() {\n return window.importMapOverrides.getCurrentPageMap();\n}\nfunction isFederatedModule(a) {\n return typeof a === 'object' && a !== null && 'init' in a && typeof a['init'] === 'function' && 'get' in a && typeof a['get'] === 'function';\n}\n// internals to track script loading\n// basically, if we're already loading a script, we should wait until the script is loaded\n// we use a global to track this\nconst OPENMRS_SCRIPT_LOADING = Symbol('__openmrs_script_loading');\n/**\n * Appends a `<script>` to the DOM with the given URL.\n */ function loadScript(url, resolve, reject) {\n const scriptElement = document.head.querySelector(`script[src=\"${url}\"]`);\n let scriptLoading = window[OPENMRS_SCRIPT_LOADING];\n if (!scriptLoading) {\n scriptLoading = window[OPENMRS_SCRIPT_LOADING] = new Set([]);\n }\n if (!scriptElement) {\n scriptLoading.add(url);\n const element = document.createElement('script');\n element.src = url;\n element.type = 'text/javascript';\n element.async = true;\n // loadTime() displays an error if a script takes more than 5 seconds to load\n const loadTimeout = setTimeout(()=>{\n console.error(`The script at ${url} did not load within 5 seconds. This may indicate an issue with the imports in the script's entry-point file or with the script's bundler configuration.`);\n }, 5000); // 5 seconds; this is arbitrary\n let loadFn, errFn, finishScriptLoading;\n finishScriptLoading = ()=>{\n clearTimeout(loadTimeout);\n scriptLoading.delete(url);\n if (loadFn) {\n element.removeEventListener('load', loadFn);\n }\n if (errFn) {\n element.removeEventListener('error', errFn);\n }\n };\n loadFn = ()=>{\n finishScriptLoading();\n resolve(null);\n };\n errFn = (ev)=>{\n finishScriptLoading();\n const msg = `Failed to load script from ${url}`;\n console.error(msg, ev);\n reject(ev.message ?? msg);\n };\n element.addEventListener('load', loadFn);\n element.addEventListener('error', errFn);\n document.head.appendChild(element);\n } else {\n if (scriptLoading.has(url)) {\n let loadFn, errFn, finishScriptLoading;\n finishScriptLoading = ()=>{\n if (loadFn) {\n scriptElement.removeEventListener('load', loadFn);\n }\n if (errFn) {\n scriptElement.removeEventListener('error', errFn);\n }\n };\n loadFn = ()=>{\n finishScriptLoading();\n resolve(null);\n };\n // this errFn does not log anything\n errFn = (ev)=>{\n finishScriptLoading();\n reject(ev.message);\n };\n scriptElement.addEventListener('load', loadFn);\n scriptElement.addEventListener('error', errFn);\n } else {\n console.warn(`Script at ${url} already loaded. Not loading it again.`);\n resolve(null);\n }\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-dynamic-loading/dist/dynamic-loading.js","mappings":";;;;;;;;;AAAA,sCAAsC,GAAgB;AACtD,+DAA+D;AACL;AACK;AAC/D;;;;;;;CAOC,GAAU,SAASE,QAAQC,IAAI;IAC5B,OAAOA,KAAKC,OAAO,CAAC,YAAY;AACpC;AACA;;;;;;;;;;;;;;;;;CAiBC,GAAU,eAAeC,cAAcC,SAAS,EAAEC,QAAQ,SAAS,EAAEC,OAAO;IACzE,wBAAwB;IACxB,MAAMC,iBAAiB,CAACD,SAASC,kBAAkBD,QAAQC,cAAc,IAAI,IAAI,SAASD,QAAQC,cAAc;IAChH,IAAIC,UAAUC;IACd,MAAMC,QAAQC,IAAI,CAAC;QACfC,cAAcR,WAAWE,SAASO;QAClC,IAAIH,QAAQ,CAACI,GAAGC;YACZP,UAAUQ,WAAW;gBACjBD,OAAO,IAAIE,MAAM,CAAC,oCAAoC,EAAEb,UAAU,SAAS,EAAEc,gBAAgBX,gBAAgB,CAAC,CAAC;YACnH,GAAGA;QACP;KACH;IACD,IAAIC,SAAS;QACTW,aAAaX;IACjB;IACA,MAAMY,gBAAgBpB,QAAQI;IAC9B,MAAMiB,YAAYC,MAAM,CAACF,cAAc;IACvC,IAAI,CAACG,kBAAkBF,YAAY;QAC/B,MAAMG,QAAQ,CAAC,oBAAoB,EAAEJ,cAAc,qCAAqC,CAAC;QACzFK,QAAQD,KAAK,CAACA;QACd,MAAM,IAAIP,MAAMO;IACpB;IACAH,UAAUK,IAAI,CAACC,qBAAwBA,CAACC,OAAO;IAC/C,MAAMC,UAAU,MAAMR,UAAUS,GAAG,CAACzB;IACpC,MAAM0B,SAASF;IACf,IAAI,CAAE,QAAOE,WAAW,QAAO,KAAMA,WAAW,MAAM;QAClD,MAAMP,QAAQ,CAAC,cAAc,EAAEpB,UAAU,yCAAyC,CAAC;QACnFqB,QAAQD,KAAK,CAACA;QACd,MAAM,IAAIP,MAAMO;IACpB;IACA,OAAOO;AACX;AACA;;;;;;CAMC,GAAG,SAASb,gBAAgBc,EAAE;IAC3B,IAAIA,KAAK,MAAM;QACX,OAAO,GAAGA,GAAG,aAAa,CAAC;IAC/B,OAAO,IAAIA,KAAK,OAAO;QACnB,OAAO,GAAGC,KAAKC,KAAK,CAACF,KAAK,MAAM,QAAQ,CAAC;IAC7C,OAAO,IAAIA,KAAK,SAAS;QACrB,OAAO,GAAGC,KAAKC,KAAK,CAACF,KAAK,OAAO,QAAQ,CAAC;IAC9C,OAAO,IAAIA,KAAK,UAAU;QACtB,OAAO,GAAGC,KAAKC,KAAK,CAACF,KAAK,SAAS,MAAM,CAAC;IAC9C,OAAO;QACH,OAAO,GAAGC,KAAKC,KAAK,CAACF,KAAK,UAAU,KAAK,CAAC;IAC9C;AACJ;AACA;;;;;;;;;;CAUC,GAAU,eAAepB,cAAcR,SAAS,EAAES,SAAS;IACxD,IAAI,OAAOT,cAAc,YAAYA,UAAU+B,IAAI,GAAGC,MAAM,KAAK,GAAG;QAChE,MAAMZ,QAAQ;QACdC,QAAQD,KAAK,CAACA;QACd,MAAM,IAAIP,MAAMO;IACpB;IACA,MAAMJ,gBAAgBpB,QAAQI;IAC9B,IAAI,CAACkB,MAAM,CAACF,cAAc,EAAE;QACxB,MAAMiB,kBAAkBxB,aAAa,MAAMyB;QAC3C,IAAI,CAACD,gBAAgBE,OAAO,CAACC,cAAc,CAACpC,YAAY;YACpD,MAAMoB,QAAQ,CAAC,2BAA2B,EAAEpB,UAAU,iCAAiC,CAAC;YACxFqB,QAAQD,KAAK,CAACA;YACd,MAAM,IAAIP,MAAMO;QACpB;QACA,IAAIiB,MAAMJ,gBAAgBE,OAAO,CAACnC,UAAU;QAC5C,IAAIqC,IAAIC,UAAU,CAAC,OAAO;YACtBD,MAAMnB,OAAOqB,OAAO,GAAGF,IAAIG,SAAS,CAAC;QACzC;QACA,MAAMC,eAAe,CAAC,CAACvB,OAAOwB,YAAY,CAACC,OAAO,CAAC,CAAC,oBAAoB,EAAE3C,WAAW;QACrF,IAAI;YACA,OAAO,MAAM,IAAIM,QAAQ,CAACsC,SAASjC;gBAC/BkC,WAAWR,KAAKO,SAASjC;YAC7B;QACJ,EAAE,OAAOmC,KAAK;YACV,IAAIL,cAAc;gBACd/C,wEAAkBA,CAAC;oBACfqD,MAAM;oBACNC,OAAOrD,6EAAkBA,CAAC,uBAAuB;oBACjDsD,aAAatD,6EAAkBA,CAAC,sBAAsB,qLAAqL;wBACvO0C;oBACJ;oBACAa,mBAAmBvD,6EAAkBA,CAAC,kBAAkB;oBACxDwD;wBACIjC,OAAOkC,kBAAkB,CAACC,cAAc;wBACxCnC,OAAOoC,QAAQ,CAACC,MAAM;oBAC1B;gBACJ;YACJ;YACA,OAAOjD,QAAQK,MAAM,CAACmC;QAC1B;IACJ;IACA,OAAOxC,QAAQsC,OAAO;AAC1B;AACA;;;;;;CAMC,GAAU,eAAeV;IACtB,OAAOhB,OAAOkC,kBAAkB,CAACI,iBAAiB;AACtD;AACA,SAASrC,kBAAkBsC,CAAC;IACxB,OAAO,OAAOA,MAAM,YAAYA,MAAM,QAAQ,UAAUA,KAAK,OAAOA,CAAC,CAAC,OAAO,KAAK,cAAc,SAASA,KAAK,OAAOA,CAAC,CAAC,MAAM,KAAK;AACtI;AACA,oCAAoC;AACpC,0FAA0F;AAC1F,gCAAgC;AAChC,MAAMC,yBAAyBC,OAAO;AACtC;;CAEC,GAAG,SAASd,WAAWR,GAAG,EAAEO,OAAO,EAAEjC,MAAM;IACxC,MAAMiD,gBAAgBC,SAASC,IAAI,CAACC,aAAa,CAAC,CAAC,YAAY,EAAE1B,IAAI,EAAE,CAAC;IACxE,IAAI2B,gBAAgB9C,MAAM,CAACwC,uBAAuB;IAClD,IAAI,CAACM,eAAe;QAChBA,gBAAgB9C,MAAM,CAACwC,uBAAuB,GAAG,IAAIO,IAAI,EAAE;IAC/D;IACA,IAAI,CAACL,eAAe;QAChBI,cAAcE,GAAG,CAAC7B;QAClB,MAAM8B,UAAUN,SAASO,aAAa,CAAC;QACvCD,QAAQE,GAAG,GAAGhC;QACd8B,QAAQG,IAAI,GAAG;QACfH,QAAQI,KAAK,GAAG;QAChB,6EAA6E;QAC7E,MAAMC,cAAc5D,WAAW;YAC3BS,QAAQD,KAAK,CAAC,CAAC,cAAc,EAAEiB,IAAI,wJAAwJ,CAAC;QAChM,GAAG,OAAO,+BAA+B;QACzC,IAAIoC,QAAQC,OAAOC;QACnBA,sBAAsB;YAClB5D,aAAayD;YACbR,cAAcY,MAAM,CAACvC;YACrB,IAAIoC,QAAQ;gBACRN,QAAQU,mBAAmB,CAAC,QAAQJ;YACxC;YACA,IAAIC,OAAO;gBACPP,QAAQU,mBAAmB,CAAC,SAASH;YACzC;QACJ;QACAD,SAAS;YACLE;YACA/B,QAAQ;QACZ;QACA8B,QAAQ,CAACI;YACLH;YACA,MAAMI,MAAM,CAAC,2BAA2B,EAAE1C,KAAK;YAC/ChB,QAAQD,KAAK,CAAC2D,KAAKD;YACnBnE,OAAOmE,GAAGE,OAAO,IAAID;QACzB;QACAZ,QAAQc,gBAAgB,CAAC,QAAQR;QACjCN,QAAQc,gBAAgB,CAAC,SAASP;QAClCb,SAASC,IAAI,CAACoB,WAAW,CAACf;IAC9B,OAAO;QACH,IAAIH,cAAcmB,GAAG,CAAC9C,MAAM;YACxB,IAAIoC,QAAQC,OAAOC;YACnBA,sBAAsB;gBAClB,IAAIF,QAAQ;oBACRb,cAAciB,mBAAmB,CAAC,QAAQJ;gBAC9C;gBACA,IAAIC,OAAO;oBACPd,cAAciB,mBAAmB,CAAC,SAASH;gBAC/C;YACJ;YACAD,SAAS;gBACLE;gBACA/B,QAAQ;YACZ;YACA,mCAAmC;YACnC8B,QAAQ,CAACI;gBACLH;gBACAhE,OAAOmE,GAAGE,OAAO;YACrB;YACApB,cAAcqB,gBAAgB,CAAC,QAAQR;YACvCb,cAAcqB,gBAAgB,CAAC,SAASP;QAC5C,OAAO;YACHrD,QAAQ+D,IAAI,CAAC,CAAC,UAAU,EAAE/C,IAAI,sCAAsC,CAAC;YACrEO,QAAQ;QACZ;IACJ;AACJ","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-dynamic-loading/dist/dynamic-loading.js?ecdf"],"sourcesContent":["/** @module @category Dynamic Loading */ 'use strict';\n// hack to make the types defined in esm-globals available here\nimport { dispatchToastShown } from \"@openmrs/esm-globals\";\nimport { getCoreTranslation } from \"@openmrs/esm-translations\";\n/**\n * @internal\n *\n * Transforms an ESM module name to a valid JS identifier\n *\n * @param name the name of a module\n * @returns An opaque, equivalent JS identifier for the module\n */ export function slugify(name) {\n    return name.replace(/[\\/\\-@]/g, '_');\n}\n/**\n * Loads the named export from a named package. This might be used like:\n *\n * ```js\n * const { someComponent } = importDynamic(\"@openmrs/esm-template-app\")\n * ```\n *\n * @param jsPackage The package to load the export from.\n * @param share Indicates the name of the shared module; this is an advanced feature if the package you are loading\n *   doesn't use the default OpenMRS shared module name \"./start\".\n * @param options Additional options to control loading this script.\n * @param options.importMap The import map to use to load the script. This is useful for situations where you're\n *   loading multiple scripts at a time, since it allows the calling code to supply an importMap, saving multiple\n *   calls to `getCurrentImportMap()`.\n * @param options.maxLoadingTime A positive integer representing the maximum number of milliseconds to wait for the\n *   script to load before the promise returned from this function will be rejected. Defaults to 600,000 milliseconds,\n *   i.e., 10 minutes.\n */ export async function importDynamic(jsPackage, share = './start', options) {\n    // default to 10 minutes\n    const maxLoadingTime = !options?.maxLoadingTime || options.maxLoadingTime <= 0 ? 600000 : options.maxLoadingTime;\n    let timeout = undefined;\n    await Promise.race([\n        preloadImport(jsPackage, options?.importMap),\n        new Promise((_, reject)=>{\n            timeout = setTimeout(()=>{\n                reject(new Error(`Could not resolve requested script, ${jsPackage}, within ${humanReadableMs(maxLoadingTime)}.`));\n            }, maxLoadingTime);\n        })\n    ]);\n    if (timeout) {\n        clearTimeout(timeout);\n    }\n    const jsPackageSlug = slugify(jsPackage);\n    const container = window[jsPackageSlug];\n    if (!isFederatedModule(container)) {\n        const error = `The global variable ${jsPackageSlug} does not refer to a federated module`;\n        console.error(error);\n        throw new Error(error);\n    }\n    container.init(__webpack_share_scopes__.default);\n    const factory = await container.get(share);\n    const module = factory();\n    if (!(typeof module === 'object') || module === null) {\n        const error = `Container for ${jsPackage} did not return an ESM module as expected`;\n        console.error(error);\n        throw new Error(error);\n    }\n    return module;\n}\n/**\n * Utility function to convert milliseconds into human-readable strings with rather absurd\n * levels of precision.\n *\n * @param ms Number of milliseconds\n * @returns A human-readable string useful only for error logging, where we can assume English\n */ function humanReadableMs(ms) {\n    if (ms < 1000) {\n        return `${ms} milliseconds`;\n    } else if (ms < 60000) {\n        return `${Math.floor(ms / 1000)} seconds`;\n    } else if (ms < 3600000) {\n        return `${Math.floor(ms / 60000)} minutes`;\n    } else if (ms < 86400000) {\n        return `${Math.floor(ms / 3600000)} hours`;\n    } else {\n        return `${Math.floor(ms / 86400000)} days`;\n    }\n}\n/**\n * @internal\n *\n * This internal method is used to ensure that the script belonging\n * to the given package is loaded and added to the head.\n *\n * @param jsPackage The package to load\n * @param importMap The import map to use for loading this package.\n *  The main reason for specifying this is to avoid needing to call\n *  `getCurrentPageMap()` for every script when bulk loading.\n */ export async function preloadImport(jsPackage, importMap) {\n    if (typeof jsPackage !== 'string' || jsPackage.trim().length === 0) {\n        const error = 'Attempted to call importDynamic() without supplying a package to load';\n        console.error(error);\n        throw new Error(error);\n    }\n    const jsPackageSlug = slugify(jsPackage);\n    if (!window[jsPackageSlug]) {\n        const activeImportMap = importMap ?? await getCurrentImportMap();\n        if (!activeImportMap.imports.hasOwnProperty(jsPackage)) {\n            const error = `Could not find the package ${jsPackage} defined in the current importmap`;\n            console.error(error);\n            throw new Error(error);\n        }\n        let url = activeImportMap.imports[jsPackage];\n        if (url.startsWith('./')) {\n            url = window.spaBase + url.substring(1);\n        }\n        const isOverridden = !!window.localStorage.getItem(`import-map-override:${jsPackage}`);\n        try {\n            return await new Promise((resolve, reject)=>{\n                loadScript(url, resolve, reject);\n            });\n        } catch (err) {\n            if (isOverridden) {\n                dispatchToastShown({\n                    kind: 'error',\n                    title: getCoreTranslation('scriptLoadingFailed', 'Error: Script failed to load'),\n                    description: getCoreTranslation('scriptLoadingError', 'Failed to load overridden script from {{- url}}. Please check that the bundled script is available at the expected URL. Click the button below to reset all import map overrides.', {\n                        url\n                    }),\n                    actionButtonLabel: getCoreTranslation('resetOverrides', 'Reset overrides'),\n                    onActionButtonClick () {\n                        window.importMapOverrides.resetOverrides();\n                        window.location.reload();\n                    }\n                });\n            }\n            return Promise.reject(err);\n        }\n    }\n    return Promise.resolve();\n}\n/**\n * @internal\n *\n * Used to load the current import map\n *\n * @returns The current page map\n */ export async function getCurrentImportMap() {\n    return window.importMapOverrides.getCurrentPageMap();\n}\nfunction isFederatedModule(a) {\n    return typeof a === 'object' && a !== null && 'init' in a && typeof a['init'] === 'function' && 'get' in a && typeof a['get'] === 'function';\n}\n// internals to track script loading\n// basically, if we're already loading a script, we should wait until the script is loaded\n// we use a global to track this\nconst OPENMRS_SCRIPT_LOADING = Symbol('__openmrs_script_loading');\n/**\n * Appends a `<script>` to the DOM with the given URL.\n */ function loadScript(url, resolve, reject) {\n    const scriptElement = document.head.querySelector(`script[src=\"${url}\"]`);\n    let scriptLoading = window[OPENMRS_SCRIPT_LOADING];\n    if (!scriptLoading) {\n        scriptLoading = window[OPENMRS_SCRIPT_LOADING] = new Set([]);\n    }\n    if (!scriptElement) {\n        scriptLoading.add(url);\n        const element = document.createElement('script');\n        element.src = url;\n        element.type = 'text/javascript';\n        element.async = true;\n        // loadTime() displays an error if a script takes more than 5 seconds to load\n        const loadTimeout = setTimeout(()=>{\n            console.error(`The script at ${url} did not load within 5 seconds. This may indicate an issue with the imports in the script's entry-point file or with the script's bundler configuration.`);\n        }, 5000); // 5 seconds; this is arbitrary\n        let loadFn, errFn, finishScriptLoading;\n        finishScriptLoading = ()=>{\n            clearTimeout(loadTimeout);\n            scriptLoading.delete(url);\n            if (loadFn) {\n                element.removeEventListener('load', loadFn);\n            }\n            if (errFn) {\n                element.removeEventListener('error', errFn);\n            }\n        };\n        loadFn = ()=>{\n            finishScriptLoading();\n            resolve(null);\n        };\n        errFn = (ev)=>{\n            finishScriptLoading();\n            const msg = `Failed to load script from ${url}`;\n            console.error(msg, ev);\n            reject(ev.message ?? msg);\n        };\n        element.addEventListener('load', loadFn);\n        element.addEventListener('error', errFn);\n        document.head.appendChild(element);\n    } else {\n        if (scriptLoading.has(url)) {\n            let loadFn, errFn, finishScriptLoading;\n            finishScriptLoading = ()=>{\n                if (loadFn) {\n                    scriptElement.removeEventListener('load', loadFn);\n                }\n                if (errFn) {\n                    scriptElement.removeEventListener('error', errFn);\n                }\n            };\n            loadFn = ()=>{\n                finishScriptLoading();\n                resolve(null);\n            };\n            // this errFn does not log anything\n            errFn = (ev)=>{\n                finishScriptLoading();\n                reject(ev.message);\n            };\n            scriptElement.addEventListener('load', loadFn);\n            scriptElement.addEventListener('error', errFn);\n        } else {\n            console.warn(`Script at ${url} already loaded. Not loading it again.`);\n            resolve(null);\n        }\n    }\n}\n"],"names":["dispatchToastShown","getCoreTranslation","slugify","name","replace","importDynamic","jsPackage","share","options","maxLoadingTime","timeout","undefined","Promise","race","preloadImport","importMap","_","reject","setTimeout","Error","humanReadableMs","clearTimeout","jsPackageSlug","container","window","isFederatedModule","error","console","init","__webpack_share_scopes__","default","factory","get","module","ms","Math","floor","trim","length","activeImportMap","getCurrentImportMap","imports","hasOwnProperty","url","startsWith","spaBase","substring","isOverridden","localStorage","getItem","resolve","loadScript","err","kind","title","description","actionButtonLabel","onActionButtonClick","importMapOverrides","resetOverrides","location","reload","getCurrentPageMap","a","OPENMRS_SCRIPT_LOADING","Symbol","scriptElement","document","head","querySelector","scriptLoading","Set","add","element","createElement","src","type","async","loadTimeout","loadFn","errFn","finishScriptLoading","delete","removeEventListener","ev","msg","message","addEventListener","appendChild","has","warn"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-dynamic-loading/dist/dynamic-loading.js\n");
268
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ getCurrentImportMap: () => (/* binding */ getCurrentImportMap),\n/* harmony export */ importDynamic: () => (/* binding */ importDynamic),\n/* harmony export */ preloadImport: () => (/* binding */ preloadImport),\n/* harmony export */ slugify: () => (/* binding */ slugify)\n/* harmony export */ });\n/* harmony import */ var _openmrs_esm_globals__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @openmrs/esm-globals */ \"../../framework/esm-globals/dist/index.js\");\n/* harmony import */ var _openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @openmrs/esm-translations */ \"../../framework/esm-translations/dist/index.js\");\n/** @module @category Dynamic Loading */ \n// hack to make the types defined in esm-globals available here\n\n\n/**\n * @internal\n *\n * Transforms an ESM module name to a valid JS identifier\n *\n * @param name the name of a module\n * @returns An opaque, equivalent JS identifier for the module\n */ function slugify(name) {\n return name.replace(/[\\/\\-@]/g, '_');\n}\n/**\n * Loads the named export from a named package. This might be used like:\n *\n * ```js\n * const { someComponent } = importDynamic(\"@openmrs/esm-template-app\")\n * ```\n *\n * @param jsPackage The package to load the export from.\n * @param share Indicates the name of the shared module; this is an advanced feature if the package you are loading\n * doesn't use the default OpenMRS shared module name \"./start\".\n * @param options Additional options to control loading this script.\n * @param options.importMap The import map to use to load the script. This is useful for situations where you're\n * loading multiple scripts at a time, since it allows the calling code to supply an importMap, saving multiple\n * calls to `getCurrentImportMap()`.\n * @param options.maxLoadingTime A positive integer representing the maximum number of milliseconds to wait for the\n * script to load before the promise returned from this function will be rejected. Defaults to 600,000 milliseconds,\n * i.e., 10 minutes.\n */ async function importDynamic(jsPackage, share = './start', options) {\n // default to 10 minutes\n const maxLoadingTime = !options?.maxLoadingTime || options.maxLoadingTime <= 0 ? 600000 : options.maxLoadingTime;\n let timeout = undefined;\n await Promise.race([\n preloadImport(jsPackage, options?.importMap),\n new Promise((_, reject)=>{\n timeout = setTimeout(()=>{\n reject(new Error(`Could not resolve requested script, ${jsPackage}, within ${humanReadableMs(maxLoadingTime)}.`));\n }, maxLoadingTime);\n })\n ]);\n if (timeout) {\n clearTimeout(timeout);\n }\n const jsPackageSlug = slugify(jsPackage);\n const container = window[jsPackageSlug];\n if (!isFederatedModule(container)) {\n const error = `The global variable ${jsPackageSlug} does not refer to a federated module`;\n console.error(error);\n throw new Error(error);\n }\n container.init(__webpack_require__.S.default);\n const factory = await container.get(share);\n const module = factory();\n if (!(typeof module === 'object') || module === null) {\n const error = `Container for ${jsPackage} did not return an ESM module as expected`;\n console.error(error);\n throw new Error(error);\n }\n return module;\n}\n/**\n * Utility function to convert milliseconds into human-readable strings with rather absurd\n * levels of precision.\n *\n * @param ms Number of milliseconds\n * @returns A human-readable string useful only for error logging, where we can assume English\n */ function humanReadableMs(ms) {\n if (ms < 1000) {\n return `${ms} milliseconds`;\n } else if (ms < 60000) {\n return `${Math.floor(ms / 1000)} seconds`;\n } else if (ms < 3600000) {\n return `${Math.floor(ms / 60000)} minutes`;\n } else if (ms < 86400000) {\n return `${Math.floor(ms / 3600000)} hours`;\n } else {\n return `${Math.floor(ms / 86400000)} days`;\n }\n}\n/**\n * @internal\n *\n * This internal method is used to ensure that the script belonging\n * to the given package is loaded and added to the head.\n *\n * @param jsPackage The package to load\n * @param importMap The import map to use for loading this package.\n * The main reason for specifying this is to avoid needing to call\n * `getCurrentPageMap()` for every script when bulk loading.\n */ async function preloadImport(jsPackage, importMap) {\n if (typeof jsPackage !== 'string' || jsPackage.trim().length === 0) {\n const error = 'Attempted to call importDynamic() without supplying a package to load';\n console.error(error);\n throw new Error(error);\n }\n const jsPackageSlug = slugify(jsPackage);\n if (!window[jsPackageSlug]) {\n const activeImportMap = importMap ?? await getCurrentImportMap();\n if (!activeImportMap.imports.hasOwnProperty(jsPackage)) {\n const error = `Could not find the package ${jsPackage} defined in the current importmap`;\n console.error(error);\n throw new Error(error);\n }\n let url = activeImportMap.imports[jsPackage];\n if (url.startsWith('./')) {\n url = window.spaBase + url.substring(1);\n }\n const isOverridden = !!window.localStorage.getItem(`import-map-override:${jsPackage}`);\n try {\n return await new Promise((resolve, reject)=>{\n loadScript(url, resolve, reject);\n });\n } catch (err) {\n if (isOverridden) {\n (0,_openmrs_esm_globals__WEBPACK_IMPORTED_MODULE_0__.dispatchToastShown)({\n kind: 'error',\n title: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_1__.getCoreTranslation)('scriptLoadingFailed', 'Error: Script failed to load'),\n description: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_1__.getCoreTranslation)('scriptLoadingError', 'Failed to load overridden script from {{- url}}. Please check that the bundled script is available at the expected URL. Click the button below to reset all import map overrides.', {\n url\n }),\n actionButtonLabel: (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_1__.getCoreTranslation)('resetOverrides', 'Reset overrides'),\n onActionButtonClick () {\n window.importMapOverrides.resetOverrides();\n window.location.reload();\n }\n });\n }\n return Promise.reject(err);\n }\n }\n return Promise.resolve();\n}\n/**\n * @internal\n *\n * Used to load the current import map.\n *\n * @returns The current import map.\n */ async function getCurrentImportMap() {\n return window.importMapOverrides.getCurrentPageMap();\n}\nfunction isFederatedModule(a) {\n return typeof a === 'object' && a !== null && 'init' in a && typeof a['init'] === 'function' && 'get' in a && typeof a['get'] === 'function';\n}\n// internals to track script loading\n// basically, if we're already loading a script, we should wait until the script is loaded\n// we use a global to track this\nconst OPENMRS_SCRIPT_LOADING = Symbol('__openmrs_script_loading');\n/**\n * Appends a `<script>` to the DOM with the given URL.\n */ function loadScript(url, resolve, reject) {\n const scriptElement = document.head.querySelector(`script[src=\"${url}\"]`);\n let scriptLoading = window[OPENMRS_SCRIPT_LOADING];\n if (!scriptLoading) {\n scriptLoading = window[OPENMRS_SCRIPT_LOADING] = new Set([]);\n }\n if (!scriptElement) {\n scriptLoading.add(url);\n const element = document.createElement('script');\n element.src = url;\n element.type = 'text/javascript';\n element.async = true;\n // loadTime() displays an error if a script takes more than 5 seconds to load\n const loadTimeout = setTimeout(()=>{\n console.error(`The script at ${url} did not load within 5 seconds. This may indicate an issue with the imports in the script's entry-point file or with the script's bundler configuration.`);\n }, 5000); // 5 seconds; this is arbitrary\n let loadFn, errFn, finishScriptLoading;\n finishScriptLoading = ()=>{\n clearTimeout(loadTimeout);\n scriptLoading.delete(url);\n if (loadFn) {\n element.removeEventListener('load', loadFn);\n }\n if (errFn) {\n element.removeEventListener('error', errFn);\n }\n };\n loadFn = ()=>{\n finishScriptLoading();\n resolve(null);\n };\n errFn = (ev)=>{\n finishScriptLoading();\n const msg = `Failed to load script from ${url}`;\n console.error(msg, ev);\n reject(ev.message ?? msg);\n };\n element.addEventListener('load', loadFn);\n element.addEventListener('error', errFn);\n document.head.appendChild(element);\n } else {\n if (scriptLoading.has(url)) {\n let loadFn, errFn, finishScriptLoading;\n finishScriptLoading = ()=>{\n if (loadFn) {\n scriptElement.removeEventListener('load', loadFn);\n }\n if (errFn) {\n scriptElement.removeEventListener('error', errFn);\n }\n };\n loadFn = ()=>{\n finishScriptLoading();\n resolve(null);\n };\n // this errFn does not log anything\n errFn = (ev)=>{\n finishScriptLoading();\n reject(ev.message);\n };\n scriptElement.addEventListener('load', loadFn);\n scriptElement.addEventListener('error', errFn);\n } else {\n console.warn(`Script at ${url} already loaded. Not loading it again.`);\n resolve(null);\n }\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-dynamic-loading/dist/dynamic-loading.js","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-dynamic-loading/dist/dynamic-loading.js?ecdf"],"sourcesContent":["/** @module @category Dynamic Loading */ 'use strict';\n// hack to make the types defined in esm-globals available here\nimport { dispatchToastShown } from \"@openmrs/esm-globals\";\nimport { getCoreTranslation } from \"@openmrs/esm-translations\";\n/**\n * @internal\n *\n * Transforms an ESM module name to a valid JS identifier\n *\n * @param name the name of a module\n * @returns An opaque, equivalent JS identifier for the module\n */ export function slugify(name) {\n    return name.replace(/[\\/\\-@]/g, '_');\n}\n/**\n * Loads the named export from a named package. This might be used like:\n *\n * ```js\n * const { someComponent } = importDynamic(\"@openmrs/esm-template-app\")\n * ```\n *\n * @param jsPackage The package to load the export from.\n * @param share Indicates the name of the shared module; this is an advanced feature if the package you are loading\n *   doesn't use the default OpenMRS shared module name \"./start\".\n * @param options Additional options to control loading this script.\n * @param options.importMap The import map to use to load the script. This is useful for situations where you're\n *   loading multiple scripts at a time, since it allows the calling code to supply an importMap, saving multiple\n *   calls to `getCurrentImportMap()`.\n * @param options.maxLoadingTime A positive integer representing the maximum number of milliseconds to wait for the\n *   script to load before the promise returned from this function will be rejected. Defaults to 600,000 milliseconds,\n *   i.e., 10 minutes.\n */ export async function importDynamic(jsPackage, share = './start', options) {\n    // default to 10 minutes\n    const maxLoadingTime = !options?.maxLoadingTime || options.maxLoadingTime <= 0 ? 600000 : options.maxLoadingTime;\n    let timeout = undefined;\n    await Promise.race([\n        preloadImport(jsPackage, options?.importMap),\n        new Promise((_, reject)=>{\n            timeout = setTimeout(()=>{\n                reject(new Error(`Could not resolve requested script, ${jsPackage}, within ${humanReadableMs(maxLoadingTime)}.`));\n            }, maxLoadingTime);\n        })\n    ]);\n    if (timeout) {\n        clearTimeout(timeout);\n    }\n    const jsPackageSlug = slugify(jsPackage);\n    const container = window[jsPackageSlug];\n    if (!isFederatedModule(container)) {\n        const error = `The global variable ${jsPackageSlug} does not refer to a federated module`;\n        console.error(error);\n        throw new Error(error);\n    }\n    container.init(__webpack_share_scopes__.default);\n    const factory = await container.get(share);\n    const module = factory();\n    if (!(typeof module === 'object') || module === null) {\n        const error = `Container for ${jsPackage} did not return an ESM module as expected`;\n        console.error(error);\n        throw new Error(error);\n    }\n    return module;\n}\n/**\n * Utility function to convert milliseconds into human-readable strings with rather absurd\n * levels of precision.\n *\n * @param ms Number of milliseconds\n * @returns A human-readable string useful only for error logging, where we can assume English\n */ function humanReadableMs(ms) {\n    if (ms < 1000) {\n        return `${ms} milliseconds`;\n    } else if (ms < 60000) {\n        return `${Math.floor(ms / 1000)} seconds`;\n    } else if (ms < 3600000) {\n        return `${Math.floor(ms / 60000)} minutes`;\n    } else if (ms < 86400000) {\n        return `${Math.floor(ms / 3600000)} hours`;\n    } else {\n        return `${Math.floor(ms / 86400000)} days`;\n    }\n}\n/**\n * @internal\n *\n * This internal method is used to ensure that the script belonging\n * to the given package is loaded and added to the head.\n *\n * @param jsPackage The package to load\n * @param importMap The import map to use for loading this package.\n *  The main reason for specifying this is to avoid needing to call\n *  `getCurrentPageMap()` for every script when bulk loading.\n */ export async function preloadImport(jsPackage, importMap) {\n    if (typeof jsPackage !== 'string' || jsPackage.trim().length === 0) {\n        const error = 'Attempted to call importDynamic() without supplying a package to load';\n        console.error(error);\n        throw new Error(error);\n    }\n    const jsPackageSlug = slugify(jsPackage);\n    if (!window[jsPackageSlug]) {\n        const activeImportMap = importMap ?? await getCurrentImportMap();\n        if (!activeImportMap.imports.hasOwnProperty(jsPackage)) {\n            const error = `Could not find the package ${jsPackage} defined in the current importmap`;\n            console.error(error);\n            throw new Error(error);\n        }\n        let url = activeImportMap.imports[jsPackage];\n        if (url.startsWith('./')) {\n            url = window.spaBase + url.substring(1);\n        }\n        const isOverridden = !!window.localStorage.getItem(`import-map-override:${jsPackage}`);\n        try {\n            return await new Promise((resolve, reject)=>{\n                loadScript(url, resolve, reject);\n            });\n        } catch (err) {\n            if (isOverridden) {\n                dispatchToastShown({\n                    kind: 'error',\n                    title: getCoreTranslation('scriptLoadingFailed', 'Error: Script failed to load'),\n                    description: getCoreTranslation('scriptLoadingError', 'Failed to load overridden script from {{- url}}. Please check that the bundled script is available at the expected URL. Click the button below to reset all import map overrides.', {\n                        url\n                    }),\n                    actionButtonLabel: getCoreTranslation('resetOverrides', 'Reset overrides'),\n                    onActionButtonClick () {\n                        window.importMapOverrides.resetOverrides();\n                        window.location.reload();\n                    }\n                });\n            }\n            return Promise.reject(err);\n        }\n    }\n    return Promise.resolve();\n}\n/**\n * @internal\n *\n * Used to load the current import map.\n *\n * @returns The current import map.\n */ export async function getCurrentImportMap() {\n    return window.importMapOverrides.getCurrentPageMap();\n}\nfunction isFederatedModule(a) {\n    return typeof a === 'object' && a !== null && 'init' in a && typeof a['init'] === 'function' && 'get' in a && typeof a['get'] === 'function';\n}\n// internals to track script loading\n// basically, if we're already loading a script, we should wait until the script is loaded\n// we use a global to track this\nconst OPENMRS_SCRIPT_LOADING = Symbol('__openmrs_script_loading');\n/**\n * Appends a `<script>` to the DOM with the given URL.\n */ function loadScript(url, resolve, reject) {\n    const scriptElement = document.head.querySelector(`script[src=\"${url}\"]`);\n    let scriptLoading = window[OPENMRS_SCRIPT_LOADING];\n    if (!scriptLoading) {\n        scriptLoading = window[OPENMRS_SCRIPT_LOADING] = new Set([]);\n    }\n    if (!scriptElement) {\n        scriptLoading.add(url);\n        const element = document.createElement('script');\n        element.src = url;\n        element.type = 'text/javascript';\n        element.async = true;\n        // loadTime() displays an error if a script takes more than 5 seconds to load\n        const loadTimeout = setTimeout(()=>{\n            console.error(`The script at ${url} did not load within 5 seconds. This may indicate an issue with the imports in the script's entry-point file or with the script's bundler configuration.`);\n        }, 5000); // 5 seconds; this is arbitrary\n        let loadFn, errFn, finishScriptLoading;\n        finishScriptLoading = ()=>{\n            clearTimeout(loadTimeout);\n            scriptLoading.delete(url);\n            if (loadFn) {\n                element.removeEventListener('load', loadFn);\n            }\n            if (errFn) {\n                element.removeEventListener('error', errFn);\n            }\n        };\n        loadFn = ()=>{\n            finishScriptLoading();\n            resolve(null);\n        };\n        errFn = (ev)=>{\n            finishScriptLoading();\n            const msg = `Failed to load script from ${url}`;\n            console.error(msg, ev);\n            reject(ev.message ?? msg);\n        };\n        element.addEventListener('load', loadFn);\n        element.addEventListener('error', errFn);\n        document.head.appendChild(element);\n    } else {\n        if (scriptLoading.has(url)) {\n            let loadFn, errFn, finishScriptLoading;\n            finishScriptLoading = ()=>{\n                if (loadFn) {\n                    scriptElement.removeEventListener('load', loadFn);\n                }\n                if (errFn) {\n                    scriptElement.removeEventListener('error', errFn);\n                }\n            };\n            loadFn = ()=>{\n                finishScriptLoading();\n                resolve(null);\n            };\n            // this errFn does not log anything\n            errFn = (ev)=>{\n                finishScriptLoading();\n                reject(ev.message);\n            };\n            scriptElement.addEventListener('load', loadFn);\n            scriptElement.addEventListener('error', errFn);\n        } else {\n            console.warn(`Script at ${url} already loaded. Not loading it again.`);\n            resolve(null);\n        }\n    }\n}\n"],"names":["dispatchToastShown","getCoreTranslation","slugify","name","replace","importDynamic","jsPackage","share","options","maxLoadingTime","timeout","undefined","Promise","race","preloadImport","importMap","_","reject","setTimeout","Error","humanReadableMs","clearTimeout","jsPackageSlug","container","window","isFederatedModule","error","console","init","__webpack_share_scopes__","default","factory","get","module","ms","Math","floor","trim","length","activeImportMap","getCurrentImportMap","imports","hasOwnProperty","url","startsWith","spaBase","substring","isOverridden","localStorage","getItem","resolve","loadScript","err","kind","title","description","actionButtonLabel","onActionButtonClick","importMapOverrides","resetOverrides","location","reload","getCurrentPageMap","a","OPENMRS_SCRIPT_LOADING","Symbol","scriptElement","document","head","querySelector","scriptLoading","Set","add","element","createElement","src","type","async","loadTimeout","loadFn","errFn","finishScriptLoading","delete","removeEventListener","ev","msg","message","addEventListener","appendChild","has","warn"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-dynamic-loading/dist/dynamic-loading.js\n");
269
269
 
270
270
  /***/ }),
271
271
 
@@ -275,7 +275,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
275
275
  \******************************************************************/
276
276
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
277
277
 
278
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ extractVariableNames: () => (/* binding */ extractVariableNames)\n/* harmony export */ });\n/* harmony import */ var _evaluator_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./evaluator.js */ \"../../../node_modules/jsep/dist/jsep.js\");\n/* harmony import */ var _globals_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./globals.js */ \"../../framework/esm-expression-evaluator/dist/globals.js\");\n/** @category Utility */ \n\n/**\n * `extractVariableNames()` is a companion function for `evaluate()` and `evaluateAsync()` which extracts the\n * names of all unbound identifiers used in the expression. The idea is to be able to extract all of the names\n * of variables that will need to be supplied in order to correctly process the expression.\n *\n * @example\n * ```ts\n * // variables will be ['isEmpty', 'array']\n * const variables = extractVariableNames('!isEmpty(array)')\n * ```\n *\n * An identifier is considered \"unbound\" if it is not a reference to the property of an object, is not defined\n * as a parameter to an inline arrow function, and is not a global value. E.g.,\n *\n * @example\n * ```ts\n * // variables will be ['obj']\n * const variables = extractVariableNames('obj.prop()')\n * ```\n *\n * @example\n * ```ts\n * // variables will be ['arr', 'needle']\n * const variables = extractVariableNames('arr.filter(v => v === needle)')\n * ```\n *\n @example\n * ```ts\n * // variables will be ['myVar']\n * const variables = extractVariableNames('new String(myVar)')\n * ```\n *\n * Note that because this expression evaluator uses a restricted definition of \"global\" there are some Javascript\n * globals that will be reported as a unbound expression. This is expected because the evaluator will still fail\n * on these expressions.\n */ function extractVariableNames(expression) {\n if (typeof expression !== 'string' && (typeof expression !== 'object' || !expression || !('type' in expression))) {\n throw `Unknown expression type ${expression}. Expressions must either be a string or pre-compiled string.`;\n }\n const context = createAsynchronousContext();\n visitExpression(typeof expression === 'string' ? (0,_evaluator_js__WEBPACK_IMPORTED_MODULE_0__[\"default\"])(expression) : expression, context);\n return [\n ...context.variables\n ];\n}\nfunction visitExpression(expression, context) {\n switch(expression.type){\n case 'UnaryExpression':\n return visitUnaryExpression(expression, context);\n case 'BinaryExpression':\n return visitBinaryExpression(expression, context);\n case 'ConditionalExpression':\n return visitConditionalExpression(expression, context);\n case 'CallExpression':\n return visitCallExpression(expression, context);\n case 'ArrowFunctionExpression':\n return visitArrowFunctionExpression(expression, context);\n case 'MemberExpression':\n return visitMemberExpression(expression, context);\n case 'ArrayExpression':\n return visitArrayExpression(expression, context);\n case 'SequenceExpression':\n return visitSequenceExpression(expression, context);\n case 'NewExpression':\n return visitNewExpression(expression, context);\n case 'Literal':\n return visitLiteral(expression, context);\n case 'Identifier':\n return visitIdentifier(expression, context);\n case 'TemplateLiteral':\n return visitTemplateLiteral(expression, context);\n case 'TemplateElement':\n return visitTemplateElement(expression, context);\n default:\n throw `Expression evaluator does not support expression of type '${expression.type}'`;\n }\n}\nfunction visitUnaryExpression(expression, context) {\n return visitExpression(expression.argument, context);\n}\nfunction visitBinaryExpression(expression, context) {\n const left = visitExpression(expression.left, context);\n const right = visitExpression(expression.right, context);\n return [\n left,\n right\n ].filter(Boolean);\n}\nfunction visitConditionalExpression(expression, context) {\n const consequent = visitExpression(expression.consequent, context);\n const test = visitExpression(expression.test, context);\n const alternate = visitExpression(expression.alternate, context);\n return [\n consequent,\n test,\n alternate\n ].filter(Boolean);\n}\nfunction visitCallExpression(expression, context) {\n const fn = visitExpression(expression.callee, context);\n expression.arguments?.map(handleNullableExpression(context));\n return fn;\n}\nfunction visitArrowFunctionExpression(expression, context) {\n const newContext = {\n ...context\n };\n newContext.isLocalExpression = true;\n const params = expression.params?.map(handleNullableExpression(newContext)) ?? [];\n const bodyVariables = visitExpression(expression.body, newContext) ?? [];\n if (bodyVariables && Array.isArray(bodyVariables)) {\n for (const v of bodyVariables){\n if (!params.includes(v)) {\n context.variables.add(v);\n }\n }\n }\n}\nfunction visitMemberExpression(expression, context) {\n visitExpression(expression.object, context);\n const newContext = {\n ...context\n };\n newContext.isLocalExpression = true;\n visitExpression(expression.property, newContext);\n}\nfunction visitArrayExpression(expression, context) {\n expression.elements?.map(handleNullableExpression(context));\n}\nfunction visitSequenceExpression(expression, context) {\n expression.expressions?.map(handleNullableExpression(context));\n}\nfunction visitNewExpression(expression, context) {\n expression.arguments?.map(handleNullableExpression(context));\n}\nfunction visitTemplateLiteral(expression, context) {\n expression.expressions?.map(handleNullableExpression(context));\n expression.quasis?.map(handleNullableExpression(context));\n}\nfunction visitTemplateElement(expression, context) {}\nfunction visitIdentifier(expression, context) {\n if (!(expression.name in context.globals)) {\n if (!context.isLocalExpression) {\n context.variables.add(expression.name);\n } else {\n return expression.name;\n }\n }\n}\nfunction visitLiteral(expression, context) {}\nfunction createAsynchronousContext() {\n return createContextInternal(_globals_js__WEBPACK_IMPORTED_MODULE_1__.globalsAsync);\n}\nfunction createContextInternal(globals_) {\n const context = {\n globals: {\n ...globals_\n },\n isLocalExpression: false,\n variables: new Set()\n };\n return context;\n}\nfunction handleNullableExpression(context) {\n return function handleNullableExpressionInner(expression) {\n if (expression === null) {\n return null;\n }\n return visitExpression(expression, context);\n };\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-expression-evaluator/dist/extractor.js","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-expression-evaluator/dist/extractor.js?5852"],"sourcesContent":["/** @category Utility */ import { jsep } from \"./evaluator.js\";\nimport { globalsAsync } from \"./globals.js\";\n/**\n * `extractVariableNames()` is a companion function for `evaluate()` and `evaluateAsync()` which extracts the\n * names of all unbound identifiers used in the expression. The idea is to be able to extract all of the names\n * of variables that will need to be supplied in order to correctly process the expression.\n *\n * @example\n * ```ts\n * // variables will be ['isEmpty', 'array']\n * const variables = extractVariableNames('!isEmpty(array)')\n * ```\n *\n * An identifier is considered \"unbound\" if it is not a reference to the property of an object, is not defined\n * as a parameter to an inline arrow function, and is not a global value. E.g.,\n *\n * @example\n * ```ts\n * // variables will be ['obj']\n * const variables = extractVariableNames('obj.prop()')\n * ```\n *\n * @example\n * ```ts\n * // variables will be ['arr', 'needle']\n * const variables = extractVariableNames('arr.filter(v => v === needle)')\n * ```\n *\n @example\n * ```ts\n * // variables will be ['myVar']\n * const  variables = extractVariableNames('new String(myVar)')\n * ```\n *\n * Note that because this expression evaluator uses a restricted definition of \"global\" there are some Javascript\n * globals that will be reported as a unbound expression. This is expected because the evaluator will still fail\n * on these expressions.\n */ export function extractVariableNames(expression) {\n    if (typeof expression !== 'string' && (typeof expression !== 'object' || !expression || !('type' in expression))) {\n        throw `Unknown expression type ${expression}. Expressions must either be a string or pre-compiled string.`;\n    }\n    const context = createAsynchronousContext();\n    visitExpression(typeof expression === 'string' ? jsep(expression) : expression, context);\n    return [\n        ...context.variables\n    ];\n}\nfunction visitExpression(expression, context) {\n    switch(expression.type){\n        case 'UnaryExpression':\n            return visitUnaryExpression(expression, context);\n        case 'BinaryExpression':\n            return visitBinaryExpression(expression, context);\n        case 'ConditionalExpression':\n            return visitConditionalExpression(expression, context);\n        case 'CallExpression':\n            return visitCallExpression(expression, context);\n        case 'ArrowFunctionExpression':\n            return visitArrowFunctionExpression(expression, context);\n        case 'MemberExpression':\n            return visitMemberExpression(expression, context);\n        case 'ArrayExpression':\n            return visitArrayExpression(expression, context);\n        case 'SequenceExpression':\n            return visitSequenceExpression(expression, context);\n        case 'NewExpression':\n            return visitNewExpression(expression, context);\n        case 'Literal':\n            return visitLiteral(expression, context);\n        case 'Identifier':\n            return visitIdentifier(expression, context);\n        case 'TemplateLiteral':\n            return visitTemplateLiteral(expression, context);\n        case 'TemplateElement':\n            return visitTemplateElement(expression, context);\n        default:\n            throw `Expression evaluator does not support expression of type '${expression.type}'`;\n    }\n}\nfunction visitUnaryExpression(expression, context) {\n    return visitExpression(expression.argument, context);\n}\nfunction visitBinaryExpression(expression, context) {\n    const left = visitExpression(expression.left, context);\n    const right = visitExpression(expression.right, context);\n    return [\n        left,\n        right\n    ].filter(Boolean);\n}\nfunction visitConditionalExpression(expression, context) {\n    const consequent = visitExpression(expression.consequent, context);\n    const test = visitExpression(expression.test, context);\n    const alternate = visitExpression(expression.alternate, context);\n    return [\n        consequent,\n        test,\n        alternate\n    ].filter(Boolean);\n}\nfunction visitCallExpression(expression, context) {\n    const fn = visitExpression(expression.callee, context);\n    expression.arguments?.map(handleNullableExpression(context));\n    return fn;\n}\nfunction visitArrowFunctionExpression(expression, context) {\n    const newContext = {\n        ...context\n    };\n    newContext.isLocalExpression = true;\n    const params = expression.params?.map(handleNullableExpression(newContext)) ?? [];\n    const bodyVariables = visitExpression(expression.body, newContext) ?? [];\n    if (bodyVariables && Array.isArray(bodyVariables)) {\n        for (const v of bodyVariables){\n            if (!params.includes(v)) {\n                context.variables.add(v);\n            }\n        }\n    }\n}\nfunction visitMemberExpression(expression, context) {\n    visitExpression(expression.object, context);\n    const newContext = {\n        ...context\n    };\n    newContext.isLocalExpression = true;\n    visitExpression(expression.property, newContext);\n}\nfunction visitArrayExpression(expression, context) {\n    expression.elements?.map(handleNullableExpression(context));\n}\nfunction visitSequenceExpression(expression, context) {\n    expression.expressions?.map(handleNullableExpression(context));\n}\nfunction visitNewExpression(expression, context) {\n    expression.arguments?.map(handleNullableExpression(context));\n}\nfunction visitTemplateLiteral(expression, context) {\n    expression.expressions?.map(handleNullableExpression(context));\n    expression.quasis?.map(handleNullableExpression(context));\n}\nfunction visitTemplateElement(expression, context) {}\nfunction visitIdentifier(expression, context) {\n    if (!(expression.name in context.globals)) {\n        if (!context.isLocalExpression) {\n            context.variables.add(expression.name);\n        } else {\n            return expression.name;\n        }\n    }\n}\nfunction visitLiteral(expression, context) {}\nfunction createAsynchronousContext() {\n    return createContextInternal(globalsAsync);\n}\nfunction createContextInternal(globals_) {\n    const context = {\n        globals: {\n            ...globals_\n        },\n        isLocalExpression: false,\n        variables: new Set()\n    };\n    return context;\n}\nfunction handleNullableExpression(context) {\n    return function handleNullableExpressionInner(expression) {\n        if (expression === null) {\n            return null;\n        }\n        return visitExpression(expression, context);\n    };\n}\n"],"names":["jsep","globalsAsync","extractVariableNames","expression","context","createAsynchronousContext","visitExpression","variables","type","visitUnaryExpression","visitBinaryExpression","visitConditionalExpression","visitCallExpression","visitArrowFunctionExpression","visitMemberExpression","visitArrayExpression","visitSequenceExpression","visitNewExpression","visitLiteral","visitIdentifier","visitTemplateLiteral","visitTemplateElement","argument","left","right","filter","Boolean","consequent","test","alternate","fn","callee","arguments","map","handleNullableExpression","newContext","isLocalExpression","params","bodyVariables","body","Array","isArray","v","includes","add","object","property","elements","expressions","quasis","name","globals","createContextInternal","globals_","Set","handleNullableExpressionInner"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-expression-evaluator/dist/extractor.js\n");
278
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ extractVariableNames: () => (/* binding */ extractVariableNames)\n/* harmony export */ });\n/* harmony import */ var _evaluator_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./evaluator.js */ \"../../../node_modules/jsep/dist/jsep.js\");\n/* harmony import */ var _globals_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./globals.js */ \"../../framework/esm-expression-evaluator/dist/globals.js\");\n/** @category Utility */ \n\n/**\n * `extractVariableNames()` is a companion function for `evaluate()` and `evaluateAsync()` which extracts the\n * names of all unbound identifiers used in the expression. The idea is to be able to extract all of the names\n * of variables that will need to be supplied in order to correctly process the expression.\n *\n * @example\n * ```ts\n * // variables will be ['isEmpty', 'array']\n * const variables = extractVariableNames('!isEmpty(array)')\n * ```\n *\n * An identifier is considered \"unbound\" if it is not a reference to the property of an object, is not defined\n * as a parameter to an inline arrow function, and is not a global value. E.g.,\n *\n * @example\n * ```ts\n * // variables will be ['obj']\n * const variables = extractVariableNames('obj.prop()')\n * ```\n *\n * @example\n * ```ts\n * // variables will be ['arr', 'needle']\n * const variables = extractVariableNames('arr.filter(v => v === needle)')\n * ```\n *\n * @example\n * ```ts\n * // variables will be ['myVar']\n * const variables = extractVariableNames('new String(myVar)')\n * ```\n *\n * Note that because this expression evaluator uses a restricted definition of \"global\" there are some Javascript\n * globals that will be reported as a unbound expression. This is expected because the evaluator will still fail\n * on these expressions.\n *\n * @param expression The expression to analyze, either as a string or pre-parsed expression.\n * @returns An array of variable names that are unbound in the expression.\n */ function extractVariableNames(expression) {\n if (typeof expression !== 'string' && (typeof expression !== 'object' || !expression || !('type' in expression))) {\n throw `Unknown expression type ${expression}. Expressions must either be a string or pre-compiled string.`;\n }\n const context = createAsynchronousContext();\n visitExpression(typeof expression === 'string' ? (0,_evaluator_js__WEBPACK_IMPORTED_MODULE_0__[\"default\"])(expression) : expression, context);\n return [\n ...context.variables\n ];\n}\nfunction visitExpression(expression, context) {\n switch(expression.type){\n case 'UnaryExpression':\n return visitUnaryExpression(expression, context);\n case 'BinaryExpression':\n return visitBinaryExpression(expression, context);\n case 'ConditionalExpression':\n return visitConditionalExpression(expression, context);\n case 'CallExpression':\n return visitCallExpression(expression, context);\n case 'ArrowFunctionExpression':\n return visitArrowFunctionExpression(expression, context);\n case 'MemberExpression':\n return visitMemberExpression(expression, context);\n case 'ArrayExpression':\n return visitArrayExpression(expression, context);\n case 'SequenceExpression':\n return visitSequenceExpression(expression, context);\n case 'NewExpression':\n return visitNewExpression(expression, context);\n case 'Literal':\n return visitLiteral(expression, context);\n case 'Identifier':\n return visitIdentifier(expression, context);\n case 'TemplateLiteral':\n return visitTemplateLiteral(expression, context);\n case 'TemplateElement':\n return visitTemplateElement(expression, context);\n default:\n throw `Expression evaluator does not support expression of type '${expression.type}'`;\n }\n}\nfunction visitUnaryExpression(expression, context) {\n return visitExpression(expression.argument, context);\n}\nfunction visitBinaryExpression(expression, context) {\n const left = visitExpression(expression.left, context);\n const right = visitExpression(expression.right, context);\n return [\n left,\n right\n ].filter(Boolean);\n}\nfunction visitConditionalExpression(expression, context) {\n const consequent = visitExpression(expression.consequent, context);\n const test = visitExpression(expression.test, context);\n const alternate = visitExpression(expression.alternate, context);\n return [\n consequent,\n test,\n alternate\n ].filter(Boolean);\n}\nfunction visitCallExpression(expression, context) {\n const fn = visitExpression(expression.callee, context);\n expression.arguments?.map(handleNullableExpression(context));\n return fn;\n}\nfunction visitArrowFunctionExpression(expression, context) {\n const newContext = {\n ...context\n };\n newContext.isLocalExpression = true;\n const params = expression.params?.map(handleNullableExpression(newContext)) ?? [];\n const bodyVariables = visitExpression(expression.body, newContext) ?? [];\n if (bodyVariables && Array.isArray(bodyVariables)) {\n for (const v of bodyVariables){\n if (!params.includes(v)) {\n context.variables.add(v);\n }\n }\n }\n}\nfunction visitMemberExpression(expression, context) {\n visitExpression(expression.object, context);\n const newContext = {\n ...context\n };\n newContext.isLocalExpression = true;\n visitExpression(expression.property, newContext);\n}\nfunction visitArrayExpression(expression, context) {\n expression.elements?.map(handleNullableExpression(context));\n}\nfunction visitSequenceExpression(expression, context) {\n expression.expressions?.map(handleNullableExpression(context));\n}\nfunction visitNewExpression(expression, context) {\n expression.arguments?.map(handleNullableExpression(context));\n}\nfunction visitTemplateLiteral(expression, context) {\n expression.expressions?.map(handleNullableExpression(context));\n expression.quasis?.map(handleNullableExpression(context));\n}\nfunction visitTemplateElement(expression, context) {}\nfunction visitIdentifier(expression, context) {\n if (!(expression.name in context.globals)) {\n if (!context.isLocalExpression) {\n context.variables.add(expression.name);\n } else {\n return expression.name;\n }\n }\n}\nfunction visitLiteral(expression, context) {}\nfunction createAsynchronousContext() {\n return createContextInternal(_globals_js__WEBPACK_IMPORTED_MODULE_1__.globalsAsync);\n}\nfunction createContextInternal(globals_) {\n const context = {\n globals: {\n ...globals_\n },\n isLocalExpression: false,\n variables: new Set()\n };\n return context;\n}\nfunction handleNullableExpression(context) {\n return function handleNullableExpressionInner(expression) {\n if (expression === null) {\n return null;\n }\n return visitExpression(expression, context);\n };\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-expression-evaluator/dist/extractor.js","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-expression-evaluator/dist/extractor.js?5852"],"sourcesContent":["/** @category Utility */ import { jsep } from \"./evaluator.js\";\nimport { globalsAsync } from \"./globals.js\";\n/**\n * `extractVariableNames()` is a companion function for `evaluate()` and `evaluateAsync()` which extracts the\n * names of all unbound identifiers used in the expression. The idea is to be able to extract all of the names\n * of variables that will need to be supplied in order to correctly process the expression.\n *\n * @example\n * ```ts\n * // variables will be ['isEmpty', 'array']\n * const variables = extractVariableNames('!isEmpty(array)')\n * ```\n *\n * An identifier is considered \"unbound\" if it is not a reference to the property of an object, is not defined\n * as a parameter to an inline arrow function, and is not a global value. E.g.,\n *\n * @example\n * ```ts\n * // variables will be ['obj']\n * const variables = extractVariableNames('obj.prop()')\n * ```\n *\n * @example\n * ```ts\n * // variables will be ['arr', 'needle']\n * const variables = extractVariableNames('arr.filter(v => v === needle)')\n * ```\n *\n * @example\n * ```ts\n * // variables will be ['myVar']\n * const  variables = extractVariableNames('new String(myVar)')\n * ```\n *\n * Note that because this expression evaluator uses a restricted definition of \"global\" there are some Javascript\n * globals that will be reported as a unbound expression. This is expected because the evaluator will still fail\n * on these expressions.\n *\n * @param expression The expression to analyze, either as a string or pre-parsed expression.\n * @returns An array of variable names that are unbound in the expression.\n */ export function extractVariableNames(expression) {\n    if (typeof expression !== 'string' && (typeof expression !== 'object' || !expression || !('type' in expression))) {\n        throw `Unknown expression type ${expression}. Expressions must either be a string or pre-compiled string.`;\n    }\n    const context = createAsynchronousContext();\n    visitExpression(typeof expression === 'string' ? jsep(expression) : expression, context);\n    return [\n        ...context.variables\n    ];\n}\nfunction visitExpression(expression, context) {\n    switch(expression.type){\n        case 'UnaryExpression':\n            return visitUnaryExpression(expression, context);\n        case 'BinaryExpression':\n            return visitBinaryExpression(expression, context);\n        case 'ConditionalExpression':\n            return visitConditionalExpression(expression, context);\n        case 'CallExpression':\n            return visitCallExpression(expression, context);\n        case 'ArrowFunctionExpression':\n            return visitArrowFunctionExpression(expression, context);\n        case 'MemberExpression':\n            return visitMemberExpression(expression, context);\n        case 'ArrayExpression':\n            return visitArrayExpression(expression, context);\n        case 'SequenceExpression':\n            return visitSequenceExpression(expression, context);\n        case 'NewExpression':\n            return visitNewExpression(expression, context);\n        case 'Literal':\n            return visitLiteral(expression, context);\n        case 'Identifier':\n            return visitIdentifier(expression, context);\n        case 'TemplateLiteral':\n            return visitTemplateLiteral(expression, context);\n        case 'TemplateElement':\n            return visitTemplateElement(expression, context);\n        default:\n            throw `Expression evaluator does not support expression of type '${expression.type}'`;\n    }\n}\nfunction visitUnaryExpression(expression, context) {\n    return visitExpression(expression.argument, context);\n}\nfunction visitBinaryExpression(expression, context) {\n    const left = visitExpression(expression.left, context);\n    const right = visitExpression(expression.right, context);\n    return [\n        left,\n        right\n    ].filter(Boolean);\n}\nfunction visitConditionalExpression(expression, context) {\n    const consequent = visitExpression(expression.consequent, context);\n    const test = visitExpression(expression.test, context);\n    const alternate = visitExpression(expression.alternate, context);\n    return [\n        consequent,\n        test,\n        alternate\n    ].filter(Boolean);\n}\nfunction visitCallExpression(expression, context) {\n    const fn = visitExpression(expression.callee, context);\n    expression.arguments?.map(handleNullableExpression(context));\n    return fn;\n}\nfunction visitArrowFunctionExpression(expression, context) {\n    const newContext = {\n        ...context\n    };\n    newContext.isLocalExpression = true;\n    const params = expression.params?.map(handleNullableExpression(newContext)) ?? [];\n    const bodyVariables = visitExpression(expression.body, newContext) ?? [];\n    if (bodyVariables && Array.isArray(bodyVariables)) {\n        for (const v of bodyVariables){\n            if (!params.includes(v)) {\n                context.variables.add(v);\n            }\n        }\n    }\n}\nfunction visitMemberExpression(expression, context) {\n    visitExpression(expression.object, context);\n    const newContext = {\n        ...context\n    };\n    newContext.isLocalExpression = true;\n    visitExpression(expression.property, newContext);\n}\nfunction visitArrayExpression(expression, context) {\n    expression.elements?.map(handleNullableExpression(context));\n}\nfunction visitSequenceExpression(expression, context) {\n    expression.expressions?.map(handleNullableExpression(context));\n}\nfunction visitNewExpression(expression, context) {\n    expression.arguments?.map(handleNullableExpression(context));\n}\nfunction visitTemplateLiteral(expression, context) {\n    expression.expressions?.map(handleNullableExpression(context));\n    expression.quasis?.map(handleNullableExpression(context));\n}\nfunction visitTemplateElement(expression, context) {}\nfunction visitIdentifier(expression, context) {\n    if (!(expression.name in context.globals)) {\n        if (!context.isLocalExpression) {\n            context.variables.add(expression.name);\n        } else {\n            return expression.name;\n        }\n    }\n}\nfunction visitLiteral(expression, context) {}\nfunction createAsynchronousContext() {\n    return createContextInternal(globalsAsync);\n}\nfunction createContextInternal(globals_) {\n    const context = {\n        globals: {\n            ...globals_\n        },\n        isLocalExpression: false,\n        variables: new Set()\n    };\n    return context;\n}\nfunction handleNullableExpression(context) {\n    return function handleNullableExpressionInner(expression) {\n        if (expression === null) {\n            return null;\n        }\n        return visitExpression(expression, context);\n    };\n}\n"],"names":["jsep","globalsAsync","extractVariableNames","expression","context","createAsynchronousContext","visitExpression","variables","type","visitUnaryExpression","visitBinaryExpression","visitConditionalExpression","visitCallExpression","visitArrowFunctionExpression","visitMemberExpression","visitArrayExpression","visitSequenceExpression","visitNewExpression","visitLiteral","visitIdentifier","visitTemplateLiteral","visitTemplateElement","argument","left","right","filter","Boolean","consequent","test","alternate","fn","callee","arguments","map","handleNullableExpression","newContext","isLocalExpression","params","bodyVariables","body","Array","isArray","v","includes","add","object","property","elements","expressions","quasis","name","globals","createContextInternal","globals_","Set","handleNullableExpressionInner"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-expression-evaluator/dist/extractor.js\n");
279
279
 
280
280
  /***/ }),
281
281
 
@@ -315,7 +315,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
315
315
  \**************************************************************************************************/
316
316
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
317
317
 
318
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ CustomOverflowMenu: () => (/* binding */ CustomOverflowMenu),\n/* harmony export */ CustomOverflowMenuItem: () => (/* binding */ CustomOverflowMenuItem),\n/* harmony export */ useCustomOverflowMenu: () => (/* binding */ useCustomOverflowMenu)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! classnames */ \"../../../node_modules/classnames/index.js\");\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @carbon/react */ \"webpack/sharing/consume/default/@carbon/react/@carbon/react\");\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_carbon_react__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @openmrs/esm-react-utils */ \"../../framework/esm-react-utils/dist/index.js\");\n/* harmony import */ var _custom_overflow_menu_module_scss__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./custom-overflow-menu.module.scss */ \"../../framework/esm-styleguide/src/custom-overflow-menu/custom-overflow-menu.module.scss\");\n/** @module @category UI */ function _array_like_to_array(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];\n return arr2;\n}\nfunction _array_with_holes(arr) {\n if (Array.isArray(arr)) return arr;\n}\nfunction _define_property(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\nfunction _iterable_to_array_limit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n var _s, _e;\n try {\n for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){\n _arr.push(_s.value);\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally{\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally{\n if (_d) throw _e;\n }\n }\n return _arr;\n}\nfunction _non_iterable_rest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nfunction _object_spread(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = arguments[i] != null ? arguments[i] : {};\n var ownKeys = Object.keys(source);\n if (typeof Object.getOwnPropertySymbols === \"function\") {\n ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {\n return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n }));\n }\n ownKeys.forEach(function(key) {\n _define_property(target, key, source[key]);\n });\n }\n return target;\n}\nfunction 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 _sliced_to_array(arr, i) {\n return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();\n}\nfunction _unsupported_iterable_to_array(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _array_like_to_array(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(n);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);\n}\n\n\n\n\n\nvar CustomOverflowMenuContext = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.createContext)(null);\nfunction useCustomOverflowMenu() {\n var context = (0,react__WEBPACK_IMPORTED_MODULE_0__.useContext)(CustomOverflowMenuContext);\n if (!context) {\n throw new Error('useCustomOverflowMenu must be used within a CustomOverflowMenu');\n }\n return context;\n}\n/**\n * A custom overflow menu that supports a text/icon trigger button instead of\n * Carbon's icon-only OverflowMenu trigger. Uses CSS-based show/hide rather\n * than Carbon's FloatingMenu portal, so keyboard behavior (Escape, arrow keys,\n * auto-focus) is implemented here to match the WAI-ARIA menu button pattern.\n */ function CustomOverflowMenu(param) {\n var menuTitle = param.menuTitle, children = param.children;\n var _React_useState = _sliced_to_array(react__WEBPACK_IMPORTED_MODULE_0___default().useState(false), 2), menuIsOpen = _React_useState[0], setMenuIsOpen = _React_useState[1];\n var ref = (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_3__.useOnClickOutside)(function() {\n return setMenuIsOpen(false);\n }, menuIsOpen);\n var isTablet = (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_3__.useLayoutType)() === 'tablet';\n var toggleShowMenu = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function() {\n return setMenuIsOpen(function(state) {\n return !state;\n });\n }, []);\n var triggerRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(null);\n var menuRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(null);\n var uniqueId = (0,react__WEBPACK_IMPORTED_MODULE_0__.useId)();\n var triggerId = \"custom-overflow-menu-trigger-\".concat(uniqueId);\n var menuId = \"custom-overflow-menu-\".concat(uniqueId);\n var closeMenuAndFocusTrigger = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function() {\n var _triggerRef_current;\n setMenuIsOpen(false);\n (_triggerRef_current = triggerRef.current) === null || _triggerRef_current === void 0 ? void 0 : _triggerRef_current.focus();\n }, []);\n var contextValue = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function() {\n return {\n closeMenu: closeMenuAndFocusTrigger\n };\n }, [\n closeMenuAndFocusTrigger\n ]);\n var handleEscapeKey = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function(e) {\n if (e.key === 'Escape' && menuIsOpen) {\n e.stopPropagation();\n closeMenuAndFocusTrigger();\n }\n }, [\n closeMenuAndFocusTrigger,\n menuIsOpen\n ]);\n var childArray = react__WEBPACK_IMPORTED_MODULE_0__.Children.toArray(children);\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function() {\n if (menuIsOpen && menuRef.current) {\n var firstItem = menuRef.current.querySelector('[role=\"menuitem\"]:not([disabled])');\n firstItem === null || firstItem === void 0 ? void 0 : firstItem.focus();\n }\n }, [\n menuIsOpen\n ]);\n var handleOverflowMenuItemFocus = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function(param) {\n var currentIndex = param.currentIndex, direction = param.direction;\n var _menuRef_current, _document_activeElement_closest, _document_activeElement, _enabledItems_wrappedPos;\n var enabledItems = (_menuRef_current = menuRef.current) === null || _menuRef_current === void 0 ? void 0 : _menuRef_current.querySelectorAll('[role=\"menuitem\"]:not([disabled])');\n if (!(enabledItems === null || enabledItems === void 0 ? void 0 : enabledItems.length)) {\n return;\n }\n var _document_activeElement_closest1;\n var activeItem = (_document_activeElement_closest1 = (_document_activeElement = document.activeElement) === null || _document_activeElement === void 0 ? void 0 : (_document_activeElement_closest = _document_activeElement.closest) === null || _document_activeElement_closest === void 0 ? void 0 : _document_activeElement_closest.call(_document_activeElement, '[role=\"menuitem\"]')) !== null && _document_activeElement_closest1 !== void 0 ? _document_activeElement_closest1 : document.activeElement;\n var currentPos = Array.from(enabledItems).indexOf(activeItem);\n if (currentPos === -1) {\n var _enabledItems_;\n (_enabledItems_ = enabledItems[direction > 0 ? 0 : enabledItems.length - 1]) === null || _enabledItems_ === void 0 ? void 0 : _enabledItems_.focus();\n return;\n }\n var nextPos = currentPos + direction;\n var wrappedPos = nextPos < 0 ? enabledItems.length - 1 : nextPos >= enabledItems.length ? 0 : nextPos;\n (_enabledItems_wrappedPos = enabledItems[wrappedPos]) === null || _enabledItems_wrappedPos === void 0 ? void 0 : _enabledItems_wrappedPos.focus();\n }, []);\n var enrichedChildren = childArray.map(function(child, index) {\n if (/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.isValidElement)(child)) {\n return /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.cloneElement)(child, {\n closeMenu: closeMenuAndFocusTrigger,\n handleOverflowMenuItemFocus: handleOverflowMenuItemFocus,\n index: index\n });\n }\n return child;\n });\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n \"data-overflow-menu\": true,\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()('cds--overflow-menu', _custom_overflow_menu_module_scss__WEBPACK_IMPORTED_MODULE_4__[\"default\"].container),\n ref: ref\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"button\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()('cds--btn', 'cds--btn--ghost', 'cds--overflow-menu__trigger', {\n 'cds--overflow-menu--open': menuIsOpen\n }, _custom_overflow_menu_module_scss__WEBPACK_IMPORTED_MODULE_4__[\"default\"].overflowMenuButton),\n \"aria-controls\": menuId,\n \"aria-expanded\": menuIsOpen,\n \"aria-haspopup\": \"true\",\n id: triggerId,\n onClick: toggleShowMenu,\n onKeyDown: handleEscapeKey,\n ref: triggerRef\n }, menuTitle), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()('cds--overflow-menu-options', 'cds--overflow-menu--flip', _custom_overflow_menu_module_scss__WEBPACK_IMPORTED_MODULE_4__[\"default\"].menu, _define_property({}, _custom_overflow_menu_module_scss__WEBPACK_IMPORTED_MODULE_4__[\"default\"].show, menuIsOpen)),\n \"aria-labelledby\": triggerId,\n \"data-floating-menu-direction\": \"bottom\",\n id: menuId,\n onKeyDown: handleEscapeKey,\n ref: menuRef,\n role: \"menu\",\n tabIndex: -1\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"ul\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()('cds--overflow-menu-options__content', {\n 'cds--overflow-menu-options--lg': isTablet\n })\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(CustomOverflowMenuContext.Provider, {\n value: contextValue\n }, enrichedChildren)), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"span\", null)));\n}\nfunction CustomOverflowMenuItem(props) {\n var context = (0,react__WEBPACK_IMPORTED_MODULE_0__.useContext)(CustomOverflowMenuContext);\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_2__.OverflowMenuItem, _object_spread_props(_object_spread({}, props), {\n closeMenu: context === null || context === void 0 ? void 0 : context.closeMenu\n }));\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-styleguide/src/custom-overflow-menu/custom-overflow-menu.component.tsx","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-styleguide/src/custom-overflow-menu/custom-overflow-menu.component.tsx?ad21"],"sourcesContent":["/** @module @category UI */\nimport React, {\n  Children,\n  cloneElement,\n  createContext,\n  isValidElement,\n  useCallback,\n  useContext,\n  useEffect,\n  useId,\n  useMemo,\n  useRef,\n  type ComponentProps,\n} from 'react';\nimport classNames from 'classnames';\nimport { OverflowMenuItem } from '@carbon/react';\nimport { useLayoutType, useOnClickOutside } from '@openmrs/esm-react-utils';\nimport styles from './custom-overflow-menu.module.scss';\n\ninterface CustomOverflowMenuContextValue {\n  closeMenu: () => void;\n}\n\nconst CustomOverflowMenuContext = createContext<CustomOverflowMenuContextValue | null>(null);\n\nexport function useCustomOverflowMenu() {\n  const context = useContext(CustomOverflowMenuContext);\n  if (!context) {\n    throw new Error('useCustomOverflowMenu must be used within a CustomOverflowMenu');\n  }\n  return context;\n}\n\ninterface CustomOverflowMenuProps {\n  menuTitle: React.ReactNode;\n  children: React.ReactNode;\n}\n\n/**\n * A custom overflow menu that supports a text/icon trigger button instead of\n * Carbon's icon-only OverflowMenu trigger. Uses CSS-based show/hide rather\n * than Carbon's FloatingMenu portal, so keyboard behavior (Escape, arrow keys,\n * auto-focus) is implemented here to match the WAI-ARIA menu button pattern.\n */\nexport function CustomOverflowMenu({ menuTitle, children }: CustomOverflowMenuProps) {\n  const [menuIsOpen, setMenuIsOpen] = React.useState(false);\n  const ref = useOnClickOutside<HTMLDivElement>(() => setMenuIsOpen(false), menuIsOpen);\n  const isTablet = useLayoutType() === 'tablet';\n  const toggleShowMenu = useCallback(() => setMenuIsOpen((state) => !state), []);\n  const triggerRef = useRef<HTMLButtonElement>(null);\n  const menuRef = useRef<HTMLDivElement>(null);\n  const uniqueId = useId();\n  const triggerId = `custom-overflow-menu-trigger-${uniqueId}`;\n  const menuId = `custom-overflow-menu-${uniqueId}`;\n\n  const closeMenuAndFocusTrigger = useCallback(() => {\n    setMenuIsOpen(false);\n    triggerRef.current?.focus();\n  }, []);\n\n  const contextValue = useMemo(() => ({ closeMenu: closeMenuAndFocusTrigger }), [closeMenuAndFocusTrigger]);\n\n  const handleEscapeKey = useCallback(\n    (e: React.KeyboardEvent) => {\n      if (e.key === 'Escape' && menuIsOpen) {\n        e.stopPropagation();\n        closeMenuAndFocusTrigger();\n      }\n    },\n    [closeMenuAndFocusTrigger, menuIsOpen],\n  );\n\n  const childArray = Children.toArray(children);\n\n  useEffect(() => {\n    if (menuIsOpen && menuRef.current) {\n      const firstItem = menuRef.current.querySelector<HTMLElement>('[role=\"menuitem\"]:not([disabled])');\n      firstItem?.focus();\n    }\n  }, [menuIsOpen]);\n\n  const handleOverflowMenuItemFocus = useCallback(\n    ({ currentIndex, direction }: { currentIndex?: number; direction: number }) => {\n      const enabledItems = menuRef.current?.querySelectorAll<HTMLElement>('[role=\"menuitem\"]:not([disabled])');\n      if (!enabledItems?.length) {\n        return;\n      }\n\n      const activeItem =\n        (document.activeElement?.closest?.('[role=\"menuitem\"]') as HTMLElement) ?? document.activeElement;\n      const currentPos = Array.from(enabledItems).indexOf(activeItem as HTMLElement);\n      if (currentPos === -1) {\n        enabledItems[direction > 0 ? 0 : enabledItems.length - 1]?.focus();\n        return;\n      }\n\n      const nextPos = currentPos + direction;\n      const wrappedPos = nextPos < 0 ? enabledItems.length - 1 : nextPos >= enabledItems.length ? 0 : nextPos;\n      enabledItems[wrappedPos]?.focus();\n    },\n    [],\n  );\n\n  const enrichedChildren = childArray.map((child, index) => {\n    if (isValidElement(child)) {\n      return cloneElement(child as React.ReactElement<any>, {\n        closeMenu: closeMenuAndFocusTrigger,\n        handleOverflowMenuItemFocus,\n        index,\n      });\n    }\n    return child;\n  });\n\n  return (\n    <div data-overflow-menu className={classNames('cds--overflow-menu', styles.container)} ref={ref}>\n      <button\n        className={classNames(\n          'cds--btn',\n          'cds--btn--ghost',\n          'cds--overflow-menu__trigger',\n          { 'cds--overflow-menu--open': menuIsOpen },\n          styles.overflowMenuButton,\n        )}\n        aria-controls={menuId}\n        aria-expanded={menuIsOpen}\n        aria-haspopup=\"true\"\n        id={triggerId}\n        onClick={toggleShowMenu}\n        onKeyDown={handleEscapeKey}\n        ref={triggerRef}\n      >\n        {menuTitle}\n      </button>\n      <div\n        className={classNames('cds--overflow-menu-options', 'cds--overflow-menu--flip', styles.menu, {\n          [styles.show]: menuIsOpen,\n        })}\n        aria-labelledby={triggerId}\n        data-floating-menu-direction=\"bottom\"\n        id={menuId}\n        onKeyDown={handleEscapeKey}\n        ref={menuRef}\n        role=\"menu\"\n        tabIndex={-1}\n      >\n        <ul\n          className={classNames('cds--overflow-menu-options__content', { 'cds--overflow-menu-options--lg': isTablet })}\n        >\n          <CustomOverflowMenuContext.Provider value={contextValue}>\n            {enrichedChildren}\n          </CustomOverflowMenuContext.Provider>\n        </ul>\n        <span />\n      </div>\n    </div>\n  );\n}\n\ntype OverflowMenuItemProps = ComponentProps<typeof OverflowMenuItem>;\n\nexport function CustomOverflowMenuItem(props: Omit<OverflowMenuItemProps, 'closeMenu'>) {\n  const context = useContext(CustomOverflowMenuContext);\n  return <OverflowMenuItem {...props} closeMenu={context?.closeMenu} />;\n}\n"],"names":["React","Children","cloneElement","createContext","isValidElement","useCallback","useContext","useEffect","useId","useMemo","useRef","classNames","OverflowMenuItem","useLayoutType","useOnClickOutside","styles","CustomOverflowMenuContext","useCustomOverflowMenu","context","Error","CustomOverflowMenu","menuTitle","children","useState","menuIsOpen","setMenuIsOpen","ref","isTablet","toggleShowMenu","state","triggerRef","menuRef","uniqueId","triggerId","menuId","closeMenuAndFocusTrigger","current","focus","contextValue","closeMenu","handleEscapeKey","e","key","stopPropagation","childArray","toArray","firstItem","querySelector","handleOverflowMenuItemFocus","currentIndex","direction","document","enabledItems","querySelectorAll","length","activeItem","activeElement","closest","currentPos","Array","from","indexOf","nextPos","wrappedPos","enrichedChildren","map","child","index","div","data-overflow-menu","className","container","button","overflowMenuButton","aria-controls","aria-expanded","aria-haspopup","id","onClick","onKeyDown","menu","show","aria-labelledby","data-floating-menu-direction","role","tabIndex","ul","Provider","value","span","CustomOverflowMenuItem","props"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/src/custom-overflow-menu/custom-overflow-menu.component.tsx\n");
318
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ CustomOverflowMenu: () => (/* binding */ CustomOverflowMenu),\n/* harmony export */ CustomOverflowMenuItem: () => (/* binding */ CustomOverflowMenuItem),\n/* harmony export */ useCustomOverflowMenu: () => (/* binding */ useCustomOverflowMenu)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! classnames */ \"../../../node_modules/classnames/index.js\");\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @carbon/react */ \"webpack/sharing/consume/default/@carbon/react/@carbon/react\");\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_carbon_react__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @openmrs/esm-react-utils */ \"../../framework/esm-react-utils/dist/index.js\");\n/* harmony import */ var _custom_overflow_menu_module_scss__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./custom-overflow-menu.module.scss */ \"../../framework/esm-styleguide/src/custom-overflow-menu/custom-overflow-menu.module.scss\");\n/** @module @category UI */ function _array_like_to_array(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];\n return arr2;\n}\nfunction _array_with_holes(arr) {\n if (Array.isArray(arr)) return arr;\n}\nfunction _define_property(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\nfunction _iterable_to_array_limit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n var _s, _e;\n try {\n for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){\n _arr.push(_s.value);\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally{\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally{\n if (_d) throw _e;\n }\n }\n return _arr;\n}\nfunction _non_iterable_rest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nfunction _object_spread(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = arguments[i] != null ? arguments[i] : {};\n var ownKeys = Object.keys(source);\n if (typeof Object.getOwnPropertySymbols === \"function\") {\n ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {\n return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n }));\n }\n ownKeys.forEach(function(key) {\n _define_property(target, key, source[key]);\n });\n }\n return target;\n}\nfunction 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 _sliced_to_array(arr, i) {\n return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();\n}\nfunction _unsupported_iterable_to_array(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return _array_like_to_array(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(n);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);\n}\n\n\n\n\n\nvar CustomOverflowMenuContext = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.createContext)(null);\nfunction useCustomOverflowMenu() {\n var context = (0,react__WEBPACK_IMPORTED_MODULE_0__.useContext)(CustomOverflowMenuContext);\n if (!context) {\n throw new Error('useCustomOverflowMenu must be used within a CustomOverflowMenu');\n }\n return context;\n}\n/**\n * A custom overflow menu that supports a text/icon trigger button instead of\n * Carbon's icon-only OverflowMenu trigger. Uses CSS-based show/hide rather\n * than Carbon's FloatingMenu portal, so keyboard behavior (Escape, arrow keys,\n * auto-focus) is implemented here to match the WAI-ARIA menu button pattern.\n */ function CustomOverflowMenu(param) {\n var menuTitle = param.menuTitle, children = param.children;\n var _React_useState = _sliced_to_array(react__WEBPACK_IMPORTED_MODULE_0___default().useState(false), 2), menuIsOpen = _React_useState[0], setMenuIsOpen = _React_useState[1];\n var ref = (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_3__.useOnClickOutside)(function() {\n return setMenuIsOpen(false);\n }, menuIsOpen);\n var isTablet = (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_3__.useLayoutType)() === 'tablet';\n var toggleShowMenu = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function() {\n return setMenuIsOpen(function(state) {\n return !state;\n });\n }, []);\n var triggerRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(null);\n var menuRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(null);\n var uniqueId = (0,react__WEBPACK_IMPORTED_MODULE_0__.useId)();\n var triggerId = \"custom-overflow-menu-trigger-\".concat(uniqueId);\n var menuId = \"custom-overflow-menu-\".concat(uniqueId);\n var closeMenuAndFocusTrigger = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function() {\n var _triggerRef_current;\n setMenuIsOpen(false);\n (_triggerRef_current = triggerRef.current) === null || _triggerRef_current === void 0 ? void 0 : _triggerRef_current.focus();\n }, []);\n var contextValue = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function() {\n return {\n closeMenu: closeMenuAndFocusTrigger\n };\n }, [\n closeMenuAndFocusTrigger\n ]);\n var handleEscapeKey = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function(e) {\n if (e.key === 'Escape' && menuIsOpen) {\n e.stopPropagation();\n closeMenuAndFocusTrigger();\n }\n }, [\n closeMenuAndFocusTrigger,\n menuIsOpen\n ]);\n var childArray = react__WEBPACK_IMPORTED_MODULE_0__.Children.toArray(children);\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function() {\n if (menuIsOpen && menuRef.current) {\n var firstItem = menuRef.current.querySelector('[role=\"menuitem\"]:not([disabled])');\n firstItem === null || firstItem === void 0 ? void 0 : firstItem.focus();\n }\n }, [\n menuIsOpen\n ]);\n var handleOverflowMenuItemFocus = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function(param) {\n var currentIndex = param.currentIndex, direction = param.direction;\n var _menuRef_current, _document_activeElement_closest, _document_activeElement, _enabledItems_wrappedPos;\n var enabledItems = (_menuRef_current = menuRef.current) === null || _menuRef_current === void 0 ? void 0 : _menuRef_current.querySelectorAll('[role=\"menuitem\"]:not([disabled])');\n if (!(enabledItems === null || enabledItems === void 0 ? void 0 : enabledItems.length)) {\n return;\n }\n var _document_activeElement_closest1;\n var activeItem = (_document_activeElement_closest1 = (_document_activeElement = document.activeElement) === null || _document_activeElement === void 0 ? void 0 : (_document_activeElement_closest = _document_activeElement.closest) === null || _document_activeElement_closest === void 0 ? void 0 : _document_activeElement_closest.call(_document_activeElement, '[role=\"menuitem\"]')) !== null && _document_activeElement_closest1 !== void 0 ? _document_activeElement_closest1 : document.activeElement;\n var currentPos = Array.from(enabledItems).indexOf(activeItem);\n if (currentPos === -1) {\n var _enabledItems_;\n (_enabledItems_ = enabledItems[direction > 0 ? 0 : enabledItems.length - 1]) === null || _enabledItems_ === void 0 ? void 0 : _enabledItems_.focus();\n return;\n }\n var nextPos = currentPos + direction;\n var wrappedPos = nextPos < 0 ? enabledItems.length - 1 : nextPos >= enabledItems.length ? 0 : nextPos;\n (_enabledItems_wrappedPos = enabledItems[wrappedPos]) === null || _enabledItems_wrappedPos === void 0 ? void 0 : _enabledItems_wrappedPos.focus();\n }, []);\n var enrichedChildren = childArray.map(function(child, index) {\n if (/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.isValidElement)(child)) {\n return /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.cloneElement)(child, {\n closeMenu: closeMenuAndFocusTrigger,\n handleOverflowMenuItemFocus: handleOverflowMenuItemFocus,\n index: index\n });\n }\n return child;\n });\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n \"data-overflow-menu\": true,\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()('cds--overflow-menu', _custom_overflow_menu_module_scss__WEBPACK_IMPORTED_MODULE_4__[\"default\"].container),\n ref: ref\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"button\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()('cds--btn', 'cds--btn--ghost', 'cds--overflow-menu__trigger', {\n 'cds--overflow-menu--open': menuIsOpen\n }, _custom_overflow_menu_module_scss__WEBPACK_IMPORTED_MODULE_4__[\"default\"].overflowMenuButton),\n \"aria-controls\": menuId,\n \"aria-expanded\": menuIsOpen,\n \"aria-haspopup\": \"true\",\n id: triggerId,\n onClick: toggleShowMenu,\n onKeyDown: handleEscapeKey,\n ref: triggerRef\n }, menuTitle), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()('cds--overflow-menu-options', 'cds--overflow-menu--flip', _custom_overflow_menu_module_scss__WEBPACK_IMPORTED_MODULE_4__[\"default\"].menu, _define_property({}, _custom_overflow_menu_module_scss__WEBPACK_IMPORTED_MODULE_4__[\"default\"].show, menuIsOpen)),\n \"aria-labelledby\": triggerId,\n \"data-floating-menu-direction\": \"bottom\",\n id: menuId,\n onKeyDown: handleEscapeKey,\n ref: menuRef,\n role: \"menu\",\n tabIndex: -1\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"ul\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()('cds--overflow-menu-options__content', {\n 'cds--overflow-menu-options--lg': isTablet\n })\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(CustomOverflowMenuContext.Provider, {\n value: contextValue\n }, enrichedChildren)), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"span\", null)));\n}\nfunction CustomOverflowMenuItem(props) {\n var context = (0,react__WEBPACK_IMPORTED_MODULE_0__.useContext)(CustomOverflowMenuContext);\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_2__.OverflowMenuItem, _object_spread_props(_object_spread({}, props), {\n closeMenu: context === null || context === void 0 ? void 0 : context.closeMenu\n }));\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-styleguide/src/custom-overflow-menu/custom-overflow-menu.component.tsx","mappings":";;;;;;;;;;;;;;AAAA,yBAAyB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAaV;AACqB;AACa;AAC2B;AACpB;AAMxD,IAAMgB,0CAA4Bb,oDAAaA,CAAwC;AAEhF,SAASc;IACd,IAAMC,UAAUZ,iDAAUA,CAACU;IAC3B,IAAI,CAACE,SAAS;QACZ,MAAM,IAAIC,MAAM;IAClB;IACA,OAAOD;AACT;AASA;;;;;CAKC,GACM,SAASE,mBAAmB,KAAgD;QAA9CC,YAAF,MAAEA,WAAWC,WAAb,MAAaA;IAC9C,IAAoCtB,mCAAAA,qDAAc,CAAC,YAA5CwB,aAA6BxB,oBAAjByB,gBAAiBzB;IACpC,IAAM0B,MAAMZ,2EAAiBA,CAAiB;eAAMW,cAAc;OAAQD;IAC1E,IAAMG,WAAWd,uEAAaA,OAAO;IACrC,IAAMe,iBAAiBvB,kDAAWA,CAAC;eAAMoB,cAAc,SAACI;mBAAU,CAACA;;OAAQ,EAAE;IAC7E,IAAMC,aAAapB,6CAAMA,CAAoB;IAC7C,IAAMqB,UAAUrB,6CAAMA,CAAiB;IACvC,IAAMsB,WAAWxB,4CAAKA;IACtB,IAAMyB,YAAY,gCAAyC,OAATD;IAClD,IAAME,SAAS,wBAAiC,OAATF;IAEvC,IAAMG,2BAA2B9B,kDAAWA,CAAC;YAE3CyB;QADAL,cAAc;SACdK,sBAAAA,WAAWM,OAAO,cAAlBN,0CAAAA,oBAAoBO,KAAK;IAC3B,GAAG,EAAE;IAEL,IAAMC,eAAe7B,8CAAOA,CAAC;eAAO;YAAE8B,WAAWJ;QAAyB;OAAI;QAACA;KAAyB;IAExG,IAAMK,kBAAkBnC,kDAAWA,CACjC,SAACoC;QACC,IAAIA,EAAEC,GAAG,KAAK,YAAYlB,YAAY;YACpCiB,EAAEE,eAAe;YACjBR;QACF;IACF,GACA;QAACA;QAA0BX;KAAW;IAGxC,IAAMoB,aAAa3C,2CAAQA,CAAC4C,OAAO,CAACvB;IAEpCf,gDAASA,CAAC;QACR,IAAIiB,cAAcO,QAAQK,OAAO,EAAE;YACjC,IAAMU,YAAYf,QAAQK,OAAO,CAACW,aAAa,CAAc;YAC7DD,sBAAAA,gCAAAA,UAAWT,KAAK;QAClB;IACF,GAAG;QAACb;KAAW;IAEf,IAAMwB,8BAA8B3C,kDAAWA,CAC7C;YAAG4C,qBAAAA,cAAcC,kBAAAA;YACMnB,kBAMlBoB,iCAAAA,yBASHC;QAfA,IAAMA,gBAAerB,mBAAAA,QAAQK,OAAO,cAAfL,uCAAAA,iBAAiBsB,gBAAgB,CAAc;QACpE,IAAI,EAACD,yBAAAA,mCAAAA,aAAcE,MAAM,GAAE;YACzB;QACF;YAGGH;QADH,IAAMI,aACJ,CAACJ,oCAAAA,0BAAAA,SAASK,aAAa,cAAtBL,+CAAAA,kCAAAA,wBAAwBM,OAAO,cAA/BN,sDAAAA,qCAAAA,yBAAkC,kCAAlCA,8CAAAA,mCAA0EA,SAASK,aAAa;QACnG,IAAME,aAAaC,MAAMC,IAAI,CAACR,cAAcS,OAAO,CAACN;QACpD,IAAIG,eAAe,CAAC,GAAG;gBACrBN;aAAAA,iBAAAA,YAAY,CAACF,YAAY,IAAI,IAAIE,aAAaE,MAAM,GAAG,EAAE,cAAzDF,qCAAAA,eAA2Df,KAAK;YAChE;QACF;QAEA,IAAMyB,UAAUJ,aAAaR;QAC7B,IAAMa,aAAaD,UAAU,IAAIV,aAAaE,MAAM,GAAG,IAAIQ,WAAWV,aAAaE,MAAM,GAAG,IAAIQ;SAChGV,2BAAAA,YAAY,CAACW,WAAW,cAAxBX,+CAAAA,yBAA0Bf,KAAK;IACjC,GACA,EAAE;IAGJ,IAAM2B,mBAAmBpB,WAAWqB,GAAG,CAAC,SAACC,OAAOC;QAC9C,kBAAI/D,qDAAcA,CAAC8D,QAAQ;YACzB,qBAAOhE,mDAAYA,CAACgE,OAAkC;gBACpD3B,WAAWJ;gBACXa,6BAAAA;gBACAmB,OAAAA;YACF;QACF;QACA,OAAOD;IACT;IAEA,qBACE,2DAACE;QAAIC,sBAAAA;QAAmBC,WAAW3D,iDAAUA,CAAC,sBAAsBI,yEAAMA,CAACwD,SAAS;QAAG7C,KAAKA;qBAC1F,2DAAC8C;QACCF,WAAW3D,iDAAUA,CACnB,YACA,mBACA,+BACA;YAAE,4BAA4Ba;QAAW,GACzCT,yEAAMA,CAAC0D,kBAAkB;QAE3BC,iBAAexC;QACfyC,iBAAenD;QACfoD,iBAAc;QACdC,IAAI5C;QACJ6C,SAASlD;QACTmD,WAAWvC;QACXd,KAAKI;OAEJT,0BAEH,2DAAC+C;QACCE,WAAW3D,iDAAUA,CAAC,8BAA8B,4BAA4BI,yEAAMA,CAACiE,IAAI,EACzF,qBAACjE,yEAAMA,CAACkE,IAAI,EAAGzD;QAEjB0D,mBAAiBjD;QACjBkD,gCAA6B;QAC7BN,IAAI3C;QACJ6C,WAAWvC;QACXd,KAAKK;QACLqD,MAAK;QACLC,UAAU,CAAC;qBAEX,2DAACC;QACChB,WAAW3D,iDAAUA,CAAC,uCAAuC;YAAE,kCAAkCgB;QAAS;qBAE1G,2DAACX,0BAA0BuE,QAAQ;QAACC,OAAOlD;OACxC0B,kCAGL,2DAACyB;AAIT;AAIO,SAASC,uBAAuBC,KAA+C;IACpF,IAAMzE,UAAUZ,iDAAUA,CAACU;IAC3B,qBAAO,2DAACJ,2DAAgBA,0CAAK+E;QAAOpD,SAAS,EAAErB,oBAAAA,8BAAAA,QAASqB,SAAS;;AACnE","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-styleguide/src/custom-overflow-menu/custom-overflow-menu.component.tsx?ad21"],"sourcesContent":["/** @module @category UI */\nimport React, {\n  Children,\n  cloneElement,\n  createContext,\n  isValidElement,\n  useCallback,\n  useContext,\n  useEffect,\n  useId,\n  useMemo,\n  useRef,\n  type ComponentProps,\n} from 'react';\nimport classNames from 'classnames';\nimport { OverflowMenuItem } from '@carbon/react';\nimport { useLayoutType, useOnClickOutside } from '@openmrs/esm-react-utils';\nimport styles from './custom-overflow-menu.module.scss';\n\ninterface CustomOverflowMenuContextValue {\n  closeMenu: () => void;\n}\n\nconst CustomOverflowMenuContext = createContext<CustomOverflowMenuContextValue | null>(null);\n\nexport function useCustomOverflowMenu() {\n  const context = useContext(CustomOverflowMenuContext);\n  if (!context) {\n    throw new Error('useCustomOverflowMenu must be used within a CustomOverflowMenu');\n  }\n  return context;\n}\n\ninterface CustomOverflowMenuProps {\n  /** The content to display as the menu trigger button. */\n  menuTitle: React.ReactNode;\n  /** The menu items to display when the menu is open. */\n  children: React.ReactNode;\n}\n\n/**\n * A custom overflow menu that supports a text/icon trigger button instead of\n * Carbon's icon-only OverflowMenu trigger. Uses CSS-based show/hide rather\n * than Carbon's FloatingMenu portal, so keyboard behavior (Escape, arrow keys,\n * auto-focus) is implemented here to match the WAI-ARIA menu button pattern.\n */\nexport function CustomOverflowMenu({ menuTitle, children }: CustomOverflowMenuProps) {\n  const [menuIsOpen, setMenuIsOpen] = React.useState(false);\n  const ref = useOnClickOutside<HTMLDivElement>(() => setMenuIsOpen(false), menuIsOpen);\n  const isTablet = useLayoutType() === 'tablet';\n  const toggleShowMenu = useCallback(() => setMenuIsOpen((state) => !state), []);\n  const triggerRef = useRef<HTMLButtonElement>(null);\n  const menuRef = useRef<HTMLDivElement>(null);\n  const uniqueId = useId();\n  const triggerId = `custom-overflow-menu-trigger-${uniqueId}`;\n  const menuId = `custom-overflow-menu-${uniqueId}`;\n\n  const closeMenuAndFocusTrigger = useCallback(() => {\n    setMenuIsOpen(false);\n    triggerRef.current?.focus();\n  }, []);\n\n  const contextValue = useMemo(() => ({ closeMenu: closeMenuAndFocusTrigger }), [closeMenuAndFocusTrigger]);\n\n  const handleEscapeKey = useCallback(\n    (e: React.KeyboardEvent) => {\n      if (e.key === 'Escape' && menuIsOpen) {\n        e.stopPropagation();\n        closeMenuAndFocusTrigger();\n      }\n    },\n    [closeMenuAndFocusTrigger, menuIsOpen],\n  );\n\n  const childArray = Children.toArray(children);\n\n  useEffect(() => {\n    if (menuIsOpen && menuRef.current) {\n      const firstItem = menuRef.current.querySelector<HTMLElement>('[role=\"menuitem\"]:not([disabled])');\n      firstItem?.focus();\n    }\n  }, [menuIsOpen]);\n\n  const handleOverflowMenuItemFocus = useCallback(\n    ({ currentIndex, direction }: { currentIndex?: number; direction: number }) => {\n      const enabledItems = menuRef.current?.querySelectorAll<HTMLElement>('[role=\"menuitem\"]:not([disabled])');\n      if (!enabledItems?.length) {\n        return;\n      }\n\n      const activeItem =\n        (document.activeElement?.closest?.('[role=\"menuitem\"]') as HTMLElement) ?? document.activeElement;\n      const currentPos = Array.from(enabledItems).indexOf(activeItem as HTMLElement);\n      if (currentPos === -1) {\n        enabledItems[direction > 0 ? 0 : enabledItems.length - 1]?.focus();\n        return;\n      }\n\n      const nextPos = currentPos + direction;\n      const wrappedPos = nextPos < 0 ? enabledItems.length - 1 : nextPos >= enabledItems.length ? 0 : nextPos;\n      enabledItems[wrappedPos]?.focus();\n    },\n    [],\n  );\n\n  const enrichedChildren = childArray.map((child, index) => {\n    if (isValidElement(child)) {\n      return cloneElement(child as React.ReactElement<any>, {\n        closeMenu: closeMenuAndFocusTrigger,\n        handleOverflowMenuItemFocus,\n        index,\n      });\n    }\n    return child;\n  });\n\n  return (\n    <div data-overflow-menu className={classNames('cds--overflow-menu', styles.container)} ref={ref}>\n      <button\n        className={classNames(\n          'cds--btn',\n          'cds--btn--ghost',\n          'cds--overflow-menu__trigger',\n          { 'cds--overflow-menu--open': menuIsOpen },\n          styles.overflowMenuButton,\n        )}\n        aria-controls={menuId}\n        aria-expanded={menuIsOpen}\n        aria-haspopup=\"true\"\n        id={triggerId}\n        onClick={toggleShowMenu}\n        onKeyDown={handleEscapeKey}\n        ref={triggerRef}\n      >\n        {menuTitle}\n      </button>\n      <div\n        className={classNames('cds--overflow-menu-options', 'cds--overflow-menu--flip', styles.menu, {\n          [styles.show]: menuIsOpen,\n        })}\n        aria-labelledby={triggerId}\n        data-floating-menu-direction=\"bottom\"\n        id={menuId}\n        onKeyDown={handleEscapeKey}\n        ref={menuRef}\n        role=\"menu\"\n        tabIndex={-1}\n      >\n        <ul\n          className={classNames('cds--overflow-menu-options__content', { 'cds--overflow-menu-options--lg': isTablet })}\n        >\n          <CustomOverflowMenuContext.Provider value={contextValue}>\n            {enrichedChildren}\n          </CustomOverflowMenuContext.Provider>\n        </ul>\n        <span />\n      </div>\n    </div>\n  );\n}\n\ntype OverflowMenuItemProps = ComponentProps<typeof OverflowMenuItem>;\n\nexport function CustomOverflowMenuItem(props: Omit<OverflowMenuItemProps, 'closeMenu'>) {\n  const context = useContext(CustomOverflowMenuContext);\n  return <OverflowMenuItem {...props} closeMenu={context?.closeMenu} />;\n}\n"],"names":["React","Children","cloneElement","createContext","isValidElement","useCallback","useContext","useEffect","useId","useMemo","useRef","classNames","OverflowMenuItem","useLayoutType","useOnClickOutside","styles","CustomOverflowMenuContext","useCustomOverflowMenu","context","Error","CustomOverflowMenu","menuTitle","children","useState","menuIsOpen","setMenuIsOpen","ref","isTablet","toggleShowMenu","state","triggerRef","menuRef","uniqueId","triggerId","menuId","closeMenuAndFocusTrigger","current","focus","contextValue","closeMenu","handleEscapeKey","e","key","stopPropagation","childArray","toArray","firstItem","querySelector","handleOverflowMenuItemFocus","currentIndex","direction","document","enabledItems","querySelectorAll","length","activeItem","activeElement","closest","currentPos","Array","from","indexOf","nextPos","wrappedPos","enrichedChildren","map","child","index","div","data-overflow-menu","className","container","button","overflowMenuButton","aria-controls","aria-expanded","aria-haspopup","id","onClick","onKeyDown","menu","show","aria-labelledby","data-floating-menu-direction","role","tabIndex","ul","Provider","value","span","CustomOverflowMenuItem","props"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/src/custom-overflow-menu/custom-overflow-menu.component.tsx\n");
319
319
 
320
320
  /***/ }),
321
321
 
@@ -605,7 +605,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
605
605
  \**********************************************************/
606
606
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
607
607
 
608
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ ActivityIcon: () => (/* binding */ ActivityIcon),\n/* harmony export */ AddIcon: () => (/* binding */ AddIcon),\n/* harmony export */ AllergiesIcon: () => (/* binding */ AllergiesIcon),\n/* harmony export */ ArrowDownIcon: () => (/* binding */ ArrowDownIcon),\n/* harmony export */ ArrowLeftIcon: () => (/* binding */ ArrowLeftIcon),\n/* harmony export */ ArrowRightIcon: () => (/* binding */ ArrowRightIcon),\n/* harmony export */ ArrowUpIcon: () => (/* binding */ ArrowUpIcon),\n/* harmony export */ AttachmentIcon: () => (/* binding */ AttachmentIcon),\n/* harmony export */ BabyIcon: () => (/* binding */ BabyIcon),\n/* harmony export */ CalendarHeatMapIcon: () => (/* binding */ CalendarHeatMapIcon),\n/* harmony export */ CalendarIcon: () => (/* binding */ CalendarIcon),\n/* harmony export */ CaretDownIcon: () => (/* binding */ CaretDownIcon),\n/* harmony export */ CaretLeftIcon: () => (/* binding */ CaretLeftIcon),\n/* harmony export */ CaretRightIcon: () => (/* binding */ CaretRightIcon),\n/* harmony export */ CaretUpIcon: () => (/* binding */ CaretUpIcon),\n/* harmony export */ ChartAverageIcon: () => (/* binding */ ChartAverageIcon),\n/* harmony export */ CheckmarkFilledIcon: () => (/* binding */ CheckmarkFilledIcon),\n/* harmony export */ CheckmarkOutlineIcon: () => (/* binding */ CheckmarkOutlineIcon),\n/* harmony export */ ChemistryIcon: () => (/* binding */ ChemistryIcon),\n/* harmony export */ ChevronDownIcon: () => (/* binding */ ChevronDownIcon),\n/* harmony export */ ChevronLeftIcon: () => (/* binding */ ChevronLeftIcon),\n/* harmony export */ ChevronRightIcon: () => (/* binding */ ChevronRightIcon),\n/* harmony export */ ChevronUpIcon: () => (/* binding */ ChevronUpIcon),\n/* harmony export */ CloseFilledIcon: () => (/* binding */ CloseFilledIcon),\n/* harmony export */ CloseIcon: () => (/* binding */ CloseIcon),\n/* harmony export */ CloseOutlineIcon: () => (/* binding */ CloseOutlineIcon),\n/* harmony export */ ConditionsIcon: () => (/* binding */ ConditionsIcon),\n/* harmony export */ DocumentAttachmentIcon: () => (/* binding */ DocumentAttachmentIcon),\n/* harmony export */ DocumentIcon: () => (/* binding */ DocumentIcon),\n/* harmony export */ DownloadIcon: () => (/* binding */ DownloadIcon),\n/* harmony export */ DrugOrderIcon: () => (/* binding */ DrugOrderIcon),\n/* harmony export */ EditIcon: () => (/* binding */ EditIcon),\n/* harmony export */ EventScheduleIcon: () => (/* binding */ EventScheduleIcon),\n/* harmony export */ EventsIcon: () => (/* binding */ EventsIcon),\n/* harmony export */ GenderFemaleIcon: () => (/* binding */ GenderFemaleIcon),\n/* harmony export */ GenderMaleIcon: () => (/* binding */ GenderMaleIcon),\n/* harmony export */ GenderOtherIcon: () => (/* binding */ GenderOtherIcon),\n/* harmony export */ GenderUnknownIcon: () => (/* binding */ GenderUnknownIcon),\n/* harmony export */ GenericOrderTypeIcon: () => (/* binding */ GenericOrderTypeIcon),\n/* harmony export */ GroupAccessIcon: () => (/* binding */ GroupAccessIcon),\n/* harmony export */ GroupIcon: () => (/* binding */ GroupIcon),\n/* harmony export */ HospitalBedIcon: () => (/* binding */ HospitalBedIcon),\n/* harmony export */ Icon: () => (/* binding */ Icon),\n/* harmony export */ ImageMedicalIcon: () => (/* binding */ ImageMedicalIcon),\n/* harmony export */ InformationFilledIcon: () => (/* binding */ InformationFilledIcon),\n/* harmony export */ InformationIcon: () => (/* binding */ InformationIcon),\n/* harmony export */ InformationSquareIcon: () => (/* binding */ InformationSquareIcon),\n/* harmony export */ InventoryManagementIcon: () => (/* binding */ InventoryManagementIcon),\n/* harmony export */ LabOrderIcon: () => (/* binding */ LabOrderIcon),\n/* harmony export */ ListCheckedIcon: () => (/* binding */ ListCheckedIcon),\n/* harmony export */ LocationIcon: () => (/* binding */ LocationIcon),\n/* harmony export */ MaterialOrderIcon: () => (/* binding */ MaterialOrderIcon),\n/* harmony export */ MaximizeIcon: () => (/* binding */ MaximizeIcon),\n/* harmony export */ MaybeIcon: () => (/* binding */ MaybeIcon),\n/* harmony export */ MedicationIcon: () => (/* binding */ MedicationIcon),\n/* harmony export */ MessageQueueIcon: () => (/* binding */ MessageQueueIcon),\n/* harmony export */ MicroscopeIcon: () => (/* binding */ MicroscopeIcon),\n/* harmony export */ MoneyIcon: () => (/* binding */ MoneyIcon),\n/* harmony export */ MotherIcon: () => (/* binding */ MotherIcon),\n/* harmony export */ MovementIcon: () => (/* binding */ MovementIcon),\n/* harmony export */ OverflowMenuHorizontalIcon: () => (/* binding */ OverflowMenuHorizontalIcon),\n/* harmony export */ OverflowMenuVerticalIcon: () => (/* binding */ OverflowMenuVerticalIcon),\n/* harmony export */ PasswordIcon: () => (/* binding */ PasswordIcon),\n/* harmony export */ PedestrianFamilyIcon: () => (/* binding */ PedestrianFamilyIcon),\n/* harmony export */ PenIcon: () => (/* binding */ PenIcon),\n/* harmony export */ PrinterIcon: () => (/* binding */ PrinterIcon),\n/* harmony export */ ProcedureOrderIcon: () => (/* binding */ ProcedureOrderIcon),\n/* harmony export */ ProgramsIcon: () => (/* binding */ ProgramsIcon),\n/* harmony export */ RadiologyIcon: () => (/* binding */ RadiologyIcon),\n/* harmony export */ ReferralOrderIcon: () => (/* binding */ ReferralOrderIcon),\n/* harmony export */ RenewIcon: () => (/* binding */ RenewIcon),\n/* harmony export */ ReportIcon: () => (/* binding */ ReportIcon),\n/* harmony export */ ResetIcon: () => (/* binding */ ResetIcon),\n/* harmony export */ SaveIcon: () => (/* binding */ SaveIcon),\n/* harmony export */ SearchIcon: () => (/* binding */ SearchIcon),\n/* harmony export */ SettingsIcon: () => (/* binding */ SettingsIcon),\n/* harmony export */ ShoppingCartAddItemIcon: () => (/* binding */ ShoppingCartAddItemIcon),\n/* harmony export */ ShoppingCartArrowDownIcon: () => (/* binding */ ShoppingCartArrowDownIcon),\n/* harmony export */ ShoppingCartIcon: () => (/* binding */ ShoppingCartIcon),\n/* harmony export */ StickyNoteAddIcon: () => (/* binding */ StickyNoteAddIcon),\n/* harmony export */ SwitcherIcon: () => (/* binding */ SwitcherIcon),\n/* harmony export */ SyringeIcon: () => (/* binding */ SyringeIcon),\n/* harmony export */ TableIcon: () => (/* binding */ TableIcon),\n/* harmony export */ TableOfContentsIcon: () => (/* binding */ TableOfContentsIcon),\n/* harmony export */ TimeIcon: () => (/* binding */ TimeIcon),\n/* harmony export */ ToolsIcon: () => (/* binding */ ToolsIcon),\n/* harmony export */ TranslateIcon: () => (/* binding */ TranslateIcon),\n/* harmony export */ TrashCanIcon: () => (/* binding */ TrashCanIcon),\n/* harmony export */ TreeViewAltIcon: () => (/* binding */ TreeViewAltIcon),\n/* harmony export */ UserAvatarIcon: () => (/* binding */ UserAvatarIcon),\n/* harmony export */ UserFollowIcon: () => (/* binding */ UserFollowIcon),\n/* harmony export */ UserIcon: () => (/* binding */ UserIcon),\n/* harmony export */ UserXrayIcon: () => (/* binding */ UserXrayIcon),\n/* harmony export */ ViewIcon: () => (/* binding */ ViewIcon),\n/* harmony export */ ViewOffIcon: () => (/* binding */ ViewOffIcon),\n/* harmony export */ WarningIcon: () => (/* binding */ WarningIcon),\n/* harmony export */ iconIds: () => (/* binding */ iconIds)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! classnames */ \"../../../node_modules/classnames/index.js\");\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @openmrs/esm-react-utils */ \"../../framework/esm-react-utils/dist/index.js\");\n/* harmony import */ var _icons_module_scss__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./icons.module.scss */ \"../../framework/esm-styleguide/src/icons/icons.module.scss\");\n/** @category Icons */ function _object_without_properties(source, excluded) {\n if (source == null) return {};\n var target = _object_without_properties_loose(source, excluded);\n var key, i;\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n for(i = 0; i < sourceSymbolKeys.length; i++){\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n return target;\n}\nfunction _object_without_properties_loose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for(i = 0; i < sourceKeys.length; i++){\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}\n\n\n\n\nvar iconIds = [\n 'omrs-icon-activity',\n 'omrs-icon-add',\n 'omrs-icon-arrow-down',\n 'omrs-icon-arrow-left',\n 'omrs-icon-arrow-right',\n 'omrs-icon-arrow-up',\n 'omrs-icon-baby',\n 'omrs-icon-calendar-heat-map',\n 'omrs-icon-calendar',\n 'omrs-icon-caret-down',\n 'omrs-icon-caret-left',\n 'omrs-icon-caret-right',\n 'omrs-icon-caret-up',\n 'omrs-icon-chart-average',\n 'omrs-icon-checkmark-filled',\n 'omrs-icon-checkmark-outline',\n 'omrs-icon-chemistry',\n 'omrs-icon-chevron-down',\n 'omrs-icon-chevron-left',\n 'omrs-icon-chevron-right',\n 'omrs-icon-chevron-up',\n 'omrs-icon-close',\n 'omrs-icon-close-filled',\n 'omrs-icon-close-outline',\n 'omrs-icon-document',\n 'omrs-icon-document-attachment',\n 'omrs-icon-download',\n 'omrs-icon-drug-order',\n 'omrs-icon-edit',\n 'omrs-icon-event-schedule',\n 'omrs-icon-events',\n 'omrs-icon-gender-female',\n 'omrs-icon-gender-male',\n 'omrs-icon-gender-other',\n 'omrs-icon-gender-unknown',\n 'omrs-icon-generic-order-type',\n 'omrs-icon-group',\n 'omrs-icon-group-access',\n 'omrs-icon-hospital-bed',\n 'omrs-icon-image-medical',\n 'omrs-icon-information',\n 'omrs-icon-information-filled',\n 'omrs-icon-information-square',\n 'omrs-icon-inventory-management',\n 'omrs-icon-lab-order',\n 'omrs-icon-list-checked',\n 'omrs-icon-location',\n 'omrs-icon-material-order',\n 'omrs-icon-maximize',\n 'omrs-icon-medication',\n 'omrs-icon-message-queue',\n 'omrs-icon-microscope',\n 'omrs-icon-money',\n 'omrs-icon-mother',\n 'omrs-icon-movement',\n 'omrs-icon-overflow-menu--horizontal',\n 'omrs-icon-overflow-menu--vertical',\n 'omrs-icon-password',\n 'omrs-icon-pedestrian-family',\n 'omrs-icon-pen',\n 'omrs-icon-printer',\n 'omrs-icon-procedure-order',\n 'omrs-icon-programs',\n 'omrs-icon-renew',\n 'omrs-icon-referral-order',\n 'omrs-icon-report',\n 'omrs-icon-reset',\n 'omrs-icon-save',\n 'omrs-icon-search',\n 'omrs-icon-settings',\n 'omrs-icon-shopping-cart',\n 'omrs-icon-shopping-cart--arrow-down',\n 'omrs-icon-sticky-note-add',\n 'omrs-icon-switcher',\n 'omrs-icon-syringe',\n 'omrs-icon-table-of-contents',\n 'omrs-icon-table',\n 'omrs-icon-time',\n 'omrs-icon-tools',\n 'omrs-icon-translate',\n 'omrs-icon-trash-can',\n 'omrs-icon-tree-view--alt',\n 'omrs-icon-user-avatar',\n 'omrs-icon-user-follow',\n 'omrs-icon-user-xray',\n 'omrs-icon-user',\n 'omrs-icon-view-off',\n 'omrs-icon-view',\n 'omrs-icon-warning'\n];\n/**\n */ var ActivityIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ActivityIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-activity\",\n iconProps: props\n });\n}));\n/**\n */ var AddIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function AddIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-add\",\n iconProps: props\n });\n}));\n/**\n */ var ArrowDownIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ArrowDownIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-arrow-down\",\n iconProps: props\n });\n}));\n/**\n */ var ArrowLeftIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ArrowLeftIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-arrow-left\",\n iconProps: props\n });\n}));\n/**\n */ var ArrowRightIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ArrowRightIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-arrow-right\",\n iconProps: props\n });\n}));\n/**\n */ var ArrowUpIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ArrowUpIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-arrow-up\",\n iconProps: props\n });\n}));\n/**\n */ var BabyIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function BabyIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-baby\",\n iconProps: props\n });\n}));\n/**\n */ var CalendarHeatMapIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CalendarHeatMap(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-calendar-heat-map\",\n iconProps: props\n });\n}));\n/**\n */ var CalendarIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function Calendar(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-calendar\",\n iconProps: props\n });\n}));\n/**\n */ var CaretDownIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CaretDownIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-caret-down\",\n iconProps: props\n });\n}));\n/**\n */ var CaretLeftIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CaretLeftIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-caret-left\",\n iconProps: props\n });\n}));\n/**\n */ var CaretRightIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CaretRightIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-caret-right\",\n iconProps: props\n });\n}));\n/**\n */ var CaretUpIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CaretUpIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-caret-up\",\n iconProps: props\n });\n}));\n/**\n */ var ChartAverageIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ChartAverageIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-chart-average\",\n iconProps: props\n });\n}));\n/**\n */ var CheckmarkFilledIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CheckmarkFilledIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-checkmark-filled\",\n iconProps: props\n });\n}));\n/**\n */ var CheckmarkOutlineIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CheckmarkOutlineIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-checkmark-outline\",\n iconProps: props\n });\n}));\n/**\n */ var ChemistryIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ChemistryIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-chemistry\",\n iconProps: props\n });\n}));\n/**\n */ var ChevronDownIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ChevronDownIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-chevron-down\",\n iconProps: props\n });\n}));\n/**\n */ var ChevronLeftIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ChevronLeftIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-chevron-left\",\n iconProps: props\n });\n}));\n/**\n */ var ChevronRightIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ChevronRightIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-chevron-right\",\n iconProps: props\n });\n}));\n/**\n */ var ChevronUpIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ChevronUpIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-chevron-up\",\n iconProps: props\n });\n}));\n/**\n */ var CloseIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CloseIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-close\",\n iconProps: props\n });\n}));\n/**\n */ var CloseFilledIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CloseFilledIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-close-filled\",\n iconProps: props\n });\n}));\n/**\n */ var CloseOutlineIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CloseOutlineIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-close-outline\",\n iconProps: props\n });\n}));\n/**\n */ var DocumentIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function DocumentIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-document\",\n iconProps: props\n });\n}));\n/**\n */ var DocumentAttachmentIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function DocumentAttachmentIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-document-attachment\",\n iconProps: props\n });\n}));\n/**\n */ var DownloadIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function DownloadIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-download\",\n iconProps: props\n });\n}));\n/**\n */ var DrugOrderIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function DrugOrderIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-drug-order\",\n iconProps: props\n });\n}));\n/**\n */ var EditIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function EditIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-edit\",\n iconProps: props\n });\n}));\n/**\n */ var EventScheduleIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function EventScheduleIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-event-schedule\",\n iconProps: props\n });\n}));\n/**\n */ var EventsIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function EventsIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-events\",\n iconProps: props\n });\n}));\n/**\n */ var GenderFemaleIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function GenderFemaleIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-gender-female\",\n iconProps: props\n });\n}));\n/**\n */ var GenderMaleIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function GenderMaleIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-gender-male\",\n iconProps: props\n });\n}));\n/**\n */ var GenderOtherIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function GenderOtherIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-gender-other\",\n iconProps: props\n });\n}));\n/**\n */ var GenderUnknownIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function GenderUnknownIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-gender-unknown\",\n iconProps: props\n });\n}));\n/**\n */ var GenericOrderTypeIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function GenericOrderTypeIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-generic-order-type\",\n iconProps: props\n });\n}));\n/**\n */ var GroupIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function GroupIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-group\",\n iconProps: props\n });\n}));\n/**\n */ var GroupAccessIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function GroupAccessIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-group-access\",\n iconProps: props\n });\n}));\n/**\n */ var HospitalBedIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function HospitalBedIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-hospital-bed\",\n iconProps: props\n });\n}));\n/**\n */ var ImageMedicalIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ImageMedicalIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-image-medical\",\n iconProps: props\n });\n}));\n/**\n */ var InformationIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function InformationIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-information\",\n iconProps: props\n });\n}));\n/**\n */ var InformationFilledIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function InformationFilledIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-information-filled\",\n iconProps: props\n });\n}));\n/**\n */ var InformationSquareIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function InformationSquareIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-information-square\",\n iconProps: props\n });\n}));\n/**\n */ var InventoryManagementIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function InventoryManagementIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-inventory-management\",\n iconProps: props\n });\n}));\n/**\n */ var LabOrderIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function LabOrderIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-lab-order\",\n iconProps: props\n });\n}));\n/**\n */ var ListCheckedIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ListCheckedIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-list-checked\",\n iconProps: props\n });\n}));\n/**\n */ var LocationIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function LocationIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-location\",\n iconProps: props\n });\n}));\n/**\n */ var MaterialOrderIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function MaterialOrderIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-material-order\",\n iconProps: props\n });\n}));\n/**\n */ var MaximizeIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function MaximizeIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-maximize\",\n iconProps: props\n });\n}));\n/**\n */ var MedicationIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function MedicationIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-medication\",\n iconProps: props\n });\n}));\n/**\n */ var MessageQueueIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function MessageQueueIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-message-queue\",\n iconProps: props\n });\n}));\n/**\n */ var MicroscopeIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function MicroscopeIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-microscope\",\n iconProps: props\n });\n}));\n/**\n * Billing\n */ var MoneyIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function MoneyIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-money\",\n iconProps: props\n });\n}));\n/**\n */ var MotherIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function MotherIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-mother\",\n iconProps: props\n });\n}));\n/**\n */ var MovementIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function MovementIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-movement\",\n iconProps: props\n });\n}));\n/**\n */ var OverflowMenuHorizontalIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function OverflowMenuHorizontalIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-overflow-menu--horizontal\",\n iconProps: props\n });\n}));\n/**\n */ var OverflowMenuVerticalIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function OverflowMenuVerticalIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-overflow-menu--horizontal\",\n iconProps: props\n });\n}));\nvar PasswordIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function PasswordIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-password\",\n iconProps: props\n });\n}));\n/**\n */ var PedestrianFamilyIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function PedestrianFamilyIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-pedestrian-family\",\n iconProps: props\n });\n}));\n/**\n */ var PenIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function PenIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-pen\",\n iconProps: props\n });\n}));\n/**\n */ var PrinterIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function PrinterIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-printer\",\n iconProps: props\n });\n}));\n/**\n */ var ProcedureOrderIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ProcedureOrderIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-procedure-order\",\n iconProps: props\n });\n}));\n/**\n */ var ProgramsIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ProgramsIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-programs\",\n iconProps: props\n });\n}));\n/**\n */ var ReferralOrderIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ReferralOrderIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-referral-order\",\n iconProps: props\n });\n}));\n/**\n */ var RenewIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function RenewIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-renew\",\n iconProps: props\n });\n}));\n/**\n */ var ReportIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ReportIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-report\",\n iconProps: props\n });\n}));\n/**\n */ var ResetIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ResetIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-reset\",\n iconProps: props\n });\n}));\n/**\n */ var SaveIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function SaveIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-save\",\n iconProps: props\n });\n}));\n/**\n */ var SearchIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function SearchIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-search\",\n iconProps: props\n });\n}));\n/**\n */ var SettingsIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function SaveIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-settings\",\n iconProps: props\n });\n}));\n/**\n */ var SwitcherIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function SwitcherIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-switcher\",\n iconProps: props\n });\n}));\n/**\n * Order Basket, the UI to enter Orders for Medications, Referrals, Labs, Procedures and more\n */ var ShoppingCartIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ShoppingCartIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-shopping-cart\",\n iconProps: props\n });\n}));\n/**\n * Used as a button to add an item to the Order basket from a search\n */ var ShoppingCartArrowDownIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ShoppingCartArrowDownIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-shopping-cart--arrow-down\",\n iconProps: props\n });\n}));\n/**\n * Used as action button to open ward in-patient note workspace\n */ var StickyNoteAddIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function StickyNoteAddIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-sticky-note-add\",\n iconProps: props\n });\n}));\n/**\n */ var SyringeIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function SyringeIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-syringe\",\n iconProps: props\n });\n}));\n/**\n * Used as a button to add an item to the Order basket from a search\n */ var TableOfContentsIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function TableOfContentsIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-table-of-contents\",\n iconProps: props\n });\n}));\n/**\n */ var TableIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function TableIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-table\",\n iconProps: props\n });\n}));\n/**\n * Lab investigations\n */ var TimeIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function TimeIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-time\",\n iconProps: props\n });\n}));\n/**\n */ var ToolsIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ToolsIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-tools\",\n iconProps: props\n });\n}));\n/**\n */ var TranslateIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function TranslateIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-translate\",\n iconProps: props\n });\n}));\n/**\n */ var TrashCanIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function TrashCanIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-trash-can\",\n iconProps: props\n });\n}));\n/**\n */ var TreeViewAltIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function TreeViewAltIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-tree-view--alt\",\n iconProps: props\n });\n}));\n/**\n * User of OpenMRS e.g. My Account\n */ var UserAvatarIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function UserAvatarIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-user-avatar\",\n iconProps: props\n });\n}));\n/**\n */ var UserFollowIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function UserFollowIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-user-follow\",\n iconProps: props\n });\n}));\n/**\n * UserXray Icon\n *\n * `UserXrayIcon` is also used for imaging orders\n */ var UserXrayIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function UserXrayIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-user-xray\",\n iconProps: props\n });\n}));\n/**\n */ var UserIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function UserIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-user\",\n iconProps: props\n });\n}));\n/**\n */ var ViewOffIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ViewOffIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-view-off\",\n iconProps: props\n });\n}));\n/**\n */ var ViewIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ViewIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-view\",\n iconProps: props\n });\n}));\n/**\n */ var WarningIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function WarningIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-warning\",\n iconProps: props\n });\n}));\n// Icon aliases that are a little more aligned to specific use-cases\n// should all resolve to a defined React icon\n/**\n */ var AllergiesIcon = WarningIcon;\n/**\n *\n */ var AttachmentIcon = DocumentAttachmentIcon;\n/**\n * Conditions\n *\n * Note this is an alias for ListCheckedIcon\n */ var ConditionsIcon = ListCheckedIcon;\n/**\n *\n */ var RadiologyIcon = ImageMedicalIcon;\n/**\n * Used as a button to add an item to the Order basket from a search\n *\n * Note this is an alias for ShoppingCartArrowDownIcon\n */ var ShoppingCartAddItemIcon = ShoppingCartArrowDownIcon;\n/**\n * This is a utility component that takes an `icon` and renders it if the sprite for the icon\n * is available. The goal is to make it easier to conditionally render configuration-specified icons.\n *\n * @example\n * ```tsx\n * <MaybeIcon icon='omrs-icon-baby' className={styles.myIconStyles} />\n * ```\n */ var MaybeIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function MaybeIcon(_param, ref) {\n var icon = _param.icon, fallback = _param.fallback, iconProps = _object_without_properties(_param, [\n \"icon\",\n \"fallback\"\n ]);\n var iconRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(icon ? document.getElementById(icon) : undefined);\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function() {\n var container = document.getElementById('omrs-svgs-container');\n var callback = function(mutationList) {\n var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;\n try {\n for(var _iterator = mutationList[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){\n var mutation = _step.value;\n if (mutation.type === 'childList') {\n iconRef.current = icon ? document.getElementById(icon) : undefined;\n }\n }\n } catch (err) {\n _didIteratorError = true;\n _iteratorError = err;\n } finally{\n try {\n if (!_iteratorNormalCompletion && _iterator.return != null) {\n _iterator.return();\n }\n } finally{\n if (_didIteratorError) {\n throw _iteratorError;\n }\n }\n }\n };\n var observer = new MutationObserver(callback);\n if (container) {\n observer.observe(container, {\n childList: true\n });\n }\n return function() {\n return observer.disconnect();\n };\n }, [\n icon\n ]);\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_2__.RenderIfValueIsTruthy, {\n value: iconRef.current,\n fallback: fallback\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: icon,\n iconProps: iconProps\n }));\n}));\n/**\n * This is a utility type for custom icons that use the svg-sprite-loader to bundle custom icons\n */ var Icon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function Icon(param, ref) {\n var icon = param.icon, iconProps = param.iconProps;\n var _Object_assign = Object.assign({}, {\n fill: 'currentColor',\n size: 20\n }, iconProps), className = _Object_assign.className, fill = _Object_assign.fill, size = _Object_assign.size;\n if (size <= 0 || size > 72) {\n console.error(\"Invalid size '\".concat(size, \"' specified for \").concat(icon, \". Defaulting to 20.\"));\n size = 20;\n }\n var iconRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(null);\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useImperativeHandle)(ref, function() {\n return iconRef.current;\n });\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function() {\n if (iconRef.current) {\n if (fill !== 'currentColor') {\n iconRef.current.style.setProperty('--omrs-icon-fill', fill);\n }\n }\n }, []);\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"svg\", {\n ref: iconRef,\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()('omrs-icon', _icons_module_scss__WEBPACK_IMPORTED_MODULE_3__[\"default\"].icon, className),\n height: size,\n width: size,\n viewBox: \"0 0 16 16\"\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"use\", {\n href: \"#\".concat(icon)\n }));\n}));\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-styleguide/src/icons/icons.tsx","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;AACoE;AACjC;AACU;AACzB;AAEjC,IAAMS,UAAU;IACrB;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;CACD,CAAU;AAUX;CACC,GACM,IAAMC,6BAAeR,2CAAIA,eAC9BD,iDAAUA,CAA2B,SAASS,aAAaC,KAAK,EAAEC,GAAG;IACnE,qBAAO,2DAACC;QAAKD,KAAKA;QAAKE,MAAK;QAAqBC,WAAWJ;;AAC9D,IACA;AAEF;CACC,GACM,IAAMK,wBAAUd,2CAAIA,eACzBD,iDAAUA,CAA2B,SAASe,QAAQL,KAAK,EAAEC,GAAG;IAC9D,qBAAO,2DAACC;QAAKD,KAAKA;QAAKE,MAAK;QAAgBC,WAAWJ;;AACzD,IACA;AAEF;CACC,GACM,IAAMM,8BAAgBf,2CAAIA,eAC/BD,iDAAUA,CAA2B,SAASgB,cAAcN,KAAK,EAAEC,GAAG;IACpE,qBAAO,2DAACC;QAAKD,KAAKA;QAAKE,MAAK;QAAuBC,WAAWJ;;AAChE,IACA;AAEF;CACC,GACM,IAAMO,8BAAgBhB,2CAAIA,eAC/BD,iDAAUA,CAA2B,SAASiB,cAAcP,KAAK,EAAEC,GAAG;IACpE,qBAAO,2DAACC;QAA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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-styleguide/src/icons/icons.tsx?5150"],"sourcesContent":["/** @category Icons */\nimport React, { forwardRef, memo, useEffect, useImperativeHandle, useRef } from 'react';\nimport classNames, { type Argument } from 'classnames';\nimport { RenderIfValueIsTruthy } from '@openmrs/esm-react-utils';\nimport style from './icons.module.scss';\n\nexport const iconIds = [\n  'omrs-icon-activity',\n  'omrs-icon-add',\n  'omrs-icon-arrow-down',\n  'omrs-icon-arrow-left',\n  'omrs-icon-arrow-right',\n  'omrs-icon-arrow-up',\n  'omrs-icon-baby',\n  'omrs-icon-calendar-heat-map',\n  'omrs-icon-calendar',\n  'omrs-icon-caret-down',\n  'omrs-icon-caret-left',\n  'omrs-icon-caret-right',\n  'omrs-icon-caret-up',\n  'omrs-icon-chart-average',\n  'omrs-icon-checkmark-filled',\n  'omrs-icon-checkmark-outline',\n  'omrs-icon-chemistry',\n  'omrs-icon-chevron-down',\n  'omrs-icon-chevron-left',\n  'omrs-icon-chevron-right',\n  'omrs-icon-chevron-up',\n  'omrs-icon-close',\n  'omrs-icon-close-filled',\n  'omrs-icon-close-outline',\n  'omrs-icon-document',\n  'omrs-icon-document-attachment',\n  'omrs-icon-download',\n  'omrs-icon-drug-order',\n  'omrs-icon-edit',\n  'omrs-icon-event-schedule',\n  'omrs-icon-events',\n  'omrs-icon-gender-female',\n  'omrs-icon-gender-male',\n  'omrs-icon-gender-other',\n  'omrs-icon-gender-unknown',\n  'omrs-icon-generic-order-type',\n  'omrs-icon-group',\n  'omrs-icon-group-access',\n  'omrs-icon-hospital-bed',\n  'omrs-icon-image-medical',\n  'omrs-icon-information',\n  'omrs-icon-information-filled',\n  'omrs-icon-information-square',\n  'omrs-icon-inventory-management',\n  'omrs-icon-lab-order',\n  'omrs-icon-list-checked',\n  'omrs-icon-location',\n  'omrs-icon-material-order',\n  'omrs-icon-maximize',\n  'omrs-icon-medication',\n  'omrs-icon-message-queue',\n  'omrs-icon-microscope',\n  'omrs-icon-money',\n  'omrs-icon-mother',\n  'omrs-icon-movement',\n  'omrs-icon-overflow-menu--horizontal',\n  'omrs-icon-overflow-menu--vertical',\n  'omrs-icon-password',\n  'omrs-icon-pedestrian-family',\n  'omrs-icon-pen',\n  'omrs-icon-printer',\n  'omrs-icon-procedure-order',\n  'omrs-icon-programs',\n  'omrs-icon-renew',\n  'omrs-icon-referral-order',\n  'omrs-icon-report',\n  'omrs-icon-reset',\n  'omrs-icon-save',\n  'omrs-icon-search',\n  'omrs-icon-settings',\n  'omrs-icon-shopping-cart',\n  'omrs-icon-shopping-cart--arrow-down',\n  'omrs-icon-sticky-note-add',\n  'omrs-icon-switcher',\n  'omrs-icon-syringe',\n  'omrs-icon-table-of-contents',\n  'omrs-icon-table',\n  'omrs-icon-time',\n  'omrs-icon-tools',\n  'omrs-icon-translate',\n  'omrs-icon-trash-can',\n  'omrs-icon-tree-view--alt',\n  'omrs-icon-user-avatar',\n  'omrs-icon-user-follow',\n  'omrs-icon-user-xray',\n  'omrs-icon-user',\n  'omrs-icon-view-off',\n  'omrs-icon-view',\n  'omrs-icon-warning',\n] as const;\n\nexport type IconId = (typeof iconIds)[number];\n\nexport type IconProps = {\n  className?: Argument;\n  fill?: string;\n  size?: number;\n};\n\n/**\n */\nexport const ActivityIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ActivityIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-activity\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const AddIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function AddIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-add\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ArrowDownIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ArrowDownIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-arrow-down\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ArrowLeftIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ArrowLeftIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-arrow-left\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ArrowRightIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ArrowRightIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-arrow-right\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ArrowUpIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ArrowUpIcon(props: IconProps, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-arrow-up\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const BabyIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function BabyIcon(props: IconProps, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-baby\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CalendarHeatMapIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function CalendarHeatMap(props: IconProps, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-calendar-heat-map\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CalendarIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function Calendar(props: IconProps, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-calendar\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CaretDownIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function CaretDownIcon(props: IconProps, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-caret-down\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CaretLeftIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function CaretLeftIcon(props: IconProps, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-caret-left\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CaretRightIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function CaretRightIcon(props: IconProps, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-caret-right\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CaretUpIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function CaretUpIcon(props: IconProps, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-caret-up\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ChartAverageIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ChartAverageIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-chart-average\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CheckmarkFilledIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function CheckmarkFilledIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-checkmark-filled\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CheckmarkOutlineIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function CheckmarkOutlineIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-checkmark-outline\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ChemistryIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ChemistryIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-chemistry\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ChevronDownIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ChevronDownIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-chevron-down\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ChevronLeftIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ChevronLeftIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-chevron-left\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ChevronRightIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ChevronRightIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-chevron-right\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ChevronUpIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ChevronUpIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-chevron-up\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CloseIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function CloseIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-close\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CloseFilledIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function CloseFilledIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-close-filled\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CloseOutlineIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function CloseOutlineIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-close-outline\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const DocumentIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function DocumentIcon(props: IconProps, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-document\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const DocumentAttachmentIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function DocumentAttachmentIcon(props: IconProps, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-document-attachment\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const DownloadIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function DownloadIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-download\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const DrugOrderIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function DrugOrderIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-drug-order\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const EditIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function EditIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-edit\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const EventScheduleIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function EventScheduleIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-event-schedule\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const EventsIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function EventsIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-events\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const GenderFemaleIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function GenderFemaleIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-gender-female\" iconProps={props} />;\n  }),\n);\n/**\n */\nexport const GenderMaleIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function GenderMaleIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-gender-male\" iconProps={props} />;\n  }),\n);\n/**\n */\nexport const GenderOtherIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function GenderOtherIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-gender-other\" iconProps={props} />;\n  }),\n);\n/**\n */\nexport const GenderUnknownIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function GenderUnknownIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-gender-unknown\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const GenericOrderTypeIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function GenericOrderTypeIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-generic-order-type\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const GroupIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function GroupIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-group\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const GroupAccessIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function GroupAccessIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-group-access\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const HospitalBedIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function HospitalBedIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-hospital-bed\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ImageMedicalIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ImageMedicalIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-image-medical\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const InformationIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function InformationIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-information\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const InformationFilledIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function InformationFilledIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-information-filled\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const InformationSquareIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function InformationSquareIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-information-square\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const InventoryManagementIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function InventoryManagementIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-inventory-management\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const LabOrderIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function LabOrderIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-lab-order\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ListCheckedIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ListCheckedIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-list-checked\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const LocationIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function LocationIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-location\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const MaterialOrderIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function MaterialOrderIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-material-order\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const MaximizeIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function MaximizeIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-maximize\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const MedicationIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function MedicationIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-medication\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const MessageQueueIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function MessageQueueIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-message-queue\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const MicroscopeIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function MicroscopeIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-microscope\" iconProps={props} />;\n  }),\n);\n\n/**\n * Billing\n */\nexport const MoneyIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function MoneyIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-money\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const MotherIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function MotherIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-mother\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const MovementIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function MovementIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-movement\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const OverflowMenuHorizontalIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function OverflowMenuHorizontalIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-overflow-menu--horizontal\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const OverflowMenuVerticalIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function OverflowMenuVerticalIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-overflow-menu--horizontal\" iconProps={props} />;\n  }),\n);\n\nexport const PasswordIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function PasswordIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-password\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const PedestrianFamilyIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function PedestrianFamilyIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-pedestrian-family\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const PenIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function PenIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-pen\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const PrinterIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function PrinterIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-printer\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ProcedureOrderIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ProcedureOrderIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-procedure-order\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ProgramsIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ProgramsIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-programs\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ReferralOrderIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ReferralOrderIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-referral-order\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const RenewIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function RenewIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-renew\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ReportIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ReportIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-report\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ResetIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ResetIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-reset\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const SaveIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function SaveIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-save\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const SearchIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function SearchIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-search\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const SettingsIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function SaveIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-settings\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const SwitcherIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function SwitcherIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-switcher\" iconProps={props} />;\n  }),\n);\n\n/**\n * Order Basket, the UI to enter Orders for Medications, Referrals, Labs, Procedures and more\n */\nexport const ShoppingCartIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ShoppingCartIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-shopping-cart\" iconProps={props} />;\n  }),\n);\n\n/**\n * Used as a button to add an item to the Order basket from a search\n */\nexport const ShoppingCartArrowDownIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ShoppingCartArrowDownIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-shopping-cart--arrow-down\" iconProps={props} />;\n  }),\n);\n\n/**\n * Used as action button to open ward in-patient note workspace\n */\nexport const StickyNoteAddIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function StickyNoteAddIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-sticky-note-add\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const SyringeIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function SyringeIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-syringe\" iconProps={props} />;\n  }),\n);\n\n/**\n * Used as a button to add an item to the Order basket from a search\n */\nexport const TableOfContentsIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function TableOfContentsIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-table-of-contents\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const TableIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function TableIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-table\" iconProps={props} />;\n  }),\n);\n\n/**\n * Lab investigations\n */\nexport const TimeIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function TimeIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-time\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ToolsIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ToolsIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-tools\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const TranslateIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function TranslateIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-translate\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const TrashCanIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function TrashCanIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-trash-can\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const TreeViewAltIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function TreeViewAltIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-tree-view--alt\" iconProps={props} />;\n  }),\n);\n\n/**\n * User of OpenMRS e.g. My Account\n */\nexport const UserAvatarIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function UserAvatarIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-user-avatar\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const UserFollowIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function UserFollowIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-user-follow\" iconProps={props} />;\n  }),\n);\n\n/**\n * UserXray Icon\n *\n * `UserXrayIcon` is also used for imaging orders\n */\nexport const UserXrayIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function UserXrayIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-user-xray\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const UserIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function UserIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-user\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ViewOffIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ViewOffIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-view-off\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ViewIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ViewIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-view\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const WarningIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function WarningIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-warning\" iconProps={props} />;\n  }),\n);\n\n// Icon aliases that are a little more aligned to specific use-cases\n// should all resolve to a defined React icon\n\n/**\n */\nexport const AllergiesIcon = WarningIcon;\n\n/**\n *\n */\nexport const AttachmentIcon = DocumentAttachmentIcon;\n\n/**\n * Conditions\n *\n * Note this is an alias for ListCheckedIcon\n */\nexport const ConditionsIcon = ListCheckedIcon;\n\n/**\n *\n */\nexport const RadiologyIcon = ImageMedicalIcon;\n\n/**\n * Used as a button to add an item to the Order basket from a search\n *\n * Note this is an alias for ShoppingCartArrowDownIcon\n */\nexport const ShoppingCartAddItemIcon = ShoppingCartArrowDownIcon;\n\n/**\n * This is a utility component that takes an `icon` and renders it if the sprite for the icon\n * is available. The goal is to make it easier to conditionally render configuration-specified icons.\n *\n * @example\n * ```tsx\n *   <MaybeIcon icon='omrs-icon-baby' className={styles.myIconStyles} />\n * ```\n */\nexport const MaybeIcon = memo(\n  forwardRef<SVGSVGElement, { icon: string | undefined; fallback?: React.ReactNode } & IconProps>(function MaybeIcon(\n    { icon, fallback, ...iconProps },\n    ref,\n  ) {\n    const iconRef = useRef(icon ? document.getElementById(icon) : undefined);\n\n    useEffect(() => {\n      const container = document.getElementById('omrs-svgs-container');\n      const callback: MutationCallback = (mutationList) => {\n        for (const mutation of mutationList) {\n          if (mutation.type === 'childList') {\n            iconRef.current = icon ? document.getElementById(icon) : undefined;\n          }\n        }\n      };\n\n      const observer = new MutationObserver(callback);\n      if (container) {\n        observer.observe(container, { childList: true });\n      }\n\n      return () => observer.disconnect();\n    }, [icon]);\n\n    return (\n      <RenderIfValueIsTruthy value={iconRef.current} fallback={fallback}>\n        <Icon ref={ref} icon={icon as IconId} iconProps={iconProps} />\n      </RenderIfValueIsTruthy>\n    );\n  }),\n);\n\nexport type SvgIconProps = {\n  icon: IconId;\n  iconProps: IconProps;\n};\n\n/**\n * This is a utility type for custom icons that use the svg-sprite-loader to bundle custom icons\n */\nexport const Icon = memo(\n  forwardRef<SVGSVGElement, SvgIconProps>(function Icon({ icon, iconProps }, ref) {\n    let { className, fill, size } = Object.assign({}, { fill: 'currentColor', size: 20 }, iconProps);\n    if (size <= 0 || size > 72) {\n      console.error(`Invalid size '${size}' specified for ${icon}. Defaulting to 20.`);\n      size = 20;\n    }\n    const iconRef = useRef<SVGSVGElement>(null);\n\n    useImperativeHandle(ref, () => iconRef.current!);\n\n    useEffect(() => {\n      if (iconRef.current) {\n        if (fill !== 'currentColor') {\n          iconRef.current.style.setProperty('--omrs-icon-fill', fill);\n        }\n      }\n    }, []);\n\n    return (\n      <svg\n        ref={iconRef}\n        className={classNames('omrs-icon', style.icon, className)}\n        height={size}\n        width={size}\n        viewBox=\"0 0 16 16\"\n      >\n        <use href={`#${icon}`} />\n      </svg>\n    );\n  }),\n);\n"],"names":["React","forwardRef","memo","useEffect","useImperativeHandle","useRef","classNames","RenderIfValueIsTruthy","style","iconIds","ActivityIcon","props","ref","Icon","icon","iconProps","AddIcon","ArrowDownIcon","ArrowLeftIcon","ArrowRightIcon","ArrowUpIcon","BabyIcon","CalendarHeatMapIcon","CalendarHeatMap","CalendarIcon","Calendar","CaretDownIcon","CaretLeftIcon","CaretRightIcon","CaretUpIcon","ChartAverageIcon","CheckmarkFilledIcon","CheckmarkOutlineIcon","ChemistryIcon","ChevronDownIcon","ChevronLeftIcon","ChevronRightIcon","ChevronUpIcon","CloseIcon","CloseFilledIcon","CloseOutlineIcon","DocumentIcon","DocumentAttachmentIcon","DownloadIcon","DrugOrderIcon","EditIcon","EventScheduleIcon","EventsIcon","GenderFemaleIcon","GenderMaleIcon","GenderOtherIcon","GenderUnknownIcon","GenericOrderTypeIcon","GroupIcon","GroupAccessIcon","HospitalBedIcon","ImageMedicalIcon","InformationIcon","InformationFilledIcon","InformationSquareIcon","InventoryManagementIcon","LabOrderIcon","ListCheckedIcon","LocationIcon","MaterialOrderIcon","MaximizeIcon","MedicationIcon","MessageQueueIcon","MicroscopeIcon","MoneyIcon","MotherIcon","MovementIcon","OverflowMenuHorizontalIcon","OverflowMenuVerticalIcon","PasswordIcon","PedestrianFamilyIcon","PenIcon","PrinterIcon","ProcedureOrderIcon","ProgramsIcon","ReferralOrderIcon","RenewIcon","ReportIcon","ResetIcon","SaveIcon","SearchIcon","SettingsIcon","SwitcherIcon","ShoppingCartIcon","ShoppingCartArrowDownIcon","StickyNoteAddIcon","SyringeIcon","TableOfContentsIcon","TableIcon","TimeIcon","ToolsIcon","TranslateIcon","TrashCanIcon","TreeViewAltIcon","UserAvatarIcon","UserFollowIcon","UserXrayIcon","UserIcon","ViewOffIcon","ViewIcon","WarningIcon","AllergiesIcon","AttachmentIcon","ConditionsIcon","RadiologyIcon","ShoppingCartAddItemIcon","MaybeIcon","fallback","iconRef","document","getElementById","undefined","container","callback","mutationList","mutation","type","current","observer","MutationObserver","observe","childList","disconnect","value","Object","assign","fill","size","className","console","error","setProperty","svg","height","width","viewBox","use","href"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/src/icons/icons.tsx\n");
608
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ ActivityIcon: () => (/* binding */ ActivityIcon),\n/* harmony export */ AddIcon: () => (/* binding */ AddIcon),\n/* harmony export */ AllergiesIcon: () => (/* binding */ AllergiesIcon),\n/* harmony export */ ArrowDownIcon: () => (/* binding */ ArrowDownIcon),\n/* harmony export */ ArrowLeftIcon: () => (/* binding */ ArrowLeftIcon),\n/* harmony export */ ArrowRightIcon: () => (/* binding */ ArrowRightIcon),\n/* harmony export */ ArrowUpIcon: () => (/* binding */ ArrowUpIcon),\n/* harmony export */ AttachmentIcon: () => (/* binding */ AttachmentIcon),\n/* harmony export */ BabyIcon: () => (/* binding */ BabyIcon),\n/* harmony export */ CalendarHeatMapIcon: () => (/* binding */ CalendarHeatMapIcon),\n/* harmony export */ CalendarIcon: () => (/* binding */ CalendarIcon),\n/* harmony export */ CaretDownIcon: () => (/* binding */ CaretDownIcon),\n/* harmony export */ CaretLeftIcon: () => (/* binding */ CaretLeftIcon),\n/* harmony export */ CaretRightIcon: () => (/* binding */ CaretRightIcon),\n/* harmony export */ CaretUpIcon: () => (/* binding */ CaretUpIcon),\n/* harmony export */ ChartAverageIcon: () => (/* binding */ ChartAverageIcon),\n/* harmony export */ CheckmarkFilledIcon: () => (/* binding */ CheckmarkFilledIcon),\n/* harmony export */ CheckmarkOutlineIcon: () => (/* binding */ CheckmarkOutlineIcon),\n/* harmony export */ ChemistryIcon: () => (/* binding */ ChemistryIcon),\n/* harmony export */ ChevronDownIcon: () => (/* binding */ ChevronDownIcon),\n/* harmony export */ ChevronLeftIcon: () => (/* binding */ ChevronLeftIcon),\n/* harmony export */ ChevronRightIcon: () => (/* binding */ ChevronRightIcon),\n/* harmony export */ ChevronUpIcon: () => (/* binding */ ChevronUpIcon),\n/* harmony export */ CloseFilledIcon: () => (/* binding */ CloseFilledIcon),\n/* harmony export */ CloseIcon: () => (/* binding */ CloseIcon),\n/* harmony export */ CloseOutlineIcon: () => (/* binding */ CloseOutlineIcon),\n/* harmony export */ ConditionsIcon: () => (/* binding */ ConditionsIcon),\n/* harmony export */ DocumentAttachmentIcon: () => (/* binding */ DocumentAttachmentIcon),\n/* harmony export */ DocumentIcon: () => (/* binding */ DocumentIcon),\n/* harmony export */ DownloadIcon: () => (/* binding */ DownloadIcon),\n/* harmony export */ DrugOrderIcon: () => (/* binding */ DrugOrderIcon),\n/* harmony export */ EditIcon: () => (/* binding */ EditIcon),\n/* harmony export */ EventScheduleIcon: () => (/* binding */ EventScheduleIcon),\n/* harmony export */ EventsIcon: () => (/* binding */ EventsIcon),\n/* harmony export */ GenderFemaleIcon: () => (/* binding */ GenderFemaleIcon),\n/* harmony export */ GenderMaleIcon: () => (/* binding */ GenderMaleIcon),\n/* harmony export */ GenderOtherIcon: () => (/* binding */ GenderOtherIcon),\n/* harmony export */ GenderUnknownIcon: () => (/* binding */ GenderUnknownIcon),\n/* harmony export */ GenericOrderTypeIcon: () => (/* binding */ GenericOrderTypeIcon),\n/* harmony export */ GroupAccessIcon: () => (/* binding */ GroupAccessIcon),\n/* harmony export */ GroupIcon: () => (/* binding */ GroupIcon),\n/* harmony export */ HospitalBedIcon: () => (/* binding */ HospitalBedIcon),\n/* harmony export */ Icon: () => (/* binding */ Icon),\n/* harmony export */ ImageMedicalIcon: () => (/* binding */ ImageMedicalIcon),\n/* harmony export */ InformationFilledIcon: () => (/* binding */ InformationFilledIcon),\n/* harmony export */ InformationIcon: () => (/* binding */ InformationIcon),\n/* harmony export */ InformationSquareIcon: () => (/* binding */ InformationSquareIcon),\n/* harmony export */ InventoryManagementIcon: () => (/* binding */ InventoryManagementIcon),\n/* harmony export */ LabOrderIcon: () => (/* binding */ LabOrderIcon),\n/* harmony export */ ListCheckedIcon: () => (/* binding */ ListCheckedIcon),\n/* harmony export */ LocationIcon: () => (/* binding */ LocationIcon),\n/* harmony export */ MaterialOrderIcon: () => (/* binding */ MaterialOrderIcon),\n/* harmony export */ MaximizeIcon: () => (/* binding */ MaximizeIcon),\n/* harmony export */ MaybeIcon: () => (/* binding */ MaybeIcon),\n/* harmony export */ MedicationIcon: () => (/* binding */ MedicationIcon),\n/* harmony export */ MessageQueueIcon: () => (/* binding */ MessageQueueIcon),\n/* harmony export */ MicroscopeIcon: () => (/* binding */ MicroscopeIcon),\n/* harmony export */ MoneyIcon: () => (/* binding */ MoneyIcon),\n/* harmony export */ MotherIcon: () => (/* binding */ MotherIcon),\n/* harmony export */ MovementIcon: () => (/* binding */ MovementIcon),\n/* harmony export */ OverflowMenuHorizontalIcon: () => (/* binding */ OverflowMenuHorizontalIcon),\n/* harmony export */ OverflowMenuVerticalIcon: () => (/* binding */ OverflowMenuVerticalIcon),\n/* harmony export */ PasswordIcon: () => (/* binding */ PasswordIcon),\n/* harmony export */ PedestrianFamilyIcon: () => (/* binding */ PedestrianFamilyIcon),\n/* harmony export */ PenIcon: () => (/* binding */ PenIcon),\n/* harmony export */ PrinterIcon: () => (/* binding */ PrinterIcon),\n/* harmony export */ ProcedureOrderIcon: () => (/* binding */ ProcedureOrderIcon),\n/* harmony export */ ProgramsIcon: () => (/* binding */ ProgramsIcon),\n/* harmony export */ RadiologyIcon: () => (/* binding */ RadiologyIcon),\n/* harmony export */ ReferralOrderIcon: () => (/* binding */ ReferralOrderIcon),\n/* harmony export */ RenewIcon: () => (/* binding */ RenewIcon),\n/* harmony export */ ReportIcon: () => (/* binding */ ReportIcon),\n/* harmony export */ ResetIcon: () => (/* binding */ ResetIcon),\n/* harmony export */ SaveIcon: () => (/* binding */ SaveIcon),\n/* harmony export */ SearchIcon: () => (/* binding */ SearchIcon),\n/* harmony export */ SettingsIcon: () => (/* binding */ SettingsIcon),\n/* harmony export */ ShoppingCartAddItemIcon: () => (/* binding */ ShoppingCartAddItemIcon),\n/* harmony export */ ShoppingCartArrowDownIcon: () => (/* binding */ ShoppingCartArrowDownIcon),\n/* harmony export */ ShoppingCartIcon: () => (/* binding */ ShoppingCartIcon),\n/* harmony export */ StickyNoteAddIcon: () => (/* binding */ StickyNoteAddIcon),\n/* harmony export */ SwitcherIcon: () => (/* binding */ SwitcherIcon),\n/* harmony export */ SyringeIcon: () => (/* binding */ SyringeIcon),\n/* harmony export */ TableIcon: () => (/* binding */ TableIcon),\n/* harmony export */ TableOfContentsIcon: () => (/* binding */ TableOfContentsIcon),\n/* harmony export */ TimeIcon: () => (/* binding */ TimeIcon),\n/* harmony export */ ToolsIcon: () => (/* binding */ ToolsIcon),\n/* harmony export */ TranslateIcon: () => (/* binding */ TranslateIcon),\n/* harmony export */ TrashCanIcon: () => (/* binding */ TrashCanIcon),\n/* harmony export */ TreeViewAltIcon: () => (/* binding */ TreeViewAltIcon),\n/* harmony export */ UserAvatarIcon: () => (/* binding */ UserAvatarIcon),\n/* harmony export */ UserFollowIcon: () => (/* binding */ UserFollowIcon),\n/* harmony export */ UserIcon: () => (/* binding */ UserIcon),\n/* harmony export */ UserXrayIcon: () => (/* binding */ UserXrayIcon),\n/* harmony export */ ViewIcon: () => (/* binding */ ViewIcon),\n/* harmony export */ ViewOffIcon: () => (/* binding */ ViewOffIcon),\n/* harmony export */ WarningIcon: () => (/* binding */ WarningIcon),\n/* harmony export */ iconIds: () => (/* binding */ iconIds)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! classnames */ \"../../../node_modules/classnames/index.js\");\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @openmrs/esm-react-utils */ \"../../framework/esm-react-utils/dist/index.js\");\n/* harmony import */ var _icons_module_scss__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./icons.module.scss */ \"../../framework/esm-styleguide/src/icons/icons.module.scss\");\n/** @category Icons */ function _object_without_properties(source, excluded) {\n if (source == null) return {};\n var target = _object_without_properties_loose(source, excluded);\n var key, i;\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n for(i = 0; i < sourceSymbolKeys.length; i++){\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n return target;\n}\nfunction _object_without_properties_loose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for(i = 0; i < sourceKeys.length; i++){\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}\n\n\n\n\n/** Array of all available OpenMRS icon IDs that can be used with the Icon component. */ var iconIds = [\n 'omrs-icon-activity',\n 'omrs-icon-add',\n 'omrs-icon-arrow-down',\n 'omrs-icon-arrow-left',\n 'omrs-icon-arrow-right',\n 'omrs-icon-arrow-up',\n 'omrs-icon-baby',\n 'omrs-icon-calendar-heat-map',\n 'omrs-icon-calendar',\n 'omrs-icon-caret-down',\n 'omrs-icon-caret-left',\n 'omrs-icon-caret-right',\n 'omrs-icon-caret-up',\n 'omrs-icon-chart-average',\n 'omrs-icon-checkmark-filled',\n 'omrs-icon-checkmark-outline',\n 'omrs-icon-chemistry',\n 'omrs-icon-chevron-down',\n 'omrs-icon-chevron-left',\n 'omrs-icon-chevron-right',\n 'omrs-icon-chevron-up',\n 'omrs-icon-close',\n 'omrs-icon-close-filled',\n 'omrs-icon-close-outline',\n 'omrs-icon-document',\n 'omrs-icon-document-attachment',\n 'omrs-icon-download',\n 'omrs-icon-drug-order',\n 'omrs-icon-edit',\n 'omrs-icon-event-schedule',\n 'omrs-icon-events',\n 'omrs-icon-gender-female',\n 'omrs-icon-gender-male',\n 'omrs-icon-gender-other',\n 'omrs-icon-gender-unknown',\n 'omrs-icon-generic-order-type',\n 'omrs-icon-group',\n 'omrs-icon-group-access',\n 'omrs-icon-hospital-bed',\n 'omrs-icon-image-medical',\n 'omrs-icon-information',\n 'omrs-icon-information-filled',\n 'omrs-icon-information-square',\n 'omrs-icon-inventory-management',\n 'omrs-icon-lab-order',\n 'omrs-icon-list-checked',\n 'omrs-icon-location',\n 'omrs-icon-material-order',\n 'omrs-icon-maximize',\n 'omrs-icon-medication',\n 'omrs-icon-message-queue',\n 'omrs-icon-microscope',\n 'omrs-icon-money',\n 'omrs-icon-mother',\n 'omrs-icon-movement',\n 'omrs-icon-overflow-menu--horizontal',\n 'omrs-icon-overflow-menu--vertical',\n 'omrs-icon-password',\n 'omrs-icon-pedestrian-family',\n 'omrs-icon-pen',\n 'omrs-icon-printer',\n 'omrs-icon-procedure-order',\n 'omrs-icon-programs',\n 'omrs-icon-renew',\n 'omrs-icon-referral-order',\n 'omrs-icon-report',\n 'omrs-icon-reset',\n 'omrs-icon-save',\n 'omrs-icon-search',\n 'omrs-icon-settings',\n 'omrs-icon-shopping-cart',\n 'omrs-icon-shopping-cart--arrow-down',\n 'omrs-icon-sticky-note-add',\n 'omrs-icon-switcher',\n 'omrs-icon-syringe',\n 'omrs-icon-table-of-contents',\n 'omrs-icon-table',\n 'omrs-icon-time',\n 'omrs-icon-tools',\n 'omrs-icon-translate',\n 'omrs-icon-trash-can',\n 'omrs-icon-tree-view--alt',\n 'omrs-icon-user-avatar',\n 'omrs-icon-user-follow',\n 'omrs-icon-user-xray',\n 'omrs-icon-user',\n 'omrs-icon-view-off',\n 'omrs-icon-view',\n 'omrs-icon-warning'\n];\n/**\n */ var ActivityIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ActivityIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-activity\",\n iconProps: props\n });\n}));\n/**\n */ var AddIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function AddIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-add\",\n iconProps: props\n });\n}));\n/**\n */ var ArrowDownIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ArrowDownIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-arrow-down\",\n iconProps: props\n });\n}));\n/**\n */ var ArrowLeftIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ArrowLeftIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-arrow-left\",\n iconProps: props\n });\n}));\n/**\n */ var ArrowRightIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ArrowRightIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-arrow-right\",\n iconProps: props\n });\n}));\n/**\n */ var ArrowUpIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ArrowUpIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-arrow-up\",\n iconProps: props\n });\n}));\n/**\n */ var BabyIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function BabyIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-baby\",\n iconProps: props\n });\n}));\n/**\n */ var CalendarHeatMapIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CalendarHeatMap(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-calendar-heat-map\",\n iconProps: props\n });\n}));\n/**\n */ var CalendarIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function Calendar(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-calendar\",\n iconProps: props\n });\n}));\n/**\n */ var CaretDownIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CaretDownIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-caret-down\",\n iconProps: props\n });\n}));\n/**\n */ var CaretLeftIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CaretLeftIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-caret-left\",\n iconProps: props\n });\n}));\n/**\n */ var CaretRightIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CaretRightIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-caret-right\",\n iconProps: props\n });\n}));\n/**\n */ var CaretUpIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CaretUpIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-caret-up\",\n iconProps: props\n });\n}));\n/**\n */ var ChartAverageIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ChartAverageIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-chart-average\",\n iconProps: props\n });\n}));\n/**\n */ var CheckmarkFilledIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CheckmarkFilledIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-checkmark-filled\",\n iconProps: props\n });\n}));\n/**\n */ var CheckmarkOutlineIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CheckmarkOutlineIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-checkmark-outline\",\n iconProps: props\n });\n}));\n/**\n */ var ChemistryIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ChemistryIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-chemistry\",\n iconProps: props\n });\n}));\n/**\n */ var ChevronDownIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ChevronDownIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-chevron-down\",\n iconProps: props\n });\n}));\n/**\n */ var ChevronLeftIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ChevronLeftIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-chevron-left\",\n iconProps: props\n });\n}));\n/**\n */ var ChevronRightIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ChevronRightIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-chevron-right\",\n iconProps: props\n });\n}));\n/**\n */ var ChevronUpIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ChevronUpIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-chevron-up\",\n iconProps: props\n });\n}));\n/**\n */ var CloseIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CloseIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-close\",\n iconProps: props\n });\n}));\n/**\n */ var CloseFilledIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CloseFilledIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-close-filled\",\n iconProps: props\n });\n}));\n/**\n */ var CloseOutlineIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CloseOutlineIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-close-outline\",\n iconProps: props\n });\n}));\n/**\n */ var DocumentIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function DocumentIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-document\",\n iconProps: props\n });\n}));\n/**\n */ var DocumentAttachmentIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function DocumentAttachmentIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-document-attachment\",\n iconProps: props\n });\n}));\n/**\n */ var DownloadIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function DownloadIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-download\",\n iconProps: props\n });\n}));\n/**\n */ var DrugOrderIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function DrugOrderIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-drug-order\",\n iconProps: props\n });\n}));\n/**\n */ var EditIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function EditIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-edit\",\n iconProps: props\n });\n}));\n/**\n */ var EventScheduleIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function EventScheduleIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-event-schedule\",\n iconProps: props\n });\n}));\n/**\n */ var EventsIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function EventsIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-events\",\n iconProps: props\n });\n}));\n/**\n */ var GenderFemaleIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function GenderFemaleIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-gender-female\",\n iconProps: props\n });\n}));\n/**\n */ var GenderMaleIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function GenderMaleIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-gender-male\",\n iconProps: props\n });\n}));\n/**\n */ var GenderOtherIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function GenderOtherIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-gender-other\",\n iconProps: props\n });\n}));\n/**\n */ var GenderUnknownIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function GenderUnknownIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-gender-unknown\",\n iconProps: props\n });\n}));\n/**\n */ var GenericOrderTypeIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function GenericOrderTypeIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-generic-order-type\",\n iconProps: props\n });\n}));\n/**\n */ var GroupIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function GroupIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-group\",\n iconProps: props\n });\n}));\n/**\n */ var GroupAccessIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function GroupAccessIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-group-access\",\n iconProps: props\n });\n}));\n/**\n */ var HospitalBedIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function HospitalBedIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-hospital-bed\",\n iconProps: props\n });\n}));\n/**\n */ var ImageMedicalIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ImageMedicalIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-image-medical\",\n iconProps: props\n });\n}));\n/**\n */ var InformationIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function InformationIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-information\",\n iconProps: props\n });\n}));\n/**\n */ var InformationFilledIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function InformationFilledIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-information-filled\",\n iconProps: props\n });\n}));\n/**\n */ var InformationSquareIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function InformationSquareIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-information-square\",\n iconProps: props\n });\n}));\n/**\n */ var InventoryManagementIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function InventoryManagementIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-inventory-management\",\n iconProps: props\n });\n}));\n/**\n */ var LabOrderIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function LabOrderIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-lab-order\",\n iconProps: props\n });\n}));\n/**\n */ var ListCheckedIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ListCheckedIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-list-checked\",\n iconProps: props\n });\n}));\n/**\n */ var LocationIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function LocationIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-location\",\n iconProps: props\n });\n}));\n/**\n */ var MaterialOrderIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function MaterialOrderIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-material-order\",\n iconProps: props\n });\n}));\n/**\n */ var MaximizeIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function MaximizeIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-maximize\",\n iconProps: props\n });\n}));\n/**\n */ var MedicationIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function MedicationIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-medication\",\n iconProps: props\n });\n}));\n/**\n */ var MessageQueueIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function MessageQueueIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-message-queue\",\n iconProps: props\n });\n}));\n/**\n */ var MicroscopeIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function MicroscopeIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-microscope\",\n iconProps: props\n });\n}));\n/**\n * Billing\n */ var MoneyIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function MoneyIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-money\",\n iconProps: props\n });\n}));\n/**\n */ var MotherIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function MotherIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-mother\",\n iconProps: props\n });\n}));\n/**\n */ var MovementIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function MovementIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-movement\",\n iconProps: props\n });\n}));\n/**\n */ var OverflowMenuHorizontalIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function OverflowMenuHorizontalIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-overflow-menu--horizontal\",\n iconProps: props\n });\n}));\n/**\n */ var OverflowMenuVerticalIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function OverflowMenuVerticalIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-overflow-menu--horizontal\",\n iconProps: props\n });\n}));\nvar PasswordIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function PasswordIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-password\",\n iconProps: props\n });\n}));\n/**\n */ var PedestrianFamilyIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function PedestrianFamilyIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-pedestrian-family\",\n iconProps: props\n });\n}));\n/**\n */ var PenIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function PenIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-pen\",\n iconProps: props\n });\n}));\n/**\n */ var PrinterIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function PrinterIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-printer\",\n iconProps: props\n });\n}));\n/**\n */ var ProcedureOrderIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ProcedureOrderIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-procedure-order\",\n iconProps: props\n });\n}));\n/**\n */ var ProgramsIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ProgramsIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-programs\",\n iconProps: props\n });\n}));\n/**\n */ var ReferralOrderIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ReferralOrderIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-referral-order\",\n iconProps: props\n });\n}));\n/**\n */ var RenewIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function RenewIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-renew\",\n iconProps: props\n });\n}));\n/**\n */ var ReportIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ReportIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-report\",\n iconProps: props\n });\n}));\n/**\n */ var ResetIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ResetIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-reset\",\n iconProps: props\n });\n}));\n/**\n */ var SaveIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function SaveIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-save\",\n iconProps: props\n });\n}));\n/**\n */ var SearchIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function SearchIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-search\",\n iconProps: props\n });\n}));\n/**\n */ var SettingsIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function SaveIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-settings\",\n iconProps: props\n });\n}));\n/**\n */ var SwitcherIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function SwitcherIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-switcher\",\n iconProps: props\n });\n}));\n/**\n * Order Basket, the UI to enter Orders for Medications, Referrals, Labs, Procedures and more\n */ var ShoppingCartIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ShoppingCartIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-shopping-cart\",\n iconProps: props\n });\n}));\n/**\n * Used as a button to add an item to the Order basket from a search\n */ var ShoppingCartArrowDownIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ShoppingCartArrowDownIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-shopping-cart--arrow-down\",\n iconProps: props\n });\n}));\n/**\n * Used as action button to open ward in-patient note workspace\n */ var StickyNoteAddIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function StickyNoteAddIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-sticky-note-add\",\n iconProps: props\n });\n}));\n/**\n */ var SyringeIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function SyringeIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-syringe\",\n iconProps: props\n });\n}));\n/**\n * Used as a button to add an item to the Order basket from a search\n */ var TableOfContentsIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function TableOfContentsIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-table-of-contents\",\n iconProps: props\n });\n}));\n/**\n */ var TableIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function TableIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-table\",\n iconProps: props\n });\n}));\n/**\n * Lab investigations\n */ var TimeIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function TimeIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-time\",\n iconProps: props\n });\n}));\n/**\n */ var ToolsIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ToolsIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-tools\",\n iconProps: props\n });\n}));\n/**\n */ var TranslateIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function TranslateIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-translate\",\n iconProps: props\n });\n}));\n/**\n */ var TrashCanIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function TrashCanIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-trash-can\",\n iconProps: props\n });\n}));\n/**\n */ var TreeViewAltIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function TreeViewAltIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-tree-view--alt\",\n iconProps: props\n });\n}));\n/**\n * User of OpenMRS e.g. My Account\n */ var UserAvatarIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function UserAvatarIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-user-avatar\",\n iconProps: props\n });\n}));\n/**\n */ var UserFollowIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function UserFollowIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-user-follow\",\n iconProps: props\n });\n}));\n/**\n * UserXray Icon\n *\n * `UserXrayIcon` is also used for imaging orders\n */ var UserXrayIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function UserXrayIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-user-xray\",\n iconProps: props\n });\n}));\n/**\n */ var UserIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function UserIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-user\",\n iconProps: props\n });\n}));\n/**\n */ var ViewOffIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ViewOffIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-view-off\",\n iconProps: props\n });\n}));\n/**\n */ var ViewIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ViewIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-view\",\n iconProps: props\n });\n}));\n/**\n */ var WarningIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function WarningIcon(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: \"omrs-icon-warning\",\n iconProps: props\n });\n}));\n// Icon aliases that are a little more aligned to specific use-cases\n// should all resolve to a defined React icon\n/**\n */ var AllergiesIcon = WarningIcon;\n/**\n *\n */ var AttachmentIcon = DocumentAttachmentIcon;\n/**\n * Conditions\n *\n * Note this is an alias for ListCheckedIcon\n */ var ConditionsIcon = ListCheckedIcon;\n/**\n *\n */ var RadiologyIcon = ImageMedicalIcon;\n/**\n * Used as a button to add an item to the Order basket from a search\n *\n * Note this is an alias for ShoppingCartArrowDownIcon\n */ var ShoppingCartAddItemIcon = ShoppingCartArrowDownIcon;\n/**\n * This is a utility component that takes an `icon` and renders it if the sprite for the icon\n * is available. The goal is to make it easier to conditionally render configuration-specified icons.\n *\n * @example\n * ```tsx\n * <MaybeIcon icon='omrs-icon-baby' className={styles.myIconStyles} />\n * ```\n */ var MaybeIcon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function MaybeIcon(_param, ref) {\n var icon = _param.icon, fallback = _param.fallback, iconProps = _object_without_properties(_param, [\n \"icon\",\n \"fallback\"\n ]);\n var iconRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(icon ? document.getElementById(icon) : undefined);\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function() {\n var container = document.getElementById('omrs-svgs-container');\n var callback = function(mutationList) {\n var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;\n try {\n for(var _iterator = mutationList[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){\n var mutation = _step.value;\n if (mutation.type === 'childList') {\n iconRef.current = icon ? document.getElementById(icon) : undefined;\n }\n }\n } catch (err) {\n _didIteratorError = true;\n _iteratorError = err;\n } finally{\n try {\n if (!_iteratorNormalCompletion && _iterator.return != null) {\n _iterator.return();\n }\n } finally{\n if (_didIteratorError) {\n throw _iteratorError;\n }\n }\n }\n };\n var observer = new MutationObserver(callback);\n if (container) {\n observer.observe(container, {\n childList: true\n });\n }\n return function() {\n return observer.disconnect();\n };\n }, [\n icon\n ]);\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_2__.RenderIfValueIsTruthy, {\n value: iconRef.current,\n fallback: fallback\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Icon, {\n ref: ref,\n icon: icon,\n iconProps: iconProps\n }));\n}));\n/**\n * This is a utility type for custom icons that use the svg-sprite-loader to bundle custom icons\n */ var Icon = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function Icon(param, ref) {\n var icon = param.icon, iconProps = param.iconProps;\n var _Object_assign = Object.assign({}, {\n fill: 'currentColor',\n size: 20\n }, iconProps), className = _Object_assign.className, fill = _Object_assign.fill, size = _Object_assign.size;\n if (size <= 0 || size > 72) {\n console.error(\"Invalid size '\".concat(size, \"' specified for \").concat(icon, \". Defaulting to 20.\"));\n size = 20;\n }\n var iconRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(null);\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useImperativeHandle)(ref, function() {\n return iconRef.current;\n });\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function() {\n if (iconRef.current) {\n if (fill !== 'currentColor') {\n iconRef.current.style.setProperty('--omrs-icon-fill', fill);\n }\n }\n }, []);\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"svg\", {\n ref: iconRef,\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()('omrs-icon', _icons_module_scss__WEBPACK_IMPORTED_MODULE_3__[\"default\"].icon, className),\n height: size,\n width: size,\n viewBox: \"0 0 16 16\"\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"use\", {\n href: \"#\".concat(icon)\n }));\n}));\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-styleguide/src/icons/icons.tsx","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;;AACoE;AACjC;AACU;AACzB;AAExC,sFAAsF,GAC/E,IAAMS,UAAU;IACrB;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;IACA;CACD,CAAU;AAUX;CACC,GACM,IAAMC,6BAAeR,2CAAIA,eAC9BD,iDAAUA,CAA2B,SAASS,aAAaC,KAAK,EAAEC,GAAG;IACnE,qBAAO,2DAACC;QAAKD,KAAKA;QAAKE,MAAK;QAAqBC,WAAWJ;;AAC9D,IACA;AAEF;CACC,GACM,IAAMK,wBAAUd,2CAAIA,eACzBD,iDAAUA,CAA2B,SAASe,QAAQL,KAAK,EAAEC,GAAG;IAC9D,qBAAO,2DAACC;QAAKD,KAAKA;QAAKE,MAAK;QAAgBC,WAAWJ;;AACzD,IACA;AAEF;CACC,GACM,IAAMM,8BAAgBf,2CAAIA,eAC/BD,iDAAUA,CAA2B,SAASgB,cAAcN,KAAK,EAAEC,GAAG;IACpE,qBAAO,2DAACC;QAAKD,KAAKA;QAAKE,MAAK;QAAuBC,WAAWJ;;AAChE,IACA;AAEF;CACC,GACM,IAAMO,8BAAgBhB,2CAAIA,eAC/BD,iDAAUA,CAA2B,SAASiB,cAAcP,KAAK,EAAEC,GAAG;IACpE,qBA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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-styleguide/src/icons/icons.tsx?5150"],"sourcesContent":["/** @category Icons */\nimport React, { forwardRef, memo, useEffect, useImperativeHandle, useRef } from 'react';\nimport classNames, { type Argument } from 'classnames';\nimport { RenderIfValueIsTruthy } from '@openmrs/esm-react-utils';\nimport style from './icons.module.scss';\n\n/** Array of all available OpenMRS icon IDs that can be used with the Icon component. */\nexport const iconIds = [\n  'omrs-icon-activity',\n  'omrs-icon-add',\n  'omrs-icon-arrow-down',\n  'omrs-icon-arrow-left',\n  'omrs-icon-arrow-right',\n  'omrs-icon-arrow-up',\n  'omrs-icon-baby',\n  'omrs-icon-calendar-heat-map',\n  'omrs-icon-calendar',\n  'omrs-icon-caret-down',\n  'omrs-icon-caret-left',\n  'omrs-icon-caret-right',\n  'omrs-icon-caret-up',\n  'omrs-icon-chart-average',\n  'omrs-icon-checkmark-filled',\n  'omrs-icon-checkmark-outline',\n  'omrs-icon-chemistry',\n  'omrs-icon-chevron-down',\n  'omrs-icon-chevron-left',\n  'omrs-icon-chevron-right',\n  'omrs-icon-chevron-up',\n  'omrs-icon-close',\n  'omrs-icon-close-filled',\n  'omrs-icon-close-outline',\n  'omrs-icon-document',\n  'omrs-icon-document-attachment',\n  'omrs-icon-download',\n  'omrs-icon-drug-order',\n  'omrs-icon-edit',\n  'omrs-icon-event-schedule',\n  'omrs-icon-events',\n  'omrs-icon-gender-female',\n  'omrs-icon-gender-male',\n  'omrs-icon-gender-other',\n  'omrs-icon-gender-unknown',\n  'omrs-icon-generic-order-type',\n  'omrs-icon-group',\n  'omrs-icon-group-access',\n  'omrs-icon-hospital-bed',\n  'omrs-icon-image-medical',\n  'omrs-icon-information',\n  'omrs-icon-information-filled',\n  'omrs-icon-information-square',\n  'omrs-icon-inventory-management',\n  'omrs-icon-lab-order',\n  'omrs-icon-list-checked',\n  'omrs-icon-location',\n  'omrs-icon-material-order',\n  'omrs-icon-maximize',\n  'omrs-icon-medication',\n  'omrs-icon-message-queue',\n  'omrs-icon-microscope',\n  'omrs-icon-money',\n  'omrs-icon-mother',\n  'omrs-icon-movement',\n  'omrs-icon-overflow-menu--horizontal',\n  'omrs-icon-overflow-menu--vertical',\n  'omrs-icon-password',\n  'omrs-icon-pedestrian-family',\n  'omrs-icon-pen',\n  'omrs-icon-printer',\n  'omrs-icon-procedure-order',\n  'omrs-icon-programs',\n  'omrs-icon-renew',\n  'omrs-icon-referral-order',\n  'omrs-icon-report',\n  'omrs-icon-reset',\n  'omrs-icon-save',\n  'omrs-icon-search',\n  'omrs-icon-settings',\n  'omrs-icon-shopping-cart',\n  'omrs-icon-shopping-cart--arrow-down',\n  'omrs-icon-sticky-note-add',\n  'omrs-icon-switcher',\n  'omrs-icon-syringe',\n  'omrs-icon-table-of-contents',\n  'omrs-icon-table',\n  'omrs-icon-time',\n  'omrs-icon-tools',\n  'omrs-icon-translate',\n  'omrs-icon-trash-can',\n  'omrs-icon-tree-view--alt',\n  'omrs-icon-user-avatar',\n  'omrs-icon-user-follow',\n  'omrs-icon-user-xray',\n  'omrs-icon-user',\n  'omrs-icon-view-off',\n  'omrs-icon-view',\n  'omrs-icon-warning',\n] as const;\n\nexport type IconId = (typeof iconIds)[number];\n\nexport type IconProps = {\n  className?: Argument;\n  fill?: string;\n  size?: number;\n};\n\n/**\n */\nexport const ActivityIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ActivityIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-activity\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const AddIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function AddIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-add\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ArrowDownIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ArrowDownIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-arrow-down\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ArrowLeftIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ArrowLeftIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-arrow-left\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ArrowRightIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ArrowRightIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-arrow-right\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ArrowUpIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ArrowUpIcon(props: IconProps, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-arrow-up\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const BabyIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function BabyIcon(props: IconProps, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-baby\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CalendarHeatMapIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function CalendarHeatMap(props: IconProps, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-calendar-heat-map\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CalendarIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function Calendar(props: IconProps, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-calendar\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CaretDownIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function CaretDownIcon(props: IconProps, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-caret-down\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CaretLeftIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function CaretLeftIcon(props: IconProps, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-caret-left\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CaretRightIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function CaretRightIcon(props: IconProps, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-caret-right\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CaretUpIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function CaretUpIcon(props: IconProps, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-caret-up\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ChartAverageIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ChartAverageIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-chart-average\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CheckmarkFilledIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function CheckmarkFilledIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-checkmark-filled\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CheckmarkOutlineIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function CheckmarkOutlineIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-checkmark-outline\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ChemistryIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ChemistryIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-chemistry\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ChevronDownIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ChevronDownIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-chevron-down\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ChevronLeftIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ChevronLeftIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-chevron-left\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ChevronRightIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ChevronRightIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-chevron-right\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ChevronUpIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ChevronUpIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-chevron-up\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CloseIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function CloseIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-close\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CloseFilledIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function CloseFilledIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-close-filled\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const CloseOutlineIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function CloseOutlineIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-close-outline\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const DocumentIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function DocumentIcon(props: IconProps, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-document\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const DocumentAttachmentIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function DocumentAttachmentIcon(props: IconProps, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-document-attachment\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const DownloadIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function DownloadIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-download\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const DrugOrderIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function DrugOrderIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-drug-order\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const EditIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function EditIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-edit\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const EventScheduleIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function EventScheduleIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-event-schedule\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const EventsIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function EventsIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-events\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const GenderFemaleIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function GenderFemaleIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-gender-female\" iconProps={props} />;\n  }),\n);\n/**\n */\nexport const GenderMaleIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function GenderMaleIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-gender-male\" iconProps={props} />;\n  }),\n);\n/**\n */\nexport const GenderOtherIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function GenderOtherIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-gender-other\" iconProps={props} />;\n  }),\n);\n/**\n */\nexport const GenderUnknownIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function GenderUnknownIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-gender-unknown\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const GenericOrderTypeIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function GenericOrderTypeIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-generic-order-type\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const GroupIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function GroupIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-group\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const GroupAccessIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function GroupAccessIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-group-access\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const HospitalBedIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function HospitalBedIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-hospital-bed\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ImageMedicalIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ImageMedicalIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-image-medical\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const InformationIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function InformationIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-information\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const InformationFilledIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function InformationFilledIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-information-filled\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const InformationSquareIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function InformationSquareIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-information-square\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const InventoryManagementIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function InventoryManagementIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-inventory-management\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const LabOrderIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function LabOrderIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-lab-order\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ListCheckedIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ListCheckedIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-list-checked\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const LocationIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function LocationIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-location\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const MaterialOrderIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function MaterialOrderIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-material-order\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const MaximizeIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function MaximizeIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-maximize\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const MedicationIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function MedicationIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-medication\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const MessageQueueIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function MessageQueueIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-message-queue\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const MicroscopeIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function MicroscopeIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-microscope\" iconProps={props} />;\n  }),\n);\n\n/**\n * Billing\n */\nexport const MoneyIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function MoneyIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-money\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const MotherIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function MotherIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-mother\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const MovementIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function MovementIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-movement\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const OverflowMenuHorizontalIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function OverflowMenuHorizontalIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-overflow-menu--horizontal\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const OverflowMenuVerticalIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function OverflowMenuVerticalIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-overflow-menu--horizontal\" iconProps={props} />;\n  }),\n);\n\nexport const PasswordIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function PasswordIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-password\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const PedestrianFamilyIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function PedestrianFamilyIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-pedestrian-family\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const PenIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function PenIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-pen\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const PrinterIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function PrinterIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-printer\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ProcedureOrderIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ProcedureOrderIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-procedure-order\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ProgramsIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ProgramsIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-programs\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ReferralOrderIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ReferralOrderIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-referral-order\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const RenewIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function RenewIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-renew\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ReportIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ReportIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-report\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ResetIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ResetIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-reset\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const SaveIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function SaveIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-save\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const SearchIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function SearchIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-search\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const SettingsIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function SaveIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-settings\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const SwitcherIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function SwitcherIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-switcher\" iconProps={props} />;\n  }),\n);\n\n/**\n * Order Basket, the UI to enter Orders for Medications, Referrals, Labs, Procedures and more\n */\nexport const ShoppingCartIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ShoppingCartIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-shopping-cart\" iconProps={props} />;\n  }),\n);\n\n/**\n * Used as a button to add an item to the Order basket from a search\n */\nexport const ShoppingCartArrowDownIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ShoppingCartArrowDownIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-shopping-cart--arrow-down\" iconProps={props} />;\n  }),\n);\n\n/**\n * Used as action button to open ward in-patient note workspace\n */\nexport const StickyNoteAddIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function StickyNoteAddIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-sticky-note-add\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const SyringeIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function SyringeIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-syringe\" iconProps={props} />;\n  }),\n);\n\n/**\n * Used as a button to add an item to the Order basket from a search\n */\nexport const TableOfContentsIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function TableOfContentsIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-table-of-contents\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const TableIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function TableIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-table\" iconProps={props} />;\n  }),\n);\n\n/**\n * Lab investigations\n */\nexport const TimeIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function TimeIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-time\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ToolsIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ToolsIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-tools\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const TranslateIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function TranslateIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-translate\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const TrashCanIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function TrashCanIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-trash-can\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const TreeViewAltIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function TreeViewAltIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-tree-view--alt\" iconProps={props} />;\n  }),\n);\n\n/**\n * User of OpenMRS e.g. My Account\n */\nexport const UserAvatarIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function UserAvatarIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-user-avatar\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const UserFollowIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function UserFollowIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-user-follow\" iconProps={props} />;\n  }),\n);\n\n/**\n * UserXray Icon\n *\n * `UserXrayIcon` is also used for imaging orders\n */\nexport const UserXrayIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function UserXrayIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-user-xray\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const UserIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function UserIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-user\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ViewOffIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ViewOffIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-view-off\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const ViewIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function ViewIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-view\" iconProps={props} />;\n  }),\n);\n\n/**\n */\nexport const WarningIcon = memo(\n  forwardRef<SVGSVGElement, IconProps>(function WarningIcon(props, ref) {\n    return <Icon ref={ref} icon=\"omrs-icon-warning\" iconProps={props} />;\n  }),\n);\n\n// Icon aliases that are a little more aligned to specific use-cases\n// should all resolve to a defined React icon\n\n/**\n */\nexport const AllergiesIcon = WarningIcon;\n\n/**\n *\n */\nexport const AttachmentIcon = DocumentAttachmentIcon;\n\n/**\n * Conditions\n *\n * Note this is an alias for ListCheckedIcon\n */\nexport const ConditionsIcon = ListCheckedIcon;\n\n/**\n *\n */\nexport const RadiologyIcon = ImageMedicalIcon;\n\n/**\n * Used as a button to add an item to the Order basket from a search\n *\n * Note this is an alias for ShoppingCartArrowDownIcon\n */\nexport const ShoppingCartAddItemIcon = ShoppingCartArrowDownIcon;\n\n/**\n * This is a utility component that takes an `icon` and renders it if the sprite for the icon\n * is available. The goal is to make it easier to conditionally render configuration-specified icons.\n *\n * @example\n * ```tsx\n *   <MaybeIcon icon='omrs-icon-baby' className={styles.myIconStyles} />\n * ```\n */\nexport const MaybeIcon = memo(\n  forwardRef<SVGSVGElement, { icon: string | undefined; fallback?: React.ReactNode } & IconProps>(function MaybeIcon(\n    { icon, fallback, ...iconProps },\n    ref,\n  ) {\n    const iconRef = useRef(icon ? document.getElementById(icon) : undefined);\n\n    useEffect(() => {\n      const container = document.getElementById('omrs-svgs-container');\n      const callback: MutationCallback = (mutationList) => {\n        for (const mutation of mutationList) {\n          if (mutation.type === 'childList') {\n            iconRef.current = icon ? document.getElementById(icon) : undefined;\n          }\n        }\n      };\n\n      const observer = new MutationObserver(callback);\n      if (container) {\n        observer.observe(container, { childList: true });\n      }\n\n      return () => observer.disconnect();\n    }, [icon]);\n\n    return (\n      <RenderIfValueIsTruthy value={iconRef.current} fallback={fallback}>\n        <Icon ref={ref} icon={icon as IconId} iconProps={iconProps} />\n      </RenderIfValueIsTruthy>\n    );\n  }),\n);\n\nexport type SvgIconProps = {\n  icon: IconId;\n  iconProps: IconProps;\n};\n\n/**\n * This is a utility type for custom icons that use the svg-sprite-loader to bundle custom icons\n */\nexport const Icon = memo(\n  forwardRef<SVGSVGElement, SvgIconProps>(function Icon({ icon, iconProps }, ref) {\n    let { className, fill, size } = Object.assign({}, { fill: 'currentColor', size: 20 }, iconProps);\n    if (size <= 0 || size > 72) {\n      console.error(`Invalid size '${size}' specified for ${icon}. Defaulting to 20.`);\n      size = 20;\n    }\n    const iconRef = useRef<SVGSVGElement>(null);\n\n    useImperativeHandle(ref, () => iconRef.current!);\n\n    useEffect(() => {\n      if (iconRef.current) {\n        if (fill !== 'currentColor') {\n          iconRef.current.style.setProperty('--omrs-icon-fill', fill);\n        }\n      }\n    }, []);\n\n    return (\n      <svg\n        ref={iconRef}\n        className={classNames('omrs-icon', style.icon, className)}\n        height={size}\n        width={size}\n        viewBox=\"0 0 16 16\"\n      >\n        <use href={`#${icon}`} />\n      </svg>\n    );\n  }),\n);\n"],"names":["React","forwardRef","memo","useEffect","useImperativeHandle","useRef","classNames","RenderIfValueIsTruthy","style","iconIds","ActivityIcon","props","ref","Icon","icon","iconProps","AddIcon","ArrowDownIcon","ArrowLeftIcon","ArrowRightIcon","ArrowUpIcon","BabyIcon","CalendarHeatMapIcon","CalendarHeatMap","CalendarIcon","Calendar","CaretDownIcon","CaretLeftIcon","CaretRightIcon","CaretUpIcon","ChartAverageIcon","CheckmarkFilledIcon","CheckmarkOutlineIcon","ChemistryIcon","ChevronDownIcon","ChevronLeftIcon","ChevronRightIcon","ChevronUpIcon","CloseIcon","CloseFilledIcon","CloseOutlineIcon","DocumentIcon","DocumentAttachmentIcon","DownloadIcon","DrugOrderIcon","EditIcon","EventScheduleIcon","EventsIcon","GenderFemaleIcon","GenderMaleIcon","GenderOtherIcon","GenderUnknownIcon","GenericOrderTypeIcon","GroupIcon","GroupAccessIcon","HospitalBedIcon","ImageMedicalIcon","InformationIcon","InformationFilledIcon","InformationSquareIcon","InventoryManagementIcon","LabOrderIcon","ListCheckedIcon","LocationIcon","MaterialOrderIcon","MaximizeIcon","MedicationIcon","MessageQueueIcon","MicroscopeIcon","MoneyIcon","MotherIcon","MovementIcon","OverflowMenuHorizontalIcon","OverflowMenuVerticalIcon","PasswordIcon","PedestrianFamilyIcon","PenIcon","PrinterIcon","ProcedureOrderIcon","ProgramsIcon","ReferralOrderIcon","RenewIcon","ReportIcon","ResetIcon","SaveIcon","SearchIcon","SettingsIcon","SwitcherIcon","ShoppingCartIcon","ShoppingCartArrowDownIcon","StickyNoteAddIcon","SyringeIcon","TableOfContentsIcon","TableIcon","TimeIcon","ToolsIcon","TranslateIcon","TrashCanIcon","TreeViewAltIcon","UserAvatarIcon","UserFollowIcon","UserXrayIcon","UserIcon","ViewOffIcon","ViewIcon","WarningIcon","AllergiesIcon","AttachmentIcon","ConditionsIcon","RadiologyIcon","ShoppingCartAddItemIcon","MaybeIcon","fallback","iconRef","document","getElementById","undefined","container","callback","mutationList","mutation","type","current","observer","MutationObserver","observe","childList","disconnect","value","Object","assign","fill","size","className","console","error","setProperty","svg","height","width","viewBox","use","href"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/src/icons/icons.tsx\n");
609
609
 
610
610
  /***/ }),
611
611
 
@@ -675,7 +675,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
675
675
  \**************************************************************************************/
676
676
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
677
677
 
678
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ useLocationByUuid: () => (/* binding */ useLocationByUuid),\n/* harmony export */ useLocations: () => (/* binding */ useLocations)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var swr_immutable__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! swr/immutable */ \"../../../node_modules/swr/dist/immutable/index.mjs\");\n/* harmony import */ var swr_infinite__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! swr/infinite */ \"../../../node_modules/swr/dist/infinite/index.mjs\");\n/* harmony import */ var _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @openmrs/esm-api */ \"../../framework/esm-api/dist/index.js\");\n/* harmony import */ var _openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @openmrs/esm-react-utils */ \"../../framework/esm-react-utils/dist/index.js\");\n\n\n\n\n\nfunction useLocationByUuid(locationUuid) {\n var url = locationUuid ? \"/ws/fhir2/R4/Location?_id=\".concat(locationUuid) : null;\n var _useSwrImmutable = (0,swr_immutable__WEBPACK_IMPORTED_MODULE_1__[\"default\"])(url, _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_3__.openmrsFetch, {\n shouldRetryOnError: function shouldRetryOnError(err) {\n var _err_response;\n if (err === null || err === void 0 ? void 0 : (_err_response = err.response) === null || _err_response === void 0 ? void 0 : _err_response.status) {\n return err.response.status >= 500;\n }\n return false;\n }\n }), data = _useSwrImmutable.data, error = _useSwrImmutable.error, isLoading = _useSwrImmutable.isLoading;\n return (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function() {\n var _data_data;\n return {\n location: (data === null || data === void 0 ? void 0 : (_data_data = data.data) === null || _data_data === void 0 ? void 0 : _data_data.entry) ? data.data.entry[0] : null,\n error: url ? error : null,\n isLoading: url ? isLoading : false\n };\n }, [\n data,\n isLoading,\n error,\n url\n ]);\n}\nfunction useLocations(locationTag) {\n var count = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 0, searchQuery = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : '';\n var debouncedSearchQuery = (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.useDebounce)(searchQuery);\n function constructUrl(page, prevPageData) {\n if (prevPageData) {\n var _prevPageData_data_link, _prevPageData_data;\n var nextLink = (_prevPageData_data = prevPageData.data) === null || _prevPageData_data === void 0 ? void 0 : (_prevPageData_data_link = _prevPageData_data.link) === null || _prevPageData_data_link === void 0 ? void 0 : _prevPageData_data_link.find(function(link) {\n return link.relation === 'next';\n });\n if (!nextLink) {\n return null;\n }\n var nextUrl = new URL(nextLink.url);\n // default for production\n if (nextUrl.origin === window.location.origin) {\n return nextLink.url;\n }\n // in development, the request should be funnelled through the local proxy\n return new URL(\"\".concat(nextUrl.pathname).concat(nextUrl.search ? \"?\".concat(nextUrl.search) : ''), window.location.origin).toString();\n }\n var url = \"\".concat(_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_3__.fhirBaseUrl, \"/Location?\");\n var urlSearchParameters = new URLSearchParams();\n urlSearchParameters.append('_summary', 'data');\n if (count) {\n urlSearchParameters.append('_count', '' + count);\n }\n if (page) {\n urlSearchParameters.append('_getpagesoffset', '' + page * count);\n }\n if (locationTag) {\n urlSearchParameters.append('_tag', locationTag);\n }\n if (typeof debouncedSearchQuery === 'string' && debouncedSearchQuery !== '') {\n urlSearchParameters.append('name:contains', debouncedSearchQuery);\n }\n return url + urlSearchParameters.toString();\n }\n var _useSwrInfinite = (0,swr_infinite__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(constructUrl, _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_3__.openmrsFetch), data = _useSwrInfinite.data, isLoading = _useSwrInfinite.isLoading, isValidating = _useSwrInfinite.isValidating, setSize = _useSwrInfinite.setSize, error = _useSwrInfinite.error;\n var memoizedLocations = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function() {\n var _data__data, _data_, _data__data_link, _data__data1, _data_1;\n return {\n locations: (data === null || data === void 0 ? void 0 : data.length) ? data === null || data === void 0 ? void 0 : data.flatMap(function(entries) {\n var _entries_data;\n var _entries_data_entry;\n return (_entries_data_entry = entries === null || entries === void 0 ? void 0 : (_entries_data = entries.data) === null || _entries_data === void 0 ? void 0 : _entries_data.entry) !== null && _entries_data_entry !== void 0 ? _entries_data_entry : [];\n }) : [],\n isLoading: isLoading,\n totalResults: data === null || data === void 0 ? void 0 : (_data_ = data[0]) === null || _data_ === void 0 ? void 0 : (_data__data = _data_.data) === null || _data__data === void 0 ? void 0 : _data__data.total,\n hasMore: (data === null || data === void 0 ? void 0 : data.length) ? data === null || data === void 0 ? void 0 : (_data_1 = data[data.length - 1]) === null || _data_1 === void 0 ? void 0 : (_data__data1 = _data_1.data) === null || _data__data1 === void 0 ? void 0 : (_data__data_link = _data__data1.link) === null || _data__data_link === void 0 ? void 0 : _data__data_link.some(function(link) {\n return link.relation === 'next';\n }) : false,\n loadingNewData: isValidating,\n error: error || null,\n setPage: setSize\n };\n }, [\n isLoading,\n data,\n isValidating,\n setSize,\n error\n ]);\n return memoizedLocations;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-styleguide/src/location-picker/location-picker.resource.ts","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-styleguide/src/location-picker/location-picker.resource.ts?e14f"],"sourcesContent":["import { useMemo } from 'react';\nimport useSwrImmutable from 'swr/immutable';\nimport useSwrInfinite from 'swr/infinite';\nimport { type FetchResponse, fhirBaseUrl, openmrsFetch } from '@openmrs/esm-api';\nimport { type FHIRLocationResource } from '@openmrs/esm-emr-api';\nimport { useDebounce } from '@openmrs/esm-react-utils';\n\nexport interface LocationResponse {\n  type: string;\n  total: number;\n  resourceType: string;\n  meta: {\n    lastUpdated: string;\n  };\n  link: Array<{\n    relation: string;\n    url: string;\n  }>;\n  id: string;\n  entry: Array<FHIRLocationResource>;\n}\nexport interface LoginLocationData {\n  locations: Array<FHIRLocationResource>;\n  isLoading: boolean;\n  totalResults?: number;\n  hasMore: boolean;\n  loadingNewData: boolean;\n  error: Error | null;\n  setPage: (size: number | ((_size: number) => number)) => Promise<FetchResponse<LocationResponse>[] | undefined>;\n}\n\nexport function useLocationByUuid(locationUuid?: string) {\n  const url = locationUuid ? `/ws/fhir2/R4/Location?_id=${locationUuid}` : null;\n\n  const { data, error, isLoading } = useSwrImmutable<FetchResponse<LocationResponse>>(url, openmrsFetch, {\n    shouldRetryOnError(err) {\n      if (err?.response?.status) {\n        return err.response.status >= 500;\n      }\n      return false;\n    },\n  });\n\n  return useMemo(\n    () => ({\n      location: data?.data?.entry ? data.data.entry[0] : null,\n      error: url ? error : null,\n      isLoading: url ? isLoading : false,\n    }),\n    [data, isLoading, error, url],\n  );\n}\n\nexport function useLocations(locationTag?: string, count: number = 0, searchQuery: string = ''): LoginLocationData {\n  const debouncedSearchQuery = useDebounce(searchQuery);\n  function constructUrl(page: number, prevPageData: FetchResponse<LocationResponse>) {\n    if (prevPageData) {\n      const nextLink = prevPageData.data?.link?.find((link) => link.relation === 'next');\n\n      if (!nextLink) {\n        return null;\n      }\n\n      const nextUrl = new URL(nextLink.url);\n      // default for production\n      if (nextUrl.origin === window.location.origin) {\n        return nextLink.url;\n      }\n\n      // in development, the request should be funnelled through the local proxy\n      return new URL(\n        `${nextUrl.pathname}${nextUrl.search ? `?${nextUrl.search}` : ''}`,\n        window.location.origin,\n      ).toString();\n    }\n\n    let url = `${fhirBaseUrl}/Location?`;\n    let urlSearchParameters = new URLSearchParams();\n    urlSearchParameters.append('_summary', 'data');\n\n    if (count) {\n      urlSearchParameters.append('_count', '' + count);\n    }\n\n    if (page) {\n      urlSearchParameters.append('_getpagesoffset', '' + page * count);\n    }\n\n    if (locationTag) {\n      urlSearchParameters.append('_tag', locationTag);\n    }\n\n    if (typeof debouncedSearchQuery === 'string' && debouncedSearchQuery !== '') {\n      urlSearchParameters.append('name:contains', debouncedSearchQuery);\n    }\n\n    return url + urlSearchParameters.toString();\n  }\n\n  const { data, isLoading, isValidating, setSize, error } = useSwrInfinite<FetchResponse<LocationResponse>, Error>(\n    constructUrl,\n    openmrsFetch,\n  );\n\n  const memoizedLocations = useMemo(() => {\n    return {\n      locations: data?.length ? data?.flatMap((entries) => entries?.data?.entry ?? []) : [],\n      isLoading,\n      totalResults: data?.[0]?.data?.total,\n      hasMore: data?.length ? data?.[data.length - 1]?.data?.link?.some((link) => link.relation === 'next') : false,\n      loadingNewData: isValidating,\n      error: error || null,\n      setPage: setSize,\n    };\n  }, [isLoading, data, isValidating, setSize, error]);\n\n  return memoizedLocations;\n}\n"],"names":["useMemo","useSwrImmutable","useSwrInfinite","fhirBaseUrl","openmrsFetch","useDebounce","useLocationByUuid","locationUuid","url","shouldRetryOnError","err","response","status","data","error","isLoading","location","entry","useLocations","locationTag","count","searchQuery","debouncedSearchQuery","constructUrl","page","prevPageData","nextLink","link","find","relation","nextUrl","URL","origin","window","pathname","search","toString","urlSearchParameters","URLSearchParams","append","isValidating","setSize","memoizedLocations","locations","length","flatMap","entries","totalResults","total","hasMore","some","loadingNewData","setPage"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/src/location-picker/location-picker.resource.ts\n");
678
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ useLocationByUuid: () => (/* binding */ useLocationByUuid),\n/* harmony export */ useLocations: () => (/* binding */ useLocations)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var swr_immutable__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! swr/immutable */ \"../../../node_modules/swr/dist/immutable/index.mjs\");\n/* harmony import */ var swr_infinite__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! swr/infinite */ \"../../../node_modules/swr/dist/infinite/index.mjs\");\n/* harmony import */ var _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @openmrs/esm-api */ \"../../framework/esm-api/dist/index.js\");\n/* harmony import */ var _openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @openmrs/esm-react-utils */ \"../../framework/esm-react-utils/dist/index.js\");\n\n\n\n\n\n/**\n * A React hook that fetches a location by its UUID using the FHIR API.\n *\n * @param locationUuid Optional UUID of the location to fetch. If not provided,\n * the hook returns null for the location without making a request.\n * @returns An object containing the location data, loading state, and any error.\n *\n * @category API\n */ function useLocationByUuid(locationUuid) {\n var url = locationUuid ? \"/ws/fhir2/R4/Location?_id=\".concat(locationUuid) : null;\n var _useSwrImmutable = (0,swr_immutable__WEBPACK_IMPORTED_MODULE_1__[\"default\"])(url, _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_3__.openmrsFetch, {\n shouldRetryOnError: function shouldRetryOnError(err) {\n var _err_response;\n if (err === null || err === void 0 ? void 0 : (_err_response = err.response) === null || _err_response === void 0 ? void 0 : _err_response.status) {\n return err.response.status >= 500;\n }\n return false;\n }\n }), data = _useSwrImmutable.data, error = _useSwrImmutable.error, isLoading = _useSwrImmutable.isLoading;\n return (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function() {\n var _data_data;\n return {\n location: (data === null || data === void 0 ? void 0 : (_data_data = data.data) === null || _data_data === void 0 ? void 0 : _data_data.entry) ? data.data.entry[0] : null,\n error: url ? error : null,\n isLoading: url ? isLoading : false\n };\n }, [\n data,\n isLoading,\n error,\n url\n ]);\n}\n/**\n * A React hook that fetches locations from the FHIR API with support for\n * pagination, filtering by tag, and searching by name. Uses SWR infinite\n * loading for efficient pagination.\n *\n * @param locationTag Optional tag to filter locations (e.g., 'Login Location').\n * @param count The number of locations to fetch per page. Defaults to 0 (no limit).\n * @param searchQuery Optional search string to filter locations by name.\n * @returns An object containing the locations array, loading states, pagination info, and any error.\n *\n * @category API\n */ function useLocations(locationTag) {\n var count = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 0, searchQuery = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : '';\n var debouncedSearchQuery = (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.useDebounce)(searchQuery);\n function constructUrl(page, prevPageData) {\n if (prevPageData) {\n var _prevPageData_data_link, _prevPageData_data;\n var nextLink = (_prevPageData_data = prevPageData.data) === null || _prevPageData_data === void 0 ? void 0 : (_prevPageData_data_link = _prevPageData_data.link) === null || _prevPageData_data_link === void 0 ? void 0 : _prevPageData_data_link.find(function(link) {\n return link.relation === 'next';\n });\n if (!nextLink) {\n return null;\n }\n var nextUrl = new URL(nextLink.url);\n // default for production\n if (nextUrl.origin === window.location.origin) {\n return nextLink.url;\n }\n // in development, the request should be funnelled through the local proxy\n return new URL(\"\".concat(nextUrl.pathname).concat(nextUrl.search ? \"?\".concat(nextUrl.search) : ''), window.location.origin).toString();\n }\n var url = \"\".concat(_openmrs_esm_api__WEBPACK_IMPORTED_MODULE_3__.fhirBaseUrl, \"/Location?\");\n var urlSearchParameters = new URLSearchParams();\n urlSearchParameters.append('_summary', 'data');\n if (count) {\n urlSearchParameters.append('_count', '' + count);\n }\n if (page) {\n urlSearchParameters.append('_getpagesoffset', '' + page * count);\n }\n if (locationTag) {\n urlSearchParameters.append('_tag', locationTag);\n }\n if (typeof debouncedSearchQuery === 'string' && debouncedSearchQuery !== '') {\n urlSearchParameters.append('name:contains', debouncedSearchQuery);\n }\n return url + urlSearchParameters.toString();\n }\n var _useSwrInfinite = (0,swr_infinite__WEBPACK_IMPORTED_MODULE_2__[\"default\"])(constructUrl, _openmrs_esm_api__WEBPACK_IMPORTED_MODULE_3__.openmrsFetch), data = _useSwrInfinite.data, isLoading = _useSwrInfinite.isLoading, isValidating = _useSwrInfinite.isValidating, setSize = _useSwrInfinite.setSize, error = _useSwrInfinite.error;\n var memoizedLocations = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function() {\n var _data__data, _data_, _data__data_link, _data__data1, _data_1;\n return {\n locations: (data === null || data === void 0 ? void 0 : data.length) ? data === null || data === void 0 ? void 0 : data.flatMap(function(entries) {\n var _entries_data;\n var _entries_data_entry;\n return (_entries_data_entry = entries === null || entries === void 0 ? void 0 : (_entries_data = entries.data) === null || _entries_data === void 0 ? void 0 : _entries_data.entry) !== null && _entries_data_entry !== void 0 ? _entries_data_entry : [];\n }) : [],\n isLoading: isLoading,\n totalResults: data === null || data === void 0 ? void 0 : (_data_ = data[0]) === null || _data_ === void 0 ? void 0 : (_data__data = _data_.data) === null || _data__data === void 0 ? void 0 : _data__data.total,\n hasMore: (data === null || data === void 0 ? void 0 : data.length) ? data === null || data === void 0 ? void 0 : (_data_1 = data[data.length - 1]) === null || _data_1 === void 0 ? void 0 : (_data__data1 = _data_1.data) === null || _data__data1 === void 0 ? void 0 : (_data__data_link = _data__data1.link) === null || _data__data_link === void 0 ? void 0 : _data__data_link.some(function(link) {\n return link.relation === 'next';\n }) : false,\n loadingNewData: isValidating,\n error: error || null,\n setPage: setSize\n };\n }, [\n isLoading,\n data,\n isValidating,\n setSize,\n error\n ]);\n return memoizedLocations;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-styleguide/src/location-picker/location-picker.resource.ts","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-styleguide/src/location-picker/location-picker.resource.ts?e14f"],"sourcesContent":["import { useMemo } from 'react';\nimport useSwrImmutable from 'swr/immutable';\nimport useSwrInfinite from 'swr/infinite';\nimport { type FetchResponse, fhirBaseUrl, openmrsFetch } from '@openmrs/esm-api';\nimport { type FHIRLocationResource } from '@openmrs/esm-emr-api';\nimport { useDebounce } from '@openmrs/esm-react-utils';\n\nexport interface LocationResponse {\n  type: string;\n  total: number;\n  resourceType: string;\n  meta: {\n    lastUpdated: string;\n  };\n  link: Array<{\n    relation: string;\n    url: string;\n  }>;\n  id: string;\n  entry: Array<FHIRLocationResource>;\n}\nexport interface LoginLocationData {\n  locations: Array<FHIRLocationResource>;\n  isLoading: boolean;\n  totalResults?: number;\n  hasMore: boolean;\n  loadingNewData: boolean;\n  error: Error | null;\n  setPage: (size: number | ((_size: number) => number)) => Promise<FetchResponse<LocationResponse>[] | undefined>;\n}\n\n/**\n * A React hook that fetches a location by its UUID using the FHIR API.\n *\n * @param locationUuid Optional UUID of the location to fetch. If not provided,\n *   the hook returns null for the location without making a request.\n * @returns An object containing the location data, loading state, and any error.\n *\n * @category API\n */\nexport function useLocationByUuid(locationUuid?: string) {\n  const url = locationUuid ? `/ws/fhir2/R4/Location?_id=${locationUuid}` : null;\n\n  const { data, error, isLoading } = useSwrImmutable<FetchResponse<LocationResponse>>(url, openmrsFetch, {\n    shouldRetryOnError(err) {\n      if (err?.response?.status) {\n        return err.response.status >= 500;\n      }\n      return false;\n    },\n  });\n\n  return useMemo(\n    () => ({\n      location: data?.data?.entry ? data.data.entry[0] : null,\n      error: url ? error : null,\n      isLoading: url ? isLoading : false,\n    }),\n    [data, isLoading, error, url],\n  );\n}\n\n/**\n * A React hook that fetches locations from the FHIR API with support for\n * pagination, filtering by tag, and searching by name. Uses SWR infinite\n * loading for efficient pagination.\n *\n * @param locationTag Optional tag to filter locations (e.g., 'Login Location').\n * @param count The number of locations to fetch per page. Defaults to 0 (no limit).\n * @param searchQuery Optional search string to filter locations by name.\n * @returns An object containing the locations array, loading states, pagination info, and any error.\n *\n * @category API\n */\nexport function useLocations(locationTag?: string, count: number = 0, searchQuery: string = ''): LoginLocationData {\n  const debouncedSearchQuery = useDebounce(searchQuery);\n  function constructUrl(page: number, prevPageData: FetchResponse<LocationResponse>) {\n    if (prevPageData) {\n      const nextLink = prevPageData.data?.link?.find((link) => link.relation === 'next');\n\n      if (!nextLink) {\n        return null;\n      }\n\n      const nextUrl = new URL(nextLink.url);\n      // default for production\n      if (nextUrl.origin === window.location.origin) {\n        return nextLink.url;\n      }\n\n      // in development, the request should be funnelled through the local proxy\n      return new URL(\n        `${nextUrl.pathname}${nextUrl.search ? `?${nextUrl.search}` : ''}`,\n        window.location.origin,\n      ).toString();\n    }\n\n    let url = `${fhirBaseUrl}/Location?`;\n    let urlSearchParameters = new URLSearchParams();\n    urlSearchParameters.append('_summary', 'data');\n\n    if (count) {\n      urlSearchParameters.append('_count', '' + count);\n    }\n\n    if (page) {\n      urlSearchParameters.append('_getpagesoffset', '' + page * count);\n    }\n\n    if (locationTag) {\n      urlSearchParameters.append('_tag', locationTag);\n    }\n\n    if (typeof debouncedSearchQuery === 'string' && debouncedSearchQuery !== '') {\n      urlSearchParameters.append('name:contains', debouncedSearchQuery);\n    }\n\n    return url + urlSearchParameters.toString();\n  }\n\n  const { data, isLoading, isValidating, setSize, error } = useSwrInfinite<FetchResponse<LocationResponse>, Error>(\n    constructUrl,\n    openmrsFetch,\n  );\n\n  const memoizedLocations = useMemo(() => {\n    return {\n      locations: data?.length ? data?.flatMap((entries) => entries?.data?.entry ?? []) : [],\n      isLoading,\n      totalResults: data?.[0]?.data?.total,\n      hasMore: data?.length ? data?.[data.length - 1]?.data?.link?.some((link) => link.relation === 'next') : false,\n      loadingNewData: isValidating,\n      error: error || null,\n      setPage: setSize,\n    };\n  }, [isLoading, data, isValidating, setSize, error]);\n\n  return memoizedLocations;\n}\n"],"names":["useMemo","useSwrImmutable","useSwrInfinite","fhirBaseUrl","openmrsFetch","useDebounce","useLocationByUuid","locationUuid","url","shouldRetryOnError","err","response","status","data","error","isLoading","location","entry","useLocations","locationTag","count","searchQuery","debouncedSearchQuery","constructUrl","page","prevPageData","nextLink","link","find","relation","nextUrl","URL","origin","window","pathname","search","toString","urlSearchParameters","URLSearchParams","append","isValidating","setSize","memoizedLocations","locations","length","flatMap","entries","totalResults","total","hasMore","some","loadingNewData","setPage"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/src/location-picker/location-picker.resource.ts\n");
679
679
 
680
680
  /***/ }),
681
681
 
@@ -985,7 +985,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
985
985
  \********************************************************************/
986
986
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
987
987
 
988
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ AppointmentsAltPictogram: () => (/* binding */ AppointmentsAltPictogram),\n/* harmony export */ AppointmentsPictogram: () => (/* binding */ AppointmentsPictogram),\n/* harmony export */ Assessment1Pictogram: () => (/* binding */ Assessment1Pictogram),\n/* harmony export */ Assessment2Pictogram: () => (/* binding */ Assessment2Pictogram),\n/* harmony export */ BloodBankPictogram: () => (/* binding */ BloodBankPictogram),\n/* harmony export */ CardiologyPictogram: () => (/* binding */ CardiologyPictogram),\n/* harmony export */ CtScanPictogram: () => (/* binding */ CtScanPictogram),\n/* harmony export */ DentistryPictogram: () => (/* binding */ DentistryPictogram),\n/* harmony export */ EmergencyDepartmentPictogram: () => (/* binding */ EmergencyDepartmentPictogram),\n/* harmony export */ FacilityPictogram: () => (/* binding */ FacilityPictogram),\n/* harmony export */ GeriatricsPictogram: () => (/* binding */ GeriatricsPictogram),\n/* harmony export */ GynaecologyPictogram: () => (/* binding */ GynaecologyPictogram),\n/* harmony export */ HomePictogram: () => (/* binding */ HomePictogram),\n/* harmony export */ InPatientPictogram: () => (/* binding */ InPatientPictogram),\n/* harmony export */ LaboratoryPictogram: () => (/* binding */ LaboratoryPictogram),\n/* harmony export */ Labs2Pictogram: () => (/* binding */ Labs2Pictogram),\n/* harmony export */ MaybePictogram: () => (/* binding */ MaybePictogram),\n/* harmony export */ ObstetricsPictogram: () => (/* binding */ ObstetricsPictogram),\n/* harmony export */ PatientListsPictogram: () => (/* binding */ PatientListsPictogram),\n/* harmony export */ PatientSearchPictogram: () => (/* binding */ PatientSearchPictogram),\n/* harmony export */ PatientsPictogram: () => (/* binding */ PatientsPictogram),\n/* harmony export */ PaymentsDeskPictogram: () => (/* binding */ PaymentsDeskPictogram),\n/* harmony export */ Pharmacy2Pictogram: () => (/* binding */ Pharmacy2Pictogram),\n/* harmony export */ PharmacyPictogram: () => (/* binding */ PharmacyPictogram),\n/* harmony export */ Pictogram: () => (/* binding */ Pictogram),\n/* harmony export */ RegistrationPictogram: () => (/* binding */ RegistrationPictogram),\n/* harmony export */ ServiceQueuesPictogram: () => (/* binding */ ServiceQueuesPictogram),\n/* harmony export */ StockManagementPictogram: () => (/* binding */ StockManagementPictogram),\n/* harmony export */ TransferPictogram: () => (/* binding */ TransferPictogram),\n/* harmony export */ TriagePictogram: () => (/* binding */ TriagePictogram),\n/* harmony export */ XrayPictogram: () => (/* binding */ XrayPictogram),\n/* harmony export */ pictogramIds: () => (/* binding */ pictogramIds)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! classnames */ \"../../../node_modules/classnames/index.js\");\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @openmrs/esm-react-utils */ \"../../framework/esm-react-utils/dist/index.js\");\n/* harmony import */ var _pictograms_module_scss__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./pictograms.module.scss */ \"../../framework/esm-styleguide/src/pictograms/pictograms.module.scss\");\n/** @category Pictograms */ function _object_without_properties(source, excluded) {\n if (source == null) return {};\n var target = _object_without_properties_loose(source, excluded);\n var key, i;\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n for(i = 0; i < sourceSymbolKeys.length; i++){\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n return target;\n}\nfunction _object_without_properties_loose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for(i = 0; i < sourceKeys.length; i++){\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}\n\n\n\n\nvar pictogramIds = [\n 'omrs-pict-appointments',\n 'omrs-pict-assessment-1',\n 'omrs-pict-assessment-2',\n 'omrs-pict-blood-bank',\n 'omrs-pict-cardiology',\n 'omrs-pict-ct-scan',\n 'omrs-pict-dentistry',\n 'omrs-pict-emergency-department',\n 'omrs-pict-facility',\n 'omrs-pict-geriatrics',\n 'omrs-pict-gynaecology',\n 'omrs-pict-in-patient',\n 'omrs-pict-laboratory',\n 'omrs-pict-labs-2',\n 'omrs-pict-obstetrics',\n 'omrs-pict-patient-search',\n 'omrs-pict-patients',\n 'omrs-pict-payments-desk',\n 'omrs-pict-pharmacy',\n 'omrs-pict-pharmacy-2',\n 'omrs-pict-registration',\n 'omrs-pict-service-queues',\n 'omrs-pict-stock-management',\n 'omrs-pict-transfer',\n 'omrs-pict-triage',\n 'omrs-pict-x-ray'\n];\nvar AppointmentsPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function AppointmentsPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-appointments\",\n pictogramProps: props\n });\n}));\n/**\n * @deprecated use AppointmentsPictogram instead\n */ var AppointmentsAltPictogram = AppointmentsPictogram;\nvar Assessment1Pictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function Assessment1Pictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-assessment-1\",\n pictogramProps: props\n });\n}));\nvar Assessment2Pictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function Assessment2Pictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-assessment-2\",\n pictogramProps: props\n });\n}));\nvar BloodBankPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function BloodBankPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-blood-bank\",\n pictogramProps: props\n });\n}));\nvar CardiologyPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CardiologyPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-cardiology\",\n pictogramProps: props\n });\n}));\nvar CtScanPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CtScanPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-ct-scan\",\n pictogramProps: props\n });\n}));\nvar DentistryPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function DentistryPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-dentistry\",\n pictogramProps: props\n });\n}));\nvar EmergencyDepartmentPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function EmergencyDepartmentPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-emergency-department\",\n pictogramProps: props\n });\n}));\nvar FacilityPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function FacilityPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-facility\",\n pictogramProps: props\n });\n}));\nvar GeriatricsPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function GeriatricsPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-geriatrics\",\n pictogramProps: props\n });\n}));\nvar GynaecologyPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function GynaecologyPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-gynaecology\",\n pictogramProps: props\n });\n}));\nvar InPatientPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function InPatientPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-in-patient\",\n pictogramProps: props\n });\n}));\nvar LaboratoryPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function LaboratoryPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-laboratory\",\n pictogramProps: props\n });\n}));\nvar Labs2Pictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function Labs2Pictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-labs-2\",\n pictogramProps: props\n });\n}));\nvar ObstetricsPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ObstetricsPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-obstetrics\",\n pictogramProps: props\n });\n}));\nvar PatientSearchPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function PatientSearchPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-patient-search\",\n pictogramProps: props\n });\n}));\nvar PatientsPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function PatientsPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-patients\",\n pictogramProps: props\n });\n}));\nvar PaymentsDeskPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function PaymentsDeskPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-payments-desk\",\n pictogramProps: props\n });\n}));\nvar PharmacyPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function PharmacyPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-pharmacy\",\n pictogramProps: props\n });\n}));\nvar Pharmacy2Pictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function Pharmacy2Pictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-pharmacy-2\",\n pictogramProps: props\n });\n}));\nvar RegistrationPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function RegistrationPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-registration\",\n pictogramProps: props\n });\n}));\nvar ServiceQueuesPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ServiceQueuesPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-service-queues\",\n pictogramProps: props\n });\n}));\nvar StockManagementPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function StockManagementPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-stock-management\",\n pictogramProps: props\n });\n}));\nvar TransferPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function TransferPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-transfer\",\n pictogramProps: props\n });\n}));\nvar TriagePictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function TriagePictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-triage\",\n pictogramProps: props\n });\n}));\nvar XrayPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function XrayPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-x-ray\",\n pictogramProps: props\n });\n}));\n// Pictogram aliases that are a little more aligned to specific use-cases\n// should all resolve to a defined React icon\nvar HomePictogram = FacilityPictogram;\nvar PatientListsPictogram = PatientsPictogram;\n/**\n * This is a utility component that takes an `pictogram` and render it if the sprite for the pictogram\n * is available. The goal is to make it easier to conditionally render configuration-specified pictograms.\n *\n * @example\n * ```tsx\n * <MaybePictogram pictogram='omrs-icon-baby' className={styles.myPictogramStyles} />\n * ```\n */ var MaybePictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function MaybePictogram(_param, ref) {\n var pictogram = _param.pictogram, fallback = _param.fallback, pictogramProps = _object_without_properties(_param, [\n \"pictogram\",\n \"fallback\"\n ]);\n var iconRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(document.getElementById(pictogram));\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function() {\n var container = document.getElementById('omrs-svgs-container');\n var callback = function(mutationList) {\n var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;\n try {\n for(var _iterator = mutationList[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){\n var mutation = _step.value;\n if (mutation.type === 'childList') {\n iconRef.current = document.getElementById(pictogram);\n }\n }\n } catch (err) {\n _didIteratorError = true;\n _iteratorError = err;\n } finally{\n try {\n if (!_iteratorNormalCompletion && _iterator.return != null) {\n _iterator.return();\n }\n } finally{\n if (_didIteratorError) {\n throw _iteratorError;\n }\n }\n }\n };\n var observer = new MutationObserver(callback);\n if (container) {\n observer.observe(container, {\n childList: true\n });\n }\n return function() {\n return observer.disconnect();\n };\n }, [\n pictogram\n ]);\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_2__.RenderIfValueIsTruthy, {\n value: iconRef.current,\n fallback: fallback\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: pictogram,\n pictogramProps: pictogramProps\n }));\n}));\n/**\n * This is a utility type for custom pictograms. Please maintain alphabetical order when adding new pictograms for readability.\n */ var Pictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function Pictogram(param, ref) {\n var pictogram = param.pictogram, pictogramProps = param.pictogramProps;\n var _Object_assign = Object.assign({}, {\n size: 92\n }, pictogramProps), className = _Object_assign.className, size = _Object_assign.size;\n if (size <= 26 || size > 144) {\n console.error(\"Invalid size '\".concat(size, \"' specified for \").concat(pictogram, \". Defaulting to 92.\"));\n size = 92;\n }\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"svg\", {\n ref: ref,\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(_pictograms_module_scss__WEBPACK_IMPORTED_MODULE_3__[\"default\"].pictogram, className),\n height: size,\n width: size\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"use\", {\n href: \"#\".concat(pictogram)\n }));\n}));\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-styleguide/src/pictograms/pictograms.tsx","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-styleguide/src/pictograms/pictograms.tsx?507b"],"sourcesContent":["/** @category Pictograms */\nimport React, { forwardRef, memo, useEffect, useRef } from 'react';\nimport classNames, { type Argument } from 'classnames';\nimport { RenderIfValueIsTruthy } from '@openmrs/esm-react-utils';\nimport style from './pictograms.module.scss';\n\nexport const pictogramIds = [\n  'omrs-pict-appointments',\n  'omrs-pict-assessment-1',\n  'omrs-pict-assessment-2',\n  'omrs-pict-blood-bank',\n  'omrs-pict-cardiology',\n  'omrs-pict-ct-scan',\n  'omrs-pict-dentistry',\n  'omrs-pict-emergency-department',\n  'omrs-pict-facility',\n  'omrs-pict-geriatrics',\n  'omrs-pict-gynaecology',\n  'omrs-pict-in-patient',\n  'omrs-pict-laboratory',\n  'omrs-pict-labs-2',\n  'omrs-pict-obstetrics',\n  'omrs-pict-patient-search',\n  'omrs-pict-patients',\n  'omrs-pict-payments-desk',\n  'omrs-pict-pharmacy',\n  'omrs-pict-pharmacy-2',\n  'omrs-pict-registration',\n  'omrs-pict-service-queues',\n  'omrs-pict-stock-management',\n  'omrs-pict-transfer',\n  'omrs-pict-triage',\n  'omrs-pict-x-ray',\n] as const;\n\nexport type PictogramId = (typeof pictogramIds)[number];\n\nexport type PictogramProps = {\n  className?: Argument;\n  size?: number;\n};\n\nexport const AppointmentsPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function AppointmentsPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-appointments\" pictogramProps={props} />;\n  }),\n);\n\n/**\n * @deprecated use AppointmentsPictogram instead\n */\nexport const AppointmentsAltPictogram = AppointmentsPictogram;\n\nexport const Assessment1Pictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function Assessment1Pictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-assessment-1\" pictogramProps={props} />;\n  }),\n);\n\nexport const Assessment2Pictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function Assessment2Pictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-assessment-2\" pictogramProps={props} />;\n  }),\n);\n\nexport const BloodBankPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function BloodBankPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-blood-bank\" pictogramProps={props} />;\n  }),\n);\n\nexport const CardiologyPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function CardiologyPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-cardiology\" pictogramProps={props} />;\n  }),\n);\n\nexport const CtScanPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function CtScanPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-ct-scan\" pictogramProps={props} />;\n  }),\n);\n\nexport const DentistryPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function DentistryPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-dentistry\" pictogramProps={props} />;\n  }),\n);\n\nexport const EmergencyDepartmentPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function EmergencyDepartmentPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-emergency-department\" pictogramProps={props} />;\n  }),\n);\n\nexport const FacilityPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function FacilityPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-facility\" pictogramProps={props} />;\n  }),\n);\n\nexport const GeriatricsPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function GeriatricsPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-geriatrics\" pictogramProps={props} />;\n  }),\n);\n\nexport const GynaecologyPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function GynaecologyPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-gynaecology\" pictogramProps={props} />;\n  }),\n);\n\nexport const InPatientPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function InPatientPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-in-patient\" pictogramProps={props} />;\n  }),\n);\n\nexport const LaboratoryPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function LaboratoryPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-laboratory\" pictogramProps={props} />;\n  }),\n);\n\nexport const Labs2Pictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function Labs2Pictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-labs-2\" pictogramProps={props} />;\n  }),\n);\n\nexport const ObstetricsPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function ObstetricsPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-obstetrics\" pictogramProps={props} />;\n  }),\n);\n\nexport const PatientSearchPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function PatientSearchPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-patient-search\" pictogramProps={props} />;\n  }),\n);\n\nexport const PatientsPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function PatientsPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-patients\" pictogramProps={props} />;\n  }),\n);\n\nexport const PaymentsDeskPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function PaymentsDeskPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-payments-desk\" pictogramProps={props} />;\n  }),\n);\n\nexport const PharmacyPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function PharmacyPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-pharmacy\" pictogramProps={props} />;\n  }),\n);\n\nexport const Pharmacy2Pictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function Pharmacy2Pictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-pharmacy-2\" pictogramProps={props} />;\n  }),\n);\n\nexport const RegistrationPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function RegistrationPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-registration\" pictogramProps={props} />;\n  }),\n);\n\nexport const ServiceQueuesPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function ServiceQueuesPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-service-queues\" pictogramProps={props} />;\n  }),\n);\n\nexport const StockManagementPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function StockManagementPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-stock-management\" pictogramProps={props} />;\n  }),\n);\n\nexport const TransferPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function TransferPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-transfer\" pictogramProps={props} />;\n  }),\n);\n\nexport const TriagePictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function TriagePictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-triage\" pictogramProps={props} />;\n  }),\n);\n\nexport const XrayPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function XrayPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-x-ray\" pictogramProps={props} />;\n  }),\n);\n\n// Pictogram aliases that are a little more aligned to specific use-cases\n// should all resolve to a defined React icon\n\nexport const HomePictogram = FacilityPictogram;\n\nexport const PatientListsPictogram = PatientsPictogram;\n\n/**\n * This is a utility component that takes an `pictogram` and render it if the sprite for the pictogram\n * is available. The goal is to make it easier to conditionally render configuration-specified pictograms.\n *\n * @example\n * ```tsx\n *   <MaybePictogram pictogram='omrs-icon-baby' className={styles.myPictogramStyles} />\n * ```\n */\nexport const MaybePictogram = memo(\n  forwardRef<SVGSVGElement, { pictogram: string; fallback?: React.ReactNode } & PictogramProps>(function MaybePictogram(\n    { pictogram, fallback, ...pictogramProps },\n    ref,\n  ) {\n    const iconRef = useRef(document.getElementById(pictogram));\n\n    useEffect(() => {\n      const container = document.getElementById('omrs-svgs-container');\n      const callback: MutationCallback = (mutationList) => {\n        for (const mutation of mutationList) {\n          if (mutation.type === 'childList') {\n            iconRef.current = document.getElementById(pictogram);\n          }\n        }\n      };\n\n      const observer = new MutationObserver(callback);\n      if (container) {\n        observer.observe(container, { childList: true });\n      }\n\n      return () => observer.disconnect();\n    }, [pictogram]);\n\n    return (\n      <RenderIfValueIsTruthy value={iconRef.current} fallback={fallback}>\n        <Pictogram ref={ref} pictogram={pictogram as PictogramId} pictogramProps={pictogramProps} />\n      </RenderIfValueIsTruthy>\n    );\n  }),\n);\n\nexport type SvgPictogramProps = {\n  /** the id of the pictogram  */\n  pictogram: PictogramId;\n  /** properties when using the pictogram  */\n  pictogramProps: PictogramProps;\n};\n\n/**\n * This is a utility type for custom pictograms. Please maintain alphabetical order when adding new pictograms for readability.\n */\nexport const Pictogram = memo(\n  forwardRef<SVGSVGElement, SvgPictogramProps>(function Pictogram({ pictogram, pictogramProps }, ref) {\n    let { className, size } = Object.assign({}, { size: 92 }, pictogramProps);\n    if (size <= 26 || size > 144) {\n      console.error(`Invalid size '${size}' specified for ${pictogram}. Defaulting to 92.`);\n      size = 92;\n    }\n\n    return (\n      <svg ref={ref} className={classNames(style.pictogram, className)} height={size} width={size}>\n        <use href={`#${pictogram}`} />\n      </svg>\n    );\n  }),\n);\n"],"names":["React","forwardRef","memo","useEffect","useRef","classNames","RenderIfValueIsTruthy","style","pictogramIds","AppointmentsPictogram","props","ref","Pictogram","pictogram","pictogramProps","AppointmentsAltPictogram","Assessment1Pictogram","Assessment2Pictogram","BloodBankPictogram","CardiologyPictogram","CtScanPictogram","DentistryPictogram","EmergencyDepartmentPictogram","FacilityPictogram","GeriatricsPictogram","GynaecologyPictogram","InPatientPictogram","LaboratoryPictogram","Labs2Pictogram","ObstetricsPictogram","PatientSearchPictogram","PatientsPictogram","PaymentsDeskPictogram","PharmacyPictogram","Pharmacy2Pictogram","RegistrationPictogram","ServiceQueuesPictogram","StockManagementPictogram","TransferPictogram","TriagePictogram","XrayPictogram","HomePictogram","PatientListsPictogram","MaybePictogram","fallback","iconRef","document","getElementById","container","callback","mutationList","mutation","type","current","observer","MutationObserver","observe","childList","disconnect","value","Object","assign","size","className","console","error","svg","height","width","use","href"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/src/pictograms/pictograms.tsx\n");
988
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ AppointmentsAltPictogram: () => (/* binding */ AppointmentsAltPictogram),\n/* harmony export */ AppointmentsPictogram: () => (/* binding */ AppointmentsPictogram),\n/* harmony export */ Assessment1Pictogram: () => (/* binding */ Assessment1Pictogram),\n/* harmony export */ Assessment2Pictogram: () => (/* binding */ Assessment2Pictogram),\n/* harmony export */ BloodBankPictogram: () => (/* binding */ BloodBankPictogram),\n/* harmony export */ CardiologyPictogram: () => (/* binding */ CardiologyPictogram),\n/* harmony export */ CtScanPictogram: () => (/* binding */ CtScanPictogram),\n/* harmony export */ DentistryPictogram: () => (/* binding */ DentistryPictogram),\n/* harmony export */ EmergencyDepartmentPictogram: () => (/* binding */ EmergencyDepartmentPictogram),\n/* harmony export */ FacilityPictogram: () => (/* binding */ FacilityPictogram),\n/* harmony export */ GeriatricsPictogram: () => (/* binding */ GeriatricsPictogram),\n/* harmony export */ GynaecologyPictogram: () => (/* binding */ GynaecologyPictogram),\n/* harmony export */ HomePictogram: () => (/* binding */ HomePictogram),\n/* harmony export */ InPatientPictogram: () => (/* binding */ InPatientPictogram),\n/* harmony export */ LaboratoryPictogram: () => (/* binding */ LaboratoryPictogram),\n/* harmony export */ Labs2Pictogram: () => (/* binding */ Labs2Pictogram),\n/* harmony export */ MaybePictogram: () => (/* binding */ MaybePictogram),\n/* harmony export */ ObstetricsPictogram: () => (/* binding */ ObstetricsPictogram),\n/* harmony export */ PatientListsPictogram: () => (/* binding */ PatientListsPictogram),\n/* harmony export */ PatientSearchPictogram: () => (/* binding */ PatientSearchPictogram),\n/* harmony export */ PatientsPictogram: () => (/* binding */ PatientsPictogram),\n/* harmony export */ PaymentsDeskPictogram: () => (/* binding */ PaymentsDeskPictogram),\n/* harmony export */ Pharmacy2Pictogram: () => (/* binding */ Pharmacy2Pictogram),\n/* harmony export */ PharmacyPictogram: () => (/* binding */ PharmacyPictogram),\n/* harmony export */ Pictogram: () => (/* binding */ Pictogram),\n/* harmony export */ RegistrationPictogram: () => (/* binding */ RegistrationPictogram),\n/* harmony export */ ServiceQueuesPictogram: () => (/* binding */ ServiceQueuesPictogram),\n/* harmony export */ StockManagementPictogram: () => (/* binding */ StockManagementPictogram),\n/* harmony export */ TransferPictogram: () => (/* binding */ TransferPictogram),\n/* harmony export */ TriagePictogram: () => (/* binding */ TriagePictogram),\n/* harmony export */ XrayPictogram: () => (/* binding */ XrayPictogram),\n/* harmony export */ pictogramIds: () => (/* binding */ pictogramIds)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! classnames */ \"../../../node_modules/classnames/index.js\");\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @openmrs/esm-react-utils */ \"../../framework/esm-react-utils/dist/index.js\");\n/* harmony import */ var _pictograms_module_scss__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./pictograms.module.scss */ \"../../framework/esm-styleguide/src/pictograms/pictograms.module.scss\");\n/** @category Pictograms */ function _object_without_properties(source, excluded) {\n if (source == null) return {};\n var target = _object_without_properties_loose(source, excluded);\n var key, i;\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n for(i = 0; i < sourceSymbolKeys.length; i++){\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n return target;\n}\nfunction _object_without_properties_loose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for(i = 0; i < sourceKeys.length; i++){\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}\n\n\n\n\n/** Array of all available OpenMRS pictogram IDs that can be used with the Pictogram component. */ var pictogramIds = [\n 'omrs-pict-appointments',\n 'omrs-pict-assessment-1',\n 'omrs-pict-assessment-2',\n 'omrs-pict-blood-bank',\n 'omrs-pict-cardiology',\n 'omrs-pict-ct-scan',\n 'omrs-pict-dentistry',\n 'omrs-pict-emergency-department',\n 'omrs-pict-facility',\n 'omrs-pict-geriatrics',\n 'omrs-pict-gynaecology',\n 'omrs-pict-in-patient',\n 'omrs-pict-laboratory',\n 'omrs-pict-labs-2',\n 'omrs-pict-obstetrics',\n 'omrs-pict-patient-search',\n 'omrs-pict-patients',\n 'omrs-pict-payments-desk',\n 'omrs-pict-pharmacy',\n 'omrs-pict-pharmacy-2',\n 'omrs-pict-registration',\n 'omrs-pict-service-queues',\n 'omrs-pict-stock-management',\n 'omrs-pict-transfer',\n 'omrs-pict-triage',\n 'omrs-pict-x-ray'\n];\nvar AppointmentsPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function AppointmentsPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-appointments\",\n pictogramProps: props\n });\n}));\n/**\n * @deprecated use AppointmentsPictogram instead\n */ var AppointmentsAltPictogram = AppointmentsPictogram;\nvar Assessment1Pictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function Assessment1Pictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-assessment-1\",\n pictogramProps: props\n });\n}));\nvar Assessment2Pictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function Assessment2Pictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-assessment-2\",\n pictogramProps: props\n });\n}));\nvar BloodBankPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function BloodBankPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-blood-bank\",\n pictogramProps: props\n });\n}));\nvar CardiologyPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CardiologyPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-cardiology\",\n pictogramProps: props\n });\n}));\nvar CtScanPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function CtScanPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-ct-scan\",\n pictogramProps: props\n });\n}));\nvar DentistryPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function DentistryPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-dentistry\",\n pictogramProps: props\n });\n}));\nvar EmergencyDepartmentPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function EmergencyDepartmentPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-emergency-department\",\n pictogramProps: props\n });\n}));\nvar FacilityPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function FacilityPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-facility\",\n pictogramProps: props\n });\n}));\nvar GeriatricsPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function GeriatricsPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-geriatrics\",\n pictogramProps: props\n });\n}));\nvar GynaecologyPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function GynaecologyPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-gynaecology\",\n pictogramProps: props\n });\n}));\nvar InPatientPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function InPatientPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-in-patient\",\n pictogramProps: props\n });\n}));\nvar LaboratoryPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function LaboratoryPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-laboratory\",\n pictogramProps: props\n });\n}));\nvar Labs2Pictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function Labs2Pictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-labs-2\",\n pictogramProps: props\n });\n}));\nvar ObstetricsPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ObstetricsPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-obstetrics\",\n pictogramProps: props\n });\n}));\nvar PatientSearchPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function PatientSearchPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-patient-search\",\n pictogramProps: props\n });\n}));\nvar PatientsPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function PatientsPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-patients\",\n pictogramProps: props\n });\n}));\nvar PaymentsDeskPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function PaymentsDeskPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-payments-desk\",\n pictogramProps: props\n });\n}));\nvar PharmacyPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function PharmacyPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-pharmacy\",\n pictogramProps: props\n });\n}));\nvar Pharmacy2Pictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function Pharmacy2Pictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-pharmacy-2\",\n pictogramProps: props\n });\n}));\nvar RegistrationPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function RegistrationPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-registration\",\n pictogramProps: props\n });\n}));\nvar ServiceQueuesPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function ServiceQueuesPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-service-queues\",\n pictogramProps: props\n });\n}));\nvar StockManagementPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function StockManagementPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-stock-management\",\n pictogramProps: props\n });\n}));\nvar TransferPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function TransferPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-transfer\",\n pictogramProps: props\n });\n}));\nvar TriagePictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function TriagePictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-triage\",\n pictogramProps: props\n });\n}));\nvar XrayPictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function XrayPictogram(props, ref) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: \"omrs-pict-x-ray\",\n pictogramProps: props\n });\n}));\n// Pictogram aliases that are a little more aligned to specific use-cases\n// should all resolve to a defined React icon\nvar HomePictogram = FacilityPictogram;\nvar PatientListsPictogram = PatientsPictogram;\n/**\n * This is a utility component that takes an `pictogram` and render it if the sprite for the pictogram\n * is available. The goal is to make it easier to conditionally render configuration-specified pictograms.\n *\n * @example\n * ```tsx\n * <MaybePictogram pictogram='omrs-icon-baby' className={styles.myPictogramStyles} />\n * ```\n */ var MaybePictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function MaybePictogram(_param, ref) {\n var pictogram = _param.pictogram, fallback = _param.fallback, pictogramProps = _object_without_properties(_param, [\n \"pictogram\",\n \"fallback\"\n ]);\n var iconRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(document.getElementById(pictogram));\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function() {\n var container = document.getElementById('omrs-svgs-container');\n var callback = function(mutationList) {\n var _iteratorNormalCompletion = true, _didIteratorError = false, _iteratorError = undefined;\n try {\n for(var _iterator = mutationList[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true){\n var mutation = _step.value;\n if (mutation.type === 'childList') {\n iconRef.current = document.getElementById(pictogram);\n }\n }\n } catch (err) {\n _didIteratorError = true;\n _iteratorError = err;\n } finally{\n try {\n if (!_iteratorNormalCompletion && _iterator.return != null) {\n _iterator.return();\n }\n } finally{\n if (_didIteratorError) {\n throw _iteratorError;\n }\n }\n }\n };\n var observer = new MutationObserver(callback);\n if (container) {\n observer.observe(container, {\n childList: true\n });\n }\n return function() {\n return observer.disconnect();\n };\n }, [\n pictogram\n ]);\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_2__.RenderIfValueIsTruthy, {\n value: iconRef.current,\n fallback: fallback\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Pictogram, {\n ref: ref,\n pictogram: pictogram,\n pictogramProps: pictogramProps\n }));\n}));\n/**\n * This is a utility type for custom pictograms. Please maintain alphabetical order when adding new pictograms for readability.\n */ var Pictogram = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.memo)(/*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_0__.forwardRef)(function Pictogram(param, ref) {\n var pictogram = param.pictogram, pictogramProps = param.pictogramProps;\n var _Object_assign = Object.assign({}, {\n size: 92\n }, pictogramProps), className = _Object_assign.className, size = _Object_assign.size;\n if (size <= 26 || size > 144) {\n console.error(\"Invalid size '\".concat(size, \"' specified for \").concat(pictogram, \". Defaulting to 92.\"));\n size = 92;\n }\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"svg\", {\n ref: ref,\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(_pictograms_module_scss__WEBPACK_IMPORTED_MODULE_3__[\"default\"].pictogram, className),\n height: size,\n width: size\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"use\", {\n href: \"#\".concat(pictogram)\n }));\n}));\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-styleguide/src/pictograms/pictograms.tsx","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-styleguide/src/pictograms/pictograms.tsx?507b"],"sourcesContent":["/** @category Pictograms */\nimport React, { forwardRef, memo, useEffect, useRef } from 'react';\nimport classNames, { type Argument } from 'classnames';\nimport { RenderIfValueIsTruthy } from '@openmrs/esm-react-utils';\nimport style from './pictograms.module.scss';\n\n/** Array of all available OpenMRS pictogram IDs that can be used with the Pictogram component. */\nexport const pictogramIds = [\n  'omrs-pict-appointments',\n  'omrs-pict-assessment-1',\n  'omrs-pict-assessment-2',\n  'omrs-pict-blood-bank',\n  'omrs-pict-cardiology',\n  'omrs-pict-ct-scan',\n  'omrs-pict-dentistry',\n  'omrs-pict-emergency-department',\n  'omrs-pict-facility',\n  'omrs-pict-geriatrics',\n  'omrs-pict-gynaecology',\n  'omrs-pict-in-patient',\n  'omrs-pict-laboratory',\n  'omrs-pict-labs-2',\n  'omrs-pict-obstetrics',\n  'omrs-pict-patient-search',\n  'omrs-pict-patients',\n  'omrs-pict-payments-desk',\n  'omrs-pict-pharmacy',\n  'omrs-pict-pharmacy-2',\n  'omrs-pict-registration',\n  'omrs-pict-service-queues',\n  'omrs-pict-stock-management',\n  'omrs-pict-transfer',\n  'omrs-pict-triage',\n  'omrs-pict-x-ray',\n] as const;\n\nexport type PictogramId = (typeof pictogramIds)[number];\n\nexport type PictogramProps = {\n  className?: Argument;\n  size?: number;\n};\n\nexport const AppointmentsPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function AppointmentsPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-appointments\" pictogramProps={props} />;\n  }),\n);\n\n/**\n * @deprecated use AppointmentsPictogram instead\n */\nexport const AppointmentsAltPictogram = AppointmentsPictogram;\n\nexport const Assessment1Pictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function Assessment1Pictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-assessment-1\" pictogramProps={props} />;\n  }),\n);\n\nexport const Assessment2Pictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function Assessment2Pictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-assessment-2\" pictogramProps={props} />;\n  }),\n);\n\nexport const BloodBankPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function BloodBankPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-blood-bank\" pictogramProps={props} />;\n  }),\n);\n\nexport const CardiologyPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function CardiologyPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-cardiology\" pictogramProps={props} />;\n  }),\n);\n\nexport const CtScanPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function CtScanPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-ct-scan\" pictogramProps={props} />;\n  }),\n);\n\nexport const DentistryPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function DentistryPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-dentistry\" pictogramProps={props} />;\n  }),\n);\n\nexport const EmergencyDepartmentPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function EmergencyDepartmentPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-emergency-department\" pictogramProps={props} />;\n  }),\n);\n\nexport const FacilityPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function FacilityPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-facility\" pictogramProps={props} />;\n  }),\n);\n\nexport const GeriatricsPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function GeriatricsPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-geriatrics\" pictogramProps={props} />;\n  }),\n);\n\nexport const GynaecologyPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function GynaecologyPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-gynaecology\" pictogramProps={props} />;\n  }),\n);\n\nexport const InPatientPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function InPatientPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-in-patient\" pictogramProps={props} />;\n  }),\n);\n\nexport const LaboratoryPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function LaboratoryPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-laboratory\" pictogramProps={props} />;\n  }),\n);\n\nexport const Labs2Pictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function Labs2Pictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-labs-2\" pictogramProps={props} />;\n  }),\n);\n\nexport const ObstetricsPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function ObstetricsPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-obstetrics\" pictogramProps={props} />;\n  }),\n);\n\nexport const PatientSearchPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function PatientSearchPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-patient-search\" pictogramProps={props} />;\n  }),\n);\n\nexport const PatientsPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function PatientsPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-patients\" pictogramProps={props} />;\n  }),\n);\n\nexport const PaymentsDeskPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function PaymentsDeskPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-payments-desk\" pictogramProps={props} />;\n  }),\n);\n\nexport const PharmacyPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function PharmacyPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-pharmacy\" pictogramProps={props} />;\n  }),\n);\n\nexport const Pharmacy2Pictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function Pharmacy2Pictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-pharmacy-2\" pictogramProps={props} />;\n  }),\n);\n\nexport const RegistrationPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function RegistrationPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-registration\" pictogramProps={props} />;\n  }),\n);\n\nexport const ServiceQueuesPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function ServiceQueuesPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-service-queues\" pictogramProps={props} />;\n  }),\n);\n\nexport const StockManagementPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function StockManagementPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-stock-management\" pictogramProps={props} />;\n  }),\n);\n\nexport const TransferPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function TransferPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-transfer\" pictogramProps={props} />;\n  }),\n);\n\nexport const TriagePictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function TriagePictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-triage\" pictogramProps={props} />;\n  }),\n);\n\nexport const XrayPictogram = memo(\n  forwardRef<SVGSVGElement, PictogramProps>(function XrayPictogram(props, ref) {\n    return <Pictogram ref={ref} pictogram=\"omrs-pict-x-ray\" pictogramProps={props} />;\n  }),\n);\n\n// Pictogram aliases that are a little more aligned to specific use-cases\n// should all resolve to a defined React icon\n\nexport const HomePictogram = FacilityPictogram;\n\nexport const PatientListsPictogram = PatientsPictogram;\n\n/**\n * This is a utility component that takes an `pictogram` and render it if the sprite for the pictogram\n * is available. The goal is to make it easier to conditionally render configuration-specified pictograms.\n *\n * @example\n * ```tsx\n *   <MaybePictogram pictogram='omrs-icon-baby' className={styles.myPictogramStyles} />\n * ```\n */\nexport const MaybePictogram = memo(\n  forwardRef<SVGSVGElement, { pictogram: string; fallback?: React.ReactNode } & PictogramProps>(function MaybePictogram(\n    { pictogram, fallback, ...pictogramProps },\n    ref,\n  ) {\n    const iconRef = useRef(document.getElementById(pictogram));\n\n    useEffect(() => {\n      const container = document.getElementById('omrs-svgs-container');\n      const callback: MutationCallback = (mutationList) => {\n        for (const mutation of mutationList) {\n          if (mutation.type === 'childList') {\n            iconRef.current = document.getElementById(pictogram);\n          }\n        }\n      };\n\n      const observer = new MutationObserver(callback);\n      if (container) {\n        observer.observe(container, { childList: true });\n      }\n\n      return () => observer.disconnect();\n    }, [pictogram]);\n\n    return (\n      <RenderIfValueIsTruthy value={iconRef.current} fallback={fallback}>\n        <Pictogram ref={ref} pictogram={pictogram as PictogramId} pictogramProps={pictogramProps} />\n      </RenderIfValueIsTruthy>\n    );\n  }),\n);\n\nexport type SvgPictogramProps = {\n  /** the id of the pictogram  */\n  pictogram: PictogramId;\n  /** properties when using the pictogram  */\n  pictogramProps: PictogramProps;\n};\n\n/**\n * This is a utility type for custom pictograms. Please maintain alphabetical order when adding new pictograms for readability.\n */\nexport const Pictogram = memo(\n  forwardRef<SVGSVGElement, SvgPictogramProps>(function Pictogram({ pictogram, pictogramProps }, ref) {\n    let { className, size } = Object.assign({}, { size: 92 }, pictogramProps);\n    if (size <= 26 || size > 144) {\n      console.error(`Invalid size '${size}' specified for ${pictogram}. Defaulting to 92.`);\n      size = 92;\n    }\n\n    return (\n      <svg ref={ref} className={classNames(style.pictogram, className)} height={size} width={size}>\n        <use href={`#${pictogram}`} />\n      </svg>\n    );\n  }),\n);\n"],"names":["React","forwardRef","memo","useEffect","useRef","classNames","RenderIfValueIsTruthy","style","pictogramIds","AppointmentsPictogram","props","ref","Pictogram","pictogram","pictogramProps","AppointmentsAltPictogram","Assessment1Pictogram","Assessment2Pictogram","BloodBankPictogram","CardiologyPictogram","CtScanPictogram","DentistryPictogram","EmergencyDepartmentPictogram","FacilityPictogram","GeriatricsPictogram","GynaecologyPictogram","InPatientPictogram","LaboratoryPictogram","Labs2Pictogram","ObstetricsPictogram","PatientSearchPictogram","PatientsPictogram","PaymentsDeskPictogram","PharmacyPictogram","Pharmacy2Pictogram","RegistrationPictogram","ServiceQueuesPictogram","StockManagementPictogram","TransferPictogram","TriagePictogram","XrayPictogram","HomePictogram","PatientListsPictogram","MaybePictogram","fallback","iconRef","document","getElementById","container","callback","mutationList","mutation","type","current","observer","MutationObserver","observe","childList","disconnect","value","Object","assign","size","className","console","error","svg","height","width","use","href"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/src/pictograms/pictograms.tsx\n");
989
989
 
990
990
  /***/ }),
991
991
 
@@ -1135,7 +1135,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
1135
1135
  \*************************************************************************************************/
1136
1136
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
1137
1137
 
1138
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ WorkspaceContainer: () => (/* binding */ WorkspaceContainer)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var react_i18next__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react-i18next */ \"webpack/sharing/consume/default/react-i18next/react-i18next\");\n/* harmony import */ var react_i18next__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react_i18next__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! classnames */ \"../../../node_modules/classnames/index.js\");\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @carbon/react */ \"webpack/sharing/consume/default/@carbon/react/@carbon/react\");\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_carbon_react__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var _carbon_react_icons__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! @carbon/react/icons */ \"../../../node_modules/@carbon/icons-react/es/generated/bucket-11.js\");\n/* harmony import */ var _carbon_react_icons__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! @carbon/react/icons */ \"../../../node_modules/@carbon/icons-react/es/generated/bucket-6.js\");\n/* harmony import */ var _openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @openmrs/esm-react-utils */ \"../../framework/esm-react-utils/dist/index.js\");\n/* harmony import */ var _openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @openmrs/esm-translations */ \"../../framework/esm-translations/dist/index.js\");\n/* harmony import */ var _icons__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../../icons */ \"../../framework/esm-styleguide/src/icons/index.ts\");\n/* harmony import */ var _notification_workspace_notification_component__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../notification/workspace-notification.component */ \"../../framework/esm-styleguide/src/workspaces/notification/workspace-notification.component.tsx\");\n/* harmony import */ var _workspaces__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../workspaces */ \"../../framework/esm-styleguide/src/workspaces/workspaces.ts\");\n/* harmony import */ var _workspace_renderer_component__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./workspace-renderer.component */ \"../../framework/esm-styleguide/src/workspaces/container/workspace-renderer.component.tsx\");\n/* harmony import */ var _action_menu_component__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./action-menu.component */ \"../../framework/esm-styleguide/src/workspaces/container/action-menu.component.tsx\");\n/* harmony import */ var _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./workspace.module.scss */ \"../../framework/esm-styleguide/src/workspaces/container/workspace.module.scss\");\nfunction _define_property(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\nfunction _object_spread(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = arguments[i] != null ? arguments[i] : {};\n var ownKeys = Object.keys(source);\n if (typeof Object.getOwnPropertySymbols === \"function\") {\n ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {\n return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n }));\n }\n ownKeys.forEach(function(key) {\n _define_property(target, key, source[key]);\n });\n }\n return target;\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n/**\n * Use this component to render the [workspace window](https://zeroheight.com/23a080e38/p/483a22-workspace)\n * in an app such as the patient chart, or a workspace overlay in an app such as the clinic dashboard.\n * This allows workspaces to be opened on the page where this component is mounted. This component\n * must not be mounted multiple times on the same page. If there are multiple apps on a page, only\n * one of those apps should use this component—it \"hosts\" the workspaces.\n *\n * Workspaces may be opened with the [[launchWorkspace]] function from `@openmrs/esm-framework`\n * (among other options).\n *\n * The `overlay` prop determines whether the workspace is rendered as an overlay or a window.\n * When a workspace window is opened, the other content on the screen will be pushed to the left.\n * When an overlay is opened, it will cover other content on the screen.\n *\n * The context key is a string that appears in the URL, which defines the pages on which workspaces\n * are valid. If the URL changes in a way such that it no longer contains the context key, then\n * all workspaces will be closed. This ensures that, for example, workspaces on the home page do\n * not stay open when the user transitions to the patient dashboard; and also that workspaces do\n * not stay open when the user navigates to a different patient. The context key must be a valid\n * sub-path of the URL, with no initial or trailing slash. So if the URL is\n * `https://example.com/patient/123/foo`, then `patient` and `patient/123` and `123/foo` are valid\n * context keys, but `patient/12` and `pati` are not.\n *\n * An extension slot is provided in the workspace header. Its name is derived from the `featureName` of\n * the top-level component in which it is defined (feature names are generally provided in the lifecycle\n * functions in an app's `index.ts` file). The slot is named `workspace-header-${featureName}-slot`.\n * For the patient chart, this is `workspace-header-patient-chart-slot`.\n *\n * This component also provides the [Siderail and Bottom Nav](https://zeroheight.com/23a080e38/p/948cf1-siderail-and-bottom-nav/b/86907e).\n * To use this, pass the `showSiderailAndBottomNav` prop. The Siderail is rendered on the right side of the screen\n * on desktop, and the Bottom Nav is rendered at the bottom of the screen on tablet or mobile. The sidebar/bottom-nav\n * menu provides an extension slot, to which buttons are attached as extensions. The slot\n * derives its name from the `featureName` of the top-level component in which this `WorkspaceContainer`\n * appears (feature names are generally provided in the lifecycle functions in an app's `index.ts` file).\n * The slot is named `action-menu-${featureName}-items-slot`. For the patient chart, this is\n * `action-menu-patient-chart-items-slot`.\n *\n * This component also provides everything needed for workspace notifications to be rendered.\n *\n * @param props.contextKey The context key (explained above)\n * @param props.additionalWorkspaceProps Additional props to pass to the workspace. Using this is\n * unusual; you will generally want to pass props to the workspace when you open it, using\n * `launchWorkspace`. Use this only for props that will apply to every workspace launched\n * on the page where this component is mounted.\n */ function WorkspaceContainer(param) {\n var contextKey = param.contextKey, overlay = param.overlay, showSiderailAndBottomNav = param.showSiderailAndBottomNav, additionalWorkspaceProps = param.additionalWorkspaceProps, actionMenuProps = param.actionMenuProps;\n var layout = (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.useLayoutType)();\n var _useWorkspaces = (0,_workspaces__WEBPACK_IMPORTED_MODULE_8__.useWorkspaces)(), workspaces = _useWorkspaces.workspaces, workspaceWindowState = _useWorkspaces.workspaceWindowState, workspaceGroup = _useWorkspaces.workspaceGroup;\n var currentGroupName = workspaceGroup === null || workspaceGroup === void 0 ? void 0 : workspaceGroup.name;\n var activeWorkspace = workspaces[0];\n var isHidden = workspaceWindowState === 'hidden' || activeWorkspace == null;\n var isMaximized = workspaceWindowState === 'maximized';\n var _activeWorkspace_width;\n var width = (_activeWorkspace_width = activeWorkspace === null || activeWorkspace === void 0 ? void 0 : activeWorkspace.width) !== null && _activeWorkspace_width !== void 0 ? _activeWorkspace_width : overlay ? 'wider' : 'narrow';\n var showActionMenu = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function() {\n return showSiderailAndBottomNav || currentGroupName && !isHidden;\n }, [\n currentGroupName,\n isHidden,\n showSiderailAndBottomNav\n ]);\n (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.useBodyScrollLock)(!isHidden && !(0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.isDesktop)(layout));\n var _obj, _obj1;\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement((react__WEBPACK_IMPORTED_MODULE_0___default().Fragment), null, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: showSiderailAndBottomNav ? _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceContainerWithActionMenu : _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceContainerWithoutActionMenu\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"aside\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()(overlay ? _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceOverlayOuterContainer : _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceWindowSpacer, (_obj = {}, _define_property(_obj, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].hiddenRelative, isHidden), _define_property(_obj, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].narrowWorkspace, width === 'narrow'), _define_property(_obj, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].widerWorkspace, width === 'wider'), _define_property(_obj, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].extraWideWorkspace, width === 'extra-wide'), _obj))\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()(_workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceFixedContainer, (_obj1 = {}, _define_property(_obj1, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].maximizedWindow, isMaximized), _define_property(_obj1, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].hiddenFixed, isHidden), _obj1))\n }, workspaces.map(function(workspace, i) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n key: \"workspace-container-\".concat(workspace ? workspace.name : \"empty-\".concat(i)),\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()(_workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceInnerContainer, _define_property({}, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].hiddenExtraWorkspace, i !== 0))\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(react__WEBPACK_IMPORTED_MODULE_0__.Suspense, {\n fallback: null\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(react_i18next__WEBPACK_IMPORTED_MODULE_1__.I18nextProvider, {\n i18n: window.i18next,\n defaultNS: workspace.moduleName\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Workspace, {\n workspaceInstance: workspace,\n additionalWorkspaceProps: additionalWorkspaceProps\n }))));\n }))), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_notification_workspace_notification_component__WEBPACK_IMPORTED_MODULE_7__.WorkspaceNotification, {\n contextKey: contextKey\n })), showActionMenu && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_action_menu_component__WEBPACK_IMPORTED_MODULE_10__[\"default\"], {\n name: currentGroupName,\n isWithinWorkspace: !showSiderailAndBottomNav,\n actionMenuProps: actionMenuProps\n }));\n}\nfunction Workspace(param) {\n var workspaceInstance = param.workspaceInstance, additionalWorkspaceProps = param.additionalWorkspaceProps;\n var t = (0,react_i18next__WEBPACK_IMPORTED_MODULE_1__.useTranslation)().t;\n var layout = (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.useLayoutType)();\n var _useWorkspaces = (0,_workspaces__WEBPACK_IMPORTED_MODULE_8__.useWorkspaces)(), workspaceWindowState = _useWorkspaces.workspaceWindowState, workspaceGroup = _useWorkspaces.workspaceGroup;\n var currentGroupName = workspaceGroup === null || workspaceGroup === void 0 ? void 0 : workspaceGroup.name;\n var isMaximized = workspaceWindowState === 'maximized';\n // Translate the workspace title\n // The workspace title is a translation key whose translation resides in the workspace module.\n // Since the workspace module is not loaded at the time of workspace registration, we need to translate it here\n // when the workspace is actually rendered and the workspace module along with its translations are loaded.\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function() {\n var translatedTitle = t(workspaceInstance.title);\n if (translatedTitle !== workspaceInstance.title) {\n workspaceInstance.setTitle(translatedTitle);\n }\n }, [\n workspaceInstance.title,\n t,\n workspaceInstance.setTitle\n ]);\n // We use the feature name of the app containing the workspace in order to set the extension\n // slot name. We can't use contextKey for this because we don't want the slot name to be\n // different for different patients, but we do want it to be different for different apps.\n var featureName = (0,react__WEBPACK_IMPORTED_MODULE_0__.useContext)(_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.ComponentContext).featureName;\n var toggleWindowState = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function() {\n (0,_workspaces__WEBPACK_IMPORTED_MODULE_8__.updateWorkspaceWindowState)(isMaximized ? 'normal' : 'maximized');\n }, [\n isMaximized\n ]);\n var _useMemo = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function() {\n return workspaceInstance !== null && workspaceInstance !== void 0 ? workspaceInstance : {};\n }, [\n workspaceInstance\n ]), _useMemo_canHide = _useMemo.canHide, canHide = _useMemo_canHide === void 0 ? false : _useMemo_canHide, _useMemo_canMaximize = _useMemo.canMaximize, canMaximize = _useMemo_canMaximize === void 0 ? false : _useMemo_canMaximize, _useMemo_currentWorkspaceGroup = _useMemo.currentWorkspaceGroup, currentWorkspaceGroup = _useMemo_currentWorkspaceGroup === void 0 ? '' : _useMemo_currentWorkspaceGroup, closeWorkspace = _useMemo.closeWorkspace;\n var workspaceProps = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function() {\n return _object_spread({}, additionalWorkspaceProps, workspaceInstance === null || workspaceInstance === void 0 ? void 0 : workspaceInstance.additionalProps);\n }, [\n additionalWorkspaceProps,\n workspaceInstance\n ]);\n var _workspaceInstance_titleNode;\n return workspaceInstance && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement((react__WEBPACK_IMPORTED_MODULE_0___default().Fragment), null, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.Header, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('workspaceHeader', 'Workspace Header'),\n className: _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].header\n }, !(0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.isDesktop)(layout) && !canHide && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderMenuButton, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('close', 'Close'),\n renderMenuIcon: /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_icons__WEBPACK_IMPORTED_MODULE_6__.ArrowLeftIcon, null),\n onClick: function() {\n return closeWorkspace();\n }\n }), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderName, {\n prefix: \"\"\n }, (_workspaceInstance_titleNode = workspaceInstance.titleNode) !== null && _workspaceInstance_titleNode !== void 0 ? _workspaceInstance_titleNode : t(workspaceInstance.title)), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].overlayHeaderSpacer\n }), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderGlobalBar, {\n className: _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].headerButtons\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.ExtensionSlot, {\n name: \"workspace-header-group-\".concat(workspaceInstance.currentWorkspaceGroup, \"-slot\"),\n state: workspaceProps\n }), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.ExtensionSlot, {\n name: \"workspace-header-type-\".concat(workspaceInstance.type, \"-slot\"),\n state: workspaceProps\n }), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.ExtensionSlot, {\n name: \"workspace-header-\".concat(featureName, \"-slot\"),\n state: workspaceProps\n }), (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.isDesktop)(layout) && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement((react__WEBPACK_IMPORTED_MODULE_0___default().Fragment), null, (canMaximize || isMaximized) && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderGlobalAction, {\n \"aria-label\": isMaximized ? (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('minimize', 'Minimize') : (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('maximize', 'Maximize'),\n onClick: toggleWindowState\n }, isMaximized ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react_icons__WEBPACK_IMPORTED_MODULE_12__.Minimize, null) : /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react_icons__WEBPACK_IMPORTED_MODULE_12__.Maximize, null)), canHide && !currentGroupName ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderGlobalAction, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('hide', 'Hide'),\n onClick: function() {\n return (0,_workspaces__WEBPACK_IMPORTED_MODULE_8__.updateWorkspaceWindowState)('hidden');\n }\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_icons__WEBPACK_IMPORTED_MODULE_6__.ArrowRightIcon, null)) : /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderGlobalAction, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('close', 'Close'),\n onClick: function() {\n return closeWorkspace === null || closeWorkspace === void 0 ? void 0 : closeWorkspace();\n }\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_icons__WEBPACK_IMPORTED_MODULE_6__.CloseIcon, null))), layout === 'tablet' && canHide && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderGlobalAction, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('close', 'Close'),\n onClick: function() {\n return closeWorkspace === null || closeWorkspace === void 0 ? void 0 : closeWorkspace();\n }\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react_icons__WEBPACK_IMPORTED_MODULE_13__.DownToBottom, null)))), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()(_workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceContent, _define_property({}, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].marginWorkspaceContent, Boolean(currentWorkspaceGroup)))\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_workspace_renderer_component__WEBPACK_IMPORTED_MODULE_9__.WorkspaceRenderer, {\n key: workspaceInstance.name,\n workspace: workspaceInstance,\n additionalPropsFromPage: additionalWorkspaceProps\n })));\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-styleguide/src/workspaces/container/workspace-container.component.tsx","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-styleguide/src/workspaces/container/workspace-container.component.tsx?ea3f"],"sourcesContent":["import React, { type ReactNode, Suspense, useCallback, useContext, useEffect, useMemo } from 'react';\nimport { I18nextProvider, useTranslation } from 'react-i18next';\nimport classNames from 'classnames';\nimport { Header, HeaderGlobalAction, HeaderGlobalBar, HeaderMenuButton, HeaderName } from '@carbon/react';\nimport { DownToBottom, Maximize, Minimize } from '@carbon/react/icons';\nimport { ComponentContext, ExtensionSlot, isDesktop, useBodyScrollLock, useLayoutType } from '@openmrs/esm-react-utils';\nimport { getCoreTranslation } from '@openmrs/esm-translations';\nimport { ArrowLeftIcon, ArrowRightIcon, CloseIcon } from '../../icons';\nimport { WorkspaceNotification } from '../notification/workspace-notification.component';\nimport { type OpenWorkspace, updateWorkspaceWindowState, useWorkspaces } from '../workspaces';\nimport { WorkspaceRenderer } from './workspace-renderer.component';\nimport ActionMenu from './action-menu.component';\nimport styles from './workspace.module.scss';\n\nexport interface WorkspaceContainerProps {\n  contextKey: string;\n  overlay?: boolean;\n  showSiderailAndBottomNav?: boolean;\n  additionalWorkspaceProps?: object;\n  actionMenuProps?: Record<string, unknown>;\n}\n\n/**\n * Use this component to render the [workspace window](https://zeroheight.com/23a080e38/p/483a22-workspace)\n * in an app such as the patient chart, or a workspace overlay in an app such as the clinic dashboard.\n * This allows workspaces to be opened on the page where this component is mounted. This component\n * must not be mounted multiple times on the same page. If there are multiple apps on a page, only\n * one of those apps should use this component—it \"hosts\" the workspaces.\n *\n * Workspaces may be opened with the [[launchWorkspace]] function from `@openmrs/esm-framework`\n * (among other options).\n *\n * The `overlay` prop determines whether the workspace is rendered as an overlay or a window.\n * When a workspace window is opened, the other content on the screen will be pushed to the left.\n * When an overlay is opened, it will cover other content on the screen.\n *\n * The context key is a string that appears in the URL, which defines the pages on which workspaces\n * are valid. If the URL changes in a way such that it no longer contains the context key, then\n * all workspaces will be closed. This ensures that, for example, workspaces on the home page do\n * not stay open when the user transitions to the patient dashboard; and also that workspaces do\n * not stay open when the user navigates to a different patient. The context key must be a valid\n * sub-path of the URL, with no initial or trailing slash. So if the URL is\n * `https://example.com/patient/123/foo`, then `patient` and `patient/123` and `123/foo` are valid\n * context keys, but `patient/12` and `pati` are not.\n *\n * An extension slot is provided in the workspace header. Its name is derived from the `featureName` of\n * the top-level component in which it is defined (feature names are generally provided in the lifecycle\n * functions in an app's `index.ts` file). The slot is named `workspace-header-${featureName}-slot`.\n * For the patient chart, this is `workspace-header-patient-chart-slot`.\n *\n * This component also provides the [Siderail and Bottom Nav](https://zeroheight.com/23a080e38/p/948cf1-siderail-and-bottom-nav/b/86907e).\n * To use this, pass the `showSiderailAndBottomNav` prop. The Siderail is rendered on the right side of the screen\n * on desktop, and the Bottom Nav is rendered at the bottom of the screen on tablet or mobile. The sidebar/bottom-nav\n * menu provides an extension slot, to which buttons are attached as extensions. The slot\n * derives its name from the `featureName` of the top-level component in which this `WorkspaceContainer`\n * appears (feature names are generally provided in the lifecycle functions in an app's `index.ts` file).\n * The slot is named `action-menu-${featureName}-items-slot`. For the patient chart, this is\n * `action-menu-patient-chart-items-slot`.\n *\n * This component also provides everything needed for workspace notifications to be rendered.\n *\n * @param props.contextKey The context key (explained above)\n * @param props.additionalWorkspaceProps Additional props to pass to the workspace. Using this is\n *          unusual; you will generally want to pass props to the workspace when you open it, using\n *          `launchWorkspace`. Use this only for props that will apply to every workspace launched\n *          on the page where this component is mounted.\n */\nexport function WorkspaceContainer({\n  contextKey,\n  overlay,\n  showSiderailAndBottomNav,\n  additionalWorkspaceProps,\n  actionMenuProps,\n}: WorkspaceContainerProps) {\n  const layout = useLayoutType();\n  const { workspaces, workspaceWindowState, workspaceGroup } = useWorkspaces();\n  const currentGroupName = workspaceGroup?.name;\n  const activeWorkspace = workspaces[0];\n  const isHidden = workspaceWindowState === 'hidden' || activeWorkspace == null;\n  const isMaximized = workspaceWindowState === 'maximized';\n  const width = activeWorkspace?.width ?? (overlay ? 'wider' : 'narrow');\n  const showActionMenu = useMemo(\n    () => showSiderailAndBottomNav || (currentGroupName && !isHidden),\n    [currentGroupName, isHidden, showSiderailAndBottomNav],\n  );\n\n  useBodyScrollLock(!isHidden && !isDesktop(layout));\n\n  return (\n    <>\n      <div\n        className={\n          showSiderailAndBottomNav\n            ? styles.workspaceContainerWithActionMenu\n            : styles.workspaceContainerWithoutActionMenu\n        }\n      >\n        <aside\n          className={classNames(overlay ? styles.workspaceOverlayOuterContainer : styles.workspaceWindowSpacer, {\n            [styles.hiddenRelative]: isHidden,\n            [styles.narrowWorkspace]: width === 'narrow',\n            [styles.widerWorkspace]: width === 'wider',\n            [styles.extraWideWorkspace]: width === 'extra-wide',\n          })}\n        >\n          <div\n            className={classNames(styles.workspaceFixedContainer, {\n              [styles.maximizedWindow]: isMaximized,\n              [styles.hiddenFixed]: isHidden,\n            })}\n          >\n            {workspaces.map((workspace, i) => (\n              <div\n                key={`workspace-container-${workspace ? workspace.name : `empty-${i}`}`}\n                className={classNames(styles.workspaceInnerContainer, { [styles.hiddenExtraWorkspace]: i !== 0 })}\n              >\n                <Suspense fallback={null}>\n                  <I18nextProvider i18n={window.i18next} defaultNS={workspace.moduleName}>\n                    <Workspace workspaceInstance={workspace} additionalWorkspaceProps={additionalWorkspaceProps} />\n                  </I18nextProvider>\n                </Suspense>\n              </div>\n            ))}\n          </div>\n        </aside>\n        <WorkspaceNotification contextKey={contextKey} />\n      </div>\n      {showActionMenu && (\n        <ActionMenu\n          name={currentGroupName}\n          isWithinWorkspace={!showSiderailAndBottomNav}\n          actionMenuProps={actionMenuProps}\n        />\n      )}\n    </>\n  );\n}\n\ninterface WorkspaceProps {\n  workspaceInstance: OpenWorkspace;\n  additionalWorkspaceProps?: object;\n}\n\nfunction Workspace({ workspaceInstance, additionalWorkspaceProps }: WorkspaceProps) {\n  const { t } = useTranslation();\n  const layout = useLayoutType();\n  const { workspaceWindowState, workspaceGroup } = useWorkspaces();\n  const currentGroupName = workspaceGroup?.name;\n  const isMaximized = workspaceWindowState === 'maximized';\n\n  // Translate the workspace title\n  // The workspace title is a translation key whose translation resides in the workspace module.\n  // Since the workspace module is not loaded at the time of workspace registration, we need to translate it here\n  // when the workspace is actually rendered and the workspace module along with its translations are loaded.\n  useEffect(() => {\n    const translatedTitle = t(workspaceInstance.title);\n    if (translatedTitle !== workspaceInstance.title) {\n      workspaceInstance.setTitle(translatedTitle);\n    }\n  }, [workspaceInstance.title, t, workspaceInstance.setTitle]);\n\n  // We use the feature name of the app containing the workspace in order to set the extension\n  // slot name. We can't use contextKey for this because we don't want the slot name to be\n  // different for different patients, but we do want it to be different for different apps.\n  const { featureName } = useContext(ComponentContext);\n\n  const toggleWindowState = useCallback(() => {\n    updateWorkspaceWindowState(isMaximized ? 'normal' : 'maximized');\n  }, [isMaximized]);\n\n  const {\n    canHide = false,\n    canMaximize = false,\n    currentWorkspaceGroup = '',\n    closeWorkspace,\n  } = useMemo(() => workspaceInstance ?? ({} as OpenWorkspace), [workspaceInstance]);\n\n  const workspaceProps = useMemo(\n    () => ({\n      ...additionalWorkspaceProps,\n      ...workspaceInstance?.additionalProps,\n    }),\n    [additionalWorkspaceProps, workspaceInstance],\n  );\n\n  return (\n    workspaceInstance && (\n      <>\n        <Header aria-label={getCoreTranslation('workspaceHeader', 'Workspace Header')} className={styles.header}>\n          {!isDesktop(layout) && !canHide && (\n            <HeaderMenuButton\n              aria-label={getCoreTranslation('close', 'Close')}\n              renderMenuIcon={<ArrowLeftIcon />}\n              onClick={() => closeWorkspace()}\n            />\n          )}\n          <HeaderName prefix=\"\">{workspaceInstance.titleNode ?? (t(workspaceInstance.title) as ReactNode)}</HeaderName>\n          <div className={styles.overlayHeaderSpacer} />\n          <HeaderGlobalBar className={styles.headerButtons}>\n            <ExtensionSlot\n              name={`workspace-header-group-${workspaceInstance.currentWorkspaceGroup}-slot`}\n              state={workspaceProps}\n            />\n            <ExtensionSlot name={`workspace-header-type-${workspaceInstance.type}-slot`} state={workspaceProps} />\n            <ExtensionSlot name={`workspace-header-${featureName}-slot`} state={workspaceProps} />\n            {isDesktop(layout) && (\n              <>\n                {(canMaximize || isMaximized) && (\n                  <HeaderGlobalAction\n                    aria-label={\n                      isMaximized\n                        ? getCoreTranslation('minimize', 'Minimize')\n                        : getCoreTranslation('maximize', 'Maximize')\n                    }\n                    onClick={toggleWindowState}\n                  >\n                    {isMaximized ? <Minimize /> : <Maximize />}\n                  </HeaderGlobalAction>\n                )}\n                {canHide && !currentGroupName ? (\n                  <HeaderGlobalAction\n                    aria-label={getCoreTranslation('hide', 'Hide')}\n                    onClick={() => updateWorkspaceWindowState('hidden')}\n                  >\n                    <ArrowRightIcon />\n                  </HeaderGlobalAction>\n                ) : (\n                  <HeaderGlobalAction\n                    aria-label={getCoreTranslation('close', 'Close')}\n                    onClick={() => closeWorkspace?.()}\n                  >\n                    <CloseIcon />\n                  </HeaderGlobalAction>\n                )}\n              </>\n            )}\n            {layout === 'tablet' && canHide && (\n              <HeaderGlobalAction aria-label={getCoreTranslation('close', 'Close')} onClick={() => closeWorkspace?.()}>\n                <DownToBottom />\n              </HeaderGlobalAction>\n            )}\n          </HeaderGlobalBar>\n        </Header>\n        <div\n          className={classNames(styles.workspaceContent, {\n            [styles.marginWorkspaceContent]: Boolean(currentWorkspaceGroup),\n          })}\n        >\n          <WorkspaceRenderer\n            key={workspaceInstance.name}\n            workspace={workspaceInstance}\n            additionalPropsFromPage={additionalWorkspaceProps}\n          />\n        </div>\n      </>\n    )\n  );\n}\n"],"names":["React","Suspense","useCallback","useContext","useEffect","useMemo","I18nextProvider","useTranslation","classNames","Header","HeaderGlobalAction","HeaderGlobalBar","HeaderMenuButton","HeaderName","DownToBottom","Maximize","Minimize","ComponentContext","ExtensionSlot","isDesktop","useBodyScrollLock","useLayoutType","getCoreTranslation","ArrowLeftIcon","ArrowRightIcon","CloseIcon","WorkspaceNotification","updateWorkspaceWindowState","useWorkspaces","WorkspaceRenderer","ActionMenu","styles","WorkspaceContainer","contextKey","overlay","showSiderailAndBottomNav","additionalWorkspaceProps","actionMenuProps","layout","workspaces","workspaceWindowState","workspaceGroup","currentGroupName","name","activeWorkspace","isHidden","isMaximized","width","showActionMenu","div","className","workspaceContainerWithActionMenu","workspaceContainerWithoutActionMenu","aside","workspaceOverlayOuterContainer","workspaceWindowSpacer","hiddenRelative","narrowWorkspace","widerWorkspace","extraWideWorkspace","workspaceFixedContainer","maximizedWindow","hiddenFixed","map","workspace","i","key","workspaceInnerContainer","hiddenExtraWorkspace","fallback","i18n","window","i18next","defaultNS","moduleName","Workspace","workspaceInstance","isWithinWorkspace","t","translatedTitle","title","setTitle","featureName","toggleWindowState","canHide","canMaximize","currentWorkspaceGroup","closeWorkspace","workspaceProps","additionalProps","aria-label","header","renderMenuIcon","onClick","prefix","titleNode","overlayHeaderSpacer","headerButtons","state","type","workspaceContent","marginWorkspaceContent","Boolean","additionalPropsFromPage"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/src/workspaces/container/workspace-container.component.tsx\n");
1138
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ WorkspaceContainer: () => (/* binding */ WorkspaceContainer)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var react_i18next__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react-i18next */ \"webpack/sharing/consume/default/react-i18next/react-i18next\");\n/* harmony import */ var react_i18next__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react_i18next__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! classnames */ \"../../../node_modules/classnames/index.js\");\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @carbon/react */ \"webpack/sharing/consume/default/@carbon/react/@carbon/react\");\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_carbon_react__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var _carbon_react_icons__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! @carbon/react/icons */ \"../../../node_modules/@carbon/icons-react/es/generated/bucket-11.js\");\n/* harmony import */ var _carbon_react_icons__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! @carbon/react/icons */ \"../../../node_modules/@carbon/icons-react/es/generated/bucket-6.js\");\n/* harmony import */ var _openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @openmrs/esm-react-utils */ \"../../framework/esm-react-utils/dist/index.js\");\n/* harmony import */ var _openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @openmrs/esm-translations */ \"../../framework/esm-translations/dist/index.js\");\n/* harmony import */ var _icons__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../../icons */ \"../../framework/esm-styleguide/src/icons/index.ts\");\n/* harmony import */ var _notification_workspace_notification_component__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../notification/workspace-notification.component */ \"../../framework/esm-styleguide/src/workspaces/notification/workspace-notification.component.tsx\");\n/* harmony import */ var _workspaces__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../workspaces */ \"../../framework/esm-styleguide/src/workspaces/workspaces.ts\");\n/* harmony import */ var _workspace_renderer_component__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./workspace-renderer.component */ \"../../framework/esm-styleguide/src/workspaces/container/workspace-renderer.component.tsx\");\n/* harmony import */ var _action_menu_component__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./action-menu.component */ \"../../framework/esm-styleguide/src/workspaces/container/action-menu.component.tsx\");\n/* harmony import */ var _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./workspace.module.scss */ \"../../framework/esm-styleguide/src/workspaces/container/workspace.module.scss\");\nfunction _define_property(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\nfunction _object_spread(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = arguments[i] != null ? arguments[i] : {};\n var ownKeys = Object.keys(source);\n if (typeof Object.getOwnPropertySymbols === \"function\") {\n ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {\n return Object.getOwnPropertyDescriptor(source, sym).enumerable;\n }));\n }\n ownKeys.forEach(function(key) {\n _define_property(target, key, source[key]);\n });\n }\n return target;\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n/**\n * Use this component to render the [workspace window](https://zeroheight.com/23a080e38/p/483a22-workspace)\n * in an app such as the patient chart, or a workspace overlay in an app such as the clinic dashboard.\n * This allows workspaces to be opened on the page where this component is mounted. This component\n * must not be mounted multiple times on the same page. If there are multiple apps on a page, only\n * one of those apps should use this component—it \"hosts\" the workspaces.\n *\n * Workspaces may be opened with the [[launchWorkspace]] function from `@openmrs/esm-framework`\n * (among other options).\n *\n * The `overlay` prop determines whether the workspace is rendered as an overlay or a window.\n * When a workspace window is opened, the other content on the screen will be pushed to the left.\n * When an overlay is opened, it will cover other content on the screen.\n *\n * The context key is a string that appears in the URL, which defines the pages on which workspaces\n * are valid. If the URL changes in a way such that it no longer contains the context key, then\n * all workspaces will be closed. This ensures that, for example, workspaces on the home page do\n * not stay open when the user transitions to the patient dashboard; and also that workspaces do\n * not stay open when the user navigates to a different patient. The context key must be a valid\n * sub-path of the URL, with no initial or trailing slash. So if the URL is\n * `https://example.com/patient/123/foo`, then `patient` and `patient/123` and `123/foo` are valid\n * context keys, but `patient/12` and `pati` are not.\n *\n * An extension slot is provided in the workspace header. Its name is derived from the `featureName` of\n * the top-level component in which it is defined (feature names are generally provided in the lifecycle\n * functions in an app's `index.ts` file). The slot is named `workspace-header-${featureName}-slot`.\n * For the patient chart, this is `workspace-header-patient-chart-slot`.\n *\n * This component also provides the [Siderail and Bottom Nav](https://zeroheight.com/23a080e38/p/948cf1-siderail-and-bottom-nav/b/86907e).\n * To use this, pass the `showSiderailAndBottomNav` prop. The Siderail is rendered on the right side of the screen\n * on desktop, and the Bottom Nav is rendered at the bottom of the screen on tablet or mobile. The sidebar/bottom-nav\n * menu provides an extension slot, to which buttons are attached as extensions. The slot\n * derives its name from the `featureName` of the top-level component in which this `WorkspaceContainer`\n * appears (feature names are generally provided in the lifecycle functions in an app's `index.ts` file).\n * The slot is named `action-menu-${featureName}-items-slot`. For the patient chart, this is\n * `action-menu-patient-chart-items-slot`.\n *\n * This component also provides everything needed for workspace notifications to be rendered.\n */ function WorkspaceContainer(param) {\n var contextKey = param.contextKey, overlay = param.overlay, showSiderailAndBottomNav = param.showSiderailAndBottomNav, additionalWorkspaceProps = param.additionalWorkspaceProps, actionMenuProps = param.actionMenuProps;\n var layout = (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.useLayoutType)();\n var _useWorkspaces = (0,_workspaces__WEBPACK_IMPORTED_MODULE_8__.useWorkspaces)(), workspaces = _useWorkspaces.workspaces, workspaceWindowState = _useWorkspaces.workspaceWindowState, workspaceGroup = _useWorkspaces.workspaceGroup;\n var currentGroupName = workspaceGroup === null || workspaceGroup === void 0 ? void 0 : workspaceGroup.name;\n var activeWorkspace = workspaces[0];\n var isHidden = workspaceWindowState === 'hidden' || activeWorkspace == null;\n var isMaximized = workspaceWindowState === 'maximized';\n var _activeWorkspace_width;\n var width = (_activeWorkspace_width = activeWorkspace === null || activeWorkspace === void 0 ? void 0 : activeWorkspace.width) !== null && _activeWorkspace_width !== void 0 ? _activeWorkspace_width : overlay ? 'wider' : 'narrow';\n var showActionMenu = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function() {\n return showSiderailAndBottomNav || currentGroupName && !isHidden;\n }, [\n currentGroupName,\n isHidden,\n showSiderailAndBottomNav\n ]);\n (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.useBodyScrollLock)(!isHidden && !(0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.isDesktop)(layout));\n var _obj, _obj1;\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement((react__WEBPACK_IMPORTED_MODULE_0___default().Fragment), null, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: showSiderailAndBottomNav ? _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceContainerWithActionMenu : _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceContainerWithoutActionMenu\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"aside\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()(overlay ? _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceOverlayOuterContainer : _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceWindowSpacer, (_obj = {}, _define_property(_obj, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].hiddenRelative, isHidden), _define_property(_obj, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].narrowWorkspace, width === 'narrow'), _define_property(_obj, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].widerWorkspace, width === 'wider'), _define_property(_obj, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].extraWideWorkspace, width === 'extra-wide'), _obj))\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()(_workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceFixedContainer, (_obj1 = {}, _define_property(_obj1, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].maximizedWindow, isMaximized), _define_property(_obj1, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].hiddenFixed, isHidden), _obj1))\n }, workspaces.map(function(workspace, i) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n key: \"workspace-container-\".concat(workspace ? workspace.name : \"empty-\".concat(i)),\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()(_workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceInnerContainer, _define_property({}, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].hiddenExtraWorkspace, i !== 0))\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(react__WEBPACK_IMPORTED_MODULE_0__.Suspense, {\n fallback: null\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(react_i18next__WEBPACK_IMPORTED_MODULE_1__.I18nextProvider, {\n i18n: window.i18next,\n defaultNS: workspace.moduleName\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(Workspace, {\n workspaceInstance: workspace,\n additionalWorkspaceProps: additionalWorkspaceProps\n }))));\n }))), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_notification_workspace_notification_component__WEBPACK_IMPORTED_MODULE_7__.WorkspaceNotification, {\n contextKey: contextKey\n })), showActionMenu && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_action_menu_component__WEBPACK_IMPORTED_MODULE_10__[\"default\"], {\n name: currentGroupName,\n isWithinWorkspace: !showSiderailAndBottomNav,\n actionMenuProps: actionMenuProps\n }));\n}\nfunction Workspace(param) {\n var workspaceInstance = param.workspaceInstance, additionalWorkspaceProps = param.additionalWorkspaceProps;\n var t = (0,react_i18next__WEBPACK_IMPORTED_MODULE_1__.useTranslation)().t;\n var layout = (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.useLayoutType)();\n var _useWorkspaces = (0,_workspaces__WEBPACK_IMPORTED_MODULE_8__.useWorkspaces)(), workspaceWindowState = _useWorkspaces.workspaceWindowState, workspaceGroup = _useWorkspaces.workspaceGroup;\n var currentGroupName = workspaceGroup === null || workspaceGroup === void 0 ? void 0 : workspaceGroup.name;\n var isMaximized = workspaceWindowState === 'maximized';\n // Translate the workspace title\n // The workspace title is a translation key whose translation resides in the workspace module.\n // Since the workspace module is not loaded at the time of workspace registration, we need to translate it here\n // when the workspace is actually rendered and the workspace module along with its translations are loaded.\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function() {\n var translatedTitle = t(workspaceInstance.title);\n if (translatedTitle !== workspaceInstance.title) {\n workspaceInstance.setTitle(translatedTitle);\n }\n }, [\n workspaceInstance.title,\n t,\n workspaceInstance.setTitle\n ]);\n // We use the feature name of the app containing the workspace in order to set the extension\n // slot name. We can't use contextKey for this because we don't want the slot name to be\n // different for different patients, but we do want it to be different for different apps.\n var featureName = (0,react__WEBPACK_IMPORTED_MODULE_0__.useContext)(_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.ComponentContext).featureName;\n var toggleWindowState = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function() {\n (0,_workspaces__WEBPACK_IMPORTED_MODULE_8__.updateWorkspaceWindowState)(isMaximized ? 'normal' : 'maximized');\n }, [\n isMaximized\n ]);\n var _useMemo = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function() {\n return workspaceInstance !== null && workspaceInstance !== void 0 ? workspaceInstance : {};\n }, [\n workspaceInstance\n ]), _useMemo_canHide = _useMemo.canHide, canHide = _useMemo_canHide === void 0 ? false : _useMemo_canHide, _useMemo_canMaximize = _useMemo.canMaximize, canMaximize = _useMemo_canMaximize === void 0 ? false : _useMemo_canMaximize, _useMemo_currentWorkspaceGroup = _useMemo.currentWorkspaceGroup, currentWorkspaceGroup = _useMemo_currentWorkspaceGroup === void 0 ? '' : _useMemo_currentWorkspaceGroup, closeWorkspace = _useMemo.closeWorkspace;\n var workspaceProps = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function() {\n return _object_spread({}, additionalWorkspaceProps, workspaceInstance === null || workspaceInstance === void 0 ? void 0 : workspaceInstance.additionalProps);\n }, [\n additionalWorkspaceProps,\n workspaceInstance\n ]);\n var _workspaceInstance_titleNode;\n return workspaceInstance && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement((react__WEBPACK_IMPORTED_MODULE_0___default().Fragment), null, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.Header, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('workspaceHeader', 'Workspace Header'),\n className: _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].header\n }, !(0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.isDesktop)(layout) && !canHide && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderMenuButton, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('close', 'Close'),\n renderMenuIcon: /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_icons__WEBPACK_IMPORTED_MODULE_6__.ArrowLeftIcon, null),\n onClick: function() {\n return closeWorkspace();\n }\n }), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderName, {\n prefix: \"\"\n }, (_workspaceInstance_titleNode = workspaceInstance.titleNode) !== null && _workspaceInstance_titleNode !== void 0 ? _workspaceInstance_titleNode : t(workspaceInstance.title)), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].overlayHeaderSpacer\n }), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderGlobalBar, {\n className: _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].headerButtons\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.ExtensionSlot, {\n name: \"workspace-header-group-\".concat(workspaceInstance.currentWorkspaceGroup, \"-slot\"),\n state: workspaceProps\n }), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.ExtensionSlot, {\n name: \"workspace-header-type-\".concat(workspaceInstance.type, \"-slot\"),\n state: workspaceProps\n }), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.ExtensionSlot, {\n name: \"workspace-header-\".concat(featureName, \"-slot\"),\n state: workspaceProps\n }), (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_4__.isDesktop)(layout) && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement((react__WEBPACK_IMPORTED_MODULE_0___default().Fragment), null, (canMaximize || isMaximized) && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderGlobalAction, {\n \"aria-label\": isMaximized ? (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('minimize', 'Minimize') : (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('maximize', 'Maximize'),\n onClick: toggleWindowState\n }, isMaximized ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react_icons__WEBPACK_IMPORTED_MODULE_12__.Minimize, null) : /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react_icons__WEBPACK_IMPORTED_MODULE_12__.Maximize, null)), canHide && !currentGroupName ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderGlobalAction, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('hide', 'Hide'),\n onClick: function() {\n return (0,_workspaces__WEBPACK_IMPORTED_MODULE_8__.updateWorkspaceWindowState)('hidden');\n }\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_icons__WEBPACK_IMPORTED_MODULE_6__.ArrowRightIcon, null)) : /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderGlobalAction, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('close', 'Close'),\n onClick: function() {\n return closeWorkspace === null || closeWorkspace === void 0 ? void 0 : closeWorkspace();\n }\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_icons__WEBPACK_IMPORTED_MODULE_6__.CloseIcon, null))), layout === 'tablet' && canHide && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_3__.HeaderGlobalAction, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_5__.getCoreTranslation)('close', 'Close'),\n onClick: function() {\n return closeWorkspace === null || closeWorkspace === void 0 ? void 0 : closeWorkspace();\n }\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react_icons__WEBPACK_IMPORTED_MODULE_13__.DownToBottom, null)))), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_2___default()(_workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].workspaceContent, _define_property({}, _workspace_module_scss__WEBPACK_IMPORTED_MODULE_11__[\"default\"].marginWorkspaceContent, Boolean(currentWorkspaceGroup)))\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_workspace_renderer_component__WEBPACK_IMPORTED_MODULE_9__.WorkspaceRenderer, {\n key: workspaceInstance.name,\n workspace: workspaceInstance,\n additionalPropsFromPage: additionalWorkspaceProps\n })));\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-styleguide/src/workspaces/container/workspace-container.component.tsx","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-styleguide/src/workspaces/container/workspace-container.component.tsx?ea3f"],"sourcesContent":["import React, { type ReactNode, Suspense, useCallback, useContext, useEffect, useMemo } from 'react';\nimport { I18nextProvider, useTranslation } from 'react-i18next';\nimport classNames from 'classnames';\nimport { Header, HeaderGlobalAction, HeaderGlobalBar, HeaderMenuButton, HeaderName } from '@carbon/react';\nimport { DownToBottom, Maximize, Minimize } from '@carbon/react/icons';\nimport { ComponentContext, ExtensionSlot, isDesktop, useBodyScrollLock, useLayoutType } from '@openmrs/esm-react-utils';\nimport { getCoreTranslation } from '@openmrs/esm-translations';\nimport { ArrowLeftIcon, ArrowRightIcon, CloseIcon } from '../../icons';\nimport { WorkspaceNotification } from '../notification/workspace-notification.component';\nimport { type OpenWorkspace, updateWorkspaceWindowState, useWorkspaces } from '../workspaces';\nimport { WorkspaceRenderer } from './workspace-renderer.component';\nimport ActionMenu from './action-menu.component';\nimport styles from './workspace.module.scss';\n\nexport interface WorkspaceContainerProps {\n  /**\n   * The context key is a path element that identifies the pages on which workspaces should\n   * appear. Defined to ensure workspaces do not stay open when navigating between pages.\n   * Must be a valid sub-path of the URL, with no initial or trailing slash.\n   */\n  contextKey: string;\n  /** When true, renders the workspace as an overlay instead of a side panel window. */\n  overlay?: boolean;\n  /** When true, renders the Siderail (desktop) or Bottom Nav (tablet/mobile) action menu. */\n  showSiderailAndBottomNav?: boolean;\n  /**\n   * Additional props to pass to the workspace. Using this is unusual; you will generally\n   * want to pass props to the workspace when you open it using `launchWorkspace`. Use this\n   * only for props that will apply to every workspace launched on the page where this\n   * component is mounted.\n   */\n  additionalWorkspaceProps?: object;\n  /** Props to pass to the action menu component. */\n  actionMenuProps?: Record<string, unknown>;\n}\n\n/**\n * Use this component to render the [workspace window](https://zeroheight.com/23a080e38/p/483a22-workspace)\n * in an app such as the patient chart, or a workspace overlay in an app such as the clinic dashboard.\n * This allows workspaces to be opened on the page where this component is mounted. This component\n * must not be mounted multiple times on the same page. If there are multiple apps on a page, only\n * one of those apps should use this component—it \"hosts\" the workspaces.\n *\n * Workspaces may be opened with the [[launchWorkspace]] function from `@openmrs/esm-framework`\n * (among other options).\n *\n * The `overlay` prop determines whether the workspace is rendered as an overlay or a window.\n * When a workspace window is opened, the other content on the screen will be pushed to the left.\n * When an overlay is opened, it will cover other content on the screen.\n *\n * The context key is a string that appears in the URL, which defines the pages on which workspaces\n * are valid. If the URL changes in a way such that it no longer contains the context key, then\n * all workspaces will be closed. This ensures that, for example, workspaces on the home page do\n * not stay open when the user transitions to the patient dashboard; and also that workspaces do\n * not stay open when the user navigates to a different patient. The context key must be a valid\n * sub-path of the URL, with no initial or trailing slash. So if the URL is\n * `https://example.com/patient/123/foo`, then `patient` and `patient/123` and `123/foo` are valid\n * context keys, but `patient/12` and `pati` are not.\n *\n * An extension slot is provided in the workspace header. Its name is derived from the `featureName` of\n * the top-level component in which it is defined (feature names are generally provided in the lifecycle\n * functions in an app's `index.ts` file). The slot is named `workspace-header-${featureName}-slot`.\n * For the patient chart, this is `workspace-header-patient-chart-slot`.\n *\n * This component also provides the [Siderail and Bottom Nav](https://zeroheight.com/23a080e38/p/948cf1-siderail-and-bottom-nav/b/86907e).\n * To use this, pass the `showSiderailAndBottomNav` prop. The Siderail is rendered on the right side of the screen\n * on desktop, and the Bottom Nav is rendered at the bottom of the screen on tablet or mobile. The sidebar/bottom-nav\n * menu provides an extension slot, to which buttons are attached as extensions. The slot\n * derives its name from the `featureName` of the top-level component in which this `WorkspaceContainer`\n * appears (feature names are generally provided in the lifecycle functions in an app's `index.ts` file).\n * The slot is named `action-menu-${featureName}-items-slot`. For the patient chart, this is\n * `action-menu-patient-chart-items-slot`.\n *\n * This component also provides everything needed for workspace notifications to be rendered.\n */\nexport function WorkspaceContainer({\n  contextKey,\n  overlay,\n  showSiderailAndBottomNav,\n  additionalWorkspaceProps,\n  actionMenuProps,\n}: WorkspaceContainerProps) {\n  const layout = useLayoutType();\n  const { workspaces, workspaceWindowState, workspaceGroup } = useWorkspaces();\n  const currentGroupName = workspaceGroup?.name;\n  const activeWorkspace = workspaces[0];\n  const isHidden = workspaceWindowState === 'hidden' || activeWorkspace == null;\n  const isMaximized = workspaceWindowState === 'maximized';\n  const width = activeWorkspace?.width ?? (overlay ? 'wider' : 'narrow');\n  const showActionMenu = useMemo(\n    () => showSiderailAndBottomNav || (currentGroupName && !isHidden),\n    [currentGroupName, isHidden, showSiderailAndBottomNav],\n  );\n\n  useBodyScrollLock(!isHidden && !isDesktop(layout));\n\n  return (\n    <>\n      <div\n        className={\n          showSiderailAndBottomNav\n            ? styles.workspaceContainerWithActionMenu\n            : styles.workspaceContainerWithoutActionMenu\n        }\n      >\n        <aside\n          className={classNames(overlay ? styles.workspaceOverlayOuterContainer : styles.workspaceWindowSpacer, {\n            [styles.hiddenRelative]: isHidden,\n            [styles.narrowWorkspace]: width === 'narrow',\n            [styles.widerWorkspace]: width === 'wider',\n            [styles.extraWideWorkspace]: width === 'extra-wide',\n          })}\n        >\n          <div\n            className={classNames(styles.workspaceFixedContainer, {\n              [styles.maximizedWindow]: isMaximized,\n              [styles.hiddenFixed]: isHidden,\n            })}\n          >\n            {workspaces.map((workspace, i) => (\n              <div\n                key={`workspace-container-${workspace ? workspace.name : `empty-${i}`}`}\n                className={classNames(styles.workspaceInnerContainer, { [styles.hiddenExtraWorkspace]: i !== 0 })}\n              >\n                <Suspense fallback={null}>\n                  <I18nextProvider i18n={window.i18next} defaultNS={workspace.moduleName}>\n                    <Workspace workspaceInstance={workspace} additionalWorkspaceProps={additionalWorkspaceProps} />\n                  </I18nextProvider>\n                </Suspense>\n              </div>\n            ))}\n          </div>\n        </aside>\n        <WorkspaceNotification contextKey={contextKey} />\n      </div>\n      {showActionMenu && (\n        <ActionMenu\n          name={currentGroupName}\n          isWithinWorkspace={!showSiderailAndBottomNav}\n          actionMenuProps={actionMenuProps}\n        />\n      )}\n    </>\n  );\n}\n\ninterface WorkspaceProps {\n  workspaceInstance: OpenWorkspace;\n  additionalWorkspaceProps?: object;\n}\n\nfunction Workspace({ workspaceInstance, additionalWorkspaceProps }: WorkspaceProps) {\n  const { t } = useTranslation();\n  const layout = useLayoutType();\n  const { workspaceWindowState, workspaceGroup } = useWorkspaces();\n  const currentGroupName = workspaceGroup?.name;\n  const isMaximized = workspaceWindowState === 'maximized';\n\n  // Translate the workspace title\n  // The workspace title is a translation key whose translation resides in the workspace module.\n  // Since the workspace module is not loaded at the time of workspace registration, we need to translate it here\n  // when the workspace is actually rendered and the workspace module along with its translations are loaded.\n  useEffect(() => {\n    const translatedTitle = t(workspaceInstance.title);\n    if (translatedTitle !== workspaceInstance.title) {\n      workspaceInstance.setTitle(translatedTitle);\n    }\n  }, [workspaceInstance.title, t, workspaceInstance.setTitle]);\n\n  // We use the feature name of the app containing the workspace in order to set the extension\n  // slot name. We can't use contextKey for this because we don't want the slot name to be\n  // different for different patients, but we do want it to be different for different apps.\n  const { featureName } = useContext(ComponentContext);\n\n  const toggleWindowState = useCallback(() => {\n    updateWorkspaceWindowState(isMaximized ? 'normal' : 'maximized');\n  }, [isMaximized]);\n\n  const {\n    canHide = false,\n    canMaximize = false,\n    currentWorkspaceGroup = '',\n    closeWorkspace,\n  } = useMemo(() => workspaceInstance ?? ({} as OpenWorkspace), [workspaceInstance]);\n\n  const workspaceProps = useMemo(\n    () => ({\n      ...additionalWorkspaceProps,\n      ...workspaceInstance?.additionalProps,\n    }),\n    [additionalWorkspaceProps, workspaceInstance],\n  );\n\n  return (\n    workspaceInstance && (\n      <>\n        <Header aria-label={getCoreTranslation('workspaceHeader', 'Workspace Header')} className={styles.header}>\n          {!isDesktop(layout) && !canHide && (\n            <HeaderMenuButton\n              aria-label={getCoreTranslation('close', 'Close')}\n              renderMenuIcon={<ArrowLeftIcon />}\n              onClick={() => closeWorkspace()}\n            />\n          )}\n          <HeaderName prefix=\"\">{workspaceInstance.titleNode ?? (t(workspaceInstance.title) as ReactNode)}</HeaderName>\n          <div className={styles.overlayHeaderSpacer} />\n          <HeaderGlobalBar className={styles.headerButtons}>\n            <ExtensionSlot\n              name={`workspace-header-group-${workspaceInstance.currentWorkspaceGroup}-slot`}\n              state={workspaceProps}\n            />\n            <ExtensionSlot name={`workspace-header-type-${workspaceInstance.type}-slot`} state={workspaceProps} />\n            <ExtensionSlot name={`workspace-header-${featureName}-slot`} state={workspaceProps} />\n            {isDesktop(layout) && (\n              <>\n                {(canMaximize || isMaximized) && (\n                  <HeaderGlobalAction\n                    aria-label={\n                      isMaximized\n                        ? getCoreTranslation('minimize', 'Minimize')\n                        : getCoreTranslation('maximize', 'Maximize')\n                    }\n                    onClick={toggleWindowState}\n                  >\n                    {isMaximized ? <Minimize /> : <Maximize />}\n                  </HeaderGlobalAction>\n                )}\n                {canHide && !currentGroupName ? (\n                  <HeaderGlobalAction\n                    aria-label={getCoreTranslation('hide', 'Hide')}\n                    onClick={() => updateWorkspaceWindowState('hidden')}\n                  >\n                    <ArrowRightIcon />\n                  </HeaderGlobalAction>\n                ) : (\n                  <HeaderGlobalAction\n                    aria-label={getCoreTranslation('close', 'Close')}\n                    onClick={() => closeWorkspace?.()}\n                  >\n                    <CloseIcon />\n                  </HeaderGlobalAction>\n                )}\n              </>\n            )}\n            {layout === 'tablet' && canHide && (\n              <HeaderGlobalAction aria-label={getCoreTranslation('close', 'Close')} onClick={() => closeWorkspace?.()}>\n                <DownToBottom />\n              </HeaderGlobalAction>\n            )}\n          </HeaderGlobalBar>\n        </Header>\n        <div\n          className={classNames(styles.workspaceContent, {\n            [styles.marginWorkspaceContent]: Boolean(currentWorkspaceGroup),\n          })}\n        >\n          <WorkspaceRenderer\n            key={workspaceInstance.name}\n            workspace={workspaceInstance}\n            additionalPropsFromPage={additionalWorkspaceProps}\n          />\n        </div>\n      </>\n    )\n  );\n}\n"],"names":["React","Suspense","useCallback","useContext","useEffect","useMemo","I18nextProvider","useTranslation","classNames","Header","HeaderGlobalAction","HeaderGlobalBar","HeaderMenuButton","HeaderName","DownToBottom","Maximize","Minimize","ComponentContext","ExtensionSlot","isDesktop","useBodyScrollLock","useLayoutType","getCoreTranslation","ArrowLeftIcon","ArrowRightIcon","CloseIcon","WorkspaceNotification","updateWorkspaceWindowState","useWorkspaces","WorkspaceRenderer","ActionMenu","styles","WorkspaceContainer","contextKey","overlay","showSiderailAndBottomNav","additionalWorkspaceProps","actionMenuProps","layout","workspaces","workspaceWindowState","workspaceGroup","currentGroupName","name","activeWorkspace","isHidden","isMaximized","width","showActionMenu","div","className","workspaceContainerWithActionMenu","workspaceContainerWithoutActionMenu","aside","workspaceOverlayOuterContainer","workspaceWindowSpacer","hiddenRelative","narrowWorkspace","widerWorkspace","extraWideWorkspace","workspaceFixedContainer","maximizedWindow","hiddenFixed","map","workspace","i","key","workspaceInnerContainer","hiddenExtraWorkspace","fallback","i18n","window","i18next","defaultNS","moduleName","Workspace","workspaceInstance","isWithinWorkspace","t","translatedTitle","title","setTitle","featureName","toggleWindowState","canHide","canMaximize","currentWorkspaceGroup","closeWorkspace","workspaceProps","additionalProps","aria-label","header","renderMenuIcon","onClick","prefix","titleNode","overlayHeaderSpacer","headerButtons","state","type","workspaceContent","marginWorkspaceContent","Boolean","additionalPropsFromPage"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/src/workspaces/container/workspace-container.component.tsx\n");
1139
1139
 
1140
1140
  /***/ }),
1141
1141
 
@@ -1205,7 +1205,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
1205
1205
  \*******************************************************************/
1206
1206
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
1207
1207
 
1208
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ 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");
1208
+ 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 The options for navigating and launching the workspace.\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 The options for navigating and launching the workspace.\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");
1209
1209
 
1210
1210
  /***/ }),
1211
1211
 
@@ -1245,7 +1245,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
1245
1245
  \*******************************************************************************/
1246
1246
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
1247
1247
 
1248
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Workspace2: () => (/* binding */ Workspace2)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! classnames */ \"../../../node_modules/classnames/index.js\");\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @carbon/react */ \"webpack/sharing/consume/default/@carbon/react/@carbon/react\");\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_carbon_react__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _carbon_react_icons__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! @carbon/react/icons */ \"../../../node_modules/@carbon/icons-react/es/generated/bucket-11.js\");\n/* harmony import */ var _carbon_react_icons__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! @carbon/react/icons */ \"../../../node_modules/@carbon/icons-react/es/generated/bucket-6.js\");\n/* harmony import */ var _openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @openmrs/esm-react-utils */ \"../../framework/esm-react-utils/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_extensions__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @openmrs/esm-extensions */ \"../../framework/esm-extensions/dist/index.js\");\n/* harmony import */ var _icons__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../icons */ \"../../framework/esm-styleguide/src/icons/index.ts\");\n/* harmony import */ var _workspace2__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./workspace2 */ \"../../framework/esm-styleguide/src/workspaces2/workspace2.ts\");\n/* harmony import */ var _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./workspace2.module.scss */ \"../../framework/esm-styleguide/src/workspaces2/workspace2.module.scss\");\nfunction _define_property(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\n\n\n\n\n\n\n\n\n\n\n/**\n * The Workspace2 component is used as a top-level container to render\n * its children as content within a workspace. When creating a workspace\n * component, `<Workspace2>` should be the top-level component returned,\n * wrapping all of the workspace content.\n * @experimental\n */ var Workspace2 = function(param) {\n var title = param.title, children = param.children, _param_hasUnsavedChanges = param.hasUnsavedChanges, hasUnsavedChanges = _param_hasUnsavedChanges === void 0 ? false : _param_hasUnsavedChanges;\n var layout = (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_3__.useLayoutType)();\n var _useWorkspace2Store = (0,_workspace2__WEBPACK_IMPORTED_MODULE_7__.useWorkspace2Store)(), setWindowMaximized = _useWorkspace2Store.setWindowMaximized, hideWindow = _useWorkspace2Store.hideWindow, setHasUnsavedChanges = _useWorkspace2Store.setHasUnsavedChanges, openedWindows = _useWorkspace2Store.openedWindows, openedGroup = _useWorkspace2Store.openedGroup, registeredGroupsByName = _useWorkspace2Store.registeredGroupsByName, registeredWindowsByName = _useWorkspace2Store.registeredWindowsByName, registeredWorkspacesByName = _useWorkspace2Store.registeredWorkspacesByName, workspaceTitleByWorkspaceName = _useWorkspace2Store.workspaceTitleByWorkspaceName, setWorkspaceTitle = _useWorkspace2Store.setWorkspaceTitle, isMostRecentlyOpenedWindowHidden = _useWorkspace2Store.isMostRecentlyOpenedWindowHidden;\n var _useWorkspace2Context = (0,_workspace2__WEBPACK_IMPORTED_MODULE_7__.useWorkspace2Context)(), workspaceName = _useWorkspace2Context.workspaceName, isRootWorkspace = _useWorkspace2Context.isRootWorkspace, closeWorkspace = _useWorkspace2Context.closeWorkspace, showActionMenu = _useWorkspace2Context.showActionMenu;\n var openedWindowIndex = (0,_openmrs_esm_extensions__WEBPACK_IMPORTED_MODULE_5__.getOpenedWindowIndexByWorkspace)(workspaceName);\n var openedWindow = openedWindows[openedWindowIndex];\n var openedWorkspace = openedWindow === null || openedWindow === void 0 ? void 0 : openedWindow.openedWorkspaces.find(function(workspace) {\n return workspace.workspaceName === workspaceName;\n });\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function() {\n if ((openedWorkspace === null || openedWorkspace === void 0 ? void 0 : openedWorkspace.hasUnsavedChanges) != hasUnsavedChanges) {\n setHasUnsavedChanges(workspaceName, hasUnsavedChanges !== null && hasUnsavedChanges !== void 0 ? hasUnsavedChanges : false);\n }\n }, [\n openedWorkspace,\n hasUnsavedChanges\n ]);\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function() {\n if (workspaceTitleByWorkspaceName[workspaceName] !== title) {\n setWorkspaceTitle(workspaceName, title);\n }\n }, [\n openedWorkspace,\n title\n ]);\n if (openedWindowIndex < 0 || openedGroup == null || openedWorkspace == null) {\n // workspace window / group has likely just closed\n return null;\n }\n var group = registeredGroupsByName[openedGroup.groupName];\n if (!group) {\n throw new Error(\"Cannot find registered workspace group \".concat(openedGroup.groupName));\n }\n var workspaceDef = registeredWorkspacesByName[workspaceName];\n var windowName = workspaceDef.window;\n var windowDef = registeredWindowsByName[windowName];\n if (!windowDef) {\n throw new Error(\"Cannot find registered workspace window \".concat(windowName));\n }\n var icon = windowDef.icon, canMaximize = windowDef.canMaximize;\n var canCloseGroup = group.persistence === 'closable';\n var canHide = !!icon && !canCloseGroup;\n var maximized = openedWindow.maximized;\n var _windowDef_width;\n var width = (_windowDef_width = windowDef === null || windowDef === void 0 ? void 0 : windowDef.width) !== null && _windowDef_width !== void 0 ? _windowDef_width : 'narrow';\n var isActionMenuOpened = Object.values(registeredWindowsByName).some(function(window) {\n return window.group === openedGroup.groupName && window.icon !== undefined;\n });\n var isWindowHidden = openedWindowIndex < openedWindows.length - 1 || isMostRecentlyOpenedWindowHidden;\n var _obj, _obj1, _obj2;\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(_workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].workspaceOuterContainer, (_obj = {}, _define_property(_obj, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].narrowWorkspace, width === 'narrow'), _define_property(_obj, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].widerWorkspace, width === 'wider'), _define_property(_obj, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].extraWideWorkspace, width === 'extra-wide'), _define_property(_obj, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].isActionMenuOpened, isActionMenuOpened), _obj))\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(_workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].workspaceSpacer, _define_property({}, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].hidden, isWindowHidden))\n }), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(_workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].workspaceMiddleContainer, (_obj1 = {}, _define_property(_obj1, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].maximized, maximized), _define_property(_obj1, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].hidden, isWindowHidden), _define_property(_obj1, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].isRootWorkspace, isRootWorkspace), _define_property(_obj1, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].showActionMenu, showActionMenu), _obj1))\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(_workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].workspaceInnerContainer, (_obj2 = {}, _define_property(_obj2, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].maximized, maximized), _define_property(_obj2, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].hidden, isWindowHidden), _define_property(_obj2, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].isRootWorkspace, isRootWorkspace), _obj2))\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_2__.Header, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('workspaceHeader'),\n className: _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].header\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_2__.HeaderName, {\n prefix: \"\"\n }, title), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].overlayHeaderSpacer\n }), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_2__.HeaderGlobalBar, {\n className: _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].headerButtons\n }, (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_3__.isDesktop)(layout) ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement((react__WEBPACK_IMPORTED_MODULE_0___default().Fragment), null, (canMaximize || maximized) && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_2__.HeaderGlobalAction, {\n \"aria-label\": maximized ? (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('minimize') : (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('maximize'),\n onClick: function() {\n return setWindowMaximized(windowName, !maximized);\n }\n }, maximized ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react_icons__WEBPACK_IMPORTED_MODULE_9__.Minimize, null) : /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react_icons__WEBPACK_IMPORTED_MODULE_9__.Maximize, null)), canHide ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_2__.HeaderGlobalAction, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('hide'),\n onClick: function() {\n return hideWindow();\n }\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_icons__WEBPACK_IMPORTED_MODULE_6__.ArrowRightIcon, null)) : // in desktop mode, if the group is closeable, the close button\n // is rendered in the side nav, not in the workspace\n !canCloseGroup && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_2__.HeaderGlobalAction, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('close'),\n onClick: function() {\n return closeWorkspace({\n closeWindow: true\n });\n }\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_icons__WEBPACK_IMPORTED_MODULE_6__.CloseIcon, null))) : /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement((react__WEBPACK_IMPORTED_MODULE_0___default().Fragment), null, canHide ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_2__.HeaderGlobalAction, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('hide'),\n onClick: function() {\n return hideWindow();\n }\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react_icons__WEBPACK_IMPORTED_MODULE_10__.DownToBottom, null)) : // in tablet mode, the close button is rendered regardless of\n // whether the group is closeable. The close button closes\n // the workspace group (and the side nav) if group is closeable;\n // otherwise it only closes the workspace window.\n /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_2__.HeaderGlobalAction, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('close'),\n onClick: function() {\n if (canCloseGroup) {\n (0,_workspace2__WEBPACK_IMPORTED_MODULE_7__.closeWorkspaceGroup2)();\n } else {\n closeWorkspace({\n closeWindow: true\n });\n }\n }\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_icons__WEBPACK_IMPORTED_MODULE_6__.CloseIcon, null))))), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(_workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].workspaceContent)\n }, children))));\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-styleguide/src/workspaces2/workspace2.component.tsx","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-styleguide/src/workspaces2/workspace2.component.tsx?37f3"],"sourcesContent":["import React, { useEffect, type ReactNode } from 'react';\nimport classNames from 'classnames';\nimport { Header, HeaderGlobalAction, HeaderGlobalBar, HeaderName } from '@carbon/react';\nimport { DownToBottom, Maximize, Minimize } from '@carbon/react/icons';\nimport { isDesktop, useLayoutType } from '@openmrs/esm-react-utils';\nimport { getCoreTranslation } from '@openmrs/esm-translations';\nimport { getOpenedWindowIndexByWorkspace } from '@openmrs/esm-extensions';\nimport { ArrowRightIcon, CloseIcon } from '../icons';\nimport { useWorkspace2Store, useWorkspace2Context, closeWorkspaceGroup2 } from './workspace2';\nimport styles from './workspace2.module.scss';\n\ninterface Workspace2Props {\n  title: string;\n  children: ReactNode;\n  hasUnsavedChanges?: boolean;\n}\n\n/**\n * @experimental\n */\nexport interface Workspace2DefinitionProps<\n  WorkspaceProps extends object = object,\n  WindowProps extends object = object,\n  GroupProps extends object = object,\n> {\n  /**\n   * This function launches a child workspace. Unlike `launchWorkspace()`, this function is meant\n   * to be called from the a workspace, and it does not allow passing (or changing)\n   * the window props or group props\n   * @param workspaceName\n   * @param workspaceProps\n   */\n  launchChildWorkspace<Props extends object>(workspaceName: string, workspaceProps?: Props): void;\n\n  /**\n   * closes the current workspace, along with its children.\n   * @param closeWindow If true, the workspace's window, along with all workspaces within it, will be closed as well\n   * @param discardUnsavedChanges If true, the \"unsaved changes\" modal will be supressed, and the value of `hasUnsavedChanges` will be ignored. Use this when closing the workspace immediately after changes are saved.\n   * @returns a Promise that resolves to true if the workspace is closed, false otherwise.\n   */\n  closeWorkspace(options?: { closeWindow?: boolean; discardUnsavedChanges?: boolean }): Promise<boolean>;\n\n  workspaceProps: WorkspaceProps | null;\n  windowProps: WindowProps | null;\n  groupProps: GroupProps | null;\n  workspaceName: string;\n  windowName: string;\n  isRootWorkspace: boolean;\n  showActionMenu: boolean;\n}\n\n/**\n * @experimental\n */\nexport type Workspace2Definition<\n  WorkspaceProps extends object,\n  WindowProps extends object,\n  GroupProps extends object,\n> = React.FC<Workspace2DefinitionProps<WorkspaceProps, WindowProps, GroupProps>>;\n\n/**\n * The Workspace2 component is used as a top-level container to render\n * its children as content within a workspace. When creating a workspace\n * component, `<Workspace2>` should be the top-level component returned,\n * wrapping all of the workspace content.\n * @experimental\n */\nexport const Workspace2: React.FC<Workspace2Props> = ({ title, children, hasUnsavedChanges = false }) => {\n  const layout = useLayoutType();\n  const {\n    setWindowMaximized,\n    hideWindow,\n    setHasUnsavedChanges,\n    openedWindows,\n    openedGroup,\n    registeredGroupsByName,\n    registeredWindowsByName,\n    registeredWorkspacesByName,\n    workspaceTitleByWorkspaceName,\n    setWorkspaceTitle,\n    isMostRecentlyOpenedWindowHidden,\n  } = useWorkspace2Store();\n  const { workspaceName, isRootWorkspace, closeWorkspace, showActionMenu } = useWorkspace2Context();\n\n  const openedWindowIndex = getOpenedWindowIndexByWorkspace(workspaceName);\n\n  const openedWindow = openedWindows[openedWindowIndex];\n  const openedWorkspace = openedWindow?.openedWorkspaces.find((workspace) => workspace.workspaceName === workspaceName);\n\n  useEffect(() => {\n    if (openedWorkspace?.hasUnsavedChanges != hasUnsavedChanges) {\n      setHasUnsavedChanges(workspaceName, hasUnsavedChanges ?? false);\n    }\n  }, [openedWorkspace, hasUnsavedChanges]);\n\n  useEffect(() => {\n    if (workspaceTitleByWorkspaceName[workspaceName] !== title) {\n      setWorkspaceTitle(workspaceName, title);\n    }\n  }, [openedWorkspace, title]);\n\n  if (openedWindowIndex < 0 || openedGroup == null || openedWorkspace == null) {\n    // workspace window / group has likely just closed\n    return null;\n  }\n\n  const group = registeredGroupsByName[openedGroup.groupName];\n  if (!group) {\n    throw new Error(`Cannot find registered workspace group ${openedGroup.groupName}`);\n  }\n  const workspaceDef = registeredWorkspacesByName[workspaceName];\n  const windowName = workspaceDef.window;\n  const windowDef = registeredWindowsByName[windowName];\n  if (!windowDef) {\n    throw new Error(`Cannot find registered workspace window ${windowName}`);\n  }\n\n  const { icon, canMaximize } = windowDef;\n  const canCloseGroup = group.persistence === 'closable';\n  const canHide = !!icon && !canCloseGroup;\n  const { maximized } = openedWindow;\n  const width = windowDef?.width ?? 'narrow';\n\n  const isActionMenuOpened = Object.values(registeredWindowsByName).some(\n    (window) => window.group === openedGroup.groupName && window.icon !== undefined,\n  );\n\n  const isWindowHidden = openedWindowIndex < openedWindows.length - 1 || isMostRecentlyOpenedWindowHidden;\n\n  return (\n    <div\n      className={classNames(styles.workspaceOuterContainer, {\n        [styles.narrowWorkspace]: width === 'narrow',\n        [styles.widerWorkspace]: width === 'wider',\n        [styles.extraWideWorkspace]: width === 'extra-wide',\n        [styles.isActionMenuOpened]: isActionMenuOpened,\n      })}\n    >\n      <div\n        className={classNames(styles.workspaceSpacer, {\n          [styles.hidden]: isWindowHidden,\n        })}\n      />\n      <div\n        className={classNames(styles.workspaceMiddleContainer, {\n          [styles.maximized]: maximized,\n          [styles.hidden]: isWindowHidden,\n          [styles.isRootWorkspace]: isRootWorkspace,\n          [styles.showActionMenu]: showActionMenu,\n        })}\n      >\n        <div\n          className={classNames(styles.workspaceInnerContainer, {\n            [styles.maximized]: maximized,\n            [styles.hidden]: isWindowHidden,\n            [styles.isRootWorkspace]: isRootWorkspace,\n          })}\n        >\n          <Header aria-label={getCoreTranslation('workspaceHeader')} className={styles.header}>\n            <HeaderName prefix=\"\">{title}</HeaderName>\n            <div className={styles.overlayHeaderSpacer} />\n            <HeaderGlobalBar className={styles.headerButtons}>\n              {isDesktop(layout) ? (\n                <>\n                  {(canMaximize || maximized) && (\n                    <HeaderGlobalAction\n                      aria-label={maximized ? getCoreTranslation('minimize') : getCoreTranslation('maximize')}\n                      onClick={() => setWindowMaximized(windowName, !maximized)}\n                    >\n                      {maximized ? <Minimize /> : <Maximize />}\n                    </HeaderGlobalAction>\n                  )}\n                  {canHide ? (\n                    <HeaderGlobalAction aria-label={getCoreTranslation('hide')} onClick={() => hideWindow()}>\n                      <ArrowRightIcon />\n                    </HeaderGlobalAction>\n                  ) : (\n                    // in desktop mode, if the group is closeable, the close button\n                    // is rendered in the side nav, not in the workspace\n                    !canCloseGroup && (\n                      <HeaderGlobalAction\n                        aria-label={getCoreTranslation('close')}\n                        onClick={() => closeWorkspace({ closeWindow: true })}\n                      >\n                        <CloseIcon />\n                      </HeaderGlobalAction>\n                    )\n                  )}\n                </>\n              ) : (\n                <>\n                  {canHide ? (\n                    <HeaderGlobalAction aria-label={getCoreTranslation('hide')} onClick={() => hideWindow()}>\n                      <DownToBottom />\n                    </HeaderGlobalAction>\n                  ) : (\n                    // in tablet mode, the close button is rendered regardless of\n                    // whether the group is closeable. The close button closes\n                    // the workspace group (and the side nav) if group is closeable;\n                    // otherwise it only closes the workspace window.\n                    <HeaderGlobalAction\n                      aria-label={getCoreTranslation('close')}\n                      onClick={() => {\n                        if (canCloseGroup) {\n                          closeWorkspaceGroup2();\n                        } else {\n                          closeWorkspace({ closeWindow: true });\n                        }\n                      }}\n                    >\n                      <CloseIcon />\n                    </HeaderGlobalAction>\n                  )}\n                </>\n              )}\n            </HeaderGlobalBar>\n          </Header>\n          <div className={classNames(styles.workspaceContent)}>{children}</div>\n        </div>\n      </div>\n    </div>\n  );\n};\n"],"names":["React","useEffect","classNames","Header","HeaderGlobalAction","HeaderGlobalBar","HeaderName","DownToBottom","Maximize","Minimize","isDesktop","useLayoutType","getCoreTranslation","getOpenedWindowIndexByWorkspace","ArrowRightIcon","CloseIcon","useWorkspace2Store","useWorkspace2Context","closeWorkspaceGroup2","styles","Workspace2","title","children","hasUnsavedChanges","layout","setWindowMaximized","hideWindow","setHasUnsavedChanges","openedWindows","openedGroup","registeredGroupsByName","registeredWindowsByName","registeredWorkspacesByName","workspaceTitleByWorkspaceName","setWorkspaceTitle","isMostRecentlyOpenedWindowHidden","workspaceName","isRootWorkspace","closeWorkspace","showActionMenu","openedWindowIndex","openedWindow","openedWorkspace","openedWorkspaces","find","workspace","group","groupName","Error","workspaceDef","windowName","window","windowDef","icon","canMaximize","canCloseGroup","persistence","canHide","maximized","width","isActionMenuOpened","Object","values","some","undefined","isWindowHidden","length","div","className","workspaceOuterContainer","narrowWorkspace","widerWorkspace","extraWideWorkspace","workspaceSpacer","hidden","workspaceMiddleContainer","workspaceInnerContainer","aria-label","header","prefix","overlayHeaderSpacer","headerButtons","onClick","closeWindow","workspaceContent"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/src/workspaces2/workspace2.component.tsx\n");
1248
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Workspace2: () => (/* binding */ Workspace2)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"webpack/sharing/consume/default/react/react\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! classnames */ \"../../../node_modules/classnames/index.js\");\n/* harmony import */ var classnames__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(classnames__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @carbon/react */ \"webpack/sharing/consume/default/@carbon/react/@carbon/react\");\n/* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_carbon_react__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _carbon_react_icons__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! @carbon/react/icons */ \"../../../node_modules/@carbon/icons-react/es/generated/bucket-11.js\");\n/* harmony import */ var _carbon_react_icons__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! @carbon/react/icons */ \"../../../node_modules/@carbon/icons-react/es/generated/bucket-6.js\");\n/* harmony import */ var _openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @openmrs/esm-react-utils */ \"../../framework/esm-react-utils/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_extensions__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @openmrs/esm-extensions */ \"../../framework/esm-extensions/dist/index.js\");\n/* harmony import */ var _icons__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../icons */ \"../../framework/esm-styleguide/src/icons/index.ts\");\n/* harmony import */ var _workspace2__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./workspace2 */ \"../../framework/esm-styleguide/src/workspaces2/workspace2.ts\");\n/* harmony import */ var _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./workspace2.module.scss */ \"../../framework/esm-styleguide/src/workspaces2/workspace2.module.scss\");\nfunction _define_property(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\n\n\n\n\n\n\n\n\n\n\n/**\n * The Workspace2 component is used as a top-level container to render\n * its children as content within a workspace. When creating a workspace\n * component, `<Workspace2>` should be the top-level component returned,\n * wrapping all of the workspace content.\n * @experimental\n */ var Workspace2 = function(param) {\n var title = param.title, children = param.children, _param_hasUnsavedChanges = param.hasUnsavedChanges, hasUnsavedChanges = _param_hasUnsavedChanges === void 0 ? false : _param_hasUnsavedChanges;\n var layout = (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_3__.useLayoutType)();\n var _useWorkspace2Store = (0,_workspace2__WEBPACK_IMPORTED_MODULE_7__.useWorkspace2Store)(), setWindowMaximized = _useWorkspace2Store.setWindowMaximized, hideWindow = _useWorkspace2Store.hideWindow, setHasUnsavedChanges = _useWorkspace2Store.setHasUnsavedChanges, openedWindows = _useWorkspace2Store.openedWindows, openedGroup = _useWorkspace2Store.openedGroup, registeredGroupsByName = _useWorkspace2Store.registeredGroupsByName, registeredWindowsByName = _useWorkspace2Store.registeredWindowsByName, registeredWorkspacesByName = _useWorkspace2Store.registeredWorkspacesByName, workspaceTitleByWorkspaceName = _useWorkspace2Store.workspaceTitleByWorkspaceName, setWorkspaceTitle = _useWorkspace2Store.setWorkspaceTitle, isMostRecentlyOpenedWindowHidden = _useWorkspace2Store.isMostRecentlyOpenedWindowHidden;\n var _useWorkspace2Context = (0,_workspace2__WEBPACK_IMPORTED_MODULE_7__.useWorkspace2Context)(), workspaceName = _useWorkspace2Context.workspaceName, isRootWorkspace = _useWorkspace2Context.isRootWorkspace, closeWorkspace = _useWorkspace2Context.closeWorkspace, showActionMenu = _useWorkspace2Context.showActionMenu;\n var openedWindowIndex = (0,_openmrs_esm_extensions__WEBPACK_IMPORTED_MODULE_5__.getOpenedWindowIndexByWorkspace)(workspaceName);\n var openedWindow = openedWindows[openedWindowIndex];\n var openedWorkspace = openedWindow === null || openedWindow === void 0 ? void 0 : openedWindow.openedWorkspaces.find(function(workspace) {\n return workspace.workspaceName === workspaceName;\n });\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function() {\n if ((openedWorkspace === null || openedWorkspace === void 0 ? void 0 : openedWorkspace.hasUnsavedChanges) != hasUnsavedChanges) {\n setHasUnsavedChanges(workspaceName, hasUnsavedChanges !== null && hasUnsavedChanges !== void 0 ? hasUnsavedChanges : false);\n }\n }, [\n openedWorkspace,\n hasUnsavedChanges\n ]);\n (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function() {\n if (workspaceTitleByWorkspaceName[workspaceName] !== title) {\n setWorkspaceTitle(workspaceName, title);\n }\n }, [\n openedWorkspace,\n title\n ]);\n if (openedWindowIndex < 0 || openedGroup == null || openedWorkspace == null) {\n // workspace window / group has likely just closed\n return null;\n }\n var group = registeredGroupsByName[openedGroup.groupName];\n if (!group) {\n throw new Error(\"Cannot find registered workspace group \".concat(openedGroup.groupName));\n }\n var workspaceDef = registeredWorkspacesByName[workspaceName];\n var windowName = workspaceDef.window;\n var windowDef = registeredWindowsByName[windowName];\n if (!windowDef) {\n throw new Error(\"Cannot find registered workspace window \".concat(windowName));\n }\n var icon = windowDef.icon, canMaximize = windowDef.canMaximize;\n var canCloseGroup = group.persistence === 'closable';\n var canHide = !!icon && !canCloseGroup;\n var maximized = openedWindow.maximized;\n var _windowDef_width;\n var width = (_windowDef_width = windowDef === null || windowDef === void 0 ? void 0 : windowDef.width) !== null && _windowDef_width !== void 0 ? _windowDef_width : 'narrow';\n var isActionMenuOpened = Object.values(registeredWindowsByName).some(function(window) {\n return window.group === openedGroup.groupName && window.icon !== undefined;\n });\n var isWindowHidden = openedWindowIndex < openedWindows.length - 1 || isMostRecentlyOpenedWindowHidden;\n var _obj, _obj1, _obj2;\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(_workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].workspaceOuterContainer, (_obj = {}, _define_property(_obj, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].narrowWorkspace, width === 'narrow'), _define_property(_obj, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].widerWorkspace, width === 'wider'), _define_property(_obj, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].extraWideWorkspace, width === 'extra-wide'), _define_property(_obj, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].isActionMenuOpened, isActionMenuOpened), _obj))\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(_workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].workspaceSpacer, _define_property({}, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].hidden, isWindowHidden))\n }), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(_workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].workspaceMiddleContainer, (_obj1 = {}, _define_property(_obj1, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].maximized, maximized), _define_property(_obj1, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].hidden, isWindowHidden), _define_property(_obj1, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].isRootWorkspace, isRootWorkspace), _define_property(_obj1, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].showActionMenu, showActionMenu), _obj1))\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(_workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].workspaceInnerContainer, (_obj2 = {}, _define_property(_obj2, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].maximized, maximized), _define_property(_obj2, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].hidden, isWindowHidden), _define_property(_obj2, _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].isRootWorkspace, isRootWorkspace), _obj2))\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_2__.Header, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('workspaceHeader'),\n className: _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].header\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_2__.HeaderName, {\n prefix: \"\"\n }, title), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].overlayHeaderSpacer\n }), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_2__.HeaderGlobalBar, {\n className: _workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].headerButtons\n }, (0,_openmrs_esm_react_utils__WEBPACK_IMPORTED_MODULE_3__.isDesktop)(layout) ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement((react__WEBPACK_IMPORTED_MODULE_0___default().Fragment), null, (canMaximize || maximized) && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_2__.HeaderGlobalAction, {\n \"aria-label\": maximized ? (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('minimize') : (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('maximize'),\n onClick: function() {\n return setWindowMaximized(windowName, !maximized);\n }\n }, maximized ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react_icons__WEBPACK_IMPORTED_MODULE_9__.Minimize, null) : /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react_icons__WEBPACK_IMPORTED_MODULE_9__.Maximize, null)), canHide ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_2__.HeaderGlobalAction, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('hide'),\n onClick: function() {\n return hideWindow();\n }\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_icons__WEBPACK_IMPORTED_MODULE_6__.ArrowRightIcon, null)) : // in desktop mode, if the group is closeable, the close button\n // is rendered in the side nav, not in the workspace\n !canCloseGroup && /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_2__.HeaderGlobalAction, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('close'),\n onClick: function() {\n return closeWorkspace({\n closeWindow: true\n });\n }\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_icons__WEBPACK_IMPORTED_MODULE_6__.CloseIcon, null))) : /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement((react__WEBPACK_IMPORTED_MODULE_0___default().Fragment), null, canHide ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_2__.HeaderGlobalAction, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('hide'),\n onClick: function() {\n return hideWindow();\n }\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react_icons__WEBPACK_IMPORTED_MODULE_10__.DownToBottom, null)) : // in tablet mode, the close button is rendered regardless of\n // whether the group is closeable. The close button closes\n // the workspace group (and the side nav) if group is closeable;\n // otherwise it only closes the workspace window.\n /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_2__.HeaderGlobalAction, {\n \"aria-label\": (0,_openmrs_esm_translations__WEBPACK_IMPORTED_MODULE_4__.getCoreTranslation)('close'),\n onClick: function() {\n if (canCloseGroup) {\n (0,_workspace2__WEBPACK_IMPORTED_MODULE_7__.closeWorkspaceGroup2)();\n } else {\n closeWorkspace({\n closeWindow: true\n });\n }\n }\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_icons__WEBPACK_IMPORTED_MODULE_6__.CloseIcon, null))))), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(\"div\", {\n className: classnames__WEBPACK_IMPORTED_MODULE_1___default()(_workspace2_module_scss__WEBPACK_IMPORTED_MODULE_8__[\"default\"].workspaceContent)\n }, children))));\n};\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-styleguide/src/workspaces2/workspace2.component.tsx","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-styleguide/src/workspaces2/workspace2.component.tsx?37f3"],"sourcesContent":["import React, { useEffect, type ReactNode } from 'react';\nimport classNames from 'classnames';\nimport { Header, HeaderGlobalAction, HeaderGlobalBar, HeaderName } from '@carbon/react';\nimport { DownToBottom, Maximize, Minimize } from '@carbon/react/icons';\nimport { isDesktop, useLayoutType } from '@openmrs/esm-react-utils';\nimport { getCoreTranslation } from '@openmrs/esm-translations';\nimport { getOpenedWindowIndexByWorkspace } from '@openmrs/esm-extensions';\nimport { ArrowRightIcon, CloseIcon } from '../icons';\nimport { useWorkspace2Store, useWorkspace2Context, closeWorkspaceGroup2 } from './workspace2';\nimport styles from './workspace2.module.scss';\n\ninterface Workspace2Props {\n  title: string;\n  children: ReactNode;\n  hasUnsavedChanges?: boolean;\n}\n\n/**\n * @experimental\n */\nexport interface Workspace2DefinitionProps<\n  WorkspaceProps extends object = object,\n  WindowProps extends object = object,\n  GroupProps extends object = object,\n> {\n  /**\n   * This function launches a child workspace. Unlike `launchWorkspace()`, this function is meant\n   * to be called from the a workspace, and it does not allow passing (or changing)\n   * the window props or group props\n   * @param workspaceName\n   * @param workspaceProps\n   */\n  launchChildWorkspace<Props extends object>(workspaceName: string, workspaceProps?: Props): void;\n\n  /**\n   * closes the current workspace, along with its children.\n   * @param options Optional configuration for closing the workspace.\n   * @param options.closeWindow If true, the workspace's window, along with all workspaces within it, will be closed as well.\n   * @param options.discardUnsavedChanges If true, the \"unsaved changes\" modal will be suppressed, and the value of `hasUnsavedChanges` will be ignored. Use this when closing the workspace immediately after changes are saved.\n   * @returns a Promise that resolves to true if the workspace is closed, false otherwise.\n   */\n  closeWorkspace(options?: { closeWindow?: boolean; discardUnsavedChanges?: boolean }): Promise<boolean>;\n\n  workspaceProps: WorkspaceProps | null;\n  windowProps: WindowProps | null;\n  groupProps: GroupProps | null;\n  workspaceName: string;\n  windowName: string;\n  isRootWorkspace: boolean;\n  showActionMenu: boolean;\n}\n\n/**\n * @experimental\n */\nexport type Workspace2Definition<\n  WorkspaceProps extends object,\n  WindowProps extends object,\n  GroupProps extends object,\n> = React.FC<Workspace2DefinitionProps<WorkspaceProps, WindowProps, GroupProps>>;\n\n/**\n * The Workspace2 component is used as a top-level container to render\n * its children as content within a workspace. When creating a workspace\n * component, `<Workspace2>` should be the top-level component returned,\n * wrapping all of the workspace content.\n * @experimental\n */\nexport const Workspace2: React.FC<Workspace2Props> = ({ title, children, hasUnsavedChanges = false }) => {\n  const layout = useLayoutType();\n  const {\n    setWindowMaximized,\n    hideWindow,\n    setHasUnsavedChanges,\n    openedWindows,\n    openedGroup,\n    registeredGroupsByName,\n    registeredWindowsByName,\n    registeredWorkspacesByName,\n    workspaceTitleByWorkspaceName,\n    setWorkspaceTitle,\n    isMostRecentlyOpenedWindowHidden,\n  } = useWorkspace2Store();\n  const { workspaceName, isRootWorkspace, closeWorkspace, showActionMenu } = useWorkspace2Context();\n\n  const openedWindowIndex = getOpenedWindowIndexByWorkspace(workspaceName);\n\n  const openedWindow = openedWindows[openedWindowIndex];\n  const openedWorkspace = openedWindow?.openedWorkspaces.find((workspace) => workspace.workspaceName === workspaceName);\n\n  useEffect(() => {\n    if (openedWorkspace?.hasUnsavedChanges != hasUnsavedChanges) {\n      setHasUnsavedChanges(workspaceName, hasUnsavedChanges ?? false);\n    }\n  }, [openedWorkspace, hasUnsavedChanges]);\n\n  useEffect(() => {\n    if (workspaceTitleByWorkspaceName[workspaceName] !== title) {\n      setWorkspaceTitle(workspaceName, title);\n    }\n  }, [openedWorkspace, title]);\n\n  if (openedWindowIndex < 0 || openedGroup == null || openedWorkspace == null) {\n    // workspace window / group has likely just closed\n    return null;\n  }\n\n  const group = registeredGroupsByName[openedGroup.groupName];\n  if (!group) {\n    throw new Error(`Cannot find registered workspace group ${openedGroup.groupName}`);\n  }\n  const workspaceDef = registeredWorkspacesByName[workspaceName];\n  const windowName = workspaceDef.window;\n  const windowDef = registeredWindowsByName[windowName];\n  if (!windowDef) {\n    throw new Error(`Cannot find registered workspace window ${windowName}`);\n  }\n\n  const { icon, canMaximize } = windowDef;\n  const canCloseGroup = group.persistence === 'closable';\n  const canHide = !!icon && !canCloseGroup;\n  const { maximized } = openedWindow;\n  const width = windowDef?.width ?? 'narrow';\n\n  const isActionMenuOpened = Object.values(registeredWindowsByName).some(\n    (window) => window.group === openedGroup.groupName && window.icon !== undefined,\n  );\n\n  const isWindowHidden = openedWindowIndex < openedWindows.length - 1 || isMostRecentlyOpenedWindowHidden;\n\n  return (\n    <div\n      className={classNames(styles.workspaceOuterContainer, {\n        [styles.narrowWorkspace]: width === 'narrow',\n        [styles.widerWorkspace]: width === 'wider',\n        [styles.extraWideWorkspace]: width === 'extra-wide',\n        [styles.isActionMenuOpened]: isActionMenuOpened,\n      })}\n    >\n      <div\n        className={classNames(styles.workspaceSpacer, {\n          [styles.hidden]: isWindowHidden,\n        })}\n      />\n      <div\n        className={classNames(styles.workspaceMiddleContainer, {\n          [styles.maximized]: maximized,\n          [styles.hidden]: isWindowHidden,\n          [styles.isRootWorkspace]: isRootWorkspace,\n          [styles.showActionMenu]: showActionMenu,\n        })}\n      >\n        <div\n          className={classNames(styles.workspaceInnerContainer, {\n            [styles.maximized]: maximized,\n            [styles.hidden]: isWindowHidden,\n            [styles.isRootWorkspace]: isRootWorkspace,\n          })}\n        >\n          <Header aria-label={getCoreTranslation('workspaceHeader')} className={styles.header}>\n            <HeaderName prefix=\"\">{title}</HeaderName>\n            <div className={styles.overlayHeaderSpacer} />\n            <HeaderGlobalBar className={styles.headerButtons}>\n              {isDesktop(layout) ? (\n                <>\n                  {(canMaximize || maximized) && (\n                    <HeaderGlobalAction\n                      aria-label={maximized ? getCoreTranslation('minimize') : getCoreTranslation('maximize')}\n                      onClick={() => setWindowMaximized(windowName, !maximized)}\n                    >\n                      {maximized ? <Minimize /> : <Maximize />}\n                    </HeaderGlobalAction>\n                  )}\n                  {canHide ? (\n                    <HeaderGlobalAction aria-label={getCoreTranslation('hide')} onClick={() => hideWindow()}>\n                      <ArrowRightIcon />\n                    </HeaderGlobalAction>\n                  ) : (\n                    // in desktop mode, if the group is closeable, the close button\n                    // is rendered in the side nav, not in the workspace\n                    !canCloseGroup && (\n                      <HeaderGlobalAction\n                        aria-label={getCoreTranslation('close')}\n                        onClick={() => closeWorkspace({ closeWindow: true })}\n                      >\n                        <CloseIcon />\n                      </HeaderGlobalAction>\n                    )\n                  )}\n                </>\n              ) : (\n                <>\n                  {canHide ? (\n                    <HeaderGlobalAction aria-label={getCoreTranslation('hide')} onClick={() => hideWindow()}>\n                      <DownToBottom />\n                    </HeaderGlobalAction>\n                  ) : (\n                    // in tablet mode, the close button is rendered regardless of\n                    // whether the group is closeable. The close button closes\n                    // the workspace group (and the side nav) if group is closeable;\n                    // otherwise it only closes the workspace window.\n                    <HeaderGlobalAction\n                      aria-label={getCoreTranslation('close')}\n                      onClick={() => {\n                        if (canCloseGroup) {\n                          closeWorkspaceGroup2();\n                        } else {\n                          closeWorkspace({ closeWindow: true });\n                        }\n                      }}\n                    >\n                      <CloseIcon />\n                    </HeaderGlobalAction>\n                  )}\n                </>\n              )}\n            </HeaderGlobalBar>\n          </Header>\n          <div className={classNames(styles.workspaceContent)}>{children}</div>\n        </div>\n      </div>\n    </div>\n  );\n};\n"],"names":["React","useEffect","classNames","Header","HeaderGlobalAction","HeaderGlobalBar","HeaderName","DownToBottom","Maximize","Minimize","isDesktop","useLayoutType","getCoreTranslation","getOpenedWindowIndexByWorkspace","ArrowRightIcon","CloseIcon","useWorkspace2Store","useWorkspace2Context","closeWorkspaceGroup2","styles","Workspace2","title","children","hasUnsavedChanges","layout","setWindowMaximized","hideWindow","setHasUnsavedChanges","openedWindows","openedGroup","registeredGroupsByName","registeredWindowsByName","registeredWorkspacesByName","workspaceTitleByWorkspaceName","setWorkspaceTitle","isMostRecentlyOpenedWindowHidden","workspaceName","isRootWorkspace","closeWorkspace","showActionMenu","openedWindowIndex","openedWindow","openedWorkspace","openedWorkspaces","find","workspace","group","groupName","Error","workspaceDef","windowName","window","windowDef","icon","canMaximize","canCloseGroup","persistence","canHide","maximized","width","isActionMenuOpened","Object","values","some","undefined","isWindowHidden","length","div","className","workspaceOuterContainer","narrowWorkspace","widerWorkspace","extraWideWorkspace","workspaceSpacer","hidden","workspaceMiddleContainer","workspaceInnerContainer","aria-label","header","prefix","overlayHeaderSpacer","headerButtons","onClick","closeWindow","workspaceContent"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/src/workspaces2/workspace2.component.tsx\n");
1249
1249
 
1250
1250
  /***/ }),
1251
1251
 
@@ -1285,7 +1285,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
1285
1285
  \*********************************************************/
1286
1286
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
1287
1287
 
1288
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ convertToLocaleCalendar: () => (/* binding */ convertToLocaleCalendar),\n/* harmony export */ formatDate: () => (/* binding */ formatDate),\n/* harmony export */ formatDatetime: () => (/* binding */ formatDatetime),\n/* harmony export */ formatDuration: () => (/* binding */ formatDuration),\n/* harmony export */ formatPartialDate: () => (/* binding */ formatPartialDate),\n/* harmony export */ formatTime: () => (/* binding */ formatTime),\n/* harmony export */ getDefaultCalendar: () => (/* binding */ getDefaultCalendar),\n/* harmony export */ isOmrsDateStrict: () => (/* binding */ isOmrsDateStrict),\n/* harmony export */ isOmrsDateToday: () => (/* binding */ isOmrsDateToday),\n/* harmony export */ parseDate: () => (/* binding */ parseDate),\n/* harmony export */ registerDefaultCalendar: () => (/* binding */ registerDefaultCalendar),\n/* harmony export */ toDateObjectStrict: () => (/* binding */ toDateObjectStrict),\n/* harmony export */ toOmrsIsoString: () => (/* binding */ toOmrsIsoString)\n/* harmony export */ });\n/* harmony import */ var _internationalized_date__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! @internationalized/date */ \"../../../node_modules/@internationalized/date/dist/conversion.mjs\");\n/* harmony import */ var _internationalized_date__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! @internationalized/date */ \"../../../node_modules/@internationalized/date/dist/createCalendar.mjs\");\n/* harmony import */ var _formatjs_intl_durationformat__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @formatjs/intl-durationformat */ \"../../../node_modules/@formatjs/intl-durationformat/index.js\");\n/* harmony import */ var any_date_parser__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! any-date-parser */ \"../../../node_modules/any-date-parser/dist/index.mjs\");\n/* harmony import */ var dayjs__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! dayjs */ \"webpack/sharing/consume/default/dayjs/dayjs\");\n/* harmony import */ var dayjs_plugin_isToday_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! dayjs/plugin/isToday.js */ \"../../../node_modules/dayjs/plugin/isToday.js\");\n/* harmony import */ var dayjs_plugin_objectSupport_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! dayjs/plugin/objectSupport.js */ \"../../../node_modules/dayjs/plugin/objectSupport.js\");\n/* harmony import */ var dayjs_plugin_utc_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! dayjs/plugin/utc.js */ \"../../../node_modules/dayjs/plugin/utc.js\");\n/* harmony import */ var lodash_es__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! lodash-es */ \"../../../node_modules/lodash-es/isNil.js\");\n/* harmony import */ var lodash_es__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! lodash-es */ \"../../../node_modules/lodash-es/omit.js\");\n/* harmony import */ var _index_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../index.js */ \"../../framework/esm-utils/dist/get-locale.js\");\n/**\n * @module\n * @category Date and Time\n */ function _check_private_redeclaration(obj, privateCollection) {\n if (privateCollection.has(obj)) {\n throw new TypeError(\"Cannot initialize the same private elements twice on an object\");\n }\n}\nfunction _class_apply_descriptor_get(receiver, descriptor) {\n if (descriptor.get) {\n return descriptor.get.call(receiver);\n }\n return descriptor.value;\n}\nfunction _class_extract_field_descriptor(receiver, privateMap, action) {\n if (!privateMap.has(receiver)) {\n throw new TypeError(\"attempted to \" + action + \" private field on non-instance\");\n }\n return privateMap.get(receiver);\n}\nfunction _class_private_field_get(receiver, privateMap) {\n var descriptor = _class_extract_field_descriptor(receiver, privateMap, \"get\");\n return _class_apply_descriptor_get(receiver, descriptor);\n}\nfunction _class_private_field_init(obj, privateMap, value) {\n _check_private_redeclaration(obj, privateMap);\n privateMap.set(obj, value);\n}\n\n\n\n\n\n\n\n\n\ndayjs__WEBPACK_IMPORTED_MODULE_1__.extend(dayjs_plugin_isToday_js__WEBPACK_IMPORTED_MODULE_2__);\ndayjs__WEBPACK_IMPORTED_MODULE_1__.extend(dayjs_plugin_utc_js__WEBPACK_IMPORTED_MODULE_4__);\ndayjs__WEBPACK_IMPORTED_MODULE_1__.extend(dayjs_plugin_objectSupport_js__WEBPACK_IMPORTED_MODULE_3__);\nconst isoFormat = 'YYYY-MM-DDTHH:mm:ss.SSSZZ';\n/**\n * This function checks whether a date string is the OpenMRS ISO format.\n * The format should be YYYY-MM-DDTHH:mm:ss.SSSZZ\n */ function isOmrsDateStrict(omrsPayloadString) {\n // omrs format 2018-03-19T00:00:00.000+0300\n if (omrsPayloadString === null || omrsPayloadString === undefined || omrsPayloadString.trim().length !== 28) {\n return false;\n }\n omrsPayloadString = omrsPayloadString.trim();\n // 11th character will always be T\n if (omrsPayloadString[10] !== 'T') {\n return false;\n }\n // checking time format\n if (omrsPayloadString[13] !== ':' || omrsPayloadString[16] !== ':' || omrsPayloadString[19] !== '.') {\n return false;\n }\n // checking UTC offset format\n if (!(omrsPayloadString[23] === '+' || omrsPayloadString[23] === '-')) {\n return false;\n }\n return dayjs__WEBPACK_IMPORTED_MODULE_1__(omrsPayloadString, isoFormat).isValid();\n}\n/**\n *\n * @param date Checks if the provided date is today.\n */ function isOmrsDateToday(date) {\n return dayjs__WEBPACK_IMPORTED_MODULE_1__(date).isToday();\n}\n/**\n * Converts the object to a date object if it is an OpenMRS ISO date time string.\n * Otherwise returns null.\n */ function toDateObjectStrict(omrsDateString) {\n if (!isOmrsDateStrict(omrsDateString)) {\n return null;\n }\n return dayjs__WEBPACK_IMPORTED_MODULE_1__(omrsDateString, isoFormat).toDate();\n}\n/**\n * Formats the input to OpenMRS ISO format: \"YYYY-MM-DDTHH:mm:ss.SSSZZ\".\n */ function toOmrsIsoString(date, toUTC = false) {\n let d = dayjs__WEBPACK_IMPORTED_MODULE_1__(date);\n if (toUTC) {\n d = d.utc();\n }\n return d.format(isoFormat);\n}\n/**\n * Utility function to parse an arbitrary string into a date.\n * Uses `dayjs(dateString)`.\n */ function parseDate(dateString) {\n return dayjs__WEBPACK_IMPORTED_MODULE_1__(dateString).toDate();\n}\nvar _registry = /*#__PURE__*/ new WeakMap();\n/**\n * Internal cache for per-locale calendars\n */ class LocaleCalendars {\n register(locale, calendar) {\n _class_private_field_get(this, _registry).set(locale, calendar);\n }\n getCalendar(locale) {\n if (!Boolean(locale)) {\n return undefined;\n }\n if (locale.calendar) {\n return locale.calendar;\n }\n if (locale.region) {\n const key = `${locale.language}-${locale.region}`;\n if (_class_private_field_get(this, _registry).has(key)) {\n return _class_private_field_get(this, _registry).get(key);\n }\n }\n if (locale.language && _class_private_field_get(this, _registry).has(locale.language)) {\n return _class_private_field_get(this, _registry).get(locale.language);\n }\n const defaultCalendar = new Intl.DateTimeFormat(locale.toString()).resolvedOptions().calendar;\n // cache this result\n _class_private_field_get(this, _registry).set(`${locale.language}${locale.region ? `-${locale.region}` : ''}`, defaultCalendar);\n return defaultCalendar;\n }\n constructor(){\n _class_private_field_init(this, _registry, {\n writable: true,\n value: new Map()\n });\n }\n}\nconst registeredLocaleCalendars = new LocaleCalendars();\n/**\n * Provides the name of the calendar to associate, as a default, with the given base locale.\n *\n * @example\n * ```\n * registerDefaultCalendar('en', 'buddhist') // sets the default calendar for the 'en' locale to Buddhist.\n * ```\n *\n * @param locale the locale to register this calendar for\n * @param calendar the calendar to use for this registration\n */ function registerDefaultCalendar(locale, calendar) {\n registeredLocaleCalendars.register(locale, calendar);\n}\n/**\n * Retrieves the default calendar for the specified locale if any.\n *\n * @param locale the locale to look-up\n */ function getDefaultCalendar(locale) {\n const locale_ = locale ?? (0,_index_js__WEBPACK_IMPORTED_MODULE_5__.getLocale)();\n return registeredLocaleCalendars.getCalendar(locale_ instanceof Intl.Locale ? locale_ : new Intl.Locale(locale_));\n}\nconst defaultOptions = {\n mode: 'standard',\n time: 'for today',\n day: true,\n month: true,\n year: true,\n noToday: false\n};\n/**\n * Formats the string representing a date, including partial representations of dates, according to the current\n * locale and the given options.\n *\n * Default options:\n * - mode: \"standard\",\n * - time: \"for today\",\n * - day: true,\n * - month: true,\n * - year: true\n * - noToday: false\n *\n * If the date is today then \"Today\" is produced (in the locale language).\n * This behavior can be disabled with `noToday: true`.\n *\n * When time is included, it is appended with a comma and a space. This\n * agrees with the output of `Date.prototype.toLocaleString` for *most*\n * locales.\n */ // TODO: Shouldn't throw on null input\nfunction formatPartialDate(dateString, options = {}) {\n const locale = (0,_index_js__WEBPACK_IMPORTED_MODULE_5__.getLocale)();\n let parsed = (0,any_date_parser__WEBPACK_IMPORTED_MODULE_6__.attempt)(dateString, locale);\n if (parsed.invalid) {\n console.warn(`Could not parse invalid date '${dateString}'`);\n return null;\n }\n // hack here but any date interprets 2000-01, etc. as yyyy-dd rather than yyyy-mm\n if (!(0,lodash_es__WEBPACK_IMPORTED_MODULE_7__[\"default\"])(parsed.day) && (0,lodash_es__WEBPACK_IMPORTED_MODULE_7__[\"default\"])(parsed.month)) {\n parsed = Object.assign({}, (0,lodash_es__WEBPACK_IMPORTED_MODULE_8__[\"default\"])(parsed, 'day'), {\n month: parsed.day\n });\n }\n // dayjs' object support uses 0-based months, whereas any-date-parser uses 1-based months\n if (parsed.month) {\n parsed.month -= 1;\n }\n // in dayjs day is day of week; in any-date-parser, its day of month, so we need to convert them\n if (parsed.day) {\n parsed = Object.assign({}, (0,lodash_es__WEBPACK_IMPORTED_MODULE_8__[\"default\"])(parsed, 'day'), {\n date: parsed.day\n });\n }\n const date = dayjs__WEBPACK_IMPORTED_MODULE_1__().set(parsed).toDate();\n if ((0,lodash_es__WEBPACK_IMPORTED_MODULE_7__[\"default\"])(parsed.year)) {\n options.year = false;\n }\n if ((0,lodash_es__WEBPACK_IMPORTED_MODULE_7__[\"default\"])(parsed.month)) {\n options.month = false;\n }\n if ((0,lodash_es__WEBPACK_IMPORTED_MODULE_7__[\"default\"])(parsed.date)) {\n options.day = false;\n }\n return formatDate(date, options);\n}\n/**\n * Formats the input date according to the current locale and the\n * given options.\n *\n * Default options:\n * - mode: \"standard\",\n * - time: \"for today\",\n * - day: true,\n * - month: true,\n * - year: true\n * - noToday: false\n *\n * If the date is today then \"Today\" is produced (in the locale language).\n * This behavior can be disabled with `noToday: true`.\n *\n * When time is included, it is appended with a comma and a space. This\n * agrees with the output of `Date.prototype.toLocaleString` for *most*\n * locales.\n */ // TODO: Shouldn't throw on null input\nfunction formatDate(date, options) {\n let locale = options?.locale ?? (0,_index_js__WEBPACK_IMPORTED_MODULE_5__.getLocale)();\n const _locale = new Intl.Locale(locale);\n const { calendar, mode, time, day, month, year, noToday, numberingSystem } = {\n ...defaultOptions,\n ...{\n noToday: _locale.language === 'am' ? true : false\n },\n ...options\n };\n const formatCalendar = calendar ?? getDefaultCalendar(_locale);\n const formatterOptions = {\n calendar: formatCalendar,\n year: year ? 'numeric' : undefined,\n month: month ? 'short' : undefined,\n day: day ? '2-digit' : undefined,\n numberingSystem\n };\n let localeString;\n const isToday = dayjs__WEBPACK_IMPORTED_MODULE_1__(date).isToday();\n if (isToday && !noToday) {\n // This produces the word \"Today\" in the language of `locale`\n const rtf = new Intl.RelativeTimeFormat(locale, {\n numeric: 'auto'\n });\n localeString = rtf.format(0, 'day');\n localeString = localeString[0].toLocaleUpperCase(locale) + localeString.slice(1);\n } else {\n if (_locale.language === 'en') {\n // This locale override is here rather than in `getLocale`\n // because Americans should see AM/PM for times.\n locale = 'en-GB';\n }\n const formatter = new Intl.DateTimeFormat(locale, formatterOptions);\n let parts = formatter.formatToParts(date);\n if ((_locale.language === 'en' || _locale.language === 'am') && mode == 'standard' && year && day) {\n // Custom formatting for English and Amharic. Use hyphens instead of spaces.\n parts = parts.map(formatParts('-'));\n }\n if (mode == 'wide') {\n parts = parts.map(formatParts(' — ')); // space-emdash-space\n }\n // omit the era when using the Ethiopic calendar\n if (formatterOptions.calendar === 'ethiopic') {\n parts = parts.filter((part, idx, values)=>{\n if (part.type === 'era' || part.type === 'literal' && idx < values.length - 1 && values[idx + 1].type === 'era') {\n return false;\n }\n return true;\n });\n }\n localeString = parts.map((p)=>p.value).join('');\n }\n if (time === true || isToday && time === 'for today') {\n localeString += `, ${formatTime(date)}`;\n }\n return localeString;\n}\n// Internal curried call-back for map()\nconst formatParts = (separator)=>{\n return (part, idx, values)=>{\n if (part.type !== 'literal' || part.value !== ' ') {\n return part;\n }\n if (idx < values.length - 1 && values[idx + 1].type === 'era') {\n return part;\n }\n return {\n type: 'literal',\n value: separator\n };\n };\n};\n/**\n * Formats the input as a time, according to the current locale.\n * 12-hour or 24-hour clock depends on locale.\n */ function formatTime(date) {\n return date.toLocaleTimeString((0,_index_js__WEBPACK_IMPORTED_MODULE_5__.getLocale)(), {\n hour: '2-digit',\n minute: '2-digit'\n });\n}\n/**\n * Formats the input into a string showing the date and time, according\n * to the current locale. The `mode` parameter is as described for\n * `formatDate`.\n *\n * This is created by concatenating the results of `formatDate`\n * and `formatTime` with a comma and space. This agrees with the\n * output of `Date.prototype.toLocaleString` for *most* locales.\n */ function formatDatetime(date, options) {\n return formatDate(date, {\n ...options,\n time: true\n });\n}\n/**\n * Converts a calendar date to the equivalent locale calendar date.\n * @returns CalendarDate\n */ function convertToLocaleCalendar(date, locale) {\n let locale_ = typeof locale === 'string' ? new Intl.Locale(locale) : locale;\n const localCalendarName = getDefaultCalendar(locale_);\n return localCalendarName ? (0,_internationalized_date__WEBPACK_IMPORTED_MODULE_9__.toCalendar)(date, (0,_internationalized_date__WEBPACK_IMPORTED_MODULE_10__.createCalendar)(localCalendarName)) : date;\n}\n/**\n * Formats the input duration according to the current locale.\n *\n * @param duration The duration to format (DurationInput object).\n * @param options Optional options for formatting.\n * @returns The formatted duration string.\n */ function formatDuration(duration, options) {\n const formatter = new _formatjs_intl_durationformat__WEBPACK_IMPORTED_MODULE_0__.DurationFormat((0,_index_js__WEBPACK_IMPORTED_MODULE_5__.getLocale)(), options);\n return formatter.format(duration);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-utils/dist/dates/date-util.js","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-utils/dist/dates/date-util.js?985f"],"sourcesContent":["/**\n * @module\n * @category Date and Time\n */ function _check_private_redeclaration(obj, privateCollection) {\n    if (privateCollection.has(obj)) {\n        throw new TypeError(\"Cannot initialize the same private elements twice on an object\");\n    }\n}\nfunction _class_apply_descriptor_get(receiver, descriptor) {\n    if (descriptor.get) {\n        return descriptor.get.call(receiver);\n    }\n    return descriptor.value;\n}\nfunction _class_extract_field_descriptor(receiver, privateMap, action) {\n    if (!privateMap.has(receiver)) {\n        throw new TypeError(\"attempted to \" + action + \" private field on non-instance\");\n    }\n    return privateMap.get(receiver);\n}\nfunction _class_private_field_get(receiver, privateMap) {\n    var descriptor = _class_extract_field_descriptor(receiver, privateMap, \"get\");\n    return _class_apply_descriptor_get(receiver, descriptor);\n}\nfunction _class_private_field_init(obj, privateMap, value) {\n    _check_private_redeclaration(obj, privateMap);\n    privateMap.set(obj, value);\n}\nimport { createCalendar, toCalendar } from \"@internationalized/date\";\nimport { DurationFormat } from \"@formatjs/intl-durationformat\";\nimport { attempt } from \"any-date-parser\";\nimport dayjs from \"dayjs\";\nimport isToday from \"dayjs/plugin/isToday.js\";\nimport objectSupport from \"dayjs/plugin/objectSupport.js\";\nimport utc from \"dayjs/plugin/utc.js\";\nimport { isNil, omit } from \"lodash-es\";\nimport { getLocale } from \"../index.js\";\ndayjs.extend(isToday);\ndayjs.extend(utc);\ndayjs.extend(objectSupport);\nconst isoFormat = 'YYYY-MM-DDTHH:mm:ss.SSSZZ';\n/**\n * This function checks whether a date string is the OpenMRS ISO format.\n * The format should be YYYY-MM-DDTHH:mm:ss.SSSZZ\n */ export function isOmrsDateStrict(omrsPayloadString) {\n    // omrs format 2018-03-19T00:00:00.000+0300\n    if (omrsPayloadString === null || omrsPayloadString === undefined || omrsPayloadString.trim().length !== 28) {\n        return false;\n    }\n    omrsPayloadString = omrsPayloadString.trim();\n    // 11th character will always be T\n    if (omrsPayloadString[10] !== 'T') {\n        return false;\n    }\n    // checking time format\n    if (omrsPayloadString[13] !== ':' || omrsPayloadString[16] !== ':' || omrsPayloadString[19] !== '.') {\n        return false;\n    }\n    // checking UTC offset format\n    if (!(omrsPayloadString[23] === '+' || omrsPayloadString[23] === '-')) {\n        return false;\n    }\n    return dayjs(omrsPayloadString, isoFormat).isValid();\n}\n/**\n *\n * @param date Checks if the provided date is today.\n */ export function isOmrsDateToday(date) {\n    return dayjs(date).isToday();\n}\n/**\n * Converts the object to a date object if it is an OpenMRS ISO date time string.\n * Otherwise returns null.\n */ export function toDateObjectStrict(omrsDateString) {\n    if (!isOmrsDateStrict(omrsDateString)) {\n        return null;\n    }\n    return dayjs(omrsDateString, isoFormat).toDate();\n}\n/**\n * Formats the input to OpenMRS ISO format: \"YYYY-MM-DDTHH:mm:ss.SSSZZ\".\n */ export function toOmrsIsoString(date, toUTC = false) {\n    let d = dayjs(date);\n    if (toUTC) {\n        d = d.utc();\n    }\n    return d.format(isoFormat);\n}\n/**\n * Utility function to parse an arbitrary string into a date.\n * Uses `dayjs(dateString)`.\n */ export function parseDate(dateString) {\n    return dayjs(dateString).toDate();\n}\nvar _registry = /*#__PURE__*/ new WeakMap();\n/**\n * Internal cache for per-locale calendars\n */ class LocaleCalendars {\n    register(locale, calendar) {\n        _class_private_field_get(this, _registry).set(locale, calendar);\n    }\n    getCalendar(locale) {\n        if (!Boolean(locale)) {\n            return undefined;\n        }\n        if (locale.calendar) {\n            return locale.calendar;\n        }\n        if (locale.region) {\n            const key = `${locale.language}-${locale.region}`;\n            if (_class_private_field_get(this, _registry).has(key)) {\n                return _class_private_field_get(this, _registry).get(key);\n            }\n        }\n        if (locale.language && _class_private_field_get(this, _registry).has(locale.language)) {\n            return _class_private_field_get(this, _registry).get(locale.language);\n        }\n        const defaultCalendar = new Intl.DateTimeFormat(locale.toString()).resolvedOptions().calendar;\n        // cache this result\n        _class_private_field_get(this, _registry).set(`${locale.language}${locale.region ? `-${locale.region}` : ''}`, defaultCalendar);\n        return defaultCalendar;\n    }\n    constructor(){\n        _class_private_field_init(this, _registry, {\n            writable: true,\n            value: new Map()\n        });\n    }\n}\nconst registeredLocaleCalendars = new LocaleCalendars();\n/**\n * Provides the name of the calendar to associate, as a default, with the given base locale.\n *\n * @example\n * ```\n * registerDefaultCalendar('en', 'buddhist') // sets the default calendar for the 'en' locale to Buddhist.\n * ```\n *\n * @param locale the locale to register this calendar for\n * @param calendar the calendar to use for this registration\n */ export function registerDefaultCalendar(locale, calendar) {\n    registeredLocaleCalendars.register(locale, calendar);\n}\n/**\n * Retrieves the default calendar for the specified locale if any.\n *\n * @param locale the locale to look-up\n */ export function getDefaultCalendar(locale) {\n    const locale_ = locale ?? getLocale();\n    return registeredLocaleCalendars.getCalendar(locale_ instanceof Intl.Locale ? locale_ : new Intl.Locale(locale_));\n}\nconst defaultOptions = {\n    mode: 'standard',\n    time: 'for today',\n    day: true,\n    month: true,\n    year: true,\n    noToday: false\n};\n/**\n * Formats the string representing a date, including partial representations of dates, according to the current\n * locale and the given options.\n *\n * Default options:\n *  - mode: \"standard\",\n *  - time: \"for today\",\n *  - day: true,\n *  - month: true,\n *  - year: true\n *  - noToday: false\n *\n * If the date is today then \"Today\" is produced (in the locale language).\n * This behavior can be disabled with `noToday: true`.\n *\n * When time is included, it is appended with a comma and a space. This\n * agrees with the output of `Date.prototype.toLocaleString` for *most*\n * locales.\n */ // TODO: Shouldn't throw on null input\nexport function formatPartialDate(dateString, options = {}) {\n    const locale = getLocale();\n    let parsed = attempt(dateString, locale);\n    if (parsed.invalid) {\n        console.warn(`Could not parse invalid date '${dateString}'`);\n        return null;\n    }\n    // hack here but any date interprets 2000-01, etc. as yyyy-dd rather than yyyy-mm\n    if (!isNil(parsed.day) && isNil(parsed.month)) {\n        parsed = Object.assign({}, omit(parsed, 'day'), {\n            month: parsed.day\n        });\n    }\n    // dayjs' object support uses 0-based months, whereas any-date-parser uses 1-based months\n    if (parsed.month) {\n        parsed.month -= 1;\n    }\n    // in dayjs day is day of week; in any-date-parser, its day of month, so we need to convert them\n    if (parsed.day) {\n        parsed = Object.assign({}, omit(parsed, 'day'), {\n            date: parsed.day\n        });\n    }\n    const date = dayjs().set(parsed).toDate();\n    if (isNil(parsed.year)) {\n        options.year = false;\n    }\n    if (isNil(parsed.month)) {\n        options.month = false;\n    }\n    if (isNil(parsed.date)) {\n        options.day = false;\n    }\n    return formatDate(date, options);\n}\n/**\n * Formats the input date according to the current locale and the\n * given options.\n *\n * Default options:\n *  - mode: \"standard\",\n *  - time: \"for today\",\n *  - day: true,\n *  - month: true,\n *  - year: true\n *  - noToday: false\n *\n * If the date is today then \"Today\" is produced (in the locale language).\n * This behavior can be disabled with `noToday: true`.\n *\n * When time is included, it is appended with a comma and a space. This\n * agrees with the output of `Date.prototype.toLocaleString` for *most*\n * locales.\n */ // TODO: Shouldn't throw on null input\nexport function formatDate(date, options) {\n    let locale = options?.locale ?? getLocale();\n    const _locale = new Intl.Locale(locale);\n    const { calendar, mode, time, day, month, year, noToday, numberingSystem } = {\n        ...defaultOptions,\n        ...{\n            noToday: _locale.language === 'am' ? true : false\n        },\n        ...options\n    };\n    const formatCalendar = calendar ?? getDefaultCalendar(_locale);\n    const formatterOptions = {\n        calendar: formatCalendar,\n        year: year ? 'numeric' : undefined,\n        month: month ? 'short' : undefined,\n        day: day ? '2-digit' : undefined,\n        numberingSystem\n    };\n    let localeString;\n    const isToday = dayjs(date).isToday();\n    if (isToday && !noToday) {\n        // This produces the word \"Today\" in the language of `locale`\n        const rtf = new Intl.RelativeTimeFormat(locale, {\n            numeric: 'auto'\n        });\n        localeString = rtf.format(0, 'day');\n        localeString = localeString[0].toLocaleUpperCase(locale) + localeString.slice(1);\n    } else {\n        if (_locale.language === 'en') {\n            // This locale override is here rather than in `getLocale`\n            // because Americans should see AM/PM for times.\n            locale = 'en-GB';\n        }\n        const formatter = new Intl.DateTimeFormat(locale, formatterOptions);\n        let parts = formatter.formatToParts(date);\n        if ((_locale.language === 'en' || _locale.language === 'am') && mode == 'standard' && year && day) {\n            // Custom formatting for English and Amharic. Use hyphens instead of spaces.\n            parts = parts.map(formatParts('-'));\n        }\n        if (mode == 'wide') {\n            parts = parts.map(formatParts(' — ')); // space-emdash-space\n        }\n        // omit the era when using the Ethiopic calendar\n        if (formatterOptions.calendar === 'ethiopic') {\n            parts = parts.filter((part, idx, values)=>{\n                if (part.type === 'era' || part.type === 'literal' && idx < values.length - 1 && values[idx + 1].type === 'era') {\n                    return false;\n                }\n                return true;\n            });\n        }\n        localeString = parts.map((p)=>p.value).join('');\n    }\n    if (time === true || isToday && time === 'for today') {\n        localeString += `, ${formatTime(date)}`;\n    }\n    return localeString;\n}\n// Internal curried call-back for map()\nconst formatParts = (separator)=>{\n    return (part, idx, values)=>{\n        if (part.type !== 'literal' || part.value !== ' ') {\n            return part;\n        }\n        if (idx < values.length - 1 && values[idx + 1].type === 'era') {\n            return part;\n        }\n        return {\n            type: 'literal',\n            value: separator\n        };\n    };\n};\n/**\n * Formats the input as a time, according to the current locale.\n * 12-hour or 24-hour clock depends on locale.\n */ export function formatTime(date) {\n    return date.toLocaleTimeString(getLocale(), {\n        hour: '2-digit',\n        minute: '2-digit'\n    });\n}\n/**\n * Formats the input into a string showing the date and time, according\n * to the current locale. The `mode` parameter is as described for\n * `formatDate`.\n *\n * This is created by concatenating the results of `formatDate`\n * and `formatTime` with a comma and space. This agrees with the\n * output of `Date.prototype.toLocaleString` for *most* locales.\n */ export function formatDatetime(date, options) {\n    return formatDate(date, {\n        ...options,\n        time: true\n    });\n}\n/**\n * Converts a calendar date to the equivalent locale calendar date.\n * @returns CalendarDate\n */ export function convertToLocaleCalendar(date, locale) {\n    let locale_ = typeof locale === 'string' ? new Intl.Locale(locale) : locale;\n    const localCalendarName = getDefaultCalendar(locale_);\n    return localCalendarName ? toCalendar(date, createCalendar(localCalendarName)) : date;\n}\n/**\n * Formats the input duration according to the current locale.\n *\n * @param duration The duration to format (DurationInput object).\n * @param options Optional options for formatting.\n * @returns The formatted duration string.\n */ export function formatDuration(duration, options) {\n    const formatter = new DurationFormat(getLocale(), options);\n    return formatter.format(duration);\n}\n"],"names":["_check_private_redeclaration","obj","privateCollection","has","TypeError","_class_apply_descriptor_get","receiver","descriptor","get","call","value","_class_extract_field_descriptor","privateMap","action","_class_private_field_get","_class_private_field_init","set","createCalendar","toCalendar","DurationFormat","attempt","dayjs","isToday","objectSupport","utc","isNil","omit","getLocale","extend","isoFormat","isOmrsDateStrict","omrsPayloadString","undefined","trim","length","isValid","isOmrsDateToday","date","toDateObjectStrict","omrsDateString","toDate","toOmrsIsoString","toUTC","d","format","parseDate","dateString","_registry","WeakMap","LocaleCalendars","register","locale","calendar","getCalendar","Boolean","region","key","language","defaultCalendar","Intl","DateTimeFormat","toString","resolvedOptions","writable","Map","registeredLocaleCalendars","registerDefaultCalendar","getDefaultCalendar","locale_","Locale","defaultOptions","mode","time","day","month","year","noToday","formatPartialDate","options","parsed","invalid","console","warn","Object","assign","formatDate","_locale","numberingSystem","formatCalendar","formatterOptions","localeString","rtf","RelativeTimeFormat","numeric","toLocaleUpperCase","slice","formatter","parts","formatToParts","map","formatParts","filter","part","idx","values","type","p","join","formatTime","separator","toLocaleTimeString","hour","minute","formatDatetime","convertToLocaleCalendar","localCalendarName","formatDuration","duration"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-utils/dist/dates/date-util.js\n");
1288
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ convertToLocaleCalendar: () => (/* binding */ convertToLocaleCalendar),\n/* harmony export */ formatDate: () => (/* binding */ formatDate),\n/* harmony export */ formatDatetime: () => (/* binding */ formatDatetime),\n/* harmony export */ formatDuration: () => (/* binding */ formatDuration),\n/* harmony export */ formatPartialDate: () => (/* binding */ formatPartialDate),\n/* harmony export */ formatTime: () => (/* binding */ formatTime),\n/* harmony export */ getDefaultCalendar: () => (/* binding */ getDefaultCalendar),\n/* harmony export */ isOmrsDateStrict: () => (/* binding */ isOmrsDateStrict),\n/* harmony export */ isOmrsDateToday: () => (/* binding */ isOmrsDateToday),\n/* harmony export */ parseDate: () => (/* binding */ parseDate),\n/* harmony export */ registerDefaultCalendar: () => (/* binding */ registerDefaultCalendar),\n/* harmony export */ toDateObjectStrict: () => (/* binding */ toDateObjectStrict),\n/* harmony export */ toOmrsIsoString: () => (/* binding */ toOmrsIsoString)\n/* harmony export */ });\n/* harmony import */ var _internationalized_date__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! @internationalized/date */ \"../../../node_modules/@internationalized/date/dist/conversion.mjs\");\n/* harmony import */ var _internationalized_date__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! @internationalized/date */ \"../../../node_modules/@internationalized/date/dist/createCalendar.mjs\");\n/* harmony import */ var _formatjs_intl_durationformat__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @formatjs/intl-durationformat */ \"../../../node_modules/@formatjs/intl-durationformat/index.js\");\n/* harmony import */ var any_date_parser__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! any-date-parser */ \"../../../node_modules/any-date-parser/dist/index.mjs\");\n/* harmony import */ var dayjs__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! dayjs */ \"webpack/sharing/consume/default/dayjs/dayjs\");\n/* harmony import */ var dayjs_plugin_isToday_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! dayjs/plugin/isToday.js */ \"../../../node_modules/dayjs/plugin/isToday.js\");\n/* harmony import */ var dayjs_plugin_objectSupport_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! dayjs/plugin/objectSupport.js */ \"../../../node_modules/dayjs/plugin/objectSupport.js\");\n/* harmony import */ var dayjs_plugin_utc_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! dayjs/plugin/utc.js */ \"../../../node_modules/dayjs/plugin/utc.js\");\n/* harmony import */ var lodash_es__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! lodash-es */ \"../../../node_modules/lodash-es/isNil.js\");\n/* harmony import */ var lodash_es__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! lodash-es */ \"../../../node_modules/lodash-es/omit.js\");\n/* harmony import */ var _index_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../index.js */ \"../../framework/esm-utils/dist/get-locale.js\");\n/**\n * @module\n * @category Date and Time\n */ function _check_private_redeclaration(obj, privateCollection) {\n if (privateCollection.has(obj)) {\n throw new TypeError(\"Cannot initialize the same private elements twice on an object\");\n }\n}\nfunction _class_apply_descriptor_get(receiver, descriptor) {\n if (descriptor.get) {\n return descriptor.get.call(receiver);\n }\n return descriptor.value;\n}\nfunction _class_extract_field_descriptor(receiver, privateMap, action) {\n if (!privateMap.has(receiver)) {\n throw new TypeError(\"attempted to \" + action + \" private field on non-instance\");\n }\n return privateMap.get(receiver);\n}\nfunction _class_private_field_get(receiver, privateMap) {\n var descriptor = _class_extract_field_descriptor(receiver, privateMap, \"get\");\n return _class_apply_descriptor_get(receiver, descriptor);\n}\nfunction _class_private_field_init(obj, privateMap, value) {\n _check_private_redeclaration(obj, privateMap);\n privateMap.set(obj, value);\n}\n\n\n\n\n\n\n\n\n\ndayjs__WEBPACK_IMPORTED_MODULE_1__.extend(dayjs_plugin_isToday_js__WEBPACK_IMPORTED_MODULE_2__);\ndayjs__WEBPACK_IMPORTED_MODULE_1__.extend(dayjs_plugin_utc_js__WEBPACK_IMPORTED_MODULE_4__);\ndayjs__WEBPACK_IMPORTED_MODULE_1__.extend(dayjs_plugin_objectSupport_js__WEBPACK_IMPORTED_MODULE_3__);\nconst isoFormat = 'YYYY-MM-DDTHH:mm:ss.SSSZZ';\n/**\n * This function checks whether a date string is the OpenMRS ISO format.\n * The format should be YYYY-MM-DDTHH:mm:ss.SSSZZ\n */ function isOmrsDateStrict(omrsPayloadString) {\n // omrs format 2018-03-19T00:00:00.000+0300\n if (omrsPayloadString === null || omrsPayloadString === undefined || omrsPayloadString.trim().length !== 28) {\n return false;\n }\n omrsPayloadString = omrsPayloadString.trim();\n // 11th character will always be T\n if (omrsPayloadString[10] !== 'T') {\n return false;\n }\n // checking time format\n if (omrsPayloadString[13] !== ':' || omrsPayloadString[16] !== ':' || omrsPayloadString[19] !== '.') {\n return false;\n }\n // checking UTC offset format\n if (!(omrsPayloadString[23] === '+' || omrsPayloadString[23] === '-')) {\n return false;\n }\n return dayjs__WEBPACK_IMPORTED_MODULE_1__(omrsPayloadString, isoFormat).isValid();\n}\n/**\n * Checks if the provided date is today.\n *\n * @param date The date to check.\n * @returns `true` if the date is today, `false` otherwise.\n */ function isOmrsDateToday(date) {\n return dayjs__WEBPACK_IMPORTED_MODULE_1__(date).isToday();\n}\n/**\n * Converts the object to a date object if it is an OpenMRS ISO date time string.\n * Otherwise returns null.\n */ function toDateObjectStrict(omrsDateString) {\n if (!isOmrsDateStrict(omrsDateString)) {\n return null;\n }\n return dayjs__WEBPACK_IMPORTED_MODULE_1__(omrsDateString, isoFormat).toDate();\n}\n/**\n * Formats the input to OpenMRS ISO format: \"YYYY-MM-DDTHH:mm:ss.SSSZZ\".\n */ function toOmrsIsoString(date, toUTC = false) {\n let d = dayjs__WEBPACK_IMPORTED_MODULE_1__(date);\n if (toUTC) {\n d = d.utc();\n }\n return d.format(isoFormat);\n}\n/**\n * Utility function to parse an arbitrary string into a date.\n * Uses `dayjs(dateString)`.\n */ function parseDate(dateString) {\n return dayjs__WEBPACK_IMPORTED_MODULE_1__(dateString).toDate();\n}\nvar _registry = /*#__PURE__*/ new WeakMap();\n/**\n * Internal cache for per-locale calendars\n */ class LocaleCalendars {\n register(locale, calendar) {\n _class_private_field_get(this, _registry).set(locale, calendar);\n }\n getCalendar(locale) {\n if (!Boolean(locale)) {\n return undefined;\n }\n if (locale.calendar) {\n return locale.calendar;\n }\n if (locale.region) {\n const key = `${locale.language}-${locale.region}`;\n if (_class_private_field_get(this, _registry).has(key)) {\n return _class_private_field_get(this, _registry).get(key);\n }\n }\n if (locale.language && _class_private_field_get(this, _registry).has(locale.language)) {\n return _class_private_field_get(this, _registry).get(locale.language);\n }\n const defaultCalendar = new Intl.DateTimeFormat(locale.toString()).resolvedOptions().calendar;\n // cache this result\n _class_private_field_get(this, _registry).set(`${locale.language}${locale.region ? `-${locale.region}` : ''}`, defaultCalendar);\n return defaultCalendar;\n }\n constructor(){\n _class_private_field_init(this, _registry, {\n writable: true,\n value: new Map()\n });\n }\n}\nconst registeredLocaleCalendars = new LocaleCalendars();\n/**\n * Provides the name of the calendar to associate, as a default, with the given base locale.\n *\n * @example\n * ```\n * registerDefaultCalendar('en', 'buddhist') // sets the default calendar for the 'en' locale to Buddhist.\n * ```\n *\n * @param locale the locale to register this calendar for\n * @param calendar the calendar to use for this registration\n */ function registerDefaultCalendar(locale, calendar) {\n registeredLocaleCalendars.register(locale, calendar);\n}\n/**\n * Retrieves the default calendar for the specified locale if any.\n *\n * @param locale the locale to look-up\n */ function getDefaultCalendar(locale) {\n const locale_ = locale ?? (0,_index_js__WEBPACK_IMPORTED_MODULE_5__.getLocale)();\n return registeredLocaleCalendars.getCalendar(locale_ instanceof Intl.Locale ? locale_ : new Intl.Locale(locale_));\n}\nconst defaultOptions = {\n mode: 'standard',\n time: 'for today',\n day: true,\n month: true,\n year: true,\n noToday: false\n};\n/**\n * Formats the string representing a date, including partial representations of dates, according to the current\n * locale and the given options.\n *\n * Default options:\n * - mode: \"standard\",\n * - time: \"for today\",\n * - day: true,\n * - month: true,\n * - year: true\n * - noToday: false\n *\n * If the date is today then \"Today\" is produced (in the locale language).\n * This behavior can be disabled with `noToday: true`.\n *\n * When time is included, it is appended with a comma and a space. This\n * agrees with the output of `Date.prototype.toLocaleString` for *most*\n * locales.\n *\n * @param dateString The date string to parse and format.\n * @param options Optional formatting options.\n * @returns The formatted date string, or `null` if the input cannot be parsed.\n */ // TODO: Shouldn't throw on null input\nfunction formatPartialDate(dateString, options = {}) {\n const locale = (0,_index_js__WEBPACK_IMPORTED_MODULE_5__.getLocale)();\n let parsed = (0,any_date_parser__WEBPACK_IMPORTED_MODULE_6__.attempt)(dateString, locale);\n if (parsed.invalid) {\n console.warn(`Could not parse invalid date '${dateString}'`);\n return null;\n }\n // hack here but any date interprets 2000-01, etc. as yyyy-dd rather than yyyy-mm\n if (!(0,lodash_es__WEBPACK_IMPORTED_MODULE_7__[\"default\"])(parsed.day) && (0,lodash_es__WEBPACK_IMPORTED_MODULE_7__[\"default\"])(parsed.month)) {\n parsed = Object.assign({}, (0,lodash_es__WEBPACK_IMPORTED_MODULE_8__[\"default\"])(parsed, 'day'), {\n month: parsed.day\n });\n }\n // dayjs' object support uses 0-based months, whereas any-date-parser uses 1-based months\n if (parsed.month) {\n parsed.month -= 1;\n }\n // in dayjs day is day of week; in any-date-parser, its day of month, so we need to convert them\n if (parsed.day) {\n parsed = Object.assign({}, (0,lodash_es__WEBPACK_IMPORTED_MODULE_8__[\"default\"])(parsed, 'day'), {\n date: parsed.day\n });\n }\n const date = dayjs__WEBPACK_IMPORTED_MODULE_1__().set(parsed).toDate();\n if ((0,lodash_es__WEBPACK_IMPORTED_MODULE_7__[\"default\"])(parsed.year)) {\n options.year = false;\n }\n if ((0,lodash_es__WEBPACK_IMPORTED_MODULE_7__[\"default\"])(parsed.month)) {\n options.month = false;\n }\n if ((0,lodash_es__WEBPACK_IMPORTED_MODULE_7__[\"default\"])(parsed.date)) {\n options.day = false;\n }\n return formatDate(date, options);\n}\n/**\n * Formats the input date according to the current locale and the\n * given options.\n *\n * Default options:\n * - mode: \"standard\",\n * - time: \"for today\",\n * - day: true,\n * - month: true,\n * - year: true\n * - noToday: false\n *\n * If the date is today then \"Today\" is produced (in the locale language).\n * This behavior can be disabled with `noToday: true`.\n *\n * When time is included, it is appended with a comma and a space. This\n * agrees with the output of `Date.prototype.toLocaleString` for *most*\n * locales.\n *\n * @param date The date to format.\n * @param options Optional formatting options.\n * @returns The formatted date string.\n */ // TODO: Shouldn't throw on null input\nfunction formatDate(date, options) {\n let locale = options?.locale ?? (0,_index_js__WEBPACK_IMPORTED_MODULE_5__.getLocale)();\n const _locale = new Intl.Locale(locale);\n const { calendar, mode, time, day, month, year, noToday, numberingSystem } = {\n ...defaultOptions,\n ...{\n noToday: _locale.language === 'am' ? true : false\n },\n ...options\n };\n const formatCalendar = calendar ?? getDefaultCalendar(_locale);\n const formatterOptions = {\n calendar: formatCalendar,\n year: year ? 'numeric' : undefined,\n month: month ? 'short' : undefined,\n day: day ? '2-digit' : undefined,\n numberingSystem\n };\n let localeString;\n const isToday = dayjs__WEBPACK_IMPORTED_MODULE_1__(date).isToday();\n if (isToday && !noToday) {\n // This produces the word \"Today\" in the language of `locale`\n const rtf = new Intl.RelativeTimeFormat(locale, {\n numeric: 'auto'\n });\n localeString = rtf.format(0, 'day');\n localeString = localeString[0].toLocaleUpperCase(locale) + localeString.slice(1);\n } else {\n if (_locale.language === 'en') {\n // This locale override is here rather than in `getLocale`\n // because Americans should see AM/PM for times.\n locale = 'en-GB';\n }\n const formatter = new Intl.DateTimeFormat(locale, formatterOptions);\n let parts = formatter.formatToParts(date);\n if ((_locale.language === 'en' || _locale.language === 'am') && mode == 'standard' && year && day) {\n // Custom formatting for English and Amharic. Use hyphens instead of spaces.\n parts = parts.map(formatParts('-'));\n }\n if (mode == 'wide') {\n parts = parts.map(formatParts(' — ')); // space-emdash-space\n }\n // omit the era when using the Ethiopic calendar\n if (formatterOptions.calendar === 'ethiopic') {\n parts = parts.filter((part, idx, values)=>{\n if (part.type === 'era' || part.type === 'literal' && idx < values.length - 1 && values[idx + 1].type === 'era') {\n return false;\n }\n return true;\n });\n }\n localeString = parts.map((p)=>p.value).join('');\n }\n if (time === true || isToday && time === 'for today') {\n localeString += `, ${formatTime(date)}`;\n }\n return localeString;\n}\n// Internal curried call-back for map()\nconst formatParts = (separator)=>{\n return (part, idx, values)=>{\n if (part.type !== 'literal' || part.value !== ' ') {\n return part;\n }\n if (idx < values.length - 1 && values[idx + 1].type === 'era') {\n return part;\n }\n return {\n type: 'literal',\n value: separator\n };\n };\n};\n/**\n * Formats the input as a time, according to the current locale.\n * 12-hour or 24-hour clock depends on locale.\n *\n * @param date The date whose time portion should be formatted.\n * @returns The formatted time string (e.g., \"2:30 PM\" or \"14:30\").\n */ function formatTime(date) {\n return date.toLocaleTimeString((0,_index_js__WEBPACK_IMPORTED_MODULE_5__.getLocale)(), {\n hour: '2-digit',\n minute: '2-digit'\n });\n}\n/**\n * Formats the input into a string showing the date and time, according\n * to the current locale. The `mode` parameter is as described for\n * `formatDate`.\n *\n * This is created by concatenating the results of `formatDate`\n * and `formatTime` with a comma and space. This agrees with the\n * output of `Date.prototype.toLocaleString` for *most* locales.\n *\n * @param date The date to format.\n * @param options Optional formatting options (same as formatDate, except time is always included).\n * @returns The formatted date and time string.\n */ function formatDatetime(date, options) {\n return formatDate(date, {\n ...options,\n time: true\n });\n}\n/**\n * Converts a calendar date to the equivalent locale calendar date.\n * @returns CalendarDate\n */ function convertToLocaleCalendar(date, locale) {\n let locale_ = typeof locale === 'string' ? new Intl.Locale(locale) : locale;\n const localCalendarName = getDefaultCalendar(locale_);\n return localCalendarName ? (0,_internationalized_date__WEBPACK_IMPORTED_MODULE_9__.toCalendar)(date, (0,_internationalized_date__WEBPACK_IMPORTED_MODULE_10__.createCalendar)(localCalendarName)) : date;\n}\n/**\n * Formats the input duration according to the current locale.\n *\n * @param duration The duration to format (DurationInput object).\n * @param options Optional options for formatting.\n * @returns The formatted duration string.\n */ function formatDuration(duration, options) {\n const formatter = new _formatjs_intl_durationformat__WEBPACK_IMPORTED_MODULE_0__.DurationFormat((0,_index_js__WEBPACK_IMPORTED_MODULE_5__.getLocale)(), options);\n return formatter.format(duration);\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../framework/esm-utils/dist/dates/date-util.js","mappings":"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","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-utils/dist/dates/date-util.js?985f"],"sourcesContent":["/**\n * @module\n * @category Date and Time\n */ function _check_private_redeclaration(obj, privateCollection) {\n    if (privateCollection.has(obj)) {\n        throw new TypeError(\"Cannot initialize the same private elements twice on an object\");\n    }\n}\nfunction _class_apply_descriptor_get(receiver, descriptor) {\n    if (descriptor.get) {\n        return descriptor.get.call(receiver);\n    }\n    return descriptor.value;\n}\nfunction _class_extract_field_descriptor(receiver, privateMap, action) {\n    if (!privateMap.has(receiver)) {\n        throw new TypeError(\"attempted to \" + action + \" private field on non-instance\");\n    }\n    return privateMap.get(receiver);\n}\nfunction _class_private_field_get(receiver, privateMap) {\n    var descriptor = _class_extract_field_descriptor(receiver, privateMap, \"get\");\n    return _class_apply_descriptor_get(receiver, descriptor);\n}\nfunction _class_private_field_init(obj, privateMap, value) {\n    _check_private_redeclaration(obj, privateMap);\n    privateMap.set(obj, value);\n}\nimport { createCalendar, toCalendar } from \"@internationalized/date\";\nimport { DurationFormat } from \"@formatjs/intl-durationformat\";\nimport { attempt } from \"any-date-parser\";\nimport dayjs from \"dayjs\";\nimport isToday from \"dayjs/plugin/isToday.js\";\nimport objectSupport from \"dayjs/plugin/objectSupport.js\";\nimport utc from \"dayjs/plugin/utc.js\";\nimport { isNil, omit } from \"lodash-es\";\nimport { getLocale } from \"../index.js\";\ndayjs.extend(isToday);\ndayjs.extend(utc);\ndayjs.extend(objectSupport);\nconst isoFormat = 'YYYY-MM-DDTHH:mm:ss.SSSZZ';\n/**\n * This function checks whether a date string is the OpenMRS ISO format.\n * The format should be YYYY-MM-DDTHH:mm:ss.SSSZZ\n */ export function isOmrsDateStrict(omrsPayloadString) {\n    // omrs format 2018-03-19T00:00:00.000+0300\n    if (omrsPayloadString === null || omrsPayloadString === undefined || omrsPayloadString.trim().length !== 28) {\n        return false;\n    }\n    omrsPayloadString = omrsPayloadString.trim();\n    // 11th character will always be T\n    if (omrsPayloadString[10] !== 'T') {\n        return false;\n    }\n    // checking time format\n    if (omrsPayloadString[13] !== ':' || omrsPayloadString[16] !== ':' || omrsPayloadString[19] !== '.') {\n        return false;\n    }\n    // checking UTC offset format\n    if (!(omrsPayloadString[23] === '+' || omrsPayloadString[23] === '-')) {\n        return false;\n    }\n    return dayjs(omrsPayloadString, isoFormat).isValid();\n}\n/**\n * Checks if the provided date is today.\n *\n * @param date The date to check.\n * @returns `true` if the date is today, `false` otherwise.\n */ export function isOmrsDateToday(date) {\n    return dayjs(date).isToday();\n}\n/**\n * Converts the object to a date object if it is an OpenMRS ISO date time string.\n * Otherwise returns null.\n */ export function toDateObjectStrict(omrsDateString) {\n    if (!isOmrsDateStrict(omrsDateString)) {\n        return null;\n    }\n    return dayjs(omrsDateString, isoFormat).toDate();\n}\n/**\n * Formats the input to OpenMRS ISO format: \"YYYY-MM-DDTHH:mm:ss.SSSZZ\".\n */ export function toOmrsIsoString(date, toUTC = false) {\n    let d = dayjs(date);\n    if (toUTC) {\n        d = d.utc();\n    }\n    return d.format(isoFormat);\n}\n/**\n * Utility function to parse an arbitrary string into a date.\n * Uses `dayjs(dateString)`.\n */ export function parseDate(dateString) {\n    return dayjs(dateString).toDate();\n}\nvar _registry = /*#__PURE__*/ new WeakMap();\n/**\n * Internal cache for per-locale calendars\n */ class LocaleCalendars {\n    register(locale, calendar) {\n        _class_private_field_get(this, _registry).set(locale, calendar);\n    }\n    getCalendar(locale) {\n        if (!Boolean(locale)) {\n            return undefined;\n        }\n        if (locale.calendar) {\n            return locale.calendar;\n        }\n        if (locale.region) {\n            const key = `${locale.language}-${locale.region}`;\n            if (_class_private_field_get(this, _registry).has(key)) {\n                return _class_private_field_get(this, _registry).get(key);\n            }\n        }\n        if (locale.language && _class_private_field_get(this, _registry).has(locale.language)) {\n            return _class_private_field_get(this, _registry).get(locale.language);\n        }\n        const defaultCalendar = new Intl.DateTimeFormat(locale.toString()).resolvedOptions().calendar;\n        // cache this result\n        _class_private_field_get(this, _registry).set(`${locale.language}${locale.region ? `-${locale.region}` : ''}`, defaultCalendar);\n        return defaultCalendar;\n    }\n    constructor(){\n        _class_private_field_init(this, _registry, {\n            writable: true,\n            value: new Map()\n        });\n    }\n}\nconst registeredLocaleCalendars = new LocaleCalendars();\n/**\n * Provides the name of the calendar to associate, as a default, with the given base locale.\n *\n * @example\n * ```\n * registerDefaultCalendar('en', 'buddhist') // sets the default calendar for the 'en' locale to Buddhist.\n * ```\n *\n * @param locale the locale to register this calendar for\n * @param calendar the calendar to use for this registration\n */ export function registerDefaultCalendar(locale, calendar) {\n    registeredLocaleCalendars.register(locale, calendar);\n}\n/**\n * Retrieves the default calendar for the specified locale if any.\n *\n * @param locale the locale to look-up\n */ export function getDefaultCalendar(locale) {\n    const locale_ = locale ?? getLocale();\n    return registeredLocaleCalendars.getCalendar(locale_ instanceof Intl.Locale ? locale_ : new Intl.Locale(locale_));\n}\nconst defaultOptions = {\n    mode: 'standard',\n    time: 'for today',\n    day: true,\n    month: true,\n    year: true,\n    noToday: false\n};\n/**\n * Formats the string representing a date, including partial representations of dates, according to the current\n * locale and the given options.\n *\n * Default options:\n *  - mode: \"standard\",\n *  - time: \"for today\",\n *  - day: true,\n *  - month: true,\n *  - year: true\n *  - noToday: false\n *\n * If the date is today then \"Today\" is produced (in the locale language).\n * This behavior can be disabled with `noToday: true`.\n *\n * When time is included, it is appended with a comma and a space. This\n * agrees with the output of `Date.prototype.toLocaleString` for *most*\n * locales.\n *\n * @param dateString The date string to parse and format.\n * @param options Optional formatting options.\n * @returns The formatted date string, or `null` if the input cannot be parsed.\n */ // TODO: Shouldn't throw on null input\nexport function formatPartialDate(dateString, options = {}) {\n    const locale = getLocale();\n    let parsed = attempt(dateString, locale);\n    if (parsed.invalid) {\n        console.warn(`Could not parse invalid date '${dateString}'`);\n        return null;\n    }\n    // hack here but any date interprets 2000-01, etc. as yyyy-dd rather than yyyy-mm\n    if (!isNil(parsed.day) && isNil(parsed.month)) {\n        parsed = Object.assign({}, omit(parsed, 'day'), {\n            month: parsed.day\n        });\n    }\n    // dayjs' object support uses 0-based months, whereas any-date-parser uses 1-based months\n    if (parsed.month) {\n        parsed.month -= 1;\n    }\n    // in dayjs day is day of week; in any-date-parser, its day of month, so we need to convert them\n    if (parsed.day) {\n        parsed = Object.assign({}, omit(parsed, 'day'), {\n            date: parsed.day\n        });\n    }\n    const date = dayjs().set(parsed).toDate();\n    if (isNil(parsed.year)) {\n        options.year = false;\n    }\n    if (isNil(parsed.month)) {\n        options.month = false;\n    }\n    if (isNil(parsed.date)) {\n        options.day = false;\n    }\n    return formatDate(date, options);\n}\n/**\n * Formats the input date according to the current locale and the\n * given options.\n *\n * Default options:\n *  - mode: \"standard\",\n *  - time: \"for today\",\n *  - day: true,\n *  - month: true,\n *  - year: true\n *  - noToday: false\n *\n * If the date is today then \"Today\" is produced (in the locale language).\n * This behavior can be disabled with `noToday: true`.\n *\n * When time is included, it is appended with a comma and a space. This\n * agrees with the output of `Date.prototype.toLocaleString` for *most*\n * locales.\n *\n * @param date The date to format.\n * @param options Optional formatting options.\n * @returns The formatted date string.\n */ // TODO: Shouldn't throw on null input\nexport function formatDate(date, options) {\n    let locale = options?.locale ?? getLocale();\n    const _locale = new Intl.Locale(locale);\n    const { calendar, mode, time, day, month, year, noToday, numberingSystem } = {\n        ...defaultOptions,\n        ...{\n            noToday: _locale.language === 'am' ? true : false\n        },\n        ...options\n    };\n    const formatCalendar = calendar ?? getDefaultCalendar(_locale);\n    const formatterOptions = {\n        calendar: formatCalendar,\n        year: year ? 'numeric' : undefined,\n        month: month ? 'short' : undefined,\n        day: day ? '2-digit' : undefined,\n        numberingSystem\n    };\n    let localeString;\n    const isToday = dayjs(date).isToday();\n    if (isToday && !noToday) {\n        // This produces the word \"Today\" in the language of `locale`\n        const rtf = new Intl.RelativeTimeFormat(locale, {\n            numeric: 'auto'\n        });\n        localeString = rtf.format(0, 'day');\n        localeString = localeString[0].toLocaleUpperCase(locale) + localeString.slice(1);\n    } else {\n        if (_locale.language === 'en') {\n            // This locale override is here rather than in `getLocale`\n            // because Americans should see AM/PM for times.\n            locale = 'en-GB';\n        }\n        const formatter = new Intl.DateTimeFormat(locale, formatterOptions);\n        let parts = formatter.formatToParts(date);\n        if ((_locale.language === 'en' || _locale.language === 'am') && mode == 'standard' && year && day) {\n            // Custom formatting for English and Amharic. Use hyphens instead of spaces.\n            parts = parts.map(formatParts('-'));\n        }\n        if (mode == 'wide') {\n            parts = parts.map(formatParts(' — ')); // space-emdash-space\n        }\n        // omit the era when using the Ethiopic calendar\n        if (formatterOptions.calendar === 'ethiopic') {\n            parts = parts.filter((part, idx, values)=>{\n                if (part.type === 'era' || part.type === 'literal' && idx < values.length - 1 && values[idx + 1].type === 'era') {\n                    return false;\n                }\n                return true;\n            });\n        }\n        localeString = parts.map((p)=>p.value).join('');\n    }\n    if (time === true || isToday && time === 'for today') {\n        localeString += `, ${formatTime(date)}`;\n    }\n    return localeString;\n}\n// Internal curried call-back for map()\nconst formatParts = (separator)=>{\n    return (part, idx, values)=>{\n        if (part.type !== 'literal' || part.value !== ' ') {\n            return part;\n        }\n        if (idx < values.length - 1 && values[idx + 1].type === 'era') {\n            return part;\n        }\n        return {\n            type: 'literal',\n            value: separator\n        };\n    };\n};\n/**\n * Formats the input as a time, according to the current locale.\n * 12-hour or 24-hour clock depends on locale.\n *\n * @param date The date whose time portion should be formatted.\n * @returns The formatted time string (e.g., \"2:30 PM\" or \"14:30\").\n */ export function formatTime(date) {\n    return date.toLocaleTimeString(getLocale(), {\n        hour: '2-digit',\n        minute: '2-digit'\n    });\n}\n/**\n * Formats the input into a string showing the date and time, according\n * to the current locale. The `mode` parameter is as described for\n * `formatDate`.\n *\n * This is created by concatenating the results of `formatDate`\n * and `formatTime` with a comma and space. This agrees with the\n * output of `Date.prototype.toLocaleString` for *most* locales.\n *\n * @param date The date to format.\n * @param options Optional formatting options (same as formatDate, except time is always included).\n * @returns The formatted date and time string.\n */ export function formatDatetime(date, options) {\n    return formatDate(date, {\n        ...options,\n        time: true\n    });\n}\n/**\n * Converts a calendar date to the equivalent locale calendar date.\n * @returns CalendarDate\n */ export function convertToLocaleCalendar(date, locale) {\n    let locale_ = typeof locale === 'string' ? new Intl.Locale(locale) : locale;\n    const localCalendarName = getDefaultCalendar(locale_);\n    return localCalendarName ? toCalendar(date, createCalendar(localCalendarName)) : date;\n}\n/**\n * Formats the input duration according to the current locale.\n *\n * @param duration The duration to format (DurationInput object).\n * @param options Optional options for formatting.\n * @returns The formatted duration string.\n */ export function formatDuration(duration, options) {\n    const formatter = new DurationFormat(getLocale(), options);\n    return formatter.format(duration);\n}\n"],"names":["_check_private_redeclaration","obj","privateCollection","has","TypeError","_class_apply_descriptor_get","receiver","descriptor","get","call","value","_class_extract_field_descriptor","privateMap","action","_class_private_field_get","_class_private_field_init","set","createCalendar","toCalendar","DurationFormat","attempt","dayjs","isToday","objectSupport","utc","isNil","omit","getLocale","extend","isoFormat","isOmrsDateStrict","omrsPayloadString","undefined","trim","length","isValid","isOmrsDateToday","date","toDateObjectStrict","omrsDateString","toDate","toOmrsIsoString","toUTC","d","format","parseDate","dateString","_registry","WeakMap","LocaleCalendars","register","locale","calendar","getCalendar","Boolean","region","key","language","defaultCalendar","Intl","DateTimeFormat","toString","resolvedOptions","writable","Map","registeredLocaleCalendars","registerDefaultCalendar","getDefaultCalendar","locale_","Locale","defaultOptions","mode","time","day","month","year","noToday","formatPartialDate","options","parsed","invalid","console","warn","Object","assign","formatDate","_locale","numberingSystem","formatCalendar","formatterOptions","localeString","rtf","RelativeTimeFormat","numeric","toLocaleUpperCase","slice","formatter","parts","formatToParts","map","formatParts","filter","part","idx","values","type","p","join","formatTime","separator","toLocaleTimeString","hour","minute","formatDatetime","convertToLocaleCalendar","localCalendarName","formatDuration","duration"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../framework/esm-utils/dist/dates/date-util.js\n");
1289
1289
 
1290
1290
  /***/ }),
1291
1291
 
@@ -1325,7 +1325,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
1325
1325
  \*********************************************************/
1326
1326
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
1327
1327
 
1328
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ displayName: () => (/* binding */ displayName),\n/* harmony export */ formatPatientName: () => (/* binding */ formatPatientName),\n/* harmony export */ formattedName: () => (/* binding */ formattedName),\n/* harmony export */ getPatientName: () => (/* binding */ getPatientName),\n/* harmony export */ selectPreferredName: () => (/* binding */ selectPreferredName)\n/* harmony export */ });\n/** @module @category Utility */ /**\n * Gets the formatted display name for a patient.\n *\n * The display name will be taken from the patient's 'usual' name,\n * or may fall back to the patient's 'official' name.\n *\n * @param patient The patient details in FHIR format.\n * @returns The patient's display name or an empty string if name is not present.\n */ function getPatientName(patient) {\n const name = selectPreferredName(patient, 'usual', 'official');\n return formatPatientName(name);\n}\n/** @deprecated Use `getPatientName` */ function displayName(patient) {\n return getPatientName(patient);\n}\n/**\n * Get a formatted display string for an FHIR name.\n * @param name The name to be formatted.\n * @returns The formatted display name or an empty string if name is undefined.\n */ function formatPatientName(name) {\n if (name) return name.text ?? defaultFormat(name);\n return '';\n}\n/** @deprecated Use `formatPatientName` */ function formattedName(name) {\n return formatPatientName(name);\n}\n/**\n * Select the preferred name from the collection of names associated with a patient.\n *\n * Names may be specified with a usage such as 'usual', 'official', 'nickname', 'maiden', etc.\n * A name with no usage specified is treated as the 'usual' name.\n *\n * The chosen name will be selected according to the priority order of `preferredNames`,\n * @example\n * // normal use case; prefer usual name, fallback to official name\n * displayNameByUsage(patient, 'usual', 'official')\n * @example\n * // prefer usual name over nickname, fallback to official name\n * displayNameByUsage(patient, 'usual', 'nickname', 'official')\n *\n * @param patient The patient from whom a name will be selected.\n * @param preferredNames Optional ordered sequence of preferred name usages; defaults to 'usual' if not specified.\n * @return the preferred name for the patient, or undefined if no acceptable name could be found.\n */ function selectPreferredName(patient, ...preferredNames) {\n if (preferredNames.length == 0) {\n preferredNames = [\n 'usual'\n ];\n }\n for (const usage of preferredNames){\n const name = patient.name?.find((name)=>nameUsageMatches(name, usage));\n if (name) {\n return name;\n }\n }\n return undefined;\n}\n/**\n * Generate a display name by concatenating forenames and surname.\n * @param name the person's name.\n * @returns the person's name as a string.\n */ function defaultFormat(name) {\n const forenames = name.given ?? [];\n const names = name.family ? forenames.concat(name.family) : forenames;\n return names.join(' ');\n}\n/**\n * Determine whether the usage of a given name matches the given NameUse.\n *\n * A name with no usage is treated as the 'usual' name.\n *\n * @param name the name to test.\n * @param usage the NameUse to test for.\n */ function nameUsageMatches(name, usage) {\n if (!name.use) return usage === 'usual';\n return name.use === usage;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS11dGlscy9kaXN0L3BhdGllbnQtaGVscGVycy5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUFBLDhCQUE4QixHQUFHOzs7Ozs7OztDQVFoQyxHQUFVLFNBQVNBLGVBQWVDLE9BQU87SUFDdEMsTUFBTUMsT0FBT0Msb0JBQW9CRixTQUFTLFNBQVM7SUFDbkQsT0FBT0csa0JBQWtCRjtBQUM3QjtBQUNBLHFDQUFxQyxHQUFVLFNBQVNHLFlBQVlKLE9BQU87SUFDdkUsT0FBT0QsZUFBZUM7QUFDMUI7QUFDQTs7OztDQUlDLEdBQVUsU0FBU0csa0JBQWtCRixJQUFJO0lBQ3RDLElBQUlBLE1BQU0sT0FBT0EsS0FBS0ksSUFBSSxJQUFJQyxjQUFjTDtJQUM1QyxPQUFPO0FBQ1g7QUFDQSx3Q0FBd0MsR0FBVSxTQUFTTSxjQUFjTixJQUFJO0lBQ3pFLE9BQU9FLGtCQUFrQkY7QUFDN0I7QUFDQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Q0FpQkMsR0FBVSxTQUFTQyxvQkFBb0JGLE9BQU8sRUFBRSxHQUFHUSxjQUFjO0lBQzlELElBQUlBLGVBQWVDLE1BQU0sSUFBSSxHQUFHO1FBQzVCRCxpQkFBaUI7WUFDYjtTQUNIO0lBQ0w7SUFDQSxLQUFLLE1BQU1FLFNBQVNGLGVBQWU7UUFDL0IsTUFBTVAsT0FBT0QsUUFBUUMsSUFBSSxFQUFFVSxLQUFLLENBQUNWLE9BQU9XLGlCQUFpQlgsTUFBTVM7UUFDL0QsSUFBSVQsTUFBTTtZQUNOLE9BQU9BO1FBQ1g7SUFDSjtJQUNBLE9BQU9ZO0FBQ1g7QUFDQTs7OztDQUlDLEdBQUcsU0FBU1AsY0FBY0wsSUFBSTtJQUMzQixNQUFNYSxZQUFZYixLQUFLYyxLQUFLLElBQUksRUFBRTtJQUNsQyxNQUFNQyxRQUFRZixLQUFLZ0IsTUFBTSxHQUFHSCxVQUFVSSxNQUFNLENBQUNqQixLQUFLZ0IsTUFBTSxJQUFJSDtJQUM1RCxPQUFPRSxNQUFNRyxJQUFJLENBQUM7QUFDdEI7QUFDQTs7Ozs7OztDQU9DLEdBQUcsU0FBU1AsaUJBQWlCWCxJQUFJLEVBQUVTLEtBQUs7SUFDckMsSUFBSSxDQUFDVCxLQUFLbUIsR0FBRyxFQUNiLE9BQU9WLFVBQVU7SUFDakIsT0FBT1QsS0FBS21CLEdBQUcsS0FBS1Y7QUFDeEIiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tdXRpbHMvZGlzdC9wYXRpZW50LWhlbHBlcnMuanM/YzdmYiJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQG1vZHVsZSBAY2F0ZWdvcnkgVXRpbGl0eSAqLyAvKipcbiAqIEdldHMgdGhlIGZvcm1hdHRlZCBkaXNwbGF5IG5hbWUgZm9yIGEgcGF0aWVudC5cbiAqXG4gKiBUaGUgZGlzcGxheSBuYW1lIHdpbGwgYmUgdGFrZW4gZnJvbSB0aGUgcGF0aWVudCdzICd1c3VhbCcgbmFtZSxcbiAqIG9yIG1heSBmYWxsIGJhY2sgdG8gdGhlIHBhdGllbnQncyAnb2ZmaWNpYWwnIG5hbWUuXG4gKlxuICogQHBhcmFtIHBhdGllbnQgVGhlIHBhdGllbnQgZGV0YWlscyBpbiBGSElSIGZvcm1hdC5cbiAqIEByZXR1cm5zIFRoZSBwYXRpZW50J3MgZGlzcGxheSBuYW1lIG9yIGFuIGVtcHR5IHN0cmluZyBpZiBuYW1lIGlzIG5vdCBwcmVzZW50LlxuICovIGV4cG9ydCBmdW5jdGlvbiBnZXRQYXRpZW50TmFtZShwYXRpZW50KSB7XG4gICAgY29uc3QgbmFtZSA9IHNlbGVjdFByZWZlcnJlZE5hbWUocGF0aWVudCwgJ3VzdWFsJywgJ29mZmljaWFsJyk7XG4gICAgcmV0dXJuIGZvcm1hdFBhdGllbnROYW1lKG5hbWUpO1xufVxuLyoqIEBkZXByZWNhdGVkIFVzZSBgZ2V0UGF0aWVudE5hbWVgICovIGV4cG9ydCBmdW5jdGlvbiBkaXNwbGF5TmFtZShwYXRpZW50KSB7XG4gICAgcmV0dXJuIGdldFBhdGllbnROYW1lKHBhdGllbnQpO1xufVxuLyoqXG4gKiBHZXQgYSBmb3JtYXR0ZWQgZGlzcGxheSBzdHJpbmcgZm9yIGFuIEZISVIgbmFtZS5cbiAqIEBwYXJhbSBuYW1lIFRoZSBuYW1lIHRvIGJlIGZvcm1hdHRlZC5cbiAqIEByZXR1cm5zIFRoZSBmb3JtYXR0ZWQgZGlzcGxheSBuYW1lIG9yIGFuIGVtcHR5IHN0cmluZyBpZiBuYW1lIGlzIHVuZGVmaW5lZC5cbiAqLyBleHBvcnQgZnVuY3Rpb24gZm9ybWF0UGF0aWVudE5hbWUobmFtZSkge1xuICAgIGlmIChuYW1lKSByZXR1cm4gbmFtZS50ZXh0ID8/IGRlZmF1bHRGb3JtYXQobmFtZSk7XG4gICAgcmV0dXJuICcnO1xufVxuLyoqIEBkZXByZWNhdGVkIFVzZSBgZm9ybWF0UGF0aWVudE5hbWVgICovIGV4cG9ydCBmdW5jdGlvbiBmb3JtYXR0ZWROYW1lKG5hbWUpIHtcbiAgICByZXR1cm4gZm9ybWF0UGF0aWVudE5hbWUobmFtZSk7XG59XG4vKipcbiAqIFNlbGVjdCB0aGUgcHJlZmVycmVkIG5hbWUgZnJvbSB0aGUgY29sbGVjdGlvbiBvZiBuYW1lcyBhc3NvY2lhdGVkIHdpdGggYSBwYXRpZW50LlxuICpcbiAqIE5hbWVzIG1heSBiZSBzcGVjaWZpZWQgd2l0aCBhIHVzYWdlIHN1Y2ggYXMgJ3VzdWFsJywgJ29mZmljaWFsJywgJ25pY2tuYW1lJywgJ21haWRlbicsIGV0Yy5cbiAqIEEgbmFtZSB3aXRoIG5vIHVzYWdlIHNwZWNpZmllZCBpcyB0cmVhdGVkIGFzIHRoZSAndXN1YWwnIG5hbWUuXG4gKlxuICogVGhlIGNob3NlbiBuYW1lIHdpbGwgYmUgc2VsZWN0ZWQgYWNjb3JkaW5nIHRvIHRoZSBwcmlvcml0eSBvcmRlciBvZiBgcHJlZmVycmVkTmFtZXNgLFxuICogQGV4YW1wbGVcbiAqIC8vIG5vcm1hbCB1c2UgY2FzZTsgcHJlZmVyIHVzdWFsIG5hbWUsIGZhbGxiYWNrIHRvIG9mZmljaWFsIG5hbWVcbiAqIGRpc3BsYXlOYW1lQnlVc2FnZShwYXRpZW50LCAndXN1YWwnLCAnb2ZmaWNpYWwnKVxuICogQGV4YW1wbGVcbiAqIC8vIHByZWZlciB1c3VhbCBuYW1lIG92ZXIgbmlja25hbWUsIGZhbGxiYWNrIHRvIG9mZmljaWFsIG5hbWVcbiAqIGRpc3BsYXlOYW1lQnlVc2FnZShwYXRpZW50LCAndXN1YWwnLCAnbmlja25hbWUnLCAnb2ZmaWNpYWwnKVxuICpcbiAqIEBwYXJhbSBwYXRpZW50IFRoZSBwYXRpZW50IGZyb20gd2hvbSBhIG5hbWUgd2lsbCBiZSBzZWxlY3RlZC5cbiAqIEBwYXJhbSBwcmVmZXJyZWROYW1lcyBPcHRpb25hbCBvcmRlcmVkIHNlcXVlbmNlIG9mIHByZWZlcnJlZCBuYW1lIHVzYWdlczsgZGVmYXVsdHMgdG8gJ3VzdWFsJyBpZiBub3Qgc3BlY2lmaWVkLlxuICogQHJldHVybiB0aGUgcHJlZmVycmVkIG5hbWUgZm9yIHRoZSBwYXRpZW50LCBvciB1bmRlZmluZWQgaWYgbm8gYWNjZXB0YWJsZSBuYW1lIGNvdWxkIGJlIGZvdW5kLlxuICovIGV4cG9ydCBmdW5jdGlvbiBzZWxlY3RQcmVmZXJyZWROYW1lKHBhdGllbnQsIC4uLnByZWZlcnJlZE5hbWVzKSB7XG4gICAgaWYgKHByZWZlcnJlZE5hbWVzLmxlbmd0aCA9PSAwKSB7XG4gICAgICAgIHByZWZlcnJlZE5hbWVzID0gW1xuICAgICAgICAgICAgJ3VzdWFsJ1xuICAgICAgICBdO1xuICAgIH1cbiAgICBmb3IgKGNvbnN0IHVzYWdlIG9mIHByZWZlcnJlZE5hbWVzKXtcbiAgICAgICAgY29uc3QgbmFtZSA9IHBhdGllbnQubmFtZT8uZmluZCgobmFtZSk9Pm5hbWVVc2FnZU1hdGNoZXMobmFtZSwgdXNhZ2UpKTtcbiAgICAgICAgaWYgKG5hbWUpIHtcbiAgICAgICAgICAgIHJldHVybiBuYW1lO1xuICAgICAgICB9XG4gICAgfVxuICAgIHJldHVybiB1bmRlZmluZWQ7XG59XG4vKipcbiAqIEdlbmVyYXRlIGEgZGlzcGxheSBuYW1lIGJ5IGNvbmNhdGVuYXRpbmcgZm9yZW5hbWVzIGFuZCBzdXJuYW1lLlxuICogQHBhcmFtIG5hbWUgdGhlIHBlcnNvbidzIG5hbWUuXG4gKiBAcmV0dXJucyB0aGUgcGVyc29uJ3MgbmFtZSBhcyBhIHN0cmluZy5cbiAqLyBmdW5jdGlvbiBkZWZhdWx0Rm9ybWF0KG5hbWUpIHtcbiAgICBjb25zdCBmb3JlbmFtZXMgPSBuYW1lLmdpdmVuID8/IFtdO1xuICAgIGNvbnN0IG5hbWVzID0gbmFtZS5mYW1pbHkgPyBmb3JlbmFtZXMuY29uY2F0KG5hbWUuZmFtaWx5KSA6IGZvcmVuYW1lcztcbiAgICByZXR1cm4gbmFtZXMuam9pbignICcpO1xufVxuLyoqXG4gKiBEZXRlcm1pbmUgd2hldGhlciB0aGUgdXNhZ2Ugb2YgYSBnaXZlbiBuYW1lIG1hdGNoZXMgdGhlIGdpdmVuIE5hbWVVc2UuXG4gKlxuICogQSBuYW1lIHdpdGggbm8gdXNhZ2UgaXMgdHJlYXRlZCBhcyB0aGUgJ3VzdWFsJyBuYW1lLlxuICpcbiAqIEBwYXJhbSBuYW1lIHRoZSBuYW1lIHRvIHRlc3QuXG4gKiBAcGFyYW0gdXNhZ2UgdGhlIE5hbWVVc2UgdG8gdGVzdCBmb3IuXG4gKi8gZnVuY3Rpb24gbmFtZVVzYWdlTWF0Y2hlcyhuYW1lLCB1c2FnZSkge1xuICAgIGlmICghbmFtZS51c2UpIC8vIGEgbmFtZSB3aXRoIG5vIHVzYWdlIGlzIHRyZWF0ZWQgYXMgJ3VzdWFsJ1xuICAgIHJldHVybiB1c2FnZSA9PT0gJ3VzdWFsJztcbiAgICByZXR1cm4gbmFtZS51c2UgPT09IHVzYWdlO1xufVxuIl0sIm5hbWVzIjpbImdldFBhdGllbnROYW1lIiwicGF0aWVudCIsIm5hbWUiLCJzZWxlY3RQcmVmZXJyZWROYW1lIiwiZm9ybWF0UGF0aWVudE5hbWUiLCJkaXNwbGF5TmFtZSIsInRleHQiLCJkZWZhdWx0Rm9ybWF0IiwiZm9ybWF0dGVkTmFtZSIsInByZWZlcnJlZE5hbWVzIiwibGVuZ3RoIiwidXNhZ2UiLCJmaW5kIiwibmFtZVVzYWdlTWF0Y2hlcyIsInVuZGVmaW5lZCIsImZvcmVuYW1lcyIsImdpdmVuIiwibmFtZXMiLCJmYW1pbHkiLCJjb25jYXQiLCJqb2luIiwidXNlIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///../../framework/esm-utils/dist/patient-helpers.js\n");
1328
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ displayName: () => (/* binding */ displayName),\n/* harmony export */ formatPatientName: () => (/* binding */ formatPatientName),\n/* harmony export */ formattedName: () => (/* binding */ formattedName),\n/* harmony export */ getPatientName: () => (/* binding */ getPatientName),\n/* harmony export */ selectPreferredName: () => (/* binding */ selectPreferredName)\n/* harmony export */ });\n/** @module @category Utility */ /**\n * Gets the formatted display name for a patient.\n *\n * The display name will be taken from the patient's 'usual' name,\n * or may fall back to the patient's 'official' name.\n *\n * @param patient The patient details in FHIR format.\n * @returns The patient's display name or an empty string if name is not present.\n */ function getPatientName(patient) {\n const name = selectPreferredName(patient, 'usual', 'official');\n return formatPatientName(name);\n}\n/** @deprecated Use `getPatientName` */ function displayName(patient) {\n return getPatientName(patient);\n}\n/**\n * Get a formatted display string for an FHIR name.\n * @param name The name to be formatted.\n * @returns The formatted display name or an empty string if name is undefined.\n */ function formatPatientName(name) {\n if (name) return name.text ?? defaultFormat(name);\n return '';\n}\n/** @deprecated Use `formatPatientName` */ function formattedName(name) {\n return formatPatientName(name);\n}\n/**\n * Select the preferred name from the collection of names associated with a patient.\n *\n * Names may be specified with a usage such as 'usual', 'official', 'nickname', 'maiden', etc.\n * A name with no usage specified is treated as the 'usual' name.\n *\n * The chosen name will be selected according to the priority order of `preferredNames`.\n *\n * @param patient The patient from whom a name will be selected.\n * @param preferredNames Optional ordered sequence of preferred name usages; defaults to 'usual' if not specified.\n * @returns The preferred name for the patient, or undefined if no acceptable name could be found.\n *\n * @example\n * ```ts\n * // normal use case; prefer usual name, fallback to official name\n * selectPreferredName(patient, 'usual', 'official')\n *\n * // prefer usual name over nickname, fallback to official name\n * selectPreferredName(patient, 'usual', 'nickname', 'official')\n * ```\n */ function selectPreferredName(patient, ...preferredNames) {\n if (preferredNames.length == 0) {\n preferredNames = [\n 'usual'\n ];\n }\n for (const usage of preferredNames){\n const name = patient.name?.find((name)=>nameUsageMatches(name, usage));\n if (name) {\n return name;\n }\n }\n return undefined;\n}\n/**\n * Generate a display name by concatenating forenames and surname.\n * @param name the person's name.\n * @returns the person's name as a string.\n */ function defaultFormat(name) {\n const forenames = name.given ?? [];\n const names = name.family ? forenames.concat(name.family) : forenames;\n return names.join(' ');\n}\n/**\n * Determine whether the usage of a given name matches the given NameUse.\n *\n * A name with no usage is treated as the 'usual' name.\n *\n * @param name the name to test.\n * @param usage the NameUse to test for.\n */ function nameUsageMatches(name, usage) {\n if (!name.use) return usage === 'usual';\n return name.use === usage;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS11dGlscy9kaXN0L3BhdGllbnQtaGVscGVycy5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7OztBQUFBLDhCQUE4QixHQUFHOzs7Ozs7OztDQVFoQyxHQUFVLFNBQVNBLGVBQWVDLE9BQU87SUFDdEMsTUFBTUMsT0FBT0Msb0JBQW9CRixTQUFTLFNBQVM7SUFDbkQsT0FBT0csa0JBQWtCRjtBQUM3QjtBQUNBLHFDQUFxQyxHQUFVLFNBQVNHLFlBQVlKLE9BQU87SUFDdkUsT0FBT0QsZUFBZUM7QUFDMUI7QUFDQTs7OztDQUlDLEdBQVUsU0FBU0csa0JBQWtCRixJQUFJO0lBQ3RDLElBQUlBLE1BQU0sT0FBT0EsS0FBS0ksSUFBSSxJQUFJQyxjQUFjTDtJQUM1QyxPQUFPO0FBQ1g7QUFDQSx3Q0FBd0MsR0FBVSxTQUFTTSxjQUFjTixJQUFJO0lBQ3pFLE9BQU9FLGtCQUFrQkY7QUFDN0I7QUFDQTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Q0FvQkMsR0FBVSxTQUFTQyxvQkFBb0JGLE9BQU8sRUFBRSxHQUFHUSxjQUFjO0lBQzlELElBQUlBLGVBQWVDLE1BQU0sSUFBSSxHQUFHO1FBQzVCRCxpQkFBaUI7WUFDYjtTQUNIO0lBQ0w7SUFDQSxLQUFLLE1BQU1FLFNBQVNGLGVBQWU7UUFDL0IsTUFBTVAsT0FBT0QsUUFBUUMsSUFBSSxFQUFFVSxLQUFLLENBQUNWLE9BQU9XLGlCQUFpQlgsTUFBTVM7UUFDL0QsSUFBSVQsTUFBTTtZQUNOLE9BQU9BO1FBQ1g7SUFDSjtJQUNBLE9BQU9ZO0FBQ1g7QUFDQTs7OztDQUlDLEdBQUcsU0FBU1AsY0FBY0wsSUFBSTtJQUMzQixNQUFNYSxZQUFZYixLQUFLYyxLQUFLLElBQUksRUFBRTtJQUNsQyxNQUFNQyxRQUFRZixLQUFLZ0IsTUFBTSxHQUFHSCxVQUFVSSxNQUFNLENBQUNqQixLQUFLZ0IsTUFBTSxJQUFJSDtJQUM1RCxPQUFPRSxNQUFNRyxJQUFJLENBQUM7QUFDdEI7QUFDQTs7Ozs7OztDQU9DLEdBQUcsU0FBU1AsaUJBQWlCWCxJQUFJLEVBQUVTLEtBQUs7SUFDckMsSUFBSSxDQUFDVCxLQUFLbUIsR0FBRyxFQUNiLE9BQU9WLFVBQVU7SUFDakIsT0FBT1QsS0FBS21CLEdBQUcsS0FBS1Y7QUFDeEIiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tdXRpbHMvZGlzdC9wYXRpZW50LWhlbHBlcnMuanM/YzdmYiJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQG1vZHVsZSBAY2F0ZWdvcnkgVXRpbGl0eSAqLyAvKipcbiAqIEdldHMgdGhlIGZvcm1hdHRlZCBkaXNwbGF5IG5hbWUgZm9yIGEgcGF0aWVudC5cbiAqXG4gKiBUaGUgZGlzcGxheSBuYW1lIHdpbGwgYmUgdGFrZW4gZnJvbSB0aGUgcGF0aWVudCdzICd1c3VhbCcgbmFtZSxcbiAqIG9yIG1heSBmYWxsIGJhY2sgdG8gdGhlIHBhdGllbnQncyAnb2ZmaWNpYWwnIG5hbWUuXG4gKlxuICogQHBhcmFtIHBhdGllbnQgVGhlIHBhdGllbnQgZGV0YWlscyBpbiBGSElSIGZvcm1hdC5cbiAqIEByZXR1cm5zIFRoZSBwYXRpZW50J3MgZGlzcGxheSBuYW1lIG9yIGFuIGVtcHR5IHN0cmluZyBpZiBuYW1lIGlzIG5vdCBwcmVzZW50LlxuICovIGV4cG9ydCBmdW5jdGlvbiBnZXRQYXRpZW50TmFtZShwYXRpZW50KSB7XG4gICAgY29uc3QgbmFtZSA9IHNlbGVjdFByZWZlcnJlZE5hbWUocGF0aWVudCwgJ3VzdWFsJywgJ29mZmljaWFsJyk7XG4gICAgcmV0dXJuIGZvcm1hdFBhdGllbnROYW1lKG5hbWUpO1xufVxuLyoqIEBkZXByZWNhdGVkIFVzZSBgZ2V0UGF0aWVudE5hbWVgICovIGV4cG9ydCBmdW5jdGlvbiBkaXNwbGF5TmFtZShwYXRpZW50KSB7XG4gICAgcmV0dXJuIGdldFBhdGllbnROYW1lKHBhdGllbnQpO1xufVxuLyoqXG4gKiBHZXQgYSBmb3JtYXR0ZWQgZGlzcGxheSBzdHJpbmcgZm9yIGFuIEZISVIgbmFtZS5cbiAqIEBwYXJhbSBuYW1lIFRoZSBuYW1lIHRvIGJlIGZvcm1hdHRlZC5cbiAqIEByZXR1cm5zIFRoZSBmb3JtYXR0ZWQgZGlzcGxheSBuYW1lIG9yIGFuIGVtcHR5IHN0cmluZyBpZiBuYW1lIGlzIHVuZGVmaW5lZC5cbiAqLyBleHBvcnQgZnVuY3Rpb24gZm9ybWF0UGF0aWVudE5hbWUobmFtZSkge1xuICAgIGlmIChuYW1lKSByZXR1cm4gbmFtZS50ZXh0ID8/IGRlZmF1bHRGb3JtYXQobmFtZSk7XG4gICAgcmV0dXJuICcnO1xufVxuLyoqIEBkZXByZWNhdGVkIFVzZSBgZm9ybWF0UGF0aWVudE5hbWVgICovIGV4cG9ydCBmdW5jdGlvbiBmb3JtYXR0ZWROYW1lKG5hbWUpIHtcbiAgICByZXR1cm4gZm9ybWF0UGF0aWVudE5hbWUobmFtZSk7XG59XG4vKipcbiAqIFNlbGVjdCB0aGUgcHJlZmVycmVkIG5hbWUgZnJvbSB0aGUgY29sbGVjdGlvbiBvZiBuYW1lcyBhc3NvY2lhdGVkIHdpdGggYSBwYXRpZW50LlxuICpcbiAqIE5hbWVzIG1heSBiZSBzcGVjaWZpZWQgd2l0aCBhIHVzYWdlIHN1Y2ggYXMgJ3VzdWFsJywgJ29mZmljaWFsJywgJ25pY2tuYW1lJywgJ21haWRlbicsIGV0Yy5cbiAqIEEgbmFtZSB3aXRoIG5vIHVzYWdlIHNwZWNpZmllZCBpcyB0cmVhdGVkIGFzIHRoZSAndXN1YWwnIG5hbWUuXG4gKlxuICogVGhlIGNob3NlbiBuYW1lIHdpbGwgYmUgc2VsZWN0ZWQgYWNjb3JkaW5nIHRvIHRoZSBwcmlvcml0eSBvcmRlciBvZiBgcHJlZmVycmVkTmFtZXNgLlxuICpcbiAqIEBwYXJhbSBwYXRpZW50IFRoZSBwYXRpZW50IGZyb20gd2hvbSBhIG5hbWUgd2lsbCBiZSBzZWxlY3RlZC5cbiAqIEBwYXJhbSBwcmVmZXJyZWROYW1lcyBPcHRpb25hbCBvcmRlcmVkIHNlcXVlbmNlIG9mIHByZWZlcnJlZCBuYW1lIHVzYWdlczsgZGVmYXVsdHMgdG8gJ3VzdWFsJyBpZiBub3Qgc3BlY2lmaWVkLlxuICogQHJldHVybnMgVGhlIHByZWZlcnJlZCBuYW1lIGZvciB0aGUgcGF0aWVudCwgb3IgdW5kZWZpbmVkIGlmIG5vIGFjY2VwdGFibGUgbmFtZSBjb3VsZCBiZSBmb3VuZC5cbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHNcbiAqIC8vIG5vcm1hbCB1c2UgY2FzZTsgcHJlZmVyIHVzdWFsIG5hbWUsIGZhbGxiYWNrIHRvIG9mZmljaWFsIG5hbWVcbiAqIHNlbGVjdFByZWZlcnJlZE5hbWUocGF0aWVudCwgJ3VzdWFsJywgJ29mZmljaWFsJylcbiAqXG4gKiAvLyBwcmVmZXIgdXN1YWwgbmFtZSBvdmVyIG5pY2tuYW1lLCBmYWxsYmFjayB0byBvZmZpY2lhbCBuYW1lXG4gKiBzZWxlY3RQcmVmZXJyZWROYW1lKHBhdGllbnQsICd1c3VhbCcsICduaWNrbmFtZScsICdvZmZpY2lhbCcpXG4gKiBgYGBcbiAqLyBleHBvcnQgZnVuY3Rpb24gc2VsZWN0UHJlZmVycmVkTmFtZShwYXRpZW50LCAuLi5wcmVmZXJyZWROYW1lcykge1xuICAgIGlmIChwcmVmZXJyZWROYW1lcy5sZW5ndGggPT0gMCkge1xuICAgICAgICBwcmVmZXJyZWROYW1lcyA9IFtcbiAgICAgICAgICAgICd1c3VhbCdcbiAgICAgICAgXTtcbiAgICB9XG4gICAgZm9yIChjb25zdCB1c2FnZSBvZiBwcmVmZXJyZWROYW1lcyl7XG4gICAgICAgIGNvbnN0IG5hbWUgPSBwYXRpZW50Lm5hbWU/LmZpbmQoKG5hbWUpPT5uYW1lVXNhZ2VNYXRjaGVzKG5hbWUsIHVzYWdlKSk7XG4gICAgICAgIGlmIChuYW1lKSB7XG4gICAgICAgICAgICByZXR1cm4gbmFtZTtcbiAgICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gdW5kZWZpbmVkO1xufVxuLyoqXG4gKiBHZW5lcmF0ZSBhIGRpc3BsYXkgbmFtZSBieSBjb25jYXRlbmF0aW5nIGZvcmVuYW1lcyBhbmQgc3VybmFtZS5cbiAqIEBwYXJhbSBuYW1lIHRoZSBwZXJzb24ncyBuYW1lLlxuICogQHJldHVybnMgdGhlIHBlcnNvbidzIG5hbWUgYXMgYSBzdHJpbmcuXG4gKi8gZnVuY3Rpb24gZGVmYXVsdEZvcm1hdChuYW1lKSB7XG4gICAgY29uc3QgZm9yZW5hbWVzID0gbmFtZS5naXZlbiA/PyBbXTtcbiAgICBjb25zdCBuYW1lcyA9IG5hbWUuZmFtaWx5ID8gZm9yZW5hbWVzLmNvbmNhdChuYW1lLmZhbWlseSkgOiBmb3JlbmFtZXM7XG4gICAgcmV0dXJuIG5hbWVzLmpvaW4oJyAnKTtcbn1cbi8qKlxuICogRGV0ZXJtaW5lIHdoZXRoZXIgdGhlIHVzYWdlIG9mIGEgZ2l2ZW4gbmFtZSBtYXRjaGVzIHRoZSBnaXZlbiBOYW1lVXNlLlxuICpcbiAqIEEgbmFtZSB3aXRoIG5vIHVzYWdlIGlzIHRyZWF0ZWQgYXMgdGhlICd1c3VhbCcgbmFtZS5cbiAqXG4gKiBAcGFyYW0gbmFtZSB0aGUgbmFtZSB0byB0ZXN0LlxuICogQHBhcmFtIHVzYWdlIHRoZSBOYW1lVXNlIHRvIHRlc3QgZm9yLlxuICovIGZ1bmN0aW9uIG5hbWVVc2FnZU1hdGNoZXMobmFtZSwgdXNhZ2UpIHtcbiAgICBpZiAoIW5hbWUudXNlKSAvLyBhIG5hbWUgd2l0aCBubyB1c2FnZSBpcyB0cmVhdGVkIGFzICd1c3VhbCdcbiAgICByZXR1cm4gdXNhZ2UgPT09ICd1c3VhbCc7XG4gICAgcmV0dXJuIG5hbWUudXNlID09PSB1c2FnZTtcbn1cbiJdLCJuYW1lcyI6WyJnZXRQYXRpZW50TmFtZSIsInBhdGllbnQiLCJuYW1lIiwic2VsZWN0UHJlZmVycmVkTmFtZSIsImZvcm1hdFBhdGllbnROYW1lIiwiZGlzcGxheU5hbWUiLCJ0ZXh0IiwiZGVmYXVsdEZvcm1hdCIsImZvcm1hdHRlZE5hbWUiLCJwcmVmZXJyZWROYW1lcyIsImxlbmd0aCIsInVzYWdlIiwiZmluZCIsIm5hbWVVc2FnZU1hdGNoZXMiLCJ1bmRlZmluZWQiLCJmb3JlbmFtZXMiLCJnaXZlbiIsIm5hbWVzIiwiZmFtaWx5IiwiY29uY2F0Iiwiam9pbiIsInVzZSJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///../../framework/esm-utils/dist/patient-helpers.js\n");
1329
1329
 
1330
1330
  /***/ }),
1331
1331
 
@@ -1365,7 +1365,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac
1365
1365
  \*************************************************/
1366
1366
  /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
1367
1367
 
1368
- eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ isVersionSatisfied: () => (/* binding */ isVersionSatisfied)\n/* harmony export */ });\n/* harmony import */ var semver__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! semver */ \"../../../node_modules/semver/index.js\");\n/** @module @category Utility */ \nfunction normalizeOnlyVersion(version) {\n const [major, minor, patch] = version.split('.');\n return `${major}.${minor}.${patch}`;\n}\nfunction normalizeFullVersion(version) {\n const idx = version.indexOf('-');\n const prerelease = idx >= 0;\n if (prerelease) {\n const ver = normalizeOnlyVersion(version.slice(0, idx));\n const pre = version.slice(idx + 1);\n return `${ver}-${pre}`;\n }\n return normalizeOnlyVersion(version);\n}\nfunction isVersionSatisfied(requiredVersion, installedVersion) {\n const version = normalizeFullVersion(installedVersion);\n return semver__WEBPACK_IMPORTED_MODULE_0__.satisfies(version, requiredVersion, {\n includePrerelease: true\n });\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS11dGlscy9kaXN0L3ZlcnNpb24uanMiLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSw4QkFBOEIsR0FBb0M7QUFDbEUsU0FBU0MscUJBQXFCQyxPQUFPO0lBQ2pDLE1BQU0sQ0FBQ0MsT0FBT0MsT0FBT0MsTUFBTSxHQUFHSCxRQUFRSSxLQUFLLENBQUM7SUFDNUMsT0FBTyxHQUFHSCxNQUFNLENBQUMsRUFBRUMsTUFBTSxDQUFDLEVBQUVDLE9BQU87QUFDdkM7QUFDQSxTQUFTRSxxQkFBcUJMLE9BQU87SUFDakMsTUFBTU0sTUFBTU4sUUFBUU8sT0FBTyxDQUFDO0lBQzVCLE1BQU1DLGFBQWFGLE9BQU87SUFDMUIsSUFBSUUsWUFBWTtRQUNaLE1BQU1DLE1BQU1WLHFCQUFxQkMsUUFBUVUsS0FBSyxDQUFDLEdBQUdKO1FBQ2xELE1BQU1LLE1BQU1YLFFBQVFVLEtBQUssQ0FBQ0osTUFBTTtRQUNoQyxPQUFPLEdBQUdHLElBQUksQ0FBQyxFQUFFRSxLQUFLO0lBQzFCO0lBQ0EsT0FBT1oscUJBQXFCQztBQUNoQztBQUNPLFNBQVNZLG1CQUFtQkMsZUFBZSxFQUFFQyxnQkFBZ0I7SUFDaEUsTUFBTWQsVUFBVUsscUJBQXFCUztJQUNyQyxPQUFPaEIsNkNBQWdCLENBQUNFLFNBQVNhLGlCQUFpQjtRQUM5Q0csbUJBQW1CO0lBQ3ZCO0FBQ0oiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9Ab3Blbm1ycy9lc20tYXBwLXNoZWxsLy4uLy4uL2ZyYW1ld29yay9lc20tdXRpbHMvZGlzdC92ZXJzaW9uLmpzP2U0NzMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBtb2R1bGUgQGNhdGVnb3J5IFV0aWxpdHkgKi8gaW1wb3J0ICogYXMgc2VtdmVyIGZyb20gXCJzZW12ZXJcIjtcbmZ1bmN0aW9uIG5vcm1hbGl6ZU9ubHlWZXJzaW9uKHZlcnNpb24pIHtcbiAgICBjb25zdCBbbWFqb3IsIG1pbm9yLCBwYXRjaF0gPSB2ZXJzaW9uLnNwbGl0KCcuJyk7XG4gICAgcmV0dXJuIGAke21ham9yfS4ke21pbm9yfS4ke3BhdGNofWA7XG59XG5mdW5jdGlvbiBub3JtYWxpemVGdWxsVmVyc2lvbih2ZXJzaW9uKSB7XG4gICAgY29uc3QgaWR4ID0gdmVyc2lvbi5pbmRleE9mKCctJyk7XG4gICAgY29uc3QgcHJlcmVsZWFzZSA9IGlkeCA+PSAwO1xuICAgIGlmIChwcmVyZWxlYXNlKSB7XG4gICAgICAgIGNvbnN0IHZlciA9IG5vcm1hbGl6ZU9ubHlWZXJzaW9uKHZlcnNpb24uc2xpY2UoMCwgaWR4KSk7XG4gICAgICAgIGNvbnN0IHByZSA9IHZlcnNpb24uc2xpY2UoaWR4ICsgMSk7XG4gICAgICAgIHJldHVybiBgJHt2ZXJ9LSR7cHJlfWA7XG4gICAgfVxuICAgIHJldHVybiBub3JtYWxpemVPbmx5VmVyc2lvbih2ZXJzaW9uKTtcbn1cbmV4cG9ydCBmdW5jdGlvbiBpc1ZlcnNpb25TYXRpc2ZpZWQocmVxdWlyZWRWZXJzaW9uLCBpbnN0YWxsZWRWZXJzaW9uKSB7XG4gICAgY29uc3QgdmVyc2lvbiA9IG5vcm1hbGl6ZUZ1bGxWZXJzaW9uKGluc3RhbGxlZFZlcnNpb24pO1xuICAgIHJldHVybiBzZW12ZXIuc2F0aXNmaWVzKHZlcnNpb24sIHJlcXVpcmVkVmVyc2lvbiwge1xuICAgICAgICBpbmNsdWRlUHJlcmVsZWFzZTogdHJ1ZVxuICAgIH0pO1xufVxuIl0sIm5hbWVzIjpbInNlbXZlciIsIm5vcm1hbGl6ZU9ubHlWZXJzaW9uIiwidmVyc2lvbiIsIm1ham9yIiwibWlub3IiLCJwYXRjaCIsInNwbGl0Iiwibm9ybWFsaXplRnVsbFZlcnNpb24iLCJpZHgiLCJpbmRleE9mIiwicHJlcmVsZWFzZSIsInZlciIsInNsaWNlIiwicHJlIiwiaXNWZXJzaW9uU2F0aXNmaWVkIiwicmVxdWlyZWRWZXJzaW9uIiwiaW5zdGFsbGVkVmVyc2lvbiIsInNhdGlzZmllcyIsImluY2x1ZGVQcmVyZWxlYXNlIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///../../framework/esm-utils/dist/version.js\n");
1368
+ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ isVersionSatisfied: () => (/* binding */ isVersionSatisfied)\n/* harmony export */ });\n/* harmony import */ var semver__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! semver */ \"../../../node_modules/semver/index.js\");\n/** @module @category Utility */ \nfunction normalizeOnlyVersion(version) {\n const [major, minor, patch] = version.split('.');\n return `${major}.${minor}.${patch}`;\n}\nfunction normalizeFullVersion(version) {\n const idx = version.indexOf('-');\n const prerelease = idx >= 0;\n if (prerelease) {\n const ver = normalizeOnlyVersion(version.slice(0, idx));\n const pre = version.slice(idx + 1);\n return `${ver}-${pre}`;\n }\n return normalizeOnlyVersion(version);\n}\n/**\n * Checks if an installed version satisfies a required version range using\n * semver comparison. Handles prerelease versions and normalizes version strings.\n *\n * @param requiredVersion A semver range string (e.g., \"^1.0.0\", \">=2.0.0\").\n * @param installedVersion The installed version string to check against the range.\n * @returns `true` if the installed version satisfies the required version range.\n *\n */ function isVersionSatisfied(requiredVersion, installedVersion) {\n const version = normalizeFullVersion(installedVersion);\n return semver__WEBPACK_IMPORTED_MODULE_0__.satisfies(version, requiredVersion, {\n includePrerelease: true\n });\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi4vLi4vZnJhbWV3b3JrL2VzbS11dGlscy9kaXN0L3ZlcnNpb24uanMiLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSw4QkFBOEIsR0FBb0M7QUFDbEUsU0FBU0MscUJBQXFCQyxPQUFPO0lBQ2pDLE1BQU0sQ0FBQ0MsT0FBT0MsT0FBT0MsTUFBTSxHQUFHSCxRQUFRSSxLQUFLLENBQUM7SUFDNUMsT0FBTyxHQUFHSCxNQUFNLENBQUMsRUFBRUMsTUFBTSxDQUFDLEVBQUVDLE9BQU87QUFDdkM7QUFDQSxTQUFTRSxxQkFBcUJMLE9BQU87SUFDakMsTUFBTU0sTUFBTU4sUUFBUU8sT0FBTyxDQUFDO0lBQzVCLE1BQU1DLGFBQWFGLE9BQU87SUFDMUIsSUFBSUUsWUFBWTtRQUNaLE1BQU1DLE1BQU1WLHFCQUFxQkMsUUFBUVUsS0FBSyxDQUFDLEdBQUdKO1FBQ2xELE1BQU1LLE1BQU1YLFFBQVFVLEtBQUssQ0FBQ0osTUFBTTtRQUNoQyxPQUFPLEdBQUdHLElBQUksQ0FBQyxFQUFFRSxLQUFLO0lBQzFCO0lBQ0EsT0FBT1oscUJBQXFCQztBQUNoQztBQUNBOzs7Ozs7OztDQVFDLEdBQVUsU0FBU1ksbUJBQW1CQyxlQUFlLEVBQUVDLGdCQUFnQjtJQUNwRSxNQUFNZCxVQUFVSyxxQkFBcUJTO0lBQ3JDLE9BQU9oQiw2Q0FBZ0IsQ0FBQ0UsU0FBU2EsaUJBQWlCO1FBQzlDRyxtQkFBbUI7SUFDdkI7QUFDSiIsInNvdXJjZXMiOlsid2VicGFjazovL0BvcGVubXJzL2VzbS1hcHAtc2hlbGwvLi4vLi4vZnJhbWV3b3JrL2VzbS11dGlscy9kaXN0L3ZlcnNpb24uanM/ZTQ3MyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQG1vZHVsZSBAY2F0ZWdvcnkgVXRpbGl0eSAqLyBpbXBvcnQgKiBhcyBzZW12ZXIgZnJvbSBcInNlbXZlclwiO1xuZnVuY3Rpb24gbm9ybWFsaXplT25seVZlcnNpb24odmVyc2lvbikge1xuICAgIGNvbnN0IFttYWpvciwgbWlub3IsIHBhdGNoXSA9IHZlcnNpb24uc3BsaXQoJy4nKTtcbiAgICByZXR1cm4gYCR7bWFqb3J9LiR7bWlub3J9LiR7cGF0Y2h9YDtcbn1cbmZ1bmN0aW9uIG5vcm1hbGl6ZUZ1bGxWZXJzaW9uKHZlcnNpb24pIHtcbiAgICBjb25zdCBpZHggPSB2ZXJzaW9uLmluZGV4T2YoJy0nKTtcbiAgICBjb25zdCBwcmVyZWxlYXNlID0gaWR4ID49IDA7XG4gICAgaWYgKHByZXJlbGVhc2UpIHtcbiAgICAgICAgY29uc3QgdmVyID0gbm9ybWFsaXplT25seVZlcnNpb24odmVyc2lvbi5zbGljZSgwLCBpZHgpKTtcbiAgICAgICAgY29uc3QgcHJlID0gdmVyc2lvbi5zbGljZShpZHggKyAxKTtcbiAgICAgICAgcmV0dXJuIGAke3Zlcn0tJHtwcmV9YDtcbiAgICB9XG4gICAgcmV0dXJuIG5vcm1hbGl6ZU9ubHlWZXJzaW9uKHZlcnNpb24pO1xufVxuLyoqXG4gKiBDaGVja3MgaWYgYW4gaW5zdGFsbGVkIHZlcnNpb24gc2F0aXNmaWVzIGEgcmVxdWlyZWQgdmVyc2lvbiByYW5nZSB1c2luZ1xuICogc2VtdmVyIGNvbXBhcmlzb24uIEhhbmRsZXMgcHJlcmVsZWFzZSB2ZXJzaW9ucyBhbmQgbm9ybWFsaXplcyB2ZXJzaW9uIHN0cmluZ3MuXG4gKlxuICogQHBhcmFtIHJlcXVpcmVkVmVyc2lvbiBBIHNlbXZlciByYW5nZSBzdHJpbmcgKGUuZy4sIFwiXjEuMC4wXCIsIFwiPj0yLjAuMFwiKS5cbiAqIEBwYXJhbSBpbnN0YWxsZWRWZXJzaW9uIFRoZSBpbnN0YWxsZWQgdmVyc2lvbiBzdHJpbmcgdG8gY2hlY2sgYWdhaW5zdCB0aGUgcmFuZ2UuXG4gKiBAcmV0dXJucyBgdHJ1ZWAgaWYgdGhlIGluc3RhbGxlZCB2ZXJzaW9uIHNhdGlzZmllcyB0aGUgcmVxdWlyZWQgdmVyc2lvbiByYW5nZS5cbiAqXG4gKi8gZXhwb3J0IGZ1bmN0aW9uIGlzVmVyc2lvblNhdGlzZmllZChyZXF1aXJlZFZlcnNpb24sIGluc3RhbGxlZFZlcnNpb24pIHtcbiAgICBjb25zdCB2ZXJzaW9uID0gbm9ybWFsaXplRnVsbFZlcnNpb24oaW5zdGFsbGVkVmVyc2lvbik7XG4gICAgcmV0dXJuIHNlbXZlci5zYXRpc2ZpZXModmVyc2lvbiwgcmVxdWlyZWRWZXJzaW9uLCB7XG4gICAgICAgIGluY2x1ZGVQcmVyZWxlYXNlOiB0cnVlXG4gICAgfSk7XG59XG4iXSwibmFtZXMiOlsic2VtdmVyIiwibm9ybWFsaXplT25seVZlcnNpb24iLCJ2ZXJzaW9uIiwibWFqb3IiLCJtaW5vciIsInBhdGNoIiwic3BsaXQiLCJub3JtYWxpemVGdWxsVmVyc2lvbiIsImlkeCIsImluZGV4T2YiLCJwcmVyZWxlYXNlIiwidmVyIiwic2xpY2UiLCJwcmUiLCJpc1ZlcnNpb25TYXRpc2ZpZWQiLCJyZXF1aXJlZFZlcnNpb24iLCJpbnN0YWxsZWRWZXJzaW9uIiwic2F0aXNmaWVzIiwiaW5jbHVkZVByZXJlbGVhc2UiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///../../framework/esm-utils/dist/version.js\n");
1369
1369
 
1370
1370
  /***/ })
1371
1371