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;
|
---|