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

ECXPURG1.m

Go to the documentation of this file.
  1. ECXPURG1 ;BIR/CML-Purge of DSS Extract Files (CONTINUED) ;8/20/13 11:04
  1. ;;3.0;DSS EXTRACTS;**2,9,8,24,49,102,112,144**;Dec 22, 1997;Build 9
  1. GET ;compile list of deletable extracts 144
  1. K HI,LO,ECBDT,ECEDT,ECLOC,^TMP("ECXPURG",$J)
  1. S QFLG=1 W !!,"...one moment please"
  1. S ECEX=0 F S ECEX=$O(^ECX(727,ECEX)) Q:'ECEX I '$G(^ECX(727,ECEX,"PURG")),$D(^ECX(727,ECEX,0)) S EC=^(0) D
  1. .S ^TMP("ECXPURG",$J,$P(EC,U,3),ECEX)="",ECLOC(ECEX)=$P(EC,U,3)_U_$P(EC,U,4,5)
  1. I '$D(^TMP("ECXPURG",$J)) W !!,"There are no extracts that can be deleted at this time." G DONE ;144
  1. ASK1 ;ask for print
  1. W !
  1. K DIR S DIR(0)="Y",DIR("A")="Do you want to print a list of extracts that can be deleted",DIR("B")="NO"
  1. D ^DIR K DIR I $D(DIRUT) K ECLOC G DONE
  1. G:'Y ASK2
  1. W !!,"The right margin for this report is 80.",!!
  1. K ZTSAVE S ZTSAVE("^TMP(""ECXPURG"",$J,")=""
  1. D EN^XUTMDEVQ("PRT^ECXPURG1","DSS - Print Deletable Extracts",.ZTSAVE) I 'POP G ASK2
  1. W !,"NO DEVICE SELECTED OR REPORT PRINTED!!"
  1. ASK2 ;ask for extract range
  1. ;
  1. ;** Check divisions for deleting
  1. N ECCHK,ECTMP,JZ ;144
  1. S ECCHK=$$DIV4^XUSER(.ECTMP,DUZ)
  1. I 'ECCHK DO
  1. .W !,"You do not have any divisions defined in your user set up and can not delete."
  1. .S DIR(0)="FAO^1:1",DIR("A")="Hit Return to continue." D ^DIR K DIR,X,Y
  1. .K ECLOC
  1. ;
  1. I 'ECCHK G DONE ;** (essentially) QUIT out of middle
  1. ;
  1. W !,"You will not be able to select an extract that is not from your division.",!
  1. S LO=$O(ECLOC(0)),HI=$O(ECLOC(" "),-1)
  1. S DIR(0)="L^"_LO_":"_HI_"",DIR("A")="Select extracts to be deleted"
  1. S DIR("?",1)="Choose the number(s) of the extract(s) you wish to delete,",DIR("?")="(e.g. 1-3,17,20 to choose 1 thru 3, 17, and 20)."
  1. W ! D ^DIR K DIR I $D(DIRUT) K ECLOC G DONE
  1. S JJ=0,Y=","_Y F S JJ=$O(ECLOC(JJ)) Q:'JJ S JZ=","_JJ_"," I Y'[JZ K ECLOC(JJ)
  1. I '$D(ECLOC) W !!,"You have not chosen a valid extract number. Try again." G GET ;144 Give message if no valid selection made
  1. D CBOCCHK(.ECLOC) I '$D(ECLOC) G GET
  1. D DIVCHK(.ECLOC,.ECTMP)
  1. I '$D(ECLOC) W !!,"You have not chosen a valid extract number. Try again." G GET
  1. ASK3 W !!,"I will delete the following extract(s):"
  1. S JJ=0 F S JJ=$O(ECLOC(JJ)) Q:'JJ D
  1. .W !?5,"#",JJ," - ",$P(ECLOC(JJ),U)
  1. .W ?47,$TR($$FMTE^XLFDT($P(ECLOC(JJ),U,2),"5DF")," ","0")," to ",$TR($$FMTE^XLFDT($P(ECLOC(JJ),U,3),"5DF")," ","0")
  1. W !! K DIR S DIR(0)="Y",DIR("A")="Is this OK",DIR("B")="NO"
  1. S DIR("?",1)=" Enter:"
  1. S DIR("?",2)=" ""YES"" if you agree with this list and would like to proceed,"
  1. S DIR("?",3)=" ""NO"" if you would like to make a different selection, or"
  1. S DIR("?")=" ""^"" to exit option."
  1. D ^DIR K DIR I $D(DIRUT) K ECLOC G DONE
  1. I 'Y G GET
  1. ; at this point, the local array ECLOC( is passed back to ^ECXPURG
  1. G DONE
  1. QUIT ;
  1. I $E(IOST)="C"&('QFLG) S DIR(0)="E" D D ^DIR K DIR
  1. .S SS=22-$Y F JJ=1:1:SS W !
  1. W:$E(IOST)'="C" @IOF D ^%ZISC S:$D(ZTQUEUED) ZTREQ="@"
  1. DONE K ^TMP("ECXPURG",$J),ZTSK Q
  1. PRT ;print list of extracts
  1. S (PG,QFLG)=0,$P(LN,"-",81)="" D NOW^%DTC S Y=$E(%,1,12) X ^DD("DD") S HDT=Y D HDR
  1. S ECTYP="" F S ECTYP=$O(^TMP("ECXPURG",$J,ECTYP)) Q:ECTYP="" Q:QFLG D:$Y+4>IOSL HDR Q:QFLG W !!,ECTYP D
  1. .S ECEX=0 F S ECEX=$O(^TMP("ECXPURG",$J,ECTYP,ECEX)) Q:'ECEX Q:QFLG I $D(^ECX(727,ECEX,0)) S EC=^(0) D
  1. ..S ECDT=$$FMTE^XLFDT($P(EC,U,2),"D")
  1. ..S ECFR=$TR($$FMTE^XLFDT($P(EC,U,4),"5DF")," ","0")
  1. ..S ECTO=$TR($$FMTE^XLFDT($P(EC,U,5),"5DF")," ","0")
  1. ..S ECRC=$P(EC,U,6) S:ECRC="" ECRC="Incomplete"
  1. ..S ECTRN=$$FMTE^XLFDT($G(^ECX(727,ECEX,"TR")),"D")
  1. ..S ECXDIV=$P($G(^ECX(727,ECEX,"DIV")),U,1) I ECXDIV D
  1. ...K ECXDIC S DA=ECXDIV,DIC="^DIC(4,",DIQ(0)="I",DIQ="ECXDIC",DR=".01;99"
  1. ...D EN^DIQ1 S ECXDIV=$G(ECXDIC(4,DA,99,"I")) K DIC,DIQ,DA,DR,ECXDIC
  1. ..D:$Y+3>IOSL HDR Q:QFLG
  1. ..W !?1,ECEX,?11,ECDT,?25,ECFR,"-",ECTO,?48,$J(ECRC,9),?60,ECTRN,?75,ECXDIV
  1. G QUIT
  1. HDR ;HEADER
  1. I $E(IOST)="C" S SS=22-$Y F JJ=1:1:SS W !
  1. I $E(IOST)="C",PG>0 S DIR(0)="E" W ! D ^DIR K DIR I 'Y S QFLG=1 Q
  1. S PG=PG+1 W:$Y!($E(IOST)="C") @IOF W !,"DELETABLE EXTRACTS",?72,"Page: ",PG,!,"Printed on ",HDT,!
  1. W !,"FEEDER SYS",?12,"EXTRACT,",!,"EXTRACT #",?12,"DATE",?33,"FROM-TO",?48,"RECORD CNT",?60,"TRANSMIT DATE",?75,"DIV",!,LN
  1. Q
  1. DATES ;ask for date range for purge of holding files
  1. K HI,LO,ECBDT,ECEDT
  1. I ECY="I" D
  1. .I '$O(^ECX(728.113,0)) W !!,"You have no data in the IVP holding file (file #728.113) to purge." Q
  1. .S LO=$O(^ECX(728.113,"A",0)),HI=$O(^ECX(728.113,"A"," "),-1)
  1. I ECY="U" D
  1. .I '$O(^ECX(728.904,0)) W !!,"You have no data in the UDP holding file (file #728.904) to purge." Q
  1. .S LO=$O(^ECX(728.904,"A",0)),HI=$O(^ECX(728.904,"A"," "),-1)
  1. I ECY="V" D
  1. .I '$O(^VBEC(6002.03,0)) W !!,"You have no data in the VBECS holding file (file #6002.03) to purge." Q
  1. .S LO=$O(^VBEC(6002.03,"C",0)),HI=$O(^VBEC(6002.03,"C"," "),-1)
  1. Q:$G(LO)=""
  1. W @IOF,!!,"This file currently holds ",$S(ECY="I":"IVP",ECY="U":"UDP",1:"VBECS")," data from <",$$FMTE^XLFDT(LO,"D"),"> to <",$$FMTE^XLFDT(HI,"D"),">."
  1. W ! K DIR S DIR(0)="DA^"_LO_":"_HI_":EPX",DIR("A")="Beginning date for purge: " D ^DIR K DIR I $D(DIRUT) K HI,LO Q
  1. S ECBDT=+Y
  1. K DIR S DIR(0)="DA^"_ECBDT_":"_HI_":EPX",DIR("A")="Ending date for purge: " D ^DIR K DIR I $D(DIRUT) K HI,LO,ECBDT Q
  1. S ECEDT=+Y
  1. ASK4 ; ask to confirm date range
  1. W !!,"I will purge the ",$S(ECY="I":"IVP",ECY="U":"UDP",1:"VBECS")," holding file from <",$$FMTE^XLFDT(ECBDT,"D"),"> to <",$$FMTE^XLFDT(ECEDT,"D"),">."
  1. W !! K DIR S DIR(0)="Y",DIR("A")="Is this OK",DIR("B")="NO"
  1. S DIR("?",1)=" Enter:"
  1. S DIR("?",2)=" ""YES"" if you agree with this date range and wish to proceed,"
  1. S DIR("?",3)=" ""NO"" if you would like to make a different selection, or"
  1. S DIR("?")=" ""^"" to exit option."
  1. D ^DIR K DIR I $D(DIRUT) K ECBDT,ECEDT Q
  1. I 'Y G DATES
  1. ; at this point, ECBDT and ECEDT are passed back to ^ECXPURG
  1. Q
  1. ;
  1. DIVCHK(ECLOC,ECTMP) ;**Remove extracts from ECLOC that are for user's div.
  1. N ECLPDA
  1. S ECLPDA=0
  1. F S ECLPDA=$O(ECLOC(ECLPDA)) Q:(+ECLPDA=0) DO
  1. .I '$D(ECTMP($P(^ECX(727,ECLPDA,"DIV"),U,1))) KILL ECLOC(ECLPDA)
  1. Q
  1. CBOCCHK(ECLOC) ;**Check that CBOC report has been viewed prior to deleting
  1. N LOOPDA,YYYMMDD
  1. S LOOPDA=0
  1. F S LOOPDA=$O(ECLOC(LOOPDA)) Q:(+LOOPDA=0) D
  1. .I ^ECX(727,LOOPDA,"HEAD")="CLI" D
  1. ..S DA(1)=1
  1. ..S YYYMMDD=$P(^ECX(727,LOOPDA,0),U,4)
  1. ..I YYYMMDD>3030930 I '$D(^ECX(728,DA(1),"CBOC","B",LOOPDA)) D
  1. ...K DIR S DIR(0)="Y",DIR("A")="The CBOC Activity Report has not been viewed. Delete anyway",DIR("B")="NO" ;144
  1. ...D ^DIR K DIR I 'Y K ECLOC(LOOPDA)
  1. Q