Add more types

This commit is contained in:
Michael 2023-04-18 21:05:31 +00:00
parent 71eb147c13
commit 9c8e7a23a6

View File

@ -501,7 +501,7 @@ function tumblr_cron()
DI::keyValue()->set('tumblr_last_poll', time());
}
function tumblr_add_npf_data($html)
function tumblr_add_npf_data(string $html, string $plink): string
{
$doc = new DOMDocument();
@ -515,7 +515,17 @@ function tumblr_add_npf_data($html)
continue;
}
tumblr_replace_with_npf($doc, $node, PageInfo::getFooterFromUrl($data['url']));
tumblr_replace_with_npf($doc, $node, tumblr_get_type_replacement($data, $plink));
}
$list = $xpath->query('//div[@data-npf]');
foreach ($list as $node) {
$data = tumblr_get_npf_data($node);
if (empty($data)) {
continue;
}
tumblr_replace_with_npf($doc, $node, tumblr_get_type_replacement($data, $plink));
}
$list = $xpath->query('//figure[@data-provider="youtube"]');
@ -530,6 +540,28 @@ function tumblr_add_npf_data($html)
return $doc->saveHTML();
}
function tumblr_get_type_replacement(array $data, string $plink): string
{
switch ($data['type']) {
case 'poll':
$body = '[p][url=' . $plink. ']'. $data['question'] . '[/url][/p][ul]';
foreach ($data['answers'] as $answer) {
$body .= '[li]' . $answer['answer_text'] . '[/li]';
}
$body .= '[/ul]';
break;
case 'link':
$body = PageInfo::getFooterFromUrl($data['url']);
default:
Logger::notice('Unknown type', ['type' => $data['type'], 'data' => $data, 'plink' => $plink]);
$body = '';
}
return $body;
}
function tumblr_get_attributes($node): array
{
$attributes = [];
@ -539,7 +571,7 @@ function tumblr_get_attributes($node): array
return $attributes;
}
function tumblr_get_npf_data($node): array
function tumblr_get_npf_data(DOMNode $node): array
{
$attributes = tumblr_get_attributes($node);
if (empty($attributes['data-npf'])) {
@ -549,7 +581,7 @@ function tumblr_get_npf_data($node): array
return json_decode($attributes['data-npf'], true);
}
function tumblr_replace_with_npf($doc, $node, $replacement)
function tumblr_replace_with_npf(DOMDocument $doc, DOMNode $node, string $replacement)
{
$replace = $doc->createTextNode($replacement);
$node->parentNode->insertBefore($replace, $node);
@ -631,7 +663,7 @@ function tumblr_get_content(array $item, stdClass $post): array
switch ($post->type) {
case 'text':
$item['title'] = $post->title;
$item['body'] = HTML::toBBCode($post->body);
$item['body'] = HTML::toBBCode(tumblr_add_npf_data($post->body, $post->post_url));
break;
case 'quote':
@ -829,7 +861,7 @@ function tumblr_connection(int $uid): ?TumblrOAuth
return new TumblrOAuth($consumer_key, $consumer_secret, $oauth_token, $oauth_token_secret);
}
function tumblr_get_page(int $uid, array $blogs = [])
function tumblr_get_page(int $uid, array $blogs = []): string
{
$page = DI::pConfig()->get($uid, 'tumblr', 'page');
@ -850,7 +882,7 @@ function tumblr_get_page(int $uid, array $blogs = [])
return '';
}
function tumblr_get_blogs(int $uid)
function tumblr_get_blogs(int $uid): array
{
$connection = tumblr_connection($uid);
if (empty($connection)) {