| 1 | IBDF5C ;ALB/CJM - ENCOUNTER FORM (creating a new block) ;MARCH 22,1993
|
---|
| 2 | ;;3.0;AUTOMATED INFO COLLECTION SYS;;APR 24, 1997
|
---|
| 3 | NEWBLOCK ;adds a new block, expects IBFORM to be defined
|
---|
| 4 | N IBBLK,TOP,BOT
|
---|
| 5 | S VALMBCK="R"
|
---|
| 6 | S IBBLK=$$CREATE()
|
---|
| 7 | I IBBLK D
|
---|
| 8 | .D TOPNBOT^IBDFU5(IBBLK,.TOP,.BOT)
|
---|
| 9 | .D IDXFORM^IBDF5A(TOP,BOT)
|
---|
| 10 | Q
|
---|
| 11 | CREATE() ;creates the new block and allows the user to edit it
|
---|
| 12 | ;INPUTS: expects IBFORM to be defined
|
---|
| 13 | ; expects IBTKBLK to be defined - IBTKBLK=1 means add to tk
|
---|
| 14 | ;returns IBBLK
|
---|
| 15 | N NAME,IBBLK,NODE,IBDFDONE,IBBG,IBLFT,DLAYGO
|
---|
| 16 | S IBBG=1,IBLFT=5
|
---|
| 17 | S VALMBCK="R"
|
---|
| 18 | I '$G(IBTKBLK) S IBBG=+$G(VALMBG),IBLFT=+$G(VALMLFT)
|
---|
| 19 | S NAME=$$NEWNAME Q:NAME=-1 ""
|
---|
| 20 | K DIC,DIE,DD,DO,DINUM S DIC="^IBE(357.1,",DIC(0)="FL",X=NAME,DLAYGO=357.1
|
---|
| 21 | D FILE^DICN K DIC,DIE,DA
|
---|
| 22 | S IBBLK=+Y
|
---|
| 23 | I 'IBBLK D
|
---|
| 24 | .W !,"Unable to create a new block!" K DIC,DIE D PAUSE^IBDFU5
|
---|
| 25 | I IBBLK D
|
---|
| 26 | .;delete everything in the block - it should be empty
|
---|
| 27 | .D DLTCNTNT^IBDFU3(IBBLK,357.1)
|
---|
| 28 | .;set the current position of the block to the upper left-hand corner of the screen as the default
|
---|
| 29 | .S $P(^IBE(357.1,IBBLK,0),"^",4,5)=(IBBG-1)_"^"_(IBLFT-5)
|
---|
| 30 | .;now let the user edit the new block - header,name,outline,etc.
|
---|
| 31 | .K DIE,DA S DIE=357.1,DA=IBBLK,DR="[IBDF NEW EMPTY BLOCK]",DIE("NO^")="BACKOUTOK" D ^DIE K DIC,DIE,DR,DA
|
---|
| 32 | .I 'IBDFDONE S DIK="^IBE(357.1,",DA=IBBLK K DA(1) D ^DIK K DIK,DA Q
|
---|
| 33 | Q IBBLK
|
---|
| 34 | NEWNAME() ;
|
---|
| 35 | K DIR S DIR(0)="357.1,.01A",DIR("A")="New Block Name: ",DIR("B")=""
|
---|
| 36 | D ^DIR K DIR I $D(DIRUT) Q -1
|
---|
| 37 | Q Y
|
---|
| 38 | REDRAW ;redraws the ;entire form
|
---|
| 39 | S VALMBCK="R"
|
---|
| 40 | D UNCMPALL^IBDF19(IBFORM)
|
---|
| 41 | D IDXFORM^IBDF5A()
|
---|
| 42 | Q
|
---|
| 43 | COPYBLK ;copies a block from another form,whether in the toolkit or not, expects IBFORM=current work form to be defined
|
---|
| 44 | N IBBLK,TOP,BOT,NEWBLOCK
|
---|
| 45 | S IBBLK=$$SELECT2^IBDF13("")
|
---|
| 46 | I IBBLK S NEWBLOCK=$$COPYBLK^IBDFU2(IBBLK,IBFORM,357.1,357.1,$$CURY^IBDFU4,$$CURX^IBDFU4,0,"",1) I NEWBLOCK D
|
---|
| 47 | .D RE^VALM4
|
---|
| 48 | .D POS^IBDFU4(NEWBLOCK)
|
---|
| 49 | .D TOPNBOT^IBDFU5(NEWBLOCK,.TOP,.BOT)
|
---|
| 50 | .D IDXFORM^IBDF5A(TOP,BOT)
|
---|
| 51 | S VALMBCK="R"
|
---|
| 52 | Q
|
---|
| 53 | ;
|
---|
| 54 | VIEW ;toggles between viewing form with data and without data
|
---|
| 55 | N STARTVAL
|
---|
| 56 | S STARTVAL=IBPRINT("WITH_DATA")
|
---|
| 57 | I 'IBPRINT("WITH_DATA") D
|
---|
| 58 | .D FULL^VALM1
|
---|
| 59 | .S DFN=$$PATIENT
|
---|
| 60 | .I DFN S IBPRINT("WITH_DATA")=1 I '$G(IBAPPT) D NOW^%DTC S IBAPPT=% K %,%H,%I,X
|
---|
| 61 | E I IBPRINT("WITH_DATA") S IBPRINT("WITH_DATA")=0
|
---|
| 62 | ;
|
---|
| 63 | ;this action could be called at the form level or the block level - action depends on which
|
---|
| 64 | I '$G(IBBLK) D
|
---|
| 65 | .I STARTVAL'=IBPRINT("WITH_DATA") D JUSTDATA^IBDF2A(IBPRINT("WITH_DATA")) K ^TMP("IB",$J,"INTERFACES")
|
---|
| 66 | I $G(IBBLK) D UNCMPBLK^IBDF19(IBBLK),IDXBLOCK^IBDFU4
|
---|
| 67 | S VALMBCK="R"
|
---|
| 68 | Q
|
---|
| 69 | ;
|
---|
| 70 | PATIENT() ;asks for a patient, returns the DFN
|
---|
| 71 | K DIR S DIR(0)="P^2:EM",DIR("A")="Test with what Patient"
|
---|
| 72 | D ^DIR K DIR I $D(DIRUT)!(+Y<1) Q 0
|
---|
| 73 | Q +Y
|
---|