745 lines
30 KiB
Plaintext
745 lines
30 KiB
Plaintext
COMPILE SUBROUTINE Print_SAP_Cass_Ship_Label( WONo,WOSteps,CassNos,RDSNos,RDSType )
|
|
#pragma precomp SRP_PreCompiler
|
|
|
|
/*
|
|
Complete Rewrite SAP changes 7/26/2011 by John C. Henry, J.C. Henry & Co., Inc.
|
|
DPC 12/5/19 - removed thickness and resistivity from SAP shipping label per Matt T.
|
|
DPC 3/11/21 - changed RevLvl to pull from CUST_EPI_PART instead of PROD_SPEC
|
|
DPC 1/12/22 - with help of Daniel at SRP, changed some print functions to allow defaulting printer
|
|
*/
|
|
|
|
$INSERT LOGICAL
|
|
$INSERT MSG_EQUATES
|
|
$INSERT RDS_EQU
|
|
|
|
$INSERT PROD_VER_EQUATES
|
|
$INSERT OIPRINT_EQUATES
|
|
$INSERT PROD_SPEC_EQU
|
|
$INSERT PRS_LAYER_EQU
|
|
$INSERT WO_LOG_EQUATES
|
|
$INSERT WO_STEP_EQU
|
|
$INSERT WO_MAT_EQUATES
|
|
$INSERT WM_OUT_EQUATES
|
|
$INSERT ORDER_EQU
|
|
$INSERT ORDER_DET_EQU
|
|
$INSERT REACTOR_EQUATES
|
|
$INSERT REACT_RUN_EQUATES
|
|
$INSERT COMPANY_EQUATES
|
|
$INSERT CUST_EPI_PART_EQUATES
|
|
$Insert EPI_PART_EQUATES
|
|
|
|
DECLARE FUNCTION Msg, Get_Printer, Set_Printer, obj_Prod_Spec, obj_Vendor_Code, Logging_Services, Unassigned, Obj_Wo_Mat
|
|
DECLARE FUNCTION Get_Status, Utility, Printer_Select, obj_Install, Environment_Services, Direct_Print
|
|
Declare function GaN_Services, Error_Services
|
|
DECLARE SUBROUTINE Set_Status, Msg, errMsg, obj_Zebra105SL, Logging_Services, Direct_Print, Sap_Services
|
|
|
|
EQU PI$LEFT TO 1
|
|
EQU PI$TOP TO 2
|
|
EQU PI$RIGHT TO 3
|
|
EQU PI$BOTTOM TO 4
|
|
EQU PI$WIDTH TO 5
|
|
EQU PI$HEIGHT TO 6
|
|
EQU PI$SIZE TO 7
|
|
|
|
ErrorMsg = ''
|
|
|
|
IF NOT(ASSIGNED(WONo)) THEN ErrorMsg = 'Unassigned parameter "WONo" passed to PRINT_CASS_SHIP_LABEL routine.'
|
|
IF NOT(ASSIGNED(WOSteps)) THEN ErrorMsg = 'Unassigned parameter "WOSteps" passed to PRINT_CASS_SHIP_LABEL routine.'
|
|
IF NOT(ASSIGNED(CassNos)) THEN ErrorMsg = 'Unassigned parameter "CassNos" passed to PRINT_CASS_SHIP_LABEL routine.'
|
|
IF NOT(ASSIGNED(RDSNos)) THEN ErrorMsg = 'Unassigned parameter "RDSNos" passed to PRINT_CASS_SHIP_LABEL routine.'
|
|
|
|
LogPath = Environment_Services('GetApplicationRootPath') : '\LogFiles\Zebra'
|
|
LogDate = Oconv(Date(), 'D4/')
|
|
LogTime = Oconv(Time(), 'MTS')
|
|
LogFileName = LogDate[7, 4] : '-' : LogDate[1, 2] : '-' : LogDate[4, 2] : '.csv'
|
|
Headers = 'Logging DTM' : @FM : 'Description'
|
|
ColumnWidths = 20 : @FM : 300
|
|
objLog = Logging_Services('NewLog', LogPath, LogFileName, CRLF$, ' ', Headers, ColumnWidths, False$, False$)
|
|
|
|
LogPath = Environment_Services('GetApplicationRootPath') : '\LogFiles\Spectrum'
|
|
LogDate = Oconv(Date(), 'D4/')
|
|
LogTime = Oconv(Time(), 'MTS')
|
|
LogFileName = LogDate[7, 4] : '-' : LogDate[1, 2] : '-' : LogDate[4, 2] : '.csv'
|
|
Headers = 'Logging DTM' : @FM : 'Description'
|
|
ColumnWidths = 20 : @FM : 300
|
|
objSpectrumLog = Logging_Services('NewLog', LogPath, LogFileName, CRLF$, ' ', Headers, ColumnWidths, False$, False$)
|
|
|
|
LoggingDTM = LogDate : ' ' : LogTime ; // Logging DTM
|
|
|
|
IF ErrorMsg NE '' THEN
|
|
ErrMsg(ErrorMsg)
|
|
RETURN
|
|
END
|
|
|
|
PrinterID = ''
|
|
* PrinterID = 'MESZBRPRT004' ;*default to the shipping printer, which is the only printer with 4x4 label stock
|
|
|
|
* Initialize the printer
|
|
FileName = "Printing Label"
|
|
Title = "Printing Label" ;* Initialize Printing
|
|
|
|
PageInfo = ''
|
|
PageInfo<PI$LEFT> = 0.1
|
|
PageInfo<PI$TOP> = 0.1
|
|
PageInfo<PI$RIGHT> = 0.1
|
|
PageInfo<PI$BOTTOM> = 0.1
|
|
|
|
PageSetup = '1' ;* Landscape
|
|
PrintSetup = '0' ;* Print to specific location
|
|
PrintPath = Printer_Select(PrinterID);* Select printer - Displays popup if PrinterPort not found
|
|
PrintPathLog = PrintPath
|
|
|
|
Swap @FM with '@FM' in PrintPathLog
|
|
Swap @VM with '@VM' in PrintPathLog
|
|
Swap @SVM with '@SVM' in PrintPathLog
|
|
Swap @TM with '@TM' in PrintPathLog
|
|
Swap @STM with '@STM' in PrintPathLog
|
|
Logging_Services('AppendLog', objLog, LoggingDTM : @FM : @User4 : ' - PrintPath = ' : PrintPathLog, @RM, @FM)
|
|
|
|
IF PrintPath = '' THEN
|
|
Def = ""
|
|
Def<MTYPE$> = "TA3"
|
|
Def<MTEXT$> = 'Destination Printer not Selected..'
|
|
Def<MCAPTION$> = ''
|
|
Def<MICON$> = '*'
|
|
Msg(@WINDOW, Def, '')
|
|
RETURN
|
|
END
|
|
|
|
If Environment_Services('GetLabelPrintMethod') _EQC 'OIPI' then
|
|
stat = Set_Printer("INIT",FileName,Title,PageInfo,PageSetup,PrintSetup,PrintPath)
|
|
end else
|
|
stat = Direct_Print('START', PrintPath<1>, '', '')
|
|
end
|
|
IF stat < 0 THEN GOSUB OIPrint_Err ;* Bail = couldn't initialize the printer
|
|
|
|
If Unassigned(RDSType) then RDSType = ''
|
|
|
|
IF RDSType EQ '' then
|
|
ReactNos = XLATE('REACT_RUN',RDSNos,REACT_RUN_REACTOR$,'X') ;* Added 12/16/2008 - JCH - Adding Reactor Type codes to cassette labels
|
|
ReactTypes = OCONV(XLATE('REACTOR',ReactNos,REACTOR_REACT_TYPE$,'X'),'[REACT_TYPE_CONV,OPSREF]') ;* Added 12/16/2008 - JCH - Adding Reactor Type codes to cassette labels
|
|
end else
|
|
ReactTypes = RDSType
|
|
end
|
|
|
|
WORec = XLATE('WO_LOG',WONo,'','X')
|
|
|
|
WoLogReqShipDt = OCONV( WORec<WO_LOG_PROMISE_SHIP_DT$>, 'D2/' )
|
|
WoLogDMShipDt = OCONV( WORec<WO_LOG_PROMISE_SHIP_DT$>, 'DE' )
|
|
WoLogCustPONo = WORec<WO_LOG_CUST_PO_NO$>
|
|
WoLogEpiPartNo = WORec<WO_LOG_EPI_PART_NO$>
|
|
WoLogCustNo = WORec<WO_LOG_CUST_NO$>
|
|
|
|
ProdOrdNo = WORec<WO_LOG_PROD_ORD_NO$>
|
|
ProdVerNo = WORec<WO_LOG_PROD_VER_NO$>
|
|
ProdVerRec = XLATE('PROD_VER',ProdVerNo,'','X')
|
|
|
|
CompRec = XLATE('COMPANY',WoLogCustNo,'','X')
|
|
|
|
Captive = CompRec<COMPANY_CAPTIVE$>
|
|
VendCd = CompRec<COMPANY_VEND_CD$>
|
|
CustName = CompRec<COMPANY_CO_NAME$>
|
|
|
|
IF ProdOrdNo NE '' THEN
|
|
IF WoLogCustPONo = 'NA' OR WoLogCustPONo = '' THEN
|
|
PONo = ProdOrdNo
|
|
END ELSE
|
|
PONo = WoLogCustPONo
|
|
END
|
|
OrderItems = ''
|
|
VisionOrderNo = ''
|
|
VisionLineNos = ''
|
|
END
|
|
|
|
CassCnt = COUNT(CassNos,@VM) + (CassNos NE '')
|
|
|
|
FOR I = 1 TO CassCnt
|
|
|
|
WOStep = WOSteps<1,I>
|
|
ProdSpecID = XLATE('WO_STEP',WONo:'*':WOStep,WO_STEP_PROD_SPEC_ID$,'X')
|
|
RevLvl = XLATE('CUST_EPI_PART',WoLogCustNo:'*':WoLogEpiPartNo,CUST_EPI_PART_SPEC_REV$,'X')[-1,'B':@VM] ;* use rev from Cust Epi Part, not PSN
|
|
CassNo = CassNos<1,I>
|
|
RDSNo = RDSNos<1,I>
|
|
ReactType = Xlate('WO_MAT', WONo:'*':CassNo,'REACTOR_TYPE','X')
|
|
WOMatRec = XLATE('WO_MAT',WONo:'*':CassNo,'','X')
|
|
ReShipCust = WOMatRec<WO_MAT_RESHIP_CUST_NO$>
|
|
If ReShipCust EQ '' then
|
|
CustNo = WoLogCustNo
|
|
end else
|
|
CustNo = ReShipCust
|
|
end
|
|
CompRec = XLATE('COMPANY',CustNo,'','X')
|
|
Captive = CompRec<COMPANY_CAPTIVE$>
|
|
VendCd = CompRec<COMPANY_VEND_CD$>
|
|
CustName = CompRec<COMPANY_CO_NAME$>
|
|
ReShipDate = WOMatRec<WO_MAT_RESHIP_DT$>
|
|
If ReShipDate EQ '' then
|
|
ReqShipDt = OCONV( WORec<WO_LOG_PROMISE_SHIP_DT$>, 'D2/' )
|
|
DMShipDt = OCONV( WORec<WO_LOG_PROMISE_SHIP_DT$>, 'DE' )
|
|
end else
|
|
ReqShipDt = OCONV( ReShipDate, 'D2/' )
|
|
DMShipDt = OCONV( ReShipDate, 'DE' )
|
|
end
|
|
ReShipCustEpiPartNo = WOMatRec<WO_MAT_RESHIP_CUST_EPI_PART_NO$>
|
|
If ReShipCustEpiPartNo EQ '' then
|
|
EpiPartNo = WoLogEpiPartNo
|
|
end else
|
|
EpiPartNo = ReShipCustEpiPartNo
|
|
end
|
|
ReShipCustPO = WOMatRec<WO_MAT_RESHIP_CUST_PO$>
|
|
If ReShipCustPO EQ '' then
|
|
CustPONo = WoLogCustPONo
|
|
end else
|
|
CustPONo = ReShipCustPO
|
|
end
|
|
IF CustPONo = 'NA' OR CustPONo = '' THEN
|
|
PONo = ProdOrdNo
|
|
END ELSE
|
|
PONo = CustPONo
|
|
END
|
|
ReShipCustPartNo = WOMatRec<WO_MAT_RESHIP_CUST_PART_NO$>
|
|
SAPBatchNo = WOMatRec<WO_MAT_SAP_BATCH_NO$>
|
|
|
|
SubSupplier = obj_Vendor_Code('SemiToEpi',WOMatRec<WO_MAT_SUB_VEND_CD$>)
|
|
|
|
IF VendCd NE '' THEN SubSupplier = VendCd ;* Override from Company Table.
|
|
|
|
Begin Case
|
|
Case (RDSNo NE '' AND RDSType EQ 'SIC') OR (RDSNo NE '' AND ReactType<1,I> NE 'EPP' AND ReactType<1,I> NE 'GAN') ;* regular Epi
|
|
|
|
CassIDLabel = 'RDSNo: '
|
|
CassID = RDSNo
|
|
ReactType = ReactTypes<1,I>
|
|
|
|
MakeupBox = WOMatRec<WO_MAT_MAKEUP_BOX$>
|
|
PartNo = XLATE('WO_LOG',WONo,WO_LOG_CUST_PART_NO$,'X')
|
|
If ReShipCustPartNo NE '' then
|
|
PartNo = ReShipCustPartNo
|
|
end
|
|
LotNo = WOMatRec<WO_MAT_LOT_NO$>
|
|
SubstrPartNo = WOMatRec<WO_MAT_SUB_PART_NO$>
|
|
|
|
IF SubstrPartNo[-2,2] _EQC '.S' THEN SubstrPartNo = ''
|
|
|
|
CassOrderItem = WOMatRec<WO_MAT_ORDER_ITEM$>
|
|
|
|
IF ProdVerNo = '' THEN
|
|
CustPNDesc = XLATE( 'ORDER_DET',WONo:'*':CassOrderItem,'CUST_PN_DESC','X')
|
|
END ELSE
|
|
CustPNDesc = XLATE('PROD_VER',ProdVerNo,PROD_VER_CUST_PART_DESC$,'X')
|
|
END
|
|
|
|
SupVerify = XLATE( 'RDS', RDSNo, 'SUP_VER_SIG_NAME', 'X' )
|
|
SupVerifyDt = OCONV(XLATE('WO_MAT',WONo:'*':CassNo,'SHIP_SUP_VER_SIG_DT','X'),'D2/')
|
|
WfrsOut = XLATE( 'RDS', RDSNo, 'WFRS_OUT', 'X' )
|
|
MUWfrsRemQty = XLATE( 'RDS', RDSNo, 'MU_WFRS_REMOVED','X' )
|
|
MUWfrsAddQty = XLATE( 'RDS', RDSNo, 'MU_WFRS_ADDED','X' )
|
|
|
|
ResultThickL1 = OCONV( XLATE( 'REACT_RUN', RDSNo, 'TTHICK_AVG', 'X' ), 'MD2' )
|
|
ResultThickL2 = OCONV( XLATE( 'REACT_RUN', RDSNo, 'TTHICK_AVG_L2', 'X' ), 'MD2' )
|
|
ResultThickL3 = OCONV( XLATE( 'REACT_RUN', RDSNo, 'TTHICK_AVG_L3', 'X' ), 'MD2' )
|
|
|
|
TargetThickL1 = OCONV( XLATE( 'REACT_RUN', RDSNo, 'THICK_TARGET', 'X' ), 'MD2' )
|
|
TargetThickL2 = OCONV( XLATE( 'REACT_RUN', RDSNo, 'THICK_TARGET_L2', 'X' ), 'MD2' )
|
|
TargetThickL3 = OCONV( XLATE( 'REACT_RUN', RDSNo, 'THICK_TARGET_L3', 'X' ), 'MD2' )
|
|
|
|
IF ResultThickL1 = '' THEN ResultThickL1 = TargetThickL1
|
|
IF ResultThickL2 = '' THEN ResultThickL2 = TargetThickL2
|
|
IF ResultThickL3 = '' THEN ResultThickL3 = TargetThickL3
|
|
|
|
ThickUnitsL1 = XLATE( 'REACT_RUN', RDSNo, 'THICK_UNITS', 'X' )
|
|
ThickUnitsL2 = XLATE( 'REACT_RUN', RDSNo, 'THICK_UNITS_L2', 'X' )
|
|
ThickUnitsL3 = XLATE( 'REACT_RUN', RDSNo, 'THICK_UNITS_L3', 'X' )
|
|
|
|
ResultThick = ResultThickL1
|
|
IF ResultThickL2 NE '' THEN ResultThick := '/':ResultThickL2
|
|
IF ResultThickL3 NE '' THEN ResultThick := '/':ResultThickL3
|
|
|
|
IF ResultThick NE '' THEN ResultThick := ThickUnitsL1
|
|
|
|
ResultResL1 = XLATE( 'REACT_RUN', RDSNo, 'TRES_AVG', 'X' )
|
|
ResultResL2 = XLATE( 'REACT_RUN', RDSNo, 'TRES_AVG_L2', 'X' )
|
|
ResultResL3 = XLATE( 'REACT_RUN', RDSNo, 'TRES_AVG_L3', 'X' )
|
|
|
|
TargetResL1 = OCONV( XLATE( 'REACT_RUN', RDSNo, 'RES_TARGET', 'X' ), 'MD3' )
|
|
TargetResL2 = OCONV( XLATE( 'REACT_RUN', RDSNo, 'RES_TARGET_L2', 'X' ), 'MD3' )
|
|
TargetResL3 = OCONV( XLATE( 'REACT_RUN', RDSNo, 'RES_TARGET_L3', 'X' ), 'MD3' )
|
|
|
|
IF ResultResL1 = '' THEN ResultResL1 = TargetResL1
|
|
IF ResultResL2 = '' THEN ResultResL2 = TargetResL2
|
|
IF ResultResL3 = '' THEN ResultResL3 = TargetResL3
|
|
|
|
ResUnitsL1 = XLATE( 'REACT_RUN', RDSNo, 'RES_UNITS', 'X' )
|
|
ResUnitsL2 = XLATE( 'REACT_RUN', RDSNo, 'RES_UNITS_L2', 'X' )
|
|
ResUnitsL3 = XLATE( 'REACT_RUN', RDSNo, 'RES_UNITS_L3', 'X' )
|
|
|
|
ResultRes = ResultResL1
|
|
|
|
IF ResultResL2 NE '' THEN ResultRes := '/':ResultResL2
|
|
IF ResultResL3 NE '' THEN ResultRes := '/':ResultResL3
|
|
|
|
IF ResultRes NE '' THEN ResultRes := ResUnitsL1
|
|
|
|
ResultResMin = XLATE( 'REACT_RUN', RDSNo, 'TRES_MIN', 'X' )
|
|
ResultResMax = XLATE( 'REACT_RUN', RDSNo, 'TRES_MAX', 'X' )
|
|
|
|
TargetConL1 = OCONV( XLATE( 'REACT_RUN', RDSNo, 'CON_TARGET', 'X' )<1,1>, 'MS21' )
|
|
TargetConL2 = OCONV( XLATE( 'REACT_RUN', RDSNo, 'CON_TARGET_L2', 'X' ), 'MS21' )
|
|
TargetConL3 = OCONV( XLATE( 'REACT_RUN', RDSNo, 'CON_TARGET_L3', 'X' ), 'MS21' )
|
|
|
|
ConUnitsL1 = XLATE( 'REACT_RUN', RDSNo, 'CON_UNITS', 'X' )
|
|
ConUnitsL2 = XLATE( 'REACT_RUN', RDSNo, 'CON_UNITS_L2', 'X' )
|
|
ConUnitsL3 = XLATE( 'REACT_RUN', RDSNo, 'CON_UNITS_L3', 'X' )
|
|
|
|
ResultCon = TargetConL1
|
|
IF TargetConL2 NE '' THEN ResultCon := '/':TargetConL2
|
|
IF TargetConL3 NE '' THEN ResultCon := '/':TargetConL3
|
|
IF ResultCon NE '' THEN ResultCon := ConUnitsL1
|
|
|
|
Case (ReactType EQ 'EPP') or (ReactType EQ 'P') ; * EpiPro
|
|
|
|
WMOutKey = WONo:'*':WOStep:'*':CassNo
|
|
WMOutRec = XLATE('WM_OUT',WMOutKey,'','X')
|
|
|
|
MakeupBox = WMOutRec<WM_OUT_MAKEUP_BOX$>
|
|
|
|
CassIDLabel = 'WMONo: '
|
|
CassID = WMOutKey
|
|
|
|
CONVERT '*' TO '.' IN CassID
|
|
|
|
ReactType = 'EpiPro' ;* * * * 12/17/2008 Harded coded reactor type for EpiPro reactors
|
|
|
|
SupVerify = WMOutRec<WM_OUT_SUP_VER_SIG$>
|
|
SupVerifyDt = OCONV(XLATE('WO_MAT',WONo:'*':CassNo,'SHIP_SUP_VER_SIG_DT','X'),'D2/')
|
|
|
|
InCassNo1 = ''
|
|
InSlotNo1 = ''
|
|
MUWoNo1 = ''
|
|
MUCassNo1 = ''
|
|
MUSlotNo1 = ''
|
|
|
|
PartNo = ''
|
|
LotNo = ''
|
|
SubstrPartNo = ''
|
|
CassOrderItem = ''
|
|
CustPNDesc = ''
|
|
|
|
Pointer = 1
|
|
LOOP
|
|
IF WMOutRec<WM_OUT_MU_WO_NO$,Pointer> = '' THEN
|
|
InCassNo1 = WMOutRec<WM_OUT_IN_CASS_NO$,Pointer>
|
|
InSlotNo1 = WMoutRec<WM_OUT_IN_SLOT_NO$,Pointer>
|
|
END ELSE
|
|
IF MUWoNo1 = '' THEN
|
|
MUWoNo1 = WMOutRec<WM_OUT_MU_WO_NO$,Pointer>
|
|
MUCassNo1 = WMOutRec<WM_OUT_MU_CASS_NO$,Pointer>
|
|
MUSlotNo1 = WMOutRec<WM_OUT_MU_SLOT_NO$,Pointer>
|
|
END
|
|
END
|
|
|
|
UNTIL InCassNo1 NE '' OR Pointer > 25
|
|
|
|
Pointer += 1
|
|
REPEAT
|
|
|
|
IF InCassNo1 NE '' THEN
|
|
WOMatRec = XLATE('WO_MAT',WONo:'*':InCassNo1,'','X')
|
|
PartNo = XLATE('WO_LOG',WONo,WO_LOG_CUST_PART_NO$,'X')
|
|
LotNo = WOMatRec<WO_MAT_LOT_NO$>
|
|
SubstrPartNo = WOMatRec<WO_MAT_SUB_PART_NO$>
|
|
|
|
END ELSE
|
|
IF MUWoNo1 NE '' AND MUCassNo1 NE '' THEN
|
|
MUWOMatRec = XLATE('WO_MAT',MUWoNo1:'*':MUCassNo1,'','X')
|
|
PartNo = XLATE('WO_LOG',MUWoNo1,WO_LOG_CUST_PART_NO$,'X')
|
|
LotNo = MUWOMatRec<WO_MAT_LOT_NO$>
|
|
SubstrPartNo = MUWOMatRec<WO_MAT_SUB_PART_NO$>
|
|
|
|
END
|
|
END
|
|
If ReShipCustPartNo NE '' then
|
|
PartNo = ReShipCustPartNo
|
|
end
|
|
WfrsOut = XLATE('WM_OUT',WMOutKey,'WFRS_OUT','X')
|
|
MUWfrsRemQty = ''
|
|
MUWfrsAddQty = ''
|
|
|
|
Specs = obj_Prod_Spec('GetLayerProp',ProdSpecID)
|
|
|
|
ResultThick = ''
|
|
ResultRes = ''
|
|
ResultResMin = ''
|
|
ResultResMax = ''
|
|
ResultCon = ''
|
|
|
|
LayerCount = COUNT(Specs,@RM) + (Specs NE '')
|
|
|
|
FOR Layer = 1 TO LayerCount
|
|
|
|
LayerSpecs = FIELD(Specs,@RM,Layer)
|
|
LayerSpecs = FIELD(LayerSpecs,@FM,2,99) ;* Pull of the layer set ID
|
|
|
|
IF LayerSpecs<PRS_LAYER_THICK_TARGET$> NE '' THEN
|
|
ResultThick := LayerSpecs<PRS_LAYER_THICK_TARGET$>
|
|
END
|
|
|
|
IF LayerSpecs<PRS_LAYER_RES_TARGET$> NE '' THEN
|
|
ResultRes := LayerSpecs<PRS_LAYER_RES_TARGET$>
|
|
ResultResMin := LayerSpecs<PRS_LAYER_RES_MIN$>
|
|
ResultResMax := LayerSpecs<PRS_LAYER_RES_MAX$>
|
|
END
|
|
|
|
IF LayerSpecs<PRS_LAYER_CONC_TARGET$> NE '' THEN
|
|
ResultCon := LayerSpecs<PRS_LAYER_CONC_TARGET$>
|
|
END
|
|
|
|
IF Layer < LayerCount THEN
|
|
IF ResultThick NE '' THEN ResultThick := '/'
|
|
IF ResultRes NE '' THEN ResultRes := '/'
|
|
IF ResultResMin NE '' THEN ResultResMin := '/'
|
|
IF ResultResMax NE '' THEN ResultResMax := '/'
|
|
IF ResultCon NE '' THEN ResultCon := '/'
|
|
END ELSE
|
|
IF ResultThick NE '' THEN ResultThick := LayerSpecs<PRS_LAYER_THICK_UNITS$>
|
|
IF ResultRes NE '' THEN ResultRes := LayerSpecs<PRS_LAYER_RES_UNITS$>
|
|
IF ResultResMin NE '' THEN ResultResMin := LayerSpecs<PRS_LAYER_RES_UNITS$>
|
|
IF ResultResMax NE '' THEN ResultResMax := LayerSpecs<PRS_LAYER_RES_UNITS$>
|
|
IF ResultCon NE '' THEN ResultCon := LayerSpecs<PRS_LAYER_CONC_UNITS$>
|
|
END
|
|
|
|
NEXT Layer
|
|
|
|
Case ReactType EQ 'GAN'
|
|
|
|
WOMatKey = WONo:'*':CassNo
|
|
MakeupBox = False$
|
|
CassIDLabel = 'WOMatNo: '
|
|
CassID = WOMatKey
|
|
MUWfrsAddQty = 0
|
|
|
|
SupVerify = WOMatRec<WO_MAT_CASS_FINAL_SIG$>
|
|
SupVerifyDt = WOMatRec<WO_MAT_CASS_FINAL_SIG_DTM$>
|
|
|
|
InCassNo1 = ''
|
|
InSlotNo1 = ''
|
|
MUWoNo1 = ''
|
|
MUCassNo1 = ''
|
|
MUSlotNo1 = ''
|
|
|
|
PartNo = ''
|
|
LotNo = ''
|
|
SubstrPartNo = ''
|
|
CassOrderItem = ''
|
|
CustPNDesc = ''
|
|
|
|
IF InCassNo1 NE '' THEN
|
|
WOMatRec = XLATE('WO_MAT',WONo:'*':InCassNo1,'','X')
|
|
PartNo = XLATE('WO_LOG',WONo,WO_LOG_CUST_PART_NO$,'X')
|
|
LotNo = WOMatRec<WO_MAT_LOT_NO$>
|
|
SubstrPartNo = WOMatRec<WO_MAT_SUB_PART_NO$>
|
|
|
|
END ELSE
|
|
IF MUWoNo1 NE '' AND MUCassNo1 NE '' THEN
|
|
MUWOMatRec = XLATE('WO_MAT',MUWoNo1:'*':MUCassNo1,'','X')
|
|
PartNo = XLATE('WO_LOG',MUWoNo1,WO_LOG_CUST_PART_NO$,'X')
|
|
LotNo = MUWOMatRec<WO_MAT_LOT_NO$>
|
|
SubstrPartNo = MUWOMatRec<WO_MAT_SUB_PART_NO$>
|
|
|
|
END
|
|
END
|
|
If ReShipCustPartNo NE '' then
|
|
PartNo = ReShipCustPartNo
|
|
end
|
|
|
|
//WfrsOut = Count(Xlate('WO_MAT_WFR', WOMatKey, 'OUT_WFR_ID', 'X'), @VM)
|
|
WfrsOut = obj_WO_Mat('CurrWaferCnt',WOMatKey)
|
|
|
|
Specs = obj_Prod_Spec('GetLayerProp',ProdSpecID)
|
|
|
|
ResultThick = ''
|
|
ResultRes = ''
|
|
ResultResMin = ''
|
|
ResultResMax = ''
|
|
ResultCon = ''
|
|
|
|
LayerCount = COUNT(Specs,@RM) + (Specs NE '')
|
|
|
|
FOR Layer = 1 TO LayerCount
|
|
|
|
LayerSpecs = FIELD(Specs,@RM,Layer)
|
|
LayerSpecs = FIELD(LayerSpecs,@FM,2,99) ;* Pull of the layer set ID
|
|
|
|
IF LayerSpecs<PRS_LAYER_THICK_TARGET$> NE '' THEN
|
|
ResultThick := LayerSpecs<PRS_LAYER_THICK_TARGET$>
|
|
END
|
|
|
|
IF LayerSpecs<PRS_LAYER_RES_TARGET$> NE '' THEN
|
|
ResultRes := LayerSpecs<PRS_LAYER_RES_TARGET$>
|
|
ResultResMin := LayerSpecs<PRS_LAYER_RES_MIN$>
|
|
ResultResMax := LayerSpecs<PRS_LAYER_RES_MAX$>
|
|
END
|
|
|
|
IF LayerSpecs<PRS_LAYER_CONC_TARGET$> NE '' THEN
|
|
ResultCon := LayerSpecs<PRS_LAYER_CONC_TARGET$>
|
|
END
|
|
|
|
IF Layer < LayerCount THEN
|
|
IF ResultThick NE '' THEN ResultThick := '/'
|
|
IF ResultRes NE '' THEN ResultRes := '/'
|
|
IF ResultResMin NE '' THEN ResultResMin := '/'
|
|
IF ResultResMax NE '' THEN ResultResMax := '/'
|
|
IF ResultCon NE '' THEN ResultCon := '/'
|
|
END ELSE
|
|
IF ResultThick NE '' THEN ResultThick := LayerSpecs<PRS_LAYER_THICK_UNITS$>
|
|
IF ResultRes NE '' THEN ResultRes := LayerSpecs<PRS_LAYER_RES_UNITS$>
|
|
IF ResultResMin NE '' THEN ResultResMin := LayerSpecs<PRS_LAYER_RES_UNITS$>
|
|
IF ResultResMax NE '' THEN ResultResMax := LayerSpecs<PRS_LAYER_RES_UNITS$>
|
|
IF ResultCon NE '' THEN ResultCon := LayerSpecs<PRS_LAYER_CONC_UNITS$>
|
|
END
|
|
|
|
NEXT Layer
|
|
End Case
|
|
|
|
IF ProdVerNo NE '' THEN
|
|
// The CassIDLabel has already been determined at this point. It can either be "RDSNo:" or "WMONo:".
|
|
// However, for some reason, it has always been overridden to be "CassID:".
|
|
// Except that QA is now requesting to not override the cassette label string for the NXP (7124) customer.
|
|
If (CustNo NE '7124') then
|
|
CassIDLabel = 'CassID: '
|
|
end
|
|
END
|
|
|
|
IF PartNo = '' THEN
|
|
PartNo = EpiPartNO
|
|
END
|
|
|
|
GOSUB PrintLabel
|
|
PrintSpectrumLabel = False$
|
|
EpiPartNo = XLATE('WO_LOG', WONo, WO_LOG_EPI_PART_NO$, 'X')
|
|
CustReshipPartNo = XLATE('WO_MAT', WONo : '*' : CassNo, WO_MAT_RESHIP_CUST_EPI_PART_NO$, 'X')
|
|
If CustReshipPartNo EQ '' then
|
|
GenerateSpectrumLabel = XLATE('EPI_PART', EpiPartNo, EPI_PART_GENERATE_SPECTRUM_LABEL$, 'X')
|
|
end else
|
|
GenerateSpectrumLabel = XLATE('EPI_PART', CustReshipPartNo, EPI_PART_GENERATE_SPECTRUM_LABEL$, 'X')
|
|
end
|
|
PrintSpectrumLabel = GenerateSpectrumLabel AND (Indexc(PrintPath, 'MESZBRPRT011', 1) OR Indexc(PrintPath, 'MESZBRPRT004', 1))
|
|
If PrintSpectrumLabel then
|
|
Sap_Services('PrintSpectrumLabel', WONo, WOStep, CassNo)
|
|
If Error_Services('NoError') then
|
|
LogData = ''
|
|
LogData<1, 1> = LoggingDTM
|
|
LogData<1, 2> = 'Successfully sent .sik file to Spectrum file share. WO#' : WONo : ', Cass# ' : CassNo
|
|
Logging_Services('AppendLog', objSpectrumLog, LogData, @FM, @VM)
|
|
end else
|
|
ErrorMessage = Error_Services('GetMessage')
|
|
LogData = ''
|
|
LogData<1, 1> = LoggingDTM
|
|
LogData<1, 2> = 'Failed to send .sik file to Spectrum file share. WO#' : WONo : ', Cass# ' : CassNo :'. ' : ErrorMessage
|
|
Logging_Services('AppendLog', objSpectrumLog, LogData, @FM, @VM)
|
|
end
|
|
end
|
|
NEXT I
|
|
|
|
|
|
* * * * * * *
|
|
OIPrint_Err:
|
|
* * * * * * *
|
|
|
|
* Local method to kill the OIPI engine
|
|
|
|
*IF stat < 0 THEN DEBUG ;*********
|
|
|
|
If Environment_Services('GetLabelPrintMethod') _EQC 'OIPI' then
|
|
stat = Set_Printer("TERM")
|
|
end else
|
|
stat = Direct_Print('STOP')
|
|
end
|
|
|
|
|
|
RETURN
|
|
|
|
|
|
* * * * * * * *
|
|
PrintLabel:
|
|
* * * * * * * *
|
|
|
|
Convert '*' to '.' in CassID
|
|
|
|
MULabel = ''
|
|
IF MakeupBox = 1 THEN MULabel = '** Makeup Box **'
|
|
IF MUWfrsAddQty > 0 THEN MULabel = 'Merged Lot'
|
|
|
|
SuppCd = SubSupplier
|
|
ErrorMsg = ''
|
|
|
|
IF LEN(PartNo) > 18 THEN ErrorMsg = 'CustPartNo parameter exceeds 18 characters.'
|
|
IF LEN(RevLvl) > 3 THEN ErrorMsg = 'RevLvl parameter exceeds 3 characters.'
|
|
IF LEN(WfrsOut) > 6 THEN ErrorMsg = 'PartQty parameter exceeds 6 characters.'
|
|
IF NOT(NUM(WfrsOut)) THEN ErrorMsg = 'PartQty parameter is not a number.'
|
|
|
|
IF ErrorMsg THEN
|
|
ErrMsg(ErrorMsg)
|
|
END ELSE
|
|
* Good to go on the label print
|
|
If Environment_Services('GetLabelPrintMethod') _EQC 'OIPI' then
|
|
stat = Set_Printer('TEXT',ImageData) ;* Download bitmap image to the printer
|
|
end else
|
|
stat = Direct_Print('PRINT', ImageData)
|
|
end
|
|
* Label is 812 x 608 dots at 8dots/mm (203 dots/inch)
|
|
* Leave periodic spaces in Label String - OIPrint interface wraps text on spaces and will cut off
|
|
* the LabelString if there aren't any spaces. Printer Width needs to be set to 132 or greater
|
|
|
|
LabelString = '^XA' ;* Start of label format
|
|
LabelString := '^LH15,50' ;* Label home offset (needed to get onto the label medium)
|
|
LabelString := '^BY3' ;* Set narrow Bar Code line width to 3 dots
|
|
LabelString := '^PR2' ;* Print speed = 2 IPS
|
|
|
|
LabelString := '^FO0,156^GB809,0,3,B^FS':@FM ;* 'Top' of 4x3 Label
|
|
LabelString := '^FO0,308^GB809,0,3,B^FS':@FM ;* 1st 'horizontal' line (bottom of 1st cell)
|
|
LabelString := '^FO0,460^GB809,0,3,B^FS':@FM ;* 2nd 'horizontal' line (bottom of 2nd cell)
|
|
|
|
* Block 1 Left (Cust Part)
|
|
LabelString := '^FO0,10^A0,25^FDCust Part (P):^FS':CRLF$ ;* Label Line 1
|
|
LabelString := '^FO15,45^A0,50,40^FD':PartNo:'^FS':CRLF$ ;* Readable
|
|
LabelString := '^FO15,95^BY2^BC,60,N^FDP':PartNo:'^FS':CRLF$ ;* Code 128
|
|
LabelString := '^BY3,3.0':CRLF$
|
|
|
|
* Block 1 Right (Rev Lvl)
|
|
LabelString := '^FO508,0^BY2^B3,,60,N^FD2P':RevLvl:'^FS':CRLF$ ;* Code 39
|
|
LabelString := '^BY3,3.0':CRLF$
|
|
LabelString := '^FO508,70^A0,25^FDRev.Level (2P):^FS':CRLF$ ;* Label Line 1
|
|
LabelString := '^FO680,70^A0,50,48^FD':RevLvl:'^FS':CRLF$ ;* Readable
|
|
|
|
* Block 2 Left (Quantity)
|
|
LabelString := '^FO0,165^A0,25^FDQuantity (Q):^FS':CRLF$ ;* Label Line 1
|
|
LabelString := '^FO15,195^A0,50,40^FD':WfrsOut:'^FS':CRLF$ ;* Readable
|
|
LabelString := '^FO15,245^BY2^B3,,60,N^FDQ':WfrsOut:'^FS':CRLF$ ;* Code 39
|
|
LabelString := '^BY3,3.0':CRLF$
|
|
|
|
LabelString := '^FO250,275^A0,25^FDReact Type:^FS':CRLF$
|
|
LabelString := '^FO380,275^A0,25^FD':ReactType:'^FS':CRLF$
|
|
|
|
LabelString := '^FO500,123^A0,25^FDReq Ship Dt:^FS':CRLF$
|
|
LabelString := '^FO635,123^A0,36^FD':ReqShipDt:'^FS':CRLF$
|
|
|
|
//Data Matrix Barcode Content
|
|
IF CustNo = '7053' THEN
|
|
* Tower Specific
|
|
//DPC - 2/10/20 - added '1B' prefix and SAPBatchNo per Matt T. request
|
|
//DPC - 3/11/20 - replaced 1T LotNo with SAPBatchNo per Matt T. request
|
|
BCContent = 'P' : PartNo :';' ;* Cust Part No
|
|
BCContent := '2T' : CassID :';' ;* CassID (Epi Lot Number)
|
|
BCContent := '1B' : SAPBatchNo :';' ;* SAP Batch ID
|
|
BCContent := '1R' : ResultResMin :';' ;* Res Min
|
|
BCContent := '2R' : ResultResMax :';' ;* Res Max
|
|
BCContent := 'Q' : WfrsOut :';' ;* Qty
|
|
BCContent := '1V' : 'IR' :';' ;* Vendor Code
|
|
BCContent := '6D' : DMShipDt :';' ;* Req Ship Date
|
|
BCContent := '32T' : EpiPartNo ;* EpiPartNo
|
|
END ELSE
|
|
* All other customers
|
|
BCContent = 'P' : PartNo :';' ;* Cust Part No
|
|
BCContent := '2T' : RevLvl :';' ;* Rev Level
|
|
BCContent := '1T' : CassID :';' ;* Cass ID (Lot Number)
|
|
BCContent := '1R' : ResultThick :';' ;* Thk Avg
|
|
BCContent := '2R' : ResultRes :';' ;* Res Avg
|
|
BCContent := '3R' : ResultCon :';' ;* Conc
|
|
BCContent := 'Q' : WfrsOut :';' ;* Qty
|
|
BCContent := '1V' : SuppCD :';' ;* Vendor Code
|
|
BCContent := '6D' : DMShipDt :';' ;* Req Ship Date
|
|
BCContent := '32T' : CustName ;* Customer Name
|
|
END
|
|
|
|
LabelString := '^FO600,178^BXN,3,200^FD':BCContent:'^FS' ;* Test Data Matrix bar code
|
|
|
|
* Block 3 Left (Customer Lot)
|
|
LabelString := '^FO0,315^A0,25^FDCustomer Lot :^FS':CRLF$ ;* Label Line 1
|
|
LabelString := '^FO15,350^A0,50,40^FD':LotNo:'^FS':CRLF$ ;* Readable
|
|
LabelString := '^FO15,400^BY2^B3,,60,N^FD':LotNo:'^FS':CRLF$ ;* Code 39
|
|
LabelString := '^BY3,3.0':CRLF$
|
|
|
|
* Block 3 Right (Supplier)
|
|
LabelString := '^FO510,320^A0,,40^FDIFX Epi Services^FS':CRLF$ ;* Added Text for 'IFX Epi Services * * * * * * * * * *
|
|
|
|
IF SuppCd NE '' THEN
|
|
|
|
LabelString := '^FO590,430^A0,25^FDSupp Cd (1V):^FS':CRLF$ ;* Label Line - Added 8/17/2005 JCH Supplier Code Info
|
|
LabelString := '^FO740,430^A0,36,40^FD':SuppCd:'^FS':CRLF$ ;* Readable
|
|
|
|
LabelString := '^FO590,370^BY2^B3,,50,N^FD1V':SuppCd:'^FS':CRLF$ ;* Code 39 Supplier Code - This bar code is in line 1 ;*Changed ^FD' to ^FD1V' - dkk 7/27/15
|
|
LabelString := '^BY3,3.0':CRLF$
|
|
END
|
|
|
|
* Block 4 1st Line Left
|
|
LabelString := '^FO0,470^A0,25^FDCustomer:^FS':CRLF$ ;* Label Line
|
|
LabelString := '^FO120,470^A0,45,25^FD':CustName:'^FS':CRLF$ ;* Readable
|
|
|
|
* Block 4 1st Line Right
|
|
IF MULabel NE '' THEN
|
|
LabelString := '^FO550,470^A0,40^FD':MULabel:'^FS':CRLF$
|
|
END
|
|
|
|
* Block 4 2nd Line
|
|
If CustNo EQ '6874' then ;* for Newport, include the 1T prefix
|
|
LabelString := '^FO0,515^A0,25^FD':'(1T)':CassIDLabel :'^FS':CRLF$ ;* Label Line
|
|
LabelString := '^FO130,515^A0,36,40^FD':CassID:'^FS':CRLF$
|
|
LabelString := '^FO340,515^BY2^B3,,40,N^FD':'1T':CassID:'^FS':CRLF$
|
|
end else
|
|
LabelString := '^FO0,515^A0,25^FD':CassIDLabel :'^FS':CRLF$ ;* Label Line
|
|
LabelString := '^FO130,515^A0,36,40^FD':CassID:'^FS':CRLF$ ;* Readable
|
|
LabelString := '^FO340,515^BY2^B3,,40,N^FD':CassID:'^FS':CRLF$ ;* Code 39 (This is the Cass ID) ;*Changed ^FD' to ^FD1T' - dkk 7/30/15
|
|
end
|
|
|
|
LabelString := '^BY3,3.0':CRLF$
|
|
|
|
* Block 4 3rd Line
|
|
IF ProdVerNo NE '' THEN
|
|
* SAP
|
|
LabelString := '^FO0,570^A0,25^FDBatch:^FS':CRLF$ ;* Label Line
|
|
LabelString := '^FO130,570^A0,36^FD':SAPBatchNo:'^FS':CRLF$ ;* Readable * SAP Batch No *
|
|
LabelString := '^FO340,570^BY2^B3,,40,N^FD':SAPBatchNo:'^FS':CRLF$ ;* Code 39 (This is the Cass ID)
|
|
LabelString := '^BY3,3.0':CRLF$
|
|
|
|
END
|
|
|
|
* Block 4 5th Line
|
|
LabelString := '^FO0,620^A0,25^FDPO No:^FS':CRLF$ ;* Label Line
|
|
|
|
IF LEN(PONo) > 11 THEN
|
|
LabelString := '^FO80,620^A0,25,20^FD':PONo:'^FS':CRLF$ ;* Readable * Production Order * Squeezed
|
|
END ELSE
|
|
LabelString := '^FO80,620^A0,25,40^FD':PONo:'^FS':CRLF$ ;* Readable * Production Order *
|
|
END
|
|
|
|
LabelString := '^FO300,620^A0,25^FDWO No:^FS':CRLF$ ;* Label Line
|
|
LabelString := '^FO380,620^A0,25^FD':WONo:'^FS':CRLF$ ;* Readable
|
|
LabelString := '^FO490,620^A0,25^FDEPI Part:^FS':CRLF$ ;* Label Line
|
|
LabelString := '^FO590,620^A0,25^FD':EpiPartNo:'^FS':CRLF$
|
|
|
|
* Block 4
|
|
IF SAPBatchNo = '' THEN
|
|
ConcLabelString = FMT(EpiPartNo,"L#15"):FMT(CassID,"L#12"):FMT(WfrsOut,"R#6")
|
|
END ELSE
|
|
ConcLabelString = EpiPartNo:' ':SAPBatchNo:' ':WfrsOut
|
|
END
|
|
|
|
LabelString := '^FO0,650^BY2^BC,90,N^FD':ConcLabelString:'^FS':CRLF$ ;* Code 128 - original
|
|
LabelString := '^XZ'
|
|
|
|
If Environment_Services('GetLabelPrintMethod') _EQC 'OIPI' then
|
|
stat = Set_Printer('TEXT',LabelString)
|
|
end else
|
|
stat = Direct_Print('PRINT', LabelString)
|
|
end
|
|
END ;* End of Check for good label data
|
|
|
|
|
|
RETURN
|
|
|
|
|
|
|
|
|
|
|