Compare commits
6 Commits
20220614-1
...
20220615-1
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
6a28aeaa16 | ||
|
|
42f32873ea | ||
|
|
e4137d4780 | ||
|
|
b10b14c420 | ||
|
|
0a1cbd31b8 | ||
|
|
dc7ace0446 |
@@ -1,6 +1,7 @@
|
||||
from tkinter import *
|
||||
from tkinter import font
|
||||
from datetime import datetime
|
||||
from tkinter import messagebox
|
||||
|
||||
class Check_addresses_popup(Toplevel):
|
||||
x_row = 0
|
||||
@@ -193,3 +194,57 @@ class Check_debitor_popup(Toplevel):
|
||||
print("nouveau code = "+ self.inp_code.get())
|
||||
return self.inp_code.get()
|
||||
|
||||
|
||||
class Input_popup(Toplevel):
|
||||
x_row = 0
|
||||
no_selection_possible = False
|
||||
|
||||
def __init__(self, parent, text="Veuillez saisir la nouvelle valeur.", default="" ,factureID=None, fip=None, object=None):
|
||||
super().__init__(parent)
|
||||
|
||||
self.object = object
|
||||
|
||||
|
||||
self.inp_value = StringVar()
|
||||
if default is not None:
|
||||
self.inp_value.set(default)
|
||||
|
||||
|
||||
self.geometry(f"650x120+{parent.winfo_x() + 25}+{parent.winfo_y() + 25}")
|
||||
self.resizable(True, True)
|
||||
self.iconbitmap("./logo_clerc_03X_icon.ico")
|
||||
self.title(f"Saisir une valeur {fip} / {factureID}.")
|
||||
|
||||
self.columnconfigure(0, weight=1)
|
||||
self.columnconfigure(1, weight=1)
|
||||
|
||||
lbf_new = LabelFrame(self, text=text)
|
||||
lbf_new.grid(row=0, column=0, sticky='WE', padx=5, pady=5)
|
||||
|
||||
label_font = font.Font(weight='bold', size=9)
|
||||
Label(lbf_new, text="", font=label_font).grid(row=0, column=0, sticky="W")
|
||||
Entry(lbf_new, textvariable=self.inp_value, width=100).grid(row=0, column=1, sticky="W", pady=10)
|
||||
|
||||
|
||||
self.btn = Button(self, text="Valider", command=self.destroy)
|
||||
self.btn.grid(row=2, column=0, pady=10, padx=10, sticky='NSEW')
|
||||
|
||||
def add(self):
|
||||
self.destroy()
|
||||
if self.object is not None:
|
||||
self.object.add_items(code=self.inp_code.get(), name=self.debitor["name"])
|
||||
self.object.save_debitors()
|
||||
|
||||
def destroy(self):
|
||||
if self.inp_value.get() is None or self.inp_value.get() == "":
|
||||
messagebox.showerror(title="ERREUR", message="Veuillez saisir une valeur !")
|
||||
self.focus()
|
||||
else:
|
||||
super().destroy()
|
||||
|
||||
def show(self):
|
||||
self.deiconify()
|
||||
self.wm_protocol("WM_DELETE_WINDOW", self.destroy)
|
||||
self.wait_window(self)
|
||||
print("nouvelle valeur = " + self.inp_value.get())
|
||||
return self.inp_value.get()
|
||||
|
||||
@@ -1 +1 @@
|
||||
20220614-1653
|
||||
20220615-1544
|
||||
63
main.py
63
main.py
@@ -245,7 +245,7 @@ class ClercAttrib2Biz():
|
||||
|
||||
|
||||
def read_addresses(self):
|
||||
file_addresses_path = os.path.join(dest_dir, f"adresses.csv")
|
||||
file_addresses_path = os.path.join(dest_dir, f"adresses.txt")
|
||||
if os.path.exists(file_addresses_path):
|
||||
file = open(file_addresses_path)
|
||||
csvreader = csv.reader(file, delimiter=';')
|
||||
@@ -262,7 +262,7 @@ class ClercAttrib2Biz():
|
||||
o_addresse.city = row[15]
|
||||
self.addresses.add_addresse(o_addresse)
|
||||
|
||||
print(self.addresses.items)
|
||||
|
||||
file.close()
|
||||
|
||||
else:
|
||||
@@ -322,6 +322,37 @@ class ClercAttrib2Biz():
|
||||
return ret
|
||||
return value.strip()
|
||||
|
||||
def trim_all_data(self, data):
|
||||
if data.Patient["lastname"] is not None:
|
||||
data.Patient["lastname"] = data.Patient["lastname"].strip()
|
||||
if data.Patient["firstname"] is not None:
|
||||
data.Patient["firstname"] = data.Patient["firstname"].strip()
|
||||
if data.Patient["street"] is not None:
|
||||
data.Patient["street"] = data.Patient["street"].strip()
|
||||
if data.Debtor["lastname"] is not None:
|
||||
data.Debtor["lastname"] = data.Debtor["lastname"].strip()
|
||||
if data.Debtor["firstname"] is not None:
|
||||
data.Debtor["firstname"] = data.Debtor["firstname"].strip()
|
||||
if data.Debtor["street"] is not None:
|
||||
data.Debtor["street"] = data.Debtor["street"].strip()
|
||||
|
||||
def check_code_validity(self, code,data):
|
||||
ret = True
|
||||
check_patients = ["firstname", "lastname", "street"]
|
||||
check_Debtor = ["firstname", "lastname", "street"]
|
||||
if code == 1:
|
||||
for check in check_patients:
|
||||
if data.Patient[check] is None:
|
||||
ret = False
|
||||
for check in check_Debtor:
|
||||
if data.Debtor[check] is None:
|
||||
ret = False
|
||||
if not ret:
|
||||
messagebox.showerror(title="Erreur Critique", message=f"Les informations de la factures [{data.data['id']}] comportes trop d'erreur arrêt du processus ")
|
||||
return False
|
||||
|
||||
return ret
|
||||
|
||||
|
||||
def parseFile(self, data, filename):
|
||||
self.index_counter += 1
|
||||
@@ -343,15 +374,19 @@ class ClercAttrib2Biz():
|
||||
data = cls_Invoice()
|
||||
data.parse_item(ele)
|
||||
|
||||
self.trim_all_data(data)
|
||||
|
||||
print(f"Code débiteur => {data.data['id']}: {data.Debtor['code']}")
|
||||
if data.Debtor["code"] is None or '.' in str(data.Debtor["code"]):
|
||||
print("ERROR code débiteur")
|
||||
messagebox.showerror(title="Erreur code débiteur erroné", message=f"Le code débiteur de la facture {data.data['id']} est faux: [{data.Debtor['code']}], merci de le corriger ")
|
||||
if data.Debtor["code"] is None:
|
||||
data.Debtor["code"] = 1
|
||||
else:
|
||||
data.Debtor["code"] = str(data.Debtor["code"]).replace('.', '')
|
||||
print("ERROR code débiteur #1")
|
||||
messagebox.showerror(title="Erreur code débiteur", message=f"Le code débiteur de la facture {data.data['id']} est faux: [{data.Debtor['code']}], merci de le corriger ")
|
||||
inp_popup = Input_popup(self.fenetre, default=data.Debtor["code"], factureID=data.data['id'], fip=data.Patient['fip_number'])
|
||||
data.Debtor["code"] = int(inp_popup.show())
|
||||
|
||||
if data.Debtor["code"] == 1:
|
||||
if not self.check_code_validity(data.Debtor["code"],data):
|
||||
return False
|
||||
|
||||
|
||||
if int(data.Debtor["code"]) != "1" and data.Debtor["code"] != None and int(data.Debtor["code"]) < 100:
|
||||
if data.Patient["fip_number"] not in self.a_listings["to_check"]:
|
||||
@@ -429,6 +464,11 @@ class ClercAttrib2Biz():
|
||||
self.bs_counter += 1
|
||||
csv_col = cls_Col(True)
|
||||
|
||||
print(article)
|
||||
if "code" in article.keys() and article["code"] == "HRF":
|
||||
break
|
||||
|
||||
|
||||
##Donnée globales
|
||||
csv_col.data[0] = data.data["id"] # N° document
|
||||
csv_col.data[1] = 20 # Type of document 20 = facture débiteur
|
||||
@@ -496,7 +536,7 @@ class ClercAttrib2Biz():
|
||||
concat_str += con + data.Debtor["name"]
|
||||
con = "#chr(13)##chr(10)#"
|
||||
else:
|
||||
messagebox.showerror(title="Erreur nom débiteur erroné", message=f"Le nom débiteur de la facture {data.data['id']} est faux: [{data.Debtor['name']}], merci de le corriger ")
|
||||
messagebox.showerror(title="Erreur nom débiteur", message=f"Le nom débiteur de la facture {data.data['id']} est faux: [{data.Debtor['name']}], merci de le corriger ")
|
||||
|
||||
|
||||
if data.Debtor["gender"] is not None:
|
||||
@@ -657,8 +697,9 @@ class ClercAttrib2Biz():
|
||||
print(f"Code débiteur => {data.data['id']}: {data.Debtor['code']}" )
|
||||
if data.Debtor["code"] == "None" or '.' in str(data.Debtor["code"]):
|
||||
print("ERROR code débiteur")
|
||||
messagebox.showerror(title="Erreur code débiteur erroné", message=f"Le code débiteur de la facture {data.data['id']} est faux: [{data.Debtor['code']}], merci de le corriger ")
|
||||
data.Debtor["code"] = str(data.Debtor["code"]).replace('.', '')
|
||||
messagebox.showerror(title="Erreur code débiteur", message=f"Le code débiteur de la facture {data.data['id']} est faux: [{data.Debtor['code']}], merci de le corriger ")
|
||||
inp_popup = Input_popup(self.fenetre,default=data.Debtor["code"],factureID=data.data['id'], fip=data.Patient['fip_number'])
|
||||
data.Debtor["code"] = str(inp_popup.show())
|
||||
|
||||
|
||||
if data.Debtor["code"] != "1" and data.Debtor["code"] != None and int(data.Debtor["code"]) < 100:
|
||||
|
||||
@@ -1 +1 @@
|
||||
VERSION = "20220614-1653"
|
||||
VERSION = "20220615-1544"
|
||||
Reference in New Issue
Block a user