Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: BMXADOF2

BMXADOF2.m

Go to the documentation of this file.
  1. BMXADOF2 ; IHS/CIHA/GIS - RPC CALL FOR EXTENDED FUNCTIONALITY OF BMXNet UTILITIES ;
  1. ;;4.0;BMX;;JUN 28, 2010
  1. ; THIS ROUTINE CONTAINS SPECIAL ENTRY POINTS FOR UPDATING RPMS
  1. ;
  1. ;
  1. ;
  1. VVAR(DATA) ; EP-CHECK SPECIAL VARIABLES REQUIRED FOR UPDATING THE VISIT FILE
  1. I '$L(DATA) S OUT="Update cancelled. Missing data string" Q 0
  1. N X,I,Y,VDATE,%DT
  1. K AUPNPAT,AUPNDOB,AUPNDOD,AUPNVSIT ; THE VARS ARE NOT NEW'D SINCE THEY WILL BE USED BY THE CALLING ROUTINE
  1. S AUPNTALK=1,AUPNOVRR=1
  1. S X=DATA S X=$TR(X,($C(30)_"+"),$C(30)) S X=$TR(X,($C(30)_"-"),$C(30)) S X=$TR(X,($C(30)_"`"),$C(30)) S DATA=X ; STRIP OFF TRANSACTION FLAGS FROM FIELD NUMBERS
  1. S X=$P(DATA,"|",2),X=$P(X,$C(30)),VDATE=-1
  1. I $E(X,1,7)?7N S VDATE=X
  1. E S %DT="T" D ^%DT S VDATE=Y
  1. I VDATE=-1 S OUT="Update cancelled. Visit timestamp misssing/invalid" Q 0
  1. S Y=+$P(DATA,($C(30)_".05|"),2) I 'Y S OUT="Update cancelled. Patient data missing" Q 0 ; FAILED TO FIND THE PATIENT IEN
  1. S AUPNPAT=Y
  1. S AUPNDOB=$P($G(^DPT(AUPNPAT,0)),U,3) I 'AUPNDOB S OUT="Update cancelled. Missing DOB" Q 0
  1. I AUPNDOB>VDATE S OUT="Update cancelled. Patient born afer visit date???" Q 0
  1. S AUPNDOD=$P($G(^DPT(AUPNPAT,.35)),U)
  1. I AUPNDOD,AUPNDOD<VDATE S OUT="Update cancelled. Patient died before this visit date" Q
  1. Q 1
  1. ;
  1. NARR() ;EP - GET IEN OF PROVIDER NARR & UPDATE DATA STG FOR PROBLEM FILE
  1. N PCE,NARR,NIEN,IPCE,%,I,NN,DIC,X,Y,FLD,FIEN
  1. S PCE=0,FIEN=+SCHEMA,NIEN=""
  1. F I=3:1:$L(SCHEMA,U) D I PCE Q
  1. . S %=$P(SCHEMA,U,I)
  1. . S FLD=$P(%,"|",2)
  1. . I 'FLD Q
  1. . I $P($G(^DD(FIEN,FLD,0)),U,2)["P9999999.27" S PCE=I
  1. . Q
  1. I 'PCE Q ""
  1. S NARR=$P(DATA,U,PCE) I NARR="" Q ""
  1. S NIEN=$$XMATCH(NARR)
  1. I 'NIEN D ; CREATE A NEW ENTRY IN THE PROVIDER NARRATIVE FILE
  1. . S DIC=9999999.27
  1. . S DIC(0)="L"
  1. . S X=""""_NARR_""""
  1. . D ^DIC I Y=-1 Q
  1. . S NIEN=+Y
  1. . Q
  1. I 'NIEN Q ""
  1. S $P(DATA,U,PCE)="`"_NIEN ; STUFF THE NARRATIVE LOOKUP VALUE INTO THE DATA STRING
  1. Q NIEN
  1. ;
  1. XMATCH(NARR) ; IF THERE IS AN EXACT MATCH IN THE PROVIDER NARRATIVE FILE, RETURN THE IEN
  1. N IX,X,Y,%
  1. S IX=$E(NARR,1,30)
  1. S %=$O(^AUTNPOV("B",IX,0))
  1. I '% Q ""
  1. I %,'$O(^AUTNPOV("B",IX,%)) Q %
  1. S Y=""
  1. S %=0 F S %=$O(^AUTNPOV("B",IX,%)) Q:'% S X=$P($G(^AUTNPOV(%,0)),U) I X=NARR S Y=% Q
  1. Q Y
  1. ;