| 1 | SCMCDD1 ;ALB/REW - DD Calls used by PCMM ; 6 November 1995 | 
|---|
| 2 | ;;5.3;Scheduling;**41,89,107**;AUG 13, 1993 | 
|---|
| 3 | ;1 | 
|---|
| 4 | WRITETP(SCTP) ;used by write node of 404.57 | 
|---|
| 5 | N SCCL | 
|---|
| 6 | S SCCL=$P($G(^SCTM(404.57,+$G(SCTP),0)),U,9) | 
|---|
| 7 | Q $P($$GETPRTP^SCAPMCU2(SCTP,DT),U,2)_"  "_$P($G(^SC(+$G(SCCL),0)),U,1) | 
|---|
| 8 | ; | 
|---|
| 9 | SETPTTM(SCPTTMA) ;delete | 
|---|
| 10 | Q | 
|---|
| 11 | ; | 
|---|
| 12 | KILLPTTM(SCPTTMA) ;delete | 
|---|
| 13 | Q | 
|---|
| 14 | ; | 
|---|
| 15 | AFTERTM(SCPTTM) ;called after update of 404.42 | 
|---|
| 16 | N SCPTTMB4,SCPCTMB4,SCTMB4,SCTMNDB4,SCPTTMAF,SCPCTMAF,SCTMAF,X,SCFLD,SCX,SCTMNDAF,SCTMNMB4,Y | 
|---|
| 17 | Q:'$G(SCPTTM) | 
|---|
| 18 | S SCPTTMAF=$G(^SCPT(404.42,SCPTTM,0)) | 
|---|
| 19 | S SCPCTMAF=$S(($P(SCPTTMAF,U,8)=1):1,1:0) | 
|---|
| 20 | S SCTMAF=$P(SCPTTMAF,U,3) | 
|---|
| 21 | S:SCTMAF SCTMNDAF=$G(^SCTM(404.51,SCTMAF,0)) | 
|---|
| 22 | F X="SCPTTMB4","SCPCTMB4","SCTMB4","SCTMNMB4" S @X=$G(^TMP($J,"SCTMCHG",SCPTTM,X)) | 
|---|
| 23 | F SCFLD=1:1:14 S SCX=$P(SCPTTMAF,U,SCFLD) S:SCX'="" ^TMP($J,"SCTMCHG",SCPTTM,"AF",(SCFLD*.01))=SCX | 
|---|
| 24 | S X=+$O(^ORD(101,"B","SCMC PATIENT TEAM CHANGES",0))_";ORD(101," | 
|---|
| 25 | D:SCPTTMAF'=SCPTTMB4 EN^XQOR | 
|---|
| 26 | K ^TMP($J,"SCTMCHG",SCPTTM) | 
|---|
| 27 | Q | 
|---|
| 28 | ; | 
|---|
| 29 | BEFORETM(SCPTTM) ;called before update of 404.42 | 
|---|
| 30 | N SCPTTMB4,SCPCTMB4,SCTMB4,SCTMNDB4,X,SCFLD,SCX,SCY,DR,DIC,DA,DIQ | 
|---|
| 31 | Q:'$G(SCPTTM) | 
|---|
| 32 | S SCPTTMB4=$G(^SCPT(404.42,SCPTTM,0)) | 
|---|
| 33 | S SCPCTMB4=$S(($P(SCPTTMB4,U,8)=1):1,1:0) | 
|---|
| 34 | S SCTMB4=$P(SCPTTMB4,U,3) | 
|---|
| 35 | S:SCTMB4 SCTMNDB4=$G(^SCTM(404.51,SCTMB4,0)) | 
|---|
| 36 | F X="SCPTTMB4","SCPCTMB4","SCTMB4","SCTMNDB4" S ^TMP($J,"SCTMCHG",SCPTTM,X)=$G(@X) | 
|---|
| 37 | F SCY=1:1:14 S SCX=$P(SCPTTMB4,U,SCY) IF SCX'="" D | 
|---|
| 38 | .S SCFLD=SCY*.01 | 
|---|
| 39 | .S ^TMP($J,"SCTMCHG",SCPTTM,"B4",SCFLD)=SCX | 
|---|
| 40 | Q | 
|---|
| 41 | ; | 
|---|
| 42 | SETPC(SC1,SC2,SC3,SC4,DA)  ;APCPOS xref for 404.43 | 
|---|
| 43 | ;DFN = Pointer to Patient File | 
|---|
| 44 | ;SC1 = pointer to 404.42 | 
|---|
| 45 | ;SC2 = ROLE (1=pc practitioner,2=pc attending) | 
|---|
| 46 | ;SC3 = Activation Date | 
|---|
| 47 | ;SC4 = Team Position | 
|---|
| 48 | N DFN | 
|---|
| 49 | S DFN=$P($G(^SCPT(404.42,SC1,0)),U,1) | 
|---|
| 50 | S:DFN&SC1&SC2&SC3&SC4&DA ^SCPT(404.43,"APCPOS",DFN,SC2,SC3,SC4,DA)="" | 
|---|
| 51 | Q | 
|---|
| 52 | KILLPC(SC1,SC2,SC3,SC4,DA) ;APCPOS xref for 404.43 | 
|---|
| 53 | ;DFN = Pointer to Patient File | 
|---|
| 54 | ;SC1 = pointer to 404.42 | 
|---|
| 55 | ;SC2 = ROLE (1=pc practitioner,2=pc attending) | 
|---|
| 56 | ;SC3 = Activation Date | 
|---|
| 57 | ;SC4 = Team Position | 
|---|
| 58 | N DFN | 
|---|
| 59 | S DFN=$P($G(^SCPT(404.42,SC1,0)),U,1) | 
|---|
| 60 | K:DFN&SC1&SC2&SC3&SC4&DA ^SCPT(404.43,"APCPOS",DFN,SC2,SC3,SC4,DA) | 
|---|
| 61 | Q | 
|---|
| 62 | ; | 
|---|
| 63 | MAKEMANY(DFNA,SCOLDASS,SCBADASS,SCNEWASS) ;Not supported for use by PCMM Only - sets PC field to YES | 
|---|
| 64 | ;   DFNA    - DFN ARRAY | 
|---|
| 65 | ;   SCOLDASS - Subset of DFNA that were previously assigned | 
|---|
| 66 | ;   SCBADASS - Subset of DFNA that could not be assigned | 
|---|
| 67 | ;   SCNEWASS - Subset of DFNA that were newly assigned | 
|---|
| 68 | ;   Returned: total^new^old^bad | 
|---|
| 69 | ; Note: No input error checking!! | 
|---|
| 70 | N DFN,SCX,SCOUTFLD,SCBADOUT,SCOLDCNT,SCBADCNT,SCNEWCNT | 
|---|
| 71 | S (SCBADCNT,SCOLDCNT,SCNEWCNT)=0 | 
|---|
| 72 | S DFN=0 | 
|---|
| 73 | F  S DFN=$O(@DFNA@(DFN)) Q:'DFN  D | 
|---|
| 74 | .S SCOUTFLD(.04)=1 | 
|---|
| 75 | .S SCX=$$ACOUTPT^SCAPMC20(DFN,"SCOUTFLD","SCBADOUT") | 
|---|
| 76 | .;SCX=OK?^p404.41^new? | 
|---|
| 77 | .IF 'SCX D | 
|---|
| 78 | ..S SCBADCNT=SCBADCNT+1 | 
|---|
| 79 | ..S @SCBADASS@(DFN)="" | 
|---|
| 80 | .ELSE  D | 
|---|
| 81 | ..IF $P(SCX,U,3) D | 
|---|
| 82 | ...S SCNEWCNT=SCNEWCNT+1 | 
|---|
| 83 | ...S @SCNEWASS@(DFN)="" | 
|---|
| 84 | ..ELSE  D | 
|---|
| 85 | ...S SCOLDCNT=SCOLDCNT+1 | 
|---|
| 86 | ...S @SCOLDASS@(DFN)="" | 
|---|
| 87 | Q (SCOLDCNT+SCNEWCNT)_U_SCNEWCNT_U_SCOLDCNT_U_SCBADCNT | 
|---|
| 88 | ; | 
|---|
| 89 | MAKEOUT(DA) ;used by 404.42 to create an outpatient profile entry (if there wasn't one) and set the PRIMARY CARE?(.04) field to YES | 
|---|
| 90 | ;  Returned (for de-bugging): ok?^ien of404.41^new? | 
|---|
| 91 | N SCNODE,SCX,DFN,SCOUTFLD | 
|---|
| 92 | S SCNODE=$G(^SCPT(404.42,+$G(DA),0)) | 
|---|
| 93 | S DFN=$P(SCNODE,U,1) | 
|---|
| 94 | IF $P(SCNODE,U,8)=1 D  ;if assignment was to primary care | 
|---|
| 95 | .S SCOUTFLD(.04)=1 | 
|---|
| 96 | .S SCX=$$ACOUTPT^SCAPMC20(DFN,"SCOUTFLD","SCBADOUT") | 
|---|
| 97 | Q $G(SCX) | 
|---|
| 98 | ; | 
|---|
| 99 | AFTERTP(SCPTTP) ;called after update of 404.43 | 
|---|
| 100 | N SCPTTPB4,SCPCTPB4,SCTPB4,SCTPNDB4,SCPTTPAF,SCPCTPAF,SCTPAF,X,SCFLD,SCX,SCTMB4,SCTMNDB4,SCTMNDAF,SCTMAF,SCPTNM,SCTPNDAF,SCTPNMB4,Y | 
|---|
| 101 | Q:'$G(SCPTTP) | 
|---|
| 102 | S SCPTTPAF=$G(^SCPT(404.43,SCPTTP,0)) | 
|---|
| 103 | S SCPCTPAF=+$P(SCPTTPAF,U,5) | 
|---|
| 104 | S SCTPAF=$P(SCPTTPAF,U,2) | 
|---|
| 105 | S:SCTPAF SCTPNDAF=$G(^SCTM(404.57,SCTPAF,0)) | 
|---|
| 106 | S:SCTPAF SCTMAF=$P(SCTPNDAF,U,2) | 
|---|
| 107 | S:SCTMAF SCTMNDAF=$G(^SCTM(404.51,SCTMAF,0)) | 
|---|
| 108 | F X="SCPTTPB4","SCPCTPB4","SCTPB4","SCTPNMB4","SCTMB4","SCTMNDB4" S @X=$G(^TMP($J,"SCTPCHG",SCPTTP,X)) | 
|---|
| 109 | F SCFLD=1:1:9 S SCX=$P(SCPTTPAF,U,SCFLD) S:SCX'="" ^TMP($J,"SCTPCHG",SCPTTP,"AF",(SCFLD*.01))=SCX | 
|---|
| 110 | S X=+$O(^ORD(101,"B","SCMC PATIENT TEAM POSITION CHANGES",0))_";ORD(101," | 
|---|
| 111 | D:SCPTTPAF'=SCPTTPB4 EN^XQOR | 
|---|
| 112 | K ^TMP($J,"SCTPCHG",SCPTTP) | 
|---|
| 113 | Q | 
|---|
| 114 | ; | 
|---|
| 115 | BEFORETP(SCPTTP) ;called before update of 404.43 | 
|---|
| 116 | N SCPTTPB4,SCPCTPB4,SCTPB4,SCTPNDB4,X,SCFLD,SCX,SCY,DR,DIC,DA,DIQ,SCTMB4,SCTMNDAF,SCTMNDB4,SCTMNMB4 | 
|---|
| 117 | Q:'$G(SCPTTP) | 
|---|
| 118 | S SCPTTPB4=$G(^SCPT(404.43,SCPTTP,0)) | 
|---|
| 119 | Q:'SCPTTPB4 | 
|---|
| 120 | S SCPCTPB4=+$P(SCPTTPB4,U,5) | 
|---|
| 121 | S SCTPB4=$P(SCPTTPB4,U,2) | 
|---|
| 122 | S:SCTPB4 SCTPNDB4=$G(^SCTM(404.57,SCTPB4,0)) | 
|---|
| 123 | S:SCTPB4 SCTMB4=$P(SCTPNDB4,U,2) | 
|---|
| 124 | S:SCTMB4 SCTMNDB4=$G(^SCTM(404.51,SCTMB4,0)) | 
|---|
| 125 | F X="SCPTTPB4","SCPCTPB4","SCTPB4","SCTPNDB4","SCTMNDB4","SCTMB4" S ^TMP($J,"SCTPCHG",SCPTTP,X)=$G(@X) | 
|---|
| 126 | F SCY=1:1:9 S SCX=$P(SCPTTPB4,U,SCY) IF SCX'="" D | 
|---|
| 127 | .S SCFLD=SCY*.01 | 
|---|
| 128 | .S ^TMP($J,"SCTPCHG",SCPTTP,"B4",SCFLD)=SCX | 
|---|
| 129 | Q | 
|---|