| [613] | 1 | SDPFSS ;ALB/SCK - Patient Financial Services System  ;11/24/0622-APR-2005 | 
|---|
|  | 2 | ;;5.3;Scheduling;**430,502**;Aug 13, 1993  ;Build 14 | 
|---|
|  | 3 | ; Modified from FOIA VISTA, | 
|---|
|  | 4 | ; Copyright (C) 2007 WorldVistA | 
|---|
|  | 5 | ; | 
|---|
|  | 6 | ; This program is free software; you can redistribute it and/or modify | 
|---|
|  | 7 | ; it under the terms of the GNU General Public License as published by | 
|---|
|  | 8 | ; the Free Software Foundation; either version 2 of the License, or | 
|---|
|  | 9 | ; (at your option) any later version. | 
|---|
|  | 10 | ; | 
|---|
|  | 11 | ; This program is distributed in the hope that it will be useful, | 
|---|
|  | 12 | ; but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|---|
|  | 13 | ; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
|---|
|  | 14 | ; GNU General Public License for more details. | 
|---|
|  | 15 | ; | 
|---|
|  | 16 | ; You should have received a copy of the GNU General Public License | 
|---|
|  | 17 | ; along with this program; if not, write to the Free Software | 
|---|
|  | 18 | ; Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA | 
|---|
|  | 19 | ; | 
|---|
|  | 20 | ; | 
|---|
|  | 21 | Q | 
|---|
|  | 22 | ; | 
|---|
|  | 23 | EVENT ; Entry point for PFSS Protocol event.  This procedure will manage the IBB event actions. | 
|---|
|  | 24 | ; | 
|---|
|  | 25 | N SDEVENT,SDTEST,SDBEFORE,SDAFTER,SDMSG,SDARRAY,SDCNT,SDPRV,SDERR,SDERRMSG,SDNODE,SDOK | 
|---|
|  | 26 | N IBBDFN,IBBAPLR,IBBEVENT,IBBPV1,IBBPV2,IBBARFN | 
|---|
|  | 27 | ; | 
|---|
|  | 28 | ; Check conditions before proceeding | 
|---|
|  | 29 | Q:'$G(DFN) | 
|---|
|  | 30 | ; VWSD LOCAL MOD HERE SDVWNVAI VARIABLE, SEE DEFINITION AT VWSD LOCAL MOD BELOW | 
|---|
|  | 31 | I $D(SDVWNVAI) G OVER | 
|---|
|  | 32 | Q:'$$CHECK | 
|---|
|  | 33 | OVER ; | 
|---|
|  | 34 | ;END LOCAL MOD | 
|---|
|  | 35 | Q:$$TESTPAT^VADPT(DFN) | 
|---|
|  | 36 | ;VWSD LOCAl MOD | 
|---|
|  | 37 | ; Call the ICN API to generate an ICN if one does not exist for the patient. | 
|---|
|  | 38 | ;VWSD SDVWNVAI VARIABLE -LOCAL MOD FOR disabling the need for ICN or use of other ICN system for non-VA system | 
|---|
|  | 39 | S SDOK=$$ICNLC^MPIF001(DFN) | 
|---|
|  | 40 | I $D(SDVWNVAI) G OVER1 | 
|---|
|  | 41 | I (SDOK<0) D | 
|---|
|  | 42 | . D ERRMSG^SDPFSS2(SDOK) | 
|---|
|  | 43 | ; | 
|---|
|  | 44 | OVER1 ; | 
|---|
|  | 45 | ;END LOCAL MOD | 
|---|
|  | 46 | ; Get event type | 
|---|
|  | 47 | S SDEVENT=$S($D(SDAMEVT):$$GET1^DIQ(409.66,SDAMEVT,.01),1:"OTHER") | 
|---|
|  | 48 | I SDEVENT="CHECK-OUT",+$G(SDPFSFLG) S SDEVENT="DELETE CO" | 
|---|
|  | 49 | ; | 
|---|
|  | 50 | S SDBEFORE=$P($G(SDATA("BEFORE","STATUS")),U,3) | 
|---|
|  | 51 | S SDAFTER=$P($G(SDATA("AFTER","STATUS")),U,3) | 
|---|
|  | 52 | ; | 
|---|
|  | 53 | I SDEVENT="CHECK-IN" D | 
|---|
|  | 54 | . I SDBEFORE="ACT REQ/CHECKED IN"&(SDAFTER["NO ACTION TAKEN") S SDEVENT="DELETE CI" | 
|---|
|  | 55 | ; | 
|---|
|  | 56 | I SDEVENT="NO-SHOW" D | 
|---|
|  | 57 | . I SDBEFORE="NO-SHOW"&(SDAFTER["NO ACTION TAKEN") S SDEVENT="DELETE NS" | 
|---|
|  | 58 | ; | 
|---|
|  | 59 | S IBBDFN=DFN | 
|---|
|  | 60 | S IBBAPLR="" | 
|---|
|  | 61 | S IBBEVENT=$$GETEVT^SDPFSS2(SDEVENT) | 
|---|
|  | 62 | ; | 
|---|
|  | 63 | ; Call the Scheduling Appointment Data API to retrieve appointment data | 
|---|
|  | 64 | K ^TMP($J,"SDAMA301") | 
|---|
|  | 65 | S SDARRAY(1)=$G(SDT)_";"_$G(SDT) | 
|---|
|  | 66 | S SDARRAY(2)=$G(SDCL) | 
|---|
|  | 67 | S SDARRAY(4)=$G(DFN) | 
|---|
|  | 68 | S SDARRAY("FLDS")="1;2;3;8;9;10;11;13;14;15;16;17;18" | 
|---|
|  | 69 | S SDCNT=$$SDAPI^SDAMA301(.SDARRAY) | 
|---|
|  | 70 | ; | 
|---|
|  | 71 | ; check for any errors in the TMP global | 
|---|
|  | 72 | I SDCNT<0 D | 
|---|
|  | 73 | . S SDERR=$O(^TMP($J,"SDAMA301",0)) | 
|---|
|  | 74 | . I SDERR D | 
|---|
|  | 75 | . . S SDERRMSG=^TMP($J,"SDAMA301",SDERR) | 
|---|
|  | 76 | . . S SDERR=SDERR_"^"_SDERRMSG | 
|---|
|  | 77 | . E  D | 
|---|
|  | 78 | . . S SDERR="-1^Undefined error returned by SDAPI" | 
|---|
|  | 79 | . D ERRMSG^SDPFSS2(SDERR) | 
|---|
|  | 80 | . ; Null out the data global for further processing | 
|---|
|  | 81 | . S ^TMP($J,"SDAMA301",DFN,SDCL,SDT)="" | 
|---|
|  | 82 | ; | 
|---|
|  | 83 | I SDCNT=0 D | 
|---|
|  | 84 | . S SDERR="-1^No appointments were returned by SDAPI"_"^"_DFN_"^"_SDT_"^"_SDCL | 
|---|
|  | 85 | . D ERRMSG^SDPFSS2(SDERR) | 
|---|
|  | 86 | ; | 
|---|
|  | 87 | ; Build data arrays for PFSS Account API | 
|---|
|  | 88 | S SDNODE=$G(^TMP($J,"SDAMA301",DFN,SDCL,SDT)) | 
|---|
|  | 89 | S IBBPV1(2)="O" | 
|---|
|  | 90 | S IBBPV1(3)=SDCL | 
|---|
|  | 91 | S IBBPV1(4)=+$P(SDNODE,U,10) | 
|---|
|  | 92 | S IBBPV1(10)=+$P(SDNODE,U,18) | 
|---|
|  | 93 | S IBBPV1(18)=$P($P(SDNODE,U,13),";",1) | 
|---|
|  | 94 | S IBBPV1(51)=$P(SDNODE,U,15) | 
|---|
|  | 95 | S IBBPV1(25)=$S(SDEVENT="DELETE CI":"",1:$P(SDNODE,U,9)) | 
|---|
|  | 96 | S IBBPV1(41)=$P($P(SDNODE,U,14),";",1) | 
|---|
|  | 97 | I "A05,A38"[IBBEVENT | 
|---|
|  | 98 | E  S IBBPV1(44)=SDT | 
|---|
|  | 99 | ; | 
|---|
|  | 100 | S IBBPV2(7)=$P($P(SDNODE,U,8),";",1) | 
|---|
|  | 101 | I "A05,A38"[IBBEVENT S IBBPV2(8)=SDT | 
|---|
|  | 102 | S IBBPV2(24)=$P($P(SDNODE,U,3),";",1) | 
|---|
|  | 103 | S IBBPV2(46)=$P(SDNODE,U,16) | 
|---|
|  | 104 | ; | 
|---|
|  | 105 | I SDEVENT="CHECK-OUT" D | 
|---|
|  | 106 | . S SDPRV=$$ENCPRV^SDPFSS2(DFN,$G(SDVSIT)) | 
|---|
|  | 107 | . S IBBPV1(45)=$P(SDNODE,U,11) | 
|---|
|  | 108 | I +$G(SDPRV)'>0 S SDPRV=$$DEFPRV^SDPFSS2(SDCL) | 
|---|
|  | 109 | ; | 
|---|
|  | 110 | I SDEVENT="DELETE CO" S IBBPV1(45)="",SDPRV="" | 
|---|
|  | 111 | S IBBPV1(7)=$P($G(SDPRV),U,1) | 
|---|
|  | 112 | ; | 
|---|
|  | 113 | S IBBARFN=$S(SDEVENT="MAKE":"",1:$$GETARN^SDPFSS2(SDT,DFN,SDCL)) | 
|---|
|  | 114 | B1 ; Call the Get Account API and retrieve the account number reference | 
|---|
|  | 115 | S SDANR=$$GETACCT^IBBAPI(IBBDFN,IBBARFN,IBBEVENT,IBBAPLR,.IBBPV1,.IBBPV2) | 
|---|
|  | 116 | ; | 
|---|
|  | 117 | ;  If this is a "Make" appt., then create a new entry in the Appointment Acct. No. Reference File | 
|---|
|  | 118 | I SDEVENT="MAKE",+$G(SDANR)>0 D | 
|---|
|  | 119 | . S SDOK=$$FILE(DFN,SDT,SDCL,SDANR) | 
|---|
|  | 120 | . I 'SDOK D | 
|---|
|  | 121 | . . S SDERRMSG=$S($P($G(SDOK),U,2)]"":$P($G(SDOK),U,2),1:"Unable to File Account Number Reference") | 
|---|
|  | 122 | . . D ERRMSG^SDPFSS2(SDERRMSG) | 
|---|
|  | 123 | K ^TMP($J,"SDAMA301") | 
|---|
|  | 124 | Q | 
|---|
|  | 125 | ; | 
|---|
|  | 126 | CHECK() ; Check routine for unit testing to allow for on/off PFSS Switch | 
|---|
|  | 127 | N RSLT,X | 
|---|
|  | 128 | ; | 
|---|
|  | 129 | ; Check if the PFSS Switch Status API call is installed | 
|---|
|  | 130 | ; If it is, then return the status of the switch, otherwise | 
|---|
|  | 131 | ; return 0 | 
|---|
|  | 132 | I $T(SWSTAT^IBBAPI)'="" S RSLT=+$$SWSTAT^IBBAPI | 
|---|
|  | 133 | Q +$G(RSLT) | 
|---|
|  | 134 | ; | 
|---|
|  | 135 | FILE(DFN,SDT,SDCLN,SDANR) ;  Procedure to validate and load appointment information and account number reference into file #409.55 | 
|---|
|  | 136 | ; | 
|---|
|  | 137 | ; Input | 
|---|
|  | 138 | ;    DFN    - Patient IEN in File #2 | 
|---|
|  | 139 | ;    SDT    - Appointment Date/Time in Fileman format | 
|---|
|  | 140 | ;    SDCLN  - Clinic IEN in Hospital Location File, #44 | 
|---|
|  | 141 | ;    SDANR  - Account Number Reference from IBB | 
|---|
|  | 142 | ; | 
|---|
|  | 143 | ; Output | 
|---|
|  | 144 | ;    1 - If entry successfully created | 
|---|
|  | 145 | ;   -1^error message - if load is unsuccessful | 
|---|
|  | 146 | ; | 
|---|
|  | 147 | N FDA,FDAIEN,ERR | 
|---|
|  | 148 | ; | 
|---|
|  | 149 | I '$G(DFN) S ERR="-1^MISSING DFN" G FILEQ | 
|---|
|  | 150 | I '$D(^DPT(DFN)) S ERR="-1^INVALID PATIENT ENTRY" G FILEQ | 
|---|
|  | 151 | I '$G(SDT) S ERR="-1^MISSING APPOINTMENT DATE/TIME" G FILEQ | 
|---|
|  | 152 | I '$G(SDCLN) S ERR="-1^MISSING CLINIC LOCATION" G FILEQ | 
|---|
|  | 153 | I '$D(^SC(SDCLN)) S ERR="-1^INVALID HOSPITAL LOCATION ENTRY" G FILEQ | 
|---|
|  | 154 | I '$G(SDANR) S ERR="-1^No Account Number Reference provided" G FILEQ | 
|---|
|  | 155 | ; | 
|---|
|  | 156 | S FDA(1,409.55,"+1,",.01)=SDT | 
|---|
|  | 157 | S FDA(1,409.55,"+1,",.02)=DFN | 
|---|
|  | 158 | S FDA(1,409.55,"+1,",.03)=SDCLN | 
|---|
|  | 159 | S FDA(1,409.55,"+1,",.04)=SDANR | 
|---|
|  | 160 | D UPDATE^DIE("","FDA(1)","FDAIEN","ERR") | 
|---|
|  | 161 | ; | 
|---|
|  | 162 | I '$D(ERR) S ERR=1 | 
|---|
|  | 163 | FILEQ Q $G(ERR) | 
|---|