@awell-health/awell-extensions 1.0.233 → 1.0.234
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/extensions/index.js +2 -0
- package/dist/extensions/index.js.map +1 -1
- package/dist/extensions/markdown.json +4 -0
- package/dist/extensions/medplum/actions/createPatient/config/dataPoints.d.ts +6 -0
- package/dist/extensions/medplum/actions/createPatient/config/dataPoints.js +10 -0
- package/dist/extensions/medplum/actions/createPatient/config/dataPoints.js.map +1 -0
- package/dist/extensions/medplum/actions/createPatient/config/fields.d.ts +119 -0
- package/dist/extensions/medplum/actions/createPatient/config/fields.js +87 -0
- package/dist/extensions/medplum/actions/createPatient/config/fields.js.map +1 -0
- package/dist/extensions/medplum/actions/createPatient/config/index.d.ts +2 -0
- package/dist/extensions/medplum/actions/createPatient/config/index.js +19 -0
- package/dist/extensions/medplum/actions/createPatient/config/index.js.map +1 -0
- package/dist/extensions/medplum/actions/createPatient/createPatient.d.ts +4 -0
- package/dist/extensions/medplum/actions/createPatient/createPatient.js +84 -0
- package/dist/extensions/medplum/actions/createPatient/createPatient.js.map +1 -0
- package/dist/extensions/medplum/actions/createPatient/createPatient.test.d.ts +1 -0
- package/dist/extensions/medplum/actions/createPatient/createPatient.test.js +47 -0
- package/dist/extensions/medplum/actions/createPatient/createPatient.test.js.map +1 -0
- package/dist/extensions/medplum/actions/createPatient/index.d.ts +1 -0
- package/dist/extensions/medplum/actions/createPatient/index.js +6 -0
- package/dist/extensions/medplum/actions/createPatient/index.js.map +1 -0
- package/dist/extensions/medplum/actions/createServiceRequest/config/dataPoints.d.ts +6 -0
- package/dist/extensions/medplum/actions/createServiceRequest/config/dataPoints.js +10 -0
- package/dist/extensions/medplum/actions/createServiceRequest/config/dataPoints.js.map +1 -0
- package/dist/extensions/medplum/actions/createServiceRequest/config/fields.d.ts +48 -0
- package/dist/extensions/medplum/actions/createServiceRequest/config/fields.js +37 -0
- package/dist/extensions/medplum/actions/createServiceRequest/config/fields.js.map +1 -0
- package/dist/extensions/medplum/actions/createServiceRequest/config/index.d.ts +2 -0
- package/dist/extensions/medplum/actions/createServiceRequest/config/index.js +19 -0
- package/dist/extensions/medplum/actions/createServiceRequest/config/index.js.map +1 -0
- package/dist/extensions/medplum/actions/createServiceRequest/createServiceRequest.d.ts +4 -0
- package/dist/extensions/medplum/actions/createServiceRequest/createServiceRequest.js +44 -0
- package/dist/extensions/medplum/actions/createServiceRequest/createServiceRequest.js.map +1 -0
- package/dist/extensions/medplum/actions/createServiceRequest/createServiceRequest.test.d.ts +1 -0
- package/dist/extensions/medplum/actions/createServiceRequest/createServiceRequest.test.js +40 -0
- package/dist/extensions/medplum/actions/createServiceRequest/createServiceRequest.test.js.map +1 -0
- package/dist/extensions/medplum/actions/createServiceRequest/index.d.ts +1 -0
- package/dist/extensions/medplum/actions/createServiceRequest/index.js +6 -0
- package/dist/extensions/medplum/actions/createServiceRequest/index.js.map +1 -0
- package/dist/extensions/medplum/actions/createTask/config/dataPoints.d.ts +6 -0
- package/dist/extensions/medplum/actions/createTask/config/dataPoints.js +10 -0
- package/dist/extensions/medplum/actions/createTask/config/dataPoints.js.map +1 -0
- package/dist/extensions/medplum/actions/createTask/config/fields.d.ts +88 -0
- package/dist/extensions/medplum/actions/createTask/config/fields.js +65 -0
- package/dist/extensions/medplum/actions/createTask/config/fields.js.map +1 -0
- package/dist/extensions/medplum/actions/createTask/config/index.d.ts +2 -0
- package/dist/extensions/medplum/actions/createTask/config/index.js +19 -0
- package/dist/extensions/medplum/actions/createTask/config/index.js.map +1 -0
- package/dist/extensions/medplum/actions/createTask/createTask.d.ts +4 -0
- package/dist/extensions/medplum/actions/createTask/createTask.js +56 -0
- package/dist/extensions/medplum/actions/createTask/createTask.js.map +1 -0
- package/dist/extensions/medplum/actions/createTask/createTask.test.d.ts +1 -0
- package/dist/extensions/medplum/actions/createTask/createTask.test.js +41 -0
- package/dist/extensions/medplum/actions/createTask/createTask.test.js.map +1 -0
- package/dist/extensions/medplum/actions/createTask/index.d.ts +1 -0
- package/dist/extensions/medplum/actions/createTask/index.js +6 -0
- package/dist/extensions/medplum/actions/createTask/index.js.map +1 -0
- package/dist/extensions/medplum/actions/executeBot/config/dataPoints.d.ts +6 -0
- package/dist/extensions/medplum/actions/executeBot/config/dataPoints.js +10 -0
- package/dist/extensions/medplum/actions/executeBot/config/dataPoints.js.map +1 -0
- package/dist/extensions/medplum/actions/executeBot/config/fields.d.ts +34 -0
- package/dist/extensions/medplum/actions/executeBot/config/fields.js +41 -0
- package/dist/extensions/medplum/actions/executeBot/config/fields.js.map +1 -0
- package/dist/extensions/medplum/actions/executeBot/config/index.d.ts +2 -0
- package/dist/extensions/medplum/actions/executeBot/config/index.js +19 -0
- package/dist/extensions/medplum/actions/executeBot/config/index.js.map +1 -0
- package/dist/extensions/medplum/actions/executeBot/executeBot.d.ts +4 -0
- package/dist/extensions/medplum/actions/executeBot/executeBot.js +28 -0
- package/dist/extensions/medplum/actions/executeBot/executeBot.js.map +1 -0
- package/dist/extensions/medplum/actions/executeBot/executeBot.test.d.ts +1 -0
- package/dist/extensions/medplum/actions/executeBot/executeBot.test.js +35 -0
- package/dist/extensions/medplum/actions/executeBot/executeBot.test.js.map +1 -0
- package/dist/extensions/medplum/actions/executeBot/index.d.ts +1 -0
- package/dist/extensions/medplum/actions/executeBot/index.js +6 -0
- package/dist/extensions/medplum/actions/executeBot/index.js.map +1 -0
- package/dist/extensions/medplum/actions/getAppointment/config/dataPoints.d.ts +6 -0
- package/dist/extensions/medplum/actions/getAppointment/config/dataPoints.js +10 -0
- package/dist/extensions/medplum/actions/getAppointment/config/dataPoints.js.map +1 -0
- package/dist/extensions/medplum/actions/getAppointment/config/fields.d.ts +18 -0
- package/dist/extensions/medplum/actions/getAppointment/config/fields.js +20 -0
- package/dist/extensions/medplum/actions/getAppointment/config/fields.js.map +1 -0
- package/dist/extensions/medplum/actions/getAppointment/config/index.d.ts +2 -0
- package/dist/extensions/medplum/actions/getAppointment/config/index.js +19 -0
- package/dist/extensions/medplum/actions/getAppointment/config/index.js.map +1 -0
- package/dist/extensions/medplum/actions/getAppointment/getAppointment.d.ts +4 -0
- package/dist/extensions/medplum/actions/getAppointment/getAppointment.js +33 -0
- package/dist/extensions/medplum/actions/getAppointment/getAppointment.js.map +1 -0
- package/dist/extensions/medplum/actions/getAppointment/getAppointment.test.d.ts +1 -0
- package/dist/extensions/medplum/actions/getAppointment/getAppointment.test.js +34 -0
- package/dist/extensions/medplum/actions/getAppointment/getAppointment.test.js.map +1 -0
- package/dist/extensions/medplum/actions/getAppointment/index.d.ts +1 -0
- package/dist/extensions/medplum/actions/getAppointment/index.js +6 -0
- package/dist/extensions/medplum/actions/getAppointment/index.js.map +1 -0
- package/dist/extensions/medplum/actions/getPatient/config/dataPoints.d.ts +6 -0
- package/dist/extensions/medplum/actions/getPatient/config/dataPoints.js +10 -0
- package/dist/extensions/medplum/actions/getPatient/config/dataPoints.js.map +1 -0
- package/dist/extensions/medplum/actions/getPatient/config/fields.d.ts +18 -0
- package/dist/extensions/medplum/actions/getPatient/config/fields.js +20 -0
- package/dist/extensions/medplum/actions/getPatient/config/fields.js.map +1 -0
- package/dist/extensions/medplum/actions/getPatient/config/index.d.ts +2 -0
- package/dist/extensions/medplum/actions/getPatient/config/index.js +19 -0
- package/dist/extensions/medplum/actions/getPatient/config/index.js.map +1 -0
- package/dist/extensions/medplum/actions/getPatient/getPatient.d.ts +4 -0
- package/dist/extensions/medplum/actions/getPatient/getPatient.js +33 -0
- package/dist/extensions/medplum/actions/getPatient/getPatient.js.map +1 -0
- package/dist/extensions/medplum/actions/getPatient/getPatient.test.d.ts +1 -0
- package/dist/extensions/medplum/actions/getPatient/getPatient.test.js +34 -0
- package/dist/extensions/medplum/actions/getPatient/getPatient.test.js.map +1 -0
- package/dist/extensions/medplum/actions/getPatient/index.d.ts +1 -0
- package/dist/extensions/medplum/actions/getPatient/index.js +6 -0
- package/dist/extensions/medplum/actions/getPatient/index.js.map +1 -0
- package/dist/extensions/medplum/actions/index.d.ts +6 -0
- package/dist/extensions/medplum/actions/index.js +16 -0
- package/dist/extensions/medplum/actions/index.js.map +1 -0
- package/dist/extensions/medplum/fhir/schemas/atoms/GenderSchema.d.ts +2 -0
- package/dist/extensions/medplum/fhir/schemas/atoms/GenderSchema.js +11 -0
- package/dist/extensions/medplum/fhir/schemas/atoms/GenderSchema.js.map +1 -0
- package/dist/extensions/medplum/fhir/schemas/atoms/IntentSchema.d.ts +3 -0
- package/dist/extensions/medplum/fhir/schemas/atoms/IntentSchema.js +27 -0
- package/dist/extensions/medplum/fhir/schemas/atoms/IntentSchema.js.map +1 -0
- package/dist/extensions/medplum/fhir/schemas/atoms/PeriodSchema.d.ts +14 -0
- package/dist/extensions/medplum/fhir/schemas/atoms/PeriodSchema.js +10 -0
- package/dist/extensions/medplum/fhir/schemas/atoms/PeriodSchema.js.map +1 -0
- package/dist/extensions/medplum/fhir/schemas/atoms/PrioritySchema.d.ts +2 -0
- package/dist/extensions/medplum/fhir/schemas/atoms/PrioritySchema.js +11 -0
- package/dist/extensions/medplum/fhir/schemas/atoms/PrioritySchema.js.map +1 -0
- package/dist/extensions/medplum/fhir/schemas/atoms/StatusSchema.d.ts +3 -0
- package/dist/extensions/medplum/fhir/schemas/atoms/StatusSchema.js +28 -0
- package/dist/extensions/medplum/fhir/schemas/atoms/StatusSchema.js.map +1 -0
- package/dist/extensions/medplum/fhir/schemas/atoms/index.d.ts +5 -0
- package/dist/extensions/medplum/fhir/schemas/atoms/index.js +16 -0
- package/dist/extensions/medplum/fhir/schemas/atoms/index.js.map +1 -0
- package/dist/extensions/medplum/fhir/schemas/index.d.ts +1 -0
- package/dist/extensions/medplum/fhir/schemas/index.js +6 -0
- package/dist/extensions/medplum/fhir/schemas/index.js.map +1 -0
- package/dist/extensions/medplum/fhir/schemas/resources/index.d.ts +3 -0
- package/dist/extensions/medplum/fhir/schemas/resources/index.js +10 -0
- package/dist/extensions/medplum/fhir/schemas/resources/index.js.map +1 -0
- package/dist/extensions/medplum/fhir/schemas/resources/patient.schema.d.ts +38 -0
- package/dist/extensions/medplum/fhir/schemas/resources/patient.schema.js +20 -0
- package/dist/extensions/medplum/fhir/schemas/resources/patient.schema.js.map +1 -0
- package/dist/extensions/medplum/fhir/schemas/resources/serviceRequest.schema.d.ts +17 -0
- package/dist/extensions/medplum/fhir/schemas/resources/serviceRequest.schema.js +12 -0
- package/dist/extensions/medplum/fhir/schemas/resources/serviceRequest.schema.js.map +1 -0
- package/dist/extensions/medplum/fhir/schemas/resources/task.schema.d.ts +29 -0
- package/dist/extensions/medplum/fhir/schemas/resources/task.schema.js +17 -0
- package/dist/extensions/medplum/fhir/schemas/resources/task.schema.js.map +1 -0
- package/dist/extensions/medplum/index.d.ts +2 -0
- package/dist/extensions/medplum/index.js +42 -0
- package/dist/extensions/medplum/index.js.map +1 -0
- package/dist/extensions/medplum/settings.d.ts +27 -0
- package/dist/extensions/medplum/settings.js +25 -0
- package/dist/extensions/medplum/settings.js.map +1 -0
- package/dist/extensions/medplum/utils/index.d.ts +2 -0
- package/dist/extensions/medplum/utils/index.js +7 -0
- package/dist/extensions/medplum/utils/index.js.map +1 -0
- package/dist/extensions/medplum/utils/validateAndCreateSdkClient.d.ts +17 -0
- package/dist/extensions/medplum/utils/validateAndCreateSdkClient.js +27 -0
- package/dist/extensions/medplum/utils/validateAndCreateSdkClient.js.map +1 -0
- 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 @@
|
|
1
|
+
export {};
|
@@ -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 @@
|
|
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,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,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 @@
|
|
1
|
+
export {};
|
@@ -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 @@
|
|
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,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,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"}
|