]>
git.wh0rd.org - tt-rss.git/blob - plugins/nsfw/init.php
2 class NSFW
extends Plugin
{
7 "Hide article content based on tags",
12 function init($host) {
15 $host->add_hook($host::HOOK_RENDER_ARTICLE
, $this);
16 $host->add_hook($host::HOOK_RENDER_ARTICLE_CDM
, $this);
17 $host->add_hook($host::HOOK_PREFS_TAB
, $this);
22 return file_get_contents(dirname(__FILE__
) . "/init.js");
25 function hook_render_article($article) {
26 $tags = array_map("trim", explode(",", $this->host
->get($this, "tags")));
27 $a_tags = array_map("trim", explode(",", $article["tag_cache"]));
29 if (count(array_intersect($tags, $a_tags)) > 0) {
30 $article["content"] = "<div class='nswf wrapper'><button onclick=\"nsfwShow(this)\">".__("Not work safe (click to toggle)")."</button>
31 <div class='nswf content' style='display : none'>".$article["content"]."</div></div>";
37 function hook_render_article_cdm($article) {
38 $tags = array_map("trim", explode(",", $this->host
->get($this, "tags")));
39 $a_tags = array_map("trim", explode(",", $article["tag_cache"]));
41 if (count(array_intersect($tags, $a_tags)) > 0) {
42 $article["content"] = "<div class='nswf wrapper'><button onclick=\"nsfwShow(this)\">".__("Not work safe (click to toggle)")."</button>
43 <div class='nswf content' style='display : none'>".$article["content"]."</div></div>";
49 function hook_prefs_tab($args) {
50 if ($args != "prefPrefs") return;
52 print "<div dojoType=\"dijit.layout.AccordionPane\" title=\"".__("NSFW Plugin")."\">";
56 $tags = $this->host
->get($this, "tags");
58 print "<form dojoType=\"dijit.form.Form\">";
60 print "<script type=\"dojo/method\" event=\"onSubmit\" args=\"evt\">
62 if (this.validate()) {
63 new Ajax.Request('backend.php', {
64 parameters: dojo.objectToQuery(this.getValues()),
65 onComplete: function(transport) {
66 notify_info(transport.responseText);
73 print "<input dojoType=\"dijit.form.TextBox\" style=\"display : none\" name=\"op\" value=\"pluginhandler\">";
74 print "<input dojoType=\"dijit.form.TextBox\" style=\"display : none\" name=\"method\" value=\"save\">";
75 print "<input dojoType=\"dijit.form.TextBox\" style=\"display : none\" name=\"plugin\" value=\"nsfw\">";
77 print "<table width=\"100%\" class=\"prefPrefsList\">";
79 print "<tr><td width=\"40%\">".__("Tags to consider NSFW (comma-separated)")."</td>";
80 print "<td class=\"prefValue\"><input dojoType=\"dijit.form.ValidationTextBox\" required=\"1\" name=\"tags\" value=\"$tags\"></td></tr>";
84 print "<p><button dojoType=\"dijit.form.Button\" type=\"submit\">".
85 __("Save")."</button>";
93 $tags = explode(",", db_escape_string($_POST["tags"]));
94 $tags = array_map("trim", $tags);
95 $tags = array_map("mb_strtolower", $tags);
96 $tags = join(", ", $tags);
98 $this->host
->set($this, "tags", $tags);
100 echo __("Configuration saved.");
103 function api_version() {