| 1 | SD53P317 ;ALB/JAM - Restricting Stop Code Post-Init Rtn ; 0707/03
 | 
|---|
| 2 |  ;;5.3;Scheduling;**317**;AUG 13, 1993
 | 
|---|
| 3 |  ;
 | 
|---|
| 4 | POST ; entry point
 | 
|---|
| 5 |  ;* Appropriating Stop Code fl #40.7 entries with restriction type & date
 | 
|---|
| 6 |  N SDJ,ZTRTN,ZTDESC,ZTIO,ZTDTH,ZTREQ,ZTSAVE
 | 
|---|
| 7 |  I $D(^UTL("STPCODE")) K ^UTL("STPCODE")
 | 
|---|
| 8 |  S SDJ=$J
 | 
|---|
| 9 |  D MES^XPDUTL(" ")
 | 
|---|
| 10 |  D BMES^XPDUTL("This post install process does the following:-")
 | 
|---|
| 11 |  D BMES^XPDUTL("  1. Appropriates Stop Code entries in CLINIC STOP file (#40.7) with a ")
 | 
|---|
| 12 |  D MES^XPDUTL("     Restriction Type and Date.")
 | 
|---|
| 13 |  D BMES^XPDUTL("  2. Check clinics in file #44 for nonconforming Stop Codes and produces")
 | 
|---|
| 14 |  D MES^XPDUTL("     a MailMan message.")
 | 
|---|
| 15 |  D MES^XPDUTL(" ")
 | 
|---|
| 16 |  ;read and store stop codes in ^UTILITY("STPCODE",SDJ,
 | 
|---|
| 17 |  D ^SDSTPD1
 | 
|---|
| 18 |  ;assign stop code restriction type and restriction date
 | 
|---|
| 19 |  D STPMOD
 | 
|---|
| 20 |  ;check file #44 for non-conforming restriction type
 | 
|---|
| 21 |  S ZTRTN="PROCESS^SD53P317"
 | 
|---|
| 22 |  S ZTDESC="Non-Conforming Clinics Restricted Stop Code Report"
 | 
|---|
| 23 |  S ZTIO="",ZTDTH=$H,ZTREQ="@" D ^%ZTLOAD
 | 
|---|
| 24 |  D MES^XPDUTL(" ")
 | 
|---|
| 25 |  D BMES^XPDUTL("completed...")
 | 
|---|
| 26 |  D MES^XPDUTL(" ")
 | 
|---|
| 27 |  K ^UTILITY("STPCODE")
 | 
|---|
| 28 |  Q
 | 
|---|
| 29 | STPMOD ;* designate stop codes in file 40.7 as primary, secondary or either
 | 
|---|
| 30 |  ;
 | 
|---|
| 31 |  ;  SDXX is in format:
 | 
|---|
| 32 |  ;   STOP CODE^NAME^RESTRICTION TYPE^RESTRICTION DATE^INACTIVE DATE
 | 
|---|
| 33 |  ;
 | 
|---|
| 34 |  N SDX,SDXX,NAME,CODE,RESTY,RESDT,X,Y,DIC,DIE,DA,DR,IEN,INACT
 | 
|---|
| 35 |  D BMES^XPDUTL("Adding Restricted Type and Restricted Date to CLINIC STOP File (#40.7)...")
 | 
|---|
| 36 |  D MES^XPDUTL(" ")
 | 
|---|
| 37 |  S SDX=0 F  S SDX=$O(^UTILITY("STPCODE",SDJ,SDX)) Q:'SDX  S SDXX=^(SDX) D
 | 
|---|
| 38 |  .S CODE=$P(SDXX,U),NAME=$P(SDXX,U,2),RESTY=$P(SDXX,U,3)
 | 
|---|
| 39 |  .S RESDT=$P(SDXX,U,4),INACT=$P(SDXX,U,5)
 | 
|---|
| 40 |  .I '$D(^DIC(40.7,"C",CODE)) S ^TMP("STPCD",$J,CODE)=SDXX Q
 | 
|---|
| 41 |  .S IEN=$O(^DIC(40.7,"C",CODE,0)) I 'IEN Q
 | 
|---|
| 42 |  .I '$D(^DIC(40.7,IEN,0)) S ^TMP("STPCD",$J,CODE)=SDXX Q
 | 
|---|
| 43 |  .S IEN=0 F  S IEN=$O(^DIC(40.7,"C",CODE,IEN)) Q:'IEN  D FILSC
 | 
|---|
| 44 |  .W !,?2,CODE,?7,NAME,?40,"National Code Updated...."
 | 
|---|
| 45 |  D MES^XPDUTL(" ")
 | 
|---|
| 46 |  S RESTY="S" F SDX=450:1:485 D
 | 
|---|
| 47 |  .Q:'$D(^DIC(40.7,"C",SDX))  S IEN=$O(^DIC(40.7,"C",SDX,0)) I 'IEN Q
 | 
|---|
| 48 |  .Q:'$D(^DIC(40.7,IEN,0))  S SDXX=^(0) S RESDT="10/1/2003"
 | 
|---|
| 49 |  .S IEN=0 F  S IEN=$O(^DIC(40.7,"C",SDX,IEN)) Q:'IEN  D FILSC
 | 
|---|
| 50 |  .W !,?2,SDX,?7,$P(SDXX,U),?40,"Local Code Updated...."
 | 
|---|
| 51 |  D MES^XPDUTL(" ")
 | 
|---|
| 52 |  S CODE="" F  S CODE=$O(^TMP("STPCD",$J,CODE)) Q:CODE=""  D
 | 
|---|
| 53 |  .S SDX=^TMP("STPCD",$J,CODE),NAME=$P(SDX,U,2)
 | 
|---|
| 54 |  .S RESTY=$P(SDXX,U,3),RESDT=$P(SDXX,U,4),INACT=$P(SDXX,U,5)
 | 
|---|
| 55 |  .W !,?2,CODE,?7,NAME,?40,"Problematic....code not in file 40.7"
 | 
|---|
| 56 |  D MES^XPDUTL(" ")
 | 
|---|
| 57 |  S IEN=0 F  S IEN=$O(^DIC(40.7,IEN)) Q:'IEN  D
 | 
|---|
| 58 |  .S SDXX=$G(^DIC(40.7,IEN,0)) Q:SDXX=""  Q:$P(SDXX,U,6)'=""
 | 
|---|
| 59 |  .W !,?2,$P(SDXX,U,2),?7,$E($P(SDXX,U),1,30),?40,"Missing Restriction Type."
 | 
|---|
| 60 |  Q
 | 
|---|
| 61 |  ;
 | 
|---|
| 62 | FILSC ;Update stop code in file 40.7
 | 
|---|
| 63 |  S DIE="^DIC(40.7,"
 | 
|---|
| 64 |  S DA=IEN,DR="5////"_RESTY_";6///"_RESDT D ^DIE
 | 
|---|
| 65 |  Q
 | 
|---|
| 66 |  ;
 | 
|---|
| 67 | PROCESS ;background entry point
 | 
|---|
| 68 |  ; Locate invalid Stop Code in file 44 & 728.44 and put in a mail message
 | 
|---|
| 69 |  N SDX,IEN,BLN,COUNT,TXTVAR,I,LNS,CNT,STR,SDJ,PSC,SSC,DPC,DSC,CNTX,NAM
 | 
|---|
| 70 |  N SCN,PSCN,SSCN,DPCN,DSCN,IDT
 | 
|---|
| 71 |  S COUNT=0,$P(BLN," ",60)="",$P(LNS,"-",80)=""
 | 
|---|
| 72 |  S SDJ=$J K ^TMP(SDJ,"SD53P309")
 | 
|---|
| 73 |  F I=1:1 S TXTVAR=$P($T(MSGTXT+I),";;",2) Q:TXTVAR="QUIT"  D LINE(TXTVAR)
 | 
|---|
| 74 |  D CK44
 | 
|---|
| 75 |  D MAIL
 | 
|---|
| 76 |  K ^TMP(SDJ,"SD53P309"),TEXT,TYP
 | 
|---|
| 77 |  Q
 | 
|---|
| 78 |  ;
 | 
|---|
| 79 | CK44 ;Check file 44 for invalid stop codes.
 | 
|---|
| 80 |  N RDT,IDAT
 | 
|---|
| 81 |  S (CNTX,IEN)=0
 | 
|---|
| 82 |  D HDR
 | 
|---|
| 83 |  ;search file #44 for invalid entries
 | 
|---|
| 84 |  F  S IEN=$O(^SC(IEN)) Q:'IEN  D
 | 
|---|
| 85 |  .K STR S SDX=$G(^SC(IEN,0)),PSC=$P(SDX,U,7),SSC=$P(SDX,U,18),CNT=1
 | 
|---|
| 86 |  .I $P(SDX,U,3)'="C" Q
 | 
|---|
| 87 |  .S NAM=$P(SDX,U),IDAT=$G(^SC(IEN,"I")) I IDAT'="" D
 | 
|---|
| 88 |  ..S IDT=$P(IDAT,U),RDT=$P(IDAT,U,2) Q:IDT=""  I RDT="" S NAM="*"_NAM Q
 | 
|---|
| 89 |  ..I RDT>IDT S NAM="*"_NAM
 | 
|---|
| 90 |  .S (PSCN,SSCN)="" D
 | 
|---|
| 91 |  ..I PSC="" S STR(CNT)="Missing primary code",CNT=CNT+1 Q
 | 
|---|
| 92 |  ..S PSCN=$$SCNUM(PSC)
 | 
|---|
| 93 |  ..I PSCN="" S STR(CNT)=PSC_" has Inv pri ptr",CNT=CNT+1 Q
 | 
|---|
| 94 |  ..D SCCHK(PSC,"P")
 | 
|---|
| 95 |  .I SSC'="" D
 | 
|---|
| 96 |  ..S SSCN=$$SCNUM(SSC)
 | 
|---|
| 97 |  ..I SSCN="" S STR(CNT)=SSC_" has Inv 2nd ptr",CNT=CNT+1 Q
 | 
|---|
| 98 |  ..D SCCHK(SSC,"S")
 | 
|---|
| 99 |  .I $O(STR(0))'="" D LINE(.STR,"P") S CNTX=CNTX+1
 | 
|---|
| 100 |  D LINE(" ")
 | 
|---|
| 101 |  S STR=$E(BLN,1,25)_$S(CNTX:CNTX,1:"NO")_" PROBLEM CLINICS FOUND."
 | 
|---|
| 102 |  D LINE(STR)
 | 
|---|
| 103 |  D LINE(" ")
 | 
|---|
| 104 |  Q
 | 
|---|
| 105 |  ;
 | 
|---|
| 106 | SCNUM(SCIEN) ;Get stop code Number
 | 
|---|
| 107 |  I SCIEN="" Q ""
 | 
|---|
| 108 |  S SCN=$P($G(^DIC(40.7,SCIEN,0)),U,2)
 | 
|---|
| 109 |  Q SCN
 | 
|---|
| 110 |  ;
 | 
|---|
| 111 | SCIEN(SCN) ;Get stop code IEN
 | 
|---|
| 112 |  I SCN="" Q ""
 | 
|---|
| 113 |  S SCIEN=$O(^DIC(40.7,"C",SCN,0))
 | 
|---|
| 114 |  Q SCIEN
 | 
|---|
| 115 |  ;
 | 
|---|
| 116 | SCCHK(SCIEN,TYP) ;check stop code against file 40.7
 | 
|---|
| 117 |  N SCN,RTY,CTY
 | 
|---|
| 118 |  S CTY=$S(TYP="P":"^P^E^",1:"^S^E^")
 | 
|---|
| 119 |  S SCN=$G(^DIC(40.7,SCIEN,0)),RTY=$P(SCN,U,6),SCN=$P(SCN,U,2)
 | 
|---|
| 120 |  I SCN="" D  D CNTR Q
 | 
|---|
| 121 |  .S STR(CNT)=SCIEN_" Invalid pointer."
 | 
|---|
| 122 |  I RTY="" S STR(CNT)=SCN_" No restriction type" D CNTR Q
 | 
|---|
| 123 |  I CTY'[("^"_RTY_"^") D
 | 
|---|
| 124 |  .S STR(CNT)=SCN_" cannot be "_$S(TYP="P":"prim",1:"second")_"ary"
 | 
|---|
| 125 | CNTR ;counter
 | 
|---|
| 126 |  S CNT=CNT+1
 | 
|---|
| 127 |  Q
 | 
|---|
| 128 |  ;
 | 
|---|
| 129 | HDR ;Header for data from file #44
 | 
|---|
| 130 |  D LINE(" ")
 | 
|---|
| 131 |  S STR="HOSPITAL LOCATION FILE (#44) - (Use Set up a Clinic [SDBUILD]"
 | 
|---|
| 132 |  S STR=STR_" menu option to"
 | 
|---|
| 133 |  D LINE(STR)
 | 
|---|
| 134 |  S STR=$E(BLN,1,32)_"make corrections)"
 | 
|---|
| 135 |  D LINE(STR)
 | 
|---|
| 136 |  D LINE(" ")
 | 
|---|
| 137 |  S STR=$E(BLN,1,35)_$E("PRIMARY"_BLN,1,10)
 | 
|---|
| 138 |  S STR=STR_$E("SECONDARY/"_BLN,1,11)_"REASON FOR"
 | 
|---|
| 139 |  D LINE(STR)
 | 
|---|
| 140 |  S STR=$E("CLINIC NAME"_BLN,1,35)_$E("STOP"_BLN,1,10)
 | 
|---|
| 141 |  S STR=STR_$E("CREDIT"_BLN,1,11)_"NON"
 | 
|---|
| 142 |  D LINE(STR)
 | 
|---|
| 143 |  S STR=$E("(* - currently inactive)"_BLN,1,35)_$E("CODE"_BLN,1,10)
 | 
|---|
| 144 |  S STR=STR_$E("STOP CODE"_BLN,1,11)_"CONFORMANCE"
 | 
|---|
| 145 |  D LINE(STR)
 | 
|---|
| 146 |  S STR=$E(LNS,1,80)
 | 
|---|
| 147 |  D LINE(STR)
 | 
|---|
| 148 |  Q
 | 
|---|
| 149 |  ;
 | 
|---|
| 150 | MSGTXT ; Message intro
 | 
|---|
| 151 |  ;; Please forward this message to your local MAS ADPAC.
 | 
|---|
| 152 |  ;;
 | 
|---|
| 153 |  ;; A review of the Primary and Secondary Stop Codes in the HOSPITAL 
 | 
|---|
| 154 |  ;; LOCATION file (#44) was completed against the Restriction Type
 | 
|---|
| 155 |  ;; field (#5) of the CLINIC STOP file (#40.7) for nonconforming clinics.
 | 
|---|
| 156 |  ;;
 | 
|---|
| 157 |  ;;    
 | 
|---|
| 158 |  ;;QUIT
 | 
|---|
| 159 |  ;
 | 
|---|
| 160 |  ;
 | 
|---|
| 161 | LINE(TEXT,TYP) ; Add line to message global
 | 
|---|
| 162 |  N FLN,STR,XI
 | 
|---|
| 163 |  ;build 1st line with name, codes, etc.
 | 
|---|
| 164 |  I $O(TEXT(0))'="" D  Q
 | 
|---|
| 165 |  .S STR=$E(NAM_BLN,1,$S(TYP="P":35,1:21))
 | 
|---|
| 166 |  .S STR=STR_$E($$SCNUM(PSC)_BLN,1,$S(TYP="P":10,1:9))
 | 
|---|
| 167 |  .S STR=STR_$E($$SCNUM(SSC)_BLN,1,$S(TYP="P":11,1:9))
 | 
|---|
| 168 |  .I TYP="S" S STR=STR_$E($$SCNUM(DPC)_BLN,1,9)_$E($$SCNUM(DSC)_BLN,1,9)
 | 
|---|
| 169 |  .;set line in ^tmp global
 | 
|---|
| 170 |  .S XI=0 F  S XI=$O(TEXT(XI)) Q:'XI  D
 | 
|---|
| 171 |  ..;I XI'=FLN S TEXT(XI)=$E(BLN,1,57)_TEXT(XI)
 | 
|---|
| 172 |  ..S TEXT(XI)=STR_TEXT(XI)
 | 
|---|
| 173 |  ..S COUNT=COUNT+1,^TMP(SDJ,"SD53P309",COUNT)=TEXT(XI)
 | 
|---|
| 174 |  S COUNT=COUNT+1,^TMP(SDJ,"SD53P309",COUNT)=TEXT
 | 
|---|
| 175 |  Q
 | 
|---|
| 176 |  ;
 | 
|---|
| 177 | MAIL ; Send message
 | 
|---|
| 178 |  N XMDUZ,XMY,XMTEXT,XMSUB
 | 
|---|
| 179 |  S XMY(DUZ)="",XMDUZ=.5
 | 
|---|
| 180 |  S XMSUB="Non-Conforming Clinics Restricted Stop Codes"
 | 
|---|
| 181 |  S XMTEXT="^TMP(SDJ,""SD53P309"","
 | 
|---|
| 182 |  D ^XMD
 | 
|---|
| 183 |  Q
 | 
|---|