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

PXRMCOPY.m

Go to the documentation of this file.
  1. PXRMCOPY ;SLC/PKR,PJH - Copy various reminder files. ;Jun 29, 2021@11:59:53
  1. ;;2.0;CLINICAL REMINDERS;**6,12,26,45,71**;Feb 04, 2005;Build 43
  1. ;
  1. ;=====================================================
  1. COPY(PROMPT,ROOT,WHAT) ;Copy an entry of ROOT into a new entry.
  1. N DIROUT,DTOUT,DUOUT
  1. F D GETORGR Q:$D(DIROUT) Q:$D(DTOUT)
  1. Q
  1. ;
  1. ;=====================================================
  1. GETORGR ;Look-up logic to get and copy source entry to destination.
  1. N DIC,IENN,IENO,Y
  1. S DIC=ROOT,DIC(0)="AEMQ",DIC("A")=PROMPT
  1. W !
  1. D ^DIC
  1. I $D(DUOUT)!$D(DTOUT) S DIROUT="" Q
  1. S IENO=$P(Y,U,1)
  1. I IENO=-1 S DIROUT="" Q
  1. D GETORGRC(IENO,.IENN,ROOT,WHAT,0)
  1. Q
  1. ;
  1. GETORGRC(IENO,IENN,ROOT,WHAT,SKIP) ;
  1. N DA,DIC,DIE,DIK,DIR,DIRUT,FAIL,FDA,FIELDLEN,FILE
  1. N HASGF,IENS,MSG,NAME,ORGNAME,X,Y
  1. ; reminder dialog checks
  1. S DIC=ROOT,FAIL=0
  1. N DTYP,LFIND,LOCK
  1. I ROOT="^PXRMD(801.41," D
  1. .;Check for Uneditable flag
  1. .S LOCK=$P($G(^PXRMD(801.41,IENO,100)),U,4)
  1. .S LFIND=$P($G(^PXRMD(801.41,IENO,1)),U,5)
  1. .S DTYP=$P($G(^PXRMD(801.41,IENO,0)),U,4)
  1. .S HASGF=$$HASGF(IENO)
  1. .I HASGF D
  1. ..I $P($G(^PXRMD(801.41,IENO,0)),U)="VA-TICKLER ELEMENT" Q
  1. ..W !,"This item cannot be copied." S FAIL=1 H 2 Q
  1. .I LOCK=1,'$G(PXRMINST),DTYP="G" D Q
  1. ..W !,"This item cannot be copied." S FAIL=1 H 2
  1. .I LOCK=1,$G(LFIND)'="",$G(LFIND)'["ORD",'$G(PXRMINST),DTYP'="G" D Q
  1. ..W !,"This item cannot be copied." S FAIL=1 H 2
  1. ;
  1. I FAIL=1 Q
  1. ;Set the starting place for additions.
  1. D SETSTART^PXRMCOPY(DIC)
  1. S IENN=$$GETFOIEN(ROOT)
  1. D MERGE(IENN,IENO,ROOT)
  1. ;
  1. ;Get the new name.
  1. S ORGNAME=$P(@(ROOT_IENO_",0)"),U,1)
  1. S FILE=$$FNFR^PXRMUTIL(ROOT)
  1. S FIELDLEN=$$GET1^DID(FILE,.01,"","FIELD LENGTH")
  1. S DIR(0)="F"_U_"3:"_FIELDLEN_U_"K:(X?.N)!'(X'?1P.E) X"
  1. S DIR("A")="PLEASE ENTER A UNIQUE NAME"
  1. GETNAM D ^DIR
  1. I $D(DIRUT) D DELETE(ROOT,IENN) Q
  1. S NAME=Y
  1. ;
  1. ;Make sure the new name is valid.
  1. I '$$VNAME^PXRMINTR(NAME) G GETNAM
  1. ;
  1. ;Change to the new name.
  1. S IENS=IENN_","
  1. S FDA(FILE,IENS,.01)=NAME
  1. K MSG
  1. D FILE^DIE("","FDA","MSG")
  1. ;Check to make sure the name was not a duplicate.
  1. I $G(MSG("DIERR",1))=740 D G GETNAM
  1. . W !,NAME," is not a unique name!"
  1. ;Change the class to local and delete the sponsor.
  1. D SCAS(FILE,IENN,"L","")
  1. ;Initialize the edit history.
  1. D INIEH(FILE,ROOT,IENN,IENO)
  1. ;
  1. ;Reindex the cross-references.
  1. S DIK=ROOT,DA=IENN
  1. D IX^DIK
  1. I $G(PXRMDANY)=1 D Q
  1. .W !!,"Completed copy of '"_ORGNAME_"'"
  1. .W !,"into '"_NAME_"'",! H 2
  1. .I $P(@(ROOT_IENN_",0)"),U,4)="P" D
  1. ..;Allow PXRM prompts to be changed into forced values
  1. ..N ANS,TEXT
  1. ..S TEXT="Change the new prompt into a forced value :"
  1. ..D ASK^PXRMDCPY(.ANS,TEXT,4,"N") Q:$D(DUOUT)!$D(DTOUT) Q:ANS'="Y"
  1. ..;Store the dialog type
  1. ..S DR="4///F",DIE=ROOT,DA=IENN
  1. ..D ^DIE
  1. .S DTOUT=1,PXRMDANY=0
  1. W !
  1. ;
  1. I SKIP=1 W !,"The original "_WHAT_" "_ORGNAME_" has been copied into "_NAME_"." H 1 Q
  1. ;Tell the user what has happened and allow for editing of the new item.
  1. S DIR(0)="Y"
  1. S DIR("A")="Do you want to edit it now"
  1. S DIR("A",1)="The original "_WHAT_" "_ORGNAME_" has been copied into "_NAME_"."
  1. D ^DIR Q:$D(DIRUT)
  1. I Y D EDIT^PXRMEDIT(ROOT,IENN)
  1. Q
  1. ;
  1. ;=====================================================
  1. COPYLL ;Copy a location list.
  1. N PROMPT,ROOT,WHAT
  1. S WHAT="location list"
  1. S ROOT="^PXRMD(810.9,"
  1. S PROMPT="Select the reminder location list to copy: "
  1. D COPY(PROMPT,ROOT,WHAT)
  1. Q
  1. ;
  1. ;=====================================================
  1. COPYREM ;Copy a reminder definition.
  1. N PROMPT,ROOT,WHAT
  1. S WHAT="reminder"
  1. S ROOT="^PXD(811.9,"
  1. S PROMPT="Select the reminder definition to copy: "
  1. D COPY(PROMPT,ROOT,WHAT)
  1. Q
  1. ;
  1. ;=====================================================
  1. COPYTAX ;Copy a taxonomy.
  1. N PROMPT,ROOT,WHAT
  1. S WHAT="taxonomy"
  1. S ROOT="^PXD(811.2,"
  1. S PROMPT="Select the reminder taxonomy to copy: "
  1. D COPY(PROMPT,ROOT,WHAT)
  1. Q
  1. ;
  1. ;=====================================================
  1. COPYTERM ;Copy a reminder term.
  1. N PROMPT,ROOT,WHAT
  1. S WHAT="reminder term"
  1. S ROOT="^PXRMD(811.5,"
  1. S PROMPT="Select the reminder term to copy: "
  1. D COPY(PROMPT,ROOT,WHAT)
  1. Q
  1. ;
  1. ;=====================================================
  1. DELETE(DIK,DA) ;Delete the entry just added.
  1. D ^DIK
  1. W !!,"New entry not created due to invalid name!",!
  1. Q
  1. ;
  1. ;=====================================================
  1. GETFOIEN(ROOT) ;Return the first open IEN in ROOT. This should be called
  1. ;after a call to SETSTART.
  1. N ENTRY,NIEN,OIEN
  1. S ENTRY=ROOT_0_")"
  1. S OIEN=+$P(@ENTRY,U,3)
  1. S ENTRY=ROOT_OIEN_")"
  1. F S NIEN=$O(@ENTRY) Q:+(NIEN-OIEN)>1 Q:+NIEN'>0 S OIEN=NIEN,ENTRY=ROOT_NIEN_")"
  1. Q OIEN+1
  1. ;
  1. ;
  1. HASGF(IEN) ;
  1. N ARRAY,CNT,DIEN,DARRAY,RESULT
  1. S CNT=0,RESULT=0
  1. I $G(PXRMINST)=1 Q RESULT
  1. S RESULT=$$ITEMHSGF(IEN) I RESULT=1 Q RESULT
  1. I '$D(^PXRMD(801.41,IEN,10)) Q RESULT
  1. D DITEMAR^PXRMDUTL(IEN,.ARRAY,.DARRAY,.CNT)
  1. S DIEN=0 F S DIEN=$O(DARRAY(DIEN)) Q:DIEN'>0!(RESULT=1) D
  1. .S RESULT=$$ITEMHSGF(DIEN)
  1. Q RESULT
  1. ;
  1. GFCANCPY(FIND) ;
  1. N NAME,RESULT
  1. S RESULT=1
  1. S NAME=$P($G(^PXRMD(801.46,FIND,0)),U)
  1. I NAME'="VIEW PROGRESS NOTE TEXT",$P(NAME," ")'="TICKLER" S RESULT=0
  1. Q RESULT
  1. ;
  1. ITEMHSGF(IEN) ;
  1. N FIND,RESULT
  1. S RESULT=0
  1. I $G(PXRMINST)=1 Q RESULT
  1. S FIND=$P($G(^PXRMD(801.41,IEN,1)),U,5)
  1. I FIND[801.46,'$$GFCANCPY(+FIND) Q 1
  1. S FOUND=0,FIND="" F S FIND=$O(^PXRMD(801.41,IEN,3,"B",FIND)) Q:FIND=""!(RESULT=1) D
  1. .I FIND[801.46,'$$GFCANCPY(+FIND) S RESULT=1
  1. Q RESULT
  1. ;
  1. ;=====================================================
  1. INIEH(FILENUM,ROOT,IENN,IENO) ;Initialize the edit history after a copy.
  1. ;First delete any existing history entries.
  1. N ENTRY,IND,IENS,FDA,FDAIEN,MSG,SFN,TARGET,WP
  1. D FIELD^DID(FILENUM,"EDIT HISTORY","","SPECIFIER","TARGET")
  1. S SFN=+$G(TARGET("SPECIFIER"))
  1. I SFN=0 Q
  1. S ENTRY=ROOT_IENN_",110)"
  1. S IND=0
  1. F S IND=$O(@ENTRY@(IND)) Q:+IND=0 D
  1. . S IENS=IND_","_IENN_","
  1. . S FDA(SFN,IENS,.01)="@"
  1. I $D(FDA(SFN)) D FILE^DIE("K","FDA","MSG")
  1. I $D(MSG) D AWRITE^PXRMUTIL("MSG")
  1. ;Establish an initial entry in the edit history.
  1. K FDA,MSG
  1. S IENS="+1,"_IENN_","
  1. S FDAIEN(IENN)=IENN
  1. S FDA(SFN,IENS,.01)=$$FMTE^XLFDT($$NOW^XLFDT,"5Z")
  1. S FDA(SFN,IENS,1)=$$GET1^DIQ(200,DUZ,.01)
  1. S FDA(SFN,IENS,2)="WP(1,1)"
  1. S WP(1,1,1)="Copied from "_$$GET1^DIQ(FILENUM,IENO,.01)
  1. D UPDATE^DIE("E","FDA","FDAIEN","MSG")
  1. I $D(MSG) D AWRITE^PXRMUTIL("MSG")
  1. Q
  1. ;
  1. ;=====================================================
  1. MERGE(IENN,IENO,ROOT) ;Use MERGE to copy ROOT(IENO into ROOT(IENN.
  1. N DEST,SOURCE
  1. S DEST=ROOT_IENN_")"
  1. ;Lock the file before merging.
  1. L +@DEST:DILOCKTM
  1. S SOURCE=ROOT_IENO_")"
  1. M @DEST=@SOURCE
  1. ;Unlock the file
  1. L -@DEST
  1. Q
  1. ;
  1. ;=====================================================
  1. SCAS(FILENUM,IEN,CLASS,SPONSOR) ;Set the class field to CLASS and the sponsor
  1. ;field to SPONSOR.
  1. N IENS,FDA,MSG
  1. S IENS=IEN_","
  1. S FDA(FILENUM,IENS,100)=CLASS
  1. S FDA(FILENUM,IENS,101)=SPONSOR
  1. D FILE^DIE("K","FDA","MSG")
  1. I $D(MSG) D AWRITE^PXRMUTIL("MSG")
  1. Q
  1. ;
  1. ;=====================================================
  1. SETSTART(ROOT) ;Set the starting value to add new entries. Start
  1. ;at the begining so empty spaces are filled in.
  1. N CUR,ENTRY
  1. S ENTRY=ROOT_"0)"
  1. S $P(@ENTRY,U,3)=1
  1. Q
  1. ;