aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVidhu Kant Sharma <vidhukant@vidhukant.com>2023-08-30 13:18:41 +0530
committerVidhu Kant Sharma <vidhukant@vidhukant.com>2023-08-30 13:18:41 +0530
commita68c5a2e52a62600d3baf579afa484f85d51efb9 (patch)
tree404a7c743bc9c39f2effdd3a9b231bf053a3283c
parentcb86b7f9e4dcd1c1331025d70b272e4de33f164a (diff)
added clients list
-rw-r--r--css/manage/_client.scss36
-rw-r--r--css/styles.scss2
-rw-r--r--src/app/manage/client/list/address.rs35
-rw-r--r--src/app/manage/client/list/list_item.rs49
-rw-r--r--src/app/manage/client/list/mod.rs44
-rw-r--r--src/app/manage/client/mod.rs77
-rw-r--r--src/app/manage/mod.rs2
-rw-r--r--src/app/mod.rs2
-rw-r--r--src/main.rs2
-rw-r--r--src/models/client.rs83
-rw-r--r--src/models/mod.rs18
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;