1
0
mirror of https://git.tt-rss.org/git/tt-rss.git synced 2025-12-13 20:25:57 +00:00

nsfw: support API clients

This commit is contained in:
Andrew Dolgov
2021-03-07 13:22:38 +03:00
parent ffb93d72ac
commit ac6a59914b
7 changed files with 66 additions and 34 deletions

View File

@@ -2,11 +2,17 @@
Plugins.NSFW = {
toggle: function(elem) {
const content = elem.domNode.parentNode.querySelector(".nswf.content");
elem = elem.domNode || elem;
if (content) {
Element.toggle(content);
}
const content = elem.closest(".nsfw-wrapper").querySelector('.nsfw-content');
// we can't use .toggle() here because this script could be invoked by the api client
// so it's back to vanilla js
if (content.style.display == 'none')
content.style.display = '';
else
content.style.display = 'none';
}
}

View File

@@ -12,9 +12,11 @@ class NSFW extends Plugin {
function init($host) {
$this->host = $host;
$host->add_hook($host::HOOK_RENDER_ARTICLE, $this);
$host->add_hook($host::HOOK_RENDER_ARTICLE_CDM, $this);
$host->add_hook($host::HOOK_PREFS_TAB, $this);
$host->add_hook(PluginHost::HOOK_RENDER_ARTICLE, $this);
$host->add_hook(PluginHost::HOOK_RENDER_ARTICLE_CDM, $this);
$host->add_hook(PluginHost::HOOK_RENDER_ARTICLE_API, $this);
$host->add_hook(PluginHost::HOOK_ARTICLE_IMAGE, $this);
$host->add_hook(PluginHost::HOOK_PREFS_TAB, $this);
}
@@ -22,22 +24,46 @@ class NSFW extends Plugin {
return file_get_contents(__DIR__ . "/init.js");
}
function hook_render_article($article) {
$tags = array_map("trim", explode(",", $this->host->get($this, "tags")));
$a_tags = array_map("trim", explode(",", $article["tag_cache"]));
function hook_article_image($enclosures, $content, $site_url, $article) {
$tags = explode(",", $this->host->get($this, "tags"));
$article_tags = $article["tags"];
if (count(array_intersect($tags, $a_tags)) > 0) {
$article["content"] = "<div class='nswf wrapper'>".
if (count(array_intersect($tags, $article_tags)) > 0) {
return [Config::get_self_url() . "/plugins/nsfw/nsfw.png", "", "nsfw", []];
} else {
return ["", "", $content];
}
}
private function rewrite_contents($article, bool $add_api_js = false) {
$tags = explode(",", $this->host->get($this, "tags"));
$article_tags = $article["tags"];
if (count(array_intersect($tags, $article_tags)) > 0) {
$article["content"] = "<div class='nsfw-wrapper'>".
\Controls\button_tag(__("Not work safe (click to toggle)"), '', ['onclick' => 'Plugins.NSFW.toggle(this)']).
"<div class='nswf content' style='display : none'>".$article["content"]."</div>
"<div class='nsfw-content' style='display : none'>".$article["content"]."</div>
</div>";
if ($add_api_js) {
$article["content"] .= "<script type='text/javascript'>const Plugins = {}; " . $this->get_js() . "</script>";
}
}
return $article;
}
function hook_render_article_api($row) {
$article = isset($row['headline']) ? $row['headline'] : $row['article'];
return $this->rewrite_contents($article, true);
}
function hook_render_article($article) {
return $this->rewrite_contents($article);
}
function hook_render_article_cdm($article) {
return $this->hook_render_article($article);
return $this->rewrite_contents($article);
}
function hook_prefs_tab($args) {

View File

@@ -142,7 +142,7 @@ class Share extends Plugin {
$line);
$enclosures = Article::_get_enclosures($line["id"]);
list ($og_image, $og_stream) = Article::_get_image($enclosures, $line['content'], $line["site_url"]);
list ($og_image, $og_stream) = Article::_get_image($enclosures, $line['content'], $line["site_url"], $line);
$content_decoded = html_entity_decode($line["title"], ENT_NOQUOTES | ENT_HTML401);
$parsed_updated = TimeHelper::make_local_datetime($line["updated"], true, $owner_uid, true);