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

DDSRSEL.m

Go to the documentation of this file.
  1. DDSRSEL ;SFISC/MKO-RECORD SELECTION ;7JAN2004
  1. ;;22.2;VA FileMan;;Jan 05, 2016;Build 42
  1. ;;Per VA Directive 6402, this routine should not be modified.
  1. ;;Submitted to OSEHRA 5 January 2015 by the VISTA Expertise Network.
  1. ;;Based on Medsphere Systems Corporation's MSC FileMan 1051.
  1. ;;Licensed under the terms of the Apache License, Version 2.0.
  1. ;
  1. PG ;Called from:
  1. ; DDS01 when user presses SELECT
  1. ; FIRSTPG^DDS0 if no DA was passed in.
  1. ;
  1. ;Returns (if there is a record selection page and we're not in
  1. ;a multiple)
  1. ; DDSPG = Record selection page #
  1. ; DDACT = "NP"
  1. ; DDSSEL = 1 (undefined if no record selection page)
  1. ;
  1. N P,P1 K DDSSEL
  1. I $D(DDSSC),$P($G(DDSSC(DDSSC)),U,4) Q ;GFT
  1. ;
  1. S P="",P1=$P($G(^DIST(.403,+DDS,21)),U)
  1. I P1]"" D
  1. . S P=$O(^DIST(.403,+DDS,40,"B",P1,""))
  1. . I P]"",$D(^DIST(.403,+DDS,40,P,0))[0 S P=""
  1. ;
  1. I P]"" D
  1. . I $G(DDO),$G(DDSDN)=1 D
  1. .. D ERR3^DDS3
  1. . E S DDSPG=P,DDACT="NP",DDSSEL=1
  1. Q
  1. ;
  1. GDA ;Called from DDS
  1. ;After a record selection page is closed get the DA from
  1. ;the first field on the page.
  1. N DDSANS,DDSREC,Y,PG
  1. S DDSANS=""
  1. GFT S PG=$P($G(^DIST(.403,+DDS,21)),U) G KILL:'PG N P S P=$O(^(40,"B",PG,0)) D:P I '$D(Y) G KILL
  1. .F Y=0:0 S Y=$O(^DIST(.403,+DDS,40,P,40,Y)) Q:'Y I $G(^(Y,"COMP MUL"))]"" K Y Q
  1. E S DDSREC=$$GET^DDSVALF(1,1,PG) ;ON THE OLD KIND OF LOOKUP PAGE, THERE IS 1 FIELD, 1 BLOCK
  1. ;
  1. K DA,DDSDAORG
  1. S DDSDA=DDSDASV,DDSDL=DDSDLSV
  1. D BLDDA^DDS(DDSDA)
  1. M DDSDAORG=DDSORGSV
  1. ;
  1. I 'DDSREC,DA S DDSREC=DA
  1. E I DDSREC,DDSREC'=DA D
  1. . I DA D Q:DDSREC=DA
  1. .. S DDSANS=$$ASKSAVE
  1. .. I DDSANS="R" S DDSREC=DA
  1. .. E I DDSANS="S" D
  1. ... D ^DDS4
  1. ... S:Y'=1 DDSREC=DA
  1. . ;
  1. . S DA=DDSREC
  1. . D REC^DDS0(DDP,.DA)
  1. . ;
  1. . I $G(DIERR) D Q
  1. .. D ERR^DDSMSG H 2
  1. .. S DA=+$G(DDSDASV),DDACT="N"
  1. .. D REC^DDS0(DDP,.DA)
  1. . ;
  1. . S DDACT="N"
  1. . I DDSSC=1 D FRSTPG^DDS0(DDS,.DA,$G(DDSPAGE))
  1. . D CLRDAT,UNLOCK
  1. ;
  1. KILL K DDSSEL,DDSDASV,DDSDASV,DDSDLSV,DDSORGSV
  1. Q
  1. ;
  1. ASKSAVE() ;
  1. ;Ask user whether to save the previous record
  1. N X,Y
  1. D:DDM CLRMSG^DDS
  1. S DDM=1
  1. ;
  1. K DIR S DIR(0)="SM^S:SAVE;D:DISCARD;R:RETURN"
  1. S DIR("A",1)=" NOTE: You must Save or Discard all edits to the"
  1. S DIR("A",2)=" previous record before editing the next record."
  1. S DIR("A",3)=" "
  1. S DIR("A")="Save, Discard, or Return (S/D/R)"
  1. S DIR("B")="SAVE"
  1. ;
  1. S DIR("?",1)="Enter 'S' to save or 'D' to discard."
  1. S DIR("?")="Enter 'R' or '^' to return to previous record."
  1. ;
  1. S DIR0=IOSL-1_U_($L(DIR("A"))+1)_"^7^"_(IOSL-4)_"^0"
  1. D ^DIR
  1. I $D(DIRUT) S Y="R"
  1. E I X="SAVE" S Y="S"
  1. K DIR,DIROUT,DIRUT,DTOUT,DUOUT
  1. Q Y
  1. ;
  1. CLRDAT ;Clear all data values from @DDSREFT
  1. N F,P
  1. S P=0 F S P=$O(@DDSREFT@(P)) Q:'P K @DDSREFT@(P)
  1. S F="F" F S F=$O(@DDSREFT@(F)) Q:$E(F)'="F" K @DDSREFT@(F)
  1. Q
  1. ;
  1. UNLOCK ;Unlock all records locked
  1. Q:'$D(^TMP("DDS",$J,"LOCK"))
  1. N I S I=""
  1. F S I=$O(^TMP("DDS",$J,"LOCK",I)) Q:I="" D
  1. . I I'=(DIE_DA_")") L -@I K ^TMP("DDS",$J,"LOCK",I)
  1. Q