ttrss/plugins/nsfw/init.php

118 lines
2.8 KiB
PHP
Raw Permalink Normal View History

2013-02-23 12:02:29 +00:00
<?php
class NSFW extends Plugin {
private $host;
function about() {
return array(null,
2013-02-23 17:28:09 +00:00
"Hide article content based on tags",
2013-02-23 12:02:29 +00:00
"fox",
false);
}
function init($host) {
$this->host = $host;
2021-03-07 10:22:38 +00:00
$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);
2013-02-23 12:02:29 +00:00
}
2021-03-07 10:22:38 +00:00
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"];
2021-03-07 10:22:38 +00:00
} else {
return ["", "", $content];
}
}
private function rewrite_contents($article) {
2021-03-07 10:22:38 +00:00
$tags = explode(",", $this->host->get($this, "tags"));
$article_tags = $article["tags"];
2013-02-23 12:02:29 +00:00
2021-03-07 10:22:38 +00:00
if (count(array_intersect($tags, $article_tags)) > 0) {
2021-03-15 16:42:48 +00:00
$article["content"] = "<details class='nsfw'><summary>" . __("Not safe for work (click to toggle)") . "</summary>" . $article["content"] . "</details>";
2013-02-23 12:02:29 +00:00
}
return $article;
}
2021-03-15 16:42:48 +00:00
function get_css() {
return
'details.nsfw {
cursor : pointer;
user-select : none;
}';
}
2021-03-07 10:22:38 +00:00
function hook_render_article_api($row) {
$article = isset($row['headline']) ? $row['headline'] : $row['article'];
return $this->rewrite_contents($article);
2021-03-07 10:22:38 +00:00
}
function hook_render_article($article) {
return $this->rewrite_contents($article);
}
2013-02-23 12:02:29 +00:00
function hook_render_article_cdm($article) {
2021-03-07 10:22:38 +00:00
return $this->rewrite_contents($article);
2013-02-23 12:02:29 +00:00
}
2013-02-23 17:28:09 +00:00
function hook_prefs_tab($args) {
if ($args != "prefPrefs") return;
$tags = $this->host->get($this, "tags");
?>
<div dojoType="dijit.layout.AccordionPane"
title="<i class='material-icons'>extension</i> <?= __("NSFW Plugin") ?>">
<form dojoType="dijit.form.Form">
<?= \Controls\pluginhandler_tags($this, "save") ?>
<script type="dojo/method" event="onSubmit" args="evt">
evt.preventDefault();
if (this.validate()) {
Notify.progress('Saving data...', true);
xhr.post("backend.php", this.getValues(), (reply) => {
Notify.info(reply);
})
2013-02-23 17:28:09 +00:00
}
</script>
2013-02-23 17:28:09 +00:00
<header><?= __("Tags to consider NSFW (comma-separated):") ?></header>
2013-02-23 17:28:09 +00:00
<fieldset>
<textarea dojoType='dijit.form.SimpleTextarea' rows='4'
style='width: 500px; font-size : 12px;'
name='tags'><?= $tags ?></textarea>
</fieldset>
2013-02-23 17:28:09 +00:00
<hr/>
2013-02-23 17:28:09 +00:00
<?= \Controls\submit_tag(__("Save")) ?>
</form>
</div>
<?php
2013-02-23 17:28:09 +00:00
}
function save() {
$tags = implode(", ",
FeedItem_Common::normalize_categories(explode(",", $_POST["tags"] ?? "")));
2013-02-23 17:28:09 +00:00
$this->host->set($this, "tags", $tags);
echo __("Configuration saved.");
}
2013-04-19 13:31:56 +00:00
function api_version() {
return 2;
}
}
2013-04-19 13:31:56 +00:00