| 1 | PRCVIT ;WOIFO/DST - Send ITEM master file update to DYNAMED ; 3/2/05 5:07pm
 | 
|---|
| 2 |  ;;5.1;IFCAP;**81**;Oct 20, 2000
 | 
|---|
| 3 |  ;Per VHA Directive 10-93-142, this routine should not be modified.
 | 
|---|
| 4 |  ;
 | 
|---|
| 5 |  Q
 | 
|---|
| 6 | NITECHK ;
 | 
|---|
| 7 |  ;    Once a day check
 | 
|---|
| 8 |  ;    Compare a checksum and set a record to update
 | 
|---|
| 9 |  ;
 | 
|---|
| 10 |  ; If not DynaMed, don't do it
 | 
|---|
| 11 |  Q:'$$GET^XPAR("SYS","PRCV COTS INVENTORY",1,"Q")
 | 
|---|
| 12 |  ;
 | 
|---|
| 13 |  N PRCND,PRCVL,PRCVP,PRCVAL,PRCVIT,PRCVN,PRCVSTN
 | 
|---|
| 14 |  N PRCVFN
 | 
|---|
| 15 |  S PRCVP=67280421310721,PRCVN=99999
 | 
|---|
| 16 |  S PRCVFN=$O(^PRCV(414.04,"D","ITEM",0))
 | 
|---|
| 17 |  ;    Clear old flag
 | 
|---|
| 18 |  K ^TMP("PRCVIT",$J)
 | 
|---|
| 19 |  S PRCVSTN=$$GET1^DIQ(4,$$KSP^XUPARAM("INST")_",",99)
 | 
|---|
| 20 |  F  S PRCVN=$O(^PRC(441,PRCVN)) Q:'PRCVN  D
 | 
|---|
| 21 |  . S PRCVAL=$$CHKSUM()
 | 
|---|
| 22 |  . ;  Compare to existing CheckSum
 | 
|---|
| 23 |  . ;  Kick off HL7 interface message to DynaMed, if not the same
 | 
|---|
| 24 |  . I PRCVAL,PRCVAL'=$P($G(^PRCV(414.04,PRCVFN,1,PRCVN,0)),U,2) D
 | 
|---|
| 25 |  .. S ^PRCV(414.04,PRCVFN,1,PRCVN,0)=PRCVN_U_PRCVAL
 | 
|---|
| 26 |  .. D GETDATA(PRCVN)
 | 
|---|
| 27 |  .. I $D(^TMP("PRCVIT",$J,PRCVN)) D EN^PRCVIMF(PRCVN)
 | 
|---|
| 28 |  .. Q
 | 
|---|
| 29 |  . Q
 | 
|---|
| 30 |  K ^TMP("PRCVIT",$J)
 | 
|---|
| 31 |  Q
 | 
|---|
| 32 |  ;
 | 
|---|
| 33 | ONECHK(PRCVN) ;
 | 
|---|
| 34 |  ;   Checksum to one ITEM only
 | 
|---|
| 35 |  Q:PRCVN<99999
 | 
|---|
| 36 |  N PRCND,PRCVL,PRCVFN,PRCVP,PRCVAL,PRCVIT
 | 
|---|
| 37 |  K ^TMP("PRCVIT",$J,PRCVN)
 | 
|---|
| 38 |  S PRCVP=67280421310721
 | 
|---|
| 39 |  S PRCVFN=$O(^PRCV(414.04,"D","ITEM",0))
 | 
|---|
| 40 |  S PRCVAL=$$CHKSUM()
 | 
|---|
| 41 |  ;   If checksum not equal 0, get data to DynaMed
 | 
|---|
| 42 |  I PRCVAL,PRCVAL'=$P($G(^PRCV(414.04,PRCVFN,1,PRCVN,0)),U,2) D
 | 
|---|
| 43 |  . D GETDATA(PRCVN)
 | 
|---|
| 44 |  . S ^PRCV(414.04,PRCVFN,1,PRCVN,0)=PRCVN_U_PRCVAL
 | 
|---|
| 45 |  . I $D(^TMP("PRCVIT",$J,PRCVN)) D EN^PRCVIMF(PRCVN)
 | 
|---|
| 46 |  . Q
 | 
|---|
| 47 |  K ^TMP("PRCVIT",$J,PRCVN)
 | 
|---|
| 48 |  Q
 | 
|---|
| 49 | INIT ;
 | 
|---|
| 50 |  ;   Initialize checksum global at installation
 | 
|---|
| 51 |  N PRCVN,PRCVP,RESULT,FDA
 | 
|---|
| 52 |  ;
 | 
|---|
| 53 |  S FDA(414.04,"?+1,",.01)="ITEM"
 | 
|---|
| 54 |  S FDA(414.04,"?+1,",.02)=441
 | 
|---|
| 55 |  S FDA(414.04,"?+1,",.03)="Item file checksum (on partial field)"
 | 
|---|
| 56 |  D UPDATE^DIE("E","FDA","RESULT")
 | 
|---|
| 57 |  S PRCVP=67280421310721,PRCVN=99999
 | 
|---|
| 58 |  F  S PRCVN=$O(^PRC(441,PRCVN)) Q:'PRCVN  D
 | 
|---|
| 59 |  . S FDA(414.41,"?+1,"_RESULT(1)_",",.01)=PRCVN
 | 
|---|
| 60 |  . S FDA(414.41,"?+1,"_RESULT(1)_",",1)=$$CHKSUM()
 | 
|---|
| 61 |  . D UPDATE^DIE("E","FDA")
 | 
|---|
| 62 |  Q
 | 
|---|
| 63 |  ;
 | 
|---|
| 64 | CHKSUM() ;
 | 
|---|
| 65 |  N PRCVST
 | 
|---|
| 66 |  S PRCVAL=0
 | 
|---|
| 67 |  ;        Node 0
 | 
|---|
| 68 |  S PRCVIT=$G(^PRC(441,PRCVN,0))
 | 
|---|
| 69 |  ;  Piece 1 - ITEM Number
 | 
|---|
| 70 |  ;  Piece 2 - ITEM Short Description
 | 
|---|
| 71 |  ;  Piece 3 - FSC - Federal Supply Classification
 | 
|---|
| 72 |  ;  Piece 4 - Last vendor ordered
 | 
|---|
| 73 |  ;  Piece 5 - NSN - National Stock Number
 | 
|---|
| 74 |  ;  Piece 6 - Case/Cart Tray/instrument kit
 | 
|---|
| 75 |  ;  Piece 8 - Mandatory Source
 | 
|---|
| 76 |  ;  Piece 9 - Date Item Created
 | 
|---|
| 77 |  ;  Piece 10 - BOC
 | 
|---|
| 78 |  ;  Piece 11 - DUZ
 | 
|---|
| 79 |  ;  Piece 13 - Reusable Item
 | 
|---|
| 80 |  ;  Piece 14 - Hazardous material
 | 
|---|
| 81 |  ;  Piece 15 - NIF ITEM number
 | 
|---|
| 82 |  S PRCVI=0
 | 
|---|
| 83 |  F PRCVI=1:1:6,8:1:11,13:1:15 D
 | 
|---|
| 84 |  . S PRCVST=$P(PRCVIT,U,PRCVI)
 | 
|---|
| 85 |  . S PRCVAL=$$CKINC(PRCVAL,PRCVST)
 | 
|---|
| 86 |  . Q
 | 
|---|
| 87 |  ;        Node 1 - Description
 | 
|---|
| 88 |  ;
 | 
|---|
| 89 |  S PRCVI=0
 | 
|---|
| 90 |  F  S PRCVI=$O(^PRC(441,PRCVN,1,PRCVI)) Q:'PRCVI  D
 | 
|---|
| 91 |  . S PRCVST=^PRC(441,PRCVN,1,PRCVI,0)
 | 
|---|
| 92 |  . S PRCVAL=$$CKINC(PRCVAL,PRCVST)
 | 
|---|
| 93 |  . Q
 | 
|---|
| 94 |  ;        Node 2 - Vendors
 | 
|---|
| 95 |  S PRCVI=0
 | 
|---|
| 96 |  F  S PRCVI=$O(^PRC(441,PRCVN,2,PRCVI)) Q:'PRCVI  D
 | 
|---|
| 97 |  . S PRCVST=^PRC(441,PRCVN,2,PRCVI,0)
 | 
|---|
| 98 |  . S PRCVAL=$$CKINC(PRCVAL,PRCVST)
 | 
|---|
| 99 |  . Q
 | 
|---|
| 100 |  ;        Node 3
 | 
|---|
| 101 |  ;  Piece 1 - Inactivated ITEM?
 | 
|---|
| 102 |  ;  Piece 2 - Date Inactivated
 | 
|---|
| 103 |  ;  Piece 3 - Inactivated By
 | 
|---|
| 104 |  ;  Piece 4 - Replacement Item
 | 
|---|
| 105 |  ;  Piece 5 - MFG Part No.
 | 
|---|
| 106 |  ;  Piece 6 - NSN Verified
 | 
|---|
| 107 |  ;  Piece 7 - Food Group
 | 
|---|
| 108 |  ;  Piece 8 - SKU
 | 
|---|
| 109 |  ;  Piece 9 - Drug Type Code
 | 
|---|
| 110 |  ;  Piece 10 - SIC Code
 | 
|---|
| 111 |  ;
 | 
|---|
| 112 |  ; Check the whole node 3
 | 
|---|
| 113 |  ;
 | 
|---|
| 114 |  S PRCVST=$G(^PRC(441,PRCVN,3))
 | 
|---|
| 115 |  I PRCVST]"" S PRCVAL=$$CKINC(PRCVAL,PRCVST)
 | 
|---|
| 116 |  ;
 | 
|---|
| 117 |  ;        Node 4 - Fund Control Point
 | 
|---|
| 118 |  S PRCVI=0
 | 
|---|
| 119 |  F  S PRCVI=$O(^PRC(441,PRCVN,4,PRCVI)) Q:'PRCVI  D
 | 
|---|
| 120 |  . S PRCVST=$G(^PRC(441,PRCVN,4,PRCVI,0))
 | 
|---|
| 121 |  . S PRCVAL=$$CKINC(PRCVAL,PRCVST)
 | 
|---|
| 122 |  . Q
 | 
|---|
| 123 |  ;        Node 6 - Pre_NIF Long Description
 | 
|---|
| 124 |  S PRCVI=0
 | 
|---|
| 125 |  F  S PRCVI=$O(^PRC(441,PRCVN,6,PRCVI)) Q:'PRCVI  D
 | 
|---|
| 126 |  . S PRCVST=^PRC(441,PRCVN,6,PRCVI,0)
 | 
|---|
| 127 |  . S PRCVAL=$$CKINC(PRCVAL,PRCVST)
 | 
|---|
| 128 |  . Q
 | 
|---|
| 129 |  ;
 | 
|---|
| 130 |  Q PRCVAL
 | 
|---|
| 131 |  ;
 | 
|---|
| 132 | GETDATA(PRCVNM) ;
 | 
|---|
| 133 |  ;     Get all field required, 
 | 
|---|
| 134 |  ;        Node 0
 | 
|---|
| 135 |  ;
 | 
|---|
| 136 |  N PRCVND,PRCVI,PRCVJ,PRCVCON,PRCVERR
 | 
|---|
| 137 |  S PRCVERR=0
 | 
|---|
| 138 |  S PRCVIT=$G(^PRC(441,PRCVNM,0))
 | 
|---|
| 139 |  S PRCVND=$P(PRCVIT,U,1,6)
 | 
|---|
| 140 |  S PRCVJ=6
 | 
|---|
| 141 |  F PRCVI=8:1:11,13,14,15 D
 | 
|---|
| 142 |  . S PRCVJ=PRCVJ+1
 | 
|---|
| 143 |  . S $P(PRCVND,U,PRCVJ)=$P(PRCVIT,U,PRCVI)
 | 
|---|
| 144 |  . Q
 | 
|---|
| 145 |  S $P(PRCVND,U,11)="N"
 | 
|---|
| 146 |  S:$P(PRCVIT,U,13)="Y"!("y") $P(PRCVND,U,11)="Y"
 | 
|---|
| 147 |  S ^TMP("PRCVIT",$J,PRCVNM,0)=PRCVND
 | 
|---|
| 148 |  ;
 | 
|---|
| 149 |  ;        Node 1 - Description
 | 
|---|
| 150 |  S PRCVI=0
 | 
|---|
| 151 |  F  S PRCVI=$O(^PRC(441,PRCVNM,1,PRCVI)) Q:'PRCVI  D
 | 
|---|
| 152 |  . S ^TMP("PRCVIT",$J,PRCVNM,1,PRCVI)=^PRC(441,PRCVNM,1,PRCVI,0)
 | 
|---|
| 153 |  . Q
 | 
|---|
| 154 |  ;        Node 2 - Vendors
 | 
|---|
| 155 |  S PRCVI=0
 | 
|---|
| 156 |  F  S PRCVI=$O(^PRC(441,PRCVNM,2,PRCVI)) Q:'PRCVI  D
 | 
|---|
| 157 |  . S PRCVND=^PRC(441,PRCVNM,2,PRCVI,0)
 | 
|---|
| 158 |  . ; Check if the contract exists in Vendor File
 | 
|---|
| 159 |  . ; If not, send a message to Control Point officer
 | 
|---|
| 160 |  . I $P(PRCVND,U)']"" S $P(PRCVND,U)=0
 | 
|---|
| 161 |  . I $P(PRCVND,U,3)']"" S $P(PRCVND,U,3)=0
 | 
|---|
| 162 |  . S PRCVCON=$G(^PRC(440,$P(PRCVND,U),4,$P(PRCVND,U,3),0))
 | 
|---|
| 163 |  . I $P(PRCVND,U)>0,($P(PRCVND,U,3)>0),($P(PRCVCON,U)']"") D
 | 
|---|
| 164 |  .. S PRCVERR=PRCVERR+1
 | 
|---|
| 165 |  .. S PRCVERR(PRCVERR)="Contract # "_$P(PRCVND,U,3)_" of VENDOR - "_$P(PRCVND,U)_", "_$P($G(^PRC(440,$P(PRCVND,U),0)),U)_", for ITEM # "_PRCVNM_" does not exist in IFCAP Vendor file."
 | 
|---|
| 166 |  .. S $P(PRCVND,U,3)=""
 | 
|---|
| 167 |  .. Q
 | 
|---|
| 168 |  . ; Check exp. date of contract, QUIT if expired more than 365 days
 | 
|---|
| 169 |  . I $P(PRCVCON,U,3)]"",($P(PRCVCON,U,3)<$$FMADD^XLFDT(DT,-365)) S $P(PRCVND,U,3)=""
 | 
|---|
| 170 |  . ; Conversion on PRCVND
 | 
|---|
| 171 |  . S:$P(PRCVND,U,2)="" $P(PRCVND,U,2)=0
 | 
|---|
| 172 |  . S:$P(PRCVND,U,8)="" $P(PRCVND,U,8)=1
 | 
|---|
| 173 |  . S ^TMP("PRCVIT",$J,PRCVNM,2,PRCVI)=PRCVND
 | 
|---|
| 174 |  . Q
 | 
|---|
| 175 |  ;        Node 3
 | 
|---|
| 176 |  I $D(^PRC(441,PRCVNM,3)) S ^TMP("PRCVIT",$J,PRCVNM,3)=^PRC(441,PRCVNM,3)
 | 
|---|
| 177 |  ;
 | 
|---|
| 178 |  ;        Node 4 - Fund Control Point
 | 
|---|
| 179 |  S PRCVI=0
 | 
|---|
| 180 |  F  S PRCVI=$O(^PRC(441,PRCVNM,4,PRCVI)) Q:'PRCVI  D
 | 
|---|
| 181 |  . S PRCVND=^PRC(441,PRCVNM,4,PRCVI,0)
 | 
|---|
| 182 |  . S $P(PRCVND,U)=$E($P(PRCVND,U),4,7)
 | 
|---|
| 183 |  . S ^TMP("PRCVIT",$J,PRCVNM,4,PRCVI)=PRCVND
 | 
|---|
| 184 |  . Q
 | 
|---|
| 185 |  ;
 | 
|---|
| 186 |  ;        Node 6 - Pre_NIF Long Description
 | 
|---|
| 187 |  S PRCVI=0
 | 
|---|
| 188 |  F  S PRCVI=$O(^PRC(441,PRCVNM,6,PRCVI)) Q:'PRCVI  D
 | 
|---|
| 189 |  . S ^TMP("PRCVIT",$J,PRCVNM,6,PRCVI)=^PRC(441,PRCVNM,6,PRCVI,0)
 | 
|---|
| 190 |  . Q
 | 
|---|
| 191 |  ; If there are error(s), inform user by e-mail 
 | 
|---|
| 192 |  I PRCVERR>0 D XMD
 | 
|---|
| 193 |  Q
 | 
|---|
| 194 |  ;
 | 
|---|
| 195 | XMD ; Send a message to Control Point officer/clerk for data mismatch
 | 
|---|
| 196 |  ;
 | 
|---|
| 197 |  N XMDUZ,XMMG,XMSUB,XMTEXT,XMY,XMZ
 | 
|---|
| 198 |  S XMSUB="Inventory System ITEM Update Info "_$$HTE^XLFDT($H)
 | 
|---|
| 199 |  S XMDUZ="IFCAP/COTS Inventory Interface"
 | 
|---|
| 200 |  S XMTEXT="PRCVERR("
 | 
|---|
| 201 |  ; S PRCVERR(1)="Contract "_PRCVCON_" of VENDOR # "_$P(PRCVND,U)_" for ITEM # "_PRCVNM_" does not existed in IFCAP Vendor file."
 | 
|---|
| 202 |  S XMY("G.PRCV Item Vendor Edits")=""
 | 
|---|
| 203 |  D ^XMD
 | 
|---|
| 204 |  Q
 | 
|---|
| 205 |  ;
 | 
|---|
| 206 | CKINC(PRCVF,PRCVS) ;incremental checksum
 | 
|---|
| 207 |  N LEN,FIB,C,I,PRCVAL,TEST
 | 
|---|
| 208 |  S TEST=PRCVF
 | 
|---|
| 209 |  S PRCVF=+$G(PRCVF)
 | 
|---|
| 210 |  S PRCVS=$G(PRCVS)
 | 
|---|
| 211 |  ;No change on null input
 | 
|---|
| 212 |  Q:PRCVS="" PRCVF
 | 
|---|
| 213 |  S LEN=$L(PRCVS)
 | 
|---|
| 214 |  S PRCVAL=0
 | 
|---|
| 215 |  S FIB(1)=1,FIB(2)=1
 | 
|---|
| 216 |  F I=1:1:LEN D
 | 
|---|
| 217 |  .S C=$E(PRCVS,I)
 | 
|---|
| 218 |  .S:I>2 FIB(I)=FIB(I-1)+FIB(I-2)#2147483647
 | 
|---|
| 219 |  .S PRCVAL=(PRCVF+PRCVAL+($A(C)*FIB(I)))#PRCVP
 | 
|---|
| 220 |  Q PRCVAL
 | 
|---|