Annotation of freem_fileman/DDSVALF.m, revision 1.1

1.1     ! snw         1: DDSVALF        ;SFISC/MKO-GET,PUT VALUES FOR FORM ONLY FIELDS ;09:01 AM  12 Dec 1994
        !             2:        ;;21.0;VA FileMan;;Dec 28, 1994
        !             3:        ;Per VHA Directive 10-93-142, this routine should not be modified.
        !             4:        ;
        !             5: GET(DDSVFD,DDSVBK,DDSVPG,DDSPARM,DDSVDA)       ;Get value
        !             6:        ;In:  DDSPG = Current page
        !             7:        ;     DDSBK = Current block
        !             8:        ;     DDSPARM = "I" : internal, "E" : external form
        !             9:        ;
        !            10:        N DDSANS,DDSFLD,DDSVDDP
        !            11:        K DIERR,^TMP("DIERR",$J)
        !            12:        I $D(DDSPG)[0 N DDSPG S DDSPG=0
        !            13:        I $D(DDSBK)[0 N DDSBK S DDSBK=0
        !            14:        S DDSANS=""
        !            15:        I $G(DDSPARM)'["I",$G(DDSPARM)'["E" S DDSPARM=$G(DDSPARM)_"I"
        !            16:        ;
        !            17:        S DDSFLD=$P($$GETFLD^DDSLIB($G(DDSVFD),$G(DDSVBK),$G(DDSVPG),DDS,$G(DDSPG),$G(DDSBK),"F"),",",1,2)
        !            18:        G:$G(DIERR) GETQ
        !            19:        ;
        !            20:        S DDSVFD=+DDSFLD,DDSVBK=+$P(DDSFLD,",",2)
        !            21:        ;
        !            22:        S DDSVDDP=+$P($G(^DIST(.404,DDSVBK,0)),U,2)
        !            23:        I DDSVDDP,$G(DDSVDA)]"" N DDSDA S DDSDA=DDSVDA
        !            24:        E  I DDSVDDP,DDSVBK'=DDSBK N DDSDA D GL^DDS10(DDSVDDP,.DDSDAORG,"","",.DDSDA)
        !            25:        ;
        !            26:        I $D(@DDSREFT@("F0",DDSDA,DDSFLD,"D"))#2 S DDSANS=^("D") S:DDSPARM["E"&($D(^("X"))#2) DDSANS=^("X") G GETQ
        !            27:        ;
        !            28:        I "^1^3^"[(U_$P(^DIST(.404,DDSVBK,40,DDSVFD,0),U,3)_U) D BLD^DIALOG(520,"DD or caption-only") G GETQ
        !            29:        ;
        !            30:        ;Form-only fields
        !            31:        I $P($G(^DIST(.404,DDSVBK,40,DDSVFD,0)),U,3)=2 D  G:$G(DIERR) GETQ
        !            32:        . I $P($G(^DIST(.404,DDSVBK,40,DDSVFD,20)),U)="" D  Q
        !            33:        .. N P S P(1)="READ TYPE",P(2)="FIELD multiple of the BLOCK"
        !            34:        .. D BLD^DIALOG(3011,.P)
        !            35:        . D:$D(^DIST(.404,DDSVBK,40,DDSVFD,3))#2 DEF(^(3),$G(^(3.1)),.DDSANS)
        !            36:        . S (@DDSREFT@("F0",DDSDA,DDSFLD,"D"),^("O"))=DDSANS
        !            37:        . I DDSANS]"" D
        !            38:        .. S:$D(DDSANS(0)) (DDSANS,@DDSREFT@("F0",DDSDA,DDSFLD,"X"))=$S($D(DDSANS(0,0))#2:DDSANS(0,0),1:DDSANS(0))
        !            39:        .. S $P(@DDSREFT@("F0",DDSDA,DDSFLD,"F"),U)=3,DDSCHG=1
        !            40:        ;
        !            41:        ;Computed fields
        !            42:        E  S:$P($G(^DIST(.404,DDSVBK,40,DDSVFD,0)),U,3)=4 DDSANS=$$VAL^DDSCOMP(DDSVFD,DDSVBK,DDSDA)
        !            43:        ;
        !            44: GETQ   D:$G(DIERR) ERR^DDSVALM("$$GET^DDSVALF")
        !            45:        Q DDSANS
        !            46:        ;
        !            47: PUT(DDSVFD,DDSVBK,DDSVPG,DDSVAL,DDSPARM,DDSVDA)        ;Put value
        !            48:        N DIR,X,Y
        !            49:        N DDER,DDSFLD,DDSVDDP,DDSVX
        !            50:        K DIERR,^TMP("DIERR",$J)
        !            51:        I $D(DDSPG)[0 N DDSPG S DDSPG=0
        !            52:        I $D(DDSBK)[0 N DDSBK S DDSBK=0
        !            53:        S:$D(DDSVAL)[0 DDSVAL=""
        !            54:        I $G(DDSPARM)'["I",$G(DDSPARM)'["E" S DDSPARM=$G(DDSPARM)_"E"
        !            55:        ;
        !            56:        S DDSFLD=$$GETFLD^DDSLIB($G(DDSVFD),$G(DDSVBK),$G(DDSVPG),DDS,DDSPG,DDSBK,"F")
        !            57:        G:$G(DIERR) PUTQ
        !            58:        S DDSVFD=+DDSFLD,DDSVBK=+$P(DDSFLD,",",2),DDSVPG=$P(DDSFLD,",",3)
        !            59:        S DDSFLD=$P(DDSFLD,",",1,2)
        !            60:        ;
        !            61:        S DDSVDDP=+$P($G(^DIST(.404,DDSVBK,0)),U,2)
        !            62:        I DDSVDDP,$G(DDSVDA)]"" N DDSDA S DDSDA=DDSVDA
        !            63:        E  I DDSVDDP,DDSVBK'=DDSBK N DDSDA D GL^DDS10(DDSVDDP,.DDSDAORG,"","",.DDSDA)
        !            64:        ;
        !            65:        ;
        !            66:        I $P(^DIST(.404,DDSVBK,40,DDSVFD,0),U,3)'=2 D BLD^DIALOG(520,"DD, computed, or caption-only") G PUTQ
        !            67:        ;
        !            68:        S DIR(0)=$P(^DIST(.404,DDSVBK,40,DDSVFD,20),U)_$P(^(20),U,2,3)
        !            69:        I DDSPARM["I",$E(DIR(0))="P"!(DIR(0)?1"DD".E) D
        !            70:        . N FIL,FLD
        !            71:        . S Y=DDSVAL
        !            72:        . I $E(DIR(0))="P" D
        !            73:        .. S FIL=+$P($G(@(U_$P($P(DIR(0),U,2),":")_"0)")),U,2) Q:'FIL
        !            74:        .. S Y(0)=$$EXTERNAL^DILFD(FIL,.01,"",Y)
        !            75:        . E  D
        !            76:        .. N DV,I S FIL=$P($P(DIR(0),","),U,2),FLD=$P(DIR(0),",",2)
        !            77:        .. S DV=$P($G(^DD(FIL,FLD,0)),U,2)
        !            78:        .. F I="O","P","V","D","S" I DV[I S Y(0)=$$EXTERNAL^DILFD(FIL,FLD,"",Y) Q
        !            79:        E  D  G:$G(DDER) PUTQ
        !            80:        . I DDSVAL="" D  Q
        !            81:        .. N DDSVREQ
        !            82:        .. S DDSVREQ=$P($G(@DDSREFT@(DDSVPG,DDSVBK,DDSVFD)),U)
        !            83:        .. S:DDSVREQ]"" DDSVREQ=$P($G(^DIST(.404,DDSVBK,40,DDSVFD,4)),U)
        !            84:        .. I DDSVREQ S DDER=1
        !            85:        .. E  S Y=""
        !            86:        . S DIR("V")="",(X,DIR("B"))=DDSVAL
        !            87:        . S:DIR(0)?1"DD".E DIR(0)=$P(DIR(0),U,2,999)
        !            88:        . I $P(DIR(0),U)["P",$P($P(DIR(0),U,2),":",2)'["Z" D
        !            89:        .. N I
        !            90:        .. S I=$P(DIR(0),U,2) Q:$P(I,":",2)["Z"
        !            91:        .. S $P(I,":",2)=$P(I,":",2)_"Z"
        !            92:        .. S $P(DIR(0),U,2)=I
        !            93:        . D ^DIR
        !            94:        . I $E($P(DIR(0),U))="P" S Y=$P(Y,U)
        !            95:        ;
        !            96:        ;Update ^TMP
        !            97:        S DDSCHG=1
        !            98:        S (DDSVX,@DDSREFT@("F0",DDSDA,DDSFLD,"D"))=Y,^("F")=3 S:$D(Y(0))#2 (DDSVX,^("X"))=$S($D(Y(0,0))#2:Y(0,0),1:Y(0)) I $D(^("X"))#2,Y="" S (DDSVX,^("X"))=""
        !            99:        ;
        !           100:        ;Repaint field if it appears on the current page
        !           101:        I $D(@DDSREFS@("F0",DDSFLD,"L",DDSPG,DDSVBK,DDSVFD))#2 D
        !           102:        . N DY,DX,DDSVL,DDSVRJ,DDSX
        !           103:        . S DY=+@DDSREFS@(DDSPG,DDSVBK,DDSVFD,"D"),DX=$P(^("D"),U,2),DDSVL=$P(^("D"),U,3),DDSVRJ=$P(^("D"),U,10)
        !           104:        . S:$D(DDSREP)#2 DY=DY+$P(DDSREP,U,3)-1
        !           105:        . S DDSX=$P(DDGLVID,DDGLDEL)_$E(DDSVX,1,DDSVL)_$P(DDGLVID,DDGLDEL,10)
        !           106:        . X IOXY
        !           107:        . W $S(DDSVRJ:$J("",DDSVL-$L(DDSVX))_DDSX,1:DDSX_$J("",DDSVL-$L(DDSVX)))
        !           108:        ;
        !           109:        D
        !           110:        . N DDP,DDSDA S DDP=0,DDSDA="0,"
        !           111:        . D:$D(@DDSREFS@("PT",DDP,DDSFLD)) RPB^DDS7(DDP,DDSFLD,DDSPG)
        !           112:        . D:$D(@DDSREFS@("COMP",DDP,DDSFLD,DDSPG)) RPCF^DDSCOMP(DDSPG)
        !           113:        ;
        !           114: PUTQ   D:$G(DIERR) ERR^DDSVALM("PUT^DDSVALF")
        !           115:        Q
        !           116:        ;
        !           117: DEF(DDSLN3,DDSLN31,Y)  ;Get default
        !           118:        N DDER,DIR,X
        !           119:        Q:DDSLN3=""
        !           120:        ;
        !           121:        I DDSLN3'="!M" S Y=DDSLN3
        !           122:        E  I DDSLN31'?."^" X DDSLN31 S:$D(Y)[0 Y=""
        !           123:        Q:Y=""
        !           124:        ;
        !           125:        S DIR(0)=$P(^DIST(.404,DDSVBK,40,DDSVFD,20),U)_$P(^(20),U,2,3)
        !           126:        S:DIR(0)?1"DD".E DIR(0)=$P(DIR(0),U,2,999)
        !           127:        S DIR("V")="",(X,DIR("B"))=Y
        !           128:        D ^DIR I DDER K Y S Y=""
        !           129:        ;
        !           130:        I Y]"",$E($P(DIR(0),U))="P" S Y=$P(Y,U)
        !           131:        Q
        !           132:        ;

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>