mirror of
https://github.com/basicswap/basicswap.git
synced 2025-01-18 16:44:34 +00:00
ui: Sort on Time and Trade (table).
This commit is contained in:
parent
014ee22b79
commit
c0d9b7c161
3 changed files with 104 additions and 36 deletions
|
@ -745,7 +745,7 @@ function updateProfitLoss(row, fromCoin, toCoin, fromAmount, toAmount, isOwnOffe
|
|||
function createTableRow(offer, isSentOffers) {
|
||||
const row = document.createElement('tr');
|
||||
row.className = `opacity-100 text-gray-500 dark:text-gray-100 hover:bg-coolGray-200 dark:hover:bg-gray-600`;
|
||||
row.setAttribute('data-offer-id', offer.offer_id);
|
||||
row.setAttribute('data-offer-id', `${offer.offer_id}_${offer.created_at}`);
|
||||
|
||||
const coinFrom = offer.coin_from ? (symbolToCoinName[coinNameToSymbol[offer.coin_from]] || offer.coin_from) : 'Unknown';
|
||||
const coinTo = offer.coin_to ? (symbolToCoinName[coinNameToSymbol[offer.coin_to]] || offer.coin_to) : 'Unknown';
|
||||
|
|
|
@ -1170,37 +1170,103 @@ const app = {
|
|||
console.log('Current BTC price:', app.btcPriceUSD);
|
||||
},
|
||||
|
||||
sortTable: (columnIndex) => {
|
||||
const sortableColumns = [5, 6];
|
||||
if (!sortableColumns.includes(columnIndex)) return;
|
||||
const table = document.querySelector('table');
|
||||
if (!table) {
|
||||
console.error("Table not found for sorting.");
|
||||
return;
|
||||
sortTable: (columnIndex) => {
|
||||
console.log(`Sorting column: ${columnIndex}`);
|
||||
const sortableColumns = [1, 5, 6, 7]; // 1: Time, 5: Rate, 6: Market +/-, 7: Trade
|
||||
if (!sortableColumns.includes(columnIndex)) {
|
||||
console.log(`Column ${columnIndex} is not sortable`);
|
||||
return;
|
||||
}
|
||||
const table = document.querySelector('table');
|
||||
if (!table) {
|
||||
console.error("Table not found for sorting.");
|
||||
return;
|
||||
}
|
||||
const rows = Array.from(table.querySelectorAll('tbody tr'));
|
||||
console.log(`Found ${rows.length} rows to sort`);
|
||||
const sortIcon = document.getElementById(`sort-icon-${columnIndex}`);
|
||||
if (!sortIcon) {
|
||||
console.error("Sort icon not found.");
|
||||
return;
|
||||
}
|
||||
const sortOrder = sortIcon.textContent === '↓' ? 1 : -1;
|
||||
sortIcon.textContent = sortOrder === 1 ? '↑' : '↓';
|
||||
|
||||
const getSafeTextContent = (element) => element ? element.textContent.trim() : '';
|
||||
|
||||
rows.sort((a, b) => {
|
||||
let aValue, bValue;
|
||||
switch (columnIndex) {
|
||||
case 1: // Time column
|
||||
aValue = getSafeTextContent(a.querySelector('td:first-child .text-xs:first-child'));
|
||||
bValue = getSafeTextContent(b.querySelector('td:first-child .text-xs:first-child'));
|
||||
// console.log(`Comparing times: "${aValue}" vs "${bValue}"`);
|
||||
|
||||
const parseTime = (timeStr) => {
|
||||
const [value, unit] = timeStr.split(' ');
|
||||
const numValue = parseFloat(value);
|
||||
switch(unit) {
|
||||
case 'seconds': return numValue;
|
||||
case 'minutes': return numValue * 60;
|
||||
case 'hours': return numValue * 3600;
|
||||
case 'days': return numValue * 86400;
|
||||
default: return 0;
|
||||
}
|
||||
};
|
||||
return (parseTime(bValue) - parseTime(aValue)) * sortOrder;
|
||||
|
||||
case 5: // Rate
|
||||
case 6: // Market +/-
|
||||
aValue = getSafeTextContent(a.cells[columnIndex]);
|
||||
bValue = getSafeTextContent(b.cells[columnIndex]);
|
||||
console.log(`Comparing values: "${aValue}" vs "${bValue}"`);
|
||||
|
||||
aValue = parseFloat(aValue.replace(/[^\d.-]/g, '') || '0');
|
||||
bValue = parseFloat(bValue.replace(/[^\d.-]/g, '') || '0');
|
||||
return (aValue - bValue) * sortOrder;
|
||||
|
||||
case 7: // Trade
|
||||
const aCell = a.cells[columnIndex];
|
||||
const bCell = b.cells[columnIndex];
|
||||
console.log('aCell:', aCell ? aCell.outerHTML : 'null');
|
||||
console.log('bCell:', bCell ? bCell.outerHTML : 'null');
|
||||
|
||||
aValue = getSafeTextContent(aCell.querySelector('a')) ||
|
||||
getSafeTextContent(aCell.querySelector('button')) ||
|
||||
getSafeTextContent(aCell);
|
||||
bValue = getSafeTextContent(bCell.querySelector('a')) ||
|
||||
getSafeTextContent(bCell.querySelector('button')) ||
|
||||
getSafeTextContent(bCell);
|
||||
|
||||
aValue = aValue.toLowerCase();
|
||||
bValue = bValue.toLowerCase();
|
||||
|
||||
console.log(`Comparing trade actions: "${aValue}" vs "${bValue}"`);
|
||||
|
||||
if (aValue === bValue) return 0;
|
||||
if (aValue === "swap") return -1 * sortOrder;
|
||||
if (bValue === "swap") return 1 * sortOrder;
|
||||
return aValue.localeCompare(bValue) * sortOrder;
|
||||
|
||||
default:
|
||||
aValue = getSafeTextContent(a.cells[columnIndex]);
|
||||
bValue = getSafeTextContent(b.cells[columnIndex]);
|
||||
console.log(`Comparing default values: "${aValue}" vs "${bValue}"`);
|
||||
return aValue.localeCompare(bValue, undefined, {
|
||||
numeric: true,
|
||||
sensitivity: 'base'
|
||||
}) * sortOrder;
|
||||
}
|
||||
const rows = Array.from(table.querySelectorAll('tbody tr'));
|
||||
const sortIcon = document.getElementById(`sort-icon-${columnIndex}`);
|
||||
if (!sortIcon) {
|
||||
console.error("Sort icon not found.");
|
||||
return;
|
||||
}
|
||||
const sortOrder = sortIcon.textContent === '↓' ? 1 : -1;
|
||||
sortIcon.textContent = sortOrder === 1 ? '↑' : '↓';
|
||||
rows.sort((a, b) => {
|
||||
const aValue = a.cells[columnIndex]?.textContent.trim() || '';
|
||||
const bValue = b.cells[columnIndex]?.textContent.trim() || '';
|
||||
return aValue.localeCompare(bValue, undefined, {
|
||||
numeric: true,
|
||||
sensitivity: 'base'
|
||||
}) * sortOrder;
|
||||
});
|
||||
const tbody = table.querySelector('tbody');
|
||||
if (tbody) {
|
||||
rows.forEach(row => tbody.appendChild(row));
|
||||
} else {
|
||||
console.error("Table body not found.");
|
||||
}
|
||||
},
|
||||
});
|
||||
|
||||
const tbody = table.querySelector('tbody');
|
||||
if (tbody) {
|
||||
rows.forEach(row => tbody.appendChild(row));
|
||||
} else {
|
||||
// console.error("Table body not found.");
|
||||
}
|
||||
// console.log('Sorting completed');
|
||||
},
|
||||
|
||||
initializeSelectImages: () => {
|
||||
const updateSelectedImage = (selectId) => {
|
||||
|
|
|
@ -296,9 +296,10 @@ function getAPIKeys() {
|
|||
<table class="w-full min-w-max">
|
||||
<thead class="uppercase">
|
||||
<tr>
|
||||
<th class="p-0">
|
||||
<th class="p-0" data-sortable="true" data-column-index="0">
|
||||
<div class="py-3 pl-4 justify-center rounded-tl-xl bg-coolGray-200 dark:bg-gray-600">
|
||||
<span class="text-sm mr-1 text-gray-600 dark:text-gray-300 font-semibold">Time</span>
|
||||
<span class="sort-icon ml-1 text-gray-600 dark:text-gray-400" id="sort-icon-0">↓</span>
|
||||
</div>
|
||||
</th>
|
||||
<th class="p-0 hidden xl:block">
|
||||
|
@ -349,11 +350,12 @@ function getAPIKeys() {
|
|||
<span class="sort-icon ml-1 text-gray-600 dark:text-gray-400" id="sort-icon-6">↓</span>
|
||||
</div>
|
||||
</th>
|
||||
<th class="p-0">
|
||||
<th class="p-0" data-sortable="true" data-column-index="7">
|
||||
<div class="py-3 px-4 bg-coolGray-200 dark:bg-gray-600 rounded-tr-xl">
|
||||
<span class="text-sm text-gray-600 dark:text-gray-300 font-semibold">Trade</span>
|
||||
</div>
|
||||
</th>
|
||||
<span class="text-sm text-gray-600 dark:text-gray-300 font-semibold">Trade</span>
|
||||
<span class="sort-icon ml-1 text-gray-600 dark:text-gray-400" id="sort-icon-7">↓</span>
|
||||
</div>
|
||||
</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody id="offers-body">
|
||||
|
|
Loading…
Reference in a new issue