]> git.wh0rd.org - tt-rss.git/blobdiff - modules/popup-dialog.php
misc code cleanup, allow ctrl-key selection in prefs
[tt-rss.git] / modules / popup-dialog.php
index 06a82ad575ca2f0cd91cc82a9b7ffef177105ea1..364dfe7b023021d66b6245b41a0ef484f1302263 100644 (file)
                        if (function_exists('domxml_open_file')) {
                                print "<ul class='nomarks'>";
                                print "<li>".__("Importing using DOMXML.")."</li>";
-                               require_once "modules/opml_domxml.php";
+                               require_once "opml_domxml.php";
                                opml_import_domxml($link, $owner_uid);
                                print "</ul>";
                        } else if (PHP_VERSION >= 5) {
                                print "<ul class='nomarks'>";
                                print "<li>".__("Importing using DOMDocument.")."</li>";
-                               require_once "modules/opml_domdoc.php";
+                               require_once "opml_domdoc.php";
                                opml_import_domdoc($link, $owner_uid);
                                print "</ul>";
                        } else {
 
                        print "<div align='center'>";
 
-                       print "<input class=\"button\"
-                               type=\"submit\" onclick=\"return opmlImportDone()\" 
-                               value=\"".__('Close this window')."\">";
+                       print "<button onclick=\"return opmlImportDone()\">".
+                               __('Close this window')."</button>";
 
                        print "</div>";
 
                        print "<script type=\"text/javascript\">";
-                       print "parent.opml_import_handler(this)";
+                       print "parent.opmlImportHandler(this)";
                        print "</script>";
 
                        print "</div></div>";
@@ -81,8 +80,8 @@
                                WHERE owner_uid = ".$_SESSION["uid"]." ORDER BY title");
 
                        print   __('Select:')." 
-                               <a href=\"javascript:selectPrefRows('fcat', true)\">".__('All')."</a>,
-                               <a href=\"javascript:selectPrefRows('fcat', false)\">".__('None')."</a>";
+                               <a href=\"#\" onclick=\"selectPrefRows('fcat', true)\">".__('All')."</a>,
+                               <a href=\"#\" onclick=\"selectPrefRows('fcat', false)\">".__('None')."</a>";
 
                        print "<div class=\"prefFeedCatHolder\">";
 
@@ -94,7 +93,7 @@
                        print "<tr class=\"odd\" id=\"FCATR-0\">";
 
                        print "<td width='5%' align='center'><input 
-                               onclick='toggleSelectPrefRow(this, \"fcat\");' 
+                               onclick='toggleSelectRow(this);' 
                                type=\"checkbox\" id=\"FCCHK-0\"></td>";
 
                        if (!$_SESSION["profile"]) {
                                $edit_title = htmlspecialchars($line["title"]);
        
                                print "<td width='5%' align='center'><input 
-                                       onclick='toggleSelectPrefRow(this, \"fcat\");' 
+                                       onclick='toggleSelectRow(this);' 
                                        type=\"checkbox\" id=\"FCCHK-$cat_id\"></td>";
 
                                if ($_SESSION["profile"] == $line["id"]) {
                                <div style='float : left'>
                                <button onclick=\"return removeSelectedPrefProfiles()\">".
                                __('Remove')."</button>
-                               <input class=\"button\"
-                               type=\"submit\" onclick=\"return activatePrefProfile()\" 
-                               value=\"".__('Activate')."\">
+                               <button onclick=\"return activatePrefProfile()\">".
+                               __('Activate')."</button>
                                </div>";
 
-                       print "<input class=\"button\"
-                               type=\"submit\" onclick=\"return closeInfoBox()\" 
-                               value=\"".__('Close this window')."\">";
+                       print "<button onclick=\"return closeInfoBox()\">".
+                               __('Close this window')."</button>";
 
                        print "</div></div>";
 
                        return;
                }
 
-               if ($id == "pubUrl") {
+               if ($id == "pubOPMLUrl") {
 
-                       print "<div id=\"infoBoxTitle\">".__('Published Articles')."</div>";
+                       print "<div id=\"infoBoxTitle\">".__('Public OPML URL')."</div>";
                        print "<div class=\"infoBoxContents\">";
-       
-                       $url_path = article_publish_url($link);
 
-                       print __("Your Published articles feed URL is:");
+                       $url_path = opml_publish_url($link);
+
+                       print __("Your Public OPML URL is:");
 
                        print "<div class=\"tagCloudContainer\">";
-                       print "<a id='pub_feed_url' href='$url_path' target='_blank'>$url_path</a>";
+                       print "<a id='pub_opml_url' href='$url_path' target='_blank'>$url_path</a>";
                        print "</div>";
 
                        print "<div align='center'>";
 
-                       print "<button onclick=\"return pubRegenKey()\">".
+                       print "<button onclick=\"return opmlRegenKey()\">".
                                __('Generate new URL')."</button> ";
 
                        print "<input class=\"button\"
                        if ($param == 1) {
                                print __("Update daemon is enabled in configuration, but daemon process is not running, which prevents all feeds from updating. Please start the daemon process or contact instance owner.");
 
-                               $stamp = (int)read_stampfile("update_daemon.stamp");
+                               $stamp = (int) file_get_contents(LOCK_DIRECTORY . "/update_daemon.stamp");
 
                                print "<p>" . __("Last update:") . " " . date("Y.m.d, G:i", $stamp); 
 
                        if ($param == 3) {
                                print __("Update daemon is taking too long to perform a feed update. This could indicate a problem like crash or a hang. Please check the daemon process or contact instance owner.");
 
-                               $stamp = (int)read_stampfile("update_daemon.stamp");
+                               $stamp = (int) file_get_contents(LOCK_DIRECTORY . "/update_daemon.stamp");
 
                                print "<p>" . __("Last update:") . " " . date("Y.m.d, G:i", $stamp); 
 
                        
                        print "<div align='center'>";
 
-                       print "<input class=\"button\"
-                               type=\"submit\" onclick=\"return visitOfficialSite()\" 
-                               value=\"".__('Visit official site')."\"> ";
-
                        print "<input class=\"button\"
                                type=\"submit\" onclick=\"return closeInfoBox()\" 
                                value=\"".__('Close this window')."\">";
 
                        print "<input size=\"40\"
                                        onkeypress=\"return filterCR(event, subscribeToFeed)\"
-                                       name=\"feed\" id=\"feed_url\"></td></tr>";
+                                       name=\"feed\" id=\"feed_url\">";
 
                        print "<br/>";
 
 
                        print "</div>";
 
+                       print '<div id="fadd_feeds_container" style="display:none">
+
+                                       <div class="dlgSec">' . __('Available feeds') . '</div>
+                                       <div class="dlgSecCont">'
+
+                                       . ' <select name="feed" id="faad_feeds_container_select" size="3"></select>'
+                               . '</div></div>';
+
                        print "<div id='fadd_login_container' style='display:none'>
        
                                        <div class=\"dlgSec\">".__("Authentication")."</div>
                        print "<div class=\"dlgButtons\">
                                <button class=\"button\" id=\"fadd_submit_btn\"
                                        onclick=\"return subscribeToFeed()\">".__('Subscribe')."</button>
-                               <button onclick=\"return browseFeeds()\">".__('More feeds')."</button>
+                               <button onclick=\"return displayDlg('feedBrowser')\">".__('More feeds')."</button>
                                <button onclick=\"return closeInfoBox()\">".__('Cancel')."</button></div>";
                        
                        return;
                        print "
                                <div style='float : right'>
                                <img style='display : none' 
-                                       id='feed_browser_spinner' src='images/indicator_white.gif'>
+                                       id='feed_browser_spinner' src='".
+                                       theme_image($link, 'images/indicator_white.gif')."'>
                                <input name=\"search\" size=\"20\" type=\"search\"
                                        onchange=\"javascript:updateFeedBrowser()\" value=\"$browser_search\">
                                <button onclick=\"javascript:updateFeedBrowser()\">".__('Search')."</button>
 
                        #$active_feed_id = db_escape_string($_REQUEST["param"]);
 
-                       $params = split(":", db_escape_string($_REQUEST["param"]));
+                       $params = explode(":", db_escape_string($_REQUEST["param"]), 2);
 
                        $active_feed_id = sprintf("%d", $params[0]);
-                       $is_cat = $params[1] == "true";
+                       $is_cat = (bool) $params[1];
 
                        print "<div class=\"dlgSec\">".__('Look for')."</div>";
 
                        print "<div class=\"dlgSecCont\">";
 
-                       print "<input name=\"query\" size=\"20\" type=\"search\"        value=''>";
+                       print "<input onkeypress=\"return filterCR(event, search)\"
+                               name=\"query\" size=\"20\" type=\"search\"      value=''>";
 
                        print " " . __('match on')." ";
 
 
                        print "<div class=\"dlgButtons\">
                        <button onclick=\"javascript:search()\">".__('Search')."</button>
-                       <button onclick=\"javascript:searchCancel()\">".__('Cancel')."</button>
+                       <button onclick=\"javascript:closeInfoBox(true)\">".__('Cancel')."</button>
                        </div>";
 
                        print "</div>";
 
                        print "<div align='center'>";
 
-                       print "<input class=\"button\"
-                               type=\"submit\" onclick=\"return closeInfoBox()\" 
-                               value=\"".__('Close')."\">";
+                       print "<button onclick=\"return closeInfoBox()\">".
+                               __('Close this window')."</button>";
 
                        print "</div>";
 
                        return;
                }
 
-/*             if ($id == "offlineDownload") {
-                       print "<div id=\"infoBoxTitle\">".__('Download articles')."</div>";
+               if ($id == "emailArticle") {
+
+                       print "<div id=\"infoBoxTitle\">".__('Forward article by email')."</div>";
                        print "<div class=\"infoBoxContents\">";
 
-                       print "<form name='download_ops_form' id='download_ops_form'>";
+                       print "<form id=\"article_email_form\" onsubmit='return false'>";
 
-                       print "<div class=\"dlgSec\">".__("Download")."</div>";
+                       $secretkey = sha1(uniqid(rand(), true));
 
-                       print "<div class=\"dlgSecCont\">";
+                       $_SESSION['email_secretkey'] = $secretkey;
 
-                       $amount = array(
-                               50  => 50,
-                               100 => 100,
-                               250 => 250,
-                               500 => 500);
+                       print "<input type=\"hidden\" name=\"secretkey\" value=\"$secretkey\">";
+                       print "<input type=\"hidden\" name=\"op\" value=\"rpc\">";
+                       print "<input type=\"hidden\" name=\"subop\" value=\"sendEmail\">"; 
 
-                       print_select_hash("amount", 50, $amount);
+                       $result = db_query($link, "SELECT email, full_name FROM ttrss_users WHERE
+                               id = " . $_SESSION["uid"]);
 
-                       print " " . __("latest articles for offline reading.");
+                       $user_email = htmlspecialchars(db_fetch_result($result, 0, "email"));
+                       $user_name = htmlspecialchars(db_fetch_result($result, 0, "full_name"));
 
-                       print "<br/>";
+                       if (!$user_name) $user_name = $_SESSION['name'];
 
-                       print "<input checked='yes' type='checkbox' name='unread_only' id='unread_only'>";
-                       print "<label for='unread_only'>".__('Only include unread articles')."</label>";
+                       $_SESSION['email_replyto'] = $user_email;
+                       $_SESSION['email_fromname'] = $user_name;
 
-                       print "</div>";
+                       require_once "lib/MiniTemplator.class.php";
+
+                       $tpl = new MiniTemplator;
+                       $tpl_t = new MiniTemplator;
+
+                       $tpl->readTemplateFromFile("templates/email_article_template.txt");
+
+                       $tpl->setVariable('USER_NAME', $_SESSION["name"]);
+                       $tpl->setVariable('USER_EMAIL', $user_email);
+                       $tpl->setVariable('TTRSS_HOST', $_SERVER["HTTP_HOST"]);
+
+//                     $tpl->addBlock('header');
+
+                       $result = db_query($link, "SELECT link, content, title
+                               FROM ttrss_user_entries, ttrss_entries WHERE id = ref_id AND
+                               id IN ($param) AND owner_uid = " . $_SESSION["uid"]);
+
+                       if (db_num_rows($result) > 1) {
+                               $subject = __("[Forwarded]") . " " . __("Multiple articles");
+                       }
+
+                       while ($line = db_fetch_assoc($result)) {
+
+                               if (!$subject)
+                                       $subject = __("[Forwarded]") . " " . htmlspecialchars($line["title"]);
+
+                               $tpl->setVariable('ARTICLE_TITLE', strip_tags($line["title"]));
+                               $tpl->setVariable('ARTICLE_URL', strip_tags($line["link"]));
+
+                               $tpl->addBlock('article');
+                       }
+
+                       $tpl->addBlock('email');
+
+                       $content = "";
+                       $tpl->generateOutputToString($content);
+
+                       print "<table width='100%'><tr><td>";
+
+                       print __('From:');
+
+                       print "</td><td>";
+
+                       print "<input size=\"40\" disabled
+                                       onkeypress=\"return filterCR(event, false)\"
+                                       value=\"$user_name <$user_email>\">";
+
+                       print "</td></tr><tr><td>";
+
+                       print __('To:');
+
+                       print "</td><td>";
+
+                       print "<input size=\"40\"
+                                       onkeypress=\"return filterCR(event, false)\"
+                                       name=\"destination\" id=\"destination\">";
+
+                       print "<div class=\"autocomplete\" id=\"destination_choices\" 
+                                       style=\"display:none\"></div>"; 
+
+                       print "</td></tr><tr><td>";
+
+                       print __('Subject:');
+
+                       print "</td><td>";
+
+                       print "<input size=\"60\" class=\"iedit\"
+                                       onkeypress=\"return filterCR(event, false)\"
+                                       name=\"subject\" value=\"$subject\" id=\"subject\">";
+
+                       print "</td></tr></table>";
+
+                       print "<textarea rows='10' class='iedit' style='font-size : small'
+                               name='content'>$content</textarea>";
 
                        print "</form>";
 
-                       print "<div class=\"dlgButtons\">
-                               <input class=\"button\"
-                                       type=\"submit\" onclick=\"return initiate_offline_download(0, this)\" value=\"".__('Download')."\">
-                               <input class=\"button\"
-                                       type=\"submit\" onclick=\"return closeInfoBox()\" 
-                                       value=\"".__('Cancel')."\"></div>";
+                       print "<div class='dlgButtons'>";
+
+                       print "<button onclick=\"return emailArticleDo()\">".__('Send e-mail')."</button> ";
+                       print "<button onclick=\"return closeInfoBox()\">".__('Cancel')."</button>";
 
                        print "</div>";
 
                        return;
-               } */
+               }
+
+               if ($id == "generatedFeed") {
+
+                       print "<div id=\"infoBoxTitle\">".__('View as RSS')."</div>";
+                       print "<div class=\"infoBoxContents\">";
+       
+                       $params = explode(":", $param, 3);
+                       $feed_id = db_escape_string($params[0]);
+                       $is_cat = (bool) $params[1];
+
+                       $key = get_feed_access_key($link, $feed_id, $is_cat);
+
+                       $url_path = htmlspecialchars($params[2]) . "&key=" . $key;
+
+                       print __("You can view this feed as RSS using the following URL:");
+
+                       print "<div class=\"tagCloudContainer\">";
+                       print "<a id='gen_feed_url' href='$url_path' target='_blank'>$url_path</a>";
+                       print "</div>";
+
+                       print "<div align='center'>";
 
+                       print "<button onclick=\"return genUrlChangeKey('$feed_id', '$is_cat')\">".
+                               __('Generate new URL')."</button> ";
+
+                       print "<input class=\"button\"
+                               type=\"submit\" onclick=\"return closeInfoBox()\" 
+                               value=\"".__('Close this window')."\">";
+
+                       print "</div></div>";
+
+                       return;
+               }
 
                print "<div id='infoBoxTitle'>Internal Error</div>
                        <div id='infoBoxContents'>