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

PSAPROC7.m

Go to the documentation of this file.
  1. PSAPROC7 ;BIR/JMB-Process Uploaded Prime Vendor Invoice Data - CONT'D ;9/6/97
  1. ;;3.0;DRUG ACCOUNTABILITY/INVENTORY INTERFACE;**3,12,27,21,42,61,64,67,68,71,73**; 10/24/97;Build 3
  1. ;This routine takes the data in XTMP and moves it to DA ORDERS file.
  1. ;It deletes the data in XTMP after it is copies.
  1. ;
  1. ;References to ^PSDRUG( are covered by IA #2095
  1. INVOICE ;PSA*3*21 (3JAN01) - FILE INVOICE IMMEDIATELY
  1. ;
  1. S PSAIN=$G(^XTMP("PSAPV",PSACTRL,"IN")) Q:PSAIN=""
  1. Q:$P(PSAIN,"^",8)'="P"
  1. S PSAORD=$P(PSAIN,"^",4),PSAIEN=+$O(^PSD(58.811,"B",PSAORD,0)),PSACRED=0
  1. I 'PSAIEN D
  1. .F L +^PSD(58.811,0):$S($G(DILOCKTM)>0:DILOCKTM,1:3) I Q
  1. .;(PSA*3*24 - Dave B. Jun 2 00 - Improper DIC call)
  1. .;(PSA*3*61 - add N DO. DICN will use DO if defined, we do not want to use it since DIC is defined.
  1. .N DO S DIC="^PSD(58.811,",DIC(0)="L",X=PSAORD D FILE^DICN K DIC L -^PSD(58.811,0) S PSAIEN=+Y
  1. F L +^PSD(58.811,PSAIEN,0):10 I Q
  1. S:'$D(^PSD(58.811,PSAIEN,1,0)) DIC("P")=$P(^DD(58.811,2,0),"^",2)
  1. S DA(1)=PSAIEN,DIC="^PSD(58.811,"_DA(1)_",1,",DIC(0)="L",X=$P(PSAIN,"^",2),DLAYGO=58.811 D ^DIC K DA,DLAYGO S PSAIEN1=+Y
  1. S DA(1)=PSAIEN,DA=PSAIEN1,DIE=DIC K DIC
  1. S PSALOCDR=$P($G(PSAIN),"^",7)
  1. S PSADELDR=$P($G(PSAIN),"^",6)
  1. S PSACSDR=$S($P(PSAIN,"^",10)="ALL CS":"A",$P(PSAIN,"^",9)="CS":"S",1:"N")
  1. S PSARECD=$P($G(PSAIN),"^",11)
  1. S PSAMV=$S(+$P(PSAIN,"^",12):$P(PSAIN,"^",12),1:"")
  1. S PSASUP=$S($P(PSAIN,"^",13)="SUP":1,1:"")
  1. ;DAVE B ( PSA*3*12) Invalid Concatenation of zero node
  1. S ^PSD(58.811,DA(1),1,DA,0)=$P(^(0),"^")_"^"_$P(PSAIN,"^",1)_"^P^"_$P(PSAIN,"^",3)_"^"_$G(PSALOCDR)_"^"_$G(PSADELDR)_"^"_$G(PSARECD)_"^"_$G(PSACSDR)_"^^"_DUZ_"^^"_$G(PSAMV)_"^"_$G(PSASUP)
  1. S DIK=DIE D IX^DIK
  1. K ^TMP($J,"PSADIF"),PSADIFLC ;*42 pre verify storage for OU, DUOU, Cost, NDC changes
  1. S PSALINE=0 F S PSALINE=$O(^XTMP("PSAPV",PSACTRL,"IT",PSALINE)) Q:PSALINE="" D LINE
  1. D SCANDIF,MM ;*42 look for differences to drug file SEND EMAIL
  1. I PSACRED K DA S DA(1)=PSAIEN,DA=PSAIEN1,DIE="^PSD(58.811,"_DA(1)_",1,",DR="10///^S X=1" D ^DIE K DIE
  1. S $P(^PSD(58.811,PSAIEN,0),"^",2)=$P($G(^XTMP("PSAPV",PSACTRL,"DS")),"^")
  1. L -^PSD(58.811,PSAIEN,0)
  1. K ^XTMP("PSAPV",PSACTRL)
  1. Q
  1. ;
  1. LINE ;Files line items.
  1. S PSADATA=^XTMP("PSAPV",PSACTRL,"IT",PSALINE) S:'$D(^PSD(58.811,PSAIEN,1,PSAIEN1,1,0)) DIC("P")=$P(^DD(58.8112,5,0),"^",2)
  1. ;PSA*3*31 Dave B - Check for invoice already in file
  1. S DA(2)=PSAIEN,DA(1)=PSAIEN1,(DA,X)=PSALINE,DIC="^PSD(58.811,"_DA(2)_",1,"_DA(1)_",1,",DIC(0)="L",DLAYGO=58.811 D ^DIC S PSAIEN2=+Y K DA,DIC,DLAYGO
  1. ;
  1. ;DAVEB PSA*3*3 (5may98)
  1. S PSADRG=$P($G(PSADATA),"^",6)
  1. S PSASYN=$P($G(PSADATA),"^",7)
  1. K PSAUNIT
  1. I $G(PSASYN)'="",$G(PSADRG)'="" S PSAUNIT=+$P($G(^PSDRUG(PSADRG,1,PSASYN,0)),"^",5)
  1. ;
  1. ;DAVE B (PSA*3*12) Assignment of order unit didn't take into
  1. ;account the adjusted order unit.
  1. S PSAUNIT=$S($G(PSAUNIT):PSAUNIT,$P(PSADATA,"^",12)'="":$P(PSADATA,"^",12),+$P($P(PSADATA,"^",2),"~",2):+$P($P(PSADATA,"^",2),"~",2),1:0) ;;*71
  1. S PSACS=$S($P(PSADATA,"^",19)="CS":1,1:0),PSANDC=$P($P(PSADATA,"^",4),"~"),PSAVSN=$P($P(PSADATA,"^",5),"~"),PSAUPC=$P($P(PSADATA,"^",26),"~")
  1. I PSANDC="",$P($P(PSADATA,"^",26),"~")'="" S PSANDC="S"_$P($P(PSADATA,"^",26),"~")
  1. S DA(2)=PSAIEN,DA(1)=PSAIEN1,DA=$S($D(PSAIEN2):PSAIEN2,1:PSALINE),DIE="^PSD(58.811,"_DA(2)_",1,"_DA(1)_",1,"
  1. ;DaveB (4may98) hard code filing data
  1. S $P(^PSD(58.811,DA(2),1,DA(1),1,DA,0),"^",3)=+PSADATA
  1. S $P(^PSD(58.811,DA(2),1,DA(1),1,DA,0),"^",11)=PSANDC
  1. S $P(^PSD(58.811,DA(2),1,DA(1),1,DA,0),"^",12)=PSAVSN
  1. S $P(^PSD(58.811,DA(2),1,DA(1),1,DA,0),"^",13)=PSAUPC
  1. S $P(^PSD(58.811,DA(2),1,DA(1),1,DA,0),"^",10)=PSACS
  1. S $P(^PSD(58.811,DA(2),1,DA(1),1,DA,0),"^",2)=PSADRG
  1. S $P(^PSD(58.811,DA(2),1,DA(1),1,DA,0),"^",4)=PSAUNIT
  1. S $P(^PSD(58.811,DA(2),1,DA(1),1,DA,0),"^",5)=$P(PSADATA,"^",3)
  1. S $P(^PSD(58.811,DA(2),1,DA(1),1,DA,0),"^",6)=DT
  1. S $P(^PSD(58.811,DA(2),1,DA(1),1,DA,0),"^",7)=DUZ
  1. ;BGN 67
  1. S $P(^PSD(58.811,DA(2),1,DA(1),3,DA,0),"^",1)=$P(PSADATA,"^",28)
  1. S $P(^PSD(58.811,DA(2),1,DA(1),3,DA,0),"^",2)=$P(PSADATA,"^",29)
  1. S $P(^PSD(58.811,DA(2),1,DA(1),3,DA,0),"^",3)=$P(PSADATA,"^",30)
  1. S $P(^PSD(58.811,DA(2),1,DA(1),3,DA,0),"^",4)=$P(PSADATA,"^",31)
  1. ;END 67
  1. S DIK=DIE D IX^DIK
  1. ;End PSA*3*7
  1. ;
  1. I +$P(PSADATA,"^",15)!($D(^XTMP("PSAPV",PSACTRL,"IT",PSALINE,"SUP"))) D ADJDRUG
  1. I $P(PSADATA,"^",8)'="" D QTY
  1. I +$P(PSADATA,"^",12) D OU
  1. I +$P(PSADATA,"^",23) D PRICE
  1. ;Adds the reorder level and/or dispense units per order unit
  1. I +$P(PSADATA,"^",7)!(+$P(PSADATA,"^",20))!(+$P(PSADATA,"^",21))!(+$P(PSADATA,"^",27)) D
  1. .S ^PSD(58.811,PSAIEN,1,PSAIEN1,1,PSAIEN2,2)=$P(PSADATA,"^",20)_"^"_$P(PSADATA,"^",21)_"^"_$S(+$P(PSADATA,"^",7):+$P(PSADATA,"^",7),1:0)_"^"_+$P(PSADATA,"^",27)
  1. ;Bgn 67
  1. I $P($P(PSADATA,"^",5),"~")'="" S ^XTMP("PSAVSN",$P($P(PSADATA,"^",5),"~"))=$P(PSADATA,"^",28)_"^"_$P(PSADATA,"^",29)_"^"_$P(PSADATA,"^",30)_"^"_$P(PSADATA,"^",31)
  1. ;End 67
  1. K ^XTMP("PSAPV",PSACTRL,"IT",PSALINE)
  1. Q
  1. ADJDRUG ;Records adjusted drug received
  1. S PSAFLD="D"
  1. I +$P(PSADATA,"^",15) S PSADJ=+$P(PSADATA,"^",15),PSADUZ=+$P(PSADATA,"^",16),PSADT=+$P(PSADATA,"^",17),PSAREA="" D RECORD Q
  1. I $D(^XTMP("PSAPV",PSACTRL,"IT",PSALINE,"SUP")) S PSASNODE=^XTMP("PSAPV",PSACTRL,"IT",PSALINE,"SUP"),PSADJ=$P(PSASNODE,"^",3),PSADUZ=+$P(PSASNODE,"^"),PSADT=+$P(PSASNODE,"^",2),PSAREA="" D RECORD
  1. Q
  1. OU ;Records adjusted order unit
  1. S PSAFLD="O",PSADJ=+$P(PSADATA,"^",12),PSADUZ=+$P(PSADATA,"^",13),PSADT=+$P(PSADATA,"^",14),PSAREA=""
  1. D RECORD
  1. Q
  1. PRICE ;Records adjusted price per order unit
  1. S PSAFLD="P",PSADJ=+$P(PSADATA,"^",23),PSADUZ=+$P(PSADATA,"^",24),PSADT=+$P(PSADATA,"^",25),PSAREA=""
  1. S:PSADJ'=+$P(PSADATA,"^",3) PSACRED=1
  1. D RECORD
  1. Q
  1. QTY ;Records adjusted quantity received.
  1. S PSAFLD="Q",PSADJ=+$P(PSADATA,"^",8),PSADUZ=+$P(PSADATA,"^",9),PSADT=+$P(PSADATA,"^",10),PSAREA=$P(PSADATA,"^",11)
  1. S:PSADJ'=+$P(PSADATA,"^") PSACRED=1
  1. D RECORD
  1. Q
  1. RECORD ;Adds adjusted data to DA ORDERS file
  1. K DA S DA(3)=PSAIEN,DA(2)=PSAIEN1,DA(1)=PSAIEN2,X=PSAFLD
  1. S:'$D(^PSD(58.811,PSAIEN,1,PSAIEN1,1,PSAIEN2,1,0)) DIC("P")=$P(^DD(58.81125,9,0),"^",2)
  1. ;PSA*3*27 (DAVE B) removed killing of DA variable on next line
  1. S DIC="^PSD(58.811,"_DA(3)_",1,"_DA(2)_",1,"_DA(1)_",1,",DIC(0)="L",DLAYGO=58.811 D ^DIC S PSAIEN3=+Y K DLAYGO
  1. ;
  1. ;PSA*3*3
  1. ;DAVEB Hard code filing
  1. S DIE=DIC,DA=PSAIEN3
  1. S $P(^PSD(58.811,DA(3),1,DA(2),1,DA(1),1,DA,0),"^",2)=PSADJ
  1. S $P(^PSD(58.811,DA(3),1,DA(2),1,DA(1),1,DA,0),"^",3)=$G(PSAREA)
  1. S $P(^PSD(58.811,DA(3),1,DA(2),1,DA(1),1,DA,0),"^",4)=DT
  1. S $P(^PSD(58.811,DA(3),1,DA(2),1,DA(1),1,DA,0),"^",5)=DUZ
  1. ;
  1. S DIK=DIE,DA=PSAIEN3 D IX1^DIK K DA,DIE,DIK,PSAFLD
  1. Q
  1. ;*42 CHANGES
  1. SCANDIF ; inspect invoice for noted differences in OU,DUOU,PPDU,NDC
  1. ;NEEDS PSAIEN, PSAIEN1
  1. K ^TMP($J,"PSADIF"),PSADIFLC
  1. S PSALINE=0 F S PSALINE=$O(^PSD(58.811,PSAIEN,1,PSAIEN1,1,PSALINE)) Q:PSALINE'>0 D CHECK
  1. Q
  1. MM ;
  1. I $D(^TMP($J,"PSADIF")) D MESSAGE
  1. Q
  1. CHECK ;Check line item for differences to drug file *42
  1. N ITM,ITMI,DRG,DRIEN,DIF,ZZ,XX,XXX,PCNT,PDIF,T,IENS
  1. ; use new API call to retrieve item fields see PSAUTL6
  1. D ITEM^PSAUTL6(PSAIEN,PSAIEN1,PSALINE,.ITM)
  1. D ITEM^PSAUTL6(PSAIEN,PSAIEN1,PSALINE,.ITMI,"I")
  1. I ITM(2)'>0 Q ;zero quantity will not be filed
  1. S ITM("OU")=ITM(3),ITM("DUOU")=ITM(10),ITM("NDC")=ITM(13),ITM("PPOU")=ITM(4),ITM("PPDU")=$J(ITM("PPOU")/ITM("DUOU"),1,4)
  1. I ITMI(1)'?1.N S DRIEN=ITMI(1)
  1. I ITMI(1)?1.N S DRIEN=+ITMI(1)
  1. Q:'$D(^PSDRUG(DRIEN))
  1. S DRG("OU")=$$GET1^DIQ(50,DRIEN,12),DRG("DUOU")=$$GET1^DIQ(50,DRIEN,15),DRG("NDC")=$$GET1^DIQ(50,DRIEN,31),DRG("PPDU")=$$GET1^DIQ(50,DRIEN,16)
  1. K DIF
  1. F XX="OU","DUOU","NDC" I $D(DRG(XX)),ITM(XX)'=DRG(XX) S DIF(XX)=""
  1. I $G(DRG("PPDU")),ITM("PPDU")'=DRG("PPDU") S PCNT=.05*DRG("PPDU"),PDIF=DRG("PPDU")-ITM("PPDU") S:PDIF<0 PDIF=-1*PDIF S:PDIF>PCNT DIF("PPDU")=""
  1. S:ITM("OU")=""!(ITM("OU")=0) ITM("OU")="Blank",DIF("OU")="" ;;*71
  1. S:DRG("OU")=""!(DRG("OU")=0) DRG("OU")="Blank",DIF("OU")="" ;;*71
  1. I $D(DIF) D
  1. . F ZZ=" ",$J(ITM(.01),3)_" "_ITM(1) D SET
  1. . S XXX="" F S XXX=$O(DIF(XXX)) Q:XXX="" D
  1. .. S ZZ=" ",T=XXX,ZZ=$$SETSTR^VALM1(T,ZZ,4,$L(T))
  1. .. S T="Old: "_DRG(XXX),ZZ=$$SETSTR^VALM1(T,ZZ,13,$L(T))
  1. .. S T="New: "_ITM(XXX),ZZ=$$SETSTR^VALM1(T,ZZ,36,$L(T))
  1. .. D SET
  1. Q
  1. SET ;set differences into ^TMP
  1. S:'$G(PSADIFLC) PSADIFLC=3
  1. S ^TMP($J,"PSADIF",PSADIFLC,0)=ZZ,PSADIFLC=PSADIFLC+1
  1. Q
  1. MESSAGE ;differences found, notify user and send message to g.PSA NDC UPDATES.
  1. K DIR N IENS
  1. S PSAORD=$$GET1^DIQ(58.811,PSAIEN,.01),IENS=PSAIEN1_","_PSAIEN
  1. S PSAINV=$$GET1^DIQ(58.8112,IENS,.01)
  1. S XMSUB="PRE Verify "_PSAORD_" : "_PSAINV_" Variance Report"
  1. S ^TMP($J,"PSADIF",1,0)=XMSUB,^TMP($J,"PSADIF",2,0)=" "
  1. W !,XMSUB,!
  1. W !,"Noted differences between the invoice line items and the drug file have",!,"been found. A mail message is being sent to G.PSA NDC UPDATES."
  1. W !!," Please check the message for accuracy.",!
  1. K DIR S DIR(0)="E",DIR("A")="<cr> - continue" D ^DIR
  1. K DIR
  1. S XMTEXT="^TMP($J,""PSADIF"",",XMY("G.PSA NDC UPDATES")=""
  1. D ^XMD
  1. K PSADIFLC,^TMP($J,"PSADIF")
  1. Q