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

ORCMEDT4.m

Go to the documentation of this file.
  1. ORCMEDT4 ;SLC/MKB-Prompt Editor ;10/08/19 16:41
  1. ;;3.0;ORDER ENTRY/RESULTS REPORTING;**8,46,95,245,313,389,397,377**;Dec 17, 1997;Build 582
  1. ;;Per VHA Directive 2004-038, this routine should not be modified.
  1. EN ; -- Enter/edit prompts
  1. N PRMT F S PRMT=+$$PROMPT Q:PRMT'>0 D W !
  1. . I $P($G(^ORD(101.41,PRMT,0)),U,7)=$O(^DIC(9.4,"C","OR",0)) D Q
  1. . . N DIC,DA S DIC="^ORD(101.41,",DA=PRMT D EN^DIQ
  1. . . W !,"This prompt is not editable!"
  1. . D EDIT(PRMT)
  1. Q
  1. ;
  1. EDIT(DA) ; -- Edit prompt DA
  1. N DR,DIE,NAME,TEXT,TYPE,DOMAIN,OR0,OR1,ORP
  1. Q:'$G(DA) S OR0=$G(^ORD(101.41,DA,0)),OR1=$G(^(1)),ORP=DA
  1. S NAME=$$NAME(DA) Q:(NAME="@")!(NAME="^") ;deleted or quit
  1. S TEXT=$$DTEXT($P(OR0,U,2)) Q:TEXT="^"
  1. S TYPE=$$DATATYPE($P(OR1,U)) Q:TYPE="^" S DOMAIN=$P(OR1,U,2)
  1. D @$S(TYPE="D"!(TYPE="R"):"DATE",TYPE="F":"TEXT",TYPE="N":"NMBR",TYPE="P":"PTR",TYPE="S":"SET",1:"OTHER") Q:DOMAIN="^"
  1. S $P(^ORD(101.41,DA,1),U,1,2)=TYPE_U_DOMAIN,DIE="^ORD(101.41,"
  1. S DR=$S(NAME'=$P(OR0,U):".01///^S X=NAME;",1:"")_$S(TEXT'=$P(OR0,U,2):"2///^S X=TEXT;",1:"")_"20"_";13" D ^DIE ;95
  1. Q
  1. ;
  1. PROMPT() ; -- Find prompt in #101.41
  1. N X,Y,DIC,DLAYGO
  1. S DIC="^ORD(101.41,",DIC(0)="AEQLM",DLAYGO=101.41
  1. S DIC("A")="Select PROMPT: ",DIC("S")="I $P(^(0),U,4)=""P"""
  1. S DIC("DR")="4////P" D ^DIC
  1. Q Y
  1. ;
  1. NAME(IFN) ; -- Edit .01 name of dialog IFN
  1. N X,Y,DIR,OLDNAME,ISPQO,NODELETE,DA,DIK,TYPE
  1. S DIR(0)="FAO^3:63",DIR("A")="NAME: "
  1. S OLDNAME=$P($G(^ORD(101.41,IFN,0)),U),ISPQO=0,NODELETE=1
  1. S TYPE=$P($G(^ORD(101.41,IFN,0)),U,4)
  1. I TYPE="Q",$E(OLDNAME,1,6)="ORWDQ " S ISPQO=1
  1. I ISPQO!(TYPE="P") S NODELETE=0 ; OK to delete personal quick orders and prompts
  1. S DIR("B")=OLDNAME
  1. S DIR("?")="Enter a unique name, up to 63 characters in length."
  1. NM I $L($P($G(^ORD(101.41,IFN,0)),U,3))>0 W !,!,"(This "_$$GETITM(IFN)_" has been disabled)"
  1. D ^DIR S:$D(DTOUT)!(X["^") Y="^"
  1. I X="@" D G NM:X=""
  1. . I $D(^ORD(101.41,"AD",IFN)) W $C(7),!,"Cannot delete - currently in use!",! S X="" Q
  1. . I $$INUSE^ORCMEDT5(IFN) W $C(7),!,"Cannot delete - currently an Add Orders Menu!",! S X="" Q
  1. . S NODELETE=$$PTRCHK(IFN,"ORDLG PTRS") I NODELETE D
  1. . . N CONTINUE W $C(7),!,"Cannot delete - other file entries point to this order dialog!",!
  1. . . S CONTINUE=$$CONT D:CONTINUE'["^" PTRRPT("ORDLG PTRS",IFN)
  1. . I NODELETE D DISABLE(IFN) S X="" Q
  1. . I '$$SURE(IFN) S X="" Q ;reask
  1. . N IDX1,IDX2 S IDX1=0
  1. . F S IDX1=$O(^ORD(101.44,"C",IFN,IDX1)) Q:'IDX1 D
  1. . . S IDX2=0
  1. . . F S IDX2=$O(^ORD(101.44,"C",IFN,IDX1,IDX2)) Q:'IDX2 D
  1. . . . S DA=IDX2,DA(1)=IDX1,DIK="^ORD(101.44,"_IDX1_",10," D ^DIK
  1. . K DA S DA=IFN,DIK="^ORD(101.41," D ^DIK W " ...deleted." S (X,Y)="@"
  1. I ISPQO,Y'="^",X'="@",Y'=OLDNAME D G NM
  1. . W $C(7),!,"Cannot rename a personal quick order",!
  1. K ^TMP($J,"ORDLG PTRS")
  1. Q Y
  1. ;
  1. GETITM(DLG) ;
  1. N ITM
  1. S ITM=$P($G(^ORD(101.41,DLG,0)),U,4)
  1. I ITM="Q",$E($P($G(^ORD(101.41,IFN,0)),U),1,6)="ORWDQ " Q "personal quick order"
  1. S ITM=$S(ITM="P":"prompt",ITM="D":"dialog",ITM="Q":"quick order",ITM="O":"order set",ITM="A":"action",ITM="M":"menu",1:"item")
  1. Q ITM
  1. ;
  1. SURE(DLG) ; -- Are you sure?
  1. N X,Y,DIR,ITM,DA
  1. S ITM=$$GETITM(DLG)
  1. S DIR(0)="YA",DIR("A")="Are you sure you want to delete this "_ITM_"? "
  1. S DIR("?")="Enter YES if you want to delete this "_ITM_" from the file, or NO to quit."
  1. D ^DIR
  1. Q +Y
  1. ;
  1. DISABLE(DLG) ; Disable item - return true if disabled
  1. N DIR,X,Y,ITM,DA,DR,DIE,DIDEL,DISABLED
  1. ;W $C(7),!,!,"Deletion not allowed outside of FileMan."
  1. S ITM=$$GETITM(DLG)
  1. S DISABLED=$L($P($G(^ORD(101.41,IFN,0)),U,3))>0
  1. S DIR(0)="YA"
  1. I DISABLED D I 1
  1. . S DIR("A",1)="This "_ITM_" is already disabled."
  1. . S DIR("A")="Would you like to edit the disable message? "
  1. . S DIR("?")="Enter YES if you want to edit the disabled message, or NO to quit."
  1. . S DIR("B")="NO"
  1. E D
  1. . S DIR("A")="Would you like to disable this "_ITM_"? "
  1. . S DIR("?")="Enter YES if you want to disable this "_ITM_", or NO to quit."
  1. . S DIR("B")="YES"
  1. D ^DIR
  1. I '+Y Q
  1. W !,"Enter disable message:"
  1. S DA=DLG,DR="3",DIE="^ORD(101.41,"
  1. D ^DIE
  1. Q
  1. ;
  1. DTEXT(X) ; -- Enter/edit display text of prompt
  1. N Y,DIR
  1. S DIR(0)="FA^3:63",DIR("A")="TEXT OF PROMPT: " S:$L($G(X)) DIR("B")=X
  1. S DIR("?")="Enter the text of this prompt, including any punctuation and spaces"
  1. D ^DIR S:$D(DTOUT) Y="^"
  1. Q Y
  1. ;
  1. DATATYPE(X) ; -- Returns desired datatype for prompt
  1. N DIR,Y S DIR("A")="TYPE OF PROMPT: "
  1. S DIR(0)="SAM^D:date/time;R:relative date/time;F:free text;N:numeric;S:set of codes;P:pointer to a file;Y:yes/no;W:word processing;"
  1. S:$L($G(X)) DIR("B")=$P($P(DIR(0),X_":",2),";")
  1. S DIR("?")="Select the type of data to be entered at this prompt"
  1. D ^DIR S:$D(DTOUT) Y="^"
  1. Q Y
  1. ;
  1. DATE ; -- date parameters
  1. N X,Y,DIR,ORX,ORT,ORS,ORR
  1. S X=$P(DOMAIN,":",3),ORX=X["X",ORT=X["T",ORS=X["S",ORR=X["R",DIR(0)="YA"
  1. ; Still need to handle Earliest and Latest dates allowed
  1. S DIR("A")="CAN DATE BE IMPRECISE? ",DIR("B")=$S(ORX:"NO",1:"YES")
  1. D ^DIR S ORX='Y I $D(DUOUT)!($D(DTOUT)) S DOMAIN="^" Q
  1. S DIR("A")="CAN TIME OF DAY BE ENTERED? ",DIR("B")=$S(ORT:"YES",1:"NO")
  1. D ^DIR I $D(DUOUT)!($D(DTOUT)) S DOMAIN="^" Q
  1. S ORT=Y I 'Y S (ORS,ORR)=0 G DQ
  1. S DIR("A")="CAN SECONDS BE ENTERED? ",DIR("B")=$S(ORS:"YES",1:"NO")
  1. D ^DIR S ORS=Y I $D(DUOUT)!($D(DTOUT)) S DOMAIN="^" Q
  1. S DIR("A")="IS TIME REQUIRED? ",DIR("B")=$S(ORR:"YES",1:"NO")
  1. D ^DIR S ORR=Y I $D(DUOUT)!($D(DTOUT)) S DOMAIN="^" Q
  1. DQ S DOMAIN="::E"_$S(ORX:"X",1:"")_$S(ORT:"T",1:"")_$S(ORS:"S",1:"")_$S(ORR:"R",1:"")
  1. Q
  1. ;
  1. TEXT ; -- free text
  1. N X,Y,DIR
  1. S DIR(0)="NAO^1:245",DIR("A")="MINIMUM LENGTH: "
  1. S:+DOMAIN DIR("B")=+DOMAIN
  1. D ^DIR I $D(DTOUT)!($D(DUOUT)) S DOMAIN="^" Q
  1. S $P(DOMAIN,":")=Y,DIR("A")="MAXIMUM LENGTH: " K DIR("B")
  1. S:$P(DOMAIN,":",2) DIR("B")=$P(DOMAIN,":",2)
  1. D ^DIR I $D(DUOUT)!($D(DTOUT)) S DOMAIN="^" Q
  1. S $P(DOMAIN,":",2)=Y
  1. ; Opt pattern match ??
  1. Q
  1. ;
  1. NMBR ; -- numeric
  1. N X,Y,DIR,STR
  1. S DIR(0)="NAO^::"_+$P(DOMAIN,":",3),DIR("A")="INCLUSIVE LOWER BOUND: ",DIR("B")=+DOMAIN ;95
  1. D ^DIR I $D(DTOUT)!($D(DUOUT)) S DOMAIN="^" Q
  1. S STR=Y,DIR(0)="NAO^"_Y_"::"_+$P(DOMAIN,":",3),DIR("A")="INCLUSIVE UPPER BOUND: ",DIR("B")=+$P(DOMAIN,":",2) ;95
  1. D ^DIR I $D(DTOUT)!($D(DUOUT)) S DOMAIN="^" Q
  1. S STR=STR_":"_Y,DIR(0)="NAO",DIR("A")="MAXIMUM NUMBER OF FRACTIONAL DIGITS: ",DIR("B")=+$P(DOMAIN,":",3) ;95
  1. D ^DIR I $D(DUOUT)!($D(DTOUT)) S DOMAIN="^" Q
  1. S DOMAIN=STR_":"_Y
  1. Q
  1. ;
  1. PTR ; -- pointer
  1. I DUZ(0)="@"!($L(DOMAIN)&'DOMAIN) D ROOT Q ; allow file root
  1. N X,Y,DIR,DIE,DR,FILE,STR,SCR
  1. S DIR(0)="PA^1:AEQM",DIR("A")="POINT TO WHICH FILE: "
  1. S:$L(DOMAIN) DIR("B")=$$FILENAME(+DOMAIN)
  1. D ^DIR I $D(DUOUT)!($D(DTOUT)) S DOMAIN="^" Q
  1. S FILE=+Y,STR=$P(DOMAIN,":",2) S:'$L(STR) STR="EQ"
  1. S DOMAIN=FILE_":"_STR
  1. Q
  1. ;
  1. ROOT ; -- pointer via file root
  1. N X,Y,DIR,STR
  1. S DIR(0)="FA^1:100",DIR("A")="POINT TO WHICH FILE: "
  1. S DIR("?")="Enter the file by name, file number, or global root (without the leading '^')."
  1. S:$L(DOMAIN) DIR("B")=$S(+DOMAIN:$$FILENAME(+DOMAIN),1:$P(DOMAIN,":"))
  1. RT1 D ^DIR I $D(DTOUT)!$D(DUOUT) S DOMAIN="^" Q
  1. I $L(DOMAIN),$L(X),X=$G(DIR("B")) S Y=$P(DOMAIN,":") G RTQ ; default
  1. I +Y=Y S X=$$FILENAME(+Y) I $L(X) W " "_X G RTQ ; valid file number
  1. I $L(Y),+Y'=Y D G:$D(Y) RTQ ; valid root or name
  1. . I "(,"[$E(Y,$L(Y)) Q:$D(@(U_Y_"0)")) ; valid file root
  1. . S DIC=1,DIC(0)="EQ",X=Y D ^DIC S:Y>0 Y=+Y K:Y'>0 Y
  1. W $C(7),!,"Invalid file!" G RT1
  1. RTQ S STR=$P(DOMAIN,":",2),DOMAIN=Y_":"_$S($L(STR):STR,1:"EQ")
  1. Q
  1. ;
  1. SET ; -- set of codes
  1. N I,ORI,ORJ,ITEM,X,Y,ORQUIT,NEWLNG S ORJ=0
  1. F I=1:1:$L(DOMAIN,";") S:$P(DOMAIN,";",I)'="" ITEM(I)=$P(DOMAIN,";",I)
  1. S ORI=0 F S ORI=$O(ITEM(ORI)) Q:ORI'>0 D SETEDIT Q:$G(ORQUIT)!(Y="")
  1. I $G(ORQUIT) S DOMAIN="^" Q
  1. S ORI=ORJ F S ORI=ORI+1 D SETEDIT Q:$G(ORQUIT)!(Y="") ; new codes
  1. I $G(ORQUIT) S DOMAIN="^" Q
  1. ; now done editing, rebuild DOMAIN
  1. S I=0,DOMAIN="" F S I=$O(ITEM(I)) Q:I'>0 S NEWLNG=$L(DOMAIN)+$L(ITEM(I))+1 S:NEWLNG'>235 DOMAIN=DOMAIN_ITEM(I)_";" I NEWLNG>235 W $C(7),!,"Domain too long - unable to store all codes." H 2 Q
  1. Q
  1. SETEDIT ; -- edit each item in DOMAIN
  1. N DIR,TEXT,CODE S DIR(0)="FAO^1:5",DIR("A")="INTERNALLY-STORED CODE: "
  1. S CODE=$P($G(ITEM(ORI)),":"),TEXT=$P($G(ITEM(ORI)),":",2),ORJ=ORI
  1. S:$L(CODE) DIR("B")=CODE
  1. D ^DIR S:$D(DUOUT)!($D(DTOUT)) ORQUIT=1 Q:$G(ORQUIT)!(X="")
  1. I X="@" K ITEM(ORI) Q
  1. S CODE=X W " WILL STAND FOR: " W:$L(TEXT) TEXT_"// "
  1. SE1 R Y:DTIME I '$T!(Y["^") S ORQUIT=1 Q
  1. S:Y="" Y=TEXT I "@"[Y W $C(7),!," Required value!",!,"'"_CODE_"' WILL STAND FOR: " W:$L(TEXT) TEXT_"// " G SE1
  1. S TEXT=Y,ITEM(ORI)=CODE_":"_TEXT
  1. Q
  1. ;
  1. OTHER ; -- no parameters needed
  1. S DOMAIN=""
  1. Q
  1. ;
  1. FILENAME(FNUM) ; -- Returns name of file FNUM
  1. N ORY,Y D:$G(FNUM) FILE^DID(+FNUM,,"NAME","ORY")
  1. S Y=$G(ORY("NAME"))
  1. Q Y
  1. PTRCHK(DLG,ARRNAME) ; --check for pointers to order dialog
  1. K ^TMP($J,ARRNAME)
  1. N AREPTRS,INC S AREPTRS=0
  1. I +$G(DLG) D
  1. .D APIONE^PXRMDLR3(ARRNAME,DLG,"ORD(101.41,",0)
  1. .I $D(^TMP($J,ARRNAME)) D
  1. ..;restructure data from PXRM API for report output to match format used in PTRRPT
  1. ..N IDX,IDX2,ORPXIEN,ORPXNAME S (IDX,IDX2)=0
  1. ..F S IDX=$O(^TMP($J,ARRNAME,DLG_";ORD(101.41,",IDX)) Q:+$G(IDX)=0 D
  1. ...F S IDX2=$O(^TMP($J,ARRNAME,DLG_";ORD(101.41,",IDX,IDX2)) Q:+$G(IDX2)=0 D
  1. ....Q:$P(^TMP($J,ARRNAME,DLG_";ORD(101.41,",IDX,IDX2),":")="Dialog" ;skip the top level reminder dialog
  1. ....S ORPXNAME=^TMP($J,ARRNAME,DLG_";ORD(101.41,",IDX,IDX2) ;" Dialog Element: TEST QO AS FINDING"
  1. ....Q:$P(ORPXNAME,":")'["Group"&($P(ORPXNAME,":")'["Element")
  1. ....S ORPXNAME=$P(ORPXNAME,":",2) ; " TEST QO AS FINDING"
  1. ....S ORPXNAME=$E(ORPXNAME,2,99) ; "TEST QO AS FINDING"
  1. ....S ORPXIEN=$O(^PXRMD(801.41,"B",ORPXNAME,""))
  1. ....S ^TMP($J,ARRNAME,801.41,ORPXIEN)=ORPXNAME
  1. .D OR100(DLG,ARRNAME)
  1. .D ORD10098(DLG,ARRNAME)
  1. S AREPTRS=$D(^TMP($J,ARRNAME))
  1. Q +AREPTRS
  1. ;
  1. PTRRPT(ARRNAME,ORIFN) ; --show list of pointers to order dialog
  1. N FILENUM,ITEMIEN,IEN,TAB,ITEM,LINCNT,CONTINUE S (FILENUM,ITEMIEN,IEN,CONTINUE)="",LINCNT=0
  1. F FILENUM=100.98,801.41,100 D
  1. .I $D(^TMP($J,ARRNAME,FILENUM)) D
  1. ..W @IOF S (CONTINUE,ITEMIEN)=""
  1. ..W !,$P(^ORD(101.41,ORIFN,0),U)_" is pointed to by:"
  1. ..W !,"FILE ",?13,"IEN",?23,"NAME"
  1. ..W !,$$REPEAT^XLFSTR("-",27)
  1. ..F S ITEMIEN=$O(^TMP($J,ARRNAME,FILENUM,ITEMIEN)) Q:ITEMIEN=""!(CONTINUE["^") D
  1. ...S ITEM=^TMP($J,ARRNAME,FILENUM,ITEMIEN)
  1. ...W !,$S(FILENUM=100:"ORDER",FILENUM=100.98:"DISPLAY GRP",FILENUM=801.41:"REMINDER DLG",1:FILENUM),?13,ITEMIEN
  1. ...W ?23,$S(FILENUM=100:"N/A",1:ITEM)
  1. ...S LINCNT=LINCNT+1
  1. ...I LINCNT#20=0 S CONTINUE=$$CONT I CONTINUE'["^" D HDR
  1. ...Q:CONTINUE["^"
  1. ..Q:$G(CONTINUE)="^" S CONTINUE=$$CONT Q:CONTINUE["^"
  1. K ^TMP($J,ARRNAME)
  1. Q
  1. ;
  1. OR100(DLG,ARR) ;100
  1. N ORIFN,TEMP
  1. S TEMP=DLG_";ORD(101.41,",ORIFN=""
  1. I $D(^OR(100,"C",TEMP)) D
  1. .F S ORIFN=$O(^OR(100,"C",TEMP,ORIFN)) Q:ORIFN="" D
  1. ..Q:$D(^OR(100,ORIFN))=0
  1. ..I $P(^OR(100,ORIFN,0),U,5)=TEMP D ;if DIALOG has pointer to order dialog
  1. ...S ^TMP($J,ARR,100,ORIFN)=$P(^OR(100,ORIFN,0),U,5)
  1. S ORIFN=""
  1. I $D(^OR(100,"D",TEMP)) D
  1. .F S ORIFN=$O(^OR(100,"D",TEMP,ORIFN)) Q:ORIFN="" D
  1. ..Q:$D(^OR(100,ORIFN))=0
  1. ..I $P(^OR(100,ORIFN,3),U,4)=TEMP D ;if ITEM ORDERED has pointer to order dialog
  1. ...S ^TMP($J,ARR,100,ORIFN)=$P(^OR(100,ORIFN,3),U,4)
  1. Q
  1. ;
  1. ORD10098(DLG,ARR) ;100.98
  1. N DISGRP,DISIEN S DISGRP="",DISIEN=""
  1. F S DISGRP=$O(^ORD(100.98,"B",DISGRP)) Q:DISGRP="" D
  1. .F S DISIEN=$O(^ORD(100.98,"B",DISGRP,DISIEN)) Q:DISIEN="" D
  1. ..Q:^ORD(100.98,"B",DISGRP,DISIEN)=1 ;second B x-ref entry for SHORT NAME, Q to avoid duplicates in results
  1. ..I $P(^ORD(100.98,DISIEN,0),U,4)=DLG D ;if DEFAULT DIALOG has pointer to order dialog
  1. ...S ^TMP($J,ARR,100.98,DISIEN)=$P(^ORD(100.98,DISIEN,0),U)
  1. Q
  1. ;
  1. HDR ;header
  1. W @IOF
  1. W !,"FILE ",?13,"IEN",?23,"NAME"
  1. W !,$$REPEAT^XLFSTR("-",27)
  1. Q
  1. CONT() ; -- gives user a chance to read output from pointer check
  1. N X,Y,DIR
  1. S DIR(0)="FO",DIR("A")="Press any key to continue reviewing pointer report"
  1. S DIR("?")="Enter any key to continue; enter ^ to exit."
  1. D ^DIR
  1. Q X
  1. ;