| [1620] | 1 | C0XPT1 ; VEN/SMH - Obtain and Store Problems ;2013-05-01  9:54 AM | 
|---|
| [1606] | 2 | ;;1.1;FILEMAN TRIPLE STORE;; | 
|---|
| [1620] | 3 | ; (C) Sam Habiel 2013 | 
|---|
|  | 4 | ; Proprietary code. Stay out! | 
|---|
| [1606] | 5 | ; | 
|---|
|  | 6 | PROBLEMS(G,DFN) ; Private EP; Process Problems for a patient graph | 
|---|
|  | 7 | ; Delete existing problems if they are present | 
|---|
|  | 8 | ; PS: This is a risky operation if somebody points to the original data. | 
|---|
|  | 9 | ; PS2: Another idea is just to quit here if Patient has problems already. | 
|---|
|  | 10 | I $D(^AUPNPROB("AC",DFN)) DO  ; Patient already has problems. | 
|---|
|  | 11 | . N DIK S DIK="^AUPNPROB("  ; Global to kill | 
|---|
|  | 12 | . N DA F DA=0:0 S DA=$O(^AUPNPROB("AC",DFN,DA)) Q:'DA  D ^DIK  ; Kill each entry | 
|---|
|  | 13 | ; | 
|---|
|  | 14 | ; Process incoming problems | 
|---|
|  | 15 | N RETURN ; Local return variable. I don't expect a patient to have more than 50 problems. | 
|---|
|  | 16 | D ONETYPE^C0XGET3($NA(RETURN),G,"sp:Problem") ; Get all problems for patient | 
|---|
|  | 17 | N S F S=0:0 S S=$O(RETURN(S)) Q:'S  D  ; For each problem | 
|---|
|  | 18 | . N PROBNM S PROBNM=$$GSPO1^C0XGET3(G,RETURN(S),"sp:problemName") ; Snomed-CT coding info | 
|---|
|  | 19 | . N CODEURL S CODEURL=$$GSPO1^C0XGET3(G,PROBNM,"sp:code") ; Snomed-CT Code URL | 
|---|
|  | 20 | . N TEXT S TEXT=$$GSPO1^C0XGET3(G,PROBNM,"dcterms:title") ; Snomed-CT Code description | 
|---|
|  | 21 | . ; | 
|---|
|  | 22 | . N CODE ; Actual Snomed code rather than URL | 
|---|
|  | 23 | . S CODE=$P(CODEURL,"/",$L(CODEURL,"/")) ; Get last / piece | 
|---|
|  | 24 | . N EXPIEN ; IEN in the EXPESSION file | 
|---|
|  | 25 | . N LEXS ; Return from Lex call | 
|---|
|  | 26 | . D EN^LEXCODE(CODE) ; Lex API | 
|---|
|  | 27 | . S EXPIEN=$P(LEXS("SCT",1),U) ; First match on Snomed CT. Crash if isn't present. | 
|---|
|  | 28 | . ; | 
|---|
|  | 29 | . N STARTDT S STARTDT=$$GSPO1^C0XGET3(G,RETURN(S),"sp:startDate") ; Start Date | 
|---|
|  | 30 | . N X,Y,%DT S X=STARTDT D ^%DT S STARTDT=Y ; Convert STARTDT to internal format | 
|---|
|  | 31 | . D PROBADD(DFN,CODE,TEXT,EXPIEN,STARTDT) ; Add problem to VISTA. | 
|---|
|  | 32 | QUIT | 
|---|
|  | 33 | ; | 
|---|
|  | 34 | PROBADD(DFN,CODE,TEXT,EXPIEN,STARTDT) ; Add a problem to a patient's record. | 
|---|
|  | 35 | ; Input | 
|---|
|  | 36 | ; DFN - you know what that is | 
|---|
|  | 37 | ; CODE - SNOMED code; not used alas; for the future. | 
|---|
|  | 38 | ; TEXT - SNOMED Text | 
|---|
|  | 39 | ; EXPIEN - IEN of Snomed CT Expression in the Expressions File (757.01) | 
|---|
|  | 40 | ; STARTDT - Internal Date of when the problem was first noted. | 
|---|
|  | 41 | ; | 
|---|
|  | 42 | ; Output: | 
|---|
|  | 43 | ; NONE | 
|---|
|  | 44 | ; Crash expected if code fails to add a problem. | 
|---|
|  | 45 | ; | 
|---|
|  | 46 | ; | 
|---|
|  | 47 | ; | 
|---|
|  | 48 | N GMPDFN S GMPDFN=DFN ; patient dfn | 
|---|
|  | 49 | ; | 
|---|
|  | 50 | ; Add unknown provider to database | 
|---|
|  | 51 | N GMPPROV S GMPPROV=$$NP^C0XPT0() ;Smart Provider IEN | 
|---|
|  | 52 | ; | 
|---|
|  | 53 | N GMPVAMC S GMPVAMC=$$KSP^XUPARAM("INST") ; Problem Institution. Ideally, the external one. But we are taking a shortcut here. | 
|---|
|  | 54 | ; | 
|---|
|  | 55 | N GMPFLD ; Input array | 
|---|
|  | 56 | S GMPFLD(".01")="" ;Code IEN - API will assign 799.9. | 
|---|
|  | 57 | ; .02 field (Patient IEN) not used. Pass variable GMPDFN instead. | 
|---|
|  | 58 | S GMPFLD(".03")=DT ;Date Last Modified | 
|---|
|  | 59 | S GMPFLD(".05")="^"_TEXT ;Expression text | 
|---|
|  | 60 | S GMPFLD(".08")=DT ; today's date (entry?) | 
|---|
|  | 61 | S GMPFLD(".12")="A" ;Active/Inactive | 
|---|
|  | 62 | S GMPFLD(".13")=STARTDT ;Onset date | 
|---|
|  | 63 | S GMPFLD("1.01")=EXPIEN_U_TEXT ;^LEX(757.01 ien,descip | 
|---|
|  | 64 | S GMPFLD("1.03")=GMPPROV ;Entered by | 
|---|
|  | 65 | S GMPFLD("1.04")=GMPPROV ;Recording provider | 
|---|
|  | 66 | S GMPFLD("1.05")=GMPPROV ;Responsible provider | 
|---|
|  | 67 | S GMPFLD("1.06")="" ; SERVICE FILE - LEAVE BLANK(#49) | 
|---|
|  | 68 | S GMPFLD("1.07")="" ; Date resolved | 
|---|
|  | 69 | S GMPFLD("1.08")="" ; Clinic (#44) | 
|---|
|  | 70 | S GMPFLD("1.09")=DT ;entry date | 
|---|
|  | 71 | S GMPFLD("1.1")=0 ;Service Connected | 
|---|
|  | 72 | S GMPFLD("1.11")=0 ;Agent Orange exposure | 
|---|
|  | 73 | S GMPFLD("1.12")=0 ;Ionizing radiation exposure | 
|---|
|  | 74 | S GMPFLD("1.13")=0 ;Persian Gulf exposure | 
|---|
|  | 75 | S GMPFLD("1.14")="C" ;Accute/Chronic (A,C) | 
|---|
|  | 76 | S GMPFLD("1.15")="" ;Head/neck cancer | 
|---|
|  | 77 | S GMPFLD("1.16")="" ;Military sexual trauma | 
|---|
|  | 78 | S GMPFLD("10",0)=0 ; Note. No note. | 
|---|
|  | 79 | ; | 
|---|
|  | 80 | ; | 
|---|
|  | 81 | N DA ; Return variable | 
|---|
|  | 82 | D NEW^GMPLSAVE ; API call | 
|---|
|  | 83 | I '$D(DA) S $EC=",U1," ; Fail here if API fails. | 
|---|
|  | 84 | QUIT | 
|---|
|  | 85 | ; | 
|---|
|  | 86 | ; | 
|---|