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

DICATTD1.m

Go to the documentation of this file.
  1. DICATTD1 ;SFISC/GFT- DATE,TIME ;2 FEB 2009
  1. ;;22.0;VA FileMan;**42,160**;Mar 30, 1999;Build 23
  1. ;Per VHA Directive 2004-038, this routine should not be modified.
  1. ;
  1. EARLY ;
  1. S Y=">X" G Y
  1. ;
  1. LATEST ;
  1. S Y="<X"
  1. Y S Y=$F(DICATT5,Y) I Y S Y=$E(DICATT5,Y-9,Y-3) S:Y?.E1"DT" Y="DT" D:Y DD^%DT Q
  1. K Y Q
  1. ;
  1. POST1 ;check DATE
  1. N Z,Y,%DT,I K DDSERROR
  1. S %DT="T"
  1. D I $D(DDSERROR) D HLP^DDSUTL("'EARLIEST DATE' & 'LATEST DATE' ARE IN WRONG ORDER") S DDSBR="21^DICATT1^2.1" Q
  1. .S Y=$$G(21) I Y="DT" S X=$$G(22) D:X]"" Q
  1. ..I X'="DT" D ^%DT I Y<DT S DDSERROR=1 Q
  1. .Q:Y="" S X=Y D ^%DT S X=$$G(22) Q:X="" I X="DT" S:Y>DT DDSERROR=1 Q
  1. .S Z=Y D ^%DT I Y<Z S DDSERROR=1
  1. S DICATT5N="S %DT=""E"_$E("S",$$G(25)=1)_$E("T",$$G(24)=1)_$E("X",$$G(23)=0)_$E("R",$$G(26)=1)_""" D ^%DT S X=Y K:"
  1. FROMTO K DICATTMN F I=21,22 S Z=$$G(I) Q:Z="" D
  1. .I Z="DT" S Y=Z,Z="CURRENT DATE"
  1. .E S X=Z D ^%DT S X=Y D DD^%DT S Z=Y,Y=X
  1. .S DICATTMN(I)=Z,DICATT5N(I)=Y ;Z is readable, Y internal
  1. I $D(DICATTMN(22)) S DICATTMN="Type a date between "_DICATTMN(21)_" and "_DICATTMN(22)_".",DICATT5N=DICATT5N_DICATT5N(22)_"<X!("_DICATT5N(21)_">X) X"
  1. E I $D(DICATTMN(21)) S DICATTMN="Type a date not earlier than "_DICATTMN(21)_".",DICATT5N=DICATT5N_DICATT5N(21)_">X X"
  1. E S DICATT5N=DICATT5N_"X<1 X",DICATTMN="(No range limit on date)"
  1. S DICATTLN=$$G(24)=1*5+7
  1. S DICATT2N="D",DICATT3N=""
  1. S X=DICATT5N K DICATT5N S DICATT5N=X ;get rid of those damn subscripts
  1. CHNG I DICATT5N=DICATT5 K DICATTMN ;No DICATTMN means no change
  1. D:$D(DICATTMN) PUT^DDSVALF(98,"DICATT",1,DICATTMN)
  1. Q
  1. ;
  1. G(I) N X Q $$GET^DDSVALF(I,"DICATT1",2.1,"I","")