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

GMPLPRF1.m

Go to the documentation of this file.
  1. GMPLPRF1 ; SLC/MKB -- Problem List User Prefs cont ;3/30/94 09:25
  1. ;;2.0;Problem List;;Aug 25, 1994
  1. ADD ; -- add item(s) to view
  1. N GMPLSEL,GMPLNO,IFN,NUM,CNUM,I,J S VALMBCK=$S(VALMCC:"",1:"R")
  1. ADD1 S GMPLSEL=$$SELECT Q:GMPLSEL="^"
  1. S GMPLNO=$L(GMPLSEL,","),I=$S(GMPLMODE="S":"service",1:"clinic")
  1. I (GMPLIST("VIEW",0)+GMPLNO-1)>60 D G ADD1
  1. . W !!,"You may not have more than 60 "_I_"s included in your view!"
  1. . W !,"Your view currently includes "_+GMPLIST("VIEW",0)_" "_I_$S(GMPLIST("VIEW",0)'=1:"s",1:"")_"."
  1. . W !,"Please select again, choosing no more than "_(60-GMPLIST("VIEW",0))_" "_I_$S(GMPLIST("VIEW",0)'=1:"s",1:"")_"."
  1. ADD2 W !!,"Adding "_(GMPLNO-1)_" "_I_"(s) ..." K I
  1. F I=1:1:GMPLNO S NUM=$P(GMPLSEL,",",I) I NUM D
  1. . S IFN=+GMPLIST("IDX",NUM) W "."
  1. . S TMP=$E(GMPLIST(NUM,0),1,44)_" Y",GMPLIST(NUM,0)=TMP
  1. . S:'$D(GMPLIST("VIEW",IFN)) GMPLIST("VIEW",IFN)="",GMPLIST("VIEW",0)=GMPLIST("VIEW",0)+1
  1. . Q:GMPLMODE'="S" Q:'$D(^DIC(49,"ACHLD",IFN))
  1. . I $$INCLCHLD(IFN) F J=0:0 S J=$O(^DIC(49,"ACHLD",IFN,J)) Q:J'>0 D
  1. . . S CNUM=+$G(GMPLIST("B",J)) W "."
  1. . . I CNUM S TMP=$E(GMPLIST(CNUM,0),1,44)_" Y",GMPLIST(CNUM,0)=TMP S:'$D(GMPLIST("VIEW",J)) GMPLIST("VIEW",J)="",GMPLIST("VIEW",0)=GMPLIST("VIEW",0)+1
  1. S VALMBCK="R",VALMSG=$$MSG^GMPLPREF K VALMHDR
  1. Q
  1. ;
  1. REMOVE ; -- delete item(s) from view
  1. N GMPLSEL,GMPLNO,IFN,NUM,CNUM,I,J S VALMBCK=$S(VALMCC:"",1:"R")
  1. S GMPLSEL=$$SELECT Q:GMPLSEL="^"
  1. S GMPLNO=$L(GMPLSEL,",")
  1. W !!,"Removing "_(GMPLNO-1)_" "_$S(GMPLMODE="S":"service",1:"clinic")_"(s) ..."
  1. F I=1:1:GMPLNO S NUM=$P(GMPLSEL,",",I) I NUM D
  1. . S IFN=+GMPLIST("IDX",NUM),GMPLIST(NUM,0)=$E(GMPLIST(NUM,0),1,44)
  1. . S:$D(GMPLIST("VIEW",IFN)) GMPLIST("VIEW",0)=GMPLIST("VIEW",0)-1
  1. . K GMPLIST("VIEW",IFN) W "."
  1. . Q:GMPLMODE'="S" Q:'$D(^DIC(49,"ACHLD",IFN))
  1. . I $$INCLCHLD(IFN) F J=0:0 S J=$O(^DIC(49,"ACHLD",IFN,J)) Q:J'>0 D
  1. . . S CNUM=+$G(GMPLIST("B",J)) W "."
  1. . . I CNUM S GMPLIST(CNUM,0)=$E(GMPLIST(CNUM,0),1,44) S:$D(GMPLIST("VIEW",J)) GMPLIST("VIEW",0)=GMPLIST("VIEW",0)-1 K GMPLIST("VIEW",J)
  1. S VALMBCK="R",VALMSG=$$MSG^GMPLPREF K VALMHDR
  1. Q
  1. ;
  1. INCLCHLD(IFN) ; Returns 1 or 0, to include 'child' services in selection
  1. N DIR,X,Y,NAME S NAME=$P($G(^DIC(49,IFN,0)),U),DIR("B")="YES"
  1. S DIR(0)="Y",DIR("A")="Include all sub-services/sections of "_NAME
  1. S DIR("?",1)="This service is a 'parent' to other services/sections,"
  1. S DIR("?",2)="listed indented above; enter YES to include all of these"
  1. S DIR("?")="as well in this action, or enter NO to exclude them."
  1. D ^DIR S:$D(DTOUT) Y="^"
  1. Q Y
  1. ;
  1. SELECT() ; Select item(s) from list
  1. N DIR,X,Y,MAX
  1. S MAX=+$G(GMPLIST(0)) I MAX'>0 Q "^"
  1. S DIR(0)="LAO^1:"_MAX
  1. S DIR("A")="Select "_$S(GMPLMODE="S":"Service",1:"Clinic")
  1. S:MAX>1 DIR("A")=DIR("A")_" (1-"_MAX_"): "
  1. S:MAX'>1 DIR("A")=DIR("A")_": ",DIR("B")=1
  1. S DIR("?")="Enter the display number of the "_$S(GMPLMODE="S":"service",1:"clinic")_"(s) you wish to select"
  1. D ^DIR I $D(DTOUT)!(X="") S Y="^"
  1. Q Y
  1. ;
  1. DIFFRENT() ; -- Returns 1 if view has changed, else 0
  1. N I,TEMP S TEMP=""
  1. F I=0:0 S I=$O(GMPLIST("VIEW",I)) Q:I'>0 S TEMP=TEMP_I_"/"
  1. S:$L(TEMP) TEMP=GMPLMODE_"/"_TEMP
  1. Q TEMP'=$P($G(^VA(200,DUZ,125)),U)
  1. ;
  1. SAVE ; -- save new view in File #200/Field #125
  1. N I,TEMP,TMP S TEMP=GMPLMODE,TMP=$P($G(^VA(200,DUZ,125)),U,2,999)
  1. F I=0:0 S I=$O(GMPLIST("VIEW",I)) Q:I'>0 S TEMP=TEMP_"/"_I
  1. S:$L(TEMP)>1 TEMP=TEMP_"/"
  1. S ^VA(200,DUZ,125)=TEMP_U_TMP,GMPSAVED=1
  1. Q
  1. ;
  1. SWITCH ; -- change preferred views (service <--> clinic)
  1. N DIR,X,Y S Y=1,VALMBCK=$S(VALMCC:"",1:"R")
  1. G SW1:'$L($G(GMPLVIEW)) ; no current view
  1. S DIR(0)="Y",DIR("A")="Are you sure this is ok",DIR("B")="NO"
  1. S DIR("?",1)="You may have only one preferred view at a time."
  1. S DIR("?",2)="Enter YES to change how your preferred view is defined,"
  1. S DIR("?")="or press <return> to keep the view you currently have."
  1. W !!,">>> This action will clear your current view of problems by "
  1. W $S(GMPLMODE="S":"service",1:"clinic")
  1. W !?5,"and present a list of "_$S(GMPLMODE="S":"clinics",1:"services")
  1. W " to replace it with.",! D ^DIR
  1. SW1 I Y D
  1. . S VALMBCK="R",GMPLVIEW="",GMPLMODE=$S(GMPLMODE="S":"C",1:"S")
  1. . D @("GET"_GMPLMODE_"LIST^GMPLPREF") K VALMHDR
  1. Q
  1. ;
  1. DELETE ; -- delete preferred view (no view)
  1. N DIR,X,Y S DIR(0)="Y",DIR("B")="NO",VALMBCK=$S(VALMCC:"",1:"R")
  1. S DIR("A")="Are you sure you want to delete your preferred view"
  1. S DIR("?",1)="Enter YES to remove your preferred view; the default view of Outpatient,",DIR("?",2)="including all active problems, will be used to display problem information.",DIR("?")="Enter NO to continue editing your current view."
  1. D ^DIR I Y D
  1. . W !!,"Deleting preferred view of "_$S(GMPLMODE="S":"services",1:"clinics")_" ..."
  1. . K GMPLIST("VIEW") S GMPLIST("VIEW",0)=0,VALMBCK="Q",GMPLMODE=""
  1. . D SAVE W " done."
  1. Q