예제 #1
0
    def HuntBreshersPrint(self, config_data):
        if(config_data['site_number'] == ""):
            self.set_siteID(re.sub(r'[a-z_\s-]','', self.siteID, flags=re.IGNORECASE))
        else:
            self.set_siteID(config_data['site_number'])
        self.set_siteID(format.padAdd("left","0",8,self.siteID))
        match self.cardType:
            case ("VF"):
                self.set_cardType("VY")
            case ("CCID"):
                self.set_cardType("CC")
            case ("Credit"):
                self.set_cardType("CR")
        #self.set_cardType
        self.set_card(format.padAdd("left","X",20,self.card))
        self.set_tranDate(f"{self.tranDate[4:6]}-{self.tranDate[6:8]}-{self.tranDate[0:4]}")
        self.set_tranTime(f"{self.tranTime[0:2]}:{self.tranTime[2:4]}:00")
        self.set_tranNum(format.padAdd("left","0",4,format.cutLength("right",4,self.tranNum)))
        self.set_pDesc(format.cutLength("Right",30,self.pDesc))
        self.set_quantity(format.decimalPad(3,self.quantity))
        self.set_price(format.decimalPad(4,self.price))
        self.set_totalAmount(f"${format.decimalPad(2,self.totalAmount)}")

        return [self.siteID,self.cardType,self.card,self.tranDate,self.tranTime,
                self.pCode,self.pDesc,self.quantity,self.price,self.totalAmount]
예제 #2
0
    def AGTRAXPrint(self, config_data):
        if(self.pCode == "01"):
            self.set_pCode("703")
        elif(self.pCode == "21"):
            self.set_pCode("702")
        elif(self.pCode == "44"):
            self.set_pCode("705")
        if config_data.get('site_number') == "":
            self.set_siteID(str(format.padAdd("left", "0", 3, self.siteID)))
        else:
            self.set_siteID(str(format.padAdd("left", "0", 3, config_data.get('site_number'))))
        self.set_account(str(format.padAdd("left", " ", 7, re.sub(r'^0*','',format.cutLength("right", 7, self.account)))))
        self.set_totalAmount(str(format.padAdd("left", "0", 10, format.decimalFormat(2, self.totalAmount))))
        self.set_card(str(format.padAdd('right', " ", 16, (format.cutLength("right", 4, self.card).strip("X")))))
        self.set_pCode(str(format.padAdd("right", " ", 16, self.pCode)))
        self.set_quantity(str(format.padAdd("left", "0", 10, format.decimalFormat(3, self.quantity))))
        self.set_price(str(format.padAdd("left", "0", 10, format.decimalFormat(4, self.price))))
        self.set_tranNum(str(format.padAdd("left", "0", 6, str(self.tranNum))))

        commentCard = self.card.strip()
        commentCard = commentCard[len(commentCard)-4:len(commentCard)]
        comment = str(format.padAdd("right", " ", 25, (f"{self.cardType} {commentCard}")))
        tranCode = ""

        if self.cardType == "NBS":
            tranCode = "05"
            self.set_account("   CASH")
        else:
            tranCode = "02"

        return(f"00{self.siteID}{self.tranNum}{self.tranDate}{self.account}{tranCode}{self.totalAmount}+00000000+00000000+0000000000+0000000000+                       {self.card}000000000000000000+\n"
               f"01004{self.pCode}{self.quantity}+{self.price}{self.totalAmount}+0000000000000000+0000000000+0000000000+                         \n"
               f"02{comment}\n")
예제 #3
0
    def CFNcsvPrint(self, config_data):
        p19 = f"{'0'*20}"
        if(len(self.pName) > 20):
            self.set_pName(self.pName[0:20])
        if(len(str(self.seqNum))>4):
            self.set_seqNum(self.seqNum[len(self.seqNum)-4:len(self.seqNum)])
        if(len(str(self.odometer))>7):
            self.set_odometer(self.odometer[len(self.odometer)-7:len(self.odometer)])
        if(len(str(self.tranNum))>4):
            self.set_tranNum(self.tranNum[len(self.tranNum)-4:len(self.tranNum)])

        tranType = "T"

        if(config_data['Downs']):
            self.set_card(f"000{self.card[len(self.card)-4:len(self.card)]}")
            p19 = f"{self.card}{'0'*13}"
            if(len(self.siteID.split(' - ')) == 2):
                self.set_siteID(re.sub(r'[a-z_\s-]','', self.siteID.split(' - ')[1], flags=re.IGNORECASE))
            else:
                self.set_siteID(re.sub(r'[a-z_\s-]','', self.siteID, flags=re.IGNORECASE))
            tranType = "N"  
        elif(config_data['Acme']):
            self.set_cardType("PV")
            self.set_siteID(config_data.get('site_number'))
            self.set_card(format.padAdd('left','0',16,self.card))
            self.set_card(f"{format.padAdd('left','0',6, self.siteID)}{self.card[6:len(self.card)]}")
            p19 = f"{self.card}{'196'}{'001454'}{'0000'}"
            #p19 = "5550123" + "321" + "001234" + "0000"         
            tranType = "P"

        return [self.siteID, self.seqNum, "0", self.totalAmount, "0", self.pCode, "FUEL", self.pName,self.price,self.quantity,self.odometer,self.pump,self.tranNum,self.tranDate[2:8],self.tranTime,
                    0,9,'',p19,'','','','','','','','','','','','','','','','','','','','','','',tranType,self.cardType,0,self.price,0,0,'','','','','','','','','']
예제 #4
0
    def JCDoylePrint(self, config_data):
        self.set_pump(format.padAdd("left", "0", 2, self.pump))
        
        self.set_tranNum(str(format.padAdd("left", "0", 6, self.tranNum)))
        self.set_tranDate(f" {str(self.rawTranTime[4:6])}/{str(self.rawTranTime[6:8])}/{str(self.rawTranTime[0:4])}")
        self.set_tranTime(f" {str(self.rawTranTime[8:10])}:{str(self.rawTranTime[10:12])}")
        self.set_account(" " + str(format.padAdd("right", " ", 8, re.sub(r'^0*X+','',format.cutLength("right", 7, self.account)))))
        self.set_totalAmount(" " + str(format.padAdd("left"," ",7,format.decimalPad(2,self.totalAmount))))
        self.set_card(" " + str(format.padAdd("left", " ", 8, self.card)))
        self.set_pCode(" " + str(format.padAdd("left", " ", 2, re.sub(r'product\.id = ','',str(self.pCode)))))
        self.set_quantity(" " + str(format.padAdd("left", " ", 7, str(format.decimalPad(3,self.quantity)))))
        self.set_price(" " + str(format.padAdd("left", " ", 6, str(format.decimalPad(3,self.price)))))
        tranCode = ""

        return(f"{self.tranNum}0{self.account}{self.card}{self.tranDate}{self.tranTime}{self.pCode}{self.quantity}{self.price}{self.totalAmount}\n")
예제 #5
0
    def FuelMasterPrint(self, config_data):
        if(config_data['site_number'] == ""):
            self.set_siteID(re.sub(r'[a-z_\s-]','', self.siteID, flags=re.IGNORECASE))
        else:
            self.set_siteID(config_data['site_number'])
        self.set_siteID(format.padAdd("left","0",4,format.cutLength("right",4,self.siteID)))
        self.set_tranDate(f"{self.tranDate[4:6]}{self.tranDate[6:8]}{self.tranDate[2:4]}")
        self.set_account(format.padAdd("left","0",5,format.cutLength("right",5,self.account)))
        self.set_card(format.padAdd("left","0",4,format.cutLength("right",4,self.card)))
        self.set_odometer(format.padAdd("left"," ",6,format.cutLength("right",6,self.odometer)))
        if len(self.pCode) == 2:
            self.set_pCode(re.sub(r'0','',self.pCode[0]) + self.pCode[1])
        self.set_pCode(format.padAdd("left"," ",2,self.pCode))
        if len(self.pump) == 2:
            self.set_pump(re.sub(r'0',' ',self.pump[0]) + self.pump[1])
        self.set_pump(format.padAdd("left"," ",2,self.pump))
        self.set_quantity(format.padAdd("left","0",9,format.decimalPad(2, self.quantity)))
        self.set_price(format.padAdd("left","0",7,format.decimalPad(4,self.price)))
        self.set_totalAmount(format.padAdd("left","0",11,format.decimalPad(2,self.totalAmount)))

        return(f"00{self.siteID}{self.tranDate}{self.tranTime}0000{self.account}0000"
               f"{self.card}{self.odometer}    {self.pCode}{self.pump}{self.quantity}{self.price}"
               f"{self.totalAmount}\n")
예제 #6
0
    def VDPPrint(self, config_data):
        if(config_data.get('site_number') == ""):
            self.set_siteID(format.padAdd("left", "0", 6, self.siteID))
        else:
            self.set_siteID(format.padAdd("left", "0", 6, config_data.get('site_number')))
        self.set_tranNum(format.padAdd("left", "0", 6, self.tranNum))
        if(self.cardType == "Credit"):
            self.set_card(format.padAdd("right", "0", 30, format.padAdd("left", "0", 23, "0000")))
        else:
            self.set_card(format.padAdd("right", "0", 30, format.padAdd("left", "0", 23, self.card)))
        
        if(self.tenderDict['actionState'] == "Unapproved"):
            self.set_pCode("00")
            self.set_seqNum("0000")
            self.set_totalAmount("00000000")
            self.set_price("0000")
            self.set_quantity("00000000")
            self.set_pump("00")
        else:
            if self.pCode == "44":
                self.set_pCode("50")
            elif self.pCode == "03":
                self.set_pCode("45")
            self.set_seqNum(format.padAdd("left", "0", 4, self.seqNum))
            self.set_totalAmount(format.padAdd("left", "0", 8, format.decimalFormat(2,self.totalAmount)))
            self.set_price(format.padAdd("left", "0", 4, format.decimalFormat(3,self.price)))
            self.set_quantity(format.padAdd("left", "0", 8, format.decimalFormat(3, self.quantity)))
            self.set_pump(format.padAdd("left", "0", 2, self.pump))

        return(f"0{self.siteID}{self.tranNum}{self.seqNum}0{self.totalAmount}00{self.pCode}{self.price}{self.quantity}"
               f"0000000000000000{self.pump}{self.tranDate}{self.tranTime}4100000000000000000000000011{self.card}"
               f"000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000\n")
예제 #7
0
    def merchantAgPrint(self, config_data):
        if(config_data['site_number'] == ""):
            self.set_siteID(re.sub(r'[a-z_\s-]','', self.siteID, flags=re.IGNORECASE))
        else:
            self.set_siteID(config_data['site_number'])
        
        self.set_siteID(format.padAdd("left","0",8,self.siteID))
        self.set_totalAmount(format.padAdd("left","0",9,re.sub(r'[.]','', format.decimalPad(3,self.totalAmount), flags=re.IGNORECASE)))
        self.set_pCode(format.padAdd("right"," ",20,format.padAdd("left","0",3,self.pCode)))
        self.set_quantity(format.padAdd("left","0",9,re.sub(r'[.]','', format.decimalPad(3,self.quantity), flags=re.IGNORECASE)))
        self.set_price(format.padAdd("left","0",9,re.sub(r'[.]','', format.decimalPad(3,self.price), flags=re.IGNORECASE)))
        self.set_pump(format.padAdd("left","0",2,self.pump))
        self.set_tranNum(format.padAdd("left","0",9,self.tranNum))
        self.set_tranDate(f"{self.tranDate[6:8]}{self.tranDate[4:6]}{self.tranDate[0:4]}")
        self.set_vehicle(format.padAdd("left","0",9,self.vehicle))
        self.set_card(format.padAdd("left","0",9,self.card))
        self.set_account(format.padAdd("left"," ",20,self.account))
        self.set_vehicleID(format.padAdd("left","0",9,self.vehicleID))
        self.set_pName(format.padAdd("right"," ",26,self.pName))
        self.set_cardType(format.mAgCardName(self.cardType))

        driver = self.card
        if self.account == self.card:
                driver = "000000000"
        
        return(f"{self.tranNum}{self.tranDate}{self.tranTime}{self.account}{self.pCode}{' '*20}{self.pName}"
               f"{self.quantity}{self.odometer}{self.vehicle}{self.price}{self.totalAmount}{self.totalAmount}{' '*20}"
               f"{self.siteID}{self.pump}{driver}{' '*53}{self.cardType}{self.account}{self.totalAmount}{' '*52}\n")
예제 #8
0
    def gasboyPrint(self, config_data):
        self.set_tranNum(format.padAdd("left", " ", 4, format.cutLength("right", 4, self.tranNum)))
        if(config_data['site_number'] == ""):
            self.set_siteID(re.sub(r'[a-z_\s-]','', self.siteID, flags=re.IGNORECASE))
            if(len(self.siteID) > 2):
                self.set_siteID(self.siteID[len(self.siteID)-2: len(self.siteID)])
            self.set_siteID(self.siteID + " ")
        else:
            self.set_siteID(format.padAdd("left", " ", 2, format.cutLength("right",2,str(config_data['site_number']))) + " ")
        self.set_tranNum(format.padAdd("left"," ",4,format.cutLength("right",4,self.tranNum)) + " ")
        self.set_card(format.padAdd("left"," ",6,format.cutLength("right",6,self.card)) + " ")
        self.set_account(format.padAdd("left"," ",6,format.cutLength("right",6,self.account)) + " ")
        self.set_vehicle(format.padAdd("left"," ",9,format.cutLength("right",9,self.vehicle)) + " ")
        self.set_tranDate(format.padAdd("left"," ",8,f"{self.tranDate[4:6][0].replace('0',' ')}{self.tranDate[4:6][1]}/{self.tranDate[6:8]}/{self.tranDate[2:4]} "))
        self.set_tranTime(format.padAdd("left"," ",5,f"{self.tranTime[0:2][0].strip('0')}{self.tranTime[0:2][1]}:{self.tranTime[2:4]} "))
        self.set_pump(format.padAdd("left","0",2,self.pump) + " ")
        self.set_pCode(format.padAdd("left","0",2,self.pCode) + " ")
        self.set_quantity(format.padAdd("left"," ",9,format.decimalPad(3,self.quantity)) + " ")
        self.set_price(format.padAdd("left"," ",5,format.decimalPad(3,self.price)) + " ")
        self.set_totalAmount(format.padAdd("left"," ",9,format.decimalPad(2,self.totalAmount)) + " ")
        self.set_odometer(format.padAdd("left"," ",6,format.cutLength("right",6,self.odometer)) + " ")

        if(config_data['Dawson'] == True):
            carwash =""
            if self.card[len(self.card)-4:len(self.card)] == self.account[len(self.card)-4:len(self.card)]:
                driver = "000000 "
            else:
                driver = self.card
            for x in ("07 ","08 ","09 "):
                if self.pCode == x:
                    carwash = "CARWASH "
            return(f"{self.siteID}{self.tranNum}{driver}{self.account}000 {self.vehicle}{self.tranDate}{self.pump}{self.pCode}"
                   f"{self.quantity}{self.price}{self.totalAmount}{self.odometer}{carwash}\n")
        else:
            return(f"{self.siteID}{self.tranNum}{self.card}{self.account}000 {self.vehicle}{self.tranDate}{self.pump}{self.pCode}"
                   f"{self.quantity}{self.price}{self.totalAmount}{self.odometer}\n")
예제 #9
0
    def ptPrint(self, config_data):
        STATCODE = "00"
        ACT = "00"
        TRANTYPE = "00"
        OID = "0"
        FILL = "00000000"
        PART_ID = "000"
        END = ("00000000000000000000000000000"
                "00000000000000000000000000000"
                "00000000000000000000000000000"
                "00000000000000000000000000000"
                "000000000000DCF00000000000000"
                "0000000000")

        self.set_tranNum(format.padAdd("left","0",4,format.cutLength("right",4, str(self.tranNum))))
        self.set_siteID(str(re.sub(r'[a-z_\s-]','', str(self.siteID), flags=re.IGNORECASE)))
        for __ in range((6-len(self.siteID))):
            self.set_siteID('0' + self.siteID)
        self.set_seqNum(format.padAdd("left","0",4, format.cutLength("right",4,str(self.seqNum))))
        self.set_totalAmount(format.padAdd("left","0",6,format.decimalFormat(2,str(self.totalAmount))))
        self.set_price(format.padAdd("left","0",8,format.decimalFormat(7,str(self.price))))
        self.set_quantity(format.padAdd("left","0",8,format.decimalFormat(3,str(self.quantity))))
        self.set_odometer(format.padAdd("left","0",7,str(format.cutLength("right",8,str(self.odometer)))))
        self.set_pump(format.padAdd("left","0",2,format.cutLength("right",2,str(self.pump))))
        self.set_tranDate(self.tranDate[2:8])
        self.set_vehicle(format.padAdd("left","0",8,format.cutLength("right",8,str(self.vehicle))))
        self.set_card(format.padAdd("left","0",7,format.cutLength("right",7,str(self.card))))
        self.set_account(format.padAdd("left","0",6,format.cutLength("right",6,str(self.account))))
        self.set_vehicleID(format.padAdd("left","0",4,format.cutLength("right",4,str(self.vehicle))))

        return(f"{self.siteID}{self.seqNum}{STATCODE}{self.totalAmount}{ACT}{TRANTYPE}{self.pCode}{self.price}"
               f"{self.quantity}{self.odometer}{OID}{self.pump}{self.tranNum}{self.tranDate}{self.tranTime}"
               f"{FILL}{self.vehicle}{self.card}{PART_ID}{self.account}{self.vehicleID}{END}\n")