@pucp-gidis-hiisc/esm-fua-app 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (95) hide show
  1. package/.turbo/turbo-extract-translations.log +11 -0
  2. package/.turbo/turbo-lint.log +0 -0
  3. package/.turbo/turbo-test.log +1 -0
  4. package/.turbo/turbo-typescript.log +0 -0
  5. package/README.md +9 -0
  6. package/dist/@pucp-gidis-hiisc/esm-dyaku-app.3156ff9f6a47f657.hot-update.js +11 -0
  7. package/dist/@pucp-gidis-hiisc/esm-dyaku-app.3156ff9f6a47f657.hot-update.js.map +1 -0
  8. package/dist/@pucp-gidis-hiisc/esm-dyaku-app.52df2f9ab9342568.hot-update.js +11 -0
  9. package/dist/@pucp-gidis-hiisc/esm-dyaku-app.52df2f9ab9342568.hot-update.js.map +1 -0
  10. package/dist/@pucp-gidis-hiisc/esm-dyaku-app.670ae221c7eb0597.hot-update.js +11 -0
  11. package/dist/@pucp-gidis-hiisc/esm-dyaku-app.670ae221c7eb0597.hot-update.js.map +1 -0
  12. package/dist/_pucp-gidis-hiisc_esm-dyaku-app.3156ff9f6a47f657.hot-update.json +1 -0
  13. package/dist/_pucp-gidis-hiisc_esm-dyaku-app.52df2f9ab9342568.hot-update.json +1 -0
  14. package/dist/_pucp-gidis-hiisc_esm-dyaku-app.670ae221c7eb0597.hot-update.json +1 -0
  15. package/dist/main.3156ff9f6a47f657.hot-update.js +11 -0
  16. package/dist/main.3156ff9f6a47f657.hot-update.js.map +1 -0
  17. package/dist/main.3156ff9f6a47f657.hot-update.json +1 -0
  18. package/dist/main.52df2f9ab9342568.hot-update.js +11 -0
  19. package/dist/main.52df2f9ab9342568.hot-update.js.map +1 -0
  20. package/dist/main.52df2f9ab9342568.hot-update.json +1 -0
  21. package/dist/main.670ae221c7eb0597.hot-update.js +11 -0
  22. package/dist/main.670ae221c7eb0597.hot-update.js.map +1 -0
  23. package/dist/main.670ae221c7eb0597.hot-update.json +1 -0
  24. package/dist/main.js +5012 -0
  25. package/dist/main.js.map +1 -0
  26. package/dist/node_modules_babel_runtime_helpers_esm_objectWithoutPropertiesLoose_js.js +28 -0
  27. package/dist/node_modules_babel_runtime_helpers_esm_objectWithoutPropertiesLoose_js.js.map +1 -0
  28. package/dist/node_modules_client-only_index_js-node_modules_use-sync-external-store_shim_index_js-_e121-_afc40.js +137 -0
  29. package/dist/node_modules_client-only_index_js-node_modules_use-sync-external-store_shim_index_js-_e121-_afc40.js.map +1 -0
  30. package/dist/node_modules_client-only_index_js-node_modules_use-sync-external-store_shim_index_js-_e121-_afc41.js +137 -0
  31. package/dist/node_modules_client-only_index_js-node_modules_use-sync-external-store_shim_index_js-_e121-_afc41.js.map +1 -0
  32. package/dist/node_modules_dayjs_dayjs_min_js.js +14 -0
  33. package/dist/node_modules_dayjs_dayjs_min_js.js.map +1 -0
  34. package/dist/pucp-gidis-hiisc-esm-dyaku-app.js +4902 -0
  35. package/dist/pucp-gidis-hiisc-esm-dyaku-app.js.buildmanifest.json +705 -0
  36. package/dist/pucp-gidis-hiisc-esm-dyaku-app.js.map +1 -0
  37. package/dist/routes.json +1 -0
  38. package/dist/src_dyaku-patients_dyaku-patients-link_component_tsx.js +46 -0
  39. package/dist/src_dyaku-patients_dyaku-patients-link_component_tsx.js.map +1 -0
  40. package/dist/src_dyaku-patients_dyaku_main_component_tsx.3156ff9f6a47f657.hot-update.js +309 -0
  41. package/dist/src_dyaku-patients_dyaku_main_component_tsx.3156ff9f6a47f657.hot-update.js.map +1 -0
  42. package/dist/src_dyaku-patients_dyaku_main_component_tsx.52df2f9ab9342568.hot-update.js +309 -0
  43. package/dist/src_dyaku-patients_dyaku_main_component_tsx.52df2f9ab9342568.hot-update.js.map +1 -0
  44. package/dist/src_dyaku-patients_dyaku_main_component_tsx.670ae221c7eb0597.hot-update.js +309 -0
  45. package/dist/src_dyaku-patients_dyaku_main_component_tsx.670ae221c7eb0597.hot-update.js.map +1 -0
  46. package/dist/src_dyaku-patients_dyaku_main_component_tsx.js +2520 -0
  47. package/dist/src_dyaku-patients_dyaku_main_component_tsx.js.map +1 -0
  48. package/dist/src_index_ts.js +146 -0
  49. package/dist/src_index_ts.js.map +1 -0
  50. package/dist/translations_en_json.js +14 -0
  51. package/dist/translations_es_json.js +14 -0
  52. package/dist/vendors-node_modules_carbon_react_es_index_js.js +121758 -0
  53. package/dist/vendors-node_modules_carbon_react_es_index_js.js.map +1 -0
  54. package/dist/vendors-node_modules_openmrs_esm-framework_src_internal_ts.js +4256 -0
  55. package/dist/vendors-node_modules_openmrs_esm-framework_src_internal_ts.js.map +1 -0
  56. package/dist/vendors-node_modules_openmrs_esm-patient-common-lib_src_index_ts.js +4200 -0
  57. package/dist/vendors-node_modules_openmrs_esm-patient-common-lib_src_index_ts.js.map +1 -0
  58. package/dist/vendors-node_modules_openmrs_esm-styleguide_src_internal_ts.js +119007 -0
  59. package/dist/vendors-node_modules_openmrs_esm-styleguide_src_internal_ts.js.map +1 -0
  60. package/dist/vendors-node_modules_react-dom_index_js.js +30632 -0
  61. package/dist/vendors-node_modules_react-dom_index_js.js.map +1 -0
  62. package/dist/vendors-node_modules_react-i18next_dist_es_index_js.js +1392 -0
  63. package/dist/vendors-node_modules_react-i18next_dist_es_index_js.js.map +1 -0
  64. package/dist/vendors-node_modules_react-router-dom_dist_index_js.js +8221 -0
  65. package/dist/vendors-node_modules_react-router-dom_dist_index_js.js.map +1 -0
  66. package/dist/vendors-node_modules_react_index_js.js +2772 -0
  67. package/dist/vendors-node_modules_react_index_js.js.map +1 -0
  68. package/dist/vendors-node_modules_rxjs__esm5_index_js.js +6245 -0
  69. package/dist/vendors-node_modules_rxjs__esm5_index_js.js.map +1 -0
  70. package/dist/vendors-node_modules_swr_dist__internal_index_mjs.js +732 -0
  71. package/dist/vendors-node_modules_swr_dist__internal_index_mjs.js.map +1 -0
  72. package/dist/vendors-node_modules_swr_dist_immutable_index_mjs.js +572 -0
  73. package/dist/vendors-node_modules_swr_dist_immutable_index_mjs.js.map +1 -0
  74. package/dist/vendors-node_modules_swr_dist_infinite_index_mjs.js +815 -0
  75. package/dist/vendors-node_modules_swr_dist_infinite_index_mjs.js.map +1 -0
  76. package/jest.config.js +3 -0
  77. package/package.json +68 -0
  78. package/src/config-schema.ts +61 -0
  79. package/src/constant.ts +1 -0
  80. package/src/dashboard.meta.tsx +8 -0
  81. package/src/declarations.d.ts +6 -0
  82. package/src/fua/case-management-header.tsx +37 -0
  83. package/src/fua/case-management-illustration.tsx +13 -0
  84. package/src/fua/fua-request-table.scss +173 -0
  85. package/src/fua/fuaRequestTable.tsx +147 -0
  86. package/src/fua/solicitudes/.gitkeep +0 -0
  87. package/src/hooks/useFuaRequests.ts +48 -0
  88. package/src/index.ts +27 -0
  89. package/src/left-panel-link.component.tsx +42 -0
  90. package/src/root.scss +102 -0
  91. package/src/routes.json +28 -0
  92. package/translations/en.json +0 -0
  93. package/translations/es.json +0 -0
  94. package/tsconfig.json +5 -0
  95. package/webpack.config.js +1 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"src_dyaku-patients_dyaku-patients-link_component_tsx.js","mappings":";;;;;;;;;;;;;;;;;;;AAAqD;AACJ;AACvB;AACqB;AAE/C,IAAMK,oBAA8B;IAClC,IAAM,IAAQD,6DAAcA,GAApBE;IAER,qBACE,2DAACL,gDAAKA,sBACJ,2DAACD,wDAAaA;QAACO,MAAM,GAAkB,OAAfC,OAAOC,OAAO,EAAC;QAAkBC,QAAO;QAASC,KAAI;qBAC3E,2DAACC,2BACC,2DAACA;QAAIC,WAAU;OAAWP,EAAE,iBAAiB,yCAC7C,2DAACM;QAAIC,WAAU;OACZP,EAAE,4BAA4B,yEAGnC,2DAACM;QAAIC,WAAU;qBACb,2DAACX,2DAAUA;QAACY,MAAM;;AAK5B;AAEA,iEAAeT,iBAAiBA,EAAC","sources":["webpack://@pucp-gidis-hiisc/esm-dyaku-app/./src/dyaku-patients/dyaku-patients-link.component.tsx"],"sourcesContent":["import { ClickableTile, Layer } from '@carbon/react';\nimport { ArrowRight } from '@carbon/react/icons';\nimport React from 'react';\nimport { useTranslation } from 'react-i18next';\n\nconst DyakuPatientsLink: React.FC = () => {\n const { t } = useTranslation();\n\n return (\n <Layer>\n <ClickableTile href={`${window.spaBase}/dyaku-patients`} target=\"_blank\" rel=\"noopener noreferrer\">\n <div>\n <div className=\"heading\">{t('dyakuPatients', 'Pacientes Dyaku MINSA')}</div>\n <div className=\"content\">\n {t('dyakuPatientsDescription', 'Consultar pacientes del sistema FHIR Dyaku del MINSA')}\n </div>\n </div>\n <div className=\"iconWrapper\">\n <ArrowRight size={16} />\n </div>\n </ClickableTile>\n </Layer>\n );\n};\n\nexport default DyakuPatientsLink;\n"],"names":["ClickableTile","Layer","ArrowRight","React","useTranslation","DyakuPatientsLink","t","href","window","spaBase","target","rel","div","className","size"],"sourceRoot":""}
@@ -0,0 +1,309 @@
1
+ "use strict";
2
+ globalThis["webpackHotUpdate_pucp_gidis_hiisc_esm_dyaku_app"]("src_dyaku-patients_dyaku_main_component_tsx",{
3
+
4
+ /***/ "./src/dyaku-patients/dyaku-patient-sync-button.component.tsx":
5
+ /*!********************************************************************!*\
6
+ !*** ./src/dyaku-patients/dyaku-patient-sync-button.component.tsx ***!
7
+ \********************************************************************/
8
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
9
+
10
+ __webpack_require__.r(__webpack_exports__);
11
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
12
+ /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
13
+ /* harmony export */ });
14
+ /* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @carbon/react */ "../../node_modules/@carbon/react/es/index.js");
15
+ /* harmony import */ var _carbon_react_icons__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @carbon/react/icons */ "../../node_modules/@carbon/icons-react/es/generated/bucket-3.js");
16
+ /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react */ "webpack/sharing/consume/default/react/react");
17
+ /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_1__);
18
+ /* harmony import */ var react_i18next__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! react-i18next */ "webpack/sharing/consume/default/react-i18next/react-i18next");
19
+ /* harmony import */ var react_i18next__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(react_i18next__WEBPACK_IMPORTED_MODULE_2__);
20
+ /* harmony import */ var _dyaku_patient_sync_button_scss__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./dyaku-patient-sync-button.scss */ "./src/dyaku-patients/dyaku-patient-sync-button.scss");
21
+ Object(function webpackMissingModule() { var e = new Error("Cannot find module '../../../esm-maternal-and-child-health/src/dyaku-patients/dyaku-patients.resource'"); e.code = 'MODULE_NOT_FOUND'; throw e; }());
22
+ function _array_like_to_array(arr, len) {
23
+ if (len == null || len > arr.length) len = arr.length;
24
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
25
+ return arr2;
26
+ }
27
+ function _array_with_holes(arr) {
28
+ if (Array.isArray(arr)) return arr;
29
+ }
30
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
31
+ try {
32
+ var info = gen[key](arg);
33
+ var value = info.value;
34
+ } catch (error) {
35
+ reject(error);
36
+ return;
37
+ }
38
+ if (info.done) {
39
+ resolve(value);
40
+ } else {
41
+ Promise.resolve(value).then(_next, _throw);
42
+ }
43
+ }
44
+ function _async_to_generator(fn) {
45
+ return function() {
46
+ var self = this, args = arguments;
47
+ return new Promise(function(resolve, reject) {
48
+ var gen = fn.apply(self, args);
49
+ function _next(value) {
50
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
51
+ }
52
+ function _throw(err) {
53
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
54
+ }
55
+ _next(undefined);
56
+ });
57
+ };
58
+ }
59
+ function _iterable_to_array_limit(arr, i) {
60
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
61
+ if (_i == null) return;
62
+ var _arr = [];
63
+ var _n = true;
64
+ var _d = false;
65
+ var _s, _e;
66
+ try {
67
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
68
+ _arr.push(_s.value);
69
+ if (i && _arr.length === i) break;
70
+ }
71
+ } catch (err) {
72
+ _d = true;
73
+ _e = err;
74
+ } finally{
75
+ try {
76
+ if (!_n && _i["return"] != null) _i["return"]();
77
+ } finally{
78
+ if (_d) throw _e;
79
+ }
80
+ }
81
+ return _arr;
82
+ }
83
+ function _non_iterable_rest() {
84
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
85
+ }
86
+ function _sliced_to_array(arr, i) {
87
+ return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
88
+ }
89
+ function _unsupported_iterable_to_array(o, minLen) {
90
+ if (!o) return;
91
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
92
+ var n = Object.prototype.toString.call(o).slice(8, -1);
93
+ if (n === "Object" && o.constructor) n = o.constructor.name;
94
+ if (n === "Map" || n === "Set") return Array.from(n);
95
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
96
+ }
97
+ function _ts_generator(thisArg, body) {
98
+ var f, y, t, _ = {
99
+ label: 0,
100
+ sent: function() {
101
+ if (t[0] & 1) throw t[1];
102
+ return t[1];
103
+ },
104
+ trys: [],
105
+ ops: []
106
+ }, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
107
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() {
108
+ return this;
109
+ }), g;
110
+ function verb(n) {
111
+ return function(v) {
112
+ return step([
113
+ n,
114
+ v
115
+ ]);
116
+ };
117
+ }
118
+ function step(op) {
119
+ if (f) throw new TypeError("Generator is already executing.");
120
+ while(g && (g = 0, op[0] && (_ = 0)), _)try {
121
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
122
+ if (y = 0, t) op = [
123
+ op[0] & 2,
124
+ t.value
125
+ ];
126
+ switch(op[0]){
127
+ case 0:
128
+ case 1:
129
+ t = op;
130
+ break;
131
+ case 4:
132
+ _.label++;
133
+ return {
134
+ value: op[1],
135
+ done: false
136
+ };
137
+ case 5:
138
+ _.label++;
139
+ y = op[1];
140
+ op = [
141
+ 0
142
+ ];
143
+ continue;
144
+ case 7:
145
+ op = _.ops.pop();
146
+ _.trys.pop();
147
+ continue;
148
+ default:
149
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
150
+ _ = 0;
151
+ continue;
152
+ }
153
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
154
+ _.label = op[1];
155
+ break;
156
+ }
157
+ if (op[0] === 6 && _.label < t[1]) {
158
+ _.label = t[1];
159
+ t = op;
160
+ break;
161
+ }
162
+ if (t && _.label < t[2]) {
163
+ _.label = t[2];
164
+ _.ops.push(op);
165
+ break;
166
+ }
167
+ if (t[2]) _.ops.pop();
168
+ _.trys.pop();
169
+ continue;
170
+ }
171
+ op = body.call(thisArg, _);
172
+ } catch (e) {
173
+ op = [
174
+ 6,
175
+ e
176
+ ];
177
+ y = 0;
178
+ } finally{
179
+ f = t = 0;
180
+ }
181
+ if (op[0] & 5) throw op[1];
182
+ return {
183
+ value: op[0] ? op[1] : void 0,
184
+ done: true
185
+ };
186
+ }
187
+ }
188
+
189
+
190
+
191
+
192
+
193
+
194
+ var DyakuPatientSyncButton = function(param) {
195
+ var patient = param.patient, onSyncComplete = param.onSyncComplete, _param_size = param.size, size = _param_size === void 0 ? 'sm' : _param_size;
196
+ var t = (0,react_i18next__WEBPACK_IMPORTED_MODULE_2__.useTranslation)().t;
197
+ var _useDyakuSync = Object(function webpackMissingModule() { var e = new Error("Cannot find module '../../../esm-maternal-and-child-health/src/dyaku-patients/dyaku-patients.resource'"); e.code = 'MODULE_NOT_FOUND'; throw e; }())(), syncSinglePatient = _useDyakuSync.syncSinglePatient, isEnabled = _useDyakuSync.isEnabled;
198
+ var _useState = _sliced_to_array((0,react__WEBPACK_IMPORTED_MODULE_1__.useState)(false), 2), isSyncing = _useState[0], setIsSyncing = _useState[1];
199
+ var _useState1 = _sliced_to_array((0,react__WEBPACK_IMPORTED_MODULE_1__.useState)(null), 2), syncResult = _useState1[0], setSyncResult = _useState1[1];
200
+ var _useState2 = _sliced_to_array((0,react__WEBPACK_IMPORTED_MODULE_1__.useState)(false), 2), showResult = _useState2[0], setShowResult = _useState2[1];
201
+ var handleSync = function() {
202
+ return _async_to_generator(function() {
203
+ var result, error;
204
+ return _ts_generator(this, function(_state) {
205
+ switch(_state.label){
206
+ case 0:
207
+ if (!isEnabled || isSyncing) return [
208
+ 2
209
+ ];
210
+ setIsSyncing(true);
211
+ setSyncResult(null);
212
+ setShowResult(false);
213
+ _state.label = 1;
214
+ case 1:
215
+ _state.trys.push([
216
+ 1,
217
+ 3,
218
+ 4,
219
+ 5
220
+ ]);
221
+ return [
222
+ 4,
223
+ syncSinglePatient(patient)
224
+ ];
225
+ case 2:
226
+ result = _state.sent();
227
+ setSyncResult(result);
228
+ setShowResult(true);
229
+ if (onSyncComplete) {
230
+ onSyncComplete(result);
231
+ }
232
+ // Auto-hide result after 3 seconds
233
+ setTimeout(function() {
234
+ setShowResult(false);
235
+ setSyncResult(null);
236
+ }, 3000);
237
+ return [
238
+ 3,
239
+ 5
240
+ ];
241
+ case 3:
242
+ error = _state.sent();
243
+ setSyncResult({
244
+ success: false,
245
+ synchronized: 0,
246
+ failed: 1,
247
+ errors: [
248
+ error.message
249
+ ]
250
+ });
251
+ setShowResult(true);
252
+ setTimeout(function() {
253
+ setShowResult(false);
254
+ setSyncResult(null);
255
+ }, 5000);
256
+ return [
257
+ 3,
258
+ 5
259
+ ];
260
+ case 4:
261
+ setIsSyncing(false);
262
+ return [
263
+ 7
264
+ ];
265
+ case 5:
266
+ return [
267
+ 2
268
+ ];
269
+ }
270
+ });
271
+ })();
272
+ };
273
+ if (isSyncing) {
274
+ return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_1___default().createElement("div", {
275
+ className: _dyaku_patient_sync_button_scss__WEBPACK_IMPORTED_MODULE_3__["default"].syncingContainer
276
+ }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_1___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_0__.InlineLoading, {
277
+ description: t('syncingPatient', 'Sincronizando...')
278
+ }));
279
+ }
280
+ if (showResult && syncResult) {
281
+ return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_1___default().createElement("div", {
282
+ className: _dyaku_patient_sync_button_scss__WEBPACK_IMPORTED_MODULE_3__["default"].resultContainer
283
+ }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_1___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_0__.InlineNotification, {
284
+ kind: syncResult.success ? 'success' : 'error',
285
+ title: syncResult.success ? t('syncSuccess', 'Éxito') : t('syncError', 'Error'),
286
+ subtitle: syncResult.success ? t('patientSyncedSuccessfully', 'Paciente sincronizado') : syncResult.errors[0] || t('syncErrorOccurred', 'Error en sincronización'),
287
+ hideCloseButton: true,
288
+ lowContrast: true,
289
+ className: _dyaku_patient_sync_button_scss__WEBPACK_IMPORTED_MODULE_3__["default"].notification
290
+ }));
291
+ }
292
+ return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_1___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_0__.Button, {
293
+ kind: "ghost",
294
+ size: size,
295
+ renderIcon: (syncResult === null || syncResult === void 0 ? void 0 : syncResult.success) ? _carbon_react_icons__WEBPACK_IMPORTED_MODULE_5__.CheckmarkOutline : _carbon_react_icons__WEBPACK_IMPORTED_MODULE_5__.CloudUpload,
296
+ onClick: handleSync,
297
+ disabled: !isEnabled,
298
+ className: "".concat(_dyaku_patient_sync_button_scss__WEBPACK_IMPORTED_MODULE_3__["default"].syncButton, " ").concat((syncResult === null || syncResult === void 0 ? void 0 : syncResult.success) ? _dyaku_patient_sync_button_scss__WEBPACK_IMPORTED_MODULE_3__["default"].synced : ''),
299
+ hasIconOnly: true,
300
+ iconDescription: (syncResult === null || syncResult === void 0 ? void 0 : syncResult.success) ? t('patientAlreadySynced', 'Paciente sincronizado') : t('syncPatient', 'Sincronizar paciente')
301
+ });
302
+ };
303
+ /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (DyakuPatientSyncButton);
304
+
305
+
306
+ /***/ })
307
+
308
+ });
309
+ //# sourceMappingURL=src_dyaku-patients_dyaku_main_component_tsx.3156ff9f6a47f657.hot-update.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"src_dyaku-patients_dyaku_main_component_tsx.3156ff9f6a47f657.hot-update.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAA0E;AACN;AAC5B;AACO;AACO;AAKqC;AAQ3F,IAAMU,yBAAgE;QAAGC,gBAAAA,SAASC,uBAAAA,oCAAgBC,MAAAA,gCAAO;IACvG,IAAM,IAAQN,6DAAcA,GAApBO;IACR,IAAyCL,gBAAAA,gNAAYA,IAA7CM,oBAAiCN,cAAjCM,mBAAmBC,YAAcP,cAAdO;IAC3B,IAAkCV,6BAAAA,+CAAQA,CAAC,YAApCW,YAA2BX,cAAhBY,eAAgBZ;IAClC,IAAoCA,8BAAAA,+CAAQA,CAAoB,WAAzDa,aAA6Bb,eAAjBc,gBAAiBd;IACpC,IAAoCA,8BAAAA,+CAAQA,CAAC,YAAtCe,aAA6Bf,eAAjBgB,gBAAiBhB;IAEpC,IAAMiB,aAAa;;gBAQTC,QAaCC;;;;wBApBT,IAAI,CAACT,aAAaC,WAAW;;;wBAE7BC,aAAa;wBACbE,cAAc;wBACdE,cAAc;;;;;;;;;wBAGG;;4BAAMP,kBAAkBJ;;;wBAAjCa,SAAS;wBACfJ,cAAcI;wBACdF,cAAc;wBAEd,IAAIV,gBAAgB;4BAClBA,eAAeY;wBACjB;wBAEA,mCAAmC;wBACnCE,WAAW;4BACTJ,cAAc;4BACdF,cAAc;wBAChB,GAAG;;;;;;wBACIK;wBACPL,cAAc;4BACZO,SAAS;4BACTC,cAAc;4BACdC,QAAQ;4BACRC,MAAM;gCAAGL,MAAMM,OAAO;;wBACxB;wBACAT,cAAc;wBAEdI,WAAW;4BACTJ,cAAc;4BACdF,cAAc;wBAChB,GAAG;;;;;;wBAEHF,aAAa;;;;;;;;;;QAEjB;;IAEA,IAAID,WAAW;QACb,qBACE,2DAACe;YAAIC,WAAWzB,uEAAMA,CAAC0B,gBAAgB;yBACrC,2DAACjC,wDAAaA;YAACkC,aAAarB,EAAE,kBAAkB;;IAGtD;IAEA,IAAIO,cAAcF,YAAY;QAC5B,qBACE,2DAACa;YAAIC,WAAWzB,uEAAMA,CAAC4B,eAAe;yBACpC,2DAAClC,6DAAkBA;YACjBmC,MAAMlB,WAAWQ,OAAO,GAAG,YAAY;YACvCW,OAAOnB,WAAWQ,OAAO,GAAGb,EAAE,eAAe,WAAWA,EAAE,aAAa;YACvEyB,UACEpB,WAAWQ,OAAO,GACdb,EAAE,6BAA6B,2BAC/BK,WAAWW,MAAM,CAAC,EAAE,IAAIhB,EAAE,qBAAqB;YAErD0B,iBAAAA;YACAC,aAAAA;YACAR,WAAWzB,uEAAMA,CAACkC,YAAY;;IAItC;IAEA,qBACE,2DAAC1C,iDAAMA;QACLqC,MAAK;QACLxB,MAAMA;QACN8B,YAAYxB,CAAAA,uBAAAA,iCAAAA,WAAYQ,OAAO,IAAGxB,iEAAgBA,GAAGC,4DAAWA;QAChEwC,SAASrB;QACTsB,UAAU,CAAC7B;QACXiB,WAAW,GAAwBd,OAArBX,uEAAMA,CAACsC,UAAU,EAAC,KAA4C,OAAzC3B,CAAAA,uBAAAA,iCAAAA,WAAYQ,OAAO,IAAGnB,uEAAMA,CAACuC,MAAM,GAAG;QACzEC,aAAAA;QACAC,iBACE9B,CAAAA,uBAAAA,iCAAAA,WAAYQ,OAAO,IACfb,EAAE,wBAAwB,2BAC1BA,EAAE,eAAe;;AAI7B;AAEA,iEAAeJ,sBAAsBA,EAAC","sources":["webpack://@pucp-gidis-hiisc/esm-dyaku-app/./src/dyaku-patients/dyaku-patient-sync-button.component.tsx"],"sourcesContent":["import { Button, InlineLoading, InlineNotification } from '@carbon/react';\nimport { CheckmarkOutline, CloudUpload } from '@carbon/react/icons';\nimport React, { useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styles from './dyaku-patient-sync-button.scss';\nimport {\n useDyakuSync,\n type DyakuPatient,\n type SyncResult,\n} from '../../../esm-maternal-and-child-health/src/dyaku-patients/dyaku-patients.resource';\n\ninterface DyakuPatientSyncButtonProps {\n patient: DyakuPatient;\n onSyncComplete?: (result: SyncResult) => void;\n size?: 'sm' | 'md' | 'lg';\n}\n\nconst DyakuPatientSyncButton: React.FC<DyakuPatientSyncButtonProps> = ({ patient, onSyncComplete, size = 'sm' }) => {\n const { t } = useTranslation();\n const { syncSinglePatient, isEnabled } = useDyakuSync();\n const [isSyncing, setIsSyncing] = useState(false);\n const [syncResult, setSyncResult] = useState<SyncResult | null>(null);\n const [showResult, setShowResult] = useState(false);\n\n const handleSync = async () => {\n if (!isEnabled || isSyncing) return;\n\n setIsSyncing(true);\n setSyncResult(null);\n setShowResult(false);\n\n try {\n const result = await syncSinglePatient(patient);\n setSyncResult(result);\n setShowResult(true);\n\n if (onSyncComplete) {\n onSyncComplete(result);\n }\n\n // Auto-hide result after 3 seconds\n setTimeout(() => {\n setShowResult(false);\n setSyncResult(null);\n }, 3000);\n } catch (error) {\n setSyncResult({\n success: false,\n synchronized: 0,\n failed: 1,\n errors: [error.message],\n });\n setShowResult(true);\n\n setTimeout(() => {\n setShowResult(false);\n setSyncResult(null);\n }, 5000);\n } finally {\n setIsSyncing(false);\n }\n };\n\n if (isSyncing) {\n return (\n <div className={styles.syncingContainer}>\n <InlineLoading description={t('syncingPatient', 'Sincronizando...')} />\n </div>\n );\n }\n\n if (showResult && syncResult) {\n return (\n <div className={styles.resultContainer}>\n <InlineNotification\n kind={syncResult.success ? 'success' : 'error'}\n title={syncResult.success ? t('syncSuccess', 'Éxito') : t('syncError', 'Error')}\n subtitle={\n syncResult.success\n ? t('patientSyncedSuccessfully', 'Paciente sincronizado')\n : syncResult.errors[0] || t('syncErrorOccurred', 'Error en sincronización')\n }\n hideCloseButton\n lowContrast\n className={styles.notification}\n />\n </div>\n );\n }\n\n return (\n <Button\n kind=\"ghost\"\n size={size}\n renderIcon={syncResult?.success ? CheckmarkOutline : CloudUpload}\n onClick={handleSync}\n disabled={!isEnabled}\n className={`${styles.syncButton} ${syncResult?.success ? styles.synced : ''}`}\n hasIconOnly\n iconDescription={\n syncResult?.success\n ? t('patientAlreadySynced', 'Paciente sincronizado')\n : t('syncPatient', 'Sincronizar paciente')\n }\n />\n );\n};\n\nexport default DyakuPatientSyncButton;\n"],"names":["Button","InlineLoading","InlineNotification","CheckmarkOutline","CloudUpload","React","useState","useTranslation","styles","useDyakuSync","DyakuPatientSyncButton","patient","onSyncComplete","size","t","syncSinglePatient","isEnabled","isSyncing","setIsSyncing","syncResult","setSyncResult","showResult","setShowResult","handleSync","result","error","setTimeout","success","synchronized","failed","errors","message","div","className","syncingContainer","description","resultContainer","kind","title","subtitle","hideCloseButton","lowContrast","notification","renderIcon","onClick","disabled","syncButton","synced","hasIconOnly","iconDescription"],"sourceRoot":""}
@@ -0,0 +1,309 @@
1
+ "use strict";
2
+ globalThis["webpackHotUpdate_pucp_gidis_hiisc_esm_dyaku_app"]("src_dyaku-patients_dyaku_main_component_tsx",{
3
+
4
+ /***/ "./src/dyaku-patients/dyaku-patient-sync-button.component.tsx":
5
+ /*!********************************************************************!*\
6
+ !*** ./src/dyaku-patients/dyaku-patient-sync-button.component.tsx ***!
7
+ \********************************************************************/
8
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
9
+
10
+ __webpack_require__.r(__webpack_exports__);
11
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
12
+ /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
13
+ /* harmony export */ });
14
+ /* harmony import */ var _carbon_react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @carbon/react */ "../../node_modules/@carbon/react/es/index.js");
15
+ /* harmony import */ var _carbon_react_icons__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @carbon/react/icons */ "../../node_modules/@carbon/icons-react/es/generated/bucket-3.js");
16
+ /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! react */ "webpack/sharing/consume/default/react/react");
17
+ /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_1__);
18
+ /* harmony import */ var react_i18next__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! react-i18next */ "webpack/sharing/consume/default/react-i18next/react-i18next");
19
+ /* harmony import */ var react_i18next__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(react_i18next__WEBPACK_IMPORTED_MODULE_2__);
20
+ /* harmony import */ var _dyaku_patient_sync_button_scss__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./dyaku-patient-sync-button.scss */ "./src/dyaku-patients/dyaku-patient-sync-button.scss");
21
+ Object(function webpackMissingModule() { var e = new Error("Cannot find module '../dyaku-patients.resource'"); e.code = 'MODULE_NOT_FOUND'; throw e; }());
22
+ function _array_like_to_array(arr, len) {
23
+ if (len == null || len > arr.length) len = arr.length;
24
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
25
+ return arr2;
26
+ }
27
+ function _array_with_holes(arr) {
28
+ if (Array.isArray(arr)) return arr;
29
+ }
30
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
31
+ try {
32
+ var info = gen[key](arg);
33
+ var value = info.value;
34
+ } catch (error) {
35
+ reject(error);
36
+ return;
37
+ }
38
+ if (info.done) {
39
+ resolve(value);
40
+ } else {
41
+ Promise.resolve(value).then(_next, _throw);
42
+ }
43
+ }
44
+ function _async_to_generator(fn) {
45
+ return function() {
46
+ var self = this, args = arguments;
47
+ return new Promise(function(resolve, reject) {
48
+ var gen = fn.apply(self, args);
49
+ function _next(value) {
50
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
51
+ }
52
+ function _throw(err) {
53
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
54
+ }
55
+ _next(undefined);
56
+ });
57
+ };
58
+ }
59
+ function _iterable_to_array_limit(arr, i) {
60
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
61
+ if (_i == null) return;
62
+ var _arr = [];
63
+ var _n = true;
64
+ var _d = false;
65
+ var _s, _e;
66
+ try {
67
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
68
+ _arr.push(_s.value);
69
+ if (i && _arr.length === i) break;
70
+ }
71
+ } catch (err) {
72
+ _d = true;
73
+ _e = err;
74
+ } finally{
75
+ try {
76
+ if (!_n && _i["return"] != null) _i["return"]();
77
+ } finally{
78
+ if (_d) throw _e;
79
+ }
80
+ }
81
+ return _arr;
82
+ }
83
+ function _non_iterable_rest() {
84
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
85
+ }
86
+ function _sliced_to_array(arr, i) {
87
+ return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
88
+ }
89
+ function _unsupported_iterable_to_array(o, minLen) {
90
+ if (!o) return;
91
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
92
+ var n = Object.prototype.toString.call(o).slice(8, -1);
93
+ if (n === "Object" && o.constructor) n = o.constructor.name;
94
+ if (n === "Map" || n === "Set") return Array.from(n);
95
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
96
+ }
97
+ function _ts_generator(thisArg, body) {
98
+ var f, y, t, _ = {
99
+ label: 0,
100
+ sent: function() {
101
+ if (t[0] & 1) throw t[1];
102
+ return t[1];
103
+ },
104
+ trys: [],
105
+ ops: []
106
+ }, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
107
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() {
108
+ return this;
109
+ }), g;
110
+ function verb(n) {
111
+ return function(v) {
112
+ return step([
113
+ n,
114
+ v
115
+ ]);
116
+ };
117
+ }
118
+ function step(op) {
119
+ if (f) throw new TypeError("Generator is already executing.");
120
+ while(g && (g = 0, op[0] && (_ = 0)), _)try {
121
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
122
+ if (y = 0, t) op = [
123
+ op[0] & 2,
124
+ t.value
125
+ ];
126
+ switch(op[0]){
127
+ case 0:
128
+ case 1:
129
+ t = op;
130
+ break;
131
+ case 4:
132
+ _.label++;
133
+ return {
134
+ value: op[1],
135
+ done: false
136
+ };
137
+ case 5:
138
+ _.label++;
139
+ y = op[1];
140
+ op = [
141
+ 0
142
+ ];
143
+ continue;
144
+ case 7:
145
+ op = _.ops.pop();
146
+ _.trys.pop();
147
+ continue;
148
+ default:
149
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
150
+ _ = 0;
151
+ continue;
152
+ }
153
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
154
+ _.label = op[1];
155
+ break;
156
+ }
157
+ if (op[0] === 6 && _.label < t[1]) {
158
+ _.label = t[1];
159
+ t = op;
160
+ break;
161
+ }
162
+ if (t && _.label < t[2]) {
163
+ _.label = t[2];
164
+ _.ops.push(op);
165
+ break;
166
+ }
167
+ if (t[2]) _.ops.pop();
168
+ _.trys.pop();
169
+ continue;
170
+ }
171
+ op = body.call(thisArg, _);
172
+ } catch (e) {
173
+ op = [
174
+ 6,
175
+ e
176
+ ];
177
+ y = 0;
178
+ } finally{
179
+ f = t = 0;
180
+ }
181
+ if (op[0] & 5) throw op[1];
182
+ return {
183
+ value: op[0] ? op[1] : void 0,
184
+ done: true
185
+ };
186
+ }
187
+ }
188
+
189
+
190
+
191
+
192
+
193
+
194
+ var DyakuPatientSyncButton = function(param) {
195
+ var patient = param.patient, onSyncComplete = param.onSyncComplete, _param_size = param.size, size = _param_size === void 0 ? 'sm' : _param_size;
196
+ var t = (0,react_i18next__WEBPACK_IMPORTED_MODULE_2__.useTranslation)().t;
197
+ var _useDyakuSync = Object(function webpackMissingModule() { var e = new Error("Cannot find module '../dyaku-patients.resource'"); e.code = 'MODULE_NOT_FOUND'; throw e; }())(), syncSinglePatient = _useDyakuSync.syncSinglePatient, isEnabled = _useDyakuSync.isEnabled;
198
+ var _useState = _sliced_to_array((0,react__WEBPACK_IMPORTED_MODULE_1__.useState)(false), 2), isSyncing = _useState[0], setIsSyncing = _useState[1];
199
+ var _useState1 = _sliced_to_array((0,react__WEBPACK_IMPORTED_MODULE_1__.useState)(null), 2), syncResult = _useState1[0], setSyncResult = _useState1[1];
200
+ var _useState2 = _sliced_to_array((0,react__WEBPACK_IMPORTED_MODULE_1__.useState)(false), 2), showResult = _useState2[0], setShowResult = _useState2[1];
201
+ var handleSync = function() {
202
+ return _async_to_generator(function() {
203
+ var result, error;
204
+ return _ts_generator(this, function(_state) {
205
+ switch(_state.label){
206
+ case 0:
207
+ if (!isEnabled || isSyncing) return [
208
+ 2
209
+ ];
210
+ setIsSyncing(true);
211
+ setSyncResult(null);
212
+ setShowResult(false);
213
+ _state.label = 1;
214
+ case 1:
215
+ _state.trys.push([
216
+ 1,
217
+ 3,
218
+ 4,
219
+ 5
220
+ ]);
221
+ return [
222
+ 4,
223
+ syncSinglePatient(patient)
224
+ ];
225
+ case 2:
226
+ result = _state.sent();
227
+ setSyncResult(result);
228
+ setShowResult(true);
229
+ if (onSyncComplete) {
230
+ onSyncComplete(result);
231
+ }
232
+ // Auto-hide result after 3 seconds
233
+ setTimeout(function() {
234
+ setShowResult(false);
235
+ setSyncResult(null);
236
+ }, 3000);
237
+ return [
238
+ 3,
239
+ 5
240
+ ];
241
+ case 3:
242
+ error = _state.sent();
243
+ setSyncResult({
244
+ success: false,
245
+ synchronized: 0,
246
+ failed: 1,
247
+ errors: [
248
+ error.message
249
+ ]
250
+ });
251
+ setShowResult(true);
252
+ setTimeout(function() {
253
+ setShowResult(false);
254
+ setSyncResult(null);
255
+ }, 5000);
256
+ return [
257
+ 3,
258
+ 5
259
+ ];
260
+ case 4:
261
+ setIsSyncing(false);
262
+ return [
263
+ 7
264
+ ];
265
+ case 5:
266
+ return [
267
+ 2
268
+ ];
269
+ }
270
+ });
271
+ })();
272
+ };
273
+ if (isSyncing) {
274
+ return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_1___default().createElement("div", {
275
+ className: _dyaku_patient_sync_button_scss__WEBPACK_IMPORTED_MODULE_3__["default"].syncingContainer
276
+ }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_1___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_0__.InlineLoading, {
277
+ description: t('syncingPatient', 'Sincronizando...')
278
+ }));
279
+ }
280
+ if (showResult && syncResult) {
281
+ return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_1___default().createElement("div", {
282
+ className: _dyaku_patient_sync_button_scss__WEBPACK_IMPORTED_MODULE_3__["default"].resultContainer
283
+ }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_1___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_0__.InlineNotification, {
284
+ kind: syncResult.success ? 'success' : 'error',
285
+ title: syncResult.success ? t('syncSuccess', 'Éxito') : t('syncError', 'Error'),
286
+ subtitle: syncResult.success ? t('patientSyncedSuccessfully', 'Paciente sincronizado') : syncResult.errors[0] || t('syncErrorOccurred', 'Error en sincronización'),
287
+ hideCloseButton: true,
288
+ lowContrast: true,
289
+ className: _dyaku_patient_sync_button_scss__WEBPACK_IMPORTED_MODULE_3__["default"].notification
290
+ }));
291
+ }
292
+ return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_1___default().createElement(_carbon_react__WEBPACK_IMPORTED_MODULE_0__.Button, {
293
+ kind: "ghost",
294
+ size: size,
295
+ renderIcon: (syncResult === null || syncResult === void 0 ? void 0 : syncResult.success) ? _carbon_react_icons__WEBPACK_IMPORTED_MODULE_5__.CheckmarkOutline : _carbon_react_icons__WEBPACK_IMPORTED_MODULE_5__.CloudUpload,
296
+ onClick: handleSync,
297
+ disabled: !isEnabled,
298
+ className: "".concat(_dyaku_patient_sync_button_scss__WEBPACK_IMPORTED_MODULE_3__["default"].syncButton, " ").concat((syncResult === null || syncResult === void 0 ? void 0 : syncResult.success) ? _dyaku_patient_sync_button_scss__WEBPACK_IMPORTED_MODULE_3__["default"].synced : ''),
299
+ hasIconOnly: true,
300
+ iconDescription: (syncResult === null || syncResult === void 0 ? void 0 : syncResult.success) ? t('patientAlreadySynced', 'Paciente sincronizado') : t('syncPatient', 'Sincronizar paciente')
301
+ });
302
+ };
303
+ /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (DyakuPatientSyncButton);
304
+
305
+
306
+ /***/ })
307
+
308
+ });
309
+ //# sourceMappingURL=src_dyaku-patients_dyaku_main_component_tsx.52df2f9ab9342568.hot-update.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"src_dyaku-patients_dyaku_main_component_tsx.52df2f9ab9342568.hot-update.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAA0E;AACN;AAC5B;AACO;AACO;AACwC;AAQ9F,IAAMU,yBAAgE;QAAGC,gBAAAA,SAASC,uBAAAA,oCAAgBC,MAAAA,gCAAO;IACvG,IAAM,IAAQN,6DAAcA,GAApBO;IACR,IAAyCL,gBAAAA,yJAAYA,IAA7CM,oBAAiCN,cAAjCM,mBAAmBC,YAAcP,cAAdO;IAC3B,IAAkCV,6BAAAA,+CAAQA,CAAC,YAApCW,YAA2BX,cAAhBY,eAAgBZ;IAClC,IAAoCA,8BAAAA,+CAAQA,CAAoB,WAAzDa,aAA6Bb,eAAjBc,gBAAiBd;IACpC,IAAoCA,8BAAAA,+CAAQA,CAAC,YAAtCe,aAA6Bf,eAAjBgB,gBAAiBhB;IAEpC,IAAMiB,aAAa;;gBAQTC,QAaCC;;;;wBApBT,IAAI,CAACT,aAAaC,WAAW;;;wBAE7BC,aAAa;wBACbE,cAAc;wBACdE,cAAc;;;;;;;;;wBAGG;;4BAAMP,kBAAkBJ;;;wBAAjCa,SAAS;wBACfJ,cAAcI;wBACdF,cAAc;wBAEd,IAAIV,gBAAgB;4BAClBA,eAAeY;wBACjB;wBAEA,mCAAmC;wBACnCE,WAAW;4BACTJ,cAAc;4BACdF,cAAc;wBAChB,GAAG;;;;;;wBACIK;wBACPL,cAAc;4BACZO,SAAS;4BACTC,cAAc;4BACdC,QAAQ;4BACRC,MAAM;gCAAGL,MAAMM,OAAO;;wBACxB;wBACAT,cAAc;wBAEdI,WAAW;4BACTJ,cAAc;4BACdF,cAAc;wBAChB,GAAG;;;;;;wBAEHF,aAAa;;;;;;;;;;QAEjB;;IAEA,IAAID,WAAW;QACb,qBACE,2DAACe;YAAIC,WAAWzB,uEAAMA,CAAC0B,gBAAgB;yBACrC,2DAACjC,wDAAaA;YAACkC,aAAarB,EAAE,kBAAkB;;IAGtD;IAEA,IAAIO,cAAcF,YAAY;QAC5B,qBACE,2DAACa;YAAIC,WAAWzB,uEAAMA,CAAC4B,eAAe;yBACpC,2DAAClC,6DAAkBA;YACjBmC,MAAMlB,WAAWQ,OAAO,GAAG,YAAY;YACvCW,OAAOnB,WAAWQ,OAAO,GAAGb,EAAE,eAAe,WAAWA,EAAE,aAAa;YACvEyB,UACEpB,WAAWQ,OAAO,GACdb,EAAE,6BAA6B,2BAC/BK,WAAWW,MAAM,CAAC,EAAE,IAAIhB,EAAE,qBAAqB;YAErD0B,iBAAAA;YACAC,aAAAA;YACAR,WAAWzB,uEAAMA,CAACkC,YAAY;;IAItC;IAEA,qBACE,2DAAC1C,iDAAMA;QACLqC,MAAK;QACLxB,MAAMA;QACN8B,YAAYxB,CAAAA,uBAAAA,iCAAAA,WAAYQ,OAAO,IAAGxB,iEAAgBA,GAAGC,4DAAWA;QAChEwC,SAASrB;QACTsB,UAAU,CAAC7B;QACXiB,WAAW,GAAwBd,OAArBX,uEAAMA,CAACsC,UAAU,EAAC,KAA4C,OAAzC3B,CAAAA,uBAAAA,iCAAAA,WAAYQ,OAAO,IAAGnB,uEAAMA,CAACuC,MAAM,GAAG;QACzEC,aAAAA;QACAC,iBACE9B,CAAAA,uBAAAA,iCAAAA,WAAYQ,OAAO,IACfb,EAAE,wBAAwB,2BAC1BA,EAAE,eAAe;;AAI7B;AAEA,iEAAeJ,sBAAsBA,EAAC","sources":["webpack://@pucp-gidis-hiisc/esm-dyaku-app/./src/dyaku-patients/dyaku-patient-sync-button.component.tsx"],"sourcesContent":["import { Button, InlineLoading, InlineNotification } from '@carbon/react';\nimport { CheckmarkOutline, CloudUpload } from '@carbon/react/icons';\nimport React, { useState } from 'react';\nimport { useTranslation } from 'react-i18next';\nimport styles from './dyaku-patient-sync-button.scss';\nimport { useDyakuSync, type DyakuPatient, type SyncResult } from '../dyaku-patients.resource';\n\ninterface DyakuPatientSyncButtonProps {\n patient: DyakuPatient;\n onSyncComplete?: (result: SyncResult) => void;\n size?: 'sm' | 'md' | 'lg';\n}\n\nconst DyakuPatientSyncButton: React.FC<DyakuPatientSyncButtonProps> = ({ patient, onSyncComplete, size = 'sm' }) => {\n const { t } = useTranslation();\n const { syncSinglePatient, isEnabled } = useDyakuSync();\n const [isSyncing, setIsSyncing] = useState(false);\n const [syncResult, setSyncResult] = useState<SyncResult | null>(null);\n const [showResult, setShowResult] = useState(false);\n\n const handleSync = async () => {\n if (!isEnabled || isSyncing) return;\n\n setIsSyncing(true);\n setSyncResult(null);\n setShowResult(false);\n\n try {\n const result = await syncSinglePatient(patient);\n setSyncResult(result);\n setShowResult(true);\n\n if (onSyncComplete) {\n onSyncComplete(result);\n }\n\n // Auto-hide result after 3 seconds\n setTimeout(() => {\n setShowResult(false);\n setSyncResult(null);\n }, 3000);\n } catch (error) {\n setSyncResult({\n success: false,\n synchronized: 0,\n failed: 1,\n errors: [error.message],\n });\n setShowResult(true);\n\n setTimeout(() => {\n setShowResult(false);\n setSyncResult(null);\n }, 5000);\n } finally {\n setIsSyncing(false);\n }\n };\n\n if (isSyncing) {\n return (\n <div className={styles.syncingContainer}>\n <InlineLoading description={t('syncingPatient', 'Sincronizando...')} />\n </div>\n );\n }\n\n if (showResult && syncResult) {\n return (\n <div className={styles.resultContainer}>\n <InlineNotification\n kind={syncResult.success ? 'success' : 'error'}\n title={syncResult.success ? t('syncSuccess', 'Éxito') : t('syncError', 'Error')}\n subtitle={\n syncResult.success\n ? t('patientSyncedSuccessfully', 'Paciente sincronizado')\n : syncResult.errors[0] || t('syncErrorOccurred', 'Error en sincronización')\n }\n hideCloseButton\n lowContrast\n className={styles.notification}\n />\n </div>\n );\n }\n\n return (\n <Button\n kind=\"ghost\"\n size={size}\n renderIcon={syncResult?.success ? CheckmarkOutline : CloudUpload}\n onClick={handleSync}\n disabled={!isEnabled}\n className={`${styles.syncButton} ${syncResult?.success ? styles.synced : ''}`}\n hasIconOnly\n iconDescription={\n syncResult?.success\n ? t('patientAlreadySynced', 'Paciente sincronizado')\n : t('syncPatient', 'Sincronizar paciente')\n }\n />\n );\n};\n\nexport default DyakuPatientSyncButton;\n"],"names":["Button","InlineLoading","InlineNotification","CheckmarkOutline","CloudUpload","React","useState","useTranslation","styles","useDyakuSync","DyakuPatientSyncButton","patient","onSyncComplete","size","t","syncSinglePatient","isEnabled","isSyncing","setIsSyncing","syncResult","setSyncResult","showResult","setShowResult","handleSync","result","error","setTimeout","success","synchronized","failed","errors","message","div","className","syncingContainer","description","resultContainer","kind","title","subtitle","hideCloseButton","lowContrast","notification","renderIcon","onClick","disabled","syncButton","synced","hasIconOnly","iconDescription"],"sourceRoot":""}