| 1 | DDSUTL ;SFISC/MKO-PROGRAMMER UTILITIES ;11:37 AM 25 Jul 1995
|
---|
| 2 | ;;22.0;VA FileMan;;Mar 30, 1999
|
---|
| 3 | ;Per VHA Directive 10-93-142, this routine should not be modified.
|
---|
| 4 | ;
|
---|
| 5 | MSG(TXT) ;
|
---|
| 6 | ;Data validation messages
|
---|
| 7 | D PROC(.TXT,$NA(@DDSREFT@("MSG")))
|
---|
| 8 | Q
|
---|
| 9 | ;
|
---|
| 10 | HLP(TXT) ;
|
---|
| 11 | ;Help box messages
|
---|
| 12 | D PROC(.TXT,$NA(@DDSREFT@("HLP")))
|
---|
| 13 | Q
|
---|
| 14 | PROC(TXT,GLB) ;
|
---|
| 15 | ;Put text into global
|
---|
| 16 | N CNT,I
|
---|
| 17 | S CNT=$G(@GLB)
|
---|
| 18 | I $D(TXT)<9 S CNT=CNT+1,@GLB@(CNT)=TXT
|
---|
| 19 | E S I="" F CNT=CNT:1 S I=$O(TXT(I)) Q:I="" S @GLB@(CNT+1)=TXT(I)
|
---|
| 20 | S @GLB=CNT
|
---|
| 21 | Q
|
---|
| 22 | ;
|
---|
| 23 | REFRESH ;Refresh the screen
|
---|
| 24 | G R^DDSR
|
---|
| 25 | ;
|
---|
| 26 | MLOAD(DDSIEN) ;Load subrecords for current multiple
|
---|
| 27 | G MLOAD^DDSM1
|
---|
| 28 | ;
|
---|
| 29 | MDEL(DDSIEN) ;Delete subrecords for current multiple
|
---|
| 30 | G MDEL^DDSM1
|
---|
| 31 | ;
|
---|
| 32 | UNED(DDSF,DDSB,DDSP,DDSVAL,DDSUDA) ;Change DISABLE EDITING attribute
|
---|
| 33 | S:$D(DDSVAL)[0 DDSVAL=""
|
---|
| 34 | D SETATT(4)
|
---|
| 35 | Q
|
---|
| 36 | ;
|
---|
| 37 | REQ(DDSF,DDSB,DDSP,DDSVAL,DDSUDA) ;Change REQUIRED attribute
|
---|
| 38 | S:$D(DDSVAL)[0 DDSVAL=""
|
---|
| 39 | D SETATT(1)
|
---|
| 40 | Q
|
---|
| 41 | ;
|
---|
| 42 | ;
|
---|
| 43 | SETATT(DDSUPC) ;Set attribute node, piece DDSUPC
|
---|
| 44 | N DDSOVAL,DDSUDDP,DDSUFLD,DDSUTP
|
---|
| 45 | I $D(DDSPG)[0 N DDSPG S DDSPG=""
|
---|
| 46 | I $D(DDSBK)[0 N DDSBK S DDSBK=""
|
---|
| 47 | S DDSP=$$GETFLD^DDSLIB(DDSF,$G(DDSB),$G(DDSP),+DDS,DDSPG,DDSBK)
|
---|
| 48 | I $G(DIERR) D ERR^DDSMSG Q
|
---|
| 49 | ;
|
---|
| 50 | S DDSF=$P(DDSP,","),DDSB=$P(DDSP,",",2),DDSP=$P(DDSP,",",3)
|
---|
| 51 | ;
|
---|
| 52 | S DDSUDDP=+$P($G(^DIST(.404,DDSB,0)),U,2)
|
---|
| 53 | I DDSUDDP,$G(DDSUDA)]"" N DDSDA S DDSDA=DDSUDA
|
---|
| 54 | E I DDSUDDP,DDSB'=DDSBK N DDSDA D GL^DDS10(DDSUDDP,.DDSDAORG,"","",.DDSDA)
|
---|
| 55 | ;
|
---|
| 56 | S DDSUTP=$P($G(^DIST(.404,DDSB,40,DDSF,0)),U,3) S:'DDSUTP DDSUTP=3
|
---|
| 57 | I DDSUTP=2 D
|
---|
| 58 | . S DDSUFLD=DDSF_","_DDSB
|
---|
| 59 | . S DDSUDDP=0
|
---|
| 60 | E I DDSUTP=3 D Q:'DDSUFLD
|
---|
| 61 | . S DDSUFLD=$P($G(^DIST(.404,DDSB,40,DDSF,1)),U)
|
---|
| 62 | E Q
|
---|
| 63 | ;
|
---|
| 64 | S DDSOVAL=$P($G(@DDSREFT@("F"_DDSUDDP,DDSDA,DDSUFLD,"A")),U,DDSUPC)
|
---|
| 65 | Q:DDSVAL=DDSOVAL
|
---|
| 66 | S $P(@DDSREFT@("F"_DDSUDDP,DDSDA,DDSUFLD,"A"),U,DDSUPC)=DDSVAL
|
---|
| 67 | Q
|
---|
| 68 | ;
|
---|
| 69 | ADD(DDSFIL,X,DA,DINUM,DDSDIC0,DDSDR,DDSL) ;
|
---|
| 70 | ;Add an entry as part of a transaction
|
---|
| 71 | ;DDSL=1 means don't lock
|
---|
| 72 | ;
|
---|
| 73 | N %,%W,%Y,C,D0,DD,DO,DI,DIC,DIE,DQ,DR
|
---|
| 74 | N DDSDA,DDSDIC,DDSFD,DDSREQ,DDSUP,I
|
---|
| 75 | K DIERR,^TMP("DIERR",$J)
|
---|
| 76 | K:'$G(DINUM) DINUM
|
---|
| 77 | S:$G(DDSDIC0)="" DDSDIC0="L"
|
---|
| 78 | S DIC(0)=DDSDIC0,Y=-1
|
---|
| 79 | S:$G(DDSDR)]"" DIC("DR")=DDSDR
|
---|
| 80 | S DIC=$$ROOT^DILFD(DDSFIL,.DA),DDSDIC=$$CREF^DIQGU(DIC)
|
---|
| 81 | ;
|
---|
| 82 | I $D(@DDSDIC@(0))[0 D Q:$G(DIC("P"))=""
|
---|
| 83 | . S DDSUP=$G(^DD(DDSFIL,0,"UP")) Q:'DDSUP
|
---|
| 84 | . S DDSFD=$O(^DD(DDSUP,"SB",DDSFIL,"")) Q:'DDSFD
|
---|
| 85 | . S DIC("P")=$P($G(^DD(DDSUP,DDSFD,0)),U,2)
|
---|
| 86 | ;
|
---|
| 87 | I DDSDIC0'["E",$$REQID(DDSFIL,.DDSREQ) D Q:$G(DIERR)
|
---|
| 88 | . N F
|
---|
| 89 | . S F=""
|
---|
| 90 | . F S F=$O(DDSREQ(F)) Q:'F I $G(DIC("DR"))'[(F_"///") D BLD^DIALOG(3031,"ADD^DDSUTL") Q
|
---|
| 91 | ;
|
---|
| 92 | D FILE^DICN K DTOUT,DUOUT Q:Y=-1!'$D(DDS)
|
---|
| 93 | ;
|
---|
| 94 | I '$G(DDSL) D
|
---|
| 95 | . N I,L,R
|
---|
| 96 | . S L=1,R=DIC_DA_","
|
---|
| 97 | . F I=$L(R,",")-1:-1:1 I $D(^TMP("DDS",$J,"LOCK",$P(R,",",1,I)_")"))#2 S L=0 Q
|
---|
| 98 | . I L,$D(^TMP("DDS",$J,"LOCK",$P(R,"(")))#2 S L=0
|
---|
| 99 | . I L L +@(DIC_+Y_")"):0 S ^TMP("DDS",$J,"LOCK",DIC_+Y_")")=""
|
---|
| 100 | ;
|
---|
| 101 | S DDSDA=+Y_","
|
---|
| 102 | F I=1:1 Q:$D(DA(I))[0 S DDSDA=DDSDA_DA(I)_","
|
---|
| 103 | S ^("ADD")=$G(@DDSREFT@("ADD"))+1,^("ADD",^("ADD"))=DDSDA_DIC
|
---|
| 104 | Q
|
---|
| 105 | ;
|
---|
| 106 | REQID(FIL,REQ) ;
|
---|
| 107 | ;Get list of required identifiers into DDSREQ
|
---|
| 108 | N F
|
---|
| 109 | K REQ
|
---|
| 110 | S F="" F S F=$O(^DD(FIL,0,"ID",F)) Q:F'=+$P(F,"E") D
|
---|
| 111 | . S:$P($G(^DD(FIL,F,0)),U,2)["R" REQ(F)=""
|
---|
| 112 | Q $D(REQ)>0
|
---|
| 113 | ;
|
---|
| 114 | DESTROY(PG) ;Destroy all data for page PG
|
---|
| 115 | N P,B,F,IENS,TP,FIL,FLD
|
---|
| 116 | S P=$O(^DIST(.403,+DDS,40,"B",PG,"")) Q:'P
|
---|
| 117 | S B=0 F S B=$O(^DIST(.403,+DDS,40,P,40,B)) Q:'B D
|
---|
| 118 | . Q:'$D(^DIST(.403,+DDS,40,P,40,B,0))
|
---|
| 119 | . Q:'$D(^DIST(.404,B,0)) S FIL=$P(^(0),U,2)
|
---|
| 120 | . S F=0 F S F=$O(^DIST(.404,B,40,F)) Q:'F D
|
---|
| 121 | .. Q:'$D(^DIST(.404,B,40,F,0)) S TP=$P(^(0),U,3)
|
---|
| 122 | .. S:'TP TP=3
|
---|
| 123 | .. ;
|
---|
| 124 | .. I TP=3 S FF="F"_FIL,FLD=$G(^DIST(.404,B,40,F,1)) Q:FLD?."^"
|
---|
| 125 | .. E I TP=2 S FF="F0",FLD=F_","_B
|
---|
| 126 | .. E Q
|
---|
| 127 | .. ;
|
---|
| 128 | .. S IENS=" "
|
---|
| 129 | .. F S IENS=$O(@DDSREFT@(FF,IENS)) Q:IENS="" K ^(IENS,FLD)
|
---|
| 130 | ;
|
---|
| 131 | K @DDSREFT@(P),@DDSREFT@("XCAP",P)
|
---|
| 132 | Q
|
---|
| 133 | ;
|
---|
| 134 | ;
|
---|
| 135 | DDSDA(DA,DL,DDSDA) ;Determine DDSDA
|
---|
| 136 | ;
|
---|
| 137 | N I
|
---|
| 138 | I DA="" S DDSDA="" Q
|
---|
| 139 | S DDSDA=DA_"," F I=1:1:DL S DDSDA=DDSDA_DA(I)_","
|
---|
| 140 | Q
|
---|