implement pending posts processing

This commit is contained in:
ghost 2023-12-06 02:32:39 +02:00
parent 8608557881
commit 9cd4bb631d
3 changed files with 91 additions and 33 deletions

View File

@ -104,11 +104,18 @@ main ul > li:last-child
border-bottom: none; border-bottom: none;
} }
main ul > li > p main ul > li p
{ {
padding: 8px 0; padding: 8px 0;
} }
main ul li > span > svg
{
cursor: default;
fill: #999;
float: right;
}
footer footer
{ {
/*backdrop-filter: blur(100px);*/ /*backdrop-filter: blur(100px);*/

View File

@ -76,6 +76,49 @@ class RoomController extends AbstractController
// Get room feed // Get room feed
$feed = []; $feed = [];
// Get pending paradise
foreach ((array) $client->kevaPending() as $pending)
{
// Ignore pending posts from other rooms
if ($pending['namespace'] !== $request->get('namespace'))
{
continue;
}
// Ignore everything in pending queue but keva_put nodes
if ($pending['op'] !== 'keva_put')
{
continue;
}
// Skip values with meta keys
if (false !== stripos($pending['key'], '_KEVA_'))
{
continue;
}
// Get more info
if ($transaction = $client->getRawTransaction($pending['txid']))
{
$feed[] =
[
'pending' => true,
'key' => $pending['key'],
'value' => $pending['value'],
'txid' => $pending['txid'],
'transaction' =>
[
'time' => date('c', $transaction['time']),
'timestamp' => $transaction['time'],
'confirmations' => $transaction['confirmations'],
],
'icon' => $this->_identicon($pending['key']),
'sort' => 0//$transaction['time'] // sort order field
];
}
}
// Get regular posts
foreach ((array) $client->kevaFilter($request->get('namespace')) as $post) foreach ((array) $client->kevaFilter($request->get('namespace')) as $post)
{ {
// Skip values with meta keys // Skip values with meta keys
@ -84,49 +127,24 @@ class RoomController extends AbstractController
continue; continue;
} }
// Set identicon if not anonymous user
if ($post['key'] === '@anonymous')
{
$icon = false;
}
else
{
$identicon = new \Jdenticon\Identicon();
$identicon->setValue(
$post['key']
);
$identicon->setSize(12);
$identicon->setStyle(
[
'backgroundColor' => 'rgba(255, 255, 255, 0)',
'padding' => 0
]
);
$icon = $identicon->getImageDataUri('webp');
}
// Get more info // Get more info
if ($transaction = $client->getRawTransaction($post['txid'])) if ($transaction = $client->getRawTransaction($post['txid']))
{ {
$feed[] = $feed[] =
[ [
# 'key' => $post['key'], 'pending' => false,
'value' => $post['value'], 'key' => $post['key'],
'height' => $post['height'], 'value' => $post['value'],
# 'vout' => $post['vout'], 'height' => $post['height'],
'txid' => $post['txid'], # 'vout' => $post['vout'],
'txid' => $post['txid'],
'transaction' => 'transaction' =>
[ [
'time' => date('c', $transaction['time']), 'time' => date('c', $transaction['time']),
'timestamp' => $transaction['time'], 'timestamp' => $transaction['time'],
'confirmations' => $transaction['confirmations'], 'confirmations' => $transaction['confirmations'],
], ],
'icon' => $icon, 'icon' => $this->_identicon($post['key']),
'sort' => $transaction['time'] // sort order field 'sort' => $transaction['time'] // sort order field
]; ];
} }
@ -371,4 +389,30 @@ class RoomController extends AbstractController
] ]
); );
} }
private function _identicon(string $key)
{
if ($key === 'anonymous')
{
return false;
}
else
{
$identicon = new \Jdenticon\Identicon();
$identicon->setValue($key);
$identicon->setSize(12);
$identicon->setStyle(
[
'backgroundColor' => 'rgba(255, 255, 255, 0)',
'padding' => 0
]
);
return $identicon->getImageDataUri('webp');
}
}
} }

View File

@ -27,6 +27,13 @@
<a href="{{ path('room_namespace', { namespace : request.get('namespace') }) }}#{{ post.txid }}" title="{{ 'time:' | trans }} {{ post.transaction.time }} / {{ 'confirmations:' | trans }} {{ post.transaction.confirmations }}">{{ post.transaction.timestamp | format_ago }}</a> <a href="{{ path('room_namespace', { namespace : request.get('namespace') }) }}#{{ post.txid }}" title="{{ 'time:' | trans }} {{ post.transaction.time }} / {{ 'confirmations:' | trans }} {{ post.transaction.confirmations }}">{{ post.transaction.timestamp | format_ago }}</a>
&bull; &bull;
<a href="{{ path('room_namespace', { namespace : request.get('namespace'), txid : post.txid }) }}#{{ post.txid }}">{{ 'reply' | trans }}</a> <a href="{{ path('room_namespace', { namespace : request.get('namespace'), txid : post.txid }) }}#{{ post.txid }}">{{ 'reply' | trans }}</a>
{% if post.pending %}
<span title="{{ 'pending in DHT' | trans }}">
<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 16 16">
<path d="M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0M8 3.5a.5.5 0 0 0-1 0V9a.5.5 0 0 0 .252.434l3.5 2a.5.5 0 0 0 .496-.868L8 8.71z"/>
</svg>
</span>
{% endif %}
<p> <p>
{{ post.value }} {{ post.value }}
</p> </p>