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

PXRMDLG4.m

Go to the documentation of this file.
  1. PXRMDLG4 ;SLC/PJH - Reminder Dialog Edit/Inquiry ;09/09/2020
  1. ;;2.0;CLINICAL REMINDERS;**4,6,12,16,26,45,71**;Feb 04, 2005;Build 43
  1. ;
  1. WP(SUB,SUB1,WIDTH,SEQ,VALMCNT) ;Format WP text
  1. N DIWF,DIWL,DIWR,IC,TEXT,X,TXTCNT,DTXT,CNT,SUB2
  1. S (CNT,SUB2,TXTCNT)=0
  1. F S SUB2=$O(^PXRMD(801.41,SUB,SUB1,SUB2)) Q:'SUB2 D
  1. .S TXTCNT=TXTCNT+1,DTXT(TXTCNT)=$G(^PXRMD(801.41,SUB,SUB1,SUB2,0))
  1. .S DTXT(TXTCNT)=$$STRREP^PXRMUTIL($G(DTXT(TXTCNT)),"<br>","\\")
  1. I TXTCNT>0 D
  1. .N OUTPUT,NLINES
  1. .S NLINES=0 D FORMAT^PXRMTEXT(1,WIDTH,TXTCNT,.DTXT,.NLINES,.OUTPUT)
  1. .I NLINES>0 K DTXT M DTXT=OUTPUT
  1. S CNT=0
  1. F S CNT=$O(DTXT(CNT)) Q:CNT="" D
  1. .S TEXT=$G(DTXT(CNT)),VALMCNT=VALMCNT+1
  1. .S ^TMP(NODE,$J,VALMCNT,0)=SEQ_TEXT,SEQ=$J("",$L(SEQ))
  1. Q
  1. ;
  1. ADD ;PXRM DIALOG ADD ELEMENT validation
  1. N ANS,DTOUT,DUOUT,LIT,LOCK,Y,PIEN,ERR,IEN,NATIONAL,SEQ
  1. W IORESET
  1. S VALMBCK="R",NATIONAL=0
  1. I $P($G(^PXRMD(801.41,PXRMDIEN,100)),U)="N" S NATIONAL=1
  1. S LOCK=$P($G(^PXRMD(801.41,PXRMDIEN,100)),U,4)
  1. I NATIONAL,'($G(PXRMINST)=1)&(DUZ(0)="@"),$G(LOCK)'=1 D Q
  1. .W !,"Elements may not be added to national reminder dialogs" H 2
  1. ;
  1. F D SEQ(.SEQ,.PIEN) Q:$D(DUOUT)!$D(DTOUT) Q:SEQ
  1. Q:$D(DUOUT)!$D(DTOUT)
  1. ;
  1. ;Check if sequence number is OK
  1. I $G(PIEN)="" Q
  1. S ANS="N" D ASK^PXRMDLG5(.ANS,PIEN) Q:$D(DUOUT)!$D(DTOUT)!($G(ANS)="N")
  1. ;
  1. ;Select a dialog element to add to parent dialog (PIEN)
  1. ;PIEN may be dialog or a group within the dialog
  1. D ESEL^PXRMDEDT(PIEN,SEQ)
  1. ;Rebuild workfile
  1. D BUILD^PXRMDLG(PXRMMODE)
  1. Q
  1. ;
  1. FADD(DIEN,FTAB,VIEW,NLINE) ;Additional Findings
  1. N FIND,FSUB,FTYP,FNAME,FNUM
  1. S FSUB=0
  1. F S FSUB=$O(^PXRMD(801.41,DIEN,3,FSUB)) Q:'FSUB D
  1. .S FIND=$P($G(^PXRMD(801.41,DIEN,3,FSUB,0)),U) Q:FIND=""
  1. .S FNAME="" D FDESC(FIND) Q:FNAME=""
  1. .;
  1. .;Save additional finding name
  1. .S FOUND=1 D FSAVE(2,FNAME,FTYP,FTAB,FIND)
  1. .I VIEW=2,FIND["PXD(811.2," D TAXDISP^PXRMDTAX(FIND,"",DIEN,.NLINE,NODE,1,0)
  1. Q
  1. ;
  1. DETAIL(DIEN,LEV,VIEW,NODE) ;;Build List Manager global for all components
  1. N DDATA,DDLG,DEND,DCIEN,DNAM,DSEQ,DSTRT,IND,JND,DSUB
  1. S DSEQ=0
  1. ;
  1. ;Get each sequence number
  1. F S DSEQ=$O(^PXRMD(801.41,DIEN,10,"B",DSEQ)) Q:'DSEQ D
  1. .;Determine subscript
  1. .S DSUB=$O(^PXRMD(801.41,DIEN,10,"B",DSEQ,"")) Q:'DSUB
  1. .;Get IEN of prompt/component
  1. .S DCIEN=$P($G(^PXRMD(801.41,DIEN,10,DSUB,0)),U,2) Q:'DCIEN
  1. .I "PF"[$P($G(^PXRMD(801.41,DCIEN,0)),U,4) D Q
  1. ..S ^TMP("PXRMDLG PROMPTS",$J,DCIEN)=""
  1. ..;S ^TMP("PXRMDLG4",$J,"IEN",NSEL)=DIEN_U_DSEQ
  1. ..;S ^TMP("PXRMDLG4",$J,"SEQ",LEV_DSEQ)=DCIEN
  1. ..S ^TMP("PXRMDLG4",$J,"PIEN",NSEL)=DIEN_U_DSEQ
  1. ..S ^TMP("PXRMDLG4",$J,"PSEQ",LEV_DSEQ)=DCIEN
  1. .;Save line in workfile
  1. .D DLINE(DCIEN,LEV,DSEQ,NODE)
  1. .;Build pointers back to parent
  1. .I VIEW'=4 D
  1. ..S ^TMP("PXRMDLG4",$J,"IEN",NSEL)=DIEN_U_DSEQ
  1. ..S ^TMP("PXRMDLG4",$J,"SEQ",LEV_DSEQ)=DCIEN
  1. .;Process any sub-components
  1. .I VIEW<5 D DETAIL(DCIEN,LEV_DSEQ_".",VIEW,NODE)
  1. Q
  1. ;
  1. DLINE(DIEN,LEV,DSEQ,NODE) ;Save individual component details
  1. N CNT,DBOX,DCAP,DDIS,DGRP,DMULT,DSUPP,DSHOW,DTYP,DTXT
  1. N IC,RESNM,RESULT,RIEN,RNAME,RCNT
  1. ;Dialog name: TESTDATA defined and NEW in PXRMDLG7
  1. S DDATA=$S($G(TESTDATA)'="":TESTDATA,1:$G(^PXRMD(801.41,DIEN,0)))
  1. ;S DDATA=$G(^PXRMD(801.41,DIEN,0))
  1. S DNAM=$P(DDATA,U) Q:DNAM=""
  1. ;Check if standard PXRM prompt
  1. I $$PXRM^PXRMEXID(DNAM) Q
  1. ;Dialog Type and Disabled
  1. S DDIS=$P(DDATA,U,3),DTYP=$P(DDATA,U,4)
  1. S DTYP=$S(DTYP="G":"Group",1:"Element"),DNAM=DTYP_": "_DNAM
  1. I VIEW=5 S DNAM=DNAM
  1. ;Resolution type and name
  1. S RNAME="",RIEN=$P($G(^PXRMD(801.41,DIEN,1)),U,3)
  1. I RIEN S RNAME=$P($G(^PXRMD(801.9,RIEN,0)),U)
  1. ;
  1. ;Group fields
  1. I DTYP="Group" D
  1. .S DGRP=1,DTXT=$P(DDATA,U,5),DCAP=" [group caption]"
  1. .I DTXT="" S DCAP=""
  1. .I DTXT]"" S DCAP=DTXT_" "_DCAP
  1. .S DBOX=$S($P(DDATA,U,6)="Y":"BOX",1:"NO BOX")
  1. .S DSUPP=$S($P(DDATA,U,11)=1:"SUPPRESS",$P(DDATA,U,11)="C":"CHECKED",1:"NO SUPPRESS")
  1. .S DSHOW=$S($P(DDATA,U,10):"HIDE",1:"SHOW")
  1. .S DMULT=$P(DDATA,U,9)
  1. .S DMULT=$S(DMULT=1:"ONE ONLY",DMULT=2:"ONE OR MORE",DMULT=3:"NONE OR ONE",DMULT=4:"ALL REQUIRED",1:"NO SELECTION")
  1. ;
  1. N DPTX,DTXT,EXIST,ITEM,TEMP,SEP,SEQ,TAB,ALTLEN
  1. S NSEL=NSEL+1,NLINE=NLINE+1,ITEM=NSEL,SEP=$E(LEV,$L(LEV)),SEQ=LEV_DSEQ
  1. ;Suppress Item numbers for INQ options
  1. I VIEW=4 S ITEM=""
  1. ;Otherwise display Item, Sequence and Dialog Name
  1. S TEMP=$J(ITEM,4)_$J("",3)_SEQ,TAB=$L(TEMP)+2
  1. S CNT=0 F IC=1:1 Q:'$P(SEQ,".",IC) S:$P(SEQ,".",IC)<10 CNT=CNT+1
  1. S TAB=TAB+CNT
  1. ;
  1. S ALTLEN=$L(TEMP)
  1. ;Display dialog name
  1. S TEMP=TEMP_$J("",2+CNT)_DNAM
  1. ;Add disabled if present
  1. I +DDIS>0 S TEMP=TEMP_" (Disabled)"
  1. ;
  1. S ^TMP(NODE,$J,NLINE,0)=TEMP
  1. ;check for alternate dialog element/group
  1. I VIEW<2!(VIEW>4) D
  1. .I $D(^PXRMD(801.41,DIEN,"BL"))>0 D ALT^PXRMDLG5(DIEN,LEV,DSEQ,NODE,VIEW,.NLINE,CNT,ALTLEN)
  1. ;
  1. ;Dialog Text or P/N Text
  1. I (VIEW=2)!(VIEW=3)!(VIEW=4) D
  1. .N DGBEG,DGSUB,TSUB
  1. .S DGSUB=0,TSUB=$$TSUB^PXRMDLG1(DIEN,VIEW)
  1. .I VIEW=4 S DGBEG=$J("",TAB)_"Text: "
  1. .I VIEW'=4 S DGBEG=$J("",5+$L(SEQ)+CNT+$L(DTYP))_"Text: "
  1. .D WP(DIEN,TSUB,65,.DGBEG,.NLINE)
  1. .I DTYP="Group" D
  1. ..S TEMP=DGBEG_"["_DBOX_", "_DSUPP_", "_DSHOW_", "_DMULT_"]"
  1. ..S NLINE=NLINE+1,^TMP(NODE,$J,NLINE,0)=TEMP
  1. ;
  1. ;Set up selection index
  1. S ^TMP(NODE,$J,"IDX",NSEL,DIEN)=""
  1. ;Insert finding items
  1. I (VIEW=1)!(VIEW=4),("Element;Group"[DTYP) D
  1. .N DSUB,FDATA,FILENUM,FLIT,FLONG,FNAME,FOUND,FREP,FTYP,TEMP
  1. .;Findings
  1. .S FNAME="",FOUND=0
  1. .D FDESC($P($G(^PXRMD(801.41,DIEN,1)),U,5))
  1. .I FNAME'="" S FOUND=1 D FSAVE(1,FNAME,FTYP,TAB)
  1. .;Resolution
  1. .I RNAME]"" D
  1. ..S TEMP=$J("",TAB)_"Resolution: "_RNAME
  1. ..S NLINE=NLINE+1,^TMP(NODE,$J,NLINE,0)=TEMP
  1. .;Result Group
  1. .I VIEW=4 D
  1. ..S RCNT=0 F S RCNT=$O(^PXRMD(801.41,DIEN,51,RCNT)) Q:RCNT'>0 D
  1. ...S RESULT=$P($G(^PXRMD(801.41,DIEN,51,RCNT,0)),U)
  1. ...S RESNM=$P($G(^PXRMD(801.41,RESULT,0)),U) Q:RESNM=""
  1. ...S TEMP=$J("",TAB)_"Result Group: "_RESNM
  1. ...S NLINE=NLINE+1,^TMP(NODE,$J,NLINE,0)=TEMP
  1. .;Additional findings
  1. .D FADD(DIEN,TAB,VIEW,.NLINE)
  1. ;Get additional prompts
  1. I VIEW=2 D
  1. .S FIEN=$P($G(^PXRMD(801.41,DIEN,1)),U,5)
  1. .I $G(FIEN)["PXD(811.2," D TAXDISP^PXRMDTAX(FIEN,DSEQ,DIEN,.NLINE,NODE,0,0)
  1. .D FADD(DIEN,TAB,VIEW,.NLINE)
  1. I VIEW,VIEW<5,"Element;Group"[DTYP D PROMPT(DIEN,TAB,"Prompts: ",VIEW)
  1. ;
  1. I VIEW=4,$D(^PXRMD(801.41,DIEN,"BL"))>0 D ALT^PXRMDLG5(DIEN,LEV,DSEQ,NODE,VIEW,.NLINE,CNT,ALTLEN)
  1. S NLINE=NLINE+1
  1. S ^TMP(NODE,$J,NLINE,0)=$J("",79)
  1. Q
  1. ;
  1. FDESC(FIEN) ;Finding description
  1. N FGLOB,FITEM,FNUM
  1. S FGLOB=$P(FIEN,";",2) Q:FGLOB=""
  1. S FITEM=$P(FIEN,";") Q:FITEM=""
  1. S FNUM=" ["_FITEM_"]"
  1. I FGLOB["ICD9" D Q
  1. .S FTYP="DIAGNOSIS",FGLOB=U_FGLOB_FITEM_",0)"
  1. .S FNAME=$P($G(@FGLOB),U,3)_FNUM
  1. I FGLOB["WV" D Q
  1. .S FTYP="WH NOTIFICATION PURPOSE",FGLOB=U_FGLOB_FITEM_",0)"
  1. .S FNAME=$P($G(@FGLOB),U)_FNUM
  1. I FGLOB["ICPT" D Q
  1. .S FTYP="PROCEDURE",FGLOB=U_FGLOB_FITEM_",0)"
  1. .S FNAME=$P($G(@FGLOB),U,2)_FNUM
  1. I FGLOB["ORD(101.41" D Q
  1. .S FTYP="QUICK ORDER",FGLOB=U_FGLOB_FITEM_",0)"
  1. .S FNAME=$P($G(@FGLOB),U,2)_FNUM
  1. I FGLOB["PXRMD(801.46" D Q
  1. .S FTYP="GENERAL FINDING",FGLOB=U_FGLOB_FITEM_",0)"
  1. .S FNAME=$P($G(@FGLOB),U)_FNUM
  1. ;Short name for finding type
  1. S FTYP=$G(DEF1(FGLOB)) Q:FTYP=""
  1. ;Long name
  1. S FTYP=$G(DEF2(FTYP))
  1. S FGLOB=U_FGLOB_FITEM_",0)"
  1. S FNAME=$P($G(@FGLOB),U,1)_FNUM
  1. I FNAME="" S FNAME=$P($G(@FGLOB),U)_FNUM
  1. I FNAME="" S FNAME=FITEM
  1. Q
  1. ;
  1. FSAVE(DSUB,FNAME,FTYP,FTAB,FIEN) ;Save finding details
  1. N DCOL,IND,FMTSTR,NL,OUTPUT,TEMP,TEXT
  1. I DSUB>1 D
  1. . S DCOL=65-FTAB I DCOL<10 S DCOL=10
  1. . S FMTSTR=FTAB_"R^13L1^"_DCOL_"L"
  1. . S TEXT=U_"Add. Finding:"
  1. I DSUB=1 D
  1. . S DCOL=70-FTAB I DCOL<10 S DCOL=10
  1. . S FMTSTR=FTAB_"R^8L1^"_DCOL_"L"
  1. . S TEXT=U_"Finding:"
  1. S TEXT=TEXT_U_FNAME_" ("_FTYP_")"
  1. D COLFMT^PXRMTEXT(FMTSTR,TEXT," ",.NL,.OUTPUT)
  1. F IND=1:1:NL D
  1. . S NLINE=NLINE+1
  1. . S ^TMP(NODE,$J,NLINE,0)=OUTPUT(IND)
  1. Q
  1. ;
  1. PROMPT(IEN,TAB,TEXT,VIEW) ;additional prompts in the dialog file
  1. N DATA,DDIS,DGSEQ,DNAME,DSUB,DTITLE,DTXT,DTYP,SEQ,SUB
  1. S SEQ=0
  1. F S SEQ=$O(^PXRMD(801.41,IEN,10,"B",SEQ)) Q:'SEQ D
  1. .S SUB=$O(^PXRMD(801.41,IEN,10,"B",SEQ,"")) Q:'SUB
  1. .S DSUB=$P($G(^PXRMD(801.41,IEN,10,SUB,0)),U,2) Q:'DSUB
  1. .S DATA=$G(^PXRMD(801.41,DSUB,0)) Q:DATA=""
  1. .S DNAME=$P(DATA,U),DDIS=$P(DATA,U,3),DTYP=$P(DATA,U,4)
  1. .I "PF"'[DTYP Q
  1. .I DTYP="F" S DNAME=DNAME_" (forced value)"
  1. .I DTYP="P",(VIEW=2)!(VIEW=3) D
  1. ..;Override prompt caption
  1. ..S DTITLE=$P($G(^PXRMD(801.41,IEN,10,SUB,0)),U,6)
  1. ..I DTITLE="" S DTITLE=$P($G(^PXRMD(801.41,DSUB,2)),U,4)
  1. ..S DNAME=DTITLE
  1. .S DNAME=$J("",TAB)_TEXT_DNAME
  1. .S:+DDIS>0 DNAME=DNAME_" (Disabled)"
  1. .S NLINE=NLINE+1
  1. .S ^TMP(NODE,$J,NLINE,0)=DNAME
  1. .S TEXT=$J("",$L(TEXT))
  1. Q
  1. ;
  1. SEQ(SEQ,PIEN) ;Select sequence number to add
  1. N X,Y,TEXT,DIR
  1. K DIROUT,DIRUT,DTOUT,DUOUT
  1. S SEQ=0
  1. S DIR(0)="FA0;1;30"
  1. S DIR("A")="Enter a new SEQUENCE NUMBER: "
  1. S DIR("?")="Enter new sequence number. For detailed help type ??"
  1. S DIR("??")=U_"D HELP^PXRMDLG4(1)"
  1. D ^DIR K DIR
  1. I $D(DIROUT) S DTOUT=1
  1. I $D(DTOUT)!($D(DUOUT)) Q
  1. ;
  1. ;Check that sequence number is new
  1. I $D(^TMP("PXRMDLG4",$J,"SEQ",X)) D Q
  1. .W !,"Sequence number "_X_" already in use."
  1. ;Check that sequence number is new and not being used by prompts
  1. I $D(^TMP("PXRMDLG4",$J,"PSEQ",X)) D Q
  1. .W !,"Sequence number "_X_" already in use."
  1. ;
  1. ;Check that the parent is a group or reminder dialog
  1. I X["." D Q:X=""
  1. .N CLASS,SUB
  1. .;Sequence number of parent
  1. .S SUB=$P(X,".",1,$L(X,".")-1)
  1. .I $G(SUB)=""!($G(SUB)=0) W !,"Invalid sequence number. A sequence number cannot be less then 1" H 2 Q
  1. .;Get IEN of parent dialog or group
  1. .S PIEN=$G(^TMP("PXRMDLG4",$J,"SEQ",SUB))
  1. .;Validate sequence number
  1. .I 'PIEN W !,"Sequence number is not part of an existing group." S X="" Q
  1. .;Validate that the parent is a group or reminder dialog
  1. .I "RG"'[$P($G(^PXRMD(801.41,PIEN,0)),U,4) D S X="" Q
  1. ..W !,"New sequences can only be added to groups or reminder dialogs"
  1. .;Disallow adding elements to national dialogs or groups
  1. .I $P($G(^PXMRD(801.41,PIEN,100)),U)="N" D Q:X=""
  1. ..Q:(DUZ(0)="@")&($G(PXRMINST)=1)
  1. ..W !,"Elements cannot be added to a national group" S X=""
  1. ;
  1. ;If adding to top level parent ien is reminder dialog
  1. I X?.N S PIEN=PXRMDIEN
  1. ;
  1. S SEQ=$P(X,".",$L(X,"."))
  1. Q
  1. ;
  1. ;
  1. HELP(CALL) ;General help text routine.
  1. N HTEXT
  1. N DIWF,DIWL,DIWR,IC
  1. S DIWF="C75",DIWL=0,DIWR=75
  1. ;
  1. I CALL=1 D
  1. .S HTEXT(1)="Sequence numbers can be added at any level. Specify the full"
  1. .S HTEXT(2)="number for the level required (e.g. 15.10.20)."
  1. ;
  1. D HELP^PXRMEUT(.HTEXT)
  1. Q
  1. ;