diff options
Diffstat (limited to 'plugins/nsfw')
-rw-r--r-- | plugins/nsfw/init.js | 14 | ||||
-rw-r--r-- | plugins/nsfw/init.php | 50 | ||||
-rw-r--r-- | plugins/nsfw/nsfw.png | bin | 0 -> 119 bytes |
3 files changed, 48 insertions, 16 deletions
diff --git a/plugins/nsfw/init.js b/plugins/nsfw/init.js index 4bc2443e8..71fe4747b 100644 --- a/plugins/nsfw/init.js +++ b/plugins/nsfw/init.js @@ -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'; } } diff --git a/plugins/nsfw/init.php b/plugins/nsfw/init.php index 7c5b8d00f..8ace94b51 100644 --- a/plugins/nsfw/init.php +++ b/plugins/nsfw/init.php @@ -3,7 +3,7 @@ class NSFW extends Plugin { private $host; function about() { - return array(1.0, + return array(null, "Hide article content based on tags", "fox", false); @@ -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, $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, $a_tags)) > 0) { - $article["content"] = "<div class='nswf wrapper'>". + 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) { @@ -90,5 +116,5 @@ class NSFW extends Plugin { function api_version() { return 2; } +} -}
\ No newline at end of file diff --git a/plugins/nsfw/nsfw.png b/plugins/nsfw/nsfw.png Binary files differnew file mode 100644 index 000000000..b735c24a9 --- /dev/null +++ b/plugins/nsfw/nsfw.png |