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

FSCRPTS.m

Go to the documentation of this file.
  1. FSCRPTS ;SLC/STAFF-NOIS Report ;1/13/98 16:31
  1. ;;1.1;NOIS;;Sep 06, 1998
  1. ;
  1. REPORTS ; from FSCOPT
  1. N CHOICE,CNT,DFORM,DIC,DIR,DISPLAY,FIELD,FIELDS,FORMAT,FSCLIMIT,FSCSTYLE,FSCINDX,FSCSORT,LIST,OK,REPORT,X,Y K DIC,DIR,DFORM,FIELDS,FORMAT,FSCSTYLE
  1. S DIR(0)="SAMO^REPORT:REPORT;CUSTOM:CUSTOM",DIR("A")="Select (R)eport or (C)ustom: "
  1. S DIR("?",1)="Enter REPORT to select reports (a report is a list with a sort and format)."
  1. S DIR("?",2)="Enter CUSTOM to select a list, sort, and format."
  1. S DIR("?")="^D HELP^FSCU(.DIR)"
  1. S DIR("??")="FSC U1 NOIS"
  1. D ^DIR K DIR
  1. I $D(DIRUT) Q
  1. S CHOICE=Y
  1. I CHOICE="REPORT" D
  1. .D LOOKUP^FSCULOOK("RPT",.REPORT,"AEMOQ",.OK)
  1. .I 'OK Q
  1. .D PARTS(+REPORT,.LIST,.FSCSORT,.FORMAT,.DFORM)
  1. .Q:'$L(LIST) S FSCLNUM=+LIST,FSCL0=$G(^FSC("LIST",FSCLNUM,0)),FSCLNAME=$P(FSCL0,U)
  1. .I $P(FSCL0,U,5) W !,"For the list ",FSCLNAME D INDEX^FSCLM(.FSCLNAME,.FSCINDX,FSCL0) I '$G(FSCINDX) K LIST
  1. .S FSCSTYLE=$P(DFORM(0),U,2),FSCSTYLE(0)=DFORM(0),OK=1 D
  1. ..I FSCSTYLE="BRIEF" S FSCSTYLE="B" Q
  1. ..I FSCSTYLE="DETAIL" S FSCSTYLE="D" Q
  1. ..I 'FORMAT S OK=0 Q
  1. ..I FSCSTYLE="FM" D Q
  1. ...I '$L($P(FORMAT(0),U,3)) S OK=0 Q
  1. ...S FSCSTYLE("T")="["_$P(FORMAT(0),U,3)_"]"
  1. ..I FSCSTYLE="EXECUTE" S FSCSTYLE("F")=FORMAT_U_$P(FORMAT(0),U)
  1. ..I FSCSTYLE="EXTRACT" S FSCSTYLE("E")=""
  1. ..S CNT=0 F S CNT=$O(^FSC("FORMAT",FORMAT,2,CNT)) Q:CNT<1 S FIELD=+^(CNT,0),FSCSTYLE(CNT)=^FSC("FLD",FIELD,0)
  1. ..S FSCSTYLE=$$CHOICE^FSCUX(FSCSTYLE)
  1. .I 'OK D OTHER^FSCUX(.FSCSTYLE,.OK)
  1. .S FSCSTYLE=$$STYLE^FSCU(FSCSTYLE)
  1. I CHOICE="CUSTOM" D
  1. .D LIST^FSCULOOK(.LIST,.FSCLIMIT,.OK)
  1. .I 'OK Q
  1. .S FSCLNAME=$P(LIST,U,2),FSCLNUM=+LIST,FSCL0=$G(^FSC("LIST",FSCLNUM,0))
  1. .I $P(FSCL0,U,5) D INDEX^FSCLM(.FSCLNAME,.FSCINDX,FSCL0) Q:'$G(FSCINDX)
  1. .S DIC=7107.6,DIC(0)="AEMOQ",DIC("A")="Select Sort (optional): ",DIC("S")="I $P(^(0),U,2)=""S"""
  1. .D ^DIC K DIC
  1. .Q:$D(DUOUT) Q:$D(DTOUT)
  1. .S FSCSORT=+Y
  1. .D EXPAND^FSCUX(.FSCSTYLE,.OK)
  1. .I 'OK Q
  1. .S FSCSTYLE=$$STYLE^FSCU(FSCSTYLE)
  1. Q:'$D(LIST) Q:'$D(FSCSTYLE)
  1. S DISPLAY="" I '($D(FSCSTYLE("E"))!$D(FSCSTYLE("T"))) D DISPLAY^FSCRU(.DISPLAY,.OK) I 'OK Q
  1. I DISPLAY="DEVICE" D DEV^FSCRU("","^TMP(""FSC LIST"",$J,","DQ^FSCRUDQ","NOIS Report",.OK) Q
  1. D SETUP I $D(VALMQUIT) Q
  1. D VIEW^FSCLM(VALMAR,"VVALUES",.FSCSTYLE)
  1. Q
  1. ;
  1. SETUP ; from FSCOPT, FSCRUDQ
  1. N CALLNUM,CNT
  1. K VALMQUIT D ENTRY^FSCLML I $D(VALMQUIT) Q
  1. S VALMAR="^TMP(""FSC LIST CALLS"",$J)"
  1. ;I '^TMP("FSC LIST CALLS",$J) W !,"No calls to View." H 2 Q
  1. I $G(FSCSORT) D SETSORT(FSCSORT,.FIELDS),SORT^FSCUS(.FIELDS)
  1. I FSCSTYLE="FM" D Q
  1. .I '$L($G(FSCSTYLE("T"))) Q
  1. .S CNT=0 F S CNT=$O(^TMP("FSC LIST CALLS",$J,"ICX",CNT)) Q:CNT<1 D
  1. ..S CALLNUM=0 F S CALLNUM=$O(^TMP("FSC LIST CALLS",$J,"ICX",CNT,CALLNUM)) Q:CALLNUM<1 D TEMP^FSCFORMP
  1. K ^TMP("FSC SELECT",$J,"VVALUES") S ^("VVALUES")=1_"-"_VALMCNT
  1. F CNT=1:1:VALMCNT S ^TMP("FSC SELECT",$J,"VVALUES",CNT)=""
  1. Q
  1. ;
  1. SETSORT(SORT,FIELDS) ;
  1. N CNT,FIELD K FIELDS
  1. K FIELDS S CNT=0 F S CNT=$O(^FSC("FORMAT",SORT,2,CNT)) Q:CNT<1 S FIELD=^(CNT,0),FIELDS(CNT)=$G(^FSC("FLD",+FIELD,0)) I $P(FIELD,U,8) S FIELDS(CNT,"D")=""
  1. Q
  1. ;
  1. PARTS(REPORT,LIST,SORT,FORMAT,DFORM) ;
  1. N ZERO
  1. S ZERO=$G(^FSC("RPT",+REPORT,0)),LIST=$P(ZERO,U,3),SORT=$P(ZERO,U,5),FORMAT=$P(ZERO,U,4),DFORM=$P(ZERO,U,6)
  1. S FORMAT(0)=$G(^FSC("FORMAT",+FORMAT,0)),DFORM(0)=$G(^FSC("FTYPE",+DFORM,0))
  1. Q