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

ORCHART.m

Go to the documentation of this file.
  1. ORCHART ;SLC/MKB/REV-OE/RR ; 11 March 2003 14:02
  1. ;;3.0;ORDER ENTRY/RESULTS REPORTING;**7,27,48,70,72,92,141,181**;Dec 17, 1997
  1. EN ; -- main entry point
  1. K ^TMP("OR",$J) ;ensure fresh start
  1. D EN^ORQPT Q:+$G(ORVP)'>0
  1. D EN^VALM("OR CHART") G:'$G(OREXIT) EN
  1. K OREXIT
  1. Q
  1. ;
  1. INIT ; -- init variables and list array
  1. S:'$D(ORTAB) ORTAB=$$UP^XLFSTR($$GET^XPAR("ALL","ORCH INITIAL TAB",1,"E"))
  1. S:ORTAB="DCSUMM" ORTAB="SUMMRIES" S:'$L(ORTAB) ORTAB="COVER"
  1. S ORACTION=0 D TAB(ORTAB)
  1. Q
  1. ;
  1. PHDR ; -- protocol header code
  1. N ORM,ORI,ORS,ORSYN K ORNMBR,OREBUILD
  1. S:$G(ORTAB)'="LABS" VALMSG=$$MSG D SHOW^VALM
  1. S:XQORM("B")="Quit" XQORM("B")=$S('$G(DGPMT):"Chart Contents",1:"Close Patient Chart")
  1. S:$G(^TMP("OR",$J,"CURRENT","#")) XQORM("#")=^("#")
  1. S ORM=$S(ORTAB="CONSULTS":+$O(^ORD(101,"B","ORC CONSULT SERVICE MENU",0)),1:+$G(XQORM("#"))),ORI=0 ;set XQORM("KEY",<synonym>)
  1. F S ORI=$O(^ORD(101,ORM,10,"B",ORI)) Q:ORI'>0 I $D(^ORD(101,+ORI,2)) D
  1. . S ORS=0 F S ORS=$O(^ORD(101,+ORI,2,ORS)) Q:ORS'>0 S ORSYN=$G(^(ORS,0)) S:$L(ORSYN) XQORM("KEY",ORSYN)=+ORI_"^1"
  1. S XQORM("KEY","EX")=$O(^ORD(101,"B","ORC EXIT",0))_"^1"
  1. S XQORM("KEY","NEXT")=$O(^ORD(101,"B","ORC NEXT SCREEN",0))_"^1"
  1. S XQORM("KEY","PL")=$O(^ORD(101,"B","ORC PRINT LIST",0))_"^1"
  1. Q
  1. ;
  1. HDR ; -- header code
  1. ; Expects ORPNM, ORSSN, ORL, ORDOB, ORAGE [, ORPD]
  1. ; N DFN S DFN=+ORVP D SLCT1^ORQPT if any are missing ??
  1. N ORX,ORX1,ORX2,ORX3,ORCWAD,L,SP K VALMHDR
  1. S ORX1=$P($G(^DPT(+ORVP,0)),U,3),ORX3=$$FMTE^XLFDT(ORX1,2)_"("_ORAGE_")"
  1. S ORX2="" I +$G(ORL) D S:$L($G(ORL(1))) ORX2=ORX2_"/"_ORL(1)
  1. . S L=$G(^SC(+ORL,0)),ORX2=$P(L,U,2)
  1. . S:'$L(ORX2) ORX2=$E($P(L,U),1,4)
  1. S L=80-$L(ORPNM)-$L(ORSSN)-$L(ORX2)-$L(ORX3),SP=$$REPEAT^XLFSTR(" ",L\3)
  1. S ORX1=ORPNM_SP_ORSSN_SP_ORX2,VALMHDR(1)=ORX1_$J(ORX3,80-$L(ORX1))
  1. S ORX1=$S(ORATTEND:"Attend: "_$$LNAMEF^ORCHTAB(ORATTEND),1:"")
  1. S ORX2="PrimCare: "_$$LNAMEF^ORCHTAB(+$$OUTPTPR^SDUTL3(+ORVP))
  1. S ORX3="PCTeam: "_$P($$OUTPTTM^SDUTL3(+ORVP),U,2)
  1. S ORX=$S($L(ORX1):$$LJ^XLFSTR(ORX1,20),1:"")_ORX2,VALMHDR(2)=$$LJ^XLFSTR(ORX,42)_ORX3
  1. S ORCWAD=$$CWAD^ORQPT2(+ORVP) S:ORCWAD]"" ORCWAD="<"_ORCWAD_">"
  1. S ORX=$S($G(ORTAB)="COVER":"",$G(ORTAB)="REPORTS":"",1:$$VIEW),VALMHDR(3)=ORX_$J(ORCWAD,80-$L(ORX))
  1. Q
  1. ;
  1. MSG() ; -- LMgr message bar
  1. Q "Enter the numbers of the items you wish to act on."
  1. ;
  1. HELP ; -- help code
  1. N X,DX,DY D FULL^VALM1
  1. W !!,"Enter the display numbers of the items you wish to change or act on; a menu of",!,"available actions will then be presented for selection."
  1. W !!,"To see a different 'page' of the chart, enter CC; if you'd like another view of",!,"the current page, by date range for example, enter CV. You may add new orders"
  1. W !,"for this patient from any page in the chart by entering AD and review them",!,"using RV. Enter ?? to see a list of actions available for navigating the list."
  1. W:ORTAB="PROBLEMS" !!,"* = Acute problem",!,"$ = Unverified problem",!,"# = Problem references inactive code"
  1. W:(ORTAB="SUMMRIES")!(ORTAB="NOTES") !!,"+ = Addenda attached"
  1. W:(ORTAB="ORDERS")!(ORTAB="MEDS") !!,"* = Order has been updated by service"
  1. W:ORTAB="ORDERS" !,"+ = Sub-orders exist"
  1. W !!,"Press <return> to continue ..." R X:DTIME
  1. S VALMBCK="R" S:$G(ORTAB)'="LABS" VALMSG=$$MSG
  1. S (DX,DY)=0 X ^%ZOSF("XY")
  1. Q
  1. ;
  1. ITEMHELP ; -- help code for action menus
  1. N X
  1. W !!,"Enter the action you wish to take on the items selected and highlighted",!,"above; each item will be processed in order, one at a time."
  1. W !!,"Press <return> to continue ..." R X:DTIME
  1. S X="?" D DISP^XQORM1 W !
  1. Q
  1. ;
  1. EXIT ; -- exit code
  1. I $G(ORVP),$$MORE^ORCMENU2 D ;unsig orders
  1. . ;I '$D(^TMP("ORNEW",$J)),'$D(^XUSEC("ORES",DUZ)) Q ;msg like 2.5??
  1. . W !!,"You have new or unsigned orders for this patient!" H 1
  1. . S ORRV=1 D EN1^ORCMENU2,NOTIF^ORCMENU2 ;sign, notif if not all signed
  1. D UNLOCK^ORX2(+ORVP) K ^TMP("OR",$J),^TMP("ORNEW",$J),^TMP("LRRR",$J)
  1. K VALMCNT,VALMHDR,VALMBG,ORQUIT,ORVP,ORSEX,ORTAB,ORPNM,ORSSN,ORL,ORDOB,ORAGE,ORPD,ORNP,ORSC,ORTS,ORWARD,ORATTEND,ORNMBR,ORACTION,OREBUILD,OREBLD,ORRV,OREVENT
  1. Q
  1. ;
  1. TAB(NEWTAB,REBUILD) ; -- switch focus to new chart tab from ORTAB
  1. S VALMBCK="",VALMBG=$S($G(ORTAB)'=NEWTAB:1,'$G(VALMBG):1,1:VALMBG)
  1. S ORTAB=NEWTAB I '$G(^TMP("OR",$J,ORTAB,0))!($G(REBUILD)) D
  1. . W !,"Searching the patient's chart ..."
  1. . D FULL^VALM1,EN^ORCHTAB ; [re]build list
  1. D CLEAN^VALM10 M ^TMP("OR",$J,"CURRENT")=^TMP("OR",$J,ORTAB)
  1. M ^TMP("VALM VIDEO",$J,VALMEVL)=^TMP("OR",$J,"CURRENT","VIDEO")
  1. I $D(^TMP("OR",$J,"CURRENT","CAPTION")) D
  1. . N FLD,LBL S FLD=""
  1. . F S FLD=$O(^TMP("OR",$J,"CURRENT","CAPTION",FLD)) Q:FLD="" S LBL=$G(^(FLD)) D CHGCAP^VALM(FLD,LBL)
  1. S VALM("TITLE")=$G(^TMP("OR",$J,"CURRENT","TITLE")),VALM("RM")=^("RM")
  1. S:$D(^TMP("OR",$J,"CURRENT","MENU")) XQORM("HIJACK")=^("MENU")
  1. S VALMCNT=+$G(^TMP("OR",$J,"CURRENT",0)),VALMLFT=$P(VALMDDF("DATA"),U,2)
  1. D HDR S VALMBCK="R" ; reset VALMHDR nodes
  1. Q
  1. ;
  1. NEWPAT ; -- Select new patient
  1. I $$MORE^ORCMENU2 D ;unsigned orders
  1. . ;I '$D(^TMP("ORNEW",$J)),'$D(^XUSEC("ORES",DUZ)) Q
  1. . W !!,"You have new or unsigned orders for this patient!" H 1
  1. . S ORRV=1 D EN1^ORCMENU2,NOTIF^ORCMENU2 ;sign, notif if not all signed
  1. N TAB,OLD,T,ORT,CTXT K ORRV S OLD=+ORVP,TAB=ORTAB
  1. D EN^ORQPT I OLD=+ORVP S VALMBCK="R" D:$G(OREBUILD) REBLD^ORCMENU K OREBUILD Q ; no change
  1. S T="" F S T=$O(^TMP("OR",$J,T)) Q:T="" D
  1. . I T="MEDS" K ^TMP("OR",$J,T) Q
  1. . S CTXT=$P($G(^TMP("OR",$J,T,0)),U,3) S:$L(CTXT) ORT(T,0)="^^"_$S(T="NOTES"&($P(CTXT,";",3)=1):"",1:CTXT)_U_$P(^(0),U,4) ; save tab contexts
  1. D UNLOCK^ORX2(+ORVP) K ^TMP("OR",$J),^TMP("ORNEW",$J),^TMP("LRRR",$J)
  1. K VALMHDR,ORTAB,ORNEW,OREBUILD,OREBLD
  1. M ^TMP("OR",$J)=ORT D TAB(TAB) S VALMBCK="R"
  1. Q
  1. ;
  1. ORDERS(ACTION) ; -- Return order numbers to act on, if action chosen first
  1. N X,Y,DIR,MAX S:'$L($G(ACTION)) ACTION="act on"
  1. S MAX=+$P($G(^TMP("OR",$J,ORTAB,0)),U,2) Q:MAX'>0 "^"
  1. S DIR(0)="LAO^1:"_MAX,DIR("A")="Select item(s): " S:MAX=1 DIR("B")=1
  1. S DIR("?")="Enter the items you wish to "_ACTION_", as a range or list of numbers"
  1. D ^DIR S:$D(DTOUT)!(Y="") Y="^"
  1. Q Y
  1. ;
  1. ALL ; -- Return all items on ORTAB
  1. N X,Y,DIR,MAX
  1. S MAX=+$P($G(^TMP("OR",$J,ORTAB,0)),U,2) Q:MAX'>0 ""
  1. S DIR(0)="L^1:"_MAX,DIR("V")="",X="1-"_MAX D ^DIR
  1. Q Y
  1. ;
  1. SELECT(NMBR) ; -- rev video on selected items
  1. N ORI,ORJ,NUM,ROW,ROWS,VALID S VALID=0
  1. F ORI=1:1:$L(NMBR,",") S NUM=$P(NMBR,",",ORI) I NUM D
  1. . I '$L($P($G(@VALMAR@("IDX",NUM)),U)) W !,NUM_" is not a valid selection." H 2 Q
  1. . S VALID=1
  1. . S ROW=$P(@VALMAR@("IDX",NUM),U,2),ROWS=$P(^(NUM),U,3)
  1. . F ORJ=ROW:1:(ROW+ROWS-1) I ORJ'<VALMBG,ORJ'>(VALMBG+VALM("LINES")-1) D
  1. . . K ^TMP("VALM VIDEO",$J,VALMEVL,ORJ)
  1. . . D CNTRL^VALM10(ORJ,1,80,IORVON,IORVOFF)
  1. . . D WRITE^VALM10(ORJ)
  1. I 'VALID S XQORQUIT=1
  1. Q
  1. ;
  1. DESELECT(NMBR) ; -- norm video on selected items
  1. N ORI,ORJ,NUM,IFN,ROW,ROWS,ON,OFF,I,IDX
  1. F ORI=1:1:$L(NMBR,",") S NUM=$P(NMBR,",",ORI) I NUM D
  1. . S IDX=$G(@VALMAR@("IDX",NUM)) Q:'$L(IDX) ;invalid NUM
  1. . S IFN=$P(IDX,U),ROW=$P(IDX,U,2),ROWS=$P(IDX,U,3)
  1. . F ORJ=ROW:1:(ROW+ROWS-1) I ORJ'<VALMBG,ORJ'>(VALMBG+VALM("LINES")-1) D
  1. . . K ^TMP("VALM VIDEO",$J,VALMEVL,ORJ) Q:'$L(IFN) ;deleted
  1. . . S ON=IOINHI,OFF=IOINORM
  1. . . I ORTAB="ORDERS",$G(^OR(100,+IFN,8,+$P(IFN,";",2),3)) S ON=IORVON,OFF=IORVOFF ; flagged
  1. . . D CNTRL^VALM10(ORJ,1,5,ON,OFF)
  1. . . I ORTAB="ORDERS" S I=$F(^TMP("OR",$J,ORTAB,ORJ,0),"*UNSIGNED*") I I D CNTRL^VALM10(ORJ,I-10,10,IOINHI,IOINORM)
  1. . . I ORTAB="XRAYS" S I=$F(^TMP("OR",$J,ORTAB,ORJ,0),"*ABNORMAL*") I I D CNTRL^VALM10(ORJ,I-10,10,IOINHI,IOINORM)
  1. . . I ORTAB="LABS" D CNTRL^VALM10(ORJ,24,2,IOINHI,IOINORM)
  1. . . D:VALMBCK="" WRITE^VALM10(ORJ)
  1. Q
  1. ;
  1. CHANGE ; -- Change view of current list
  1. G EN^ORCHANGE
  1. Q
  1. ;
  1. REV(ORVP) ; -- Review orders for patient
  1. Q:'$G(ORVP) Q:$D(ZTQUEUED) Q:$G(DGQUIET) ;silent
  1. I $D(SDAMEVT) Q:$S(SDAMEVT=1:0,1:1) ;continue if new appt
  1. Q:'$$GET^XPAR("ALL","ORPF REVIEW ON PATIENT MVMT")
  1. Q:'$$ACCESS^ORCHTAB ;CPRS not in user's option menu tree
  1. N X,Y,DIR,DTOUT,DUOUT,DIRUT,DIROUT,DFN ;protect DFN
  1. S DFN=+ORVP,ORVP=DFN_";DPT(" Q:'$D(^OR(100,"AC",ORVP)) ; no orders
  1. S DIR(0)="YA",DIR("A")="Review active orders? ",DIR("B")="YES"
  1. S DIR("?")="Answer YES to review this patient's active orders"
  1. D ^DIR Q:Y'>0 K DIR
  1. D SLCT1^ORQPT Q:'$G(ORVP)
  1. S ORTAB="ORDERS" D EN^VALM("OR CHART")
  1. Q
  1. ;
  1. VIEW() ; -- return line 3 of header w/current view of tab
  1. N BEGIN,END,ITEMS,STS,TEXT,X
  1. I $G(ORTAB)']"" Q ""
  1. S X=$P($G(^TMP("OR",$J,ORTAB,0)),U,3),TEXT=""
  1. S BEGIN=$P(X,";"),END=$P(X,";",2),STS=$P(X,";",3),ITEMS=$P(X,";",5)
  1. I ORTAB="NOTES",(STS'=5) S TEXT=$S(ITEMS:"up to "_ITEMS,1:"all")_$S(STS=1:" notes",STS=2:" unsigned notes",STS=3:" uncosigned notes",STS=4:" signed notes by author",1:"")
  1. E D
  1. . S:$L(BEGIN)!$L(END) TEXT=$$FDATE^VALM1($$DT^ORCHTAB1(BEGIN))_" thru "_$$FDATE^VALM1($$DT^ORCHTAB1(END))
  1. . I ORTAB="XRAYS",ITEMS>0 S TEXT=$S($L(TEXT):TEXT_", ",1:"")_"limit "_ITEMS
  1. S:$L(TEXT) TEXT="Current View: "_TEXT,TEXT=$J(TEXT,40+($L(TEXT)\2))
  1. Q TEXT