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

ESP122P2.m

Go to the documentation of this file.
  1. ESP122P2 ;ALB/JAP; POST-INSTALL FOR ES*1*22 cont.;3/98
  1. ;;1.0;POLICE & SECURITY;**22**;Mar 31, 1994
  1. ;
  1. MANUAL ;user update of file #912 entries (manual)
  1. N X,Y,DIC,DTOUT,DUOUT,ESPOUT,LN,ESIEN,ESN
  1. S $P(LN,"=",80)=""
  1. ;subtype conversion array - these are the only changes allowed
  1. S ESPCNV("ABOVE $100 (GOV'T)",1)="39^ABOVE $1000 (GOV'T)"
  1. S ESPCNV("ABOVE $100 (GOV'T)",2)="40^BELOW $1000 (GOV'T)"
  1. S ESPCNV("ABOVE $100 (PERSONAL)",1)="41^ABOVE $1000 (PERSONAL)"
  1. S ESPCNV("ABOVE $100 (PERSONAL)",2)="42^BELOW $1000 (PERSONAL)"
  1. S ESPCNV("ABOVE $1000 (GOV'T)",1)="40^BELOW $1000 (GOV'T)"
  1. S ESPCNV("BELOW $1000 (GOV'T)",1)="39^ABOVE $1000 (GOV'T)"
  1. S ESPCNV("ABOVE $1000 (PERSONAL)",1)="42^BELOW $1000 (PERSONAL)"
  1. S ESPCNV("BELOW $1000 (PERSONAL)",1)="41^ABOVE $1000 (PERSONAL)"
  1. ;subtype iens
  1. S ESPOLD("ABOVE $100 (GOV'T)")=23
  1. S ESPOLD("ABOVE $100 (PERSONAL)")=25
  1. S ESPOLD("ABOVE $1000 (GOV'T)")=39
  1. S ESPOLD("BELOW $1000 (GOV'T)")=40
  1. S ESPOLD("ABOVE $1000 (PERSONAL)")=41
  1. S ESPOLD("BELOW $1000 (PERSONAL)")=42
  1. ;select a file #912 record eligible for conversion/change
  1. F S ESPOUT=0 D Q:$D(DTOUT)!($D(DUOUT))!(ESPOUT)
  1. .S DIC="^ESP(912,",DIC(0)="AEMNQ"
  1. .S DIC("S")="I $P(^ESP(912,Y,0),U,3)>2970930.235959"
  1. .D ^DIC
  1. .I X="" S ESPOUT=1 Q
  1. .Q:Y=-1
  1. .S ESIEN=+Y
  1. .I ('$D(^XTMP("ESP","CONV",ESIEN)))&('$D(^XTMP("ESP","USER",ESIEN))) D Q
  1. ..W !,"That record doesn't need to be converted. Try again...",!! K ESIEN
  1. .D DISPLAY Q:ESPOUT
  1. .D UPDATE
  1. K ESPCNV,ESPOLD
  1. Q
  1. ;
  1. DISPLAY ;display file #912 record data
  1. D HOME^%ZIS
  1. W @IOF
  1. S ESPDTR=$P($G(^ESP(912,ESIEN,0)),U,2) Q:ESPDTR=""
  1. W !?20,"Patch ES*1*22 Conversion Utility"
  1. W !,"File #912 ien: ",ESIEN
  1. W ?45,"UOR# ",$E(ESPDTR,2,3),"-",$E(ESPDTR,4,5),"-",$E(ESPDTR,6,7),"-",$TR($E($P(ESPDTR,".",2)_"ZZZZ",1,4),"Z",0)
  1. K ^UTILITY("DIQ1",$J)
  1. S DIC="^ESP(912,",DA=ESIEN,DR=".02;.03;.04;.06;.08;5.02;5.05;5.06;6.01;6.02",DIQ(0)="E" D EN^DIQ1 Q:'$D(^UTILITY("DIQ1",$J,912,DA))
  1. W !,"DATE/TIME RECEIVED: ",$G(^UTILITY("DIQ1",$J,912,DA,.02,"E"))
  1. W !,"DATE/TIME OF OFFENSE: ",$G(^UTILITY("DIQ1",$J,912,DA,.03,"E"))
  1. W !,"LOCATION: ",$G(^UTILITY("DIQ1",$J,912,DA,.04,"E"))
  1. W !,"INVESTIGATING OFFICER: ",$G(^UTILITY("DIQ1",$J,912,DA,.06,"E"))
  1. W !,"CASE STATUS: ",$G(^UTILITY("DIQ1",$J,912,DA,.08,"E"))
  1. W ?45,"COMPLETED FLAG: ",$G(^UTILITY("DIQ1",$J,912,DA,5.02,"E"))
  1. S FLAG=$G(^UTILITY("DIQ1",$J,912,DA,5.05,"E")) D
  1. .Q:FLAG="" Q:FLAG["NONE"
  1. .W !,"DELETED/REOPENED FLAG: ",FLAG
  1. .I $E(FLAG,1)="D" W ?45,"DATE/TIME: ",$G(^UTILITY("DIQ1",$J,912,DA,5.06,"E"))
  1. .I ($E(FLAG,1)="R")&($D(^UTILITY("DIQ1",$J,912,DA,6.02,"E"))) W ?45,"DATE/TIME: ",^UTILITY("DIQ1",$J,912,DA,6.02,"E"),!?45,"PREVIOUS ID#: ",$G(^UTILITY("DIQ1",$J,912,DA,6.01,"E"))
  1. W !,"LOST/STOLEN PROPERTY:"
  1. I $D(^ESP(912,ESIEN,90)) D
  1. .S ESL=0 F S ESL=$O(^ESP(912,ESIEN,90,ESL)) Q:ESL="" D
  1. ..S DIC="^ESP(912,"_ESIEN_",90,",DA=ESL,DR=".01;.03",DIQ(0)="E" D EN^DIQ1 Q:'$D(^UTILITY("DIQ1",$J,912.1,DA))
  1. ..W !?5,$G(^UTILITY("DIQ1",$J,912.1,DA,.01,"E"))
  1. ..W ?45,"LOSS: $",$G(^UTILITY("DIQ1",$J,912.1,DA,.03,"E"))
  1. I '$D(^ESP(912,ESIEN,90)) D
  1. .W !?5,"(No information available.)"
  1. K ESN S ESN=0 F S ESN=$O(^ESP(912,ESIEN,10,ESN)) Q:ESN="" D
  1. .S (ESOLD,ESUSER,ESCNVDT)=0,ESOLDNM=""
  1. .S ESOLD=$P($G(^XTMP("ESP","CONV",ESIEN,ESN)),U,1)
  1. .I ESOLD S ESUSER=$P($G(^XTMP("ESP","CONV",ESIEN,ESN)),U,3),ESCNVDT=$P($G(^XTMP("ESP","CONV",ESIEN,ESN)),U,4)
  1. .S DIC="^ESP(912,"_ESIEN_",10,",DA=ESN,DR=".01;.02;.03",DIQ(0)="E" D EN^DIQ1 Q:'$D(^UTILITY("DIQ1",$J,912.01,DA,.01,"E"))
  1. .I $D(^XTMP("ESP","CONV",ESIEN,ESN)) S ESN(ESN)=$G(^UTILITY("DIQ1",$J,912.01,DA,.03,"E"))
  1. .I $D(^XTMP("ESP","USER",ESIEN,ESN)) S ESN(ESN)=$G(^UTILITY("DIQ1",$J,912.01,DA,.03,"E"))
  1. .I ESOLD D
  1. ..S NUM="("_ESN_") ",NUML=$L(NUM)
  1. ..W !,NUM_"Classification: ",!?5,$G(^UTILITY("DIQ1",$J,912.01,DA,.01,"E"))
  1. ..I $G(^UTILITY("DIQ1",$J,912.01,DA,.02,"E"))]"" W "/",^("E")
  1. ..I $G(^UTILITY("DIQ1",$J,912.01,DA,.03,"E"))]"" W "/",^("E")
  1. ..I ESUSER W !,?NUML,"Converted by: ",$E($P($G(^VA(200,ESUSER,0)),U,1),1,20),?45,"Date/time: ",ESCNVDT
  1. .I 'ESOLD D
  1. ..S NUM="("_ESN_") ",NUML=$L(NUM)
  1. ..W !,NUM_"Classification: ",!?5,$G(^UTILITY("DIQ1",$J,912.01,DA,.01,"E"))
  1. ..I $G(^UTILITY("DIQ1",$J,912.01,DA,.02,"E"))]"" W "/",^("E")
  1. ..I $G(^UTILITY("DIQ1",$J,912.01,DA,.03,"E"))]"" W "/",^("E")
  1. W !,LN,!
  1. Q
  1. ;
  1. UPDATE ;allow user to update subtype of subrecord
  1. ;variable esien=record, array esn=subrecords which may be converted
  1. N DIR,DTOUT,DUOUT,DIRUT,X,Y,SUBTYPE,NUM,NEWSUB,OLDSUB,ESPOUT,ESPPREV
  1. D NOW^%DTC S Y=$E(%,1,12),ESCNVDT=$$FMTE^XLFDT(Y,"5")
  1. W !!,"You may modify the following sub-record(s) -- ",!
  1. W !?5,"Sub-record #",?25,"Current Subtype"
  1. S JJ=0,DIR(0)="LA^",DIR("A")="Select sub-record #: "
  1. F S JJ=$O(ESN(JJ)) Q:JJ="" D
  1. .S DIR(0)=DIR(0)_","_JJ_","
  1. .W !,?8,JJ,?25,ESN(JJ)
  1. W ! D ^DIR W ! K DIR
  1. Q:$D(DTOUT)!($D(DUOUT))!($D(DIRUT))
  1. Q:(X["^")!(Y["^")
  1. I '$D(ESN(+Y)) G UPDATE
  1. S ESN=+Y,SUBTYPE=ESN(+Y),OLDSUB=ESPOLD(SUBTYPE)
  1. ;if more than 1 possible subtype to change to
  1. S (ESPOUT,NUM,NEWSUB)=0
  1. I $D(ESPCNV(SUBTYPE,2)) F D Q:(NUM)!(ESPOUT)
  1. .W !!?5,"The subrecord selected may be converted"
  1. .W !?5," to one of the following:",!
  1. .W !!?10,"(a) "_$P(ESPCNV(SUBTYPE,1),U,2)
  1. .W !?10,"(b) "_$P(ESPCNV(SUBTYPE,2),U,2)
  1. .S DIR(0)="SA^A:"_$P(ESPCNV(SUBTYPE,1),U,2)_";B:"_$P(ESPCNV(SUBTYPE,2),U,2)
  1. .S DIR("A")="Select (a) or (b): "
  1. .W !?5 D ^DIR W ! K DIR
  1. .I $D(DTOUT)!($D(DUOUT))!($D(DIRUT)) S ESPOUT=1
  1. .I (X["^")!(Y["^") S ESPOUT=1
  1. .I Y="A" S NUM=1
  1. .I Y="B" S NUM=2
  1. Q:ESPOUT
  1. ;if only 1 possible subtype to change to
  1. I '$D(ESPCNV(SUBTYPE,2)) S NUM=1
  1. S NEWSUB=$P(ESPCNV(SUBTYPE,NUM),U,1)
  1. ;update the subrecord
  1. S $P(^ESP(912,ESIEN,10,ESN,0),U,3)=NEWSUB
  1. ;keep previous conversion data, if any
  1. S ESPPREV=1+$O(^XTMP("ESP","PREV",ESIEN,ESN,""),-1)
  1. I $D(^XTMP("ESP","CONV",ESIEN,ESN)) S ^XTMP("ESP","PREV",ESIEN,ESN,ESPPREV)=^XTMP("ESP","CONV",ESIEN,ESN)
  1. ;store the conversion data
  1. S ^XTMP("ESP","CONV",ESIEN,ESN)=OLDSUB_"^"_NEWSUB_"^"_DUZ_"^"_ESCNVDT
  1. ;delete from unreviewed, if necessary
  1. K ^XTMP("ESP","USER",ESIEN,ESN)
  1. W !!,"...done.",!
  1. K X,Y,DIR S DIR(0)="E" D ^DIR K DIR W !!
  1. Q