EASECSCR ;ALB/LBD - LTC Co-Pay Test Screen Read Processor;10 AUG 2001
;;1.0;ENROLLMENT APPLICATION SYSTEM;**5,40**;Mar 15, 2001
;
;NOTE: This routine was modified from DGMTSCR for LTC Co-pay
; Input -- DGRNG Range of selectable items
; DGMTACT Means Test Action
; DGMTSC Screen Driver Array
; DGMTSCI Screen number
; DGVINI Veteran Individual Annual Income IEN
; DGVIRI Veteran Income Relation IEN
; Output -- DGDR Template tags (ie, 101,102,103,104)
; DGX User input - maybe modified (ie, 1-4)
; DGY Items selected in expanded form (ie, 1,2,3,4)
; Returned for screen 2 and 4:
; DGSEL Column selections available (ie, V, S, C)
; DGSELTY User input - column selected (ie, V or S or C)
;
EN K DGDR,DGSEL,DGSELTY,DGX,DGY,I D FEED
I $G(DGSCR1) S X="" G EN1
W !,DGVI,"<RET>",DGVO," to CONTINUE," W:DGMTACT'="VEW" " ",DGVI,DGRNG,DGVO," or ",DGVI,"'ALL' ",DGVO,"to EDIT," W DGVI," ^N",DGVO," for screen N, or ",DGVI,"'^'",DGVO," to EXIT: " R X:DTIME S:'$T X="^"
EN1 K DGSCR1 S DGX=$$UPPER^DGUTL(X)
I DGX="^" G Q^EASECSC
I DGX?1"^".N,$D(DGMTSC(+$P(DGX,"^",2))) G @($$ROU^EASECSCU(+$P(DGX,"^",2)))
; Modified next line to allow entry of assets for spouse (only for new
; 10-10EC form). Added for LTC Phase IV (EAS*1*40)
I DGMTACT'="VEW",(DGMTSCI=5!($G(DGFORM)&(DGMTSCI=4))) D SEL I DGSEL[$E(DGX),$E(DGX,2)?1N S DGSELTY=$E(DGX),DGX=$P(DGX,DGSELTY,2)
I DGMTACT'="VEW",$E(DGX)="A" S X=DGX,Z="^ALL" D IN^DGHELP S:%'=-1 DGX=DGRNG
I DGX["?" D HLP G Q^EASECSC:$D(DTOUT)!($D(DUOUT)),@($$ROU^EASECSCU(DGMTSCI))
I DGX="",$O(DGMTSC(DGMTSCI)) G @($$ROU^EASECSCU($O(DGMTSC(DGMTSCI))))
I DGX="" G Q^EASECSC
I DGMTACT'="VEW" D PRO I $D(DGSELTY) S DGX=DGSELTY_DGX
S:DGMTACT="VEW" DGERR=1 I DGERR D HLP G @($$ROU^EASECSCU(DGMTSCI))
Q G @($$ROURET^EASECSCU(DGMTSCI))
;
FEED ;Line feed to the bottom of the screen
N DGB,I
S DGB=$S('IOSL:24,1:IOSL)-5 F I=$Y:1:DGB W !
Q
;
SEL ;Check available column selections for Veteran, Spouse or Children
N DGDC,DGNC,DGND,DGSP,DGVIR0,DGX
D DEP^EASECSU3
S DGSEL="V"_$S(DGSP:"S",1:"")
SELQ Q
;
HLP ;Help display
N DGIOM,DGLNE,DGMTSCR,DIR,I,X
S DGHLPF=1 D HD^EASECSCU
W !!,"Enter <RET> to continue to the next available screen."
I DGMTACT'="VEW" W !,"Enter an available item number from ",DGRNG," to edit.",!,"The items should be separated by commas or a range of numbers",!,"separated by a dash, or a combination of commas and dashes."
;Modified next line to add screen 4 for LTC Phase IV (EAS*1*40)
I DGMTACT'="VEW","^4^5^"[(U_DGMTSCI_U),$D(DGSEL) W !,"To edit a specific column, enter 'V'",$S(DGSEL["S":", 'S'",1:"")," in front of the selected items."
I DGMTACT'="VEW" W !,"Enter 'ALL' to edit all available items on the screen."
W !,"Enter '^N' to jump to a select screen. Enter '^' to exit."
W !!,"AVAILABLE SCREENS"
S I=0 F S I=$O(DGMTSC(I)) Q:'I W !,"[",+$$SCR^EASECSCU(I),"] ",$P($$SCR^EASECSCU(I),";",2)
S DGLNE="",DGIOM=$S('IOM:80,1:IOM),$P(DGLNE,"=",(DGIOM-1))=""
W !,DGLNE S DIR(0)="E" D ^DIR
Q
;
PRO ;Process user selection; cnt - dash - parse - selection
N DGC,DGD,DGP,DGS
S DGC=0,DGERR=0,DGY="",DGDR=""
PARSE S DGC=DGC+1,DGP=$P(DGX,",",DGC) G PROQ:DGP=""
I DGP?.N1"-".N S DGD="" F DGS=$P(DGP,"-"):1:$P(DGP,"-",2) D CHK Q:DGERR
I '$D(DGD) S DGS=DGP D CHK
K DGD G PROQ:DGERR,PARSE
PROQ Q
;
CHK I $D(DGD),+$P(DGP,"-",2)<+$P(DGP,"-",1) S DGERR=1
I 'DGERR,DGS'?.N S DGERR=1
I 'DGERR&(DGS>$P(DGRNG,"-",2)!(DGS<$P(DGRNG,"-"))) S DGERR=1
I 'DGERR S DGY=DGY_$S($L(DGY):",",1:"")_DGS,DGDR=DGDR_$S($L(DGDR):",",1:"")_(DGS+100)
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HEASECSCR 3709 printed Oct 16, 2024@17:55:03 Page 2
EASECSCR ;ALB/LBD - LTC Co-Pay Test Screen Read Processor;10 AUG 2001
+1 ;;1.0;ENROLLMENT APPLICATION SYSTEM;**5,40**;Mar 15, 2001
+2 ;
+3 ;NOTE: This routine was modified from DGMTSCR for LTC Co-pay
+4 ; Input -- DGRNG Range of selectable items
+5 ; DGMTACT Means Test Action
+6 ; DGMTSC Screen Driver Array
+7 ; DGMTSCI Screen number
+8 ; DGVINI Veteran Individual Annual Income IEN
+9 ; DGVIRI Veteran Income Relation IEN
+10 ; Output -- DGDR Template tags (ie, 101,102,103,104)
+11 ; DGX User input - maybe modified (ie, 1-4)
+12 ; DGY Items selected in expanded form (ie, 1,2,3,4)
+13 ; Returned for screen 2 and 4:
+14 ; DGSEL Column selections available (ie, V, S, C)
+15 ; DGSELTY User input - column selected (ie, V or S or C)
+16 ;
EN KILL DGDR,DGSEL,DGSELTY,DGX,DGY,I
DO FEED
+1 IF $GET(DGSCR1)
SET X=""
GOTO EN1
+2 WRITE !,DGVI,"<RET>",DGVO," to CONTINUE,"
if DGMTACT'="VEW"
WRITE " ",DGVI,DGRNG,DGVO," or ",DGVI,"'ALL' ",DGVO,"to EDIT,"
WRITE DGVI," ^N",DGVO," for screen N, or ",DGVI,"'^'",DGVO," to EXIT: "
READ X:DTIME
if '$TEST
SET X="^"
EN1 KILL DGSCR1
SET DGX=$$UPPER^DGUTL(X)
+1 IF DGX="^"
GOTO Q^EASECSC
+2 IF DGX?1"^".N
IF $DATA(DGMTSC(+$PIECE(DGX,"^",2)))
GOTO @($$ROU^EASECSCU(+$PIECE(DGX,"^",2)))
+3 ; Modified next line to allow entry of assets for spouse (only for new
+4 ; 10-10EC form). Added for LTC Phase IV (EAS*1*40)
+5 IF DGMTACT'="VEW"
IF (DGMTSCI=5!($GET(DGFORM)&(DGMTSCI=4)))
DO SEL
IF DGSEL[$EXTRACT(DGX)
IF $EXTRACT(DGX,2)?1N
SET DGSELTY=$EXTRACT(DGX)
SET DGX=$PIECE(DGX,DGSELTY,2)
+6 IF DGMTACT'="VEW"
IF $EXTRACT(DGX)="A"
SET X=DGX
SET Z="^ALL"
DO IN^DGHELP
if %'=-1
SET DGX=DGRNG
+7 IF DGX["?"
DO HLP
if $DATA(DTOUT)!($DATA(DUOUT))
GOTO Q^EASECSC
GOTO @($$ROU^EASECSCU(DGMTSCI))
+8 IF DGX=""
IF $ORDER(DGMTSC(DGMTSCI))
GOTO @($$ROU^EASECSCU($ORDER(DGMTSC(DGMTSCI))))
+9 IF DGX=""
GOTO Q^EASECSC
+10 IF DGMTACT'="VEW"
DO PRO
IF $DATA(DGSELTY)
SET DGX=DGSELTY_DGX
+11 if DGMTACT="VEW"
SET DGERR=1
IF DGERR
DO HLP
GOTO @($$ROU^EASECSCU(DGMTSCI))
Q GOTO @($$ROURET^EASECSCU(DGMTSCI))
+1 ;
FEED ;Line feed to the bottom of the screen
+1 NEW DGB,I
+2 SET DGB=$SELECT('IOSL:24,1:IOSL)-5
FOR I=$Y:1:DGB
WRITE !
+3 QUIT
+4 ;
SEL ;Check available column selections for Veteran, Spouse or Children
+1 NEW DGDC,DGNC,DGND,DGSP,DGVIR0,DGX
+2 DO DEP^EASECSU3
+3 SET DGSEL="V"_$SELECT(DGSP:"S",1:"")
SELQ QUIT
+1 ;
HLP ;Help display
+1 NEW DGIOM,DGLNE,DGMTSCR,DIR,I,X
+2 SET DGHLPF=1
DO HD^EASECSCU
+3 WRITE !!,"Enter <RET> to continue to the next available screen."
+4 IF DGMTACT'="VEW"
WRITE !,"Enter an available item number from ",DGRNG," to edit.",!,"The items should be separated by commas or a range of numbers",!,"separated by a dash, or a combination of commas and dashes."
+5 ;Modified next line to add screen 4 for LTC Phase IV (EAS*1*40)
+6 IF DGMTACT'="VEW"
IF "^4^5^"[(U_DGMTSCI_U)
IF $DATA(DGSEL)
WRITE !,"To edit a specific column, enter 'V'",$SELECT(DGSEL["S":", 'S'",1:"")," in front of the selected items."
+7 IF DGMTACT'="VEW"
WRITE !,"Enter 'ALL' to edit all available items on the screen."
+8 WRITE !,"Enter '^N' to jump to a select screen. Enter '^' to exit."
+9 WRITE !!,"AVAILABLE SCREENS"
+10 SET I=0
FOR
SET I=$ORDER(DGMTSC(I))
if 'I
QUIT
WRITE !,"[",+$$SCR^EASECSCU(I),"] ",$PIECE($$SCR^EASECSCU(I),";",2)
+11 SET DGLNE=""
SET DGIOM=$SELECT('IOM:80,1:IOM)
SET $PIECE(DGLNE,"=",(DGIOM-1))=""
+12 WRITE !,DGLNE
SET DIR(0)="E"
DO ^DIR
+13 QUIT
+14 ;
PRO ;Process user selection; cnt - dash - parse - selection
+1 NEW DGC,DGD,DGP,DGS
+2 SET DGC=0
SET DGERR=0
SET DGY=""
SET DGDR=""
PARSE SET DGC=DGC+1
SET DGP=$PIECE(DGX,",",DGC)
if DGP=""
GOTO PROQ
+1 IF DGP?.N1"-".N
SET DGD=""
FOR DGS=$PIECE(DGP,"-"):1:$PIECE(DGP,"-",2)
DO CHK
if DGERR
QUIT
+2 IF '$DATA(DGD)
SET DGS=DGP
DO CHK
+3 KILL DGD
if DGERR
GOTO PROQ
GOTO PARSE
PROQ QUIT
+1 ;
CHK IF $DATA(DGD)
IF +$PIECE(DGP,"-",2)<+$PIECE(DGP,"-",1)
SET DGERR=1
+1 IF 'DGERR
IF DGS'?.N
SET DGERR=1
+2 IF 'DGERR&(DGS>$PIECE(DGRNG,"-",2)!(DGS<$PIECE(DGRNG,"-")))
SET DGERR=1
+3 IF 'DGERR
SET DGY=DGY_$SELECT($LENGTH(DGY):",",1:"")_DGS
SET DGDR=DGDR_$SELECT($LENGTH(DGDR):",",1:"")_(DGS+100)
+4 QUIT