mirror of
https://github.com/aljazceru/btcpayserver.git
synced 2025-12-18 06:24:24 +01:00
* Update WalletTransactions pagination default settings Remove the numeric page selection and add displaying data of last 30 days by default. * Update WalletTransactions to show txs based on Days * Update text formatting on WalletTransactions view Keeps the logic changes. Just undo the formatting of the file from previous commit * Update WalletTransactions to show all after second load Utilize Model.Days instead of new variables Moved javascript code to PageFootContent section * Update WalletTransactions to use ajax for infinite scroll * Cleanups * Apply skip and count only when not prefiltering * Infinite scroll mode * Improve datetime formatting and switching * Upgrade NBXplorer to include get_wallets_recent bugfix * Revert "Upgrade NBXplorer to include get_wallets_recent bugfix" This reverts commit b390d942d74d88bb1da3ab8e3407184a527175ef. * JS fixes * Upgrade ChromeDriver and BundleMinifier Co-authored-by: Dennis Reimann <mail@dennisreimann.de>
130 lines
5.7 KiB
C#
130 lines
5.7 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Globalization;
|
|
using System.Linq;
|
|
using Microsoft.AspNetCore.Html;
|
|
using Microsoft.AspNetCore.Mvc.ViewFeatures;
|
|
|
|
namespace BTCPayServer.Abstractions.Extensions
|
|
{
|
|
public static class ViewsRazor
|
|
{
|
|
private const string ACTIVE_CATEGORY_KEY = "ActiveCategory";
|
|
private const string ACTIVE_PAGE_KEY = "ActivePage";
|
|
private const string ACTIVE_ID_KEY = "ActiveId";
|
|
private const string ActivePageClass = "active";
|
|
|
|
public static void SetActivePage<T>(this ViewDataDictionary viewData, T activePage, string title = null, string activeId = null)
|
|
where T : IConvertible
|
|
{
|
|
SetActivePage(viewData, activePage.ToString(), activePage.GetType().ToString(), title, activeId);
|
|
}
|
|
|
|
public static void SetActivePage(this ViewDataDictionary viewData, string activePage, string category, string title = null, string activeId = null)
|
|
{
|
|
// Page Title
|
|
viewData["Title"] = title ?? activePage;
|
|
// Navigation
|
|
viewData[ACTIVE_PAGE_KEY] = activePage;
|
|
viewData[ACTIVE_ID_KEY] = activeId;
|
|
SetActiveCategory(viewData, category);
|
|
}
|
|
|
|
public static void SetActiveCategory<T>(this ViewDataDictionary viewData, T activeCategory)
|
|
{
|
|
SetActiveCategory(viewData, activeCategory.ToString());
|
|
}
|
|
|
|
public static void SetActiveCategory(this ViewDataDictionary viewData, string activeCategory)
|
|
{
|
|
viewData[ACTIVE_CATEGORY_KEY] = activeCategory;
|
|
}
|
|
|
|
public static string IsActiveCategory<T>(this ViewDataDictionary viewData, T category, object id = null)
|
|
{
|
|
return IsActiveCategory(viewData, category.ToString(), id);
|
|
}
|
|
|
|
public static string IsActiveCategory(this ViewDataDictionary viewData, string category, object id = null)
|
|
{
|
|
if (!viewData.ContainsKey(ACTIVE_CATEGORY_KEY))
|
|
{
|
|
return null;
|
|
}
|
|
var activeId = viewData[ACTIVE_ID_KEY];
|
|
var activeCategory = viewData[ACTIVE_CATEGORY_KEY]?.ToString();
|
|
var categoryMatch = category.Equals(activeCategory, StringComparison.InvariantCultureIgnoreCase);
|
|
var idMatch = id == null || activeId == null || id.Equals(activeId);
|
|
return categoryMatch && idMatch ? ActivePageClass : null;
|
|
}
|
|
|
|
public static string IsActivePage<T>(this ViewDataDictionary viewData, T page, object id = null)
|
|
where T : IConvertible
|
|
{
|
|
return IsActivePage(viewData, page.ToString(), page.GetType().ToString(), id);
|
|
}
|
|
|
|
public static string IsActivePage<T>(this ViewDataDictionary viewData, IEnumerable<T> pages, object id = null)
|
|
where T : IConvertible
|
|
{
|
|
return pages.Any(page => IsActivePage(viewData, page.ToString(), page.GetType().ToString(), id) == ActivePageClass)
|
|
? ActivePageClass
|
|
: null;
|
|
}
|
|
|
|
public static string IsActivePage(this ViewDataDictionary viewData, string page, string category, object id = null)
|
|
{
|
|
if (!viewData.ContainsKey(ACTIVE_PAGE_KEY))
|
|
{
|
|
return null;
|
|
}
|
|
var activeId = viewData[ACTIVE_ID_KEY];
|
|
var activePage = viewData[ACTIVE_PAGE_KEY]?.ToString();
|
|
var activeCategory = viewData[ACTIVE_CATEGORY_KEY]?.ToString();
|
|
var categoryAndPageMatch = (category == null || activeCategory.Equals(category, StringComparison.InvariantCultureIgnoreCase)) && page.Equals(activePage, StringComparison.InvariantCultureIgnoreCase);
|
|
var idMatch = id == null || activeId == null || id.Equals(activeId);
|
|
return categoryAndPageMatch && idMatch ? ActivePageClass : null;
|
|
}
|
|
|
|
public static HtmlString ToBrowserDate(this DateTimeOffset date)
|
|
{
|
|
var displayDate = date.ToString("g", CultureInfo.InvariantCulture);
|
|
var dateTime = date.ToString("s", CultureInfo.InvariantCulture);
|
|
return new HtmlString($"<time datetime=\"{dateTime}\" data-relative=\"{date.ToTimeAgo()}\">{displayDate}</time>");
|
|
}
|
|
|
|
public static HtmlString ToBrowserDate(this DateTime date)
|
|
{
|
|
var displayDate = date.ToString("g", CultureInfo.InvariantCulture);
|
|
var dateTime = date.ToString("s", CultureInfo.InvariantCulture);
|
|
return new HtmlString($"<time datetime=\"{dateTime}\" data-relative=\"{date.ToTimeAgo()}\">{displayDate}</time>");
|
|
}
|
|
|
|
public static string ToTimeAgo(this DateTimeOffset date) => (DateTimeOffset.UtcNow - date).ToTimeAgo();
|
|
|
|
public static string ToTimeAgo(this DateTime date) => (DateTimeOffset.UtcNow - date).ToTimeAgo();
|
|
|
|
public static string ToTimeAgo(this TimeSpan diff) => diff.TotalSeconds > 0 ? $"{diff.TimeString()} ago" : $"in {diff.Negate().TimeString()}";
|
|
|
|
public static string TimeString(this TimeSpan timeSpan)
|
|
{
|
|
if (timeSpan.TotalMinutes < 1)
|
|
{
|
|
return $"{(int)timeSpan.TotalSeconds} second{Plural((int)timeSpan.TotalSeconds)}";
|
|
}
|
|
if (timeSpan.TotalHours < 1)
|
|
{
|
|
return $"{(int)timeSpan.TotalMinutes} minute{Plural((int)timeSpan.TotalMinutes)}";
|
|
}
|
|
return timeSpan.Days < 1
|
|
? $"{(int)timeSpan.TotalHours} hour{Plural((int)timeSpan.TotalHours)}"
|
|
: $"{(int)timeSpan.TotalDays} day{Plural((int)timeSpan.TotalDays)}";
|
|
}
|
|
|
|
private static string Plural(int value)
|
|
{
|
|
return value == 1 ? string.Empty : "s";
|
|
}
|
|
}
|
|
}
|