oro-sdk 6.3.0 → 7.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.
package/package.json CHANGED
@@ -1,5 +1,5 @@
1
1
  {
2
- "version": "6.3.0",
2
+ "version": "7.0.0",
3
3
  "main": "dist/index.js",
4
4
  "typings": "dist/index.d.ts",
5
5
  "files": [
@@ -55,7 +55,7 @@
55
55
  "form-data": "^4.0.0",
56
56
  "formdata-node": "^4.3.1",
57
57
  "idb-keyval": "^5.0.6",
58
- "oro-sdk-apis": "~6.3.0",
58
+ "oro-sdk-apis": "~7.0.0",
59
59
  "oro-toolbox": "0.0.6",
60
60
  "uuid": "^8.3.2"
61
61
  }
@@ -50,6 +50,7 @@ export function getRefillAnswersAsWorkflow(
50
50
  createdAt: '2022-10-03T00:00:00.000Z',
51
51
  culDeSacs: [],
52
52
  hidePlanRules: [],
53
+ startingPlanIds: [],
53
54
  pages: [
54
55
  {
55
56
  title: 'Prescription Refill',
@@ -212,9 +213,9 @@ export async function createRefill(
212
213
 
213
214
  if (errorsThrown.length > 0) throw errorsThrown
214
215
 
215
- if( newConsult.statusMedical === MedicalStatus.Assigning ){
216
+ if (newConsult.statusMedical === MedicalStatus.Assigning) {
216
217
  //hopefully svelte query received all updates
217
- console.warn( 'Consult Refill assignation took too much time, moving to new anyway')
218
+ console.warn('Consult Refill assignation took too much time, moving to new anyway')
218
219
  }
219
220
 
220
221
  // Deem the consultation as ready
@@ -295,23 +295,30 @@ export function getInitialisedSelectedAnswers(workflow: WorkflowData, useDefault
295
295
  })
296
296
  }
297
297
 
298
- export function fillWorkflowFromPopulatedWorkflow(workflow: WorkflowData, populatedWorkflow: PopulatedWorkflowData) {
299
- const filledWorkflow = JSON.parse(JSON.stringify(workflow))
298
+ export function fillWorkflowFromPopulatedWorkflow(workflow: WorkflowData, populatedWorkflow: PopulatedWorkflowData): WorkflowData {
299
+ const filledWorkflow: WorkflowData = JSON.parse(JSON.stringify(workflow))
300
300
 
301
301
  if (!filledWorkflow.selectedAnswers) {
302
302
  filledWorkflow.selectedAnswers = getInitialisedSelectedAnswers(filledWorkflow, false)
303
303
  }
304
304
 
305
+ if (!filledWorkflow.previousAnswers && !!Object.values(populatedWorkflow.fields).find(answers => !!answers.previousAnswer))
306
+ filledWorkflow.previousAnswers = filledWorkflow.selectedAnswers
307
+ .map(pageAnswers => Object
308
+ .fromEntries(Object
309
+ .entries(pageAnswers)
310
+ .map(([questionId, answer]) => ([questionId, { previousAnswer: answer, changed: false }])))
311
+ )
312
+
305
313
  filledWorkflow.pages.forEach((page: WorkflowPageData, pageIdx: number) => {
306
- const ret: any = {}
307
314
  for (const [id] of Object.entries(page.questions)) {
308
315
  if (populatedWorkflow.fields[id]) {
309
316
  if (filledWorkflow.selectedAnswers)
310
317
  filledWorkflow.selectedAnswers[pageIdx][id] = populatedWorkflow.fields[id].answer as
311
318
  | string
312
319
  | string[]
313
- if (filledWorkflow.previousAnswers)
314
- filledWorkflow.previousAnswers[pageIdx][id] = populatedWorkflow.fields[id].previousAnswer
320
+ if (filledWorkflow.previousAnswers && populatedWorkflow.fields[id]?.previousAnswer)
321
+ filledWorkflow.previousAnswers[pageIdx][id] = populatedWorkflow.fields[id].previousAnswer!
315
322
  }
316
323
  }
317
324
  })