/** * Load the View */ public function onLoad() { if (!needRole()) { return; } $jsonData = null; switch (post("action")) { case "delete-feed-user": $feed = RDR_Feed::getById(post("data[fid]")); if ($feed) { $cats = user()->getCategories(); foreach ($cats as $category) { $feeds = $category->feeds; if ($feeds) { foreach ($feeds as $key => $catFeed) { if (compare($catFeed, $feed)) { unset($feeds[$key]); } } if (count($feeds) != count($category->feeds)) { $category->feeds = $feeds; $category->store(); } } } } break; case "delete-feed-admin": if (needRole(RDR_User::ROLE_ADMIN)) { $feed = RDR_Feed::getById(post("data[fid]")); if ($feed) { $feed->delete(); } } break; case "add-feed": $event = RDR_Import::addFeed(post("data[url]"), RDR_Category::get(post("data[category]"))); if ($event->feed) { RDR_Import::importFeedEntries($event->feed); } break; case "mark-all-as-readed": $cache = session("entry.ids.original"); if ($cache) { $ids = array_keys($cache); user()->loadReadedFlags(array_keys($ids)); $insertIds = array(); foreach ($ids as $id) { if (!isset(user()->_cacheReaded[$id])) { $insertIds[$id] = $id; } } if ($insertIds) { $query = "INSERT IGNORE INTO RDR_User_readed (o,k,v) VALUES "; foreach ($insertIds as $id) { $query .= " (" . user()->getId() . ", {$id}, 1), "; } $query = substr($query, 0, -2); db()->query($query); user()->updateReadedCount(); } } break; case "update-setting-user": user()->setting(post("data[key]"), post("data[value]")); user()->store(); break; case "update-newscache": user()->updateNewsCache(); $jsonData = user()->getAjaxData(); break; case "set-entries-readed": if (post("data[ids]")) { $entries = RDR_Entry::getByIds(post("data[ids]")); if ($entries) { user()->loadReadedFlags(array_keys($entries)); $insertIds = $deleteIds = array(); foreach ($entries as $entry) { $id = $entry->getId(); if ($id < user()->setting("init.entry")) { continue; } if (isset(user()->_cacheReaded[$id])) { $deleteIds[$id] = $id; } else { $insertIds[$id] = $id; } } if ($insertIds) { $query = "INSERT IGNORE INTO RDR_User_readed (o,k,v) VALUES "; foreach ($insertIds as $id) { $query .= " (" . user()->getId() . ", {$id}, 1), "; } $query = substr($query, 0, -2); db()->query($query); } if ($deleteIds) { $query = "DELETE FROM RDR_User_readed WHERE o = " . user()->getId() . " && k IN " . db()->toDb($deleteIds); } user()->updateReadedCount(); } } break; case "set-entries-saved": if (post("data[ids]")) { $entry = RDR_Entry::getById(post("data[ids][0]")); if ($entry) { if (user()->getByKey("saved", $entry->getId())) { user()->remove("saved", $entry->getId()); } else { user()->add("saved", 1, $entry->getId()); } user()->store(); } } break; case "set-feed-property": if (needRole(RDR_User::ROLE_ADMIN)) { $feed = RDR_Feed::getById(post("data[feed]")); if ($feed) { $feed->{post("data[field]")} = post("data[value]"); $feed->store(); } } break; } echo json_encode($jsonData, JSON_FORCE_OBJECT); }
/** * Load the View */ public function onLoad() { if (!needRole()) { return; } # some ajax actions switch (post("action")) { case "admin-feed": if (needRole(RDR_User::ROLE_ADMIN)) { $entry = RDR_Entry::getById(post("eid")); $feed = RDR_Feed::getById(post("fid")); ?> <b><?php echo t("feedadmin.raw.1"); ?> </b> <div class="small"> <?php echo t("feedadmin.raw.2"); ?> </div> <code class="raw"><?php echo s('<div>' . $entry->text . '</div>'); ?> </code><br/><br/> <b><?php echo t("feedadmin.format.1"); ?> </b> <div class="small"> <?php echo t("feedadmin.format.2"); ?> </div> <code class="formated"></code><br/><br/> <b><?php echo sprintf(t("feedadmin.js.1"), s(cut($feed->name, 30))); ?> </b> <div class="small"> <?php echo nl2br(sprintf(t("feedadmin.js.2"), s('<p>'), 'html = $(html); html.find("p").remove()')); ?> <br/> <textarea data-field="contentJS" style="width:90%" cols="45" rows="3"><?php echo s($feed->contentJS); ?> </textarea> </div> <?php } return; break; case "readed": if (post("ids")) { $entries = RDR_Entry::getByIds(post("ids")); if ($entries) { user()->loadReadedFlags(array_keys($entries)); $insertIds = $deleteIds = array(); foreach ($entries as $entry) { $id = $entry->getId(); if ($id < user()->setting("init.entry")) { continue; } if (isset(user()->_cacheReaded[$id])) { $deleteIds[$id] = $id; } else { $insertIds[$id] = $id; } } if ($insertIds) { $query = "INSERT IGNORE INTO RDR_User_readed (o,k,v) VALUES "; foreach ($insertIds as $id) { $query .= " (" . user()->getId() . ", {$id}, 1), "; } $query = substr($query, 0, -2); db()->query($query); } if ($deleteIds) { $query = "DELETE FROM RDR_User_readed WHERE o = " . user()->getId() . " && k IN " . db()->toDb($deleteIds); } user()->updateReadedCount(); } } break; case "saved": if (post("ids")) { $entry = RDR_Entry::getById(post("ids[0]")); if ($entry) { if (user()->getByKey("saved", $entry->getId())) { user()->remove("saved", $entry->getId()); } else { user()->add("saved", 1, $entry->getId()); } user()->store(); } } break; } $jsonData = user()->getAjaxData(); echo json_encode($jsonData, JSON_FORCE_OBJECT); }