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

PSOBAIRP.m

Go to the documentation of this file.
  1. PSOBAIRP ;BIR/RTR-Report of prescription mail labels with bad address ;08/16/2006
  1. ;;7.0;OUTPATIENT PHARMACY;**233,326**;DEC 1997;Build 11
  1. ;
  1. EN ;
  1. N PSOFORM,PSOAPAT,PSOSDT,PSOEDT,PSOSDTX,PSOEDTX,X,Y,X1,X2
  1. W !!,"This option provides a report that shows patients and prescriptions whose last"
  1. W !,"label activity had a routing of mail and no valid permanent or temporary"
  1. W !,"address. It will also indicate whether the patient now has a good address.",!!
  1. K DIR S DIR(0)="SB^S:Single;A:All",DIR("A")="Print report for a Single patient, or All patients",DIR("B")="Single",DIR("?")=" ",DIR("?",1)="Enter 'S' to print address changes for one patient over the selected"
  1. S DIR("?",2)="date range, enter 'A' to print address changes for all patients",DIR("?",3)="over the selected date range."
  1. D ^DIR K DIR I Y["^"!($D(DTOUT))!($D(DUOUT)) D MESS Q
  1. S PSOFORM=$S(Y="S":1,1:0)
  1. I 'PSOFORM G DATE
  1. K DIC W ! S DIC(0)="QEAM",DIC("A")="Select PATIENT: " D EN^PSOPATLK S Y=PSOPTLK K DIC,PSOPTLK I Y<1!($D(DUOUT))!($D(DTOUT)) D MESS Q
  1. S PSOAPAT=+Y
  1. DATE ;
  1. W !!
  1. W ! K %DT S %DT="AEX",%DT("A")="Start fill date: " D ^%DT K %DT I Y<0!($D(DTOUT))!($D(DUOUT)) D MESS Q
  1. S (%DT(0),PSOSDT)=Y D DD^%DT S PSOSDTX=Y
  1. W ! S %DT="AEX",%DT("A")="End fill date: " D ^%DT K %DT I Y<0!($D(DTOUT))!($D(DUOUT)) D MESS Q
  1. S PSOEDT=Y D DD^%DT S PSOEDTX=Y
  1. S X1=PSOSDT,X2=-1 D C^%DTC S PSOSDT=X_".9999"
  1. S X1=PSOEDT,X2=+1 D C^%DTC S PSOEDT=X
  1. K IOP,%ZIS,POP S %ZIS="QM" D ^%ZIS I $G(POP) D MESS Q
  1. I $D(IO("Q")) D Q
  1. .S ZTRTN="REP^PSOBAIRP",ZTDESC="Pharmacy bad address mail label report",ZTSAVE("PSOFORM")="",ZTSAVE("PSOAPAT")="",ZTSAVE("PSOSDT")="",ZTSAVE("PSOEDT")="",ZTSAVE("PSOEDTX")="",ZTSAVE("PSOSDTX")="" D ^%ZTLOAD K %ZIS
  1. .W !!,"Report queued to print.",!
  1. REP ;
  1. K ^TMP("PSOBADL",$J)
  1. N PSODEV,PSOUT,PSOLINE,PSOPAGE,PSOADND,PSOADF,PSOADFF,PSOAOPT,PSOAOPTA,PSOAOPTZ,PSOAOPTB,PSOAOPTC,PSOADLP,PSOANODE,PSOADX,PSORX,PSOADATE,PSOC,PSOAALL,PSOADFN,PSOANAME,PSONI,PSONX,PSONB,PSOASN,VA,DFN,PSONSSN,PSOAFLAG
  1. U IO
  1. S (PSOUT,PSOAFLAG)=0,PSODEV=$S($E(IOST,1,2)'="C-":0,1:1),PSOPAGE=1
  1. S $P(PSOLINE,"-",78)=""
  1. ALL ;Print report for all patients
  1. N PSORD,PSORX,PSOLBL,PSOX
  1. S PSORD=PSOSDT F S PSORD=$O(^PSRX("AD",PSORD)) Q:'PSORD!(PSORD>PSOEDT) D
  1. .S PSORX=0 F S PSORX=$O(^PSRX("AD",PSORD,PSORX)) Q:'PSORX D
  1. ..S PSOLBL=$O(^PSRX(PSORX,"L",999999),-1) I 'PSOLBL Q
  1. ..S PSOX=$G(^PSRX(PSORX,"L",PSOLBL,0)) I PSOX["(BAD ADDRESS",PSOX'["WINDOW" D
  1. ...S PSOADFN=$P($G(^PSRX(PSORX,0)),"^",2) Q:'PSOADFN
  1. ...I $G(PSOFORM),PSOADFN'=PSOAPAT Q
  1. ...S PSOANAME=$P($G(^DPT(PSOADFN,0)),"^") Q:PSOANAME=""
  1. ...S ^TMP("PSOBADL",$J,PSOANAME,PSOADFN,PSORD,PSORX)=""
  1. D HD
  1. I '$D(^TMP("PSOBADL",$J)) W !!,"No data found to print for this date range.",! G END
  1. S PSONI="" F S PSONI=$O(^TMP("PSOBADL",$J,PSONI)) Q:PSONI=""!(PSOUT) D
  1. .S PSONX="" F S PSONX=$O(^TMP("PSOBADL",$J,PSONI,PSONX)) Q:PSONX=""!(PSOUT) D NAME,PRALL D
  1. ..S PSONB="" F S PSONB=$O(^TMP("PSOBADL",$J,PSONI,PSONX,PSONB)) Q:PSONB=""!(PSOUT) D
  1. ...S PSORX="" F S PSORX=$O(^TMP("PSOBADL",$J,PSONI,PSONX,PSONB,PSORX)) Q:PSORX=""!(PSOUT) D
  1. ....I ($Y+5)>IOSL D HD Q:PSOUT
  1. ....S Y=PSONB D DD^%DT S PSOADATE=Y
  1. ....D PRONE
  1. END ;
  1. K ^TMP("PSOBADL",$J)
  1. K DTOUT,DUOUT
  1. I '$G(PSOUT),PSODEV W !!,"End of Report." K DIR S DIR(0)="E",DIR("A")="Press Return to continue" D ^DIR K DIR
  1. I 'PSODEV W !!,"End of Report."
  1. I PSODEV W !
  1. E W @IOF
  1. D ^%ZISC S:$D(ZTQUEUED) ZTREQ="@"
  1. Q
  1. HD ;
  1. I '$G(PSOFORM) S PSOAFLAG=1
  1. I PSODEV,PSOPAGE'=1 W ! K DIR S DIR(0)="E",DIR("A")="Press Return to continue, '^' to exit" D ^DIR K DIR I 'Y S PSOUT=1 Q
  1. I PSOPAGE=1,'PSODEV W ! I 1
  1. E W @IOF
  1. D W ?67,"PAGE: "_PSOPAGE S PSOPAGE=PSOPAGE+1
  1. .I PSOFORM W !,"Bad address mail label report for "_$G(PSOANAME) Q
  1. .W !,"Bad address mail label report for ALL Patients"
  1. W !,"for fill date between "_$G(PSOSDTX)_" and "_$G(PSOEDTX)
  1. W !,PSOLINE
  1. Q
  1. MESS ;
  1. W !!,"Nothing queued to print.",!
  1. Q
  1. NAME ;Set name(ssn)
  1. K VA S DFN=PSONX D PID^VADPT6
  1. S PSONSSN=$G(PSONI)_" ("_$E(VA("PID"),5,12)_")"
  1. K VA
  1. Q
  1. PRALL ;Print data for all patients
  1. N PSOADDR
  1. S PSOADDR=""
  1. S PSOAFLAG=0
  1. W !!,$G(PSONSSN) D CHKADDR W ?30," ",PSOADDR I ($Y+5)>IOSL D HD Q:PSOUT
  1. Q
  1. PRONE ;Print data for one patient
  1. N PSORX0
  1. S PSORX0=$G(^PSRX(PSORX,0)) I PSORX0=""!($P(PSORX0,"^",6)="") Q
  1. D CON W !,$G(PSOADATE),?15," Rx#: ",$P(PSORX0,"^"),?30," ",$P($G(^PSDRUG($P(PSORX0,"^",6),0)),"^")
  1. I ($Y+5)>IOSL D HD Q:PSOUT
  1. Q
  1. CON ;
  1. I PSOAFLAG,'PSOFORM W !,$G(PSONSSN) S PSOAFLAG=0
  1. Q
  1. ;
  1. CHKADDR ;
  1. N PSOBADR,PSOTEMP
  1. I $G(PSONX)="" Q
  1. S PSOBADR=$$BADADR^DGUTL3(PSONX)
  1. I PSOBADR D
  1. .S PSOTEMP=$$CHKTEMP^PSOBAI(PSONX)
  1. I PSOBADR,'PSOTEMP S PSOADDR="** BAD ADDRESS **" Q
  1. S PSOADDR="PATIENT NOW HAS A VALID ADDRESS"
  1. Q