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

PRCOVTST.m

Go to the documentation of this file.
  1. PRCOVTST ;WISC/DJM/BGJ-IFCAP VRQ TO-DO ROUTINE ; [10/19/98 11:20am]
  1. V ;;5.1;IFCAP;**30**;Oct 20, 2000
  1. ;Per VHA Directive 10-93-142, this routine should not be modified.
  1. NEW(VEN1,SITE,FLAG) ;VEN1 = VENDOR INTERNAL ENTRY NUMBER
  1. N %,B,DATE,GECSFMS,FLAGN,FY,I,J,PS,NAME,MO,PAY,PAY1,PRCOVA,PRCOVA3,PRCOVN,PRCOVN3,SEQ,SSNT,ST,TIME,TRANS,VEN,VEND,X,Y
  1. S FLAGN=$G(^PRC(440.3,VEN1,0))
  1. S PRCOVN=$G(^PRC(440,VEN1,0))
  1. S PRCOVN3=$G(^PRC(440,VEN1,3))
  1. S PAY=$G(^PRC(440,VEN1,7))
  1. I FLAGN]"" D
  1. .S PRCOVA=FLAGN
  1. .S PRCOVA3=$G(^PRC(440.3,VEN1,3))
  1. .S PAY1=$G(^PRC(440.3,VEN1,7))
  1. G:PRCOVN3="" EXIT ;THERE IS NO DATA IN NODE 3 FOR THIS VENDOR--THIS USUALLY WILL NOT HAPPEN. CAN ONLY QUIT WITHOUT CREATING 'VRQ'
  1. ;
  1. G:$P(PRCOVN3,U,6)="N" EXIT ;NON-RECURRING VENDOR "N"=ONE-TIME VENDOR--DON'T NEED TO 'ADD'
  1. ;
  1. I FLAG=1,$P(PRCOVN3,U,4)]"" G EXIT ;'ADD' VRQ & FMS VENDOR CODE??? VENDOR UPDATED--DON'T NEED TO 'ADD' AGAIN (SHOULD NOT SEE THIS)
  1. ;
  1. I FLAG=1,(($P(PRCOVN3,U,9)="")!($P(PRCOVN3,U,8)="")) G EXIT ;NO TAX ID/SSN OR SSN/TAX ID INDICATOR--DON'T HAVE ALL INFORMATION TO SEND 'VRQ'
  1. ;
  1. G:PAY="" EXIT ;DON'T HAVE ANY PAYMENT ADDRESS INFORMATION--DON'T SEND 'VRQ'
  1. ;
  1. I FLAGN="" G DOIT ;THIS IS A NEW IFCAP VENDOR ENTRY--SEND IT
  1. I FLAG=1,$P(PRCOVN3,U,4)="",$P(PRCOVN3,U,12)="" G DOIT ;THIS ENTRY NEEDS TO BE SENT BECAUSE IT WASEN'T EVER DONE BEFORE
  1. ;
  1. I $P(PRCOVN,U)'=$P(PRCOVA,U) G DOIT
  1. I $P(PRCOVN3,U,11)'=$P(PRCOVA3,U,11) G DOIT
  1. I $P(PRCOVN3,U,13)'=$P(PRCOVA3,U,13) G DOIT
  1. I $P(PRCOVN3,U,14)'=$P(PRCOVA3,U,14) G DOIT
  1. I $P(PAY,U,3)'=$P(PAY1,U,3) G DOIT
  1. I $P(PAY,U,4)'=$P(PAY1,U,4) G DOIT
  1. I $P(PAY,U,7)'=$P(PAY1,U,7) G DOIT
  1. I $P(PAY,U,8)'=$P(PAY1,U,8) G DOIT
  1. I $P(PAY,U,9)'=$P(PAY1,U,9) G DOIT
  1. G EXIT ;USER DIDN'T CHANGE ANYTHING USED TO CREAT A VENDOR REQUEST
  1. ;
  1. DOIT ;COME HERE IF A VRQ SHOULD BE CREATED.
  1. S NOVRQ=0
  1. Q NOVRQ
  1. ;
  1. EXIT ;USE THIS EXIT ONLY IF NO VRQ SHOULD BE CREATED.
  1. ;DON'T FORGET TO REMOVE UN-EDITED COPY OF VENDOR RECORD (IN 440.3).
  1. K ^PRC(440.3,VEN1)
  1. S NOVRQ=1
  1. Q NOVRQ
  1. ;
  1. CHECK(DA,SITE,FLAG) ; CALL TO SEE IF VENDOR IS PROPERLY SET UP FROM AR
  1. ; VENDOR LOOKUP CALL -- VENSEL^PRCHUTL().
  1. ; COME HERE TO DECIDE WHAT NEEDS TO BE DONE WITH THE SELECTED
  1. ; VENDOR.
  1. ;
  1. ; RETURNED VALUE MEANING
  1. ; 0 NEED TO CREATE A VRQ - ALL DATA TO
  1. ; CREATE A VRQ IS HERE.
  1. ; 1 NEED TO EDIT VENDOR RECORD BEFORE A
  1. ; VRQ CAN BE CREATED.
  1. ; 2 THE VENDOR IS PROPERLY SET UP. NO
  1. ; VRQ NEEDS TO BE CREATED.
  1. ;
  1. S PRCOVN3=$G(^PRC(440,DA,3))
  1. I FLAG=1,$P(PRCOVN3,U,4)]"" G EXIT2 ;ADD VRQ WITH FMS VENDOR CODE
  1. ; PRESENT??? VENDOR UPDATED--DON'T NEED TO 'ADD' AGAIN.
  1. ;
  1. S (I,J)=0
  1. F S I=$O(^PRC(411,I)) Q:I'>0 S J=J+1
  1. I J>1 S PS=$O(^PRC(411,"AC","Y",0)) G:PS="" EXIT1
  1. ; 'PRIMARY STATION' NEEDS TO BE FILLED IN.
  1. ;
  1. S PAY=$G(^PRC(440,DA,7))
  1. G:PRCOVN3="" EXIT1 ; THIS RECORD NEEDS TO BE EDITED.
  1. ;
  1. G:$P(PRCOVN3,U,6)="N" EXIT1 ; NON-RECURRING VENDOR THIS RECORD
  1. ; NEEDS TO BE EDITED.
  1. ;
  1. G:$P(PRCOVN3,U,14)="" EXIT1 ; VENDOR TYPE UNDEFINED.
  1. G:PAY="" EXIT1
  1. ; DON'T HAVE ANY PAYMENT ADDRESS INFORMATION--EDIT THIS RECORD.
  1. ;
  1. G:$P(PAY,U,3)=""!($P(PAY,U,7)="")!($P(PAY,U,8)="")!($P(PAY,U,9)="") EXIT1 ; PAYMENT FIELDS AREN'T FILLED IN.
  1. S ST=$P(PAY,U,8)
  1. S ST=$E($P($G(^DIC(5,ST,0)),U,2),1,2)
  1. G:ST="" EXIT1 ; FOR SOME REASON THIS STATE IS MISSING FROM THE
  1. ; STATE FILE.
  1. ;
  1. I FLAG=1,(($P(PRCOVN3,U,9)="")!($P(PRCOVN3,U,8)="")) G EXIT1
  1. ; NO TAX ID/SSN OR SSN/TAX ID INDICATOR--DON'T HAVE ALL INFORMATION
  1. ; TO SEND 'VRQ'. EDIT THIS RECORD.
  1. ;
  1. DOIT1 ; COME HERE IF A VRQ SHOULD BE CREATED.
  1. S NOVRQ=0
  1. Q NOVRQ
  1. ;
  1. EXIT1 ; COME HERE IF THE VENDOR RECORD NEEDS TO BE EDITED.
  1. S NOVRQ=1
  1. Q NOVRQ
  1. ;
  1. EXIT2 ; USE THIS EXIT ONLY IF NO VRQ SHOULD BE CREATED.
  1. ; IF THERE IS NO "AR" NODE PRESENT REMOVE UN-EDITED COPY OF VENDOR
  1. ; RECORD (IN 440.3).
  1. S NODE=$D(^PRC(440.3,DA,"AR"))
  1. I NODE]"" S NODE=1
  1. K:NODE=0 ^PRC(440.3,DA)
  1. S NOVRQ=2
  1. Q NOVRQ
  1. ;
  1. VRQ(DA,SITE) ; COME HERE TO SEND A VRQ FOR THE VENDOR RECORD SELECTED
  1. ; BY THE AR USER. THIS ENTRY POINT IS CALLED FROM VENSEL^PRCHUTL().
  1. S PRCXDA=DA
  1. K ^PRC(440.3,DA)
  1. VRQ1 S PRCOVN3=$G(^PRC(440,DA,3))
  1. D NOW^%DTC
  1. S DATE=$P(%,".")
  1. S DATE=$E(DATE,2,7)
  1. S TIME=$P(%,".",2)_"000000"
  1. S TIME=$E(TIME,1,6)
  1. S FY=$E($P(%,"."),2,3)
  1. S MO=$E($P(%,U),4,5)
  1. S FY=$E(100+$S(+MO>9:FY+1,1:FY),2,3)
  1. K PRCFLN
  1. S X=SITE_"-"_FY_"-"_MO
  1. D COUNTER^PRCFACP
  1. S SEQ="000"_Y
  1. S SEQ=$E(SEQ,$L(SEQ)-3,99)
  1. S TRANS=SITE_FY_MO_SEQ
  1. S DA=PRCXDA
  1. S B="VRQ^"_DATE_"^"_TIME_"^"_SITE_"^"_DA_"^"_$P(PRCOVN3,U,8)_"^"
  1. S B=B_$S($P(PRCOVN3,U,5)]"":$P(PRCOVN3,U,5),1:"")
  1. S NAME=$P($G(^PRC(440,DA,0)),"^")
  1. S NAME=$E(NAME,1,30)
  1. S B=B_"^"_NAME_"^"
  1. S PAY=$G(^PRC(440,DA,7))
  1. S B=B_$E($P(PAY,U,3),1,30)_"^"
  1. S B=B_$S($P(PAY,U,4)]"":$E($P(PAY,U,4),1,30),1:"")_"^"
  1. S B=B_$E($P(PAY,U,7),1,19)_"^"
  1. S ST=$P(PAY,U,8)
  1. S ST=$E($P($G(^DIC(5,ST,0)),U,2),1,2)
  1. S B=B_ST_"^"_$TR($P(PAY,U,9),"-")_"^"
  1. S VEND=$S($P(PRCOVN3,U,11)]"":$P(PRCOVN3,U,11),1:"N")
  1. S SSNT=$S($P(PRCOVN3,U,9)]"":$P(PRCOVN3,U,9),1:"T")
  1. S:VEND="N" SSNT=""
  1. S B=B_SSNT_"^"_VEND_"^"_$P(PRCOVN3,U,14)_"^N^A^~"
  1. ;
  1. ; REQUEST GENERIC CODE SHEET PACKAGE SET UP AN ENTRY IN FILE 2100.1.
  1. ;
  1. D CONTROL^GECSUFMS("I",SITE,TRANS,"VR","","","","Vendor Request")
  1. ;
  1. ; ENTER THE 'VRQ' SEGMENT INTO FILE 2100.1 RECORD CREATED IN
  1. ; PREVIOUS CALL.
  1. ;
  1. D SETCS^GECSSTAA(GECSFMS("DA"),B)
  1. ;
  1. ; TELL GCS PACKAGE WHAT TO DO WITH THIS RECORD--'QUEUE' IT TO SEND
  1. ; THE NEXT TIME ANY FMS TRANSACTIONS ARE SENT TO AUSTIN.
  1. ;
  1. Q
  1. ;
  1. VRQS(DA,SITE) ; COME HERE TO SEND A VRQ FROM THE 'SEND VRQ' PROTOCOL.
  1. ;
  1. S PRCXDA=DA
  1. ;
  1. ; NOW LETS GO OVER TO SEND THIS VRQ TO AUSTIN, WITHOUT KILLING THE
  1. ; RECORD IN FILE 440.3. THAT RECORD IS USED WITHIN THE AR EDIT
  1. ; LIST TEMPLATE UNTIL 'DELETE EDIT REQUEST' REMOVES THE RECORD.
  1. ;
  1. G VRQ1