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

GMPLPREF.m

Go to the documentation of this file.
  1. GMPLPREF ; SLC/MKB -- Problem List User Preferences ;2/1/96 12:31
  1. ;;2.0;Problem List;**3,5**;Aug 25, 1994
  1. EN ; -- main entry point for GMPL USER PREFS
  1. D CURRENT^GMPLPRF0(DUZ) Q:'$$CHANGE^GMPLPRF0
  1. D EN^VALM("GMPL USER PREFS")
  1. Q
  1. ;
  1. INIT ; -- init variables and list array
  1. S GMPLVIEW=$P($G(^VA(200,DUZ,125)),U),GMPLMODE=$E(GMPLVIEW) ; 'S' or 'C'
  1. S GMPLMODE=$$VIEW^GMPLPRF0(GMPLMODE)
  1. I GMPLMODE="^" K GMPLVIEW,GMPLMODE S VALMQUIT=1 Q
  1. I $$ALL^GMPLPRF0(GMPLMODE,$L(GMPLVIEW,"/")) D SAVE^GMPLPRF1 W !!,"Preferred View saved.",! H 1 S VALMQUIT=1 Q
  1. D GETSLIST:GMPLMODE="S",GETCLIST:GMPLMODE'="S"
  1. Q
  1. ;
  1. GETSLIST ; -- init SERVICE list array
  1. N LCNT,IFN,NAME,PARENT K ^TMP("GMPLIST",$J) S LCNT=0,^TMP("GMPLIST",$J,"VIEW",0)=0
  1. W !!,"Retrieving the list of clinical services ..."
  1. F IFN=0:0 S IFN=$O(^DIC(49,"F","C",IFN)) Q:IFN'>0 D
  1. . Q:$D(^TMP("GMPLIST",$J,"B",IFN)) ; service already on list
  1. . S PARENT=+$P($G(^DIC(49,IFN,0)),U,4) I PARENT,PARENT'=IFN,$D(^DIC(49,"F","C",PARENT)) Q ; child of clin service
  1. . S NAME=$P($G(^DIC(49,IFN,0)),U)
  1. . D ITEM(IFN,NAME,GMPLVIEW,.LCNT)
  1. . Q:'$D(^DIC(49,"ACHLD",IFN)) ; service has no 'children'
  1. . F CHILD=0:0 S CHILD=$O(^DIC(49,"ACHLD",IFN,CHILD)) Q:CHILD'>0 I CHILD'=IFN D
  1. . . S NAME=" "_$P($G(^DIC(49,CHILD,0)),U)
  1. . . D ITEM(CHILD,NAME,GMPLVIEW,.LCNT)
  1. I LCNT'>0 S ^TMP("GMPLIST",$J,1,0)=" ",^TMP("GMPLIST",$J,2,0)=" No clinical services available to select from."
  1. D:$P(VALMDDF("SERVICE"),U,4)'="Service" CHGCAP^VALM("SERVICE","Service")
  1. S VALMCNT=LCNT,^TMP("GMPLIST",$J,0)=VALMCNT,VALMSG=$$MSG
  1. Q
  1. ;
  1. GETCLIST ; -- init CLINIC list array
  1. N LCNT,IFN,NAME K ^TMP("GMPLIST",$J) S LCNT=0,^TMP("GMPLIST",$J,"VIEW",0)=0
  1. W !!,"Retrieving the list of clinics ..."
  1. F IFN=0:0 S IFN=$O(^SC(IFN)) Q:IFN'>0 D
  1. . S NODE=$G(^SC(IFN,0)) Q:$P(NODE,U,3)'="C" ; loc not a clinic
  1. . S NAME=$P(NODE,U) D ITEM(IFN,NAME,GMPLVIEW,.LCNT)
  1. I LCNT'>0 S ^TMP("GMPLIST",$J,1,0)=" ",^TMP("GMPLIST",$J,2,0)=" No clinics available to select from."
  1. D:$P(VALMDDF("SERVICE"),U,4)'="Clinic" CHGCAP^VALM("SERVICE","Clinic")
  1. S VALMCNT=LCNT,^TMP("GMPLIST",$J,0)=VALMCNT,VALMSG=$$MSG
  1. Q
  1. ;
  1. ITEM(IFN,NAME,VIEW,CNT) ;Add item to list display
  1. N LNG,TMP,LINE,INCL S INCL=VIEW[("/"_IFN_"/")
  1. S LINE=" . . . . . . . . . . . . . . . . . . . . "
  1. S CNT=CNT+1,LINE=$$SETFLD^VALM1(CNT,LINE,"NUMBER")
  1. S LNG=4+$L(NAME),TMP=$E(LINE,1,4)_NAME_$E(LINE,LNG+1,$L(LINE)),LINE=TMP
  1. I INCL S LINE=$$SETFLD^VALM1(" Y",LINE,"ACCEPT"),^TMP("GMPLIST",$J,"VIEW",IFN)="",^TMP("GMPLIST",$J,"VIEW",0)=^TMP("GMPLIST",$J,"VIEW",0)+1
  1. S ^TMP("GMPLIST",$J,CNT,0)=LINE,^TMP("GMPLIST",$J,"IDX",CNT)=IFN,^TMP("GMPLIST",$J,"B",IFN)=CNT
  1. D CNTRL^VALM10(CNT,1,2,IOINHI,IOINORM) ; highlight numbers
  1. Q
  1. ;
  1. HDR ; -- header code
  1. N NUM,USER,X S USER=$P($G(^VA(200,DUZ,0)),U)
  1. S X="CLINIC"_$S(GMPLMODE="S":"AL SERVICE",1:"")_"S"
  1. S NUM=+$G(^TMP("GMPLIST",$J,"VIEW",0))_" "_$S(GMPLMODE="S":"services",1:"clinics")
  1. S VALMHDR(1)=USER_$J(NUM,79-$L(USER)),VALMHDR(2)=$J(X,$L(X)\2+41)
  1. Q
  1. ;
  1. HELP ; -- help code
  1. N X,Y S:GMPLMODE="S" X="services",Y="clinics"
  1. S:GMPLMODE'="S" X="clinics",Y="services"
  1. W !!?4,"To create or change your preferred view, choose either Add or"
  1. W !?4,"Remove; those "_X_" you add will be flagged above with a 'Y'."
  1. W !?4,"Within the Problem List application, ONLY those problems associated"
  1. W !?4,"with your selected "_X_" will initially be displayed, however"
  1. W !?4,"the entire list is always available using its Select View option."
  1. W !?4,"If you wish to create a view according to "_Y_" instead, or not"
  1. W !?4,"to have a view at all, choose Select New View or Delete respectively."
  1. W !!,"Press <return> to continue ... " R X:DTIME
  1. S VALMSG=$$MSG,VALMBCK=$S(VALMCC:"",1:"R")
  1. Q
  1. ;
  1. CLEAN ; -- exit code
  1. I $$DIFFRENT^GMPLPRF1,'$D(GMPSAVED) D
  1. . N DIR,X,Y S DIR(0)="Y"
  1. . W !!,$C(7),">>> YOUR PREFERRED VIEW HAS CHANGED!!"
  1. . S DIR("A")="Do you want to save these changes",DIR("B")="YES"
  1. . S DIR("?",1)="Enter YES to have only problems from the "_$S(GMPLMODE="S":"service",1:"clinic")_"s indicated above"
  1. . S DIR("?",2)="listed, when initially displaying a patient's problem list;"
  1. . S DIR("?")="enter NO to retain your previous view."
  1. . D ^DIR D:Y SAVE^GMPLPRF1
  1. K GMPLVIEW,GMPLIST,GMPLMODE,GMPSAVED
  1. K ^TMP("GMPLIST",$J)
  1. K VALMHDR,VALMCNT,VALMSG,VALMBCK
  1. Q
  1. ;
  1. MSG() ; -- msg line for more help
  1. N X S X="+ More "_$S(GMPLMODE="S":"Services",1:"Clinics")_" ?? More actions"
  1. Q X