2022-01-13 18:07:01 -05:00
|
|
|
// Copyright 2022 Jeremy Wall
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
2022-07-15 19:30:06 -04:00
|
|
|
use crate::pages::*;
|
2022-09-08 20:17:46 -04:00
|
|
|
use crate::{
|
|
|
|
app_state::*,
|
|
|
|
components::*,
|
|
|
|
router_integration::*,
|
|
|
|
service::{self, AppService},
|
|
|
|
};
|
2022-09-25 17:04:46 -04:00
|
|
|
use tracing::{error, info, instrument};
|
2022-01-24 19:59:16 -05:00
|
|
|
|
2022-09-25 17:04:46 -04:00
|
|
|
use sycamore::{futures::spawn_local_scoped, prelude::*};
|
2022-01-13 18:07:01 -05:00
|
|
|
|
2022-07-21 16:33:55 -04:00
|
|
|
#[instrument]
|
2022-09-25 17:04:46 -04:00
|
|
|
fn route_switch<G: Html>(cx: Scope, route: &ReadSignal<AppRoutes>) -> View<G> {
|
2022-07-15 19:30:06 -04:00
|
|
|
// NOTE(jwall): This needs to not be a dynamic node. The rules around
|
|
|
|
// this are somewhat unclear and underdocumented for Sycamore. But basically
|
|
|
|
// avoid conditionals in the `view!` macro calls here.
|
2022-09-25 17:04:46 -04:00
|
|
|
match route.get().as_ref() {
|
|
|
|
AppRoutes::Plan => view! {cx,
|
2022-07-15 19:30:06 -04:00
|
|
|
PlanPage()
|
|
|
|
},
|
2022-09-25 17:04:46 -04:00
|
|
|
AppRoutes::Inventory => view! {cx,
|
2022-07-15 19:30:06 -04:00
|
|
|
InventoryPage()
|
|
|
|
},
|
2022-09-25 17:04:46 -04:00
|
|
|
AppRoutes::Login => view! {cx,
|
2022-08-30 17:31:33 -04:00
|
|
|
LoginPage()
|
|
|
|
},
|
2022-09-25 17:04:46 -04:00
|
|
|
AppRoutes::Cook => view! {cx,
|
2022-07-15 19:30:06 -04:00
|
|
|
CookPage()
|
|
|
|
},
|
2022-09-25 17:04:46 -04:00
|
|
|
AppRoutes::Recipe(idx) => view! {cx,
|
|
|
|
RecipePage(recipe=idx.clone())
|
2022-07-15 19:30:06 -04:00
|
|
|
},
|
2022-09-25 17:04:46 -04:00
|
|
|
AppRoutes::Categories => view! {cx,
|
2022-09-19 17:19:29 -04:00
|
|
|
CategoryPage()
|
|
|
|
},
|
2022-09-25 17:04:46 -04:00
|
|
|
AppRoutes::NotFound => view! {cx,
|
2022-07-15 19:30:06 -04:00
|
|
|
// TODO(Create a real one)
|
|
|
|
PlanPage()
|
|
|
|
},
|
2022-09-25 17:04:46 -04:00
|
|
|
}
|
2022-08-12 21:41:19 -04:00
|
|
|
}
|
|
|
|
|
2022-07-18 18:50:11 -04:00
|
|
|
#[instrument]
|
2022-09-25 17:04:46 -04:00
|
|
|
#[component]
|
|
|
|
pub fn UI<G: Html>(cx: Scope) -> View<G> {
|
|
|
|
let app_service = AppService::new(service::HttpStore::new("/api/v1".to_owned()));
|
|
|
|
provide_context(cx, app_service.clone());
|
2022-07-18 18:50:11 -04:00
|
|
|
info!("Starting UI");
|
2022-07-15 19:30:06 -04:00
|
|
|
|
2022-09-25 17:04:46 -04:00
|
|
|
let view = create_signal(cx, View::empty());
|
|
|
|
// FIXME(jwall): We need a way to trigger refreshes when required. Turn this
|
|
|
|
// into a create_effect with a refresh signal stored as a context.
|
|
|
|
spawn_local_scoped(cx, {
|
|
|
|
let mut app_service = crate::service::get_appservice_from_context(cx).clone();
|
|
|
|
async move {
|
|
|
|
if let Err(err) = app_service.synchronize().await {
|
|
|
|
error!(?err);
|
|
|
|
};
|
|
|
|
view.set(view! { cx,
|
|
|
|
div(class="app") {
|
|
|
|
Header()
|
|
|
|
Router(RouterProps {
|
|
|
|
route: AppRoutes::Plan,
|
|
|
|
route_select: route_switch,
|
|
|
|
browser_integration: BrowserIntegration::new(),
|
|
|
|
})
|
2022-01-26 20:40:21 -05:00
|
|
|
}
|
2022-09-25 17:04:46 -04:00
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
view! { cx, (view.get().as_ref()) }
|
2022-01-23 14:28:01 -05:00
|
|
|
}
|