Hadeeratef91 commited on
Commit
5c4a858
·
verified ·
1 Parent(s): e093d26

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +11 -53
app.py CHANGED
@@ -62,6 +62,7 @@ if not st.session_state.is_logged_in:
62
 
63
  # مقدم الشكوى
64
  elif st.session_state.user_type == "sender":
 
65
  complaint_text = st.text_area("📝 وصف الشكوى")
66
 
67
  if st.button("📤 إرسال الشكوى"):
@@ -82,7 +83,7 @@ elif st.session_state.user_type == "sender":
82
  (complaint_id, st.session_state.username, complaint_text.strip(), "Pending", "", timestamp))
83
  conn.commit()
84
  st.success("✅ تم تقديم الشكوى بنجاح")
85
- st.experimental_rerun()
86
 
87
  st.subheader("📋 الشكاوى السابقة")
88
  c.execute("SELECT * FROM complaints WHERE username=? ORDER BY id DESC", (st.session_state.username,))
@@ -102,12 +103,6 @@ elif st.session_state.user_type == "sender":
102
  if response and response.strip():
103
  st.success(f"💬 الرد: {response}")
104
 
105
- if st.button("🚪 تسجيل الخروج"):
106
- st.session_state.is_logged_in = False
107
- st.session_state.user_type = None
108
- st.session_state.username = ""
109
- st.rerun()
110
-
111
  # مستقبل الشكوى
112
  elif st.session_state.user_type == "receiver":
113
  st.title("📬 إدارة الشكاوى")
@@ -135,50 +130,16 @@ elif st.session_state.user_type == "receiver":
135
  st.success("✅ تم حفظ التعديلات")
136
  st.rerun()
137
 
138
- if st.button("🚪 تسجيل الخروج"):
139
- st.session_state.is_logged_in = False
140
- st.session_state.user_type = None
141
- st.session_state.username = ""
142
- st.rerun()
143
- if st.session_state.get("username") == "admin":
144
- st.subheader("📤 رفع ملف مستخدمين (Excel أو CSV)")
145
-
146
- uploaded_file = st.file_uploader("اختر الملف", type=["csv", "xlsx"])
147
-
148
- if uploaded_file is not None:
149
- try:
150
- if uploaded_file.name.endswith(".csv"):
151
- df = pd.read_csv(uploaded_file)
152
- else:
153
- df = pd.read_excel(uploaded_file)
154
-
155
- st.write("📋 المعاينة:")
156
- st.dataframe(df)
157
-
158
- if st.button("✅ رفع المستخدمين"):
159
- count_added = 0
160
- for _, row in df.iterrows():
161
- username = row["username"]
162
- password = row["password"]
163
- role = row["role"]
164
-
165
- # التحقق من عدم وجود المستخدم
166
- c.execute("SELECT * FROM users WHERE username=?", (username,))
167
- if c.fetchone():
168
- continue # تخطي المستخدم الموجود
169
- hashed_pw = bcrypt.hash(str(password))
170
- c.execute("INSERT INTO users (username, password, role) VALUES (?, ?, ?)",
171
- (username, hashed_pw, role))
172
- count_added += 1
173
-
174
- conn.commit()
175
- st.success(f"✅ تم إضافة {count_added} مستخدم جديد.")
176
-
177
- except Exception as e:
178
- st.error(f"❌ خطأ في قراءة الملف: {e}")
179
- import os
180
 
181
- # زر لتحميل ملف قاعدة البيانات - يظهر دائمًا
182
  if os.path.exists("complaints_system.db"):
183
  with open("complaints_system.db", "rb") as db_file:
184
  st.download_button(
@@ -189,6 +150,3 @@ if os.path.exists("complaints_system.db"):
189
  )
190
  else:
191
  st.warning("⚠️ ملف قاعدة البيانات غير موجود في هذا المسار.")
192
-
193
-
194
-
 
62
 
63
  # مقدم الشكوى
64
  elif st.session_state.user_type == "sender":
65
+ st.title("📨 إرسال شكوى جديدة")
66
  complaint_text = st.text_area("📝 وصف الشكوى")
67
 
68
  if st.button("📤 إرسال الشكوى"):
 
83
  (complaint_id, st.session_state.username, complaint_text.strip(), "Pending", "", timestamp))
84
  conn.commit()
85
  st.success("✅ تم تقديم الشكوى بنجاح")
86
+ st.rerun()
87
 
88
  st.subheader("📋 الشكاوى السابقة")
89
  c.execute("SELECT * FROM complaints WHERE username=? ORDER BY id DESC", (st.session_state.username,))
 
103
  if response and response.strip():
104
  st.success(f"💬 الرد: {response}")
105
 
 
 
 
 
 
 
106
  # مستقبل الشكوى
107
  elif st.session_state.user_type == "receiver":
108
  st.title("📬 إدارة الشكاوى")
 
130
  st.success("✅ تم حفظ التعديلات")
131
  st.rerun()
132
 
133
+ # زر تسجيل الخروج يظهر دائمًا لأي مستخدم مسجل
134
+ if st.session_state.get("is_logged_in"):
135
+ st.markdown("---")
136
+ if st.button("🚪 تسجيل الخروج"):
137
+ st.session_state.is_logged_in = False
138
+ st.session_state.user_type = None
139
+ st.session_state.username = ""
140
+ st.rerun()
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
141
 
142
+ # 📥 زر لتحميل قاعدة البيانات (لـ admin أو أي مستخدم)
143
  if os.path.exists("complaints_system.db"):
144
  with open("complaints_system.db", "rb") as db_file:
145
  st.download_button(
 
150
  )
151
  else:
152
  st.warning("⚠️ ملف قاعدة البيانات غير موجود في هذا المسار.")