Spaces:
Sleeping
Sleeping
Update app.py
Browse files
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.
|
| 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 |
-
|
| 139 |
-
|
| 140 |
-
|
| 141 |
-
|
| 142 |
-
|
| 143 |
-
|
| 144 |
-
|
| 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("⚠️ ملف قاعدة البيانات غير موجود في هذا المسار.")
|
|
|
|
|
|
|
|
|