- 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 Jan 18, 2025@02:55:30 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