diff options
author | Vidhu Kant Sharma <vidhukant@vidhukant.com> | 2023-08-30 13:18:41 +0530 |
---|---|---|
committer | Vidhu Kant Sharma <vidhukant@vidhukant.com> | 2023-08-30 13:18:41 +0530 |
commit | a68c5a2e52a62600d3baf579afa484f85d51efb9 (patch) | |
tree | 404a7c743bc9c39f2effdd3a9b231bf053a3283c | |
parent | cb86b7f9e4dcd1c1331025d70b272e4de33f164a (diff) |
added clients list
-rw-r--r-- | css/manage/_client.scss | 36 | ||||
-rw-r--r-- | css/styles.scss | 2 | ||||
-rw-r--r-- | src/app/manage/client/list/address.rs | 35 | ||||
-rw-r--r-- | src/app/manage/client/list/list_item.rs | 49 | ||||
-rw-r--r-- | src/app/manage/client/list/mod.rs | 44 | ||||
-rw-r--r-- | src/app/manage/client/mod.rs | 77 | ||||
-rw-r--r-- | src/app/manage/mod.rs | 2 | ||||
-rw-r--r-- | src/app/mod.rs | 2 | ||||
-rw-r--r-- | src/main.rs | 2 | ||||
-rw-r--r-- | src/models/client.rs | 83 | ||||
-rw-r--r-- | src/models/mod.rs | 18 |
11 files changed, 349 insertions, 1 deletions
diff --git a/css/manage/_client.scss b/css/manage/_client.scss new file mode 100644 index 0000000..7908333 --- /dev/null +++ b/css/manage/_client.scss @@ -0,0 +1,36 @@ +#manage-client-page { + //$h: calc(var(--nav-height) + calc(var(--main-padding) * 2)); + //height: calc(100vh - $h); + width: 100%; + + .clients-list-wrapper { + .clients-list { + .clients-list-item { + border-bottom: 1px solid var(--link-fg); + display: flex; + flex-direction: column; + + .header { + display: flex; + align-items: center; + gap: 0.5em; + font-size: 1.4em; + + .client-name { + font-weight: bold; + } + + .client-gstin { + font-size: 0.8em; + color: var(--body-fg-alt); + } + } + + .details { + width: 90%; + display: grid; + } + } + } + } +} diff --git a/css/styles.scss b/css/styles.scss index 900d4a5..b2f09ba 100644 --- a/css/styles.scss +++ b/css/styles.scss @@ -4,10 +4,12 @@ @import "navbar"; @import "menu_page"; +@import "manage/client"; :root { --body-bg: #282a36; --body-fg: #f8f8f8; + --body-fg-alt: lightgray; --nav-bg: #383a59; --nav-fg: #f8f8f8; diff --git a/src/app/manage/client/list/address.rs b/src/app/manage/client/list/address.rs new file mode 100644 index 0000000..c57ac89 --- /dev/null +++ b/src/app/manage/client/list/address.rs @@ -0,0 +1,35 @@ +/* openbills-web - Web client for Libre Billing Software + * Copyright (C) 2023 Vidhu Kant Sharma <vidhukant@vidhukant.com> + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see <https://www.gnu.org/licenses/>. + */ + +use yew::prelude::*; + +use crate::models::client; + +#[derive(Properties, PartialEq)] +pub struct Props { + pub address: client::Address, +} + +#[function_component(Address)] +pub fn address(props: &Props) -> Html { + + html! { + <div class={"client-address"}> + {props.address.address_text.clone()} + </div> + } +} diff --git a/src/app/manage/client/list/list_item.rs b/src/app/manage/client/list/list_item.rs new file mode 100644 index 0000000..b2d9ca9 --- /dev/null +++ b/src/app/manage/client/list/list_item.rs @@ -0,0 +1,49 @@ +/* openbills-web - Web client for Libre Billing Software + * Copyright (C) 2023 Vidhu Kant Sharma <vidhukant@vidhukant.com> + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see <https://www.gnu.org/licenses/>. + */ + +use yew::prelude::*; + +use crate::app::manage::client::list::address; + +use crate::models::client; + +#[derive(Properties, PartialEq)] +pub struct Props { + pub client: client::Client, +} + +#[function_component(ListItem)] +pub fn list_item(props: &Props) -> Html { + html! { + <div class={"clients-list-item"}> + <div class={"header"}> + <span class={"client-name"}>{props.client.name.clone()}</span> + <span class={"client-gstin"}>{props.client.gstin.clone()}</span> + </div> + + <div class={"details"}> + <div class={"general-info"}> + </div> + + <address::Address address={props.client.billing_address.clone()} /> + + <div class={"shipping-addresses-wrapper"}> + </div> + </div> + </div> + } +} diff --git a/src/app/manage/client/list/mod.rs b/src/app/manage/client/list/mod.rs new file mode 100644 index 0000000..2e13be6 --- /dev/null +++ b/src/app/manage/client/list/mod.rs @@ -0,0 +1,44 @@ +/* openbills-web - Web client for Libre Billing Software + * Copyright (C) 2023 Vidhu Kant Sharma <vidhukant@vidhukant.com> + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see <https://www.gnu.org/licenses/>. + */ + +mod list_item; +mod address; + +use yew::prelude::*; + +use crate::models::client; + +#[derive(Properties, PartialEq)] +pub struct Props { + pub clients: Vec<client::Client>, +} + +#[function_component(ClientsList)] +pub fn clients_list(props: &Props) -> Html { + let list_items: Html = props.clients + .iter() + .map(|c| html!(<list_item::ListItem key={c.id} client={c.clone()} />)) + .collect(); + + html! { + <div class={"clients-list-wrapper"}> + <div class={"clients-list"}> + {list_items} + </div> + </div> + } +} diff --git a/src/app/manage/client/mod.rs b/src/app/manage/client/mod.rs new file mode 100644 index 0000000..de4ac4b --- /dev/null +++ b/src/app/manage/client/mod.rs @@ -0,0 +1,77 @@ +/* openbills-web - Web client for Libre Billing Software + * Copyright (C) 2023 Vidhu Kant Sharma <vidhukant@vidhukant.com> + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see <https://www.gnu.org/licenses/>. + */ + +mod list; + +use yew::prelude::*; + +use crate::models::client; + +#[function_component(ManageClientPage)] +pub fn manage_client_page() -> Html { + let mut clients = Vec::new(); + + let mut c1: client::Client = client::Client::new(); + c1.id = 1; + c1.name = "MikunoNaka".to_string(); + c1.gstin = "AKSK821KASJ123LJF".to_string(); + c1.contact.contact_name = "Vidhu Kant".to_string(); + c1.contact.phone_number = "123810210293".to_string(); + c1.contact.email_address = "zt@vidhukant.com".to_string(); + c1.contact.website = "vidhukant.com".to_string(); + c1.billing_address.address_text = "Address".to_string(); + c1.billing_address.city = "City".to_string(); + c1.billing_address.state = "State".to_string(); + c1.billing_address.postal_code = "121212".to_string(); + c1.billing_address.country = "India".to_string(); + let mut c1s1 = client::Address::new(); + c1s1.address_text = "Shipping Address".to_string(); + c1s1.city = "City".to_string(); + c1s1.state = "State".to_string(); + c1s1.postal_code = "121212".to_string(); + c1s1.country = "India".to_string(); + c1.add_shipping_address(c1s1); + clients.push(c1); + + let mut c2: client::Client = client::Client::new(); + c2.id = 1; + c2.name = "Google Inc.".to_string(); + c2.gstin = "AKSK821KA12SJ123LJF".to_string(); + c2.contact.contact_name = "Google".to_string(); + c2.contact.phone_number = "490183212".to_string(); + c2.contact.email_address = "google@google.com".to_string(); + c2.contact.website = "google.com".to_string(); + c2.billing_address.address_text = "Address".to_string(); + c2.billing_address.city = "City".to_string(); + c2.billing_address.state = "State".to_string(); + c2.billing_address.postal_code = "121212".to_string(); + c2.billing_address.country = "India".to_string(); + let mut c2s1 = client::Address::new(); + c2s1.address_text = "Address".to_string(); + c2s1.city = "City".to_string(); + c2s1.state = "State".to_string(); + c2s1.postal_code = "121212".to_string(); + c2s1.country = "India".to_string(); + c2.add_shipping_address(c2s1); + clients.push(c2); + + html! { + <div id={"manage-client-page"}> + <list::ClientsList clients={clients}/> + </div> + } +} diff --git a/src/app/manage/mod.rs b/src/app/manage/mod.rs index bdca731..ccaddc6 100644 --- a/src/app/manage/mod.rs +++ b/src/app/manage/mod.rs @@ -15,6 +15,8 @@ * along with this program. If not, see <https://www.gnu.org/licenses/>. */ +pub mod client; + use yew::prelude::*; use yew_icons::IconId; diff --git a/src/app/mod.rs b/src/app/mod.rs index 1f37a9f..68c4d0c 100644 --- a/src/app/mod.rs +++ b/src/app/mod.rs @@ -61,7 +61,7 @@ pub fn switch(routes: Route) -> Html { Route::Home => html! {<home::HomePage />}, Route::ManageMenu => html! {<manage::ManageMenuPage />}, - Route::ManageClients => html! {<h1>{ "Edit Clients (To Be Added)" }</h1>}, + Route::ManageClients => html! {<manage::client::ManageClientPage />}, Route::ManageBrands => html! {<h1>{ "Edit Brands (To Be Added)" }</h1>}, Route::ManageItems => html! {<h1>{ "Edit Items (To Be Added)" }</h1>}, Route::ManageInvoices => html! {<h1>{ "Edit Invoices (To Be Added)" }</h1>}, diff --git a/src/main.rs b/src/main.rs index a95dffc..f6560ed 100644 --- a/src/main.rs +++ b/src/main.rs @@ -18,6 +18,8 @@ mod app; mod components; +mod models; + use app::App; fn main() { diff --git a/src/models/client.rs b/src/models/client.rs new file mode 100644 index 0000000..a76af70 --- /dev/null +++ b/src/models/client.rs @@ -0,0 +1,83 @@ +/* openbills-web - Web client for Libre Billing Software + * Copyright (C) 2023 Vidhu Kant Sharma <vidhukant@vidhukant.com> + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see <https://www.gnu.org/licenses/>. + */ + +#[derive(Clone, PartialEq)] +pub struct Address { + pub address_text: String, + pub city: String, + pub state: String, + pub postal_code: String, + pub country: String, +} + +impl Address { + pub fn new() -> Address { + Address { + address_text: String::new(), + city: String::new(), + state: String::new(), + postal_code: String::new(), + country: String::new(), + } + } +} + +#[derive(Clone, PartialEq)] +pub struct Contact { + pub contact_name: String, + pub phone_number: String, + pub email_address: String, + pub website: String, +} + +impl Contact { + pub fn new() -> Contact { + Contact { + contact_name: String::new(), + phone_number: String::new(), + email_address: String::new(), + website: String::new(), + } + } +} + +#[derive(Clone, PartialEq)] +pub struct Client { + pub id: u64, + pub name: String, + pub contact: Contact, + pub gstin: String, + pub billing_address: Address, + pub shipping_addresses: Vec<Address>, +} + +impl Client { + pub fn new() -> Client { + Client { + id: 0, + name: String::new(), + contact: Contact::new(), + gstin: String::new(), + billing_address: Address::new(), + shipping_addresses: Vec::new(), + } + } + + pub fn add_shipping_address(&mut self, address: Address) { + self.shipping_addresses.push(address); + } +} diff --git a/src/models/mod.rs b/src/models/mod.rs new file mode 100644 index 0000000..514c03d --- /dev/null +++ b/src/models/mod.rs @@ -0,0 +1,18 @@ +/* openbills-web - Web client for Libre Billing Software + * Copyright (C) 2023 Vidhu Kant Sharma <vidhukant@vidhukant.com> + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see <https://www.gnu.org/licenses/>. + */ + +pub mod client; |