123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275 |
- <?php
- if (!defined('GNUSOCIAL')) {
- exit(1);
- }
- class SensitiveContentPlugin extends Plugin
- {
- const PLUGIN_VERSION = '0.0.1';
- function onPluginVersion(array &$versions)
- {
- $versions[] = array('name' => 'Sensitive Content',
- 'version' => self::PLUGIN_VERSION,
- 'author' => 'MoonMan',
- 'homepage' => 'https://gitgud.io/ShitposterClub/SensitiveContent/',
- 'description' =>
- _m('Mark, hide/show sensitive notices like on Twitter.'));
- return true;
- }
- static function settings($setting)
- {
- $settings['blockerimage'] = Plugin::staticPath('SensitiveContent', '').'img/blocker.png';
- $configphpsettings = common_config('site','sensitivecontent') ?: array();
- foreach($configphpsettings as $configphpsetting=>$value) {
- $settings[$configphpsetting] = $value;
- }
- if(isset($settings[$setting])) {
- return $settings[$setting];
- }
- else FALSE;
- }
- function onNoticeSimpleStatusArray($notice, &$twitter_status, $scoped)
- {
- $twitter_status['tags'] = $notice->getTags();
- }
- function onTwitterUserArray($profile, &$twitter_user, $scoped)
- {
- if ($scoped instanceof Profile && $scoped->sameAs($profile)) {
- $twitter_user['hide_sensitive'] = $this->getHideSensitive($scoped);
- }
- }
- public function onRouterInitialized(URLMapper $m)
- {
- $m->connect('settings/sensitivecontent',
- ['action' => 'sensitivecontentsettings']);
- }
- function onEndAccountSettingsNav($action)
- {
- $action->menuItem(common_local_url('sensitivecontentsettings'),
- _m('MENU', 'Sensitive Content'),
- _m('Settings for display of sensitive content.'));
- return true;
- }
- public function onQvitterEndShowHeadElements(Action $action)
- {
- $blocker = static::settings('blockerimage');
- common_log( LOG_DEBUG, "SENSITIVECONTENT " . $blocker );
- $styles = <<<EOB
- .sensitive-blocker {
- display: none;
- }
- div.stream-item.notice.sensitive-notice .sensitive-blocker {
- display: block;
- width: 100%;
- height: 100%;
- position: absolute;
- z-index: 100;
- background-color: #d4baba;
- background-image: url($blocker);
- background-repeat: no-repeat;
- background-position: center center;
- background-size: contain;
- transition: opacity 1s ease-in-out;
- }
- .sensitive-blocker:hover {
- opacity: .5;
- }
- div.stream-item.notice.expanded.sensitive-notice .sensitive-blocker {
- display: none;
- background-color: transparent;
- background-image: none;
- }
- EOB;
- $action->style($styles);
- }
- function onQvitterEndShowScripts(Action $action)
- {
- $action->script( Plugin::staticPath('SensitiveContent', '').'js/sensitivecontent.js' );
- }
- function onEndShowStyles(Action $action)
- {
- $blocker = static::settings('blockerimage');
- $styles = <<<EOB
- /* default no show */
- html .tagcontainer > footer > .attachments > .inline-attachment > .attachment-wrapper > .sensitive-blocker {
- display: none;
- }
- html[data-hidesensitive='true'] .tagcontainer.data-tag-nsfw > footer > .attachments > .inline-attachment > .attachment-wrapper > .sensitive-blocker {
- display: block;
- width: 100%;
- height: 100%;
- position: absolute;
- z-index: 100;
- /*background-color: #d4baba;*/
- background-color: black;
- background-image: url($blocker);
- background-repeat: no-repeat;
- background-position: center center;
- background-size: contain;
- transition: opacity 1s ease-in-out;
- }
- html[data-hidesensitive='true'] .tagcontainer.data-tag-nsfw > footer > .attachments > .inline-attachment > .attachment-wrapper > .sensitive-blocker.reveal {
- opacity: 0;
- }
- EOB;
- $action->style($styles);
- }
- function onStartShowAttachmentRepresentation($out, $file)
- {
- $profile = Profile::current();
- if (!is_null($profile) && $profile instanceof Profile)
- {
- $hidesensitive = $this->getHideSensitive($profile);
- }
- else
- {
- $hidesensitive = false;
- }
- $classes = "sensitive-blocker"; //'sensitive-blocker';
- $out->elementStart('div', array(
- 'class'=>'attachment-wrapper',
- 'style'=>'height: ' . $file->getThumbnail()->height . 'px; width: ' . $file->getThumbnail()->width . 'px;'
- )); /*needs height of thumb*/
- $out->elementStart('div', array(
- 'class'=>$classes,
- 'onclick'=>'toggleSpoiler(event)',
- 'style'=>'height: ' . $file->getThumbnail()->height . 'px; width: ' . $file->getThumbnail()->width . 'px;'
- ));
- $out->raw(' ');
- $out->elementEnd('div');
- }
- function onEndShowAttachmentRepresentation($out, $file)
- {
- $out->elementEnd('div');
- }
- function onEndShowScripts(Action $action)
- {
- $profile = $action->getScoped();
- if (!is_null($profile) && $profile instanceof Profile)
- {
- $hidesensitive = $this->getHideSensitive($profile) ? "true" : "false";
- }
- else
- {
- $hidesensitive = "false";
- }
- $inline = <<<EOB
- window.hidesensitive = $hidesensitive ;
- function toggleSpoiler(evt) {
- if (window.hidesensitive) evt.target.classList.toggle('reveal');
- }
- EOB;
- $action->inlineScript($inline);
- }
- function onEndOpenNoticeListItemElement(NoticeListItem $nli)
- {
- $rawtags = $nli->getNotice()->getTags();
- $classes = "tagcontainer";
- foreach($rawtags as $tag)
- {
- $classes = $classes . ' data-tag-' . $tag;
- }
- $nli->elementStart('span', array('class' => $classes));
- //$nli->elementEnd('span');
- }
- function onStartCloseNoticeListItemElement(NoticeListItem $nli)
- {
- $nli->elementEnd('span');
- }
- function onStartHtmlElement($action, &$attrs) {
- $profile = Profile::current();
- if (!is_null($profile) && $profile instanceof Profile)
- {
- $hidesensitive = $this->getHideSensitive($profile);
- }
- else
- {
- $hidesensitive = false;
- }
- $attrs = array_merge($attrs,
- array('data-hidesensitive' => ($hidesensitive ? "true" : "false"))
- );
- }
- function getHideSensitive($profile) {
- $c = Cache::instance();
- /*
- if (!empty($c)) {
- $hidesensitive = $c->get(Cache::key('profile:hide_sensitive:'.$profile->id));
- if (is_numeric($hidesensitive)) {
- return (boolean) $hidesensitive;
- }
- else return FALSE;
- }
- */
- $hidesensitive = $profile->getPref('MoonMan', 'hide_sensitive', '0');
- if (!empty($c)) {
- //not using it yet.
- $c->set(Cache::key('profile:hide_sensitive:'.$profile->id), $hidesensitive);
- }
- //common_log(LOG_DEBUG, "SENSITIVECONTENT hidesensitive? id " . $profile->id . " value " . (boolean)$hidesensitive );
- if (is_null($hidesensitive)) {
- return FALSE;
- } else
- if (is_numeric($hidesensitive)) {
- return (boolean) $hidesensitive;
- }
- else return FALSE;
- }
- }
|