Spaces:
Build error
Build error
Fixed merge conflict, filtering for projects with geometries
Browse files- app.py +45 -13
- utils/js.py +8 -0
app.py
CHANGED
|
@@ -14,6 +14,9 @@ import json
|
|
| 14 |
import geojson
|
| 15 |
from google.oauth2 import service_account
|
| 16 |
|
|
|
|
|
|
|
|
|
|
| 17 |
# Logging
|
| 18 |
logging.basicConfig(format="%(levelname)s:%(message)s", level=logging.INFO)
|
| 19 |
|
|
@@ -239,7 +242,7 @@ def create_dataframe(years, project_name):
|
|
| 239 |
dfs.append(df)
|
| 240 |
return pd.concat(dfs)
|
| 241 |
|
| 242 |
-
def
|
| 243 |
prepared_statement = \
|
| 244 |
con.execute("SELECT geometry FROM project WHERE name = ? LIMIT 1",
|
| 245 |
[project_name]).fetchall()
|
|
@@ -307,9 +310,9 @@ def calculate_biodiversity_score(start_year, end_year, project_name):
|
|
| 307 |
[start_year, end_year, project_name]).df()
|
| 308 |
return scores
|
| 309 |
|
| 310 |
-
def
|
| 311 |
-
|
| 312 |
-
|
| 313 |
|
| 314 |
|
| 315 |
with gr.Blocks() as demo:
|
|
@@ -319,21 +322,50 @@ with gr.Blocks() as demo:
|
|
| 319 |
with gr.Column():
|
| 320 |
m1 = gr.Plot()
|
| 321 |
with gr.Row():
|
|
|
|
| 322 |
start_year = gr.Number(value=2017, label="Start Year", precision=0)
|
| 323 |
end_year = gr.Number(value=2022, label="End Year", precision=0)
|
| 324 |
-
project_name = gr.Textbox(label='Project Name')
|
| 325 |
-
|
| 326 |
with gr.Row():
|
|
|
|
| 327 |
calc_btn = gr.Button(value="Calculate!")
|
| 328 |
-
|
| 329 |
-
save_btn = gr.Button(value="Save")
|
| 330 |
results_df = gr.Dataframe(
|
| 331 |
headers=["Year", "Project Name", "Score"],
|
| 332 |
datatype=["number", "str", "number"],
|
| 333 |
label="Biodiversity scores by year",
|
| 334 |
)
|
| 335 |
-
|
| 336 |
-
|
| 337 |
-
|
| 338 |
-
|
| 339 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 14 |
import geojson
|
| 15 |
from google.oauth2 import service_account
|
| 16 |
|
| 17 |
+
|
| 18 |
+
from utils.js import get_window_url_params
|
| 19 |
+
|
| 20 |
# Logging
|
| 21 |
logging.basicConfig(format="%(levelname)s:%(message)s", level=logging.INFO)
|
| 22 |
|
|
|
|
| 242 |
dfs.append(df)
|
| 243 |
return pd.concat(dfs)
|
| 244 |
|
| 245 |
+
def show_project_map(project_name):
|
| 246 |
prepared_statement = \
|
| 247 |
con.execute("SELECT geometry FROM project WHERE name = ? LIMIT 1",
|
| 248 |
[project_name]).fetchall()
|
|
|
|
| 310 |
[start_year, end_year, project_name]).df()
|
| 311 |
return scores
|
| 312 |
|
| 313 |
+
def motherduck_list_projects(author_id):
|
| 314 |
+
return \
|
| 315 |
+
con.execute("SELECT DISTINCT name FROM project WHERE authorId = ? AND geometry != 'null'", [author_id]).df()
|
| 316 |
|
| 317 |
|
| 318 |
with gr.Blocks() as demo:
|
|
|
|
| 322 |
with gr.Column():
|
| 323 |
m1 = gr.Plot()
|
| 324 |
with gr.Row():
|
| 325 |
+
project_name = gr.Dropdown([], label="Project", value="Select project")
|
| 326 |
start_year = gr.Number(value=2017, label="Start Year", precision=0)
|
| 327 |
end_year = gr.Number(value=2022, label="End Year", precision=0)
|
|
|
|
|
|
|
| 328 |
with gr.Row():
|
| 329 |
+
view_btn = gr.Button(value="Show project map")
|
| 330 |
calc_btn = gr.Button(value="Calculate!")
|
| 331 |
+
# save_btn = gr.Button(value="Save")
|
|
|
|
| 332 |
results_df = gr.Dataframe(
|
| 333 |
headers=["Year", "Project Name", "Score"],
|
| 334 |
datatype=["number", "str", "number"],
|
| 335 |
label="Biodiversity scores by year",
|
| 336 |
)
|
| 337 |
+
calc_btn.click(
|
| 338 |
+
calculate_biodiversity_score,
|
| 339 |
+
inputs=[start_year, end_year, project_name],
|
| 340 |
+
outputs=results_df,
|
| 341 |
+
)
|
| 342 |
+
view_btn.click(
|
| 343 |
+
fn=show_project_map,
|
| 344 |
+
inputs=[project_name],
|
| 345 |
+
outputs=[m1],
|
| 346 |
+
)
|
| 347 |
+
|
| 348 |
+
def update_project_dropdown_list(url_params):
|
| 349 |
+
username = url_params.get("username", "default")
|
| 350 |
+
projects = motherduck_list_projects(author_id=username)
|
| 351 |
+
# to-do: filter projects based on user
|
| 352 |
+
return gr.Dropdown.update(choices=projects["name"].tolist())
|
| 353 |
+
|
| 354 |
+
# Get url params
|
| 355 |
+
url_params = gr.JSON({"username": "default"}, visible=False, label="URL Params")
|
| 356 |
+
|
| 357 |
+
# Gradio has a bug
|
| 358 |
+
# For dropdown to update by demo.load, dropdown value must be called downstream
|
| 359 |
+
b1 = gr.Button("Hidden button that fixes bug.", visible=False)
|
| 360 |
+
b1.click(lambda x: x, inputs=project_name, outputs=[])
|
| 361 |
+
|
| 362 |
+
# Update project dropdown list on page load
|
| 363 |
+
demo.load(
|
| 364 |
+
fn=update_project_dropdown_list,
|
| 365 |
+
inputs=[url_params],
|
| 366 |
+
outputs=[project_name],
|
| 367 |
+
_js=get_window_url_params,
|
| 368 |
+
queue=False,
|
| 369 |
+
)
|
| 370 |
+
|
| 371 |
+
demo.launch()
|
utils/js.py
ADDED
|
@@ -0,0 +1,8 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
get_window_url_params = """
|
| 2 |
+
function() {
|
| 3 |
+
const params = new URLSearchParams(window.location.search);
|
| 4 |
+
const url_params = Object.fromEntries(params);
|
| 5 |
+
console.log('url_params', url_params)
|
| 6 |
+
return url_params;
|
| 7 |
+
}
|
| 8 |
+
"""
|