| [613] | 1 | QACNEW ;HISC/RS,CEW,DAD-Enter a new Patient representative record ; 11/24/00 1:40pm | 
|---|
|  | 2 | ;;2.0;Patient Representative;**3,5,8,10,11,13,16,17**;07/25/1995 | 
|---|
|  | 3 | S DIR("A")="Enter Date of Contact: ",DIR(0)="DOA^2010101:"_DT_":PEX" | 
|---|
|  | 4 | S DIR("?")="^D HELP^%DTC",DIR("??")="^D HELP^QACNEW" | 
|---|
|  | 5 | D ^DIR K DIR | 
|---|
|  | 6 | G QUIT:$D(DIROUT)!($D(DIRUT)) | 
|---|
|  | 7 | S QACDOC=Y | 
|---|
|  | 8 | K DA S DIR("A")="Enter Patient Name",DIR(0)="745.1,2" | 
|---|
|  | 9 | D ^DIR K DIR | 
|---|
|  | 10 | G QUIT:$D(DIROUT)!($D(DTOUT))!($D(DUOUT)) | 
|---|
|  | 11 | ; | 
|---|
|  | 12 | N QACNAME,QACPAT,QACPSRV,QACGWV,RECNR | 
|---|
|  | 13 | ; | 
|---|
|  | 14 | S QACPN=$P(Y,"^",1) | 
|---|
|  | 15 | S QACINCR=0 | 
|---|
|  | 16 | G:QACPN="" QACRECN | 
|---|
|  | 17 | SHOW S (QACELI,QACCAT,QACSSN,QACDOB)="",QACY=+Y | 
|---|
|  | 18 | I QACPN'="" S QACDATA=$G(^DPT(QACPN,0)),QACNAME=$P(QACDATA,"^") D | 
|---|
|  | 19 | .S QACSSN=$P(QACDATA,"^",9),QACDOB=$P(QACDATA,"^",3),QACSEX=$P(QACDATA,"^",2) S DFN=QACPN D ELIG^VADPT S QACELI=$P($G(VAEL(1)),"^",2),QACCAT=$P($G(VAEL(9)),"^",2) | 
|---|
|  | 20 | I QACPN'="" S QACPSRV=$P($G(^DPT(QACPN,.32)),U,3) | 
|---|
|  | 21 | I QACPN'="" S QACGWV=$P($G(^DPT(QACPN,.322)),U,10) | 
|---|
|  | 22 | W @IOF,!!,?15,"Enter New Patient Representative Contact",! | 
|---|
|  | 23 | I QACPN'="" S QACPAT=^DPT(QACPN,0) | 
|---|
|  | 24 | W !,"Patient Name:",?20,$P($G(QACPAT),U) | 
|---|
|  | 25 | W ?47,"Patient SSN:",?66,$P($G(QACPAT),U,9) | 
|---|
|  | 26 | S Y=$P($G(QACPAT),U,3) D DD^%DT W !,"Patient DOB: ",?20,$G(Y) | 
|---|
|  | 27 | W ?47,"Patient Sex:",?66,$P($G(QACPAT),U,2) | 
|---|
|  | 28 | W !,"Eligibility Status:",?20,$G(QACELI) | 
|---|
|  | 29 | W ?47,"Patient Category:",?66,$G(QACCAT) | 
|---|
|  | 30 | I $G(QACPSRV)]"" W !,"Period of Service: ",?20,$P(^DIC(21,$G(QACPSRV),0),U) | 
|---|
|  | 31 | W ?47,"Persian Gulf War?: ",?66,$S($G(QACGWV)="Y":"YES",$G(QACGWV)="N":"NO",$G(QACGWV)="U":"UNKNOWN",1:"Not Entered") | 
|---|
|  | 32 | N CNT1,CNT2,J,K,L,M,N,QACCODE,QACCSS,QACFLG,QACNUM,QACOPEN,QACROC,QACSS | 
|---|
|  | 33 | I QACPN'="" S J="",CNT1=0 F  S J=$O(^QA(745.1,"E",QACPN,J)) Q:'J  D | 
|---|
|  | 34 | . S CNT1=CNT1+1 | 
|---|
|  | 35 | . S QACROC(CNT1)=J | 
|---|
|  | 36 | I $G(CNT1)>0 D | 
|---|
|  | 37 | . W !!,"Last ROC for ",QACNAME,": ",$P(^QA(745.1,QACROC(CNT1),0),U) | 
|---|
|  | 38 | . S Y=$P(^QA(745.1,QACROC(CNT1),0),U,2) D DD^%DT | 
|---|
|  | 39 | . W "  Date: ",Y | 
|---|
|  | 40 | . I $G(^QA(745.1,QACROC(CNT1),3,0))]"" S QACNUM=QACROC(CNT1) D CODES | 
|---|
|  | 41 | I QACPN'="" S DFN=QACPN D DIS^DGRPDB | 
|---|
|  | 42 | I $G(CNT1)>0 D | 
|---|
|  | 43 | . S K=0,CNT2=0 F  S K=$O(QACROC(K)) Q:'K  Q:QACROC(K)'>0  D | 
|---|
|  | 44 | . . I '$D(^XUSEC("QAC EDIT",DUZ))#2,(DUZ'=$P(^QA(745.1,QACROC(K),0),U,7)) Q | 
|---|
|  | 45 | . . I $P($G(^QA(745.1,QACROC(K),7)),U,2)="O" S CNT2=CNT2+1,QACOPEN(CNT2)=QACROC(K) | 
|---|
|  | 46 | I $G(CNT2)'>0,(QACPN'="") W !!,"There are no open Contacts on patient ",$P(^DPT(QACPN,0),U),"." | 
|---|
|  | 47 | N % | 
|---|
|  | 48 | I $G(CNT2)>0 W !!,"Would you like to edit open ROC(s) at this time" S %=0 D YN^DICN W:%'=1 !! I %=1 D | 
|---|
|  | 49 | . I CNT2>1,(QACPN'="") D | 
|---|
|  | 50 | EDOPEN . . ; If user chooses, can edit open ROCs on this patient. | 
|---|
|  | 51 | . . W !!?10,"Edit an open Report of Contact on ",$P(^DPT(QACPN,0),U) | 
|---|
|  | 52 | . . W !,"Choose from: " | 
|---|
|  | 53 | . . S L=0 F  S L=$O(QACOPEN(L)) Q:'L  D | 
|---|
|  | 54 | . . . I $D(^XUSEC("QAC EDIT",DUZ))#2!(DUZ=$P(^QA(745.1,QACOPEN(L),0),U,7)) W !,L,"   ",$P(^QA(745.1,QACOPEN(L),0),U) S Y=$P(^QA(745.1,QACOPEN(L),0),U,2) D DD^%DT W ?40,"Date: ",Y S QACNUM=QACOPEN(L) D CODES | 
|---|
|  | 55 | . . S DIR(0)="NO",DIR("S")="I X>0,(X<QACLAST+1)" | 
|---|
|  | 56 | . . S DIR("?")="Enter the list number of your selection." | 
|---|
|  | 57 | . . D ^DIR Q:$D(DIRUT) | 
|---|
|  | 58 | . . S (RECNR,Y)=QACOPEN(X),QACFLG=1,DIE=745.1 | 
|---|
|  | 59 | . . D EDT^QACEDIT G EDOPEN | 
|---|
|  | 60 | . . W !!!!,"****Returning to 'Enter New Contact' session.****",!! | 
|---|
|  | 61 | . I CNT2=1 D | 
|---|
|  | 62 | . . S (Y,RECNR,QACNUM)=QACOPEN(CNT2),QACFLG=1 | 
|---|
|  | 63 | . . W !!!,$P(^QA(745.1,QACNUM,0),U) S Y=$P(^QA(745.1,QACNUM,0),U,2) D DD^%DT W ?40,"Date: ",Y | 
|---|
|  | 64 | . . D CODES | 
|---|
|  | 65 | . . S Y=QACNUM D EDT^QACEDIT | 
|---|
|  | 66 | . . W !!!!,"****Returning to 'Enter New Contact' session.****",!! | 
|---|
|  | 67 | S QACINCR=0 | 
|---|
|  | 68 | QACRECN ; Build next contact number | 
|---|
|  | 69 | N QACLEN,QACLEN1,QACNO,QACNT S QACNT=0 | 
|---|
|  | 70 | S QACYR=$E(DT,2,3),(QACRCFLG,QAC)=+$P($G(^QA(745.1,0)),U,3) | 
|---|
|  | 71 | I $G(QACRCFLG) D | 
|---|
|  | 72 | . S QAC=$O(^QA(745.1," "),-1) Q:QAC'>0  S QACRCFLG=QAC | 
|---|
|  | 73 | . S QACRCD(1)=$P($G(^QA(745.1,QACRCFLG,0)),U) | 
|---|
|  | 74 | . S QACRCD(2)=$P($$SITE^VASITE(DT),U,3) ;QAC*2*13 - use api for station # QAC*2*16 - access 3rd piece | 
|---|
|  | 75 | . S QACLEN1=$L(QACRCD(2)) | 
|---|
|  | 76 | . S QACRCD(3)=$E(QACRCD(1),QACLEN1+1,999) | 
|---|
|  | 77 | . I QACYR'=$E(QACRCD(3),2,3) S QACRCD="."_QACYR_"000"_1+QACINCR Q | 
|---|
|  | 78 | . ; splitting off contact number from year to allow for >9999 records | 
|---|
|  | 79 | . ; per year.  patch QAC*2*8 - ERC | 
|---|
|  | 80 | . S QACRCD(4)=$E(QACRCD(3),4,999) | 
|---|
|  | 81 | . S QACRCD(4)=QACRCD(4)+1+QACINCR | 
|---|
|  | 82 | . S QACLEN=$L(QACRCD(4)) | 
|---|
|  | 83 | . S QACRCD="."_QACYR_QACRCD(4) | 
|---|
|  | 84 | . I QACLEN<4 S QACRCD="."_QACYR_$E("000",1,(4-QACLEN))_QACRCD(4) | 
|---|
|  | 85 | E  S QACRCD="."_QACYR_"000"_1+QACINCR | 
|---|
|  | 86 | S QACCASE=QACRCD(2)_QACRCD | 
|---|
|  | 87 | I $O(^QA(745.1,"B",QACCASE,0))>0 S QACINCR=QACINCR+1 G QACRECN | 
|---|
|  | 88 | S QACLC="L +X"_$P(QACCASE,".",2)_":0" | 
|---|
|  | 89 | X QACLC I '$T S QACINCR=QACINCR+1 G QACRECN | 
|---|
|  | 90 | K DIC,DD,DO,DINUM,DLAYGO S X=QACCASE | 
|---|
|  | 91 | S DIC("DR")="",DIC(0)="EMQLZ",(DIC,DLAYGO)=745.1 D ^DIC K DIC | 
|---|
|  | 92 | S QACLC="L -X"_$P(QACCASE,".",2) X QACLC G END:Y<0 | 
|---|
|  | 93 | S QACDA=+Y | 
|---|
|  | 94 | Q:$G(DUOUT) | 
|---|
|  | 95 | D DIVLIST | 
|---|
|  | 96 | ;S DIE="^QA(745.1,",DR=37 D ^DIE | 
|---|
|  | 97 | ;S QACDA=QAC+1 | 
|---|
|  | 98 | S QACALERT=1 | 
|---|
|  | 99 | S DIE="^QA(745.1,",DA=QACDA,DR="1////"_QACDOC_";2////"_$G(QACPN)_";9////"_DUZ_";27///^S X=""O"";6////"_$G(QACELI)_";7///"_$G(QACCAT)_";31////"_$G(QACPSRV)_";32////"_$G(QACGWV) D ^DIE | 
|---|
|  | 100 | K DIC,DIQ,DR | 
|---|
|  | 101 | ;I QACPN'="" S DFN=QACPN D DIS^DGRPDB | 
|---|
|  | 102 | K TMP,DFN,CODE,DIQ,DIR,DR,LINE,N1,N2,QAC,QACCASE,QACCAT,QACDATA,QACDOB,QACDOC,QACELI,QACFL1,QACRCD,QACRCD(1),QACRCD(2),QACRCFLG,QACSEX,QACSITE,QACSSN,QACYR,TAB,TEXT,VAEL,QACY | 
|---|
|  | 103 | EDIT ;FILL IN REST OF DATA FIELDS | 
|---|
|  | 104 | W ! S DIE="^QA(745.1," | 
|---|
|  | 105 | S DA=QACDA | 
|---|
|  | 106 | I $G(QACPN)]"" S DR=16.5 D ^DIE | 
|---|
|  | 107 | S DR="[QAC CONTACT ENTER/EDIT]" | 
|---|
|  | 108 | D ^DIE | 
|---|
|  | 109 | END K D,D0,DA,DD,DI,DIC,DIE,DIR,DLAYGO,DTOUT,DO,DR,DUOUT,FLD,J,TEMPY,X,Y | 
|---|
|  | 110 | K QACALERT,QACCASE,QACD1,QACDA,QACDFLT,QACFL1,QACINCR,QACLAST,QACLC,QACN,QACOPEN,QACOUT,QACPN,QACY,QACDVNAM | 
|---|
|  | 111 | W !! G ^QACNEW | 
|---|
|  | 112 | HELP ; | 
|---|
|  | 113 | W !!,"This is the date the Patient Representative was initially contacted." | 
|---|
|  | 114 | W !,"Enter a date no later than TODAY." | 
|---|
|  | 115 | Q | 
|---|
|  | 116 | TEXT ; | 
|---|
|  | 117 | 1 ;;0^Contact Number:^W ?20,QACDATA | 
|---|
|  | 118 | 100 ;;47^Date of Contact:^W ?66,QACDATA | 
|---|
|  | 119 | 200 ;;0^Patient Name:^W ?20,QACDATA | 
|---|
|  | 120 | 300 ;;47^Patient SSN (c):^W ?66,QACDATA | 
|---|
|  | 121 | 400 ;;0^Patient DOB (c):^S Y=QACDATA D DD^%DT S QACDATA=Y W ?20,QACDATA | 
|---|
|  | 122 | 500 ;;47^Patient sex (c):^W ?66,QACDATA | 
|---|
|  | 123 | 600 ;;0^Eligibility Status:^W ?20,QACDATA | 
|---|
|  | 124 | 700 ;;47^Patient Category:^W ?66,QACDATA | 
|---|
|  | 125 | ; | 
|---|
|  | 126 | QUIT K DIR,DIROUT,DIRUT,DTOUT,DUOUT,X,Y | 
|---|
|  | 127 | K QACALERT,QACDOC,QACFL1,QACPN,QACRCD,QACY | 
|---|
|  | 128 | Q | 
|---|
|  | 129 | CODES ; Display Issue Codes and Customer Service Standards with ROC | 
|---|
|  | 130 | W !?3,"Issue Code(s):" | 
|---|
|  | 131 | S M=0 | 
|---|
|  | 132 | F  S M=$O(^QA(745.1,QACNUM,3,M)) Q:'M  S QACCODE=^QA(745.1,QACNUM,3,M,0) D | 
|---|
|  | 133 | . W !,$P(^QA(745.2,QACCODE,0),U)_"-"_$P(^QA(745.2,QACCODE,0),U,3) | 
|---|
|  | 134 | . S QACCSS=$P(^QA(745.2,QACCODE,0),U,7) | 
|---|
|  | 135 | . I $G(QACCSS)]"" S N="" S QACSS=$O(^QA(745.6,"B",QACCSS,N)) W "(*",$P(^QA(745.6,QACSS,0),U,2),")" | 
|---|
|  | 136 | Q | 
|---|
|  | 137 | DIVLIST ; | 
|---|
|  | 138 | ;W !!,"DIVISION: " | 
|---|
|  | 139 | N QAC,QACC | 
|---|
|  | 140 | S (QAC,QACC)=0 | 
|---|
|  | 141 | F  S QACC=$O(^DG(40.8,"AD",QACC)) Q:QACC'>0  D | 
|---|
|  | 142 | . S QAC=QAC+1 | 
|---|
|  | 143 | . S QAC(QAC)=QAC | 
|---|
|  | 144 | . S QACC(QAC)=QACC | 
|---|
|  | 145 | . I $D(^DIC(4,QACC,0)) W !,"    "_QAC(QAC)_"  "_$P(^DIC(4,QACC,0),U) | 
|---|
|  | 146 | S DIR(0)="NA" | 
|---|
|  | 147 | S DIR("A")="Enter your Division: " | 
|---|
|  | 148 | S DIR("?")="Choose the number of your division." | 
|---|
|  | 149 | D ^DIR K DIR | 
|---|
|  | 150 | Q:$G(DIRUT) | 
|---|
|  | 151 | I $G(QAC(+Y))]"" S QAC=$P($G(^DIC(4,QACC(+Y),0)),U) | 
|---|
|  | 152 | S DR="37///^S X=QAC",DIE="^QA(745.1,",DA=QACDA D ^DIE | 
|---|
|  | 153 | Q | 
|---|