@awell-health/awell-extensions 1.0.232 → 1.0.234

Sign up to get free protection for your applications and to get access to all the features.
Files changed (168) hide show
  1. package/dist/extensions/index.js +2 -0
  2. package/dist/extensions/index.js.map +1 -1
  3. package/dist/extensions/markdown.json +4 -0
  4. package/dist/extensions/medplum/actions/createPatient/config/dataPoints.d.ts +6 -0
  5. package/dist/extensions/medplum/actions/createPatient/config/dataPoints.js +10 -0
  6. package/dist/extensions/medplum/actions/createPatient/config/dataPoints.js.map +1 -0
  7. package/dist/extensions/medplum/actions/createPatient/config/fields.d.ts +119 -0
  8. package/dist/extensions/medplum/actions/createPatient/config/fields.js +87 -0
  9. package/dist/extensions/medplum/actions/createPatient/config/fields.js.map +1 -0
  10. package/dist/extensions/medplum/actions/createPatient/config/index.d.ts +2 -0
  11. package/dist/extensions/medplum/actions/createPatient/config/index.js +19 -0
  12. package/dist/extensions/medplum/actions/createPatient/config/index.js.map +1 -0
  13. package/dist/extensions/medplum/actions/createPatient/createPatient.d.ts +4 -0
  14. package/dist/extensions/medplum/actions/createPatient/createPatient.js +84 -0
  15. package/dist/extensions/medplum/actions/createPatient/createPatient.js.map +1 -0
  16. package/dist/extensions/medplum/actions/createPatient/createPatient.test.d.ts +1 -0
  17. package/dist/extensions/medplum/actions/createPatient/createPatient.test.js +47 -0
  18. package/dist/extensions/medplum/actions/createPatient/createPatient.test.js.map +1 -0
  19. package/dist/extensions/medplum/actions/createPatient/index.d.ts +1 -0
  20. package/dist/extensions/medplum/actions/createPatient/index.js +6 -0
  21. package/dist/extensions/medplum/actions/createPatient/index.js.map +1 -0
  22. package/dist/extensions/medplum/actions/createServiceRequest/config/dataPoints.d.ts +6 -0
  23. package/dist/extensions/medplum/actions/createServiceRequest/config/dataPoints.js +10 -0
  24. package/dist/extensions/medplum/actions/createServiceRequest/config/dataPoints.js.map +1 -0
  25. package/dist/extensions/medplum/actions/createServiceRequest/config/fields.d.ts +48 -0
  26. package/dist/extensions/medplum/actions/createServiceRequest/config/fields.js +37 -0
  27. package/dist/extensions/medplum/actions/createServiceRequest/config/fields.js.map +1 -0
  28. package/dist/extensions/medplum/actions/createServiceRequest/config/index.d.ts +2 -0
  29. package/dist/extensions/medplum/actions/createServiceRequest/config/index.js +19 -0
  30. package/dist/extensions/medplum/actions/createServiceRequest/config/index.js.map +1 -0
  31. package/dist/extensions/medplum/actions/createServiceRequest/createServiceRequest.d.ts +4 -0
  32. package/dist/extensions/medplum/actions/createServiceRequest/createServiceRequest.js +44 -0
  33. package/dist/extensions/medplum/actions/createServiceRequest/createServiceRequest.js.map +1 -0
  34. package/dist/extensions/medplum/actions/createServiceRequest/createServiceRequest.test.d.ts +1 -0
  35. package/dist/extensions/medplum/actions/createServiceRequest/createServiceRequest.test.js +40 -0
  36. package/dist/extensions/medplum/actions/createServiceRequest/createServiceRequest.test.js.map +1 -0
  37. package/dist/extensions/medplum/actions/createServiceRequest/index.d.ts +1 -0
  38. package/dist/extensions/medplum/actions/createServiceRequest/index.js +6 -0
  39. package/dist/extensions/medplum/actions/createServiceRequest/index.js.map +1 -0
  40. package/dist/extensions/medplum/actions/createTask/config/dataPoints.d.ts +6 -0
  41. package/dist/extensions/medplum/actions/createTask/config/dataPoints.js +10 -0
  42. package/dist/extensions/medplum/actions/createTask/config/dataPoints.js.map +1 -0
  43. package/dist/extensions/medplum/actions/createTask/config/fields.d.ts +88 -0
  44. package/dist/extensions/medplum/actions/createTask/config/fields.js +65 -0
  45. package/dist/extensions/medplum/actions/createTask/config/fields.js.map +1 -0
  46. package/dist/extensions/medplum/actions/createTask/config/index.d.ts +2 -0
  47. package/dist/extensions/medplum/actions/createTask/config/index.js +19 -0
  48. package/dist/extensions/medplum/actions/createTask/config/index.js.map +1 -0
  49. package/dist/extensions/medplum/actions/createTask/createTask.d.ts +4 -0
  50. package/dist/extensions/medplum/actions/createTask/createTask.js +56 -0
  51. package/dist/extensions/medplum/actions/createTask/createTask.js.map +1 -0
  52. package/dist/extensions/medplum/actions/createTask/createTask.test.d.ts +1 -0
  53. package/dist/extensions/medplum/actions/createTask/createTask.test.js +41 -0
  54. package/dist/extensions/medplum/actions/createTask/createTask.test.js.map +1 -0
  55. package/dist/extensions/medplum/actions/createTask/index.d.ts +1 -0
  56. package/dist/extensions/medplum/actions/createTask/index.js +6 -0
  57. package/dist/extensions/medplum/actions/createTask/index.js.map +1 -0
  58. package/dist/extensions/medplum/actions/executeBot/config/dataPoints.d.ts +6 -0
  59. package/dist/extensions/medplum/actions/executeBot/config/dataPoints.js +10 -0
  60. package/dist/extensions/medplum/actions/executeBot/config/dataPoints.js.map +1 -0
  61. package/dist/extensions/medplum/actions/executeBot/config/fields.d.ts +34 -0
  62. package/dist/extensions/medplum/actions/executeBot/config/fields.js +41 -0
  63. package/dist/extensions/medplum/actions/executeBot/config/fields.js.map +1 -0
  64. package/dist/extensions/medplum/actions/executeBot/config/index.d.ts +2 -0
  65. package/dist/extensions/medplum/actions/executeBot/config/index.js +19 -0
  66. package/dist/extensions/medplum/actions/executeBot/config/index.js.map +1 -0
  67. package/dist/extensions/medplum/actions/executeBot/executeBot.d.ts +4 -0
  68. package/dist/extensions/medplum/actions/executeBot/executeBot.js +28 -0
  69. package/dist/extensions/medplum/actions/executeBot/executeBot.js.map +1 -0
  70. package/dist/extensions/medplum/actions/executeBot/executeBot.test.d.ts +1 -0
  71. package/dist/extensions/medplum/actions/executeBot/executeBot.test.js +35 -0
  72. package/dist/extensions/medplum/actions/executeBot/executeBot.test.js.map +1 -0
  73. package/dist/extensions/medplum/actions/executeBot/index.d.ts +1 -0
  74. package/dist/extensions/medplum/actions/executeBot/index.js +6 -0
  75. package/dist/extensions/medplum/actions/executeBot/index.js.map +1 -0
  76. package/dist/extensions/medplum/actions/getAppointment/config/dataPoints.d.ts +6 -0
  77. package/dist/extensions/medplum/actions/getAppointment/config/dataPoints.js +10 -0
  78. package/dist/extensions/medplum/actions/getAppointment/config/dataPoints.js.map +1 -0
  79. package/dist/extensions/medplum/actions/getAppointment/config/fields.d.ts +18 -0
  80. package/dist/extensions/medplum/actions/getAppointment/config/fields.js +20 -0
  81. package/dist/extensions/medplum/actions/getAppointment/config/fields.js.map +1 -0
  82. package/dist/extensions/medplum/actions/getAppointment/config/index.d.ts +2 -0
  83. package/dist/extensions/medplum/actions/getAppointment/config/index.js +19 -0
  84. package/dist/extensions/medplum/actions/getAppointment/config/index.js.map +1 -0
  85. package/dist/extensions/medplum/actions/getAppointment/getAppointment.d.ts +4 -0
  86. package/dist/extensions/medplum/actions/getAppointment/getAppointment.js +33 -0
  87. package/dist/extensions/medplum/actions/getAppointment/getAppointment.js.map +1 -0
  88. package/dist/extensions/medplum/actions/getAppointment/getAppointment.test.d.ts +1 -0
  89. package/dist/extensions/medplum/actions/getAppointment/getAppointment.test.js +34 -0
  90. package/dist/extensions/medplum/actions/getAppointment/getAppointment.test.js.map +1 -0
  91. package/dist/extensions/medplum/actions/getAppointment/index.d.ts +1 -0
  92. package/dist/extensions/medplum/actions/getAppointment/index.js +6 -0
  93. package/dist/extensions/medplum/actions/getAppointment/index.js.map +1 -0
  94. package/dist/extensions/medplum/actions/getPatient/config/dataPoints.d.ts +6 -0
  95. package/dist/extensions/medplum/actions/getPatient/config/dataPoints.js +10 -0
  96. package/dist/extensions/medplum/actions/getPatient/config/dataPoints.js.map +1 -0
  97. package/dist/extensions/medplum/actions/getPatient/config/fields.d.ts +18 -0
  98. package/dist/extensions/medplum/actions/getPatient/config/fields.js +20 -0
  99. package/dist/extensions/medplum/actions/getPatient/config/fields.js.map +1 -0
  100. package/dist/extensions/medplum/actions/getPatient/config/index.d.ts +2 -0
  101. package/dist/extensions/medplum/actions/getPatient/config/index.js +19 -0
  102. package/dist/extensions/medplum/actions/getPatient/config/index.js.map +1 -0
  103. package/dist/extensions/medplum/actions/getPatient/getPatient.d.ts +4 -0
  104. package/dist/extensions/medplum/actions/getPatient/getPatient.js +33 -0
  105. package/dist/extensions/medplum/actions/getPatient/getPatient.js.map +1 -0
  106. package/dist/extensions/medplum/actions/getPatient/getPatient.test.d.ts +1 -0
  107. package/dist/extensions/medplum/actions/getPatient/getPatient.test.js +34 -0
  108. package/dist/extensions/medplum/actions/getPatient/getPatient.test.js.map +1 -0
  109. package/dist/extensions/medplum/actions/getPatient/index.d.ts +1 -0
  110. package/dist/extensions/medplum/actions/getPatient/index.js +6 -0
  111. package/dist/extensions/medplum/actions/getPatient/index.js.map +1 -0
  112. package/dist/extensions/medplum/actions/index.d.ts +6 -0
  113. package/dist/extensions/medplum/actions/index.js +16 -0
  114. package/dist/extensions/medplum/actions/index.js.map +1 -0
  115. package/dist/extensions/medplum/fhir/schemas/atoms/GenderSchema.d.ts +2 -0
  116. package/dist/extensions/medplum/fhir/schemas/atoms/GenderSchema.js +11 -0
  117. package/dist/extensions/medplum/fhir/schemas/atoms/GenderSchema.js.map +1 -0
  118. package/dist/extensions/medplum/fhir/schemas/atoms/IntentSchema.d.ts +3 -0
  119. package/dist/extensions/medplum/fhir/schemas/atoms/IntentSchema.js +27 -0
  120. package/dist/extensions/medplum/fhir/schemas/atoms/IntentSchema.js.map +1 -0
  121. package/dist/extensions/medplum/fhir/schemas/atoms/PeriodSchema.d.ts +14 -0
  122. package/dist/extensions/medplum/fhir/schemas/atoms/PeriodSchema.js +10 -0
  123. package/dist/extensions/medplum/fhir/schemas/atoms/PeriodSchema.js.map +1 -0
  124. package/dist/extensions/medplum/fhir/schemas/atoms/PrioritySchema.d.ts +2 -0
  125. package/dist/extensions/medplum/fhir/schemas/atoms/PrioritySchema.js +11 -0
  126. package/dist/extensions/medplum/fhir/schemas/atoms/PrioritySchema.js.map +1 -0
  127. package/dist/extensions/medplum/fhir/schemas/atoms/StatusSchema.d.ts +3 -0
  128. package/dist/extensions/medplum/fhir/schemas/atoms/StatusSchema.js +28 -0
  129. package/dist/extensions/medplum/fhir/schemas/atoms/StatusSchema.js.map +1 -0
  130. package/dist/extensions/medplum/fhir/schemas/atoms/index.d.ts +5 -0
  131. package/dist/extensions/medplum/fhir/schemas/atoms/index.js +16 -0
  132. package/dist/extensions/medplum/fhir/schemas/atoms/index.js.map +1 -0
  133. package/dist/extensions/medplum/fhir/schemas/index.d.ts +1 -0
  134. package/dist/extensions/medplum/fhir/schemas/index.js +6 -0
  135. package/dist/extensions/medplum/fhir/schemas/index.js.map +1 -0
  136. package/dist/extensions/medplum/fhir/schemas/resources/index.d.ts +3 -0
  137. package/dist/extensions/medplum/fhir/schemas/resources/index.js +10 -0
  138. package/dist/extensions/medplum/fhir/schemas/resources/index.js.map +1 -0
  139. package/dist/extensions/medplum/fhir/schemas/resources/patient.schema.d.ts +38 -0
  140. package/dist/extensions/medplum/fhir/schemas/resources/patient.schema.js +20 -0
  141. package/dist/extensions/medplum/fhir/schemas/resources/patient.schema.js.map +1 -0
  142. package/dist/extensions/medplum/fhir/schemas/resources/serviceRequest.schema.d.ts +17 -0
  143. package/dist/extensions/medplum/fhir/schemas/resources/serviceRequest.schema.js +12 -0
  144. package/dist/extensions/medplum/fhir/schemas/resources/serviceRequest.schema.js.map +1 -0
  145. package/dist/extensions/medplum/fhir/schemas/resources/task.schema.d.ts +29 -0
  146. package/dist/extensions/medplum/fhir/schemas/resources/task.schema.js +17 -0
  147. package/dist/extensions/medplum/fhir/schemas/resources/task.schema.js.map +1 -0
  148. package/dist/extensions/medplum/index.d.ts +2 -0
  149. package/dist/extensions/medplum/index.js +42 -0
  150. package/dist/extensions/medplum/index.js.map +1 -0
  151. package/dist/extensions/medplum/settings.d.ts +27 -0
  152. package/dist/extensions/medplum/settings.js +25 -0
  153. package/dist/extensions/medplum/settings.js.map +1 -0
  154. package/dist/extensions/medplum/utils/index.d.ts +2 -0
  155. package/dist/extensions/medplum/utils/index.js +7 -0
  156. package/dist/extensions/medplum/utils/index.js.map +1 -0
  157. package/dist/extensions/medplum/utils/validateAndCreateSdkClient.d.ts +17 -0
  158. package/dist/extensions/medplum/utils/validateAndCreateSdkClient.js +27 -0
  159. package/dist/extensions/medplum/utils/validateAndCreateSdkClient.js.map +1 -0
  160. package/dist/extensions/talkDesk/actions/index.d.ts +7 -0
  161. package/dist/extensions/talkDesk/actions/triggerFlow/config/fields.d.ts +10 -0
  162. package/dist/extensions/talkDesk/actions/triggerFlow/config/fields.js +9 -1
  163. package/dist/extensions/talkDesk/actions/triggerFlow/config/fields.js.map +1 -1
  164. package/dist/extensions/talkDesk/actions/triggerFlow/triggerFlow.js +14 -7
  165. package/dist/extensions/talkDesk/actions/triggerFlow/triggerFlow.js.map +1 -1
  166. package/dist/extensions/talkDesk/actions/triggerFlow/triggerFlow.test.js +1 -0
  167. package/dist/extensions/talkDesk/actions/triggerFlow/triggerFlow.test.js.map +1 -1
  168. package/package.json +4 -1
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createServiceRequest = void 0;
4
+ const extensions_core_1 = require("@awell-health/extensions-core");
5
+ const config_1 = require("./config");
6
+ const utils_1 = require("../../utils");
7
+ exports.createServiceRequest = {
8
+ key: 'createServiceRequest',
9
+ category: extensions_core_1.Category.EHR_INTEGRATIONS,
10
+ title: 'Create service request',
11
+ description: 'Create a service request in Medplum',
12
+ fields: config_1.fields,
13
+ previewable: false,
14
+ dataPoints: config_1.dataPoints,
15
+ onActivityCreated: async (payload, onComplete, onError) => {
16
+ const { fields: input, medplumSdk, activity, } = await (0, utils_1.validateAndCreateSdkClient)({
17
+ fieldsSchema: config_1.FieldsValidationSchema,
18
+ payload,
19
+ });
20
+ const res = await medplumSdk.createResource({
21
+ resourceType: 'ServiceRequest',
22
+ status: input.status,
23
+ intent: input.intent,
24
+ priority: input.priority,
25
+ subject: {
26
+ reference: `Patient/${input.patientId}`,
27
+ },
28
+ requester: {
29
+ identifier: {
30
+ system: 'https://awellhealth.com/activities/',
31
+ value: activity.id,
32
+ },
33
+ display: 'Awell',
34
+ },
35
+ });
36
+ await onComplete({
37
+ data_points: {
38
+ // @ts-expect-error id is not included in the response type?
39
+ serviceRequestId: res.id,
40
+ },
41
+ });
42
+ },
43
+ };
44
+ //# sourceMappingURL=createServiceRequest.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createServiceRequest.js","sourceRoot":"","sources":["../../../../../extensions/medplum/actions/createServiceRequest/createServiceRequest.ts"],"names":[],"mappings":";;;AAAA,mEAAqE;AAErE,qCAAqE;AACrE,uCAAwD;AAE3C,QAAA,oBAAoB,GAI7B;IACF,GAAG,EAAE,sBAAsB;IAC3B,QAAQ,EAAE,0BAAQ,CAAC,gBAAgB;IACnC,KAAK,EAAE,wBAAwB;IAC/B,WAAW,EAAE,qCAAqC;IAClD,MAAM,EAAN,eAAM;IACN,WAAW,EAAE,KAAK;IAClB,UAAU,EAAV,mBAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,OAAO,EAAiB,EAAE;QACvE,MAAM,EACJ,MAAM,EAAE,KAAK,EACb,UAAU,EACV,QAAQ,GACT,GAAG,MAAM,IAAA,kCAA0B,EAAC;YACnC,YAAY,EAAE,+BAAsB;YACpC,OAAO;SACR,CAAC,CAAA;QAEF,MAAM,GAAG,GAAG,MAAM,UAAU,CAAC,cAAc,CAAC;YAC1C,YAAY,EAAE,gBAAgB;YAC9B,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,OAAO,EAAE;gBACP,SAAS,EAAE,WAAW,KAAK,CAAC,SAAS,EAAE;aACxC;YACD,SAAS,EAAE;gBACT,UAAU,EAAE;oBACV,MAAM,EAAE,qCAAqC;oBAC7C,KAAK,EAAE,QAAQ,CAAC,EAAE;iBACnB;gBACD,OAAO,EAAE,OAAO;aACjB;SACF,CAAC,CAAA;QAEF,MAAM,UAAU,CAAC;YACf,WAAW,EAAE;gBACX,4DAA4D;gBAC5D,gBAAgB,EAAE,GAAG,CAAC,EAAE;aACzB;SACF,CAAC,CAAA;IACJ,CAAC;CACF,CAAA"}
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const _1 = require(".");
4
+ const tests_1 = require("../../../../src/tests");
5
+ const __mocks__1 = require("../../__mocks__");
6
+ jest.mock('@medplum/core', () => {
7
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
8
+ const { MedplumClient: MedplumMockClient } = require('../../__mocks__');
9
+ return {
10
+ MedplumClient: MedplumMockClient,
11
+ };
12
+ });
13
+ describe('Medplum - Create service request', () => {
14
+ const onComplete = jest.fn();
15
+ const onError = jest.fn();
16
+ beforeEach(() => {
17
+ jest.clearAllMocks();
18
+ });
19
+ test('Should create a service request', async () => {
20
+ const mockOnActivityCreateParams = (0, tests_1.generateTestPayload)({
21
+ fields: {
22
+ patientId: '5d1e74dd-6b92-43e6-ab07-e55d1033fbb6',
23
+ status: 'active',
24
+ intent: 'directive',
25
+ priority: 'urgent',
26
+ },
27
+ activity: {
28
+ id: 'test-activity-id',
29
+ },
30
+ settings: __mocks__1.mockSettings,
31
+ });
32
+ await _1.createServiceRequest.onActivityCreated(mockOnActivityCreateParams, onComplete, onError);
33
+ expect(onComplete).toHaveBeenCalledWith({
34
+ data_points: {
35
+ serviceRequestId: __mocks__1.mockCreateServiceRequestResponse.id,
36
+ },
37
+ });
38
+ });
39
+ });
40
+ //# sourceMappingURL=createServiceRequest.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createServiceRequest.test.js","sourceRoot":"","sources":["../../../../../extensions/medplum/actions/createServiceRequest/createServiceRequest.test.ts"],"names":[],"mappings":";;AAAA,wBAAwC;AACxC,iDAA2D;AAC3D,8CAAgF;AAEhF,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,GAAG,EAAE;IAC9B,8DAA8D;IAC9D,MAAM,EAAE,aAAa,EAAE,iBAAiB,EAAE,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAA;IAEvE,OAAO;QACL,aAAa,EAAE,iBAAiB;KACjC,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,QAAQ,CAAC,kCAAkC,EAAE,GAAG,EAAE;IAChD,MAAM,UAAU,GAAG,IAAI,CAAC,EAAE,EAAE,CAAA;IAC5B,MAAM,OAAO,GAAG,IAAI,CAAC,EAAE,EAAE,CAAA;IAEzB,UAAU,CAAC,GAAG,EAAE;QACd,IAAI,CAAC,aAAa,EAAE,CAAA;IACtB,CAAC,CAAC,CAAA;IAEF,IAAI,CAAC,iCAAiC,EAAE,KAAK,IAAI,EAAE;QACjD,MAAM,0BAA0B,GAAG,IAAA,2BAAmB,EAAC;YACrD,MAAM,EAAE;gBACN,SAAS,EAAE,sCAAsC;gBACjD,MAAM,EAAE,QAAQ;gBAChB,MAAM,EAAE,WAAW;gBACnB,QAAQ,EAAE,QAAQ;aACnB;YACD,QAAQ,EAAE;gBACR,EAAE,EAAE,kBAAkB;aACvB;YACD,QAAQ,EAAE,uBAAY;SACvB,CAAC,CAAA;QAEF,MAAM,uBAAoB,CAAC,iBAAiB,CAC1C,0BAA0B,EAC1B,UAAU,EACV,OAAO,CACR,CAAA;QAED,MAAM,CAAC,UAAU,CAAC,CAAC,oBAAoB,CAAC;YACtC,WAAW,EAAE;gBACX,gBAAgB,EAAE,2CAAgC,CAAC,EAAE;aACtD;SACF,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
@@ -0,0 +1 @@
1
+ export { createServiceRequest } from './createServiceRequest';
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createServiceRequest = void 0;
4
+ var createServiceRequest_1 = require("./createServiceRequest");
5
+ Object.defineProperty(exports, "createServiceRequest", { enumerable: true, get: function () { return createServiceRequest_1.createServiceRequest; } });
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../extensions/medplum/actions/createServiceRequest/index.ts"],"names":[],"mappings":";;;AAAA,+DAA6D;AAApD,4HAAA,oBAAoB,OAAA"}
@@ -0,0 +1,6 @@
1
+ export declare const dataPoints: {
2
+ taskId: {
3
+ key: string;
4
+ valueType: "string";
5
+ };
6
+ };
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.dataPoints = void 0;
4
+ exports.dataPoints = {
5
+ taskId: {
6
+ key: 'taskId',
7
+ valueType: 'string',
8
+ },
9
+ };
10
+ //# sourceMappingURL=dataPoints.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dataPoints.js","sourceRoot":"","sources":["../../../../../../extensions/medplum/actions/createTask/config/dataPoints.ts"],"names":[],"mappings":";;;AAEa,QAAA,UAAU,GAAG;IACxB,MAAM,EAAE;QACN,GAAG,EAAE,QAAQ;QACb,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA"}
@@ -0,0 +1,88 @@
1
+ import { FieldType } from '@awell-health/extensions-core';
2
+ import { type ZodObject, type ZodTypeAny } from 'zod';
3
+ export declare const fields: {
4
+ patientId: {
5
+ id: string;
6
+ label: string;
7
+ description: string;
8
+ type: FieldType.STRING;
9
+ required: true;
10
+ };
11
+ taskTitle: {
12
+ id: string;
13
+ label: string;
14
+ description: string;
15
+ type: FieldType.STRING;
16
+ required: true;
17
+ };
18
+ description: {
19
+ id: string;
20
+ label: string;
21
+ description: string;
22
+ type: FieldType.STRING;
23
+ required: false;
24
+ };
25
+ status: {
26
+ id: string;
27
+ label: string;
28
+ description: string;
29
+ type: FieldType.STRING;
30
+ required: true;
31
+ };
32
+ intent: {
33
+ id: string;
34
+ label: string;
35
+ description: string;
36
+ type: FieldType.STRING;
37
+ required: true;
38
+ };
39
+ priority: {
40
+ id: string;
41
+ label: string;
42
+ description: string;
43
+ type: FieldType.STRING;
44
+ required: false;
45
+ };
46
+ dueDate: {
47
+ id: string;
48
+ label: string;
49
+ description: string;
50
+ type: FieldType.DATE;
51
+ required: false;
52
+ };
53
+ performerType: {
54
+ id: string;
55
+ label: string;
56
+ description: string;
57
+ type: FieldType.DATE;
58
+ required: false;
59
+ };
60
+ };
61
+ export declare const FieldsValidationSchema: ZodObject<{
62
+ patientId: import("zod").ZodString;
63
+ taskTitle: import("zod").ZodString;
64
+ description: import("zod").ZodOptional<import("zod").ZodString>;
65
+ status: import("zod").ZodUnion<[import("zod").ZodLiteral<"draft">, import("zod").ZodLiteral<"requested">, import("zod").ZodLiteral<"received">, import("zod").ZodLiteral<"accepted">, import("zod").ZodLiteral<"rejected">, import("zod").ZodLiteral<"ready">, import("zod").ZodLiteral<"cancelled">, import("zod").ZodLiteral<"in-progress">, import("zod").ZodLiteral<"on-hold">, import("zod").ZodLiteral<"failed">, import("zod").ZodLiteral<"completed">, import("zod").ZodLiteral<"entered-in-error">]>;
66
+ intent: import("zod").ZodUnion<[import("zod").ZodLiteral<"unknown">, import("zod").ZodLiteral<"proposal">, import("zod").ZodLiteral<"plan">, import("zod").ZodLiteral<"order">, import("zod").ZodLiteral<"original-order">, import("zod").ZodLiteral<"reflex-order">, import("zod").ZodLiteral<"filler-order">, import("zod").ZodLiteral<"instance-order">, import("zod").ZodLiteral<"option">]>;
67
+ priority: import("zod").ZodOptional<import("zod").ZodUnion<[import("zod").ZodLiteral<"routine">, import("zod").ZodLiteral<"urgent">, import("zod").ZodLiteral<"asap">, import("zod").ZodLiteral<"stat">]>>;
68
+ dueDate: import("zod").ZodUnion<[import("zod").ZodOptional<import("zod").ZodEffects<import("zod").ZodDate, string, Date>>, import("zod").ZodEffects<import("zod").ZodLiteral<"">, undefined, "">]>;
69
+ performerType: import("zod").ZodOptional<import("zod").ZodString>;
70
+ }, "strip", ZodTypeAny, {
71
+ status: "failed" | "in-progress" | "completed" | "rejected" | "received" | "ready" | "accepted" | "draft" | "requested" | "cancelled" | "on-hold" | "entered-in-error";
72
+ patientId: string;
73
+ intent: "order" | "option" | "unknown" | "plan" | "proposal" | "original-order" | "reflex-order" | "filler-order" | "instance-order";
74
+ taskTitle: string;
75
+ description?: string | undefined;
76
+ priority?: "routine" | "urgent" | "asap" | "stat" | undefined;
77
+ dueDate?: string | undefined;
78
+ performerType?: string | undefined;
79
+ }, {
80
+ status: "failed" | "in-progress" | "completed" | "rejected" | "received" | "ready" | "accepted" | "draft" | "requested" | "cancelled" | "on-hold" | "entered-in-error";
81
+ patientId: string;
82
+ intent: "order" | "option" | "unknown" | "plan" | "proposal" | "original-order" | "reflex-order" | "filler-order" | "instance-order";
83
+ taskTitle: string;
84
+ description?: string | undefined;
85
+ priority?: "routine" | "urgent" | "asap" | "stat" | undefined;
86
+ dueDate?: "" | Date | undefined;
87
+ performerType?: string | undefined;
88
+ }>;
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FieldsValidationSchema = exports.fields = void 0;
4
+ const extensions_core_1 = require("@awell-health/extensions-core");
5
+ const resources_1 = require("../../../fhir/schemas/resources");
6
+ exports.fields = {
7
+ patientId: {
8
+ id: 'patientId',
9
+ label: 'Patient ID',
10
+ description: 'ID of the patient in Medplum the task is for',
11
+ type: extensions_core_1.FieldType.STRING,
12
+ required: true,
13
+ },
14
+ taskTitle: {
15
+ id: 'taskTitle',
16
+ label: 'Task name',
17
+ description: 'Briefly describes what the task involves',
18
+ type: extensions_core_1.FieldType.STRING,
19
+ required: true,
20
+ },
21
+ description: {
22
+ id: 'description',
23
+ label: 'Description name',
24
+ description: 'Human-readable explanation of task',
25
+ type: extensions_core_1.FieldType.STRING,
26
+ required: false,
27
+ },
28
+ status: {
29
+ id: 'status',
30
+ label: 'Status',
31
+ description: 'The status of the task. Allowed values: draft | requested | received | accepted | rejected | ready | cancelled | in-progress | on-hold | failed | completed | entered-in-error',
32
+ type: extensions_core_1.FieldType.STRING,
33
+ required: true,
34
+ },
35
+ intent: {
36
+ id: 'intent',
37
+ label: 'Mobile phone',
38
+ description: 'Indicates the "level" of actionability associated with the Task. Allowed values: unknown | proposal | plan | order | original-order | reflex-order | filler-order | instance-order | option',
39
+ type: extensions_core_1.FieldType.STRING,
40
+ required: true,
41
+ },
42
+ priority: {
43
+ id: 'priority',
44
+ label: 'Priority',
45
+ description: 'Allowed values: routine | urgent | asap | stat',
46
+ type: extensions_core_1.FieldType.STRING,
47
+ required: false,
48
+ },
49
+ dueDate: {
50
+ id: 'dueDate',
51
+ label: 'Due date',
52
+ description: '',
53
+ type: extensions_core_1.FieldType.DATE,
54
+ required: false,
55
+ },
56
+ performerType: {
57
+ id: 'performerType',
58
+ label: 'Performer type',
59
+ description: 'Who needs to complete the task?',
60
+ type: extensions_core_1.FieldType.DATE,
61
+ required: false,
62
+ },
63
+ };
64
+ exports.FieldsValidationSchema = resources_1.CreateTaskSchema;
65
+ //# sourceMappingURL=fields.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fields.js","sourceRoot":"","sources":["../../../../../../extensions/medplum/actions/createTask/config/fields.ts"],"names":[],"mappings":";;;AAAA,mEAAqE;AAErE,+DAAkE;AAErD,QAAA,MAAM,GAAG;IACpB,SAAS,EAAE;QACT,EAAE,EAAE,WAAW;QACf,KAAK,EAAE,YAAY;QACnB,WAAW,EAAE,8CAA8C;QAC3D,IAAI,EAAE,2BAAS,CAAC,MAAM;QACtB,QAAQ,EAAE,IAAI;KACf;IACD,SAAS,EAAE;QACT,EAAE,EAAE,WAAW;QACf,KAAK,EAAE,WAAW;QAClB,WAAW,EAAE,0CAA0C;QACvD,IAAI,EAAE,2BAAS,CAAC,MAAM;QACtB,QAAQ,EAAE,IAAI;KACf;IACD,WAAW,EAAE;QACX,EAAE,EAAE,aAAa;QACjB,KAAK,EAAE,kBAAkB;QACzB,WAAW,EAAE,oCAAoC;QACjD,IAAI,EAAE,2BAAS,CAAC,MAAM;QACtB,QAAQ,EAAE,KAAK;KAChB;IACD,MAAM,EAAE;QACN,EAAE,EAAE,QAAQ;QACZ,KAAK,EAAE,QAAQ;QACf,WAAW,EACT,gLAAgL;QAClL,IAAI,EAAE,2BAAS,CAAC,MAAM;QACtB,QAAQ,EAAE,IAAI;KACf;IACD,MAAM,EAAE;QACN,EAAE,EAAE,QAAQ;QACZ,KAAK,EAAE,cAAc;QACrB,WAAW,EACT,6LAA6L;QAC/L,IAAI,EAAE,2BAAS,CAAC,MAAM;QACtB,QAAQ,EAAE,IAAI;KACf;IACD,QAAQ,EAAE;QACR,EAAE,EAAE,UAAU;QACd,KAAK,EAAE,UAAU;QACjB,WAAW,EAAE,gDAAgD;QAC7D,IAAI,EAAE,2BAAS,CAAC,MAAM;QACtB,QAAQ,EAAE,KAAK;KAChB;IACD,OAAO,EAAE;QACP,EAAE,EAAE,SAAS;QACb,KAAK,EAAE,UAAU;QACjB,WAAW,EAAE,EAAE;QACf,IAAI,EAAE,2BAAS,CAAC,IAAI;QACpB,QAAQ,EAAE,KAAK;KAChB;IACD,aAAa,EAAE;QACb,EAAE,EAAE,eAAe;QACnB,KAAK,EAAE,gBAAgB;QACvB,WAAW,EAAE,iCAAiC;QAC9C,IAAI,EAAE,2BAAS,CAAC,IAAI;QACpB,QAAQ,EAAE,KAAK;KAChB;CAC8B,CAAA;AAEpB,QAAA,sBAAsB,GAAG,4BAErC,CAAA"}
@@ -0,0 +1,2 @@
1
+ export * from './dataPoints';
2
+ export * from './fields';
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./dataPoints"), exports);
18
+ __exportStar(require("./fields"), exports);
19
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../extensions/medplum/actions/createTask/config/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,+CAA4B;AAC5B,2CAAwB"}
@@ -0,0 +1,4 @@
1
+ import { type Action } from '@awell-health/extensions-core';
2
+ import { type settings } from '../../settings';
3
+ import { fields, dataPoints } from './config';
4
+ export declare const createTask: Action<typeof fields, typeof settings, keyof typeof dataPoints>;
@@ -0,0 +1,56 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createTask = void 0;
4
+ const extensions_core_1 = require("@awell-health/extensions-core");
5
+ const config_1 = require("./config");
6
+ const utils_1 = require("../../utils");
7
+ exports.createTask = {
8
+ key: 'createTask',
9
+ category: extensions_core_1.Category.EHR_INTEGRATIONS,
10
+ title: 'Create task',
11
+ description: 'Create a Task in Medplum',
12
+ fields: config_1.fields,
13
+ previewable: false,
14
+ dataPoints: config_1.dataPoints,
15
+ onActivityCreated: async (payload, onComplete, onError) => {
16
+ const { fields: input, medplumSdk, activity, } = await (0, utils_1.validateAndCreateSdkClient)({
17
+ fieldsSchema: config_1.FieldsValidationSchema,
18
+ payload,
19
+ });
20
+ const res = await medplumSdk.createResource({
21
+ resourceType: 'Task',
22
+ code: {
23
+ text: input.taskTitle,
24
+ },
25
+ description: input.description,
26
+ status: input.status,
27
+ intent: input.intent,
28
+ priority: input.priority,
29
+ for: {
30
+ reference: `Patient/${input.patientId}`,
31
+ },
32
+ executionPeriod: {
33
+ end: input.dueDate,
34
+ },
35
+ performerType: [
36
+ {
37
+ text: input.performerType,
38
+ },
39
+ ],
40
+ requester: {
41
+ identifier: {
42
+ system: 'https://awellhealth.com/activities/',
43
+ value: activity.id,
44
+ },
45
+ display: 'Awell',
46
+ },
47
+ });
48
+ await onComplete({
49
+ data_points: {
50
+ // @ts-expect-error id is not included in the response type?
51
+ taskId: res.id,
52
+ },
53
+ });
54
+ },
55
+ };
56
+ //# sourceMappingURL=createTask.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createTask.js","sourceRoot":"","sources":["../../../../../extensions/medplum/actions/createTask/createTask.ts"],"names":[],"mappings":";;;AAAA,mEAAqE;AAErE,qCAAqE;AACrE,uCAAwD;AAE3C,QAAA,UAAU,GAInB;IACF,GAAG,EAAE,YAAY;IACjB,QAAQ,EAAE,0BAAQ,CAAC,gBAAgB;IACnC,KAAK,EAAE,aAAa;IACpB,WAAW,EAAE,0BAA0B;IACvC,MAAM,EAAN,eAAM;IACN,WAAW,EAAE,KAAK;IAClB,UAAU,EAAV,mBAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,OAAO,EAAiB,EAAE;QACvE,MAAM,EACJ,MAAM,EAAE,KAAK,EACb,UAAU,EACV,QAAQ,GACT,GAAG,MAAM,IAAA,kCAA0B,EAAC;YACnC,YAAY,EAAE,+BAAsB;YACpC,OAAO;SACR,CAAC,CAAA;QAEF,MAAM,GAAG,GAAG,MAAM,UAAU,CAAC,cAAc,CAAC;YAC1C,YAAY,EAAE,MAAM;YACpB,IAAI,EAAE;gBACJ,IAAI,EAAE,KAAK,CAAC,SAAS;aACtB;YACD,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,MAAM,EAAE,KAAK,CAAC,MAAM;YACpB,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,GAAG,EAAE;gBACH,SAAS,EAAE,WAAW,KAAK,CAAC,SAAS,EAAE;aACxC;YACD,eAAe,EAAE;gBACf,GAAG,EAAE,KAAK,CAAC,OAAO;aACnB;YACD,aAAa,EAAE;gBACb;oBACE,IAAI,EAAE,KAAK,CAAC,aAAa;iBAC1B;aACF;YACD,SAAS,EAAE;gBACT,UAAU,EAAE;oBACV,MAAM,EAAE,qCAAqC;oBAC7C,KAAK,EAAE,QAAQ,CAAC,EAAE;iBACnB;gBACD,OAAO,EAAE,OAAO;aACjB;SACF,CAAC,CAAA;QAEF,MAAM,UAAU,CAAC;YACf,WAAW,EAAE;gBACX,4DAA4D;gBAC5D,MAAM,EAAE,GAAG,CAAC,EAAE;aACf;SACF,CAAC,CAAA;IACJ,CAAC;CACF,CAAA"}
@@ -0,0 +1,41 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const _1 = require(".");
4
+ const tests_1 = require("../../../../src/tests");
5
+ const __mocks__1 = require("../../__mocks__");
6
+ jest.mock('@medplum/core', () => {
7
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
8
+ const { MedplumClient: MedplumMockClient } = require('../../__mocks__');
9
+ return {
10
+ MedplumClient: MedplumMockClient,
11
+ };
12
+ });
13
+ describe('Medplum - Create task', () => {
14
+ const onComplete = jest.fn();
15
+ const onError = jest.fn();
16
+ beforeEach(() => {
17
+ jest.clearAllMocks();
18
+ });
19
+ test('Should create a task', async () => {
20
+ const mockOnActivityCreateParams = (0, tests_1.generateTestPayload)({
21
+ fields: {
22
+ patientId: '5d1e74dd-6b92-43e6-ab07-e55d1033fbb6',
23
+ taskTitle: 'Test task',
24
+ description: 'A description goes here',
25
+ status: 'requested',
26
+ intent: 'unknown',
27
+ priority: 'urgent',
28
+ dueDate: '2024-05-31',
29
+ performerType: 'Clinician',
30
+ },
31
+ settings: __mocks__1.mockSettings,
32
+ });
33
+ await _1.createTask.onActivityCreated(mockOnActivityCreateParams, onComplete, onError);
34
+ expect(onComplete).toHaveBeenCalledWith({
35
+ data_points: {
36
+ taskId: __mocks__1.mockCreateTaskResponse.id,
37
+ },
38
+ });
39
+ });
40
+ });
41
+ //# sourceMappingURL=createTask.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createTask.test.js","sourceRoot":"","sources":["../../../../../extensions/medplum/actions/createTask/createTask.test.ts"],"names":[],"mappings":";;AAAA,wBAA8B;AAC9B,iDAA2D;AAC3D,8CAAsE;AAEtE,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,GAAG,EAAE;IAC9B,8DAA8D;IAC9D,MAAM,EAAE,aAAa,EAAE,iBAAiB,EAAE,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAA;IAEvE,OAAO;QACL,aAAa,EAAE,iBAAiB;KACjC,CAAA;AACH,CAAC,CAAC,CAAA;AAEF,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,MAAM,UAAU,GAAG,IAAI,CAAC,EAAE,EAAE,CAAA;IAC5B,MAAM,OAAO,GAAG,IAAI,CAAC,EAAE,EAAE,CAAA;IAEzB,UAAU,CAAC,GAAG,EAAE;QACd,IAAI,CAAC,aAAa,EAAE,CAAA;IACtB,CAAC,CAAC,CAAA;IAEF,IAAI,CAAC,sBAAsB,EAAE,KAAK,IAAI,EAAE;QACtC,MAAM,0BAA0B,GAAG,IAAA,2BAAmB,EAAC;YACrD,MAAM,EAAE;gBACN,SAAS,EAAE,sCAAsC;gBACjD,SAAS,EAAE,WAAW;gBACtB,WAAW,EAAE,yBAAyB;gBACtC,MAAM,EAAE,WAAW;gBACnB,MAAM,EAAE,SAAS;gBACjB,QAAQ,EAAE,QAAQ;gBAClB,OAAO,EAAE,YAAY;gBACrB,aAAa,EAAE,WAAW;aAC3B;YACD,QAAQ,EAAE,uBAAY;SACvB,CAAC,CAAA;QAEF,MAAM,aAAU,CAAC,iBAAiB,CAChC,0BAA0B,EAC1B,UAAU,EACV,OAAO,CACR,CAAA;QAED,MAAM,CAAC,UAAU,CAAC,CAAC,oBAAoB,CAAC;YACtC,WAAW,EAAE;gBACX,MAAM,EAAE,iCAAsB,CAAC,EAAE;aAClC;SACF,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
@@ -0,0 +1 @@
1
+ export { createTask } from './createTask';
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createTask = void 0;
4
+ var createTask_1 = require("./createTask");
5
+ Object.defineProperty(exports, "createTask", { enumerable: true, get: function () { return createTask_1.createTask; } });
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../extensions/medplum/actions/createTask/index.ts"],"names":[],"mappings":";;;AAAA,2CAAyC;AAAhC,wGAAA,UAAU,OAAA"}
@@ -0,0 +1,6 @@
1
+ export declare const dataPoints: {
2
+ data: {
3
+ key: string;
4
+ valueType: "string";
5
+ };
6
+ };
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.dataPoints = void 0;
4
+ exports.dataPoints = {
5
+ data: {
6
+ key: 'data',
7
+ valueType: 'string',
8
+ },
9
+ };
10
+ //# sourceMappingURL=dataPoints.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dataPoints.js","sourceRoot":"","sources":["../../../../../../extensions/medplum/actions/executeBot/config/dataPoints.ts"],"names":[],"mappings":";;;AAEa,QAAA,UAAU,GAAG;IACxB,IAAI,EAAE;QACJ,GAAG,EAAE,MAAM;QACX,SAAS,EAAE,QAAQ;KACpB;CAC4C,CAAA"}
@@ -0,0 +1,34 @@
1
+ import { FieldType } from '@awell-health/extensions-core';
2
+ import { z } from 'zod';
3
+ export declare const fields: {
4
+ botId: {
5
+ id: string;
6
+ label: string;
7
+ description: string;
8
+ type: FieldType.STRING;
9
+ required: true;
10
+ };
11
+ body: {
12
+ id: string;
13
+ label: string;
14
+ description: string;
15
+ type: FieldType.JSON;
16
+ required: false;
17
+ };
18
+ };
19
+ export declare const FieldsValidationSchema: z.ZodObject<{
20
+ botId: z.ZodString;
21
+ body: z.ZodEffects<z.ZodOptional<z.ZodString>, string | number | boolean | {
22
+ [key: string]: string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | any | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null;
23
+ } | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | any | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null, string | undefined>;
24
+ }, "strip", z.ZodTypeAny, {
25
+ body: ((string | number | boolean | {
26
+ [key: string]: string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | any | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null;
27
+ } | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | any | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[]) & (string | number | boolean | {
28
+ [key: string]: string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | any | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null;
29
+ } | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | (string | number | boolean | any | any | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | null)[] | undefined)) | null;
30
+ botId: string;
31
+ }, {
32
+ botId: string;
33
+ body?: string | undefined;
34
+ }>;
@@ -0,0 +1,41 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FieldsValidationSchema = exports.fields = void 0;
4
+ const extensions_core_1 = require("@awell-health/extensions-core");
5
+ const lodash_1 = require("lodash");
6
+ const zod_1 = require("zod");
7
+ exports.fields = {
8
+ botId: {
9
+ id: 'botId',
10
+ label: 'Bot ID',
11
+ description: 'You can find the id of your Bot by clicking on the Details tab of the Bot resource in the Medplum app',
12
+ type: extensions_core_1.FieldType.STRING,
13
+ required: true,
14
+ },
15
+ body: {
16
+ id: 'body',
17
+ label: 'Body',
18
+ description: 'Data in JSON format you would like to pass to the Bot',
19
+ type: extensions_core_1.FieldType.JSON,
20
+ required: false,
21
+ },
22
+ };
23
+ exports.FieldsValidationSchema = zod_1.z.object({
24
+ botId: zod_1.z.string().nonempty({
25
+ message: 'Missing "Bot ID"',
26
+ }),
27
+ body: zod_1.z
28
+ .optional(zod_1.z.string())
29
+ .transform((str, ctx) => {
30
+ if ((0, lodash_1.isNil)(str))
31
+ return {};
32
+ try {
33
+ return JSON.parse(str);
34
+ }
35
+ catch (e) {
36
+ ctx.addIssue({ code: 'custom', message: 'Invalid JSON' });
37
+ return zod_1.z.NEVER;
38
+ }
39
+ }),
40
+ });
41
+ //# sourceMappingURL=fields.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fields.js","sourceRoot":"","sources":["../../../../../../extensions/medplum/actions/executeBot/config/fields.ts"],"names":[],"mappings":";;;AAAA,mEAAgF;AAChF,mCAA8B;AAC9B,6BAAwC;AAE3B,QAAA,MAAM,GAAG;IACpB,KAAK,EAAE;QACL,EAAE,EAAE,OAAO;QACX,KAAK,EAAE,QAAQ;QACf,WAAW,EACT,uGAAuG;QACzG,IAAI,EAAE,2BAAS,CAAC,MAAM;QACtB,QAAQ,EAAE,IAAI;KACf;IACD,IAAI,EAAE;QACJ,EAAE,EAAE,MAAM;QACV,KAAK,EAAE,MAAM;QACb,WAAW,EAAE,uDAAuD;QACpE,IAAI,EAAE,2BAAS,CAAC,IAAI;QACpB,QAAQ,EAAE,KAAK;KAChB;CAC8B,CAAA;AAEpB,QAAA,sBAAsB,GAAG,OAAC,CAAC,MAAM,CAAC;IAC7C,KAAK,EAAE,OAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC;QACzB,OAAO,EAAE,kBAAkB;KAC5B,CAAC;IACF,IAAI,EAAE,OAAC;SACJ,QAAQ,CAAC,OAAC,CAAC,MAAM,EAAE,CAAC;SACpB,SAAS,CAAC,CAAC,GAAG,EAAE,GAAG,EAAoC,EAAE;QACxD,IAAI,IAAA,cAAK,EAAC,GAAG,CAAC;YAAE,OAAO,EAAE,CAAA;QAEzB,IAAI;YACF,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;SACvB;QAAC,OAAO,CAAC,EAAE;YACV,GAAG,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,cAAc,EAAE,CAAC,CAAA;YACzD,OAAO,OAAC,CAAC,KAAK,CAAA;SACf;IACH,CAAC,CAAC;CAC6C,CAAC,CAAA"}
@@ -0,0 +1,2 @@
1
+ export * from './dataPoints';
2
+ export * from './fields';
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./dataPoints"), exports);
18
+ __exportStar(require("./fields"), exports);
19
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../extensions/medplum/actions/executeBot/config/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,+CAA4B;AAC5B,2CAAwB"}
@@ -0,0 +1,4 @@
1
+ import { type Action } from '@awell-health/extensions-core';
2
+ import { type settings } from '../../settings';
3
+ import { fields, dataPoints } from './config';
4
+ export declare const executeBot: Action<typeof fields, typeof settings, keyof typeof dataPoints>;
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.executeBot = void 0;
4
+ const extensions_core_1 = require("@awell-health/extensions-core");
5
+ const config_1 = require("./config");
6
+ const utils_1 = require("../../utils");
7
+ exports.executeBot = {
8
+ key: 'executeBot',
9
+ category: extensions_core_1.Category.EHR_INTEGRATIONS,
10
+ title: 'Execute Bot',
11
+ description: 'Execute a Medplum Bot',
12
+ fields: config_1.fields,
13
+ previewable: false,
14
+ dataPoints: config_1.dataPoints,
15
+ onActivityCreated: async (payload, onComplete, onError) => {
16
+ const { fields: input, medplumSdk } = await (0, utils_1.validateAndCreateSdkClient)({
17
+ fieldsSchema: config_1.FieldsValidationSchema,
18
+ payload,
19
+ });
20
+ const res = await medplumSdk.executeBot(input.botId, input.body, 'application/json');
21
+ await onComplete({
22
+ data_points: {
23
+ data: JSON.stringify(res),
24
+ },
25
+ });
26
+ },
27
+ };
28
+ //# sourceMappingURL=executeBot.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"executeBot.js","sourceRoot":"","sources":["../../../../../extensions/medplum/actions/executeBot/executeBot.ts"],"names":[],"mappings":";;;AAAA,mEAAqE;AAErE,qCAAqE;AACrE,uCAAwD;AAE3C,QAAA,UAAU,GAInB;IACF,GAAG,EAAE,YAAY;IACjB,QAAQ,EAAE,0BAAQ,CAAC,gBAAgB;IACnC,KAAK,EAAE,aAAa;IACpB,WAAW,EAAE,uBAAuB;IACpC,MAAM,EAAN,eAAM;IACN,WAAW,EAAE,KAAK;IAClB,UAAU,EAAV,mBAAU;IACV,iBAAiB,EAAE,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,OAAO,EAAiB,EAAE;QACvE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,UAAU,EAAE,GAAG,MAAM,IAAA,kCAA0B,EAAC;YACrE,YAAY,EAAE,+BAAsB;YACpC,OAAO;SACR,CAAC,CAAA;QAEF,MAAM,GAAG,GAAG,MAAM,UAAU,CAAC,UAAU,CACrC,KAAK,CAAC,KAAK,EACX,KAAK,CAAC,IAAI,EACV,kBAAkB,CACnB,CAAA;QAED,MAAM,UAAU,CAAC;YACf,WAAW,EAAE;gBACX,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC;aAC1B;SACF,CAAC,CAAA;IACJ,CAAC;CACF,CAAA"}