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

PSOCPIB.m

Go to the documentation of this file.
  1. PSOCPIB ;BHAM ISC/EJW - PHARMACY CO-PAY IB-INITIATED COPAY CHARGE ; 07/27/01
  1. ;;7.0;OUTPATIENT PHARMACY;**71,137**;DEC 1997
  1. ;External reference to IBARX supported by DBIA 125
  1. ; files IB-initiated charges into original or refill node
  1. ; IB passes date/time^person initiating copay^Rx#^Fill#^Partial or full charge^IB transaction IEN from file #350
  1. N PSODA,PSOCOMM,PSOREF,PREA,SAVEDUZ,PSORSN
  1. S PREA="I"
  1. S SAVEDUZ=DUZ
  1. S DUZ=$P(Y(1),"^",2)
  1. S PSODA=$P(Y(1),"^",3)
  1. I 'PSODA Q
  1. S PSOREF=$P(Y(1),"^",4)
  1. D CHKIB
  1. S PSOCOMM=$S($P(Y(1),"^",5)="F":"FULL CHARGE",1:"PARTIAL CHARGE")
  1. FILE ; File IB number in ^PSRX
  1. S:PSOREF>0 ^PSRX(PSODA,1,PSOREF,"IB")=$P(Y(1),"^",6) ; Filing in refill node
  1. I PSOREF>0,'$D(^PSRX(PSODA,"IB")) S ^PSRX(PSODA,"IB")="^^" ; If refill "IB" exists, need "IB" entry on original fill node
  1. S:PSOREF=0 $P(^PSRX(PSODA,"IB"),"^",2)=$P(Y(1),"^",6) ;Filing in original fill (zero node)
  1. D ACTLOG^PSOCPA
  1. I $P($G(^PSRX(PSODA,"IB")),"^",1)="" D CANCEL ; IF Rx is 'no copay', send a cancel back to IB in 10 minutes for their IB-initiated charge
  1. S DUZ=SAVEDUZ
  1. Q
  1. ;
  1. CANCEL ;
  1. S ZTRTN="CANCHG^PSOCPIB"
  1. S ZTDESC="Call IB back to cancel charges"
  1. S PSORX=Y(1)_"^"_$G(PSOPAR7)
  1. S ZTSAVE("PSORX")=""
  1. S ZTDTH=$$HADD^XLFDT($H,0,0,10),ZTIO=""
  1. D ^%ZTLOAD
  1. Q
  1. ;
  1. CANCHG ; Cancel charges if IB initiates a charge for a 'no copay' Rx
  1. N PSODA,PSOCOMM,PSOREF,PREA,SAVEDUZ,X
  1. S PREA="C"
  1. S DUZ=$P(PSORX,"^",2)
  1. S PSODA=$P(PSORX,"^",3)
  1. S PSOREF=$P(PSORX,"^",4)
  1. S PSOPAR7=$P(PSORX,"^",7)
  1. S X=PSOPAR7_"^"_+$P(^PSRX(PSODA,0),"^",2)_"^^"_DUZ
  1. I PSOREF=0 D I $O(X(""))="" Q
  1. . I $P($G(^PSRX(PSODA,"IB")),"^",2)>0 S X(PSODA)=$P(^PSRX(PSODA,"IB"),"^",2)_"^40"
  1. I PSOREF>0 D I $O(X(""))="" Q
  1. . I $P($G(^PSRX(PSODA,1,PSOREF,"IB")),"^",1)>0 S X(PSODA)=$P(^PSRX(PSODA,1,PSOREF,"IB"),"^",1)_"^40"
  1. D CANCEL^IBARX
  1. I $D(Y(PSODA)),+$G(Y(PSODA))'=-1 D
  1. . S $P(^PSRX(PSODA,"IB"),"^",2)=+Y(PSODA),$P(^PSRX(PSODA,"IB"),"^",4)="" K Y(PSODA)
  1. . S PREA="C",PSOREF=0,PSOCOMM="AUTO-CANCEL IB-INITIATED CHARGE FOR 'NO COPAY' RX" D ACTLOG^PSOCPA
  1. F PSOREF=0:0 S PSOREF=$O(Y(PSOREF)) Q:PSOREF="" Q:PSOREF>12 D
  1. . I +Y(PSOREF)'=-1,$D(^PSRX(PSODA,1,PSOREF)) S ^PSRX(PSODA,1,PSOREF,"IB")=+Y(PSOREF)
  1. . S PREA="C",PSOCOMM="AUTO-CANCEL IB-INITIATED CHARGE FOR 'NO COPAY' RX" D ACTLOG^PSOCPA
  1. Q
  1. ;
  1. CHKIB ; SEE IF IB NUMBER ALREADY EXISTS AND IS A BILL OR UPDATE NUMBER (NOT A CANCEL NUMBER)
  1. N PSOIB,PSOSTAT
  1. I PSOREF=0 S PSOIB=$P($G(^PSRX(PSODA,"IB")),"^",2)
  1. I PSOREF'=0 S PSOIB=$P($G(^PSRX(PSODA,1,PSOREF,"IB")),"^",1)
  1. I PSOIB'="" D STATUS
  1. Q
  1. ;
  1. STATUS ;
  1. S PSOSTAT=$$STATUS^IBARX(PSOIB)
  1. I PSOSTAT'=1,PSOSTAT'=3 Q
  1. S PSOCOMM="Copay charge(s) removed"
  1. D ACTLOG^PSOCPA
  1. Q
  1. ;