Spaces:
Sleeping
Sleeping
Update app.py
Browse files
app.py
CHANGED
@@ -1,44 +1,53 @@
|
|
1 |
-
import
|
2 |
-
import
|
3 |
-
|
4 |
-
|
5 |
-
|
6 |
-
|
7 |
-
|
8 |
-
|
9 |
-
|
10 |
-
|
11 |
-
|
12 |
-
|
13 |
-
|
14 |
-
|
15 |
-
|
16 |
-
|
17 |
-
|
18 |
-
|
19 |
-
|
20 |
-
|
21 |
-
|
22 |
-
|
23 |
-
|
24 |
-
|
25 |
-
|
26 |
-
|
27 |
-
|
28 |
-
|
29 |
-
|
30 |
-
|
31 |
-
|
32 |
-
|
33 |
-
|
34 |
-
|
35 |
-
|
36 |
-
|
37 |
-
|
38 |
-
|
39 |
-
|
40 |
-
|
41 |
-
|
42 |
-
|
43 |
-
|
44 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import streamlit as st
|
2 |
+
import pandas as pd
|
3 |
+
import numpy as np
|
4 |
+
import datetime
|
5 |
+
from simple_salesforce import Salesforce
|
6 |
+
from modules.simulator import simulate_data
|
7 |
+
from modules.filters import apply_filters
|
8 |
+
from modules.visuals import display_dashboard, display_charts
|
9 |
+
|
10 |
+
# Salesforce Authentication (replace with your Salesforce login credentials)
|
11 |
+
sf = Salesforce(username='[email protected]', password='Vedavathi@04', security_token='jqe4His8AcuFJucZz5NBHfGU')
|
12 |
+
|
13 |
+
st.set_page_config(page_title="Vedavathi Smart Pole Monitoring", layout="wide")
|
14 |
+
|
15 |
+
st.title("π‘ Vedavathi Smart Pole Monitoring - PoC Simulator")
|
16 |
+
|
17 |
+
# Sidebar for Simulation Controls
|
18 |
+
st.sidebar.header("π οΈ Simulation Controls")
|
19 |
+
num_poles = st.sidebar.slider("Number of Poles", min_value=5, max_value=50, value=10)
|
20 |
+
simulate_faults = st.sidebar.checkbox("Simulate Random Faults", value=True)
|
21 |
+
|
22 |
+
# Simulate Data for Poles
|
23 |
+
df = simulate_data(num_poles, simulate_faults)
|
24 |
+
|
25 |
+
# Sidebar for Filter Data
|
26 |
+
st.sidebar.header("π Filter Data")
|
27 |
+
alert_filter = st.sidebar.multiselect("Alert Level", ["Green", "Yellow", "Red"], default=["Green", "Yellow", "Red"])
|
28 |
+
cam_filter = st.sidebar.selectbox("Camera Status", ["All", "Online", "Offline"], index=0)
|
29 |
+
|
30 |
+
# Apply Filters
|
31 |
+
filtered_df = apply_filters(df, alert_filter, cam_filter)
|
32 |
+
|
33 |
+
# Display System Summary
|
34 |
+
display_dashboard(df)
|
35 |
+
|
36 |
+
# Pole Monitoring Table
|
37 |
+
st.subheader("π Pole Monitoring Table")
|
38 |
+
st.dataframe(filtered_df, use_container_width=True)
|
39 |
+
|
40 |
+
# Display Charts
|
41 |
+
display_charts(df)
|
42 |
+
|
43 |
+
# Salesforce Integration (e.g., fetch records from Salesforce)
|
44 |
+
def fetch_salesforce_data():
|
45 |
+
# Example: Querying Salesforce for related data
|
46 |
+
query = "SELECT Id, Name, Alert_Level__c, Camera_Status__c FROM Pole__c"
|
47 |
+
result = sf.query_all(query)
|
48 |
+
return result['records']
|
49 |
+
|
50 |
+
# Fetch Salesforce data
|
51 |
+
sf_data = fetch_salesforce_data()
|
52 |
+
st.write("Salesforce Data:", sf_data)
|
53 |
+
|