Skip to content

Commit

Permalink
feat: add date and status filters to experiments listing
Browse files Browse the repository at this point in the history
  • Loading branch information
Datron committed Nov 20, 2024
1 parent 523a478 commit 5e4039e
Show file tree
Hide file tree
Showing 5 changed files with 440 additions and 36 deletions.
4 changes: 2 additions & 2 deletions crates/frontend/src/components/context_form.rs
Original file line number Diff line number Diff line change
Expand Up @@ -403,7 +403,7 @@ where
}
>

<i class="ri-delete-bin-2-line text-xl text-2xl font-bold"></i>
<i class="ri-delete-bin-2-line text-2xl font-bold"></i>
</button>
</Show>
</div>
Expand All @@ -413,7 +413,7 @@ where
{move || {
if last_idx.get() != idx {
view! {
<div class="my-3 ml-5 ml-6 ml-7">
<div class="my-3 ml-7">
<span class="font-mono text-xs">"&&"</span>
</div>
}
Expand Down
54 changes: 54 additions & 0 deletions crates/frontend/src/components/input.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
use std::time::Duration;

use chrono::{DateTime, Utc};
use leptos::*;
use serde_json::{json, Map, Value};

Expand All @@ -21,6 +22,7 @@ pub enum InputType {
Monaco,
Select(EnumVariants),
Disabled,
Date,
}

impl InputType {
Expand All @@ -33,6 +35,8 @@ impl InputType {
| InputType::Select(_) => "text",

InputType::Number | InputType::Integer => "number",

InputType::Date => "datetime-local",
}
}
}
Expand Down Expand Up @@ -415,6 +419,56 @@ pub fn monaco_input(
}
}

#[component]
pub fn date_input(
id: String,
class: String,
name: String,
on_change: Callback<DateTime<Utc>, ()>,
#[prop(into, default = Utc::now().format("%Y-%m-%d").to_string())] value: String,
#[prop(default = false)] disabled: bool,
#[prop(default = false)] required: bool,
#[prop(into, default = String::from("2020-01-01"))] min: String,
#[prop(into, default = Utc::now().format("%Y-%m-%d").to_string())] max: String,
) -> impl IntoView {
let (error_rs, error_ws) = create_signal::<String>(String::new());
view! {
<div class="flex flex-col gap-1">
<input
id=id
name=name
type="date"
class=format!("input input-bordered {}", class)
required=required
disabled=disabled
min=min
max=max
value=value
on:change=move |e| {
let date = format!("{}T00:00:00Z", event_target_value(&e));
logging::log!("The date selected is: {}", date);
match DateTime::parse_from_rfc3339(&date) {
Ok(v) => {
on_change.call(v.to_utc());
}
Err(e) => {
logging::log!("error occurred: {:?}", e);
error_ws.set(e.to_string());
},
}
}
/>
<Show when=move || !error_rs.get().is_empty() >
<span class="flex gap-2 px-4 text-xs font-semibold text-red-600">
<i class="ri-close-circle-line"></i>
{move || error_rs.get()}
</span>
</Show>

</div>
}
}

#[component]
pub fn input(
value: Value,
Expand Down
Loading

0 comments on commit 5e4039e

Please sign in to comment.