1 | SCAPMC20 ;ALB/REW - Team APIs:APPTTM ; 20 Mar 1996
|
---|
2 | ;;5.3;Scheduling;**41**;AUG 13, 1993
|
---|
3 | ;;1.0
|
---|
4 | ACOUTPT(DFN,SCFIELDA,SCERR) ;add/edit a record in OUTPATIENT PROFILE #404.41
|
---|
5 | ; input:
|
---|
6 | ; DFN = pointer to PATIENT file (#2)
|
---|
7 | ; SCFIELDA= array of additional fields to be added
|
---|
8 | ; SCERR = array NAME to store error messages.
|
---|
9 | ; [ex. ^TMP("ORXX",$J)]
|
---|
10 | ;
|
---|
11 | ; Output:
|
---|
12 | ; Returned = ok?^404.41 ien^new?
|
---|
13 | ; SCERR() = Array of DIALOG file messages(errors) .
|
---|
14 | ; Foramt:
|
---|
15 | ; Subscript: Sequential # from 1 to n
|
---|
16 | ; Piece Description
|
---|
17 | ; 1 IEN of DIALOG file
|
---|
18 | N SCEXIST
|
---|
19 | N SCESEQ,SCPARM,SCIEN,SC,SCFLD
|
---|
20 | G:'$$OKDATA APTTMQ ;check/setup variables
|
---|
21 | S SCEXIST=$D(^SCPT(404.41,DFN,0))#2
|
---|
22 | IF SCEXIST D
|
---|
23 | .IF $D(SCFIELDA) D
|
---|
24 | ..S SCFLD=0
|
---|
25 | ..F S SCFLD=$O(@SCFIELDA@(SCFLD)) Q:'SCFLD D
|
---|
26 | ...S SC($J,404.41,(+DFN)_",",SCFLD)=@SCFIELDA@(SCFLD)
|
---|
27 | .D FILE^DIE("E","SC($J)",SCERR)
|
---|
28 | ELSE D
|
---|
29 | .S SCIEN(1)=DFN
|
---|
30 | .S SC($J,404.41,"+1,",.01)="`"_DFN
|
---|
31 | .IF $D(SCFIELDA) D
|
---|
32 | ..S SCFLD=0
|
---|
33 | ..F S SCFLD=$O(@SCFIELDA@(SCFLD)) Q:'SCFLD D
|
---|
34 | ...S SC($J,404.41,"+1,",SCFLD)=@SCFIELDA@(SCFLD)
|
---|
35 | .D UPDATE^DIE("E","SC($J)","SCIEN",SCERR)
|
---|
36 | .IF $D(@SCERR)!($G(SCIEN(1))'=DFN) S @SCERR=1 K SCIEN
|
---|
37 | .ELSE D
|
---|
38 | ..S SCEXIST=0
|
---|
39 | APTTMQ Q '$D(@SCERR@(0))_U_+$G(DFN)_U_'$G(SCEXIST)
|
---|
40 | ;
|
---|
41 | OKDATA() ;setup/check variables
|
---|
42 | N SCOK
|
---|
43 | S SCOK=1
|
---|
44 | D INIT^SCAPMCU1(.SCOK)
|
---|
45 | IF '$D(^DPT(DFN,0)) D S SCOK=0
|
---|
46 | . S SCPARM("PATIENT")=DFN
|
---|
47 | . D ERR^SCAPMCU1(SCESEQ,4045101,.SCPARM,"",.SCERR)
|
---|
48 | Q SCOK
|
---|
49 | ;
|
---|
50 | MAKEMANY(DFNA,SCOLDASS,SCBADASS,SCNEWASS) ;Not supported for use by PCMM Only
|
---|
51 | ; DFNA - DFN ARRAY
|
---|
52 | ; SCOLDASS - Subset of DFNA that were previously assigned
|
---|
53 | ; SCBADASS - Subset of DFNA that could not be assigned
|
---|
54 | ; SCNEWASS - Subset of DFNA that were newly assigned
|
---|
55 | ; Return: total^new^old^bad
|
---|
56 | ; Note: No input error checking!!
|
---|
57 | N DFN,SCX,SCOUTFLD,SCBADOUT,SCBADCNT,SCNEWCND,SCOLDCNT
|
---|
58 | S (SCBADCNT,SCNEWCNT,SCOLDCNT)=0
|
---|
59 | S DFN=0
|
---|
60 | F S DFN=$O(@DFNA@(DFN)) Q:'DFN D
|
---|
61 | .S SCOUTFLD(.04)=1
|
---|
62 | .S SCX=$$ACOUTPT(DFN,"SCOUTFLD","SCBADOUT")
|
---|
63 | .IF 'SCX D
|
---|
64 | ..S @SCBADASS@(DFN)=""
|
---|
65 | ..S SCBADCNT=SCBADCNT+1
|
---|
66 | .ELSE D
|
---|
67 | ..IF $P(SCX,U,3) D
|
---|
68 | ...S @SCNEWASS@(DFN)=""
|
---|
69 | ...S SCNEWCNT=SCNEWCNT+1
|
---|
70 | ..ELSE D
|
---|
71 | ...S @SCOLDASS@(DFN)=""
|
---|
72 | ...S SCOLDCNT=SCOLDCNT+1
|
---|
73 | Q (SCOLDCNT+SCNEWCNT)_U_SCNEWCNT_U_SCOLDCNT_U_SCBADCNT
|
---|
74 | ;
|
---|
75 | PTPCNOTM(SCOUTA,SCDATE) ;Not Supported For Use by PCMM Only
|
---|
76 | ; SCOUTA - Output array of DFNs that are PC but no Team Now
|
---|
77 | N DFN,SCPC
|
---|
78 | S DFN=0
|
---|
79 | F S DFN=$O(^SCPT(404.41,"APC",DFN)) Q:'DFN S SCPC=$O(^(DFN)) Q:'SCPC D
|
---|
80 | .Q:$D(^TMP("SCMC",$J,"EXCLUDE PT","SCPTA",+DFN))
|
---|
81 | .S:'$$GETPCTM^SCAPMCU2(DFN,SCDATE,1) @SCOUTA@(DFN)=DFN_U_$P($G(^DPT(DFN,0)),U,1)
|
---|
82 | Q
|
---|