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

GECSUFMS.m

Go to the documentation of this file.
  1. GECSUFMS ;WISC/RFJ/KLD-fms utilities ;10/13/98
  1. ;;2.0;GCS;**7,8,15,19,30,31,34,40**;MAR 14, 1995;Build 13
  1. Q
  1. ;
  1. ;GEC*2.0*40 Modified document MOA segment to insure the
  1. ; document transaction date used was from
  1. ; Committed Date in file 410 entry and handles
  1. ; the FY/FQ correctly when date is before
  1. ; or after current FY.
  1. ;
  1. CONTROL(SYSTEM,STATION,DOCUMENT,TRANCODE,SECCODE,MODFLAG,FCPFLAG,DESCRIPT,COMMDATE) ; return fms control segment
  1. ; system = "A" for ar, "I" for ifcap, "E" for eng, "C" for create doc
  1. ; station = 3 digit station number
  1. ; document = source document [sta-po####xx] where xx=partial (opt)
  1. ; trancode = MO, SV, etc for class = DOC
  1. ; = VR for vendor requests
  1. ; seccode = security 1 code (usually '10 ')
  1. ; modflag = 1 for modification document (batch number auto gen)
  1. ; fcpflag = Y if transaction has updated ifcap fcp balance
  1. ; use only for tran-code AR, CR, IV, MO, SA, ST
  1. ; descript = description of event
  1. ; return gecsfms("ctl"), gecsfms("bat"), gecsfms("doc")
  1. N %,%H,%I,BATNUMB,DATE,FY,H,M,S,SEGMENT,STACK,TIME,TRANCLAS,X,Y,SYSTEMI,GECOMDT ;GEC*2.0*40
  1. K GECSFMS
  1. S SYSTEMI=SYSTEM ; save initial system for rebuild
  1. S SYSTEM=$S($E(SYSTEM)="A":"ARS",$E(SYSTEM)="I":"IFC",$E(SYSTEM)="E":"AMM",1:"CFD")
  1. S STATION=$E(STATION,1,3)
  1. S DOCUMENT=$E($TR(DOCUMENT,"-")_" ",1,11)
  1. S TRANCODE=$E(TRANCODE,1,2)
  1. S SECCODE=$E(SECCODE_" ",1,4)
  1. GCOMDT D NOW^%DTC S Y=%,(GECOMDT,DATE)=X D DD^%DT ;GEC*2.0*40
  1. I $G(COMMDATE) S GECOMDT=COMMDATE,TIME="100000"
  1. S %=$P(Y,"@",2),H=$P(%,":"),M=$P(%,":",2),S=$P(%,":",3),H=$E("00",$L(H)+1,2)_H,M=$E("00",$L(M)+1,2)_M,S=$E("00",$L(S)+1,2)_S,TIME=H_M_S
  1. S Y=X X ^DD("DD") S FY=$S(GECOMDT>($E(DATE,1,3)_"0930"):$E(DATE,2,3)+1,GECOMDT<DATE:999,1:$E(DATE,2,3)) ;GEC*2.0*40
  1. I FY=999 D ;GEC*2.0*40
  1. . I $E(GECOMDT,1,3)=$E(DATE,1,3)!((GECOMDT>($E(DATE,1,3)-1)_"0930")) S FY=$E(DATE,2,3) Q
  1. . I GECOMDT>($E(GECOMDT,1,3)_"0930"),GECOMDT<($E(GECOMDT,1,3)_1232) S FY=$E(GECOMDT,2,3)+1 Q
  1. . S FY=$E(GECOMDT,2,3)
  1. S STACK=TRANCODE_"-"_DOCUMENT
  1. ; check if STACK exists in 2100.1 file
  1. K GECSDATA
  1. D DATA^GECSSGET(STACK,0)
  1. I $G(GECSDATA)>0,MODFLAG'>0 S GECSTEST=GECSDATA D Q
  1. . ;STACK entry exists. convert CONTROL call into REBUILD call
  1. . D REBUILD^GECSUFM1(GECSDATA,SYSTEMI,SECCODE,FCPFLAG,DESCRIPT)
  1. . S DA=GECSTEST,GECSFMS("DA")=GECSTEST
  1. . K GECSDATA,GECSTEST
  1. ;
  1. I MODFLAG F S %=$$ACOUNTER^GECSUNUM(STATION_"-FMS:BATCH-"_FY),%=$E(%,$L(%)-2,$L(%)),%=$E("000",$L(%)+1,3)_%,X=STACK_"-"_STATION_% I '$D(^GECS(2100.1,"B",X)) L +^GECS(2100.1,"AZ",X):0 I $T S STACK=X Q
  1. S BATNUMB=$E($P(STACK,"-",3)_" ",1,6)
  1. S TRANCLAS="DOC" I TRANCODE="VR" S TRANCLAS="VRQ",TRANCODE=" "
  1. S GECSFMS("CTL")="CTL^"_SYSTEM_"^FMS^"_$E(STATION,1,3)_"^"_TRANCLAS_"^"_TRANCODE_"^"_SECCODE_"^"_$E(BATNUMB,1,6)_"^"_DOCUMENT_"^"_(17+$E(GECOMDT))_$E(GECOMDT,2,7)_"^"_TIME_"^001^001^001^"_$C(126) ;GEC*2.0*40
  1. ;
  1. ; vendor request, add ctl to stack and quit
  1. I TRANCLAS="VRQ" D Q
  1. . S GECSFMS("DA")=$$ADD^GECSSTAA("VR:FMS",GECSFMS("CTL"),"","",DESCRIPT)
  1. . L -^GECS(2100.1,"AZ",STACK)
  1. ;
  1. ; change segment for specific transaction codes
  1. S SEGMENT=TRANCODE
  1. I TRANCODE="CF"!(TRANCODE="WR")!(TRANCODE="TR") S SEGMENT="CR"
  1. I TRANCODE="DV"!(TRANCODE="ET") S SEGMENT="DD"
  1. I TRANCODE="AO"!(TRANCODE="CO")!(TRANCODE="SO")!(TRANCODE="TG")!(TRANCODE="WO") S SEGMENT="MO"
  1. I TRANCODE="AV"!(TRANCODE="CT")!(TRANCODE="MV")!(TRANCODE="OP")!(TRANCODE="PS")!(TRANCODE="TD") S SEGMENT="PV"
  1. I TRANCODE="AR"!(TRANCODE="RT") S SEGMENT="RC"
  1. I TRANCODE="BV" S SEGMENT="SV"
  1. I TRANCODE="RO"!(TRANCODE="TZ") S SEGMENT="TO"
  1. I TRANCODE="RV"!(TRANCODE="TY") S SEGMENT="TV"
  1. ; create bat segment
  1. I MODFLAG S GECSFMS("BAT")="BAT^"_$C(126)_SEGMENT_"0^"_BATNUMB_"^"_$C(126)
  1. ; create doc and <tc>1 segments
  1. I "RC^CR^TR^IV^MO^SA^ST"[SEGMENT S FCPFLAG=$S(FCPFLAG="Y":"Y",1:"N")_"^"
  1. ; security code is not on the sa1,st1 code sheets
  1. S SECCODE=SECCODE_"^"
  1. I "SA^ST"[SEGMENT S SECCODE=""
  1. S GECSFMS("DOC")="DOC^"_$C(126)
  1. ; do not create <tc>1 document for at transaction code or amm system
  1. I SEGMENT'="AT",SYSTEM'="AMM" S GECSFMS("DOC")=GECSFMS("DOC")_SEGMENT_"1^"_TRANCODE_"^"_DOCUMENT_"^"_SECCODE_FCPFLAG_$C(126)
  1. ; add entry and control segment to stack file
  1. S GECSFMS("DA")=$$ADD^GECSSTAA(TRANCODE_":FMS",GECSFMS("CTL"),$G(GECSFMS("BAT")),GECSFMS("DOC"),DESCRIPT)
  1. L -^GECS(2100.1,"AZ",STACK)
  1. Q
  1. ;
  1. ;
  1. TRANSMIT ; transmit fms document from file 2100 immediately without batching
  1. ; called from gecsxbl1 routine
  1. N %,CTLDATA,DA,GECSFMS,STACK
  1. S CTLDATA=$G(^GECS(2100,GECS("CSDA"),"FMS"))
  1. ; ctldata=trancode^transnumber^modification=Y^securitycode^fcpflag
  1. D CONTROL("C",GECS("SITE"),$P(CTLDATA,"^",2),$P(CTLDATA,"^"),$P(CTLDATA,"^",4),$S($P(CTLDATA,"^",3)="Y":1,1:0),$P(CTLDATA,"^",5),"Create a Code Sheet Document")
  1. S DA=0 F S DA=$O(^GECS(2100,GECS("CSDA"),"CODE",DA)) Q:'DA S %=$G(^(DA,0)) I %'="" D SETCS^GECSSTAA(GECSFMS("DA"),%)
  1. ; set status for queued task to pick up and transmit
  1. D SETSTAT^GECSSTAA(GECSFMS("DA"),"Q")
  1. ; set status in file 2100
  1. S STACK=$P($G(^GECS(2100.1,GECSFMS("DA"),0)),"^")
  1. S $P(^GECS(2100,GECS("CSDA"),"TRANS"),"^",3)=STACK
  1. W !!,"STACK FILE ENTRY: ",STACK,?53,"QUEUED FOR TRANSMISSION"
  1. W !?5,"document header automatically created:",!,GECSFMS("CTL")
  1. I $D(GECSFMS("BAT")) W !,GECSFMS("BAT")
  1. W !,$G(GECSFMS("DOC"))
  1. Q