| 1 | MPIFAG1 ; EHR/DAOU/WCJ - ENTER HEALTH RECORD NUMBER ;1/27/07  21:26 | 
|---|
| 2 | ;;1.0; MASTER PATIENT INDEX VISTA ;**40**;30 Apr 99;Build 13 | 
|---|
| 3 | ; Copyright (C) 2007 WorldVistA | 
|---|
| 4 | ; | 
|---|
| 5 | ; This program is free software; you can redistribute it and/or modify | 
|---|
| 6 | ; it under the terms of the GNU General Public License as published by | 
|---|
| 7 | ; the Free Software Foundation; either version 2 of the License, or | 
|---|
| 8 | ; (at your option) any later version. | 
|---|
| 9 | ; | 
|---|
| 10 | ; This program is distributed in the hope that it will be useful, | 
|---|
| 11 | ; but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|---|
| 12 | ; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
|---|
| 13 | ; GNU General Public License for more details. | 
|---|
| 14 | ; | 
|---|
| 15 | ; You should have received a copy of the GNU General Public License | 
|---|
| 16 | ; along with this program; if not, write to the Free Software | 
|---|
| 17 | ; Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA | 
|---|
| 18 | ;'Modified' MAS Patient Look-up Check Cross-References June 1987 | 
|---|
| 19 | ;;;EHR PATIENT REGISTRATION;; | 
|---|
| 20 | ; | 
|---|
| 21 | ;This routine was originally from IHS routine AG1. | 
|---|
| 22 | ;It was modified so that it could be called from anywhere as long as | 
|---|
| 23 | ;DFN - patient | 
|---|
| 24 | ;DUZ(2) - location | 
|---|
| 25 | ;are defined. | 
|---|
| 26 | ; | 
|---|
| 27 | ;It was specifcally written so that it could be called within a DR string | 
|---|
| 28 | ;It is used to modify file 9000001 while in file 2. | 
|---|
| 29 | ; | 
|---|
| 30 | HRN ; | 
|---|
| 31 | Q:'$G(DUZ(2)) | 
|---|
| 32 | Q:'$G(DFN) | 
|---|
| 33 | N IENS,OUT,AG,SEQ,LIEN | 
|---|
| 34 | N DTOUT,DFOUT,DLOUT,DUOUT,DQOUT,Y | 
|---|
| 35 | N FDA,FDAIEN,XXX,PATID | 
|---|
| 36 | ; | 
|---|
| 37 | ; Find HRN for this DFN/location | 
|---|
| 38 | S IENS=","_DFN_"," | 
|---|
| 39 | D FIND^DIC(9000001.41,IENS,"@;.01;.02;","X",DUZ(2),,,,,"OUT") | 
|---|
| 40 | ; | 
|---|
| 41 | ; Check if it's a new location | 
|---|
| 42 | S SEQ=$O(OUT("DILIST","ID",0)) | 
|---|
| 43 | I SEQ S LIEN=$O(OUT("DILIST",2,SEQ)) ;(No point to this!) | 
|---|
| 44 | ; | 
|---|
| 45 | ; prompt user for HRN | 
|---|
| 46 | L1 ; | 
|---|
| 47 | I SEQ S (AG("CH"),AG("OCH"))=OUT("DILIST","ID",SEQ,.02) | 
|---|
| 48 | I 'SEQ S (AG("CH"),AG("OCH"))=$$GENHRN() | 
|---|
| 49 | S DIR(0)="9000001.41,.02",DIR("B")=AG("CH") | 
|---|
| 50 | D ^DIR | 
|---|
| 51 | I 'SEQ,$D(DTOUT) S Y=$G(AG("CH")) K DTOUT | 
|---|
| 52 | I $G(AG("CH"))]"",$D(DTOUT) Q | 
|---|
| 53 | I $D(DUOUT) Q  ;W !,"EXIT NOT ALLOWED ??" | 
|---|
| 54 | ; See if anyone is using that one | 
|---|
| 55 | S AG("CH")=+Y | 
|---|
| 56 | G L3:'$D(^AUPNPAT("D",AG("CH"))) | 
|---|
| 57 | Q:$D(^AUPNPAT("D",AG("CH"),$G(DFN))) | 
|---|
| 58 | S AG("D")=0 | 
|---|
| 59 | ; | 
|---|
| 60 | ; someone is using this one already, see if it's the same location | 
|---|
| 61 | L2 ; | 
|---|
| 62 | S AG("D")=$O(^AUPNPAT("D",AG("CH"),AG("D"))) | 
|---|
| 63 | G L3:AG("D")="" | 
|---|
| 64 | S AG("DD")=0 | 
|---|
| 65 | S AG("DD")=$O(^AUPNPAT("D",AG("CH"),AG("D"),AG("DD"))) | 
|---|
| 66 | G L2:AG("DD")'=DUZ(2) | 
|---|
| 67 | W !,*7,AG("CH")," is already assigned to ",$P(^DPT(AG("D"),0),U) | 
|---|
| 68 | G L1 | 
|---|
| 69 | ; | 
|---|
| 70 | ; let's do it.  unique for this Location | 
|---|
| 71 | L3 ; | 
|---|
| 72 | S IENS="?+1,"_DFN_"," | 
|---|
| 73 | S FDAIEN(1)=DUZ(2) | 
|---|
| 74 | S XXX="FDA" | 
|---|
| 75 | S FDA(9000001.41,IENS,.01)=DUZ(2) | 
|---|
| 76 | S FDA(9000001.41,IENS,.02)=AG("CH") | 
|---|
| 77 | D UPDATE^DIE("",XXX,"FDAIEN","RET") | 
|---|
| 78 | Q | 
|---|
| 79 | ; | 
|---|
| 80 | ; | 
|---|
| 81 | CHECK(Y) ; | 
|---|
| 82 | N X,DA S DA(1)=+$G(DFN),DA=DUZ(2),X=Y | 
|---|
| 83 | X $P(^DD(9000001.41,.02,0),U,5,99) Q $D(X)>0 | 
|---|
| 84 | ; | 
|---|
| 85 | ; | 
|---|
| 86 | GENHRN() ; | 
|---|
| 87 | N HRN | 
|---|
| 88 | S HRN=$O(^AUPNPAT("D",999999999),-1) I HRN'?.N S HRN="" G Q | 
|---|
| 89 | S HRN=HRN+1 | 
|---|
| 90 | I '$$CHECK(HRN) S HRN="" G Q | 
|---|
| 91 | F  Q:'$D(^AUPNPAT("D",HRN))  S HRN=HRN+1 I '$$CHECK(HRN) S HRN="" G Q | 
|---|
| 92 | Q Q HRN | 
|---|