| 1 | MAGDMEDL ;WOIFO/LB - Routine to look up entries in the Medicine files ; 05/16/2005  09:18
 | 
|---|
| 2 |  ;;3.0;IMAGING;**51**;26-August-2005
 | 
|---|
| 3 |  ;; +---------------------------------------------------------------+
 | 
|---|
| 4 |  ;; | Property of the US Government.                                |
 | 
|---|
| 5 |  ;; | No permission to copy or redistribute this software is given. |
 | 
|---|
| 6 |  ;; | Use of unreleased versions of this software requires the user |
 | 
|---|
| 7 |  ;; | to execute a written test agreement with the VistA Imaging    |
 | 
|---|
| 8 |  ;; | Development Office of the Department of Veterans Affairs,     |
 | 
|---|
| 9 |  ;; | telephone (301) 734-0100.                                     |
 | 
|---|
| 10 |  ;; |                                                               |
 | 
|---|
| 11 |  ;; | The Food and Drug Administration classifies this software as  |
 | 
|---|
| 12 |  ;; | a medical device.  As such, it may not be changed in any way. |
 | 
|---|
| 13 |  ;; | Modifications to this software may result in an adulterated   |
 | 
|---|
| 14 |  ;; | medical device under 21CFR820, the use of which is considered |
 | 
|---|
| 15 |  ;; | to be a violation of US Federal Statutes.                     |
 | 
|---|
| 16 |  ;; +---------------------------------------------------------------+
 | 
|---|
| 17 |  ;;
 | 
|---|
| 18 |  Q
 | 
|---|
| 19 | SELECT(ITEM,ARRAY) ;
 | 
|---|
| 20 |  ;
 | 
|---|
| 21 |  N CNT,DIR,DIROUT,DIRUT,ENTRY
 | 
|---|
| 22 |  S CNT=+ARRAY
 | 
|---|
| 23 |  I 'CNT Q 0
 | 
|---|
| 24 |  S DIR(0)="NO^1:"_CNT,DIR("A")="Select a Medicine Procedure"
 | 
|---|
| 25 |  S DIR("T")=600 D ^DIR
 | 
|---|
| 26 |  I $D(DIRUT)!($D(DIROUT)) Q 0
 | 
|---|
| 27 |  S ENTRY=+Y
 | 
|---|
| 28 |  I '$D(ARRAY(ENTRY)) D  G SELECT
 | 
|---|
| 29 |  . W !,"Please select an entry or use '^' to exit"
 | 
|---|
| 30 |  W !,"You have selected ",$P(ARRAY(ENTRY),"^"),"."
 | 
|---|
| 31 |  Q $P(ARRAY(ENTRY),"^",2)
 | 
|---|
| 32 |  ;
 | 
|---|
| 33 | LOOP(ARRAY,MAGPAT,SUB,CASEDT) ;
 | 
|---|
| 34 |  ; MAGPAT = patient's dfn
 | 
|---|
| 35 |  ; SUB = Medicine specialty
 | 
|---|
| 36 |  ; CASEDT = case date
 | 
|---|
| 37 |  ;  array(0)= 1 or 0 ^ # entries found ^ message text
 | 
|---|
| 38 |  ;  array(#)= formatted out display without delimiters
 | 
|---|
| 39 |  ;  array(#,1) = internal stored values
 | 
|---|
| 40 |  ; Variable MAGDIMG
 | 
|---|
| 41 |  S ARRAY(0)="0^^No entries found"
 | 
|---|
| 42 |  Q:'MAGPAT
 | 
|---|
| 43 |  Q:'$D(MAGMC)#10   ;Array should be available.
 | 
|---|
| 44 |  N BEG,CDT,CNT,DATA,DICOM,EN,END,IMG,IMAGEPTR,MAGDIMG,PATIENT,PATNME,PRC,PRCNM,SSN,THEDT,X1,X2,X
 | 
|---|
| 45 |  N IEN,II,IOUT,MAGMC,MEDFILE
 | 
|---|
| 46 |  Q:'$$FIND1^DIC(2,,"A",MAGPAT,"","")
 | 
|---|
| 47 |  S PATNME=$P(^DPT(MAGPAT,0),"^"),SSN=$P(^(0),"^",9)
 | 
|---|
| 48 |  S PATIENT=PATNME_" "_SSN
 | 
|---|
| 49 |  I 'CASEDT S CASEDT=DT
 | 
|---|
| 50 |  S X1=CASEDT,X2=-3 D C^%DTC S BEG=X
 | 
|---|
| 51 |  S END=CASEDT+.9999
 | 
|---|
| 52 |  S CNT=0,CDT=BEG-.001
 | 
|---|
| 53 |  F  S CDT=$O(MAGMC(MAGPAT,SUB,CDT)) Q:'CDT!(CDT>END)  D
 | 
|---|
| 54 |  . S EN=0 F  S EN=$O(MAGMC(MAGPAT,SUB,CDT,EN)) Q:'EN  D
 | 
|---|
| 55 |  . . S DATA=MAGMC(MAGPAT,SUB,CDT,EN)
 | 
|---|
| 56 |  . . S PRCNM=$P(DATA,"^",2),PRC=SUB
 | 
|---|
| 57 |  . . S THEDT=$P(DATA,"^"),IEN=$P(DATA,"^",5)
 | 
|---|
| 58 |  . . I $D(MAGMC(MAGPAT,SUB,CDT,EN,2005)) S (IOUT,II)=0 D
 | 
|---|
| 59 |  . . . F  S II=$O(MAGMC(MAGPAT,SUB,CDT,EN,2005,II)) Q:'II!IOUT  D
 | 
|---|
| 60 |  . . . . S IMAGEPTR=MAGMC(MAGPAT,SUB,CDT,EN,2005,II)
 | 
|---|
| 61 |  . . . . I '$D(^MAG(2005,IMAGEPTR)) S IMAGEPTR="" Q
 | 
|---|
| 62 |  . . . . I '$D(^MAG(2005,IMAGEPTR,"PACS"))  S IMAGEPTR="",IOUT=1
 | 
|---|
| 63 |  . . S MEDFILE=$P(DATA,"^",4),MEDFILE=$P(MEDFILE,"MCAR(",2)
 | 
|---|
| 64 |  . . S DICOM="" D DICOMID^MAGDMEDI(.DICOM,MEDFILE,IEN,PRC,MAGPAT)
 | 
|---|
| 65 |  . . I DICOM'="" D
 | 
|---|
| 66 |  . . . S DICOM=$P(DICOM,":",2)
 | 
|---|
| 67 |  . . . S CNT=CNT+1
 | 
|---|
| 68 |  . . . S ARRAY(CNT)=DICOM_" "_PRCNM_", "_THEDT_" "_PATIENT
 | 
|---|
| 69 |  . . . S ARRAY(CNT,1)=DICOM_"^"_PATNME_"^"_SSN_"^"_EN_"^"_PRCNM_"^"_PRC_"^"_$G(IMAGEPTR)_"^"_MEDFILE
 | 
|---|
| 70 |  I CNT S ARRAY(0)="1^"_CNT_"^Medicine file entries for "_PATIENT
 | 
|---|
| 71 |  Q
 | 
|---|
| 72 | DISPLAY(ARRAY) ;
 | 
|---|
| 73 |  ; Call routine needs to pass array in the following sequence
 | 
|---|
| 74 |  ; ARRAY(0)= 1 or 0 ^ #entries ^ message
 | 
|---|
| 75 |  ; ARRAY(#)=  Formatted output to be displayed.
 | 
|---|
| 76 |  ; Will set the RES variable for selected entry.
 | 
|---|
| 77 |  I '$D(ARRAY(0)) Q 0
 | 
|---|
| 78 |  ; If only one entry return the subscript variable.
 | 
|---|
| 79 |  I $P(ARRAY(0),"^",2)=1 Q 1
 | 
|---|
| 80 |  I $P(ARRAY(0),"^")'=1 Q 0
 | 
|---|
| 81 |  N ENTRY,ITEM,ITEMS,MSG,OUT,OUTPUT,RES
 | 
|---|
| 82 |  S RES=0,MSG=$P(ARRAY(0),"^",3)
 | 
|---|
| 83 |  S IOF="#,$C(27,91,72,27,91,74,8,8,8,8)",IO=0,IOSL=24,POP=0
 | 
|---|
| 84 |  D HEAD
 | 
|---|
| 85 |  S (ENTRY,OUT)=0,ITEMS=$P(ARRAY(0),"^",2)
 | 
|---|
| 86 |  F  S ENTRY=$O(ARRAY(ENTRY)) Q:'ENTRY!OUT  D
 | 
|---|
| 87 |  . S OUTPUT=$G(ARRAY(ENTRY))
 | 
|---|
| 88 |  . D:$Y+3>IOSL HEAD D LINE
 | 
|---|
| 89 |  . D:$Y+3>IOSL ASKQ
 | 
|---|
| 90 |  I 'OUT D ASKQ S RES=ITEM
 | 
|---|
| 91 |  Q RES
 | 
|---|
| 92 | HEAD ;
 | 
|---|
| 93 |  W:$Y+3>IOSL @IOF W !,MSG
 | 
|---|
| 94 |  Q
 | 
|---|
| 95 | LINE ;
 | 
|---|
| 96 |  W !,ENTRY,".) "_OUTPUT
 | 
|---|
| 97 |  Q
 | 
|---|
| 98 | ASKQ ;
 | 
|---|
| 99 |  N X,Y,DIR
 | 
|---|
| 100 |  S DIR(0)="L^1:"_$S('ENTRY:ITEMS,1:ENTRY)
 | 
|---|
| 101 |  S DIR("T")=600,DIR("A")="Select an entry: " D ^DIR
 | 
|---|
| 102 |  S ITEM=+Y
 | 
|---|
| 103 |  Q:$D(DIRUT)!($D(DIROUT))
 | 
|---|
| 104 |  Q:'ITEM
 | 
|---|
| 105 |  I '$D(ARRAY(ITEM)) W !,"Please select an entry or '^' to exit" G ASKQ
 | 
|---|
| 106 |  W !,"You have selected ",$P($G(ARRAY(ITEM)),"^")
 | 
|---|
| 107 |  S OUT=1
 | 
|---|
| 108 |  Q
 | 
|---|
| 109 | ASKMORE() ;
 | 
|---|
| 110 |  N DIR,DATE,X,XX,Y
 | 
|---|
| 111 |  Q:'$D(MAGPAT)
 | 
|---|
| 112 |  Q:'$D(SUB)
 | 
|---|
| 113 |  S DIR(0)="Y",DIR("B")="NO"
 | 
|---|
| 114 |  S DIR("A")="Search further"
 | 
|---|
| 115 |  D ^DIR K DIR
 | 
|---|
| 116 |  I 'Y Q 0
 | 
|---|
| 117 |  W !,"Search will include 3 days prior to the day specified."
 | 
|---|
| 118 |  S DIR(0)="D^::EXP" D ^DIR
 | 
|---|
| 119 |  ; Y2K compliance all calls to %DT must have either past or future date
 | 
|---|
| 120 |  I 'Y Q 0
 | 
|---|
| 121 |  S DATE=Y
 | 
|---|
| 122 |  D LOOP(.XX,MAGPAT,SUB,DATE)
 | 
|---|
| 123 |  I $D(XX(0)),$P(XX(0),"^")=0 D  Q 0
 | 
|---|
| 124 |  . W "No entries found."
 | 
|---|
| 125 |  Q 1
 | 
|---|