Compare commits

...

3 commits

3 changed files with 39 additions and 17 deletions

View file

@ -84,8 +84,19 @@ pub fn ItemsList(
// Signal to store the fetched property labels // Signal to store the fetched property labels
let (property_labels, set_property_labels) = create_signal(HashMap::<String, String>::new()); let (property_labels, set_property_labels) = create_signal(HashMap::<String, String>::new());
#[cfg(feature = "ssr")]
fn get_current_url() -> String { fn get_current_url() -> String {
window() use leptos::use_context;
use actix_web::HttpRequest;
use_context::<HttpRequest>()
.map(|req| req.uri().to_string())
.unwrap_or_default()
}
#[cfg(not(feature = "ssr"))]
fn get_current_url() -> String {
web_sys::window()
.and_then(|win| win.location().href().ok()) .and_then(|win| win.location().href().ok())
.unwrap_or_else(|| "".to_string()) .unwrap_or_else(|| "".to_string())
} }

View file

@ -36,17 +36,22 @@ mod db_impl {
name TEXT NOT NULL UNIQUE, name TEXT NOT NULL UNIQUE,
global_usage_count INTEGER DEFAULT 0 global_usage_count INTEGER DEFAULT 0
);" );"
)?; ).map_err(|e| {
eprintln!("Failed creating properties table: {}", e);
e
})?;
// 2. URLs table // 2. URLs table
conn.execute_batch( conn.execute_batch(
"CREATE TABLE IF NOT EXISTS urls ( "CREATE TABLE IF NOT EXISTS urls (
id INTEGER PRIMARY KEY, id INTEGER PRIMARY KEY,
url TEXT NOT NULL UNIQUE, // Enforce unique URLs url TEXT NOT NULL UNIQUE,
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);", );",
)?; ).map_err(|e| {
logging::log!("URLs table created or verified"); eprintln!("Failed creating urls table: {}", e);
e
})?;
// 3. Items table // 3. Items table
conn.execute_batch( conn.execute_batch(
@ -58,8 +63,10 @@ mod db_impl {
wikidata_id TEXT, wikidata_id TEXT,
FOREIGN KEY (url_id) REFERENCES urls(id) ON DELETE CASCADE FOREIGN KEY (url_id) REFERENCES urls(id) ON DELETE CASCADE
);", );",
)?; ).map_err(|e| {
logging::log!("Items table updated with foreign key to URLs table"); eprintln!("Failed creating items table: {}", e);
e
})?;
// 4. Junction table for custom properties // 4. Junction table for custom properties
conn.execute_batch( conn.execute_batch(
@ -71,7 +78,10 @@ mod db_impl {
FOREIGN KEY (item_id) REFERENCES items(id) ON DELETE CASCADE, FOREIGN KEY (item_id) REFERENCES items(id) ON DELETE CASCADE,
FOREIGN KEY (property_id) REFERENCES properties(id) ON DELETE CASCADE FOREIGN KEY (property_id) REFERENCES properties(id) ON DELETE CASCADE
);" );"
)?; ).map_err(|e| {
eprintln!("Failed creating item_properties table: {}", e);
e
})?;
Ok(()) Ok(())
} }

View file

@ -18,15 +18,16 @@ async fn main() -> std::io::Result<()> {
use std::sync::Arc; use std::sync::Arc;
use tokio::sync::Mutex; use tokio::sync::Mutex;
// Initialize the database
let db = Database::new("compareware.db").unwrap();
db.create_schema().await.unwrap(); // Ensure the schema is created
let db = Arc::new(Mutex::new(db)); // Wrap the database in an Arc<Mutex<T>> for shared state
println!("Schema created successfully!");
// Load configuration // Load configuration
let conf = get_configuration(None).await.unwrap(); let conf = get_configuration(None).await.unwrap();
let addr = conf.leptos_options.site_addr; let addr = conf.leptos_options.site_addr;
// Initialize the database
let db = Database::new("compareware.db").unwrap();
db.create_schema().await.unwrap(); // Ensure the schema is created
let db = Arc::new(Mutex::new(db)); // Wrap the database in an Arc<Mutex<T>> for shared state
// Generate the list of routes in your Leptos App // Generate the list of routes in your Leptos App
let routes = generate_route_list(App); let routes = generate_route_list(App);