| 1 | SRBL ;BIR/ADM - BLOOD PRODUCT VERIFICATION FOR VBECS ;09/01/05
 | 
|---|
| 2 |  ;;3.0; Surgery ;**148**;24 Jun 93
 | 
|---|
| 3 |  ; 
 | 
|---|
| 4 |  ; Reference to AVUNIT^VBECA1B supported by DBIA #4629
 | 
|---|
| 5 |  ;
 | 
|---|
| 6 | SCAN D BAR ; test bar code reader
 | 
|---|
| 7 |  S SRQ=0,DFN=$P(^SRF(SRTN,0),"^") K ^TMP("SRBL",$J)
 | 
|---|
| 8 |  D AVUNIT^VBECA1B("SRBL",DFN) ; get list of units available for the patient
 | 
|---|
| 9 | TST K DIR S DIR(0)="FA^1:50",(SRPROMPT,DIR("A"))="Enter Blood Product Identifier: "
 | 
|---|
| 10 |  S DIR("?")="Enter or scan the Blood Product Unit Id" D ^DIR K DIR G END:$D(DTOUT)!$D(DUOUT)
 | 
|---|
| 11 |  D CODA,MATCH I 'SRMATCH G SRNO
 | 
|---|
| 12 |  I SRMATCH=1 S SRY=SRMATCH D SRYES Q
 | 
|---|
| 13 |  D LIST I SRQ G END
 | 
|---|
| 14 |  S SRY=Y D SRYES
 | 
|---|
| 15 |  Q
 | 
|---|
| 16 | LIST W ! S Y=^TMP("SRBL",$J,0),Z=$P(Y,"^",7),SRSSN=$E(Z,1,3)_"-"_$E(Z,4,5)_"-"_$E(Z,6,12)
 | 
|---|
| 17 |  S SRNAME=$P(Y,"^",5)_","_$P(Y,"^",4)_" "_SRSSN
 | 
|---|
| 18 |  S (SRI,SRZ)=0 F  S SRZ=$O(SRBL(SRZ)) Q:'SRZ  D
 | 
|---|
| 19 |  .S Z=SRBL(SRZ),SRPROD=$P(Z,"^",4),X=$P(Z,"^",2) D ^%DT S SREXP=Y
 | 
|---|
| 20 |  .W !!," ",SRZ_") Unit ID: ",SRUID,?45,SRPROD
 | 
|---|
| 21 |  .W !,?4,"Patient: ",SRNAME,?45,"Expiration Date: " S Y=SREXP D DD^%DT W Y
 | 
|---|
| 22 |  .S SRI=SRI+1
 | 
|---|
| 23 |  W ! K DIR S DIR(0)="NO^1:"_SRI,DIR("A")="Select the blood product matching the unit label"
 | 
|---|
| 24 |  D ^DIR K DIR I $D(DTOUT)!$D(DUOUT)!'Y S SRQ=1 Q
 | 
|---|
| 25 |  S SRY=Y
 | 
|---|
| 26 |  Q
 | 
|---|
| 27 | MATCH ; retrieve matching units from list of available units
 | 
|---|
| 28 |  S (SRIDT,SRMATCH)=0 F  S SRIDT=$O(^TMP("SRBL",$J,SRIDT)) Q:'SRIDT  D
 | 
|---|
| 29 |  .S X=^TMP("SRBL",$J,SRIDT)
 | 
|---|
| 30 |  .I $P(X,"^",3)=SRUID S SRMATCH=SRMATCH+1,SRBL(SRMATCH)=X
 | 
|---|
| 31 |  Q
 | 
|---|
| 32 | CODA ; interpret Codabar barcodes used to label the Unit ID of blood component
 | 
|---|
| 33 |  I $$ISBTUID(.X) S SRUID=X Q
 | 
|---|
| 34 |  S SRUID=$$STRIP(X)
 | 
|---|
| 35 |  W ?45,"UNIT ID: ",SRUID
 | 
|---|
| 36 |  Q
 | 
|---|
| 37 | SRYES S X=$P(SRBL(SRY),"^",2) D ^%DT I Y<DT D  D ASK Q
 | 
|---|
| 38 |  .I SRMATCH=1 D LIST
 | 
|---|
| 39 |  .W !!,?30,"**WARNING**",!!,"Today's date exceeds the blood product expiration date.",!
 | 
|---|
| 40 |  W !!!,?25,"No Discrepancies Found",!!! K DIR S DIR(0)="FOA",DIR("A")="Press RETURN to continue" D ^DIR G END
 | 
|---|
| 41 | SRNO W !!,?30,"**WARNING**",!!
 | 
|---|
| 42 |  W ?5,"There is no record that this unit has been assigned to this patient."
 | 
|---|
| 43 |  W !!,?8,"      Please recheck the patient and blood product IDs.",!!
 | 
|---|
| 44 | ASK K DIR S DIR(0)="Y",DIR("A")="Do you want to scan another product (Y/N)",DIR("B")="YES" D ^DIR I Y D END G SCAN
 | 
|---|
| 45 | END K ^TMP("SRBL",$J),DIR,SR,SRBL,SREXP,SRI,SRIDT,SRMATCH,SRNAME,SRPROD,SRPROMPT,SRQ,SRSSN,SRUID,SRY,SRZ,X,Y,Z
 | 
|---|
| 46 |  Q
 | 
|---|
| 47 | STRIP(X) ; strip off any ISBT-128 barcode identifier characters
 | 
|---|
| 48 |  S X=$TR(X,"=<>&%(","")
 | 
|---|
| 49 |  Q X
 | 
|---|
| 50 | BAR ; test bar code reader
 | 
|---|
| 51 |  N A,SR,SRABO,SRRH,SRPROMPT,X,Y S SR=""
 | 
|---|
| 52 |  K DIR S DIR(0)="FAO^1:20" S DIR("A",1)="",(SRPROMPT,DIR("A"))="                         => "
 | 
|---|
| 53 |  S DIR("A",2)="                            To use BAR CODE READER"
 | 
|---|
| 54 |  S DIR("A",3)="               Pass reader wand over a GROUP-TYPE (ABO/Rh) label"
 | 
|---|
| 55 |  S DIR("?",2)="     To test scanner, scan a GROUP-TYPE (ABO/Rh) label. Otherwise, press"
 | 
|---|
| 56 |  S DIR("?",1)="",DIR("?")="     the Enter key." D ^DIR K DIR Q:$D(DTOUT)!$D(DUOUT)!(X="")
 | 
|---|
| 57 |  W $C(13),$J("",79),$C(13),SRPROMPT,"(Bar code)"
 | 
|---|
| 58 |  D ISBTBG(X,.SRABO,.SRRH) I SRABO]"" D  Q
 | 
|---|
| 59 |  .S SR=1,SR(2)=""
 | 
|---|
| 60 |  .W " ",SRABO," ",SRRH
 | 
|---|
| 61 |  S X=$$STRIP(X)
 | 
|---|
| 62 |  F A=1:1 S Y=$P($T(G+A),";",4) Q:Y=""  S X(1)=$F(X,Y) I X(1),$L(X)<X(1) S SR=$L(X)-3,SR(2)=$E(X,1,SR),SR=SR+1 Q
 | 
|---|
| 63 |  I SR="" W $C(7),!!?28,"Not a GROUP-TYPE label",!?15,"Press <ENTER> key if BAR CODE READER is not used",! G BAR
 | 
|---|
| 64 |  W " ",$P($T(G+A),";",3)
 | 
|---|
| 65 |  Q
 | 
|---|
| 66 | ISBTBG(SRIN,SRBLABO,SRBLRH) ; check for ISBT-128 valid blood group and return ABO & Rh values
 | 
|---|
| 67 |  ; Valid codes are prefixed by "=%".
 | 
|---|
| 68 |  ;
 | 
|---|
| 69 |  ; INPUT  : SRIN = input from Blood Group barcode label.
 | 
|---|
| 70 |  ; OUTPUT : SRBLABO (passed by reference) = ABO value
 | 
|---|
| 71 |  ;          SRBLRH  (passed by reference) = Rh value
 | 
|---|
| 72 |  ;
 | 
|---|
| 73 |  N Z S (SRBLABO,SRBLRH)=""
 | 
|---|
| 74 |  Q:$L(SRIN)'>3
 | 
|---|
| 75 |  Q:$E(SRIN,1,2)'="=%"
 | 
|---|
| 76 |  S Z=$E(SRIN,3,4)
 | 
|---|
| 77 |  S SRBLABO=$S(57<Z&(Z<66):"A POS",46<Z&(Z<55):"O POS",90<Z&(Z<99):"O NEG",1<Z&(Z<10):"A NEG",12<Z&(Z<21):"B NEG",68<Z&(Z<77):"B POS",23<Z&(Z<32):"AB NEG",79<Z&(Z<88):"AB POS",1:"")
 | 
|---|
| 78 |  Q:SRBLABO=""
 | 
|---|
| 79 |  S SRBLRH=$P(SRBLABO," ",2)
 | 
|---|
| 80 |  S SRBLABO=$P(SRBLABO," ")
 | 
|---|
| 81 |  Q
 | 
|---|
| 82 | ISBTUID(SRBLIN) ; Check for and display valid ISBT-128 Unit Id
 | 
|---|
| 83 |  ; Valid codes are prefixed by "="
 | 
|---|
| 84 |  ;
 | 
|---|
| 85 |  ; INPUT  : SRBLIN = input from Unit Id barcode label.
 | 
|---|
| 86 |  ; OUTPUT : Boolean
 | 
|---|
| 87 |  ;
 | 
|---|
| 88 |  Q:$E(SRBLIN,1,2)'?1"="1(1A,1N) 0
 | 
|---|
| 89 |  S SRBLIN=$E(SRBLIN,2,14)
 | 
|---|
| 90 |  S SRBLIN=$$UP^XLFSTR(SRBLIN) ; make uppercase
 | 
|---|
| 91 |  W $C(13),$J("",79),$C(13),SRPROMPT,?32,"(Bar code)"
 | 
|---|
| 92 |  D EN^DDIOL("UNIT ID: "_SRBLIN,"","?46")
 | 
|---|
| 93 |  Q 1
 | 
|---|
| 94 | G ;;
 | 
|---|
| 95 | 51 ;;O POS;510
 | 
|---|
| 96 | 62 ;;A POS;620
 | 
|---|
| 97 | 73 ;;B POS;730
 | 
|---|
| 98 | 84 ;;AB POS;840
 | 
|---|
| 99 | 95 ;;O NEG;950
 | 
|---|
| 100 | 6 ;;A NEG;060
 | 
|---|
| 101 | 17 ;;B NEG;170
 | 
|---|
| 102 | 28 ;;AB NEG;280
 | 
|---|
| 103 | 55 ;;O;550
 | 
|---|
| 104 | 66 ;;A;660
 | 
|---|
| 105 | 77 ;;B;770
 | 
|---|
| 106 | 88 ;;AB;880
 | 
|---|
| 107 |  ;;NA NA;
 | 
|---|