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

ACHSTXAR.m

Go to the documentation of this file.
  1. ACHSTXAR ; IHS/ITSC/PMF - REGENERATION OF EXPORT GLOBAL ;
  1. ;;3.1;CONTRACT HEALTH MGMT SYSTEM;**13,14,21,26**;JUN 11, 2001;Build 43
  1. ;ACHS*3.1*13 6.26.2007 IHS/OIT/FCJ FIXED EXITING IF NO DOC SELECTED
  1. ;ACHS*3.1*14 11.5.2007 IHS/OIT/FCJ RE-EXPORT UFMS INSTEAD OF CORE RECORDS
  1. ;ACHS*3.1*26 2.26.2016 IHS/OIT/FCJ ADDED RANGE SELECTION OPTION
  1. ;
  1. ;ACHS*3.1*14 11.5.2007 IHS/OIT/FCJ ADDED COMMENT AND TEST FOR EXPORT ALREADY RAN;ACHS*3.1*21 ADDED TEST FOR RE-EXPORT
  1. I 'ACHSREEX,$D(^ACHSTXST("C",DT,DUZ(2))) W !!,"EXPORT PROGRAM ALREADY RUN THIS DATE FOR THIS FACILITY",*7 H 2 G EXIT1
  1. ;S Y=$$DIR^XBDIR("S^1:Re-Export a Batch;2:Select (up to) 101 transactions","Which Re-export option","1","","Select one of the re-export options or ""^""","^D HELP^ACHSTXAR(""H"")","2")
  1. S Y=$$DIR^XBDIR("S^1:Re-Export a Batch;2:Select (up to) 101 transactions;3:Select range for Intial transactions only","Which Re-export option","1","","Select one of the re-export options or ""^""","^D HELP^ACHSTXAR(""H"")","2")
  1. G EXIT1:$D(DUOUT)!$D(DTOUT)
  1. ;ACHS*3.1*13 IHS/OIT/FCJ ADDED TEST FOR ^TMP IN NXT LINE TO EXIT IF NO DOCS SELECTED ACHS*3.1*14 CHANGE RTN FR ACHSTXA1 TO ACHSTXF1
  1. ;I Y=2 D SELDOC G EXIT1:$D(DUOUT)!$D(DTOUT)!'$D(^TMP("ACHSTXAR",$J)),^ACHSTXA1
  1. I Y=2 D SELDOC G EXIT1:$D(DUOUT)!$D(DTOUT)!'$D(^TMP("ACHSTXAR",$J)) G ^ACHSTXF1:ACHSTXTY="U" G ^ACHSTXA1
  1. I Y=3 D SELRANG G EXIT1:$D(DUOUT)!$D(DTOUT)!'$D(^TMP("ACHSTXAR",$J)) G ^ACHSTXF1:ACHSTXTY="U" G ^ACHSTXA1
  1. D LINES^ACHSFU,HDR
  1. S ACHSCHSS=""
  1. D ^ACHSUF
  1. K ACHSCHSS
  1. S (J,ACHSEDT,ACHSBDT)=0,ACHSRR="",ACHSF638=$$PARM^ACHS(0,8)
  1. F I=2:1:7 S ACHSRTYP(I)=0
  1. W !?10,"FACILITY NAME: ",$$LOC^ACHS
  1. L1 ;
  1. I '$D(^ACHSTXST(DUZ(2),1,0)) W !!,*7,"NO DATA ON FILE FOR THIS FACILITY, JOB CANCELLED" G EXIT1
  1. S ACHS("MAX")=+$P($G(^ACHSTXST(DUZ(2),1,0)),U,4),ACHS("NUM")=10
  1. S:ACHS("MAX")<10 ACHS("NUM")=ACHS("MAX")
  1. S Y=$$DIR^XBDIR("NO^1:"_ACHS("MAX"),"ENTER NUMBER OF EXPORT ENTRIES TO DISPLAY ",ACHS("NUM"),"","ENTER A NUMBER BETWEEN 1 AND "_ACHS("MAX"),"",2)
  1. G L2:(Y=""),EXIT1:$D(DUOUT)!$D(DTOUT)
  1. S ACHS("NUM")=+Y
  1. L2 ;
  1. S (ACHSR,ACHSRR)=0,ACHSLCAT=0
  1. D HDR1
  1. L3 ;
  1. S ACHSR=$O(^ACHSTXST("AC",DUZ(2),ACHSR))
  1. G L4:ACHSR=""
  1. S ACHSRR=$O(^ACHSTXST("AC",DUZ(2),ACHSR,""))
  1. G L3:ACHSRR=""
  1. S ACHSLCAT=ACHSLCAT+1,X=^ACHSTXST(DUZ(2),1,ACHSRR,0),X1=$$FMTE^XLFDT($P(X,U)),X2=$$FMTE^XLFDT($P(X,U,2)),X3=$$FMTE^XLFDT($P(X,U,3)),ACHS(ACHSLCAT)=ACHSRR
  1. W $J(ACHSLCAT,4),?10,X1,?25,X2,?40,X3,?55,$J($P(X,U,5),5),!
  1. I ACHSLCAT+1>ACHS("NUM") G L4
  1. I '(ACHSLCAT#10) W:$$DIR^XBDIR("E","'^' TO STOP ") "" G:$D(DUOUT) L4 D HDR1
  1. G L3
  1. ;
  1. L4 ;
  1. I 'ACHSLCAT G NORECDS^ACHSTX8
  1. S Y=$$DIR^XBDIR("N^1:"_ACHSLCAT,"ENTER ITEM # FOR EXPORT DATE","","","","",2)
  1. G NORECDS^ACHSTX8:$D(DUOUT)!$D(DTOUT)
  1. S ACHS("REXNUM")=ACHS(+Y)
  1. W *7,!!!?15,"*******************NOTICE******************",!?15,"The number of records in this re-export",!?15,"might differ from the number in the original.",!?15,"*******************************************",!!
  1. D KILLGLBS^ACHSTX
  1. I ACHSTXTY="U" G ^ACHSTXF1
  1. S ACHSBDT=$P($G(^ACHSTXST(DUZ(2),1,ACHS("REXNUM"),0)),U,2)
  1. S ACHSBDT=ACHSBDT-1
  1. S ACHSEDT=$P($G(^ACHSTXST(DUZ(2),1,ACHS("REXNUM"),0)),U,3)
  1. K ACHS("MAX"),ACHS("NUM"),ACHSLCAT,ACHSR,ACHSRR,X1,X2,X3
  1. G S2^ACHSTX2
  1. ;
  1. HDR1 ;
  1. W !!,"ITM #",?10,"EXPORT DATE",?25,"BEG DATE",?40,"END DATE",?55,"# RECORDS",!!
  1. Q
  1. ;
  1. HDR ;
  1. U IO(0)
  1. W @IOF,!,ACHS("*"),!?22,"GENERATE PREVIOUS CHS TRANSMISSION DATA",!,ACHS("*"),!
  1. Q
  1. ;
  1. EXIT1 ;
  1. U IO(0)
  1. W !!,"JOB CANCELLED BY OPERATOR"
  1. D KILL^ACHSTX8
  1. Q
  1. ;
  1. SELDOC ; Select transactions from particular documents for export.
  1. K ^TMP("ACHSTXAR",$J)
  1. N D,T
  1. F D ^ACHSUD Q:$D(DUOUT)!$D(DTOUT)!'$D(ACHSDIEN) D Q:%>101
  1. . S T=$$SELTRANS(ACHSDIEN)
  1. . I $D(DUOUT)!$D(DTOUT)!'T S %=102 Q
  1. . I $P(T,U,2)="-" S T=$P(T,U,1) K ^TMP("ACHSTXAR",$J,$P(^ACHSF(DUZ(2),"D",ACHSDIEN,"T",T,0),U),ACHSDIEN,T)
  1. . E S ^TMP("ACHSTXAR",$J,$P(^ACHSF(DUZ(2),"D",ACHSDIEN,"T",T,0),U),ACHSDIEN,T)=""
  1. . ;Sel Doc Index
  1. . S (%,ACHSSDI)=0
  1. . W !!,"The list now consists of the following transactions:"
  1. . F S ACHSSDI=$O(^TMP("ACHSTXAR",$J,ACHSSDI)) Q:'ACHSSDI S D=0 F S D=$O(^TMP("ACHSTXAR",$J,ACHSSDI,D)) Q:'D S T=0 F S T=$O(^TMP("ACHSTXAR",$J,ACHSSDI,D,T)) Q:'T D
  1. .. ;
  1. .. S %=%+1
  1. .. W !,$J(%,2),". ",$P(^ACHSF(DUZ(2),"D",D,0),U,14),"-",$$FC^ACHS(DUZ(2)),"-",$P(^ACHSF(DUZ(2),"D",D,0),U,1)
  1. .. D DISTRANS(D,T)
  1. ..Q
  1. . I %=101 S %=102
  1. .Q
  1. K ACHSDIEN
  1. I $$DIR^XBDIR("E")
  1. Q
  1. ;
  1. SELRANG ; Select Document range only Initial transactions.
  1. K ^TMP("ACHSTXAR",$J)
  1. N D,T
  1. S SEL=1
  1. BEGDOC ;
  1. W !!!,"ENTER THE BEGINNING DOCUMENT NUMBER"
  1. D ^ACHSUD Q:$D(DUOUT)!$D(DTOUT)!'$D(ACHSDIEN)
  1. S ACHSEDOC(SEL,"B")=ACHSDIEN_"^"_$E(X,1,2)_"-"_ACHSFC_"-"_$E(X,3,7)_"^"_X_"^"_$P(Y(0),U,27)_$E(X,3,7)
  1. ENDDOC ;
  1. W !!!,"ENTER THE ENDING DOCUMENT NUMBER"
  1. D ^ACHSUD G:$D(DUOUT)!$D(DTOUT)!'$D(ACHSDIEN) BEGDOC
  1. I $P(Y(0),U,27)_$E(X,3,7)<$P(ACHSEDOC(SEL,"B"),U,4) W !!,"*****Document selected is not after beginning Document.*****" G ENDDOC
  1. S ACHSEDOC(SEL,"E")=ACHSDIEN_"^"_$E(X,1,2)_"-"_ACHSFC_"-"_$E(X,3,7)_"^"_X_"^"_$P(Y(0),U,27)_$E(X,3,7)
  1. ;ANOTHER DOC RANGE?
  1. S %=$$DIR^XBDIR("Y","Add additional Documents","N","","","",2)
  1. I Y S SEL=SEL+1 G BEGDOC
  1. Q:$D(DUOUT)
  1. SETRTR ;SET TRANS FOR DOCUMENT RANGE
  1. F L=1:1:SEL D
  1. .S BEGDOC=$P(ACHSEDOC(L,"B"),U,3)-1,ENDDOC=$P(ACHSEDOC(L,"E"),U,3)
  1. .I $P(ACHSEDOC(L,"B"),U,3)>$P(ACHSEDOC(L,"E"),U,3) D
  1. ..F S BEGDOC=$O(^ACHSF(DUZ(2),"D","B",BEGDOC)) Q:BEGDOC'?1N.N D SETRTR1
  1. ..S BEGDOC=1000000 F S BEGDOC=$O(^ACHSF(DUZ(2),"D","B",BEGDOC)) Q:(BEGDOC>ENDDOC)!(BEGDOC'?1N.N) D SETRTR1
  1. .E F S BEGDOC=$O(^ACHSF(DUZ(2),"D","B",BEGDOC)) Q:(BEGDOC>ENDDOC)!(BEGDOC'?1N.N) D SETRTR1
  1. ;DISPLAY Doc Index
  1. N ACHSQ S (%,ACHSSDI,ACHSQ)=0
  1. W !!,"The list now consists of the following transactions:"
  1. F S ACHSSDI=$O(^TMP("ACHSTXAR",$J,ACHSSDI)) Q:'ACHSSDI D Q:ACHSQ
  1. .S D=0 F S D=$O(^TMP("ACHSTXAR",$J,ACHSSDI,D)) Q:'D S T=0 Q:ACHSQ F S T=$O(^TMP("ACHSTXAR",$J,ACHSSDI,D,T)) Q:'T D Q:ACHSQ
  1. .. S %=%+1
  1. .. W !,$J(%,2),". ",$P(^ACHSF(DUZ(2),"D",D,0),U,14),"-",$$FC^ACHS(DUZ(2)),"-",$P(^ACHSF(DUZ(2),"D",D,0),U,1)
  1. .. D DISTRANS(D,T)
  1. .. I %#25=0 S:'$$DIR^XBDIR("E") ACHSQ=1
  1. K ACHSDIEN,BEGDOC,ENDDOC,ACHSEDOC,L,SEL
  1. W !!,"CONTINUE TO EXPORT RECORDS"
  1. I $$DIR^XBDIR("E")
  1. Q
  1. SETRTR1 ;SET DOC TRANS IN TEMP
  1. S ACHSDIEN=0,ACHSDIEN=$O(^ACHSF(DUZ(2),"D","B",BEGDOC,ACHSDIEN))
  1. S ^TMP("ACHSTXAR",$J,$P(^ACHSF(DUZ(2),"D",ACHSDIEN,"T",1,0),U),ACHSDIEN,1)=""
  1. Q
  1. ;
  1. SELTRANS(D) ; Display trans of doc D, and allow selection.
  1. D HELP("H1")
  1. N C,T
  1. W !!?10,"----------------------------------------------------",!?10,"TRANS",?30,"TRANS",!?11,"NUM",?19,"D A T E",?30,"TYPE",?40,"AMOUNT",!?10,"----------------------------------------------------",!!
  1. S (C,T)=0
  1. F S T=$O(^ACHSF(DUZ(2),"D",D,"T",T)) Q:+T=0 S Y=^(T,0),C=C+1,C(C)=T W !?10,$J(C,3) D DISTRANS(D,T)
  1. S Y=$$DIR^XBDIR("N^-"_C_":"_C,"Re-export which transaction","1","","Enter the number corresponding to the transaction you want re-exported","^D HELP^ACHSTXAR(""H1"")",2)
  1. Q:$D(DUOUT)!$D(DTOUT)!(Y=0) 0
  1. I Y<1 Q C(-1*Y)_"^-"
  1. Q C(Y)
  1. ;
  1. DISTRANS(D,T) ;
  1. S Y=^ACHSF(DUZ(2),"D",D,"T",T,0)
  1. W ?17,$$FMTE^XLFDT($P(Y,U,1)),?32,$P(Y,U,2),$P(Y,U,5),?35,$J($FN($P(Y,U,4),",",2),11)," <",$$EXTSET^XBFUNC(9002080.02,1,$P(Y,U,2)),">"
  1. Q
  1. ;
  1. HELP(L) ;EP - Display text at label L.
  1. W !
  1. F %=1:1 W !?4,$P($T(@L+%),";",3) Q:$P($T(@L+%+1),";",3)="###"
  1. Q
  1. ;
  1. H ;
  1. ;;Selection of individual documents is intended to allow the local
  1. ;;service unit to clear documents that are not processing at higher
  1. ;;levels.
  1. ;;
  1. ;;E.g., if an FI document is PEND'ing for no obligation (P259), the
  1. ;;S.U. may want to selectively re-export the initial obligation
  1. ;;transaction of the document.
  1. ;;
  1. ;;Re-export the pay transaction will not export
  1. ;;"ZA" and "IP" transactions.
  1. ;;
  1. ;;Option 3 is used to select export of only INITIAL transactions,
  1. ;;using a document range.
  1. ;;
  1. ;;###
  1. ;
  1. H1 ;
  1. ;;Enter a number corresponding to the transaction that you want to re-export.
  1. ;;Enter a "-" before the number to remove the transaction from the list.
  1. ;;###
  1. ;