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
|
---|