import streamlit as st import os import mysql.connector import math # Fungsi untuk mendapatkan gambar sebagai base64 def get_image_as_base64(image_path): import base64 with open(image_path, "rb") as img_file: return base64.b64encode(img_file.read()).decode("utf-8") # Fungsi untuk menampilkan navbar def navbar(): current_page = st.session_state.get("page", "Home") logo_path = os.path.join(os.path.dirname(__file__), "../asset/logo.png") # Cek status login if 'logged_in' in st.session_state and st.session_state['logged_in']: login_button_text = "Logout" login_button_link = "?page=Login&logout=true" # Tambahkan parameter logout else: login_button_text = "Logout" login_button_link = "?page=Login" st.markdown( f""" """, unsafe_allow_html=True, ) # Fungsi untuk koneksi ke database def connect_to_db(): try: conn = mysql.connector.connect( host=st.secrets["mysql"]["host"], user=st.secrets["mysql"]["user"], password=st.secrets["mysql"]["password"], database=st.secrets["mysql"]["dbname"], port=st.secrets["mysql"]["port"] ) return conn except mysql.connector.Error as e: st.error(f"Koneksi ke database gagal: {e}") return None # Fungsi untuk mencocokkan employee_id di database def check_employee_in_db(employee_id): conn = connect_to_db() if conn: try: cursor = conn.cursor(dictionary=True) query = "SELECT * FROM data_employee_db WHERE employee_id = %s" cursor.execute(query, (employee_id,)) result = cursor.fetchone() conn.close() return result # Mengembalikan data karyawan jika ditemukan except mysql.connector.Error as e: st.error(f"Terjadi kesalahan saat mengakses database: {e}") return None return None # Fungsi untuk menyimpan data dan menghitung skor akhir def save_employee_ratings(employee_id, responses): conn = connect_to_db() if conn: try: # Hitung skor akhir total_score = sum([responses[q] for q in range(len(responses))]) average_score = total_score / len(responses) final_score = min(max(round(average_score), 1), 4) # Batas 1-4 # Simpan ke tabel employee_ratings cursor = conn.cursor() query = """ INSERT INTO employee_ratings ( employee_id, question_1, question_2, question_3, question_4, question_5, question_6, question_7, question_8, skor_akhir ) VALUES (%s, %s, %s, %s, %s, %s, %s, %s, %s, %s) """ cursor.execute(query, (employee_id, *responses, final_score)) conn.commit() # Update performance_rating di data_employee_db update_query = """ UPDATE data_employee_db SET performance_rating = %s WHERE employee_id = %s """ cursor.execute(update_query, (final_score, employee_id)) conn.commit() conn.close() return final_score except mysql.connector.Error as e: st.error(f"Terjadi kesalahan saat menyimpan data: {e}") conn.close() return None # Fungsi utama untuk form kinerja rating karyawan def show_pimpinan_form(): navbar() st.markdown(""" """, unsafe_allow_html=True) st.markdown( """

Form Kinerja Rating Karyawan

""", unsafe_allow_html=True ) # Inisialisasi session state if "employee_id" not in st.session_state: st.session_state.employee_id = None # Awalnya kosong if "submit_success" not in st.session_state: st.session_state.submit_success = False # Awalnya False # Input Employee ID if not st.session_state.employee_id: # Jika belum ada ID yang tersimpan employee_id = st.text_input("Masukkan Employee ID Karyawan", placeholder="Contoh: 12345") # Tombol untuk mencocokkan employee_id if st.button("Isi Form"): if not employee_id: st.error("Harap masukkan Employee ID terlebih dahulu.") return # Cek apakah employee_id ada di database employee_data = check_employee_in_db(employee_id) if not employee_data: st.error("Employee ID tidak ditemukan di database.") return # Jika ditemukan, simpan Employee ID di session_state st.session_state.employee_id = employee_id # Jika Employee ID sudah disimpan if st.session_state.employee_id: st.success(f"Karyawan_ID ditemukan! Anda sedang mengisi untuk ID: {st.session_state.employee_id}") # Pertanyaan penilaian (2 kolom) st.markdown( """
Isi Form Kinerja Karyawan
""", unsafe_allow_html=True ) questions = [ "Bagaimana tingkat keandalan karyawan dalam menyelesaikan tugas tepat waktu?", "Seberapa efektif karyawan ini dalam bekerja secara mandiri atau dalam tim?", "Bagaimana penilaian Anda terhadap kemampuan karyawan untuk memecahkan masalah?", "Seberapa baik karyawan ini dalam mencapai target atau KPI yang telah ditentukan?", "Seberapa baik karyawan ini beradaptasi terhadap perubahan atau tantangan baru?", "Bagaimana penilaian Anda terhadap inisiatif yang diambil oleh karyawan ini dalam pekerjaannya?", "Seberapa efektif komunikasi karyawan ini, baik kepada rekan kerja maupun kepada pelanggan?", "Bagaimana Anda menilai sikap profesionalisme karyawan dalam menjalankan tugas sehari-hari?" ] options = {"Sangat Buruk": 1, "Cukup Baik": 2, "Baik": 3, "Sangat Baik": 4} # Buat dua kolom col1, col2 = st.columns(2) responses = [] for idx, question in enumerate(questions): if idx % 2 == 0: with col1: response = st.selectbox(question, list(options.keys()), key=f"q{idx}") responses.append(options[response]) else: with col2: response = st.selectbox(question, list(options.keys()), key=f"q{idx}") responses.append(options[response]) # Tombol Submit if st.button("Submit") and not st.session_state.submit_success: final_score = save_employee_ratings(st.session_state.employee_id, responses) if final_score is not None: st.session_state.submit_success = True # Tandai data berhasil disimpan st.success(f"Data berhasil disimpan! Skor Akhir: {final_score} untuk Karyawan_ID: {st.session_state.employee_id}") # Jika data berhasil disimpan, tampilkan tombol kembali if st.session_state.submit_success: if st.button("Kembali ke Form Awal"): # Reset Employee ID dan status submit st.session_state.employee_id = None st.session_state.submit_success = False st.rerun() # Footer st.markdown( """ """, unsafe_allow_html=True ) # Jalankan fungsi show_pimpinan_form if __name__ == "__main__": show_pimpinan_form()