| 1 | PRCOVUP ;WISC/DJM/AS-VENDOR UPDATE SERVER ROUTINE ;3/8/05
 | 
|---|
| 2 | V ;;5.1;IFCAP;**81**;Oct 20, 2000
 | 
|---|
| 3 |  ;Per VHA Directive 10-93-142, this routine should not be modified.
 | 
|---|
| 4 | IN ;THIS ROUTINE WILL BE CALLED FROM THE 'FMS' SERVER VIA FILE 423.5
 | 
|---|
| 5 |  ;ENTRY FOR THE VENDOR UPDATE TRANSACTION (VUP).
 | 
|---|
| 6 |  ;PRCDA IS THE INTERNAL ENTRY NUMBER FOR THE RECORD FROM FILE 423.6.
 | 
|---|
| 7 |  N AAN,AAC,ALTADD,ENTRY1,II,LOOP,PRCMG,PRCXM,LINE,STATION,STCK,ENTRY,ENCK,VEN3,VEN7,MGP,NAME,DIE,DR,DA,MTI,FMSVC,ZIP,%X,%Y,ALTFLG,FMS,ACTIVE
 | 
|---|
| 8 |  S LINE=$G(^PRCF(423.6,PRCDA,1,10000,0))
 | 
|---|
| 9 |  S MGP=$O(^PRCF(423.5,"B",$P(LINE,U)_"-"_$P(LINE,U,5),0))
 | 
|---|
| 10 |  S MGP=$G(^PRCF(423.5,MGP,0))
 | 
|---|
| 11 |  S PRCMG=$P($G(^XMB(3.8,$P(MGP,U,2),0)),U)
 | 
|---|
| 12 |  S LOOP=10000
 | 
|---|
| 13 |  F  S LOOP=$O(^PRCF(423.6,PRCDA,1,LOOP)) Q:LOOP'>0  D FIND Q:LINE["{"  I $D(PRCXM) S PRCXM(4)=LINE D PERROR^PRCOSRV3
 | 
|---|
| 14 |  D KILL^PRCOSRV3(PRCDA)
 | 
|---|
| 15 |  Q
 | 
|---|
| 16 |  ;
 | 
|---|
| 17 | FIND S LINE=$G(^PRCF(423.6,PRCDA,1,LOOP,0))
 | 
|---|
| 18 |  Q:LINE["{"
 | 
|---|
| 19 |  S STATION=$P(LINE,U,4)
 | 
|---|
| 20 |  S STCK=$O(^PRC(411,"B",STATION,0))
 | 
|---|
| 21 |  I STCK'>0 S PRCXM(1)=$P($T(ERROR+1),";;",2) Q
 | 
|---|
| 22 |  K ACTIVE
 | 
|---|
| 23 |  S ENTRY=$P(LINE,U,5)
 | 
|---|
| 24 |  I ENTRY>0 S ACTIVE=1 D ENCK
 | 
|---|
| 25 |  S (ENTRY1,ALTFLG)=0
 | 
|---|
| 26 |  S FMS=$P(LINE,U,6)
 | 
|---|
| 27 |  I FMS="" S PRCXM(3)=$P($T(ERROR+3),";;",2) Q
 | 
|---|
| 28 |  S AAC=$P(LINE,U,7)
 | 
|---|
| 29 |  F  S ENTRY1=$O(^PRC(440,"D",FMS,ENTRY1)) Q:ENTRY1'>0  D  Q:$D(PRCXM)  I ALTFLG=1 S ENTRY=ENTRY1 D ENCK I $D(PRCXM) S PRCXM(4)=LINE D PERROR^PRCOSRV3
 | 
|---|
| 30 |  .S VEN3=$G(^PRC(440,ENTRY1,3))
 | 
|---|
| 31 |  .I VEN3="" S PRCXM(2)=$P($T(ERROR+2),";;",2),PRCXM(4)=LINE D PERROR^PRCOSRV3 Q
 | 
|---|
| 32 |  .S ALTADD=$P(VEN3,U,5) I ALTADD=AAC S ALTFLG=1
 | 
|---|
| 33 |  .Q
 | 
|---|
| 34 |  Q
 | 
|---|
| 35 |  ;
 | 
|---|
| 36 | ENCK S ALTFLG=0
 | 
|---|
| 37 |  S ENCK=$G(^PRC(440,ENTRY,0))
 | 
|---|
| 38 |  I ENCK="" S PRCXM(2)=$P($T(ERROR+2),";;",2) Q
 | 
|---|
| 39 |  K ^PRC(440.3,ENTRY)
 | 
|---|
| 40 |  S %Y="^PRC(440.3,ENTRY,"
 | 
|---|
| 41 |  S %X="^PRC(440,ENTRY,"
 | 
|---|
| 42 |  D %XY^%RCR
 | 
|---|
| 43 |  S VEN3=$G(^PRC(440,ENTRY,3))
 | 
|---|
| 44 |  I $P(LINE,U,7)]"" S $P(VEN3,U,5)=$P(LINE,U,7)
 | 
|---|
| 45 |  I $P(LINE,U,14)]"" S $P(VEN3,U,9)=$P(LINE,U,14)
 | 
|---|
| 46 |  S $P(VEN3,U,12)="C"
 | 
|---|
| 47 |  I $P(LINE,U,15)]"" S $P(VEN3,U,11)=$P(LINE,U,15)
 | 
|---|
| 48 |  I $P(LINE,U,16)]"" S $P(VEN3,U,14)=$P(LINE,U,16)
 | 
|---|
| 49 |  I $P(LINE,U,17)]"" S $P(VEN3,U,13)=$P(LINE,U,17)
 | 
|---|
| 50 |  I $P(LINE,U,19)]"" S $P(VEN3,U,15)=$P(LINE,U,19)
 | 
|---|
| 51 |  I $P(LINE,U,20)]"" S $P(VEN3,U,10)=$P(LINE,U,20)
 | 
|---|
| 52 |  ;set fms vendor name (field is uneditable)
 | 
|---|
| 53 |  S NAME=$P(LINE,U,8)
 | 
|---|
| 54 |  I NAME]"" D
 | 
|---|
| 55 |  .F II=1:1 S AAN=$E(NAME,II) Q:AAN?1AN  S NAME=$E(NAME,2,99)
 | 
|---|
| 56 |  .S $P(VEN3,U,7)=NAME
 | 
|---|
| 57 |  .Q
 | 
|---|
| 58 |  S VEN7=$G(^PRC(440,ENTRY,7))
 | 
|---|
| 59 |  I $P(LINE,U,9)]"" S $P(VEN7,U,3)=$P(LINE,U,9)
 | 
|---|
| 60 |  I $P(LINE,U,10)]"" S $P(VEN7,U,4)=$P(LINE,U,10)
 | 
|---|
| 61 |  I $P(LINE,U,11)]"" S $P(VEN7,U,7)=$P(LINE,U,11)
 | 
|---|
| 62 |  S ZIP=$P(LINE,U,13) I ZIP]"" D
 | 
|---|
| 63 |  .S $P(VEN7,U,9)=$S($L(ZIP)=9:$E(ZIP,1,5)_"-"_$E(ZIP,6,9),1:ZIP)
 | 
|---|
| 64 |  .Q
 | 
|---|
| 65 |  I $P(LINE,U,12)]"" S $P(VEN7,U,8)=$O(^DIC(5,"C",$P(LINE,U,12),0))
 | 
|---|
| 66 |  S ^PRC(440,ENTRY,3)=VEN3
 | 
|---|
| 67 |  S ^PRC(440,ENTRY,7)=VEN7
 | 
|---|
| 68 |  S DIE="^PRC(440,"
 | 
|---|
| 69 |  S DA=ENTRY
 | 
|---|
| 70 |  S FMSVC=$P(LINE,U,6)
 | 
|---|
| 71 |  S DR="34////^S X=FMSVC"
 | 
|---|
| 72 |  S NAME=$P(ENCK,U)
 | 
|---|
| 73 |  S MTI="" I $P(LINE,U,19)]"" S MTI=$P(LINE,U,19)
 | 
|---|
| 74 |  I MTI="D" S NAME="**"_NAME,DR=DR_";.01////^S X=NAME;31.5////^S X=1;15////@"
 | 
|---|
| 75 |  I $G(ACTIVE),"ACF"[MTI,$E(NAME,1,2)="**" S NAME=$E(NAME,3,99),DR=DR_";.01////^S X=NAME;31.5////@;15////@"
 | 
|---|
| 76 |  D ^DIE
 | 
|---|
| 77 |  D BUL^PRCOVUP4
 | 
|---|
| 78 |  ;   SEND VENDOR UPDATE INFORMATION TO DYNAMED  **81**
 | 
|---|
| 79 |  D:$$GET^XPAR("SYS","PRCV COTS INVENTORY",1)=1 ONECHK^PRCVNDR(ENTRY)
 | 
|---|
| 80 |  K ^PRC(440.3,ENTRY),ACTIVE
 | 
|---|
| 81 |  Q
 | 
|---|
| 82 |  ;
 | 
|---|
| 83 | ERROR ;HERE IS THE LIST OF ERROR MESSAGES
 | 
|---|
| 84 |  ;;The STATION number from FMS can not be found at this location.
 | 
|---|
| 85 |  ;;The VENDOR file entry returned from FMS can not be found.
 | 
|---|
| 86 |  ;;This FMS transaction has no FMS VENDOR CODE.
 | 
|---|