From de9ef20b1f398af5662722a15405d4292197fb1e Mon Sep 17 00:00:00 2001 From: prokawsar Date: Thu, 25 Jul 2024 13:11:12 +0600 Subject: [PATCH] Toaster added, sorted by date on history --- package.json | 1 + src/routes/(app)/+layout.svelte | 7 +++++++ src/routes/(app)/+page.svelte | 4 ++-- src/routes/(app)/history/+page.svelte | 16 +++++++++++++++- 4 files changed, 25 insertions(+), 3 deletions(-) diff --git a/package.json b/package.json index d618d49..05a852f 100644 --- a/package.json +++ b/package.json @@ -40,6 +40,7 @@ "dayjs": "^1.11.11", "mixpanel-browser": "^2.53.0", "svelte-persisted-store": "^0.11.0", + "svelte-sonner": "^0.3.27", "tippy.js": "^6.3.7" } } diff --git a/src/routes/(app)/+layout.svelte b/src/routes/(app)/+layout.svelte index eb9cce9..cabf983 100644 --- a/src/routes/(app)/+layout.svelte +++ b/src/routes/(app)/+layout.svelte @@ -8,6 +8,7 @@ import mixpanel from 'mixpanel-browser' import { slide } from 'svelte/transition' import { supabase } from '$lib/db/supabaseClient' + import { Toaster } from 'svelte-sonner' //Import Mixpanel SDK mixpanel.init(PUBLIC_MIX_TOKEN, { @@ -24,6 +25,12 @@
+ {#if $navigating}
{ - // const element = document.getElementById(idx) - // if (element) inputGroupRef.removeChild(element) paperCount = paperCount.filter((field) => field.id != idx) if (perPaperResult.has(idx)) perPaperResult.delete(idx) perPaperResult = perPaperResult @@ -86,6 +85,7 @@ papers: paperCount }) $totalHistoryStore = await getTotalHistory() + toast.success('Cost details saved successfully') } } diff --git a/src/routes/(app)/history/+page.svelte b/src/routes/(app)/history/+page.svelte index 9773555..daaca7f 100644 --- a/src/routes/(app)/history/+page.svelte +++ b/src/routes/(app)/history/+page.svelte @@ -5,6 +5,7 @@ import Icon from '@iconify/svelte' import days from 'dayjs' import mixpanel from 'mixpanel-browser' + import { toast } from 'svelte-sonner' export let data let isLoading = false @@ -19,6 +20,19 @@ await deleteHistory(id) await invalidateAll() isLoading = false + toast.message('History deleted successfully') + } + + const sortedByCreatedAt = (data: any) => { + return data.sort((a: any, b: any) => { + // Convert 'created_at' strings to Date objects + let dateA = new Date(a.created_at) + let dateB = new Date(b.created_at) + + if (dateA > dateB) return -1 + if (dateA < dateB) return 1 + return 0 + }) } @@ -38,7 +52,7 @@
{#if !isLoading} {#if data.histories.length} - {#each data.histories as { name, id, final_price, created_at }} + {#each sortedByCreatedAt(data.histories) as { name, id, final_price, created_at }}