| 1 | PSAP56 ;VMP/PDW-DUPLICATE REMOVAL ;93/17/2006
 | 
|---|
| 2 |  ;;3.0;DRUG ACCOUNTABILITY/INVENTORY INTERFACE;**56**; 10/24/97
 | 
|---|
| 3 |  ;;References to ^PSDRUG( are covered by DBIA #2095
 | 
|---|
| 4 | EN ;
 | 
|---|
| 5 |  D EXIT
 | 
|---|
| 6 |  S VSN=0 F  S VSN=$O(^PSDRUG("AVSN",VSN)) Q:VSN'>0  D VSN
 | 
|---|
| 7 |  D MAILMSG,EXIT
 | 
|---|
| 8 |  Q
 | 
|---|
| 9 | VSN ;
 | 
|---|
| 10 |  S DRDA=0,RXCNT=0 F  S DRDA=$O(^PSDRUG("AVSN",VSN,DRDA)) Q:DRDA'>0  D DRDA
 | 
|---|
| 11 |  Q
 | 
|---|
| 12 | DRDA ;process drug:VSN
 | 
|---|
| 13 |  ;SYN0(counter)=node, SYNIEN(counter)=SYDA
 | 
|---|
| 14 |  K SYN0,SYNIEN,SYNDUP,SYNDC,SYCNT
 | 
|---|
| 15 |  S SYDA=0 F  S SYDA=$O(^PSDRUG("AVSN",VSN,DRDA,SYDA)) Q:SYDA'>0  D
 | 
|---|
| 16 |  . ; if more DRUG VSN decendents process the DRUG
 | 
|---|
| 17 |  .I +$O(^PSDRUG("AVSN",VSN,DRDA,SYDA)) D MORE
 | 
|---|
| 18 |  Q
 | 
|---|
| 19 | MORE ;
 | 
|---|
| 20 |  K SYN0,SYNIEN,SYNDUP,SYNDC,SYCNT
 | 
|---|
| 21 |  S SYNIEN=0 F  S SYNIEN=$O(^PSDRUG("AVSN",VSN,DRDA,SYNIEN)) Q:SYNIEN'>0  D
 | 
|---|
| 22 |  .S SYCNT=$G(SYCNT)+1,SYN0(SYCNT)=^PSDRUG(DRDA,1,SYNIEN,0),SYNIEN(SYCNT)=SYNIEN
 | 
|---|
| 23 |  .S SYDA=SYNIEN ; reset upper loop to end of VSNs
 | 
|---|
| 24 |  ;
 | 
|---|
| 25 | DUPS ;compare synonyms of the identical VSN/drug found
 | 
|---|
| 26 |  K SYNDUP
 | 
|---|
| 27 |  ;pairs of divisions may have set the same drug with different DUOU, dups then on sereval DUOU
 | 
|---|
| 28 |  ;FIND EXACT MATCHES, store pairs in SYNDUP(N1,N2)="", and DELETE ALL BUT FIRST
 | 
|---|
| 29 |  F N1=1:1:SYCNT-1 F N2=N1+1:1:SYCNT I SYN0(N1)=SYN0(N2) S SYNDUP(N1,N2)=""
 | 
|---|
| 30 |  I '$D(SYNDUP) Q
 | 
|---|
| 31 |  D DELETE
 | 
|---|
| 32 |  D LOGDUP
 | 
|---|
| 33 |  Q
 | 
|---|
| 34 | DELETE ;
 | 
|---|
| 35 |  Q:'$D(SYNDUP)
 | 
|---|
| 36 |  S N1=0 F  S N1=$O(SYNDUP(N1)) Q:N1'>0  D
 | 
|---|
| 37 |  . S N2=0 F  S N2=$O(SYNDUP(N1,N2)) Q:N2'>0  D
 | 
|---|
| 38 |  . . K DIK S DA(1)=DRDA,DA=SYNIEN(N2),DIK="^PSDRUG("_DA(1)_",1," D ^DIK
 | 
|---|
| 39 |  . . K SYNDC(N2) ;if dup N2 is removed its NDC match to others needs to be removed
 | 
|---|
| 40 |  . . K SYNDUP(N2) ; if N2 has dups they will also have been picked up under N1 already
 | 
|---|
| 41 |  Q
 | 
|---|
| 42 | LOGDUP ;
 | 
|---|
| 43 |  S DRGNM=$P(^PSDRUG(DRDA,0),U,1)
 | 
|---|
| 44 |  S SYDAL=0 F  S SYDAL=$O(SYNDUP(SYDAL)) Q:SYDAL'>0  S ^TMP($J,"PSADUP",DRGNM,DRDA,SYNIEN(SYDAL))=0
 | 
|---|
| 45 |  Q
 | 
|---|
| 46 |  ;SYN0(SYCNT)=^PSDRUG(DRDA,1,SYDA,0)
 | 
|---|
| 47 |  ;SYNIEN(SYCNT)=SYDA
 | 
|---|
| 48 |  ;S SYNDUP(N1,N2)=""
 | 
|---|
| 49 |  ;S SYNDC(N1,N2)=""
 | 
|---|
| 50 | MAILMSG ; generate mail message of duplicates deleted.
 | 
|---|
| 51 |  K ^TMP($J,"PSAMM")
 | 
|---|
| 52 |  N DIFROM
 | 
|---|
| 53 |  I $D(^TMP($J,"PSADUP")) I 1
 | 
|---|
| 54 |  E  G NOMSG
 | 
|---|
| 55 |  S X="PSA*3*56 DELETE DUPLICATE SYNONYMS REPORT" D MMLN
 | 
|---|
| 56 |  S X="The following Drug-Synonyms have had identical synonyms removed from the drug." D MMLN
 | 
|---|
| 57 |  S X="" D TXT("Drug Name",1),TXT("DRG#,SYN#",43),TXT("NDC",53),TXT("VSN",68),MMLN
 | 
|---|
| 58 |  S DRGNM="" F  S DRGNM=$O(^TMP($J,"PSADUP",DRGNM)) Q:DRGNM=""  D DRIEN
 | 
|---|
| 59 |  S XMSUB="PSA*3*56 Delete Duplicate Drug Synonyms report"
 | 
|---|
| 60 |  S XMTEXT="^TMP($J,""PSAMM"",",XMDUZ="PSA*3*56 Post Init"
 | 
|---|
| 61 |  S XMY(DUZ)=""
 | 
|---|
| 62 |  D ^XMD
 | 
|---|
| 63 |  Q
 | 
|---|
| 64 | DRIEN ;work the specific drug
 | 
|---|
| 65 |  S DRDA=0 F  S DRDA=$O(^TMP($J,"PSADUP",DRGNM,DRDA)) Q:DRDA'>0  D SYNDR
 | 
|---|
| 66 |  Q
 | 
|---|
| 67 | SYNDR ; work synonyms under a drug
 | 
|---|
| 68 |  S SYNDA=0 F  S SYNDA=$O(^TMP($J,"PSADUP",DRGNM,DRDA,SYNDA)) Q:SYNDA'>0  D SYN
 | 
|---|
| 69 |  Q
 | 
|---|
| 70 | SYN ;report the individual synonym that had duplicates deleted
 | 
|---|
| 71 |  K SYNFLD
 | 
|---|
| 72 |  ;2-NDC'2 400-VSN'4 401-OU'5 402-PPOU'6 403-DUOU'7 404-PPDU'8
 | 
|---|
| 73 |  S SYN0=^PSDRUG(DRDA,1,SYNDA,0),X=SYN0,DA=SYNDA,DA(1)=DRDA,IENS=DA_","_DA(1)_","
 | 
|---|
| 74 |  S NDC=$P(X,U,2),VSN=$P(X,U,4),PPOU="PPOU: $"_$P(X,U,6),DUOU="DUOU: "_$P(X,U,7),PPDU="PPDU: $"_$P(X,U,8)
 | 
|---|
| 75 |  S OU="OU: "_$$GET1^DIQ(50.1,IENS,401),DA(1)=DRDA
 | 
|---|
| 76 |  S X="" D TXT(DRGNM,1),TXT(DRDA_","_SYNDA,43),TXT(NDC,53),TXT(VSN,68) D MMLN
 | 
|---|
| 77 |  S X="" D TXT(OU,1),TXT(PPOU,15),TXT(DUOU,45),TXT(PPDU,60) D MMLN
 | 
|---|
| 78 |  Q
 | 
|---|
| 79 | MMLN S MMLC=+$G(MMLC)+1 S ^TMP($J,"PSAMM",MMLC)=X Q
 | 
|---|
| 80 | TXT(VAL,COL) S:'$D(X) X="" S X=$$SETSTR^VALM1(VAL,X,COL,$L(VAL)) Q
 | 
|---|
| 81 | NOMSG ; report no duplicates found to remove.
 | 
|---|
| 82 |  S X="PSA*3*56 DELETE DUPLICATE SYNONYMS REPORT" D MMLN
 | 
|---|
| 83 |  S X=" " D MMLN
 | 
|---|
| 84 |  S X="There were no duplicate drug-synonyms found. No synonyms removed." D MMLN
 | 
|---|
| 85 |  S XMSUB="PSA*3*56 Delete Duplicate Drug Synonyms report"
 | 
|---|
| 86 |  S XMTEXT="^TMP($J,""PSAMM"",",XMDUZ="PSA*3*56 Post Init"
 | 
|---|
| 87 |  S XMY(DUZ)=""
 | 
|---|
| 88 |  D ^XMD
 | 
|---|
| 89 | EXIT ;
 | 
|---|
| 90 |  K COL,DIK,DRDA,DRGNM,DUOU,IENS,MMLC,N1,N2,NDC,OU,PPDU,DDOU,RXCNT,SYCNT,SYDA,SYN0
 | 
|---|
| 91 |  K SYNDA,SYNDC,SYNDUP,SYNFLD,SYNIEN,SYN0,^TMP($J),VAL,VSN,PPOU,SYDAL
 | 
|---|
| 92 |  Q
 | 
|---|