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

PXRMDLG3.m

Go to the documentation of this file.
  1. PXRMDLG3 ;SLC/PJH - Reminder Dialog Edit/Inquiry ;03/27/2015 08:40
  1. ;;2.0;CLINICAL REMINDERS;**45**;Feb 04, 2005;Build 566
  1. ;
  1. ;
  1. ;Display national dialog
  1. START N NLINE,NSEL
  1. S NLINE=0,NSEL=0
  1. ;
  1. ;Group header
  1. I $P($G(^PXRMD(801.41,PXRMDIEN,0)),U,4)="G" D
  1. .D DLINE(PXRMDIEN,"","")
  1. ;Other components
  1. D DETAIL(PXRMDIEN,"")
  1. ;Create headings
  1. D CHGCAP^VALM("HEADER1","Item Seq.")
  1. D CHGCAP^VALM("HEADER2","Dialog Details/Findings")
  1. D CHGCAP^VALM("HEADER3","Type")
  1. S VALMCNT=NLINE
  1. S ^TMP("PXRMDLG",$J,"VALMCNT")=VALMCNT
  1. EXIT Q
  1. ;
  1. ;Additional Findings
  1. ;-------------------
  1. ADD(DIEN) ;
  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. .;Save additional finding name
  1. .S FOUND=1 D SAVE(2,FNAME,FTYP)
  1. Q
  1. ;
  1. ;Build listman global for all components
  1. ;---------------------------------------
  1. DETAIL(PXRMDIEN,LEV) ;
  1. N DDATA,DDLG,DEND,DIEN,DNAM,DSEQ,DSTRT,IND,JND,DSUB
  1. S DSEQ=0
  1. ;
  1. ;Get each sequence number
  1. F S DSEQ=$O(^PXRMD(801.41,PXRMDIEN,10,"B",DSEQ)) Q:'DSEQ D
  1. .;Determine subscript
  1. .S DSUB=$O(^PXRMD(801.41,PXRMDIEN,10,"B",DSEQ,"")) Q:'DSUB
  1. .;Get ien of prompt/component
  1. .S DIEN=$P($G(^PXRMD(801.41,PXRMDIEN,10,DSUB,0)),U,2) Q:'DIEN
  1. .;Ignore prompts and forced values
  1. .I "PF"[$P($G(^PXRMD(801.41,DIEN,0)),U,4) Q
  1. .;Save line in workfile
  1. .D DLINE(DIEN,LEV,DSEQ)
  1. .;
  1. .;Process any sub-components
  1. .D DETAIL(DIEN,LEV_DSEQ_".")
  1. .;Extra line feed
  1. .I LEV="" D
  1. ..S NLINE=NLINE+1
  1. ..S ^TMP("PXRMDLG",$J,NLINE,0)=$J("",79)
  1. Q
  1. ;
  1. ;Save individual component details
  1. ;---------------------------------
  1. DLINE(DIEN,LEV,DSEQ) ;
  1. ;Dialog name
  1. S DNAM=$P($G(^PXRMD(801.41,DIEN,0)),U) Q:DNAM=""
  1. ;Check if standard PXRM prompt
  1. I $$PXRM^PXRMEXID(DNAM) Q
  1. ;
  1. N DPTX,DTXT,DTYP,EXIST,ITEM,TEMP,SEP
  1. S ITEM=""
  1. S NSEL=NSEL+1,ITEM=NSEL
  1. S NLINE=NLINE+1,SEP=$E(LEV,$L(LEV))
  1. S TEMP=$J(ITEM,3)_$J("",4)_LEV_DSEQ
  1. ;Determine type
  1. S DTYP=$S($P($G(^PXRMD(801.41,DIEN,0)),U,4)="G":"group",1:"element")
  1. ;Dialog component display
  1. I $L(TEMP)<13 S TEMP=TEMP_$J("",12+$L(SEP)-$L(TEMP))_$E(DNAM,1,50)
  1. E S TEMP=TEMP_" "_$E(DNAM,1,50)
  1. ;Add Type
  1. S ^TMP("PXRMDLG",$J,NLINE,0)=TEMP_$J("",70-$L(TEMP))_DTYP
  1. ;
  1. ;Set up selection index
  1. S ^TMP("PXRMDLG",$J,"IDX",NSEL,DIEN)=""
  1. ;
  1. ;Insert finding items
  1. I ("element;group"[DTYP) D
  1. .N DSUB,FDATA,FILENUM,FLIT,FLONG,FNAME,FOUND,FREP,FTAB,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 SAVE(1,FNAME,FTYP)
  1. .;Additional findings (see ADD^PXRMDLG2)
  1. .D ADD(DIEN)
  1. .;If no findings
  1. .I 'FOUND D
  1. ..S NLINE=NLINE+1
  1. ..S ^TMP("PXRMDLG",$J,NLINE,0)=$J("",12+$L(SEP))_"Finding: *NONE*"
  1. Q
  1. ;
  1. ;Finding description
  1. ;-------------------
  1. FDESC(FIEN) ;
  1. N FGLOB,FITEM
  1. ;Determine finding type
  1. S FGLOB=$P(FIEN,";",2) Q:FGLOB=""
  1. S FITEM=$P(FIEN,";") Q:FITEM=""
  1. ;Diagnosis POV
  1. I FGLOB["ICD9" D Q
  1. .S FTYP="DIAGNOSIS",FGLOB=U_FGLOB_FITEM_",0)"
  1. .S FNAME=$P($G(@FGLOB),U,3)
  1. I FGLOB["WV" D Q
  1. .S FTYP="WH NOTIFICATION PURPOSE",FGLOB=U_FGLOB_FITEM_",0)"
  1. .S FNAME=$P($G(@FGLOB),U)
  1. ;Procedure CPT
  1. I FGLOB["ICPT" D Q
  1. .S FTYP="PROCEDURE",FGLOB=U_FGLOB_FITEM_",0)"
  1. .S FNAME=$P($G(@FGLOB),U,2)
  1. ;Quick order
  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)
  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)
  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)
  1. I FNAME="" S FNAME=$P($G(@FGLOB),U)
  1. I FNAME]"" S FNAME=FNAME Q
  1. S FNAME=FITEM
  1. Q
  1. ;
  1. ;Save finding details
  1. ;--------------------
  1. SAVE(DSUB,FNAME,FTYP) ;
  1. N TEMP
  1. I DSUB=1 S FLIT="Finding: "
  1. I DSUB>1 S FLIT="Add. Finding: "
  1. S FLONG=0
  1. I $L(FLIT_FNAME_" ("_FTYP_")")>60 S FLONG=1
  1. I 'FLONG S FNAME=FLIT_FNAME_" ("_FTYP_")"
  1. I FLONG S FNAME=FLIT_FNAME
  1. S TEMP=$J("",12+$L(SEP))_$E(FNAME,1,60)_$J("",60-$L(FNAME))
  1. S NLINE=NLINE+1
  1. S ^TMP("PXRMDLG",$J,NLINE,0)=TEMP
  1. I FLONG D
  1. .S NLINE=NLINE+1
  1. .S FTAB=$S(DSUB=1:21,1:26)
  1. .S ^TMP("PXRMDLG",$J,NLINE,0)=$J("",FTAB)_"("_FTYP_")"
  1. Q