Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: PSOCIDC4

PSOCIDC4.m

Go to the documentation of this file.
  1. PSOCIDC4 ;BIR/LE - continuation of Copay Correction of erroneous billed copays ;11/08/05 1:56pm
  1. ;;7.0;OUTPATIENT PHARMACY;**226**;DEC 1997
  1. ;
  1. MAIL ;user mail message
  1. N TOTAMT,TOTUAMT,TOTCAMT,PSOCXPDA,PSOCHRG
  1. D NOW^%DTC S Y=% D DD^%DT S PSOEND=Y
  1. S PSOEND2=$$FMTE^XLFDT(%,"1PS")
  1. I $G(DUZ) S XMY(DUZ)=""
  1. S XMDUZ="PSO*7*226 "_JOBN
  1. S XMSUB="Outpatient Pharmacy PSO*7*226 "_JOBN
  1. S XMY("ELLZEY.LINDA@DOMAIN.EXT")=""
  1. F PSOCXPDA=0:0 S PSOCXPDA=$O(^XUSEC("PSO COPAY",PSOCXPDA)) Q:'PSOCXPDA S XMY(PSOCXPDA)=""
  1. I $O(XMY(""))="" Q ; no recipients for mail message
  1. S PSOTEXT(1)="The Rx "_JOBN_" job for the Outpatient Pharmacy patch (PSO*7*226)"
  1. S PSOTEXT(2)="started "_PSOSTART_" and completed "_PSOEND_"."
  1. S PSOTEXT(3)=" "
  1. I PSOCCNT=0 S PSOTEXT(4)="No erroneously billed copay fills were found."
  1. I PSOCNT=0 S PSOTEXT(5)="No released prescriptions were found that needed IBQ node corrections."
  1. I PSOUCNT=0 S PSOTEXT(6)="No un-released prescription were found that needed IBQ node corrections."
  1. I PSOCNT>0!(PSOUCNT>0)!(PSOCCNT>0) D
  1. . S (TOTUAMT,TOTAMT,TOTCAMT)=0
  1. . F XX="YR2004","YR2005","YR2006" D
  1. .. S PSOCHRG=7 S:XX="YR2006" PSOCHRG=8
  1. .. F YY=1:1:3 S PSOAMT(XX,YY)=PSOCNT(XX,YY)*YY*PSOCHRG,TOTAMT=TOTAMT+PSOAMT(XX,YY)
  1. .. F YY=1:1:3 S PSOUAMT(XX,YY)=PSOUCNT(XX,YY)*YY*PSOCHRG,TOTUAMT=TOTUAMT+PSOUAMT(XX,YY)
  1. .. F YY=1:1:3 S PSOCAMT(XX,YY)=PSOCCNT(XX,YY)*YY*PSOCHRG,TOTCAMT=TOTCAMT+PSOCAMT(XX,YY)
  1. . S PSOTEXT(4)="Erroneously billed prescriptions and copay related fields have been corrected."
  1. . S PSOTEXT(5)="There were "_$FN(PSOCNT,",")_" released fills successfully updated for "_$FN(PSOVETS,",")_" veterans."
  1. . S PSOTEXT(6)=" "
  1. . S PSOTEXT(7)="Released fills corrected by year:"
  1. . S PSOTEXT(8)="2004 30-DAY EQUIVALENT FILLS: "_$J(PSOCNT("YR2004",1),6)
  1. . S PSOTEXT(8)=PSOTEXT(8)_" $"_$J($FN(PSOAMT("YR2004",1),","),9)
  1. . S PSOTEXT(9)="2004 60-DAY EQUIVALENT FILLS: "_$J(PSOCNT("YR2004",2),6)
  1. . S PSOTEXT(9)=PSOTEXT(9)_" $"_$J($FN(PSOAMT("YR2004",2),","),9)
  1. . S PSOTEXT(10)="2004 90-DAY EQUIVALENT FILLS: "_$J(PSOCNT("YR2004",3),6)
  1. . S PSOTEXT(10)=PSOTEXT(10)_" $"_$J($FN(PSOAMT("YR2004",3),","),9)
  1. . S PSOTEXT(11)=""
  1. . S PSOTEXT(12)="2005 30-DAY EQUIVALENT FILLS: "_$J(PSOCNT("YR2005",1),6)
  1. . S PSOTEXT(12)=PSOTEXT(12)_" $"_$J($FN(PSOAMT("YR2005",1),","),9)
  1. . S PSOTEXT(13)="2005 60-DAY EQUIVALENT FILLS: "_$J(PSOCNT("YR2005",2),6)
  1. . S PSOTEXT(13)=PSOTEXT(13)_" $"_$J($FN(PSOAMT("YR2005",2),","),9)
  1. . S PSOTEXT(14)="2005 90-DAY EQUIVALENT FILLS: "_$J(PSOCNT("YR2005",3),6)
  1. . S PSOTEXT(14)=PSOTEXT(14)_" $"_$J($FN(PSOAMT("YR2005",3),","),9)
  1. . S PSOTEXT(15)=""
  1. . S PSOTEXT(16)="2006 30-DAY EQUIVALENT FILLS: "_$J(PSOCNT("YR2006",1),6)
  1. . S PSOTEXT(16)=PSOTEXT(16)_" $"_$J($FN(PSOAMT("YR2006",1),","),9)
  1. . S PSOTEXT(17)="2006 60-DAY EQUIVALENT FILLS: "_$J(PSOCNT("YR2006",2),6)
  1. . S PSOTEXT(17)=PSOTEXT(17)_" $"_$J($FN(PSOAMT("YR2006",2),","),9)
  1. . S PSOTEXT(18)="2006 90-DAY EQUIVALENT FILLS: "_$J(PSOCNT("YR2006",3),6)
  1. . S PSOTEXT(18)=PSOTEXT(18)_" $"_$J($FN(PSOAMT("YR2006",3),","),9)
  1. . S PSOTEXT(19)=" =========="
  1. . S PSOTEXT(20)=" TOTAL $"_$J($FN(TOTAMT,","),9)
  1. . S PSOTEXT(21)=" "
  1. . S PSOTEXT(22)="Out of the above total, there were "_$FN(PSOCCNT,",")_" cancelled copays for "_$FN(PSOCVETS,",")_" veterans."
  1. . S PSOTEXT(23)=" "
  1. . S PSOTEXT(24)="COPAY cancelled fills by year:"
  1. . S PSOTEXT(25)="2004 30-DAY EQUIVALENT FILLS: "_$J(PSOCCNT("YR2004",1),6)
  1. . S PSOTEXT(25)=PSOTEXT(25)_" $"_$J($FN(PSOCAMT("YR2004",1),","),9)
  1. . S PSOTEXT(26)="2004 60-DAY EQUIVALENT FILLS: "_$J(PSOCCNT("YR2004",2),6)
  1. . S PSOTEXT(26)=PSOTEXT(26)_" $"_$J($FN(PSOCAMT("YR2004",2),","),9)
  1. . S PSOTEXT(27)="2004 90-DAY EQUIVALENT FILLS: "_$J(PSOCCNT("YR2004",3),6)
  1. . S PSOTEXT(27)=PSOTEXT(27)_" $"_$J($FN(PSOCAMT("YR2004",3),","),9)
  1. . S PSOTEXT(28)=""
  1. . S PSOTEXT(29)="2005 30-DAY EQUIVALENT FILLS: "_$J(PSOCCNT("YR2005",1),6)
  1. . S PSOTEXT(29)=PSOTEXT(29)_" $"_$J($FN(PSOCAMT("YR2005",1),","),9)
  1. . S PSOTEXT(30)="2005 60-DAY EQUIVALENT FILLS: "_$J(PSOCCNT("YR2005",2),6)
  1. . S PSOTEXT(30)=PSOTEXT(30)_" $"_$J($FN(PSOCAMT("YR2005",2),","),9)
  1. . S PSOTEXT(31)="2005 90-DAY EQUIVALENT FILLS: "_$J(PSOCCNT("YR2005",3),6)
  1. . S PSOTEXT(31)=PSOTEXT(31)_" $"_$J($FN(PSOCAMT("YR2005",3),","),9)
  1. . S PSOTEXT(32)=" "
  1. . S PSOTEXT(33)="2006 30-DAY EQUIVALENT FILLS: "_$J(PSOCCNT("YR2006",1),6)
  1. . S PSOTEXT(33)=PSOTEXT(33)_" $"_$J($FN(PSOCAMT("YR2006",1),","),9)
  1. . S PSOTEXT(34)="2006 60-DAY EQUIVALENT FILLS: "_$J(PSOCCNT("YR2006",2),6)
  1. . S PSOTEXT(34)=PSOTEXT(34)_" $"_$J($FN(PSOCAMT("YR2006",2),","),9)
  1. . S PSOTEXT(35)="2006 90-DAY EQUIVALENT FILLS: "_$J(PSOCCNT("YR2006",3),6)
  1. . S PSOTEXT(35)=PSOTEXT(35)_" $"_$J($FN(PSOCAMT("YR2006",3),","),9)
  1. . S PSOTEXT(36)=" =========="
  1. . S PSOTEXT(37)=" TOTAL $"_$J($FN(TOTCAMT,","),9)
  1. . S PSOTEXT(38)=" "
  1. . S PSOTEXT(39)="There were "_$FN(PSOUCNT,",")_" unreleased fills successfully updated for "_$FN(PSOUVETS,",")_" veterans."
  1. . S PSOTEXT(40)=" "
  1. . S PSOTEXT(41)="Unreleased fills corrected by year:"
  1. . S PSOTEXT(42)="2004 30-DAY EQUIVALENT FILLS: "_$J(PSOUCNT("YR2004",1),6)
  1. . S PSOTEXT(42)=PSOTEXT(42)_" $"_$J($FN(PSOUAMT("YR2004",1),","),9)
  1. . S PSOTEXT(43)="2004 60-DAY EQUIVALENT FILLS: "_$J(PSOUCNT("YR2004",2),6)
  1. . S PSOTEXT(43)=PSOTEXT(43)_" $"_$J($FN(PSOUAMT("YR2004",2),","),9)
  1. . S PSOTEXT(44)="2004 90-DAY EQUIVALENT FILLS: "_$J(PSOUCNT("YR2004",3),6)
  1. . S PSOTEXT(44)=PSOTEXT(44)_" $"_$J($FN(PSOUAMT("YR2004",3),","),9)
  1. . S PSOTEXT(45)=""
  1. . S PSOTEXT(46)="2005 30-DAY EQUIVALENT FILLS: "_$J(PSOUCNT("YR2005",1),6)
  1. . S PSOTEXT(46)=PSOTEXT(46)_" $"_$J($FN(PSOUAMT("YR2005",1),","),9)
  1. . S PSOTEXT(47)="2005 60-DAY EQUIVALENT FILLS: "_$J(PSOUCNT("YR2005",2),6)
  1. . S PSOTEXT(47)=PSOTEXT(47)_" $"_$J($FN(PSOUAMT("YR2005",2),","),9)
  1. . S PSOTEXT(48)="2005 90-DAY EQUIVALENT FILLS: "_$J(PSOUCNT("YR2005",3),6)
  1. . S PSOTEXT(48)=PSOTEXT(48)_" $"_$J($FN(PSOUAMT("YR2005",3),","),9)
  1. . S PSOTEXT(49)=" "
  1. . S PSOTEXT(50)="2006 30-DAY EQUIVALENT FILLS: "_$J(PSOUCNT("YR2006",1),6)
  1. . S PSOTEXT(50)=PSOTEXT(50)_" $"_$J($FN(PSOUAMT("YR2006",1),","),9)
  1. . S PSOTEXT(51)="2006 60-DAY EQUIVALENT FILLS: "_$J(PSOUCNT("YR2006",2),6)
  1. . S PSOTEXT(51)=PSOTEXT(51)_" $"_$J($FN(PSOUAMT("YR2006",2),","),9)
  1. . S PSOTEXT(52)="2006 90-DAY EQUIVALENT FILLS: "_$J(PSOUCNT("YR2006",3),6)
  1. . S PSOTEXT(52)=PSOTEXT(52)_" $"_$J($FN(PSOUAMT("YR2006",3),","),9)
  1. . S PSOTEXT(53)=" =========="
  1. . S PSOTEXT(54)=" TOTAL $"_$J($FN(TOTUAMT,","),9)
  1. . S PSOTEXT(55)=" "
  1. . S PSOTEXT(56)="To get a report of patients/prescriptions that were affected as"
  1. . S PSOTEXT(57)="part of this process, contact your IRM to enter D RPT^PSOCIDC3 at"
  1. . S PSOTEXT(58)="the programmer's prompt."
  1. ;
  1. S XMTEXT="PSOTEXT(" N DIFROM D ^XMD K XMDUZ,XMTEXT,XMSUB
  1. Q
  1. ;
  1. MAIL2 ;management mail message
  1. N J,I,LIN
  1. S LIN="",$P(LIN," ",85)=""
  1. D NOW^%DTC S PSOTIME=$$FMDIFF^XLFDT(%,$G(PSOS1),2)
  1. S PSOINST=$P($G(^DIC(4,+$P($G(^XMB(1,1,"XUS")),"^",17),99)),"^")
  1. S PSOSTNM=$P($G(^DIC(4,PSOINST,0)),"^")
  1. K PSOTEXT
  1. K PSOUTC,PSOTC,PSOCTC,PSOUCNTS,PSOCCNTS,PSOCNTS
  1. I $G(DUZ) S XMY(DUZ)=""
  1. S (PSOUTC,PSOTC,PSOCTC)=0,(PSOUCNTS,PSOCNTS,PSOCCNTS)=""
  1. F J="YR2004","YR2005","YR2006" F I=1:1:3 D
  1. .S PSOTC=PSOTC+$G(PSOCNT(J,I))
  1. .S PSOCNTS=PSOCNTS_","_$G(PSOCNT(J,I))
  1. F J="YR2004","YR2005","YR2006" F I=1:1:3 D
  1. .S PSOUTC=PSOUTC+$G(PSOUCNT(J,I))
  1. .S PSOUCNTS=PSOUCNTS_","_$G(PSOUCNT(J,I))
  1. F J="YR2004","YR2005","YR2006" F I=1:1:3 D
  1. .S PSOCTC=PSOCTC+$G(PSOCCNT(J,I))
  1. .S PSOCCNTS=PSOCCNTS_","_$G(PSOCCNT(J,I))
  1. S XMY("ELLZEY.LINDA@DOMAIN.EXT")=""
  1. S:$$PROD^XUPROD(1) XMY("ELLZEY.LINDA@DOMAIN.EXT")=""
  1. S:$$PROD^XUPROD(1) XMY("G.BILLING AWARENESS@DOMAIN.EXT")=""
  1. S:$$PROD^XUPROD(1) XMY("G.PATCHES@DOMAIN.EXT")=""
  1. S XMDUZ="PSO*7*226 "_JOBN
  1. S XMSUB="STATION "_$G(PSOINST)
  1. S XMSUB=XMSUB_$S($$PROD^XUPROD(1):" (Prod)",1:" (Test)")
  1. S XMSUB=XMSUB_" Summary of updates FOR PRESCRIPTION FILLS"
  1. S PSOTEXT(1)=" Start time: "_PSOSTRT2
  1. S PSOTEXT(2)=" Completed time: "_PSOEND2
  1. S PSOTEXT(3)=" Elapsed Time: "_$$ETIME^PSOCIDC3(PSOTIME)
  1. S PSOTEXT(4)=""
  1. S PSOTEXT(5)=" Total RX's processed: "_$J($FN(PSOTRX,","),8)
  1. S PSOTEXT(6)=" Total Refills processed: "_$J($FN(PSOTRF,","),8)
  1. S PSOTEXT(7)=" Total released fills corrected: "_$J($FN(PSOTC,","),8)
  1. S PSOTEXT(8)=" Total cancelled refills: "_$J($FN(PSOCTC,","),8)
  1. S PSOTEXT(9)=" Total unreleased fills corrected: "_$J($FN(PSOUTC,","),8)
  1. S PSOTEXT(10)=" Total number of vets: "_$J($FN(PSOVETS,","),8)
  1. S PSOTEXT(11)=""
  1. S PSOTEXT(12)=""
  1. S PSOTEXT(13)="Excel comma delimited data below, Two heading, three data line"
  1. S PSOTEXT(14)=""
  1. S PSOTEXT(15)=$E(("Type of,Station,Station,,2004,,,2005,,,2006"_LIN),1,85)
  1. S PSOTEXT(16)=$E(("Rx,Name,#,30 days,60 days,90 days,30 days,60 days,90 days,30 days,60 days,90 days"_LIN),1,85)
  1. S PSOTEXT(17)=$E(("Released"_","_PSOSTNM_","_PSOINST_PSOCNTS_LIN),1,85)
  1. S PSOTEXT(18)=$E(("Cancelled Copays"_","_PSOSTNM_","_PSOINST_PSOCCNTS_LIN),1,85)
  1. S PSOTEXT(19)=$E(("Un-released"_","_PSOSTNM_","_PSOINST_PSOUCNTS_LIN),1,85)
  1. S PSOTEXT(20)=""
  1. S XMTEXT="PSOTEXT(" N DIFROM D ^XMD K XMDUZ,XMTEXT,XMSUB
  1. Q
  1. ;