From a2c75257f191d218dae6de8e5e4ad240a0588654 Mon Sep 17 00:00:00 2001 From: Andrew Dolgov Date: Thu, 18 Feb 2021 13:16:55 +0300 Subject: bookmarklets: cleanup --- include/controls.php | 6 +++- plugins/bookmarklets/init.php | 71 ++++++++++++++++++++++--------------------- 2 files changed, 41 insertions(+), 36 deletions(-) diff --git a/include/controls.php b/include/controls.php index d8506877b..a60b1e0b0 100755 --- a/include/controls.php +++ b/include/controls.php @@ -23,7 +23,7 @@ } function button_tag(string $value, string $type, array $attributes = []) { - return ""; + return ""; } function submit_tag(string $value, array $attributes = []) { @@ -34,6 +34,10 @@ return button_tag($value, "", array_merge(["onclick" => "App.dialogOf(this).hide()"], $attributes)); } + function icon(string $icon, array $attributes = []) { + return "$icon"; + } + function select_tag(string $name, $value, array $values, array $attributes = [], string $id = "") { $attributes_str = attributes_to_string($attributes); $dojo_type = strpos($attributes_str, "dojoType") === false ? "dojoType='fox.form.Select'" : ""; diff --git a/plugins/bookmarklets/init.php b/plugins/bookmarklets/init.php index 9e0f8f348..a9dc3e69d 100644 --- a/plugins/bookmarklets/init.php +++ b/plugins/bookmarklets/init.php @@ -1,59 +1,60 @@ host = $host; + function init($host) { + $this->host = $host; - $host->add_hook($host::HOOK_PREFS_TAB, $this); - } + $host->add_hook($host::HOOK_PREFS_TAB, $this); + } - private function subscribe_to_feed_url() { + private function subscribe_to_feed_url() { $url_path = get_self_url_prefix() . "/public.php?op=subscribe&feed_url=%s"; return $url_path; } - function hook_prefs_tab($args) { - if ($args == "prefFeeds") { - - print "
bookmark ".__('Bookmarklets')."\">"; + function hook_prefs_tab($args) { + if ($args != "prefFeeds") + return; - print "

" . __("Drag the link below to your browser toolbar, open the feed you're interested in in your browser and click on the link to subscribe to it.") . "

"; + $bm_subscribe_url = str_replace('%s', '', $this->subscribe_to_feed_url()); + $confirm_str = str_replace("'", "\'", __('Subscribe to %s in Tiny Tiny RSS?')); + $bm_subscribe_url = htmlspecialchars("javascript:{if(confirm('$confirm_str'.replace('%s',window.location.href)))window.location.href='$bm_subscribe_url'+encodeURIComponent(window.location.href)}"); - $bm_subscribe_url = str_replace('%s', '', $this->subscribe_to_feed_url()); + $bm_share_url = htmlspecialchars("javascript:(function(){var d=document,w=window,e=w.getSelection,k=d.getSelection,x=d.selection,s=(e?e():(k)?k():(x?x.createRange().text:0)),f='".get_self_url_prefix()."/public.php?op=sharepopup',l=d.location,e=encodeURIComponent,g=f+'&title='+((e(s))?e(s):e(document.title))+'&url='+e(l.href);function a(){if(!w.open(g,'t','toolbar=0,resizable=0,scrollbars=1,status=1,width=500,height=250')){l.href=g;}}a();})()"); + ?> - $confirm_str = str_replace("'", "\'", __('Subscribe to %s in Tiny Tiny RSS?')); +
- $bm_url = htmlspecialchars("javascript:{if(confirm('$confirm_str'.replace('%s',window.location.href)))window.location.href='$bm_subscribe_url'+encodeURIComponent(window.location.href)}"); +

- print "

"; + - print "

" . __("Use this bookmarklet to publish arbitrary pages using Tiny Tiny RSS") . "

"; +

- print ""; + - print ""; + 'alt-info', "onclick" => "window.open('https://tt-rss.org/wiki/ShareAnything')"]) ?> - print "
"; #pane +
- } - } +