| 1 | MCUIMAG0 ;HCIOFO/DAD-Create / Update Med Procedure with Image Pointer ;7/23/97  07:36 | 
|---|
| 2 | ;;2.3;Medicine;**7,12**;09/13/1996 | 
|---|
| 3 | Q | 
|---|
| 4 | ; | 
|---|
| 5 | UPDATE(MCDATE,MCPROCD0,MCDFN,MCMAGPTR,MCD0,OK) ; | 
|---|
| 6 | ; *** Main driver to update Medicine files from Imaging *** | 
|---|
| 7 | ;  MCDATE = Date/Time of procedure (FM internal format) | 
|---|
| 8 | ;  MCPROCD0 = Pointer to the Procedure/Subspecialty file (#697.2) | 
|---|
| 9 | ;  MCDFN = Pointer to the Patient file (#2) | 
|---|
| 10 | ;  MCMAGPTR() = An array whose subscripts are pointers to the Image | 
|---|
| 11 | ;               file (#2005)  Returned as: MCMAGPTR(File 2005 IEN)= | 
|---|
| 12 | ;               MCFILE ^ MCD0 ^ MCD1 (IEN of image in image mult) | 
|---|
| 13 | ;  MCD0 = Pointer to one of the Medicine Procedure data files | 
|---|
| 14 | ;  OK = A return flag: '1^Message' = All is well, '0^Message' = Bad news | 
|---|
| 15 | N DD,DIC,DINUM,DO,MCPATFLD,X,Y | 
|---|
| 16 | S MCDATE=+$G(MCDATE),MCPROCD0=+$G(MCPROCD0) | 
|---|
| 17 | S MCDFN=+$G(MCDFN),MCD0=+$G(MCD0) | 
|---|
| 18 | S MCFILE=+$P($P($G(^MCAR(697.2,MCPROCD0,0)),U,2),"(",2) | 
|---|
| 19 | I MCFILE'>0 D  Q | 
|---|
| 20 | . S OK="0^Medicine Procedure file global location not found" | 
|---|
| 21 | . Q | 
|---|
| 22 | S MCPATFLD=$$PATFLD(MCFILE) | 
|---|
| 23 | I MCPATFLD'>0 D  Q | 
|---|
| 24 | . S OK="0^Medical Patient field not found in Medicine Procedure file" | 
|---|
| 25 | . Q | 
|---|
| 26 | I MCD0>0 S OK=$$VALID(MCFILE,MCD0,MCDFN,MCPROCD0) Q:'OK | 
|---|
| 27 | I MCD0'>0 D  Q:'OK | 
|---|
| 28 | . N MCIEN S MCIEN=0 | 
|---|
| 29 | . F  S MCIEN=$O(^MCAR(MCFILE,"B",MCDATE,MCIEN)) Q:MCIEN'>0  D  Q:MCD0 | 
|---|
| 30 | .. S OK=$$VALID(MCFILE,MCIEN,MCDFN,MCPROCD0) | 
|---|
| 31 | .. I OK S MCD0=MCIEN | 
|---|
| 32 | .. Q | 
|---|
| 33 | . I MCD0'>0 D NEW(MCDATE,MCDFN,MCFILE,MCPROCD0,MCPATFLD,.MCD0,.OK) | 
|---|
| 34 | . Q | 
|---|
| 35 | I $O(MCMAGPTR(0)) D FILE(MCD0,MCFILE,.MCMAGPTR,.OK) Q:'OK | 
|---|
| 36 | S MCD0=MCD0_U_MCFILE | 
|---|
| 37 | Q | 
|---|
| 38 | ; | 
|---|
| 39 | NEW(MCDATE,MCDFN,MCFILE,MCPROCD0,MCPATFLD,MCD0,OK) ; | 
|---|
| 40 | ; *** Create new Medicine patient (if needed) and procedure records *** | 
|---|
| 41 | ;  MCDATE = Date/Time of procedure (FM internal format) | 
|---|
| 42 | ;  MCDFN = Pointer to the Patient file (#2) | 
|---|
| 43 | ;  MCFILE = File number of one of the Medicine Procedure data files | 
|---|
| 44 | ;  MCPROCD0 = Pointer to the Procedure/Subspecialty file (#697.2) | 
|---|
| 45 | ;  MCPATFLD = Field# in one of the Medicine Procedure data files | 
|---|
| 46 | ;             that points to the Medical Patient file (#690) | 
|---|
| 47 | ;  MCD0 = Pointer to one of the Medicine Procedure data files | 
|---|
| 48 | ;  OK = A return flag: '1^Message' = All is well, '0^Message' = Bad news | 
|---|
| 49 | N DD,DIC,DINUM,DLAYGO,DO,MCARCODE,MCPRCFLD,MCRESULT,X,Y | 
|---|
| 50 | S OK="1^New stub record created in Medicine Procedure data file" | 
|---|
| 51 | ; *** Create a new record in the Medical Patient file (#690) *** | 
|---|
| 52 | I '$D(^MCAR(690,MCDFN)) D  Q:'OK | 
|---|
| 53 | . K DD,DIC,DINUM,DO | 
|---|
| 54 | . S (X,DINUM)=MCDFN,DLAYGO=690 | 
|---|
| 55 | . S DIC="^MCAR(690,",DIC(0)="L" | 
|---|
| 56 | . D FILE^DICN | 
|---|
| 57 | . I Y'>0 D | 
|---|
| 58 | .. S OK="0^Cannot add patient to Medical Patient file" | 
|---|
| 59 | .. Q | 
|---|
| 60 | . Q | 
|---|
| 61 | ; *** Create a stub record *** | 
|---|
| 62 | K DD,DIC,DINUM,DO | 
|---|
| 63 | S DIC=$$GET1^DID(MCFILE,"","","GLOBAL NAME") | 
|---|
| 64 | S DIC(0)="L",DLAYGO=MCFILE | 
|---|
| 65 | S DIC("DR")=MCPATFLD_"///`"_MCDFN | 
|---|
| 66 | S MCARCODE=$P($G(^MCAR(697.2,MCPROCD0,0)),U,4) S:MCARCODE="" MCARCODE=U | 
|---|
| 67 | S MCPRCFLD=$$PRCFLD(MCFILE) | 
|---|
| 68 | I MCPRCFLD>0 D PRCSUBS Q:'OK | 
|---|
| 69 | S X=MCDATE | 
|---|
| 70 | D FILE^DICN S MCD0=+Y | 
|---|
| 71 | I MCD0'>0 D | 
|---|
| 72 | . S OK="0^Cannot create stub record in the Medicine Procedure data file" | 
|---|
| 73 | . Q | 
|---|
| 74 | Q | 
|---|
| 75 | ; | 
|---|
| 76 | FILE(MCD0,MCFILE,MCMAGPTR,OK) ; | 
|---|
| 77 | ; *** Store the Image file (#2005) pointers in Med Proc data files *** | 
|---|
| 78 | ;  MCD0 = Pointer to one of the Medicine Procedure data files | 
|---|
| 79 | ;  MCFILE = File number of one of the Medicine Procedure data files | 
|---|
| 80 | ;  MCMAGPTR() = An array whose subscripts are pointers to the Image | 
|---|
| 81 | ;               file (#2005)  Returned as: MCMAGPTR(File 2005 IEN)= | 
|---|
| 82 | ;               MCFILE ^ MCD0 ^ MCD1 (IEN of image in image mult) | 
|---|
| 83 | ;  OK = A return flag: '1^Message' = All is well, '0^Message' = Bad news | 
|---|
| 84 | N DD,DIC,DINUM,DLAYGO,DO,MCD1,MCDIC,MCMAGD0,MCNODE,X,Y | 
|---|
| 85 | S OK="1^The Medicine Procedure file has been updated" | 
|---|
| 86 | I $O(MCMAGPTR(0))'>0 D  Q | 
|---|
| 87 | . S OK="0^No image number to file in Medicine Procedure file" | 
|---|
| 88 | . Q | 
|---|
| 89 | I $$VFIELD^DILFD(MCFILE,2005)'>0 D  Q | 
|---|
| 90 | . S OK="0^Image field not found in the Medicine Procedure file" | 
|---|
| 91 | . Q | 
|---|
| 92 | S MCNODE=$P($$GET1^DID(MCFILE,2005,"","GLOBAL SUBSCRIPT LOCATION"),";") | 
|---|
| 93 | I MCNODE="" D  Q | 
|---|
| 94 | . S OK="0^Medicine Procedure file global subscript location not found" | 
|---|
| 95 | . Q | 
|---|
| 96 | S MCDIC=$$GET1^DID(MCFILE,"","","GLOBAL NAME")_MCD0_"," | 
|---|
| 97 | S MCDIC=MCDIC_$S(MCNODE=+MCNODE:MCNODE,1:""""_MCNODE_"""")_"," | 
|---|
| 98 | S MCDIC("P")=$$GET1^DID(MCFILE,2005,"","SPECIFIER") | 
|---|
| 99 | S MCMAGD0=0 | 
|---|
| 100 | F  S MCMAGD0=$O(MCMAGPTR(MCMAGD0)) Q:MCMAGD0'>0  D  Q:'OK | 
|---|
| 101 | . S MCD1=+$O(^MCAR(MCFILE,MCD0,MCNODE,"B",MCMAGD0,0)) | 
|---|
| 102 | . I MCMAGD0'=$P($G(^MCAR(MCFILE,MCD0,MCNODE,MCD1,0)),U) S MCD1=0 | 
|---|
| 103 | . K DD,DIC,DINUM,DO | 
|---|
| 104 | . S DIC=MCDIC,DIC(0)="L",DIC("P")=MCDIC("P") | 
|---|
| 105 | . S DLAYGO=MCFILE,(D0,DA(1))=MCD0 | 
|---|
| 106 | . S X=MCMAGD0 | 
|---|
| 107 | . I MCD1'>0 D | 
|---|
| 108 | .. D FILE^DICN S MCD1=+Y | 
|---|
| 109 | .. I MCD1'>0 S OK="0^Cannot add image to Medicine Procedure file" | 
|---|
| 110 | .. Q | 
|---|
| 111 | . I OK S MCMAGPTR(MCMAGD0)=MCFILE_U_MCD0_U_MCD1 | 
|---|
| 112 | . Q | 
|---|
| 113 | Q | 
|---|
| 114 | ; | 
|---|
| 115 | VALID(FILE,IEN,DFN,PRC) ; | 
|---|
| 116 | ; *** Make sure we have the right Medicine Procedure data file rec *** | 
|---|
| 117 | ;  FILE = File number of one of the Medicine Procedure data files | 
|---|
| 118 | ;  IEN = Pointer to one of the Medicine Procedure data files | 
|---|
| 119 | ;  DFN = Pointer to the Patient file (#2) | 
|---|
| 120 | ;  PRC = Pointer to the Procedure/Subspecialty file (#697.2) | 
|---|
| 121 | ; Returns | 
|---|
| 122 | ;  '1^Message' = All is well, '0^Message' = Bad news | 
|---|
| 123 | N FIELD,OK,TYPE | 
|---|
| 124 | S OK="1^Record match found" | 
|---|
| 125 | S FIELD=$$PATFLD(FILE) | 
|---|
| 126 | I FIELD,$$GET1^DIQ(FILE,IEN,FIELD,"I")'=DFN D | 
|---|
| 127 | . S OK="0^Patient mismatch" | 
|---|
| 128 | . Q | 
|---|
| 129 | S FIELD=$$PRCFLD(FILE),TYPE=$$PRCTYPE(PRC) | 
|---|
| 130 | ; *** Old Generalized Procedures module and other modules | 
|---|
| 131 | I (MCFILE'=699.5)!((MCFILE=699.5)&($$VFILE^DILFD(MCFILE,.06)'>0)) D | 
|---|
| 132 | . S FIELD=$P(FIELD,U) | 
|---|
| 133 | . Q | 
|---|
| 134 | ; *** New Generalized Procedures module | 
|---|
| 135 | I (MCFILE=699.5)&($$VFIELD^DILFD(MCFILE,.06)>0) D | 
|---|
| 136 | . S FIELD=$S(TYPE="S":$P(FIELD,U),TYPE="P":$P(FIELD,U,2),1:0) | 
|---|
| 137 | . Q | 
|---|
| 138 | I FIELD,$$GET1^DIQ(FILE,IEN,FIELD,"I")'=PRC D | 
|---|
| 139 | . S OK="0^Procedure/Subspecialty mismatch" | 
|---|
| 140 | . Q | 
|---|
| 141 | Q OK | 
|---|
| 142 | ; | 
|---|
| 143 | PRCFLD(FILE) ; | 
|---|
| 144 | ; *** Procedure/Subspecialty pointer field *** | 
|---|
| 145 | ;  FILE = File number of one of the Medicine Procedure data files | 
|---|
| 146 | ; Returns | 
|---|
| 147 | ;  The field# in one of the Medicine Procedure data files that points | 
|---|
| 148 | ;  to the Procedure/Subspecialty file (#690)  (Zero [0] if not found) | 
|---|
| 149 | N PRCFLD | 
|---|
| 150 | S PRCFLD(694)=2,PRCFLD(694.8)=9,PRCFLD(699)=1,PRCFLD(699.5)=".05^.06" | 
|---|
| 151 | Q $G(PRCFLD(FILE),0) | 
|---|
| 152 | ; | 
|---|
| 153 | PATFLD(FILE) ; | 
|---|
| 154 | ; *** Medical Patient pointer field *** | 
|---|
| 155 | ;  FILE = File number of one of the Medicine Procedure data files | 
|---|
| 156 | ; Returns | 
|---|
| 157 | ;  The field# in one of the Medicine Procedure data files that points | 
|---|
| 158 | ;  to the Medical Patient file (#690)  (Zero [0] if not found) | 
|---|
| 159 | N MEDPAT | 
|---|
| 160 | S MEDPAT(691)=1,MEDPAT(691.1)=1,MEDPAT(691.5)=1,MEDPAT(691.6)=1 | 
|---|
| 161 | S MEDPAT(691.7)=1,MEDPAT(691.8)=1,MEDPAT(694)=1,MEDPAT(694.5)=1 | 
|---|
| 162 | S MEDPAT(698)=1,MEDPAT(698.1)=1,MEDPAT(698.2)=1,MEDPAT(698.3)=1 | 
|---|
| 163 | S MEDPAT(699)=.02,MEDPAT(699.5)=.02,MEDPAT(700)=1,MEDPAT(701)=1 | 
|---|
| 164 | Q $G(MEDPAT(FILE),0) | 
|---|
| 165 | ; | 
|---|
| 166 | PRCSUBS ; *** Procedure/Subspecialty DIC("DR") builder *** | 
|---|
| 167 | ; *** Old Generalized Procedures module and other modules | 
|---|
| 168 | N MCGENPRC,MCGENSUB,MCPRCTYP | 
|---|
| 169 | I (MCFILE'=699.5)!((MCFILE=699.5)&($$VFIELD^DILFD(MCFILE,.06)'>0)) D | 
|---|
| 170 | . D PRCTEST(MCFILE,$P(MCPRCFLD,U),MCPROCD0,.OK) | 
|---|
| 171 | . S DIC("DR")=DIC("DR")_";"_$P(MCPRCFLD,U)_"///`"_MCPROCD0 | 
|---|
| 172 | . Q | 
|---|
| 173 | ; *** New Generalized Procedures module | 
|---|
| 174 | I (MCFILE=699.5)&($$VFIELD^DILFD(MCFILE,.06)>0) D | 
|---|
| 175 | . S MCGENPRC=$$FINDPRC("GENERIC PROCEDURE","P") | 
|---|
| 176 | . I MCGENPRC'>0 S OK="0^Entry 'GENERIC PROCEDURE' not found" Q | 
|---|
| 177 | . S MCGENSUB=$$FINDPRC("GENERIC SUBSPECIALTY","S") | 
|---|
| 178 | . I MCGENSUB'>0 S OK="0^Entry 'GENERIC SUBSPECIALTY' not found" Q | 
|---|
| 179 | . S MCPRCTYP=$$PRCTYPE(MCPROCD0) | 
|---|
| 180 | . I "^P^S^"'[(U_MCPRCTYP_U) S OK="0^Invalid Procedure/Subspecialty" Q | 
|---|
| 181 | . D PRCTEST(MCFILE,$P(MCPRCFLD,U,$TR(MCPRCTYP,"PS","21")),MCPROCD0,.OK) | 
|---|
| 182 | . I MCPRCTYP="P" D | 
|---|
| 183 | .. S DIC("DR")=DIC("DR")_";"_$P(MCPRCFLD,U)_"///`"_MCGENSUB | 
|---|
| 184 | .. S DIC("DR")=DIC("DR")_";"_$P(MCPRCFLD,U,2)_"///`"_MCPROCD0 | 
|---|
| 185 | .. Q | 
|---|
| 186 | . I MCPRCTYP="S" D | 
|---|
| 187 | .. S DIC("DR")=DIC("DR")_";"_$P(MCPRCFLD,U)_"///`"_MCPROCD0 | 
|---|
| 188 | .. S DIC("DR")=DIC("DR")_";"_$P(MCPRCFLD,U,2)_"///`"_MCGENPRC | 
|---|
| 189 | .. Q | 
|---|
| 190 | . Q | 
|---|
| 191 | Q | 
|---|
| 192 | ; | 
|---|
| 193 | PRCTEST(MCFILE,MCPRCFLD,MCPROCD0,OK) ; | 
|---|
| 194 | ; *** Test for valid procedure | 
|---|
| 195 | N MCRESULT | 
|---|
| 196 | D CHK^DIE(MCFILE,MCPRCFLD,"","`"_MCPROCD0,.MCRESULT) | 
|---|
| 197 | K ^TMP("DIERR",$J) | 
|---|
| 198 | I MCRESULT=U S OK="0^Procedure is invalid" | 
|---|
| 199 | Q | 
|---|
| 200 | ; | 
|---|
| 201 | PRCTYPE(MCPROCD0) ; | 
|---|
| 202 | ; *** Return the procedure type *** | 
|---|
| 203 | Q $P($G(^MCAR(697.2,MCPROCD0,1)),U) | 
|---|
| 204 | ; | 
|---|
| 205 | FINDPRC(MCENTRY,MCTYPE) ; | 
|---|
| 206 | ; *** Find a procedure *** | 
|---|
| 207 | ;  MCENTRY = External name of the entry (697.2,.01) | 
|---|
| 208 | ;  MCTYPE  = Internal 'Procedure/Subspecialty' type (697.2,1001) | 
|---|
| 209 | ; Returns | 
|---|
| 210 | ;  The IEN of the procedure or zero if not found. | 
|---|
| 211 | N MCFOUND,MCIEN | 
|---|
| 212 | S (MCIEN,MCFOUND)=0 | 
|---|
| 213 | F  S MCIEN=$O(^MCAR(697.2,"B",MCENTRY,MCIEN)) Q:MCIEN'>0  D  Q:MCFOUND | 
|---|
| 214 | . I $P($G(^MCAR(697.2,MCIEN,0)),U)=MCENTRY D | 
|---|
| 215 | .. I $P($G(^MCAR(697.2,MCIEN,1)),U)=MCTYPE S MCFOUND=1 | 
|---|
| 216 | .. Q | 
|---|
| 217 | . Q | 
|---|
| 218 | Q +MCIEN | 
|---|
| 219 | ; | 
|---|
| 220 | KILL(MCFILE,MCD0,MCD1,OK) ; | 
|---|
| 221 | ; *** Remove an image from Image multiple *** | 
|---|
| 222 | ;  MCFILE = A Medicine Procedure data file number | 
|---|
| 223 | ;  MCD0 = Pointer to one of the Medicine Procedure data files | 
|---|
| 224 | ;  MCD1 = Pointer to one of the entries in the in the Image multiple | 
|---|
| 225 | ;  OK = A return flag: '1^Message' = All is well, '0^Message' = Bad news | 
|---|
| 226 | N D0,D1,DA,DIK,MCNODE | 
|---|
| 227 | S OK="1^Image pointer deleted from Medicine Procedure file" | 
|---|
| 228 | I $$VFIELD^DILFD(MCFILE,2005)'>0 D  Q | 
|---|
| 229 | . S OK="0^Image field not found in the Medicine Procedure file" | 
|---|
| 230 | . Q | 
|---|
| 231 | S DIK=$$GET1^DID(MCFILE,"","","GLOBAL NAME") | 
|---|
| 232 | I DIK="" D  Q | 
|---|
| 233 | . S OK="0^Medicine Procedure file global name not found" | 
|---|
| 234 | . Q | 
|---|
| 235 | S MCNODE=$P($$GET1^DID(MCFILE,2005,"","GLOBAL SUBSCRIPT LOCATION"),";") | 
|---|
| 236 | I MCNODE="" D  Q | 
|---|
| 237 | . S OK="0^Medicine Procedure file global subscript location not found" | 
|---|
| 238 | . Q | 
|---|
| 239 | S DIK=DIK_MCD0_","_$S(MCNODE=+MCNODE:MCNODE,1:""""_MCNODE_"""")_"," | 
|---|
| 240 | S (D0,DA(1))=MCD0,(D1,DA)=MCD1 | 
|---|
| 241 | D ^DIK | 
|---|
| 242 | Q | 
|---|