@openmrs/esm-app-shell 9.0.3-pre.4371 → 9.0.3-pre.4380
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.
- package/.turbo/turbo-build.log +3 -3
- package/dist/{8ba959ea5fc57b63.js → 5d652169e71a218c.js} +1 -1
- package/dist/{8ba959ea5fc57b63.js.map → 5d652169e71a218c.js.map} +1 -1
- package/dist/index.html +1 -1
- package/dist/{openmrs.465c88cf327ba1c5.js → openmrs.97749d8135f71369.js} +2 -2
- package/dist/{openmrs.465c88cf327ba1c5.js.map → openmrs.97749d8135f71369.js.map} +1 -1
- package/lib/{50383662cb651f1a.js → 2490f488dac54c7c.js} +2 -2
- package/lib/openmrs.js +3 -3
- package/package.json +3 -3
|
@@ -1760,7 +1760,7 @@ eval("{__webpack_require__.r(__webpack_exports__);\n__webpack_require__.d(__webp
|
|
|
1760
1760
|
},
|
|
1761
1761
|
"../../framework/esm-styleguide/dist/numeric-observation/numeric-observation.component.js"(__unused_rspack_module, __webpack_exports__, __webpack_require__) {
|
|
1762
1762
|
"use strict";
|
|
1763
|
-
eval("{__webpack_require__.r(__webpack_exports__);\n__webpack_require__.d(__webpack_exports__, {\n NumericObservation: () => (NumericObservation)\n});\n/* import */ var react_jsx_runtime__rspack_import_0 = __webpack_require__(\"../../../node_modules/react/jsx-runtime.js\");\n/* import */ var react__rspack_import_1 = __webpack_require__(\"webpack/sharing/consume/default/react/react\");\n/* import */ var react__rspack_import_1_default = /*#__PURE__*/__webpack_require__.n(react__rspack_import_1);\n/* import */ var classnames__rspack_import_2 = __webpack_require__(\"../../../node_modules/classnames/index.js\");\n/* import */ var classnames__rspack_import_2_default = /*#__PURE__*/__webpack_require__.n(classnames__rspack_import_2);\n/* import */ var _openmrs_esm_translations__rspack_import_3 = __webpack_require__(\"../../framework/esm-translations/dist/index.js\");\n/* import */ var _interpretation_utils_js__rspack_import_4 = __webpack_require__(\"../../framework/esm-styleguide/dist/numeric-observation/interpretation-utils.js\");\n/* import */ var _use_concept_reference_range_js__rspack_import_5 = __webpack_require__(\"../../framework/esm-styleguide/dist/numeric-observation/use-concept-reference-range.js\");\n/* import */ var _numeric_observation_module_scss__rspack_import_6 = __webpack_require__(\"../../framework/esm-styleguide/dist/numeric-observation/numeric-observation.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/** @module @category UI */ \n\n\n\n\n\n/**\n * Generic numeric observation component for displaying numeric observation values with interpretation-based styling.\n * Supports both vitals and test results display patterns.\n */ var NumericObservation = function NumericObservation(param) {\n var value = param.value, unit = param.unit, label = param.label, providedInterpretation = param.interpretation, providedReferenceRange = param.referenceRange, conceptUuid = param.conceptUuid, _param_variant = param.variant, variant = _param_variant === void 0 ? 'card' : _param_variant, patientUuid = param.patientUuid;\n var generatedId = (0,react__rspack_import_1.useId)();\n var _useConceptReferenceRange = (0,_use_concept_reference_range_js__rspack_import_5.useConceptReferenceRange)(providedReferenceRange ? undefined : conceptUuid, patientUuid), fetchedReferenceRange = _useConceptReferenceRange.referenceRange, isLoadingConcept = _useConceptReferenceRange.isLoading;\n var referenceRange = providedReferenceRange !== null && providedReferenceRange !== void 0 ? providedReferenceRange : fetchedReferenceRange;\n var calculatedInterpretation = (0,react__rspack_import_1.useMemo)(function() {\n if (providedInterpretation) {\n return (0,_interpretation_utils_js__rspack_import_4.normalizeInterpretation)(providedInterpretation);\n }\n if (referenceRange && !isLoadingConcept) {\n return (0,_interpretation_utils_js__rspack_import_4.calculateInterpretation)(value, referenceRange);\n }\n return 'normal';\n }, [\n providedInterpretation,\n referenceRange,\n value,\n isLoadingConcept\n ]);\n var interpretation = calculatedInterpretation !== null && calculatedInterpretation !== void 0 ? calculatedInterpretation : 'normal';\n var flaggedCritical = interpretation === 'critically_low' || interpretation === 'critically_high' || interpretation === 'off_scale_low' || interpretation === 'off_scale_high';\n var flaggedAbnormal = interpretation !== 'normal';\n var labelId = label ? \"omrs-numeric-obs-label-\".concat(label.replaceAll(/\\s+/g, '-').toLowerCase(), \"-\").concat(generatedId) : undefined;\n var valueId = \"omrs-numeric-obs-value-\".concat(generatedId);\n var unitId = \"omrs-numeric-obs-unit-\".concat(generatedId);\n var hasValue = value != null && value !== '';\n var displayValue = hasValue ? value : (0,_openmrs_esm_translations__rspack_import_3.getCoreTranslation)('notAvailable', 'Not available');\n var _obj;\n var interpretationClasses = classnames__rspack_import_2_default()((_obj = {}, _define_property(_obj, _numeric_observation_module_scss__rspack_import_6[\"default\"][\"critically-low\"], interpretation === 'critically_low' || interpretation === 'off_scale_low'), _define_property(_obj, _numeric_observation_module_scss__rspack_import_6[\"default\"][\"critically-high\"], interpretation === 'critically_high' || interpretation === 'off_scale_high'), _define_property(_obj, _numeric_observation_module_scss__rspack_import_6[\"default\"].low, interpretation === 'low'), _define_property(_obj, _numeric_observation_module_scss__rspack_import_6[\"default\"].high, interpretation === 'high'), _define_property(_obj, _numeric_observation_module_scss__rspack_import_6[\"default\"][\"off-scale-low\"], interpretation === 'off_scale_low'), _define_property(_obj, _numeric_observation_module_scss__rspack_import_6[\"default\"][\"off-scale-high\"], interpretation === 'off_scale_high'), _obj));\n var _obj1;\n var cardContainerClasses = classnames__rspack_import_2_default()((_obj1 = {}, _define_property(_obj1, _numeric_observation_module_scss__rspack_import_6[\"default\"].container, true), _define_property(_obj1, _numeric_observation_module_scss__rspack_import_6[\"default\"].card, true), _define_property(_obj1, _numeric_observation_module_scss__rspack_import_6[\"default\"][\"critical-value\"], flaggedCritical), _define_property(_obj1, _numeric_observation_module_scss__rspack_import_6[\"default\"][\"abnormal-value\"], flaggedAbnormal && !flaggedCritical), _obj1));\n var _obj2;\n var cellClasses = classnames__rspack_import_2_default()((_obj2 = {}, _define_property(_obj2, _numeric_observation_module_scss__rspack_import_6[\"default\"].cell, true), _define_property(_obj2, interpretationClasses, true), _obj2));\n if (variant === 'cell') {\n return /*#__PURE__*/ (0,react_jsx_runtime__rspack_import_0.jsxs)(\"div\", {\n className: cellClasses,\n children: [\n displayValue,\n hasValue && unit ? \" \".concat(unit) : ''\n ]\n });\n }\n return /*#__PURE__*/ (0,react_jsx_runtime__rspack_import_0.jsxs)(\"section\", {\n className: cardContainerClasses,\n \"data-testid\": \"numeric-observation-card\",\n children: [\n label && /*#__PURE__*/ (0,react_jsx_runtime__rspack_import_0.jsxs)(\"div\", {\n className: _numeric_observation_module_scss__rspack_import_6[\"default\"][\"label-container\"],\n children: [\n /*#__PURE__*/ (0,react_jsx_runtime__rspack_import_0.jsx)(\"span\", {\n id: labelId,\n className: _numeric_observation_module_scss__rspack_import_6[\"default\"].label,\n children: label\n }),\n flaggedAbnormal && /*#__PURE__*/ (0,react_jsx_runtime__rspack_import_0.jsx)(\"span\", {\n className: _numeric_observation_module_scss__rspack_import_6[\"default\"][interpretation.replace('_', '-')],\n title: (0,_openmrs_esm_translations__rspack_import_3.getCoreTranslation)('abnormalValue', 'Abnormal value')\n })\n ]\n }),\n /*#__PURE__*/ (0,react_jsx_runtime__rspack_import_0.jsxs)(\"div\", {\n className: _numeric_observation_module_scss__rspack_import_6[\"default\"][\"value-container\"],\n children: [\n /*#__PURE__*/ (0,react_jsx_runtime__rspack_import_0.jsx)(\"span\", {\n id: valueId,\n \"aria-labelledby\": labelId && unitId ? \"\".concat(labelId, \" \").concat(unitId) : labelId || unitId || undefined,\n className: _numeric_observation_module_scss__rspack_import_6[\"default\"].value,\n children: displayValue\n }),\n hasValue && unit && /*#__PURE__*/ (0,react_jsx_runtime__rspack_import_0.jsx)(\"span\", {\n id: unitId,\n className: _numeric_observation_module_scss__rspack_import_6[\"default\"].units,\n children: unit\n })\n ]\n })\n ]\n });\n};\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"builtin:swc-loader!/home/runner/work/openmrs-esm-core/openmrs-esm-core/packages/framework/esm-styleguide/dist/numeric-observation/numeric-observation.component.js","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-styleguide/dist/numeric-observation/numeric-observation.component.js?6f5d"],"sourcesContent":["import { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\n/** @module @category UI */ import React, { useMemo, useId } from \"react\";\nimport classNames from \"classnames\";\nimport { getCoreTranslation } from \"@openmrs/esm-translations\";\nimport { calculateInterpretation, normalizeInterpretation } from \"./interpretation-utils.js\";\nimport { useConceptReferenceRange } from \"./use-concept-reference-range.js\";\nimport styles from \"./numeric-observation.module.scss\";\n/**\n * Generic numeric observation component for displaying numeric observation values with interpretation-based styling.\n * Supports both vitals and test results display patterns.\n */ export const NumericObservation = ({ value, unit, label, interpretation: providedInterpretation, referenceRange: providedReferenceRange, conceptUuid, variant = 'card', patientUuid })=>{\n    const generatedId = useId();\n    const { referenceRange: fetchedReferenceRange, isLoading: isLoadingConcept } = useConceptReferenceRange(providedReferenceRange ? undefined : conceptUuid, patientUuid);\n    const referenceRange = providedReferenceRange ?? fetchedReferenceRange;\n    const calculatedInterpretation = useMemo(()=>{\n        if (providedInterpretation) {\n            return normalizeInterpretation(providedInterpretation);\n        }\n        if (referenceRange && !isLoadingConcept) {\n            return calculateInterpretation(value, referenceRange);\n        }\n        return 'normal';\n    }, [\n        providedInterpretation,\n        referenceRange,\n        value,\n        isLoadingConcept\n    ]);\n    const interpretation = calculatedInterpretation ?? 'normal';\n    const flaggedCritical = interpretation === 'critically_low' || interpretation === 'critically_high' || interpretation === 'off_scale_low' || interpretation === 'off_scale_high';\n    const flaggedAbnormal = interpretation !== 'normal';\n    const labelId = label ? `omrs-numeric-obs-label-${label.replaceAll(/\\s+/g, '-').toLowerCase()}-${generatedId}` : undefined;\n    const valueId = `omrs-numeric-obs-value-${generatedId}`;\n    const unitId = `omrs-numeric-obs-unit-${generatedId}`;\n    const hasValue = value != null && value !== '';\n    const displayValue = hasValue ? value : getCoreTranslation('notAvailable', 'Not available');\n    const interpretationClasses = classNames({\n        [styles['critically-low']]: interpretation === 'critically_low' || interpretation === 'off_scale_low',\n        [styles['critically-high']]: interpretation === 'critically_high' || interpretation === 'off_scale_high',\n        [styles.low]: interpretation === 'low',\n        [styles.high]: interpretation === 'high',\n        [styles['off-scale-low']]: interpretation === 'off_scale_low',\n        [styles['off-scale-high']]: interpretation === 'off_scale_high'\n    });\n    const cardContainerClasses = classNames({\n        [styles.container]: true,\n        [styles.card]: true,\n        [styles['critical-value']]: flaggedCritical,\n        [styles['abnormal-value']]: flaggedAbnormal && !flaggedCritical\n    });\n    const cellClasses = classNames({\n        [styles.cell]: true,\n        [interpretationClasses]: true\n    });\n    if (variant === 'cell') {\n        return /*#__PURE__*/ _jsxs(\"div\", {\n            className: cellClasses,\n            children: [\n                displayValue,\n                hasValue && unit ? ` ${unit}` : ''\n            ]\n        });\n    }\n    return /*#__PURE__*/ _jsxs(\"section\", {\n        className: cardContainerClasses,\n        \"data-testid\": \"numeric-observation-card\",\n        children: [\n            label && /*#__PURE__*/ _jsxs(\"div\", {\n                className: styles['label-container'],\n                children: [\n                    /*#__PURE__*/ _jsx(\"span\", {\n                        id: labelId,\n                        className: styles.label,\n                        children: label\n                    }),\n                    flaggedAbnormal && /*#__PURE__*/ _jsx(\"span\", {\n                        className: styles[interpretation.replace('_', '-')],\n                        title: getCoreTranslation('abnormalValue', 'Abnormal value')\n                    })\n                ]\n            }),\n            /*#__PURE__*/ _jsxs(\"div\", {\n                className: styles['value-container'],\n                children: [\n                    /*#__PURE__*/ _jsx(\"span\", {\n                        id: valueId,\n                        \"aria-labelledby\": labelId && unitId ? `${labelId} ${unitId}` : labelId || unitId || undefined,\n                        className: styles.value,\n                        children: displayValue\n                    }),\n                    hasValue && unit && /*#__PURE__*/ _jsx(\"span\", {\n                        id: unitId,\n                        className: styles.units,\n                        children: unit\n                    })\n                ]\n            })\n        ]\n    });\n};\n"],"names":["jsx","_jsx","jsxs","_jsxs","React","useMemo","useId","classNames","getCoreTranslation","calculateInterpretation","normalizeInterpretation","useConceptReferenceRange","styles","NumericObservation","value","unit","label","providedInterpretation","providedReferenceRange","conceptUuid","variant","patientUuid","generatedId","_useConceptReferenceRange","undefined","fetchedReferenceRange","isLoadingConcept","referenceRange","calculatedInterpretation","interpretation","flaggedCritical","flaggedAbnormal","labelId","valueId","unitId","hasValue","displayValue","_obj","interpretationClasses","_obj1","cardContainerClasses","_obj2","cellClasses"],"mappings":"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"}\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/dist/numeric-observation/numeric-observation.component.js\n\n}");
|
|
1763
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n__webpack_require__.d(__webpack_exports__, {\n NumericObservation: () => (NumericObservation)\n});\n/* import */ var react_jsx_runtime__rspack_import_0 = __webpack_require__(\"../../../node_modules/react/jsx-runtime.js\");\n/* import */ var react__rspack_import_1 = __webpack_require__(\"webpack/sharing/consume/default/react/react\");\n/* import */ var react__rspack_import_1_default = /*#__PURE__*/__webpack_require__.n(react__rspack_import_1);\n/* import */ var classnames__rspack_import_2 = __webpack_require__(\"../../../node_modules/classnames/index.js\");\n/* import */ var classnames__rspack_import_2_default = /*#__PURE__*/__webpack_require__.n(classnames__rspack_import_2);\n/* import */ var _openmrs_esm_translations__rspack_import_3 = __webpack_require__(\"../../framework/esm-translations/dist/index.js\");\n/* import */ var _interpretation_utils_js__rspack_import_4 = __webpack_require__(\"../../framework/esm-styleguide/dist/numeric-observation/interpretation-utils.js\");\n/* import */ var _use_concept_reference_range_js__rspack_import_5 = __webpack_require__(\"../../framework/esm-styleguide/dist/numeric-observation/use-concept-reference-range.js\");\n/* import */ var _numeric_observation_module_scss__rspack_import_6 = __webpack_require__(\"../../framework/esm-styleguide/dist/numeric-observation/numeric-observation.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/** @module @category UI */ \n\n\n\n\n\n/**\n * Generic numeric observation component for displaying numeric observation values with interpretation-based styling.\n * Supports both vitals and test results display patterns.\n */ var NumericObservation = function NumericObservation(param) {\n var value = param.value, unit = param.unit, label = param.label, providedInterpretation = param.interpretation, providedReferenceRange = param.referenceRange, conceptUuid = param.conceptUuid, _param_variant = param.variant, variant = _param_variant === void 0 ? 'card' : _param_variant, patientUuid = param.patientUuid;\n var generatedId = (0,react__rspack_import_1.useId)();\n var _useConceptReferenceRange = (0,_use_concept_reference_range_js__rspack_import_5.useConceptReferenceRange)(providedReferenceRange || providedInterpretation ? undefined : conceptUuid, patientUuid), fetchedReferenceRange = _useConceptReferenceRange.referenceRange, isLoadingConcept = _useConceptReferenceRange.isLoading;\n var referenceRange = providedReferenceRange !== null && providedReferenceRange !== void 0 ? providedReferenceRange : fetchedReferenceRange;\n var calculatedInterpretation = (0,react__rspack_import_1.useMemo)(function() {\n if (providedInterpretation) {\n return (0,_interpretation_utils_js__rspack_import_4.normalizeInterpretation)(providedInterpretation);\n }\n if (referenceRange && !isLoadingConcept) {\n return (0,_interpretation_utils_js__rspack_import_4.calculateInterpretation)(value, referenceRange);\n }\n return 'normal';\n }, [\n providedInterpretation,\n referenceRange,\n value,\n isLoadingConcept\n ]);\n var interpretation = calculatedInterpretation !== null && calculatedInterpretation !== void 0 ? calculatedInterpretation : 'normal';\n var flaggedCritical = interpretation === 'critically_low' || interpretation === 'critically_high' || interpretation === 'off_scale_low' || interpretation === 'off_scale_high';\n var flaggedAbnormal = interpretation !== 'normal';\n var labelId = label ? \"omrs-numeric-obs-label-\".concat(label.replaceAll(/\\s+/g, '-').toLowerCase(), \"-\").concat(generatedId) : undefined;\n var valueId = \"omrs-numeric-obs-value-\".concat(generatedId);\n var unitId = \"omrs-numeric-obs-unit-\".concat(generatedId);\n var hasValue = value != null && value !== '';\n var displayValue = hasValue ? value : (0,_openmrs_esm_translations__rspack_import_3.getCoreTranslation)('notAvailable', 'Not available');\n var _obj;\n var interpretationClasses = classnames__rspack_import_2_default()((_obj = {}, _define_property(_obj, _numeric_observation_module_scss__rspack_import_6[\"default\"][\"critically-low\"], interpretation === 'critically_low' || interpretation === 'off_scale_low'), _define_property(_obj, _numeric_observation_module_scss__rspack_import_6[\"default\"][\"critically-high\"], interpretation === 'critically_high' || interpretation === 'off_scale_high'), _define_property(_obj, _numeric_observation_module_scss__rspack_import_6[\"default\"].low, interpretation === 'low'), _define_property(_obj, _numeric_observation_module_scss__rspack_import_6[\"default\"].high, interpretation === 'high'), _define_property(_obj, _numeric_observation_module_scss__rspack_import_6[\"default\"][\"off-scale-low\"], interpretation === 'off_scale_low'), _define_property(_obj, _numeric_observation_module_scss__rspack_import_6[\"default\"][\"off-scale-high\"], interpretation === 'off_scale_high'), _obj));\n var _obj1;\n var cardContainerClasses = classnames__rspack_import_2_default()((_obj1 = {}, _define_property(_obj1, _numeric_observation_module_scss__rspack_import_6[\"default\"].container, true), _define_property(_obj1, _numeric_observation_module_scss__rspack_import_6[\"default\"].card, true), _define_property(_obj1, _numeric_observation_module_scss__rspack_import_6[\"default\"][\"critical-value\"], flaggedCritical), _define_property(_obj1, _numeric_observation_module_scss__rspack_import_6[\"default\"][\"abnormal-value\"], flaggedAbnormal && !flaggedCritical), _obj1));\n var _obj2;\n var cellClasses = classnames__rspack_import_2_default()((_obj2 = {}, _define_property(_obj2, _numeric_observation_module_scss__rspack_import_6[\"default\"].cell, true), _define_property(_obj2, interpretationClasses, true), _obj2));\n if (variant === 'cell') {\n return /*#__PURE__*/ (0,react_jsx_runtime__rspack_import_0.jsxs)(\"div\", {\n className: cellClasses,\n children: [\n displayValue,\n hasValue && unit ? \" \".concat(unit) : ''\n ]\n });\n }\n return /*#__PURE__*/ (0,react_jsx_runtime__rspack_import_0.jsxs)(\"section\", {\n className: cardContainerClasses,\n \"data-testid\": \"numeric-observation-card\",\n children: [\n label && /*#__PURE__*/ (0,react_jsx_runtime__rspack_import_0.jsxs)(\"div\", {\n className: _numeric_observation_module_scss__rspack_import_6[\"default\"][\"label-container\"],\n children: [\n /*#__PURE__*/ (0,react_jsx_runtime__rspack_import_0.jsx)(\"span\", {\n id: labelId,\n className: _numeric_observation_module_scss__rspack_import_6[\"default\"].label,\n children: label\n }),\n flaggedAbnormal && /*#__PURE__*/ (0,react_jsx_runtime__rspack_import_0.jsx)(\"span\", {\n className: _numeric_observation_module_scss__rspack_import_6[\"default\"][interpretation.replace('_', '-')],\n title: (0,_openmrs_esm_translations__rspack_import_3.getCoreTranslation)('abnormalValue', 'Abnormal value')\n })\n ]\n }),\n /*#__PURE__*/ (0,react_jsx_runtime__rspack_import_0.jsxs)(\"div\", {\n className: _numeric_observation_module_scss__rspack_import_6[\"default\"][\"value-container\"],\n children: [\n /*#__PURE__*/ (0,react_jsx_runtime__rspack_import_0.jsx)(\"span\", {\n id: valueId,\n \"aria-labelledby\": labelId && unitId ? \"\".concat(labelId, \" \").concat(unitId) : labelId || unitId || undefined,\n className: _numeric_observation_module_scss__rspack_import_6[\"default\"].value,\n children: displayValue\n }),\n hasValue && unit && /*#__PURE__*/ (0,react_jsx_runtime__rspack_import_0.jsx)(\"span\", {\n id: unitId,\n className: _numeric_observation_module_scss__rspack_import_6[\"default\"].units,\n children: unit\n })\n ]\n })\n ]\n });\n};\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"builtin:swc-loader!/home/runner/work/openmrs-esm-core/openmrs-esm-core/packages/framework/esm-styleguide/dist/numeric-observation/numeric-observation.component.js","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-styleguide/dist/numeric-observation/numeric-observation.component.js?6f5d"],"sourcesContent":["import { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\n/** @module @category UI */ import React, { useMemo, useId } from \"react\";\nimport classNames from \"classnames\";\nimport { getCoreTranslation } from \"@openmrs/esm-translations\";\nimport { calculateInterpretation, normalizeInterpretation } from \"./interpretation-utils.js\";\nimport { useConceptReferenceRange } from \"./use-concept-reference-range.js\";\nimport styles from \"./numeric-observation.module.scss\";\n/**\n * Generic numeric observation component for displaying numeric observation values with interpretation-based styling.\n * Supports both vitals and test results display patterns.\n */ export const NumericObservation = ({ value, unit, label, interpretation: providedInterpretation, referenceRange: providedReferenceRange, conceptUuid, variant = 'card', patientUuid })=>{\n    const generatedId = useId();\n    const { referenceRange: fetchedReferenceRange, isLoading: isLoadingConcept } = useConceptReferenceRange(providedReferenceRange || providedInterpretation ? undefined : conceptUuid, patientUuid);\n    const referenceRange = providedReferenceRange ?? fetchedReferenceRange;\n    const calculatedInterpretation = useMemo(()=>{\n        if (providedInterpretation) {\n            return normalizeInterpretation(providedInterpretation);\n        }\n        if (referenceRange && !isLoadingConcept) {\n            return calculateInterpretation(value, referenceRange);\n        }\n        return 'normal';\n    }, [\n        providedInterpretation,\n        referenceRange,\n        value,\n        isLoadingConcept\n    ]);\n    const interpretation = calculatedInterpretation ?? 'normal';\n    const flaggedCritical = interpretation === 'critically_low' || interpretation === 'critically_high' || interpretation === 'off_scale_low' || interpretation === 'off_scale_high';\n    const flaggedAbnormal = interpretation !== 'normal';\n    const labelId = label ? `omrs-numeric-obs-label-${label.replaceAll(/\\s+/g, '-').toLowerCase()}-${generatedId}` : undefined;\n    const valueId = `omrs-numeric-obs-value-${generatedId}`;\n    const unitId = `omrs-numeric-obs-unit-${generatedId}`;\n    const hasValue = value != null && value !== '';\n    const displayValue = hasValue ? value : getCoreTranslation('notAvailable', 'Not available');\n    const interpretationClasses = classNames({\n        [styles['critically-low']]: interpretation === 'critically_low' || interpretation === 'off_scale_low',\n        [styles['critically-high']]: interpretation === 'critically_high' || interpretation === 'off_scale_high',\n        [styles.low]: interpretation === 'low',\n        [styles.high]: interpretation === 'high',\n        [styles['off-scale-low']]: interpretation === 'off_scale_low',\n        [styles['off-scale-high']]: interpretation === 'off_scale_high'\n    });\n    const cardContainerClasses = classNames({\n        [styles.container]: true,\n        [styles.card]: true,\n        [styles['critical-value']]: flaggedCritical,\n        [styles['abnormal-value']]: flaggedAbnormal && !flaggedCritical\n    });\n    const cellClasses = classNames({\n        [styles.cell]: true,\n        [interpretationClasses]: true\n    });\n    if (variant === 'cell') {\n        return /*#__PURE__*/ _jsxs(\"div\", {\n            className: cellClasses,\n            children: [\n                displayValue,\n                hasValue && unit ? ` ${unit}` : ''\n            ]\n        });\n    }\n    return /*#__PURE__*/ _jsxs(\"section\", {\n        className: cardContainerClasses,\n        \"data-testid\": \"numeric-observation-card\",\n        children: [\n            label && /*#__PURE__*/ _jsxs(\"div\", {\n                className: styles['label-container'],\n                children: [\n                    /*#__PURE__*/ _jsx(\"span\", {\n                        id: labelId,\n                        className: styles.label,\n                        children: label\n                    }),\n                    flaggedAbnormal && /*#__PURE__*/ _jsx(\"span\", {\n                        className: styles[interpretation.replace('_', '-')],\n                        title: getCoreTranslation('abnormalValue', 'Abnormal value')\n                    })\n                ]\n            }),\n            /*#__PURE__*/ _jsxs(\"div\", {\n                className: styles['value-container'],\n                children: [\n                    /*#__PURE__*/ _jsx(\"span\", {\n                        id: valueId,\n                        \"aria-labelledby\": labelId && unitId ? `${labelId} ${unitId}` : labelId || unitId || undefined,\n                        className: styles.value,\n                        children: displayValue\n                    }),\n                    hasValue && unit && /*#__PURE__*/ _jsx(\"span\", {\n                        id: unitId,\n                        className: styles.units,\n                        children: unit\n                    })\n                ]\n            })\n        ]\n    });\n};\n"],"names":["jsx","_jsx","jsxs","_jsxs","React","useMemo","useId","classNames","getCoreTranslation","calculateInterpretation","normalizeInterpretation","useConceptReferenceRange","styles","NumericObservation","value","unit","label","providedInterpretation","providedReferenceRange","conceptUuid","variant","patientUuid","generatedId","_useConceptReferenceRange","undefined","fetchedReferenceRange","isLoadingConcept","referenceRange","calculatedInterpretation","interpretation","flaggedCritical","flaggedAbnormal","labelId","valueId","unitId","hasValue","displayValue","_obj","interpretationClasses","_obj1","cardContainerClasses","_obj2","cellClasses"],"mappings":"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"}\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/dist/numeric-observation/numeric-observation.component.js\n\n}");
|
|
1764
1764
|
|
|
1765
1765
|
},
|
|
1766
1766
|
"../../framework/esm-styleguide/dist/numeric-observation/use-concept-reference-range.js"(__unused_rspack_module, __webpack_exports__, __webpack_require__) {
|
|
@@ -1955,7 +1955,7 @@ eval("{__webpack_require__.r(__webpack_exports__);\n__webpack_require__.d(__webp
|
|
|
1955
1955
|
},
|
|
1956
1956
|
"../../framework/esm-styleguide/dist/workspaces/workspaces.js"(__unused_rspack_module, __webpack_exports__, __webpack_require__) {
|
|
1957
1957
|
"use strict";
|
|
1958
|
-
eval("{__webpack_require__.r(__webpack_exports__);\n__webpack_require__.d(__webpack_exports__, {\n canCloseWorkspaceWithoutPrompting: () => (canCloseWorkspaceWithoutPrompting),\n cancelPrompt: () => (cancelPrompt),\n changeWorkspaceContext: () => (changeWorkspaceContext),\n closeAllWorkspaces: () => (closeAllWorkspaces),\n closeWorkspace: () => (closeWorkspace),\n getPromptBeforeClosingFcn: () => (getPromptBeforeClosingFcn),\n getWorkspaceGroupStore: () => (getWorkspaceGroupStore),\n getWorkspaceStore: () => (getWorkspaceStore),\n launchWorkspace: () => (launchWorkspace),\n launchWorkspaceGroup: () => (launchWorkspaceGroup),\n navigateAndLaunchWorkspace: () => (navigateAndLaunchWorkspace),\n promptBeforeClosing: () => (promptBeforeClosing),\n resetWorkspaceStore: () => (resetWorkspaceStore),\n showWorkspacePrompts: () => (showWorkspacePrompts),\n updateWorkspaceWindowState: () => (updateWorkspaceWindowState),\n useWorkspaces: () => (useWorkspaces),\n workspaceStore: () => (workspaceStore)\n});\n/* import */ var react__rspack_import_0 = __webpack_require__(\"webpack/sharing/consume/default/react/react\");\n/* import */ var react__rspack_import_0_default = /*#__PURE__*/__webpack_require__.n(react__rspack_import_0);\n/* import */ var _openmrs_esm_extensions__rspack_import_1 = __webpack_require__(\"../../framework/esm-extensions/dist/index.js\");\n/* import */ var _openmrs_esm_navigation__rspack_import_2 = __webpack_require__(\"../../framework/esm-navigation/dist/index.js\");\n/* import */ var _openmrs_esm_state__rspack_import_3 = __webpack_require__(\"../../framework/esm-state/dist/index.js\");\n/* import */ var _openmrs_esm_translations__rspack_import_4 = __webpack_require__(\"../../framework/esm-translations/dist/index.js\");\n/* import */ var _openmrs_esm_react_utils__rspack_import_5 = __webpack_require__(\"../../framework/esm-react-utils/dist/index.js\");\nfunction _array_like_to_array(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];\n return arr2;\n}\nfunction _array_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/** @module @category Workspace */ \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 *\n * @deprecated migrate to workspace v2 and use closeWorkspaceGroup2 instead. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\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 *\n * @deprecated migrate to workspace v2 and use launchWorkspaceGroup2 instead. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\n */ function launchWorkspaceGroup(groupName, args) {\n var workspaceGroupRegistration = (0,_openmrs_esm_extensions__rspack_import_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__rspack_import_1.getWorkspaceRegistration)(name);\n var proceed = function 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: function onWorkspaceClose() {\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 *\n * @deprecated migrate to workspace v2 and use launchWorkspace2 instead. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\n */ function launchWorkspace(name, additionalProps) {\n var _currentWorkspaceGroup_members, _store_getState_workspaceGroup;\n var store = getWorkspaceStore();\n var workspace = (0,_openmrs_esm_extensions__rspack_import_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 closeWorkspace1() {\n var options = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {};\n return closeWorkspace(name, options);\n },\n closeWorkspaceWithSavedChanges: function closeWorkspaceWithSavedChanges(options) {\n return closeWorkspace(name, _object_spread({\n ignoreChanges: true\n }, options));\n },\n promptBeforeClosing: function promptBeforeClosing1(testFcn) {\n return promptBeforeClosing(name, testFcn);\n },\n setTitle: function setTitle(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 *\n * @deprecated migrate to workspace v2 and call launchWorkspace2 instead. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\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__rspack_import_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 onWorkspaceClose() {},\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 *\n * @deprecated migrate to workspace v2 and call closeWorkspace from Workspace2DefinitionProps instead. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\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 updateStoreWithClosedWorkspace() {\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__rspack_import_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__rspack_import_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 _ref;\n return (_ref = workspaceAtTop === null || workspaceAtTop === void 0 ? void 0 : workspaceAtTop.preferredWindowSize) !== null && _ref !== void 0 ? _ref : '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 updateWorkspaceStore() {\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}\n/**\n * @deprecated migrate to workspace v2. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\n */ function useWorkspaces() {\n var _useStore = (0,_openmrs_esm_react_utils__rspack_import_5.useStore)(workspaceStore), workspaceWindowState = _useStore.workspaceWindowState, openWorkspaces = _useStore.openWorkspaces, prompt = _useStore.prompt, workspaceGroup = _useStore.workspaceGroup;\n var memoisedResults = (0,react__rspack_import_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__rspack_import_4.getCoreTranslation)('unsavedChangesTitleText', 'Unsaved changes'),\n body: (0,_openmrs_esm_translations__rspack_import_4.getCoreTranslation)('unsavedChangesInOpenedWorkspace', \"You may have unsaved changes in the opened workspace. Do you want to discard these changes?\"),\n onConfirm: function onConfirm() {\n onConfirmation === null || onConfirmation === void 0 ? void 0 : onConfirmation();\n },\n confirmText: (0,_openmrs_esm_translations__rspack_import_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__rspack_import_4.getCoreTranslation)('closingAllWorkspacesPromptTitle', 'You have unsaved changes'),\n body: (0,_openmrs_esm_translations__rspack_import_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 onConfirm() {\n onConfirmation === null || onConfirmation === void 0 ? void 0 : onConfirmation();\n },\n confirmText: (0,_openmrs_esm_translations__rspack_import_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__rspack_import_4.getCoreTranslation)('unsavedChangesTitleText', 'Unsaved changes'),\n body: (0,_openmrs_esm_translations__rspack_import_4.getCoreTranslation)('unsavedChangesInWorkspace', 'There may be unsaved changes in \"{{workspaceName}}\". Please save them before opening another workspace.', {\n workspaceName: workspaceTitle\n }),\n onConfirm: function onConfirm() {\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__rspack_import_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 _ref;\n return (_ref = additionalProps === null || additionalProps === void 0 ? void 0 : additionalProps['workspaceTitle']) !== null && _ref !== void 0 ? _ref : 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__rspack_import_3.getGlobalStore)(workspaceGroupName, {});\n if (additionalProps) {\n store.setState(function(prev) {\n return _object_spread({}, prev, additionalProps);\n });\n }\n return store;\n}\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"builtin:swc-loader!/home/runner/work/openmrs-esm-core/openmrs-esm-core/packages/framework/esm-styleguide/dist/workspaces/workspaces.js","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-styleguide/dist/workspaces/workspaces.js?7e90"],"sourcesContent":["/** @module @category Workspace */ import { useMemo } from \"react\";\nimport { getWorkspaceGroupRegistration, getWorkspaceRegistration } from \"@openmrs/esm-extensions\";\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/**\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 */ export function canCloseWorkspaceWithoutPrompting(name, ignoreChanges = false) {\n    if (ignoreChanges) {\n        return true;\n    }\n    const 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 *\n * @deprecated migrate to workspace v2 and use closeWorkspaceGroup2 instead. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\n */ function closeWorkspaceGroup(groupName, onWorkspaceCloseup) {\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 = currentGroupName ? (workspace)=>workspace.currentWorkspaceGroup === currentGroupName : ()=>true;\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        if (typeof currentWorkspaceGroup?.cleanup === 'function') {\n            currentWorkspaceGroup.cleanup();\n        }\n        store.setState((prev)=>({\n                ...prev,\n                workspaceGroup: undefined\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 *\n * @deprecated migrate to workspace v2 and use launchWorkspaceGroup2 instead. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\n */ export function launchWorkspaceGroup(groupName, args) {\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}\nfunction promptBeforeLaunchingWorkspace(workspace, newWorkspaceDetails) {\n    const { name, additionalProps } = newWorkspaceDetails;\n    const newWorkspaceRegistration = getWorkspaceRegistration(name);\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    if (!canCloseWorkspaceWithoutPrompting(workspace.name)) {\n        showWorkspacePrompts('closing-workspace-launching-new-workspace', proceed, 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 *\n * @deprecated migrate to workspace v2 and use launchWorkspace2 instead. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\n */ export function launchWorkspace(name, additionalProps) {\n    const store = getWorkspaceStore();\n    const workspace = getWorkspaceRegistration(name);\n    const currentWorkspaceGroup = store.getState().workspaceGroup;\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 = {\n        ...workspace,\n        title: getWorkspaceTitle(workspace, additionalProps),\n        closeWorkspace: (options = {})=>closeWorkspace(name, options),\n        closeWorkspaceWithSavedChanges: (options)=>closeWorkspace(name, {\n                ignoreChanges: true,\n                ...options\n            }),\n        promptBeforeClosing: (testFcn)=>promptBeforeClosing(name, testFcn),\n        setTitle: (title, titleNode)=>{\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    if (currentGroupName) {\n        getWorkspaceGroupStore(currentGroupName, additionalProps);\n    }\n    function updateStoreWithNewWorkspace(workspaceToBeAdded, restOfTheWorkspaces) {\n        store.setState((state)=>{\n            const openWorkspaces = [\n                workspaceToBeAdded,\n                ...restOfTheWorkspaces ?? state.openWorkspaces\n            ];\n            let workspaceWindowState = getUpdatedWorkspaceWindowState(workspaceToBeAdded);\n            return {\n                ...state,\n                openWorkspaces,\n                workspaceWindowState\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    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 * 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 *\n * @deprecated migrate to workspace v2 and call launchWorkspace2 instead. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\n */ export function navigateAndLaunchWorkspace({ targetUrl, contextKey, workspaceName, additionalProps }) {\n    changeWorkspaceContext(contextKey);\n    launchWorkspace(workspaceName, additionalProps);\n    navigate({\n        to: targetUrl\n    });\n}\nconst promptBeforeClosingFcns = {};\nexport function promptBeforeClosing(workspaceName, testFcn) {\n    promptBeforeClosingFcns[workspaceName] = testFcn;\n}\nexport function getPromptBeforeClosingFcn(workspaceName) {\n    return promptBeforeClosingFcns[workspaceName];\n}\nexport function cancelPrompt() {\n    const store = getWorkspaceStore();\n    const state = store.getState();\n    store.setState({\n        ...state,\n        prompt: null\n    });\n}\nconst defaultOptions = {\n    ignoreChanges: false,\n    onWorkspaceClose: ()=>{},\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 *\n * @deprecated migrate to workspace v2 and call closeWorkspace from Workspace2DefinitionProps instead. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\n */ export function closeWorkspace(name, options = {}) {\n    options = {\n        ...defaultOptions,\n        ...options\n    };\n    const store = getWorkspaceStore();\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        const workspaceGroupName = store.getState().workspaceGroup?.name;\n        if (workspaceGroupName && options.closeWorkspaceGroup) {\n            closeWorkspaceGroup(workspaceGroupName);\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        options?.onWorkspaceClose?.();\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 * 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 */ export function changeWorkspaceContext(contextKey) {\n    const store = getWorkspaceStore();\n    const state = store.getState();\n    if (state.context != contextKey) {\n        store.setState({\n            context: contextKey,\n            openWorkspaces: [],\n            prompt: null\n        });\n    }\n}\nconst initialState = {\n    context: '',\n    openWorkspaces: [],\n    prompt: null,\n    workspaceWindowState: 'normal',\n    workspaceGroup: undefined\n};\nexport const workspaceStore = createGlobalStore('workspace', initialState);\nexport function getWorkspaceStore() {\n    return workspaceStore;\n}\nexport function updateWorkspaceWindowState(value) {\n    const store = getWorkspaceStore();\n    const state = store.getState();\n    store.setState({\n        ...state,\n        workspaceWindowState: value\n    });\n}\nfunction getUpdatedWorkspaceWindowState(workspaceAtTop) {\n    return workspaceAtTop?.preferredWindowSize ?? 'normal';\n}\nexport function closeAllWorkspaces(onClosingWorkspaces = ()=>{}, filter = ()=>true) {\n    const store = getWorkspaceStore();\n    const canCloseAllWorkspaces = store.getState().openWorkspaces.filter(filter).every(({ name })=>{\n        return canCloseWorkspaceWithoutPrompting(name);\n    });\n    const updateWorkspaceStore = ()=>{\n        resetWorkspaceStore();\n        onClosingWorkspaces?.();\n    };\n    if (!canCloseAllWorkspaces) {\n        showWorkspacePrompts('closing-all-workspaces', updateWorkspaceStore);\n    } else {\n        updateWorkspaceStore();\n    }\n}\n/**\n * @deprecated migrate to workspace v2. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\n */ export function useWorkspaces() {\n    const { workspaceWindowState, openWorkspaces, prompt, workspaceGroup } = useStore(workspaceStore);\n    const memoisedResults = useMemo(()=>{\n        return {\n            active: openWorkspaces.length > 0,\n            prompt,\n            workspaceWindowState,\n            workspaces: openWorkspaces,\n            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 */ export function showWorkspacePrompts(promptType, onConfirmation = ()=>{}, workspaceTitle = '') {\n    const store = getWorkspaceStore();\n    let prompt;\n    switch(promptType){\n        case 'closing-workspace':\n            {\n                prompt = {\n                    title: getCoreTranslation('unsavedChangesTitleText', 'Unsaved changes'),\n                    body: getCoreTranslation('unsavedChangesInOpenedWorkspace', `You may have unsaved changes in the opened workspace. Do you want to discard these changes?`),\n                    onConfirm: ()=>{\n                        onConfirmation?.();\n                    },\n                    confirmText: getCoreTranslation('discard', 'Discard')\n                };\n                break;\n            }\n        case 'closing-all-workspaces':\n            {\n                const workspacesNotClosed = store.getState().openWorkspaces.filter(({ name })=>!canCloseWorkspaceWithoutPrompting(name)).map(({ title }, indx)=>`${indx + 1}. ${title}`);\n                prompt = {\n                    title: getCoreTranslation('closingAllWorkspacesPromptTitle', 'You have unsaved changes'),\n                    body: 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: ()=>{\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            {\n                prompt = {\n                    title: getCoreTranslation('unsavedChangesTitleText', 'Unsaved changes'),\n                    body: getCoreTranslation('unsavedChangesInWorkspace', '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            {\n                console.error(`Workspace system trying to open unknown prompt type \"${promptType}\" in function \"showWorkspacePrompts\"`);\n                onConfirmation?.();\n                return;\n            }\n    }\n    store.setState((state)=>({\n            ...state,\n            prompt\n        }));\n}\nfunction getWorkspaceTitle(workspace, additionalProps) {\n    return additionalProps?.['workspaceTitle'] ?? workspace.title;\n}\nexport function 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 */ export function getWorkspaceGroupStore(workspaceGroupName, additionalProps = {}) {\n    if (!workspaceGroupName || workspaceGroupName === 'default') {\n        return undefined;\n    }\n    const store = getGlobalStore(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_getState","store","getWorkspaceStore","currentWorkspaceGroup","currentGroupName","filter","workspace","closeAllWorkspaces","workspaceGroupStore","getWorkspaceGroupStore","unsubscribe","prev","undefined","launchWorkspaceGroup","args","workspaceGroupRegistration","state","onWorkspaceGroupLaunch","workspaceGroupCleanup","workspaceToLaunch","workspaceGroup","_workspaceToLaunch_additionalProps","launchWorkspace","promptBeforeLaunchingWorkspace","newWorkspaceDetails","additionalProps","newWorkspaceRegistration","proceed","closeWorkspace","onWorkspaceClose","_workspace_title","showWorkspacePrompts","_currentWorkspaceGroup_members","_store_getState_workspaceGroup","newWorkspace","getWorkspaceTitle","closeWorkspace1","options","closeWorkspaceWithSavedChanges","promptBeforeClosing1","testFcn","promptBeforeClosing","setTitle","title","titleNode","openWorkspaces","w","updateStoreWithNewWorkspace","workspaceToBeAdded","restOfTheWorkspaces","workspaceWindowState","getUpdatedWorkspaceWindowState","workspaceIndexInOpenWorkspaces","isWorkspaceAlreadyOpen","openedWorkspaceWithSameType","openWorkspace","restOfTheWorkspaces1","navigateAndLaunchWorkspace","param","targetUrl","contextKey","workspaceName","changeWorkspaceContext","promptBeforeClosingFcns","cancelPrompt","defaultOptions","updateStoreWithClosedWorkspace","workspaceToBeClosed","newOpenWorkspaces","workspaceGroupName","_getWorkspaceRegistration_title","currentName","initialState","workspaceStore","updateWorkspaceWindowState","value","workspaceAtTop","onClosingWorkspaces","canCloseAllWorkspaces","updateWorkspaceStore","resetWorkspaceStore","useWorkspaces","_useStore","prompt","memoisedResults","promptType","onConfirmation","workspaceTitle","onConfirm","workspacesNotClosed","indx","console"],"mappings":"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"}\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/dist/workspaces/workspaces.js\n\n}");
|
|
1958
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n__webpack_require__.d(__webpack_exports__, {\n canCloseWorkspaceWithoutPrompting: () => (canCloseWorkspaceWithoutPrompting),\n cancelPrompt: () => (cancelPrompt),\n changeWorkspaceContext: () => (changeWorkspaceContext),\n closeAllWorkspaces: () => (closeAllWorkspaces),\n closeWorkspace: () => (closeWorkspace),\n getPromptBeforeClosingFcn: () => (getPromptBeforeClosingFcn),\n getWorkspaceGroupStore: () => (getWorkspaceGroupStore),\n getWorkspaceStore: () => (getWorkspaceStore),\n launchWorkspace: () => (launchWorkspace),\n launchWorkspaceGroup: () => (launchWorkspaceGroup),\n navigateAndLaunchWorkspace: () => (navigateAndLaunchWorkspace),\n promptBeforeClosing: () => (promptBeforeClosing),\n resetWorkspaceStore: () => (resetWorkspaceStore),\n showWorkspacePrompts: () => (showWorkspacePrompts),\n updateWorkspaceWindowState: () => (updateWorkspaceWindowState),\n useWorkspaces: () => (useWorkspaces),\n workspaceStore: () => (workspaceStore)\n});\n/* import */ var react__rspack_import_0 = __webpack_require__(\"webpack/sharing/consume/default/react/react\");\n/* import */ var react__rspack_import_0_default = /*#__PURE__*/__webpack_require__.n(react__rspack_import_0);\n/* import */ var _openmrs_esm_extensions__rspack_import_1 = __webpack_require__(\"../../framework/esm-extensions/dist/index.js\");\n/* import */ var _openmrs_esm_navigation__rspack_import_2 = __webpack_require__(\"../../framework/esm-navigation/dist/index.js\");\n/* import */ var _openmrs_esm_state__rspack_import_3 = __webpack_require__(\"../../framework/esm-state/dist/index.js\");\n/* import */ var _openmrs_esm_translations__rspack_import_4 = __webpack_require__(\"../../framework/esm-translations/dist/index.js\");\n/* import */ var _openmrs_esm_react_utils__rspack_import_5 = __webpack_require__(\"../../framework/esm-react-utils/dist/index.js\");\nfunction _array_like_to_array(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];\n return arr2;\n}\nfunction _array_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/** @module @category Workspace */ \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 *\n * @deprecated migrate to workspace v2 and use closeWorkspaceGroup2 instead. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\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 *\n * @deprecated migrate to workspace v2 and use launchWorkspaceGroup2 instead. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\n */ function launchWorkspaceGroup(groupName, args) {\n var workspaceGroupRegistration = (0,_openmrs_esm_extensions__rspack_import_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__rspack_import_1.getWorkspaceRegistration)(name);\n var proceed = function 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: function onWorkspaceClose() {\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 *\n * @deprecated migrate to workspace v2 and use launchWorkspace2 instead. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\n */ function launchWorkspace(name, additionalProps) {\n var _currentWorkspaceGroup_members, _store_getState_workspaceGroup;\n var store = getWorkspaceStore();\n var workspace = (0,_openmrs_esm_extensions__rspack_import_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 closeWorkspace1() {\n var options = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {};\n return closeWorkspace(name, options);\n },\n closeWorkspaceWithSavedChanges: function closeWorkspaceWithSavedChanges(options) {\n return closeWorkspace(name, _object_spread({\n ignoreChanges: true\n }, options));\n },\n promptBeforeClosing: function promptBeforeClosing1(testFcn) {\n return promptBeforeClosing(name, testFcn);\n },\n setTitle: function setTitle(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 // Create a new object reference so that WorkspaceRenderer's useMemo\n // detects the change and re-renders with the updated additionalProps.\n var updatedWorkspace = _object_spread(_object_spread_props(_object_spread({}, openWorkspace), {\n additionalProps: newWorkspace.additionalProps\n }), openWorkspace.title === getWorkspaceTitle(openWorkspace, openWorkspace.additionalProps) && {\n title: getWorkspaceTitle(newWorkspace, newWorkspace.additionalProps)\n });\n var restOfTheWorkspaces = openWorkspaces.filter(function(w) {\n return w.name != name;\n });\n updateStoreWithNewWorkspace(updatedWorkspace, 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 *\n * @deprecated migrate to workspace v2 and call launchWorkspace2 instead. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\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__rspack_import_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 onWorkspaceClose() {},\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 *\n * @deprecated migrate to workspace v2 and call closeWorkspace from Workspace2DefinitionProps instead. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\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 updateStoreWithClosedWorkspace() {\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__rspack_import_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__rspack_import_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 _ref;\n return (_ref = workspaceAtTop === null || workspaceAtTop === void 0 ? void 0 : workspaceAtTop.preferredWindowSize) !== null && _ref !== void 0 ? _ref : '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 updateWorkspaceStore() {\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}\n/**\n * @deprecated migrate to workspace v2. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\n */ function useWorkspaces() {\n var _useStore = (0,_openmrs_esm_react_utils__rspack_import_5.useStore)(workspaceStore), workspaceWindowState = _useStore.workspaceWindowState, openWorkspaces = _useStore.openWorkspaces, prompt = _useStore.prompt, workspaceGroup = _useStore.workspaceGroup;\n var memoisedResults = (0,react__rspack_import_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__rspack_import_4.getCoreTranslation)('unsavedChangesTitleText', 'Unsaved changes'),\n body: (0,_openmrs_esm_translations__rspack_import_4.getCoreTranslation)('unsavedChangesInOpenedWorkspace', \"You may have unsaved changes in the opened workspace. Do you want to discard these changes?\"),\n onConfirm: function onConfirm() {\n onConfirmation === null || onConfirmation === void 0 ? void 0 : onConfirmation();\n },\n confirmText: (0,_openmrs_esm_translations__rspack_import_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__rspack_import_4.getCoreTranslation)('closingAllWorkspacesPromptTitle', 'You have unsaved changes'),\n body: (0,_openmrs_esm_translations__rspack_import_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 onConfirm() {\n onConfirmation === null || onConfirmation === void 0 ? void 0 : onConfirmation();\n },\n confirmText: (0,_openmrs_esm_translations__rspack_import_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__rspack_import_4.getCoreTranslation)('unsavedChangesTitleText', 'Unsaved changes'),\n body: (0,_openmrs_esm_translations__rspack_import_4.getCoreTranslation)('unsavedChangesInWorkspace', 'There may be unsaved changes in \"{{workspaceName}}\". Please save them before opening another workspace.', {\n workspaceName: workspaceTitle\n }),\n onConfirm: function onConfirm() {\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__rspack_import_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 _ref;\n return (_ref = additionalProps === null || additionalProps === void 0 ? void 0 : additionalProps['workspaceTitle']) !== null && _ref !== void 0 ? _ref : 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__rspack_import_3.getGlobalStore)(workspaceGroupName, {});\n if (additionalProps) {\n store.setState(function(prev) {\n return _object_spread({}, prev, additionalProps);\n });\n }\n return store;\n}\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"builtin:swc-loader!/home/runner/work/openmrs-esm-core/openmrs-esm-core/packages/framework/esm-styleguide/dist/workspaces/workspaces.js","sources":["webpack://@openmrs/esm-app-shell/../../framework/esm-styleguide/dist/workspaces/workspaces.js?7e90"],"sourcesContent":["/** @module @category Workspace */ import { useMemo } from \"react\";\nimport { getWorkspaceGroupRegistration, getWorkspaceRegistration } from \"@openmrs/esm-extensions\";\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/**\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 */ export function canCloseWorkspaceWithoutPrompting(name, ignoreChanges = false) {\n    if (ignoreChanges) {\n        return true;\n    }\n    const 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 *\n * @deprecated migrate to workspace v2 and use closeWorkspaceGroup2 instead. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\n */ function closeWorkspaceGroup(groupName, onWorkspaceCloseup) {\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 = currentGroupName ? (workspace)=>workspace.currentWorkspaceGroup === currentGroupName : ()=>true;\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        if (typeof currentWorkspaceGroup?.cleanup === 'function') {\n            currentWorkspaceGroup.cleanup();\n        }\n        store.setState((prev)=>({\n                ...prev,\n                workspaceGroup: undefined\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 *\n * @deprecated migrate to workspace v2 and use launchWorkspaceGroup2 instead. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\n */ export function launchWorkspaceGroup(groupName, args) {\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}\nfunction promptBeforeLaunchingWorkspace(workspace, newWorkspaceDetails) {\n    const { name, additionalProps } = newWorkspaceDetails;\n    const newWorkspaceRegistration = getWorkspaceRegistration(name);\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    if (!canCloseWorkspaceWithoutPrompting(workspace.name)) {\n        showWorkspacePrompts('closing-workspace-launching-new-workspace', proceed, 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 *\n * @deprecated migrate to workspace v2 and use launchWorkspace2 instead. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\n */ export function launchWorkspace(name, additionalProps) {\n    const store = getWorkspaceStore();\n    const workspace = getWorkspaceRegistration(name);\n    const currentWorkspaceGroup = store.getState().workspaceGroup;\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 = {\n        ...workspace,\n        title: getWorkspaceTitle(workspace, additionalProps),\n        closeWorkspace: (options = {})=>closeWorkspace(name, options),\n        closeWorkspaceWithSavedChanges: (options)=>closeWorkspace(name, {\n                ignoreChanges: true,\n                ...options\n            }),\n        promptBeforeClosing: (testFcn)=>promptBeforeClosing(name, testFcn),\n        setTitle: (title, titleNode)=>{\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    if (currentGroupName) {\n        getWorkspaceGroupStore(currentGroupName, additionalProps);\n    }\n    function updateStoreWithNewWorkspace(workspaceToBeAdded, restOfTheWorkspaces) {\n        store.setState((state)=>{\n            const openWorkspaces = [\n                workspaceToBeAdded,\n                ...restOfTheWorkspaces ?? state.openWorkspaces\n            ];\n            let workspaceWindowState = getUpdatedWorkspaceWindowState(workspaceToBeAdded);\n            return {\n                ...state,\n                openWorkspaces,\n                workspaceWindowState\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    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        // Create a new object reference so that WorkspaceRenderer's useMemo\n        // detects the change and re-renders with the updated additionalProps.\n        const updatedWorkspace = {\n            ...openWorkspace,\n            additionalProps: newWorkspace.additionalProps,\n            // Only update the title if it hasn't been set by `setTitle`\n            ...openWorkspace.title === getWorkspaceTitle(openWorkspace, openWorkspace.additionalProps) && {\n                title: getWorkspaceTitle(newWorkspace, newWorkspace.additionalProps)\n            }\n        };\n        const restOfTheWorkspaces = openWorkspaces.filter((w)=>w.name != name);\n        updateStoreWithNewWorkspace(updatedWorkspace, 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 * 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 *\n * @deprecated migrate to workspace v2 and call launchWorkspace2 instead. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\n */ export function navigateAndLaunchWorkspace({ targetUrl, contextKey, workspaceName, additionalProps }) {\n    changeWorkspaceContext(contextKey);\n    launchWorkspace(workspaceName, additionalProps);\n    navigate({\n        to: targetUrl\n    });\n}\nconst promptBeforeClosingFcns = {};\nexport function promptBeforeClosing(workspaceName, testFcn) {\n    promptBeforeClosingFcns[workspaceName] = testFcn;\n}\nexport function getPromptBeforeClosingFcn(workspaceName) {\n    return promptBeforeClosingFcns[workspaceName];\n}\nexport function cancelPrompt() {\n    const store = getWorkspaceStore();\n    const state = store.getState();\n    store.setState({\n        ...state,\n        prompt: null\n    });\n}\nconst defaultOptions = {\n    ignoreChanges: false,\n    onWorkspaceClose: ()=>{},\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 *\n * @deprecated migrate to workspace v2 and call closeWorkspace from Workspace2DefinitionProps instead. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\n */ export function closeWorkspace(name, options = {}) {\n    options = {\n        ...defaultOptions,\n        ...options\n    };\n    const store = getWorkspaceStore();\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        const workspaceGroupName = store.getState().workspaceGroup?.name;\n        if (workspaceGroupName && options.closeWorkspaceGroup) {\n            closeWorkspaceGroup(workspaceGroupName);\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        options?.onWorkspaceClose?.();\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 * 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 */ export function changeWorkspaceContext(contextKey) {\n    const store = getWorkspaceStore();\n    const state = store.getState();\n    if (state.context != contextKey) {\n        store.setState({\n            context: contextKey,\n            openWorkspaces: [],\n            prompt: null\n        });\n    }\n}\nconst initialState = {\n    context: '',\n    openWorkspaces: [],\n    prompt: null,\n    workspaceWindowState: 'normal',\n    workspaceGroup: undefined\n};\nexport const workspaceStore = createGlobalStore('workspace', initialState);\nexport function getWorkspaceStore() {\n    return workspaceStore;\n}\nexport function updateWorkspaceWindowState(value) {\n    const store = getWorkspaceStore();\n    const state = store.getState();\n    store.setState({\n        ...state,\n        workspaceWindowState: value\n    });\n}\nfunction getUpdatedWorkspaceWindowState(workspaceAtTop) {\n    return workspaceAtTop?.preferredWindowSize ?? 'normal';\n}\nexport function closeAllWorkspaces(onClosingWorkspaces = ()=>{}, filter = ()=>true) {\n    const store = getWorkspaceStore();\n    const canCloseAllWorkspaces = store.getState().openWorkspaces.filter(filter).every(({ name })=>{\n        return canCloseWorkspaceWithoutPrompting(name);\n    });\n    const updateWorkspaceStore = ()=>{\n        resetWorkspaceStore();\n        onClosingWorkspaces?.();\n    };\n    if (!canCloseAllWorkspaces) {\n        showWorkspacePrompts('closing-all-workspaces', updateWorkspaceStore);\n    } else {\n        updateWorkspaceStore();\n    }\n}\n/**\n * @deprecated migrate to workspace v2. See:\n * https://openmrs.atlassian.net/wiki/spaces/docs/pages/615677981/Workspace+v2+Migration+Guide\n */ export function useWorkspaces() {\n    const { workspaceWindowState, openWorkspaces, prompt, workspaceGroup } = useStore(workspaceStore);\n    const memoisedResults = useMemo(()=>{\n        return {\n            active: openWorkspaces.length > 0,\n            prompt,\n            workspaceWindowState,\n            workspaces: openWorkspaces,\n            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 */ export function showWorkspacePrompts(promptType, onConfirmation = ()=>{}, workspaceTitle = '') {\n    const store = getWorkspaceStore();\n    let prompt;\n    switch(promptType){\n        case 'closing-workspace':\n            {\n                prompt = {\n                    title: getCoreTranslation('unsavedChangesTitleText', 'Unsaved changes'),\n                    body: getCoreTranslation('unsavedChangesInOpenedWorkspace', `You may have unsaved changes in the opened workspace. Do you want to discard these changes?`),\n                    onConfirm: ()=>{\n                        onConfirmation?.();\n                    },\n                    confirmText: getCoreTranslation('discard', 'Discard')\n                };\n                break;\n            }\n        case 'closing-all-workspaces':\n            {\n                const workspacesNotClosed = store.getState().openWorkspaces.filter(({ name })=>!canCloseWorkspaceWithoutPrompting(name)).map(({ title }, indx)=>`${indx + 1}. ${title}`);\n                prompt = {\n                    title: getCoreTranslation('closingAllWorkspacesPromptTitle', 'You have unsaved changes'),\n                    body: 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: ()=>{\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            {\n                prompt = {\n                    title: getCoreTranslation('unsavedChangesTitleText', 'Unsaved changes'),\n                    body: getCoreTranslation('unsavedChangesInWorkspace', '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            {\n                console.error(`Workspace system trying to open unknown prompt type \"${promptType}\" in function \"showWorkspacePrompts\"`);\n                onConfirmation?.();\n                return;\n            }\n    }\n    store.setState((state)=>({\n            ...state,\n            prompt\n        }));\n}\nfunction getWorkspaceTitle(workspace, additionalProps) {\n    return additionalProps?.['workspaceTitle'] ?? workspace.title;\n}\nexport function 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 */ export function getWorkspaceGroupStore(workspaceGroupName, additionalProps = {}) {\n    if (!workspaceGroupName || workspaceGroupName === 'default') {\n        return undefined;\n    }\n    const store = getGlobalStore(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_getState","store","getWorkspaceStore","currentWorkspaceGroup","currentGroupName","filter","workspace","closeAllWorkspaces","workspaceGroupStore","getWorkspaceGroupStore","unsubscribe","prev","undefined","launchWorkspaceGroup","args","workspaceGroupRegistration","state","onWorkspaceGroupLaunch","workspaceGroupCleanup","workspaceToLaunch","workspaceGroup","_workspaceToLaunch_additionalProps","launchWorkspace","promptBeforeLaunchingWorkspace","newWorkspaceDetails","additionalProps","newWorkspaceRegistration","proceed","closeWorkspace","onWorkspaceClose","_workspace_title","showWorkspacePrompts","_currentWorkspaceGroup_members","_store_getState_workspaceGroup","newWorkspace","getWorkspaceTitle","closeWorkspace1","options","closeWorkspaceWithSavedChanges","promptBeforeClosing1","testFcn","promptBeforeClosing","setTitle","title","titleNode","openWorkspaces","w","updateStoreWithNewWorkspace","workspaceToBeAdded","restOfTheWorkspaces","workspaceWindowState","getUpdatedWorkspaceWindowState","workspaceIndexInOpenWorkspaces","isWorkspaceAlreadyOpen","openedWorkspaceWithSameType","openWorkspace","updatedWorkspace","restOfTheWorkspaces1","navigateAndLaunchWorkspace","param","targetUrl","contextKey","workspaceName","changeWorkspaceContext","promptBeforeClosingFcns","cancelPrompt","defaultOptions","updateStoreWithClosedWorkspace","workspaceToBeClosed","newOpenWorkspaces","workspaceGroupName","_getWorkspaceRegistration_title","currentName","initialState","workspaceStore","updateWorkspaceWindowState","value","workspaceAtTop","onClosingWorkspaces","canCloseAllWorkspaces","updateWorkspaceStore","resetWorkspaceStore","useWorkspaces","_useStore","prompt","memoisedResults","promptType","onConfirmation","workspaceTitle","onConfirm","workspacesNotClosed","indx","console"],"mappings":"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"}\n//# sourceURL=webpack-internal:///../../framework/esm-styleguide/dist/workspaces/workspaces.js\n\n}");
|
|
1959
1959
|
|
|
1960
1960
|
},
|
|
1961
1961
|
"../../framework/esm-styleguide/dist/workspaces2/action-menu2/action-menu-button2.component.js"(__unused_rspack_module, __webpack_exports__, __webpack_require__) {
|