aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorValentin Popov <info@valentineus.link>2017-10-24 04:01:07 +0300
committerValentin Popov <info@valentineus.link>2017-10-24 04:01:07 +0300
commit4273d97f5f900cd23f58a8089bfa0bdb0dfccc82 (patch)
tree7e42d7b1b46b79d3951f1e44d710701e72567b49
parenta8ad95f44e1f9f9410b38f69187d843b2b806928 (diff)
downloadlocal_webhooks-4273d97f5f900cd23f58a8089bfa0bdb0dfccc82.tar.xz
local_webhooks-4273d97f5f900cd23f58a8089bfa0bdb0dfccc82.zip
The finished version of the service manager
-rw-r--r--managerservice.php57
1 files changed, 49 insertions, 8 deletions
diff --git a/managerservice.php b/managerservice.php
index 62131d2..c7c6749 100644
--- a/managerservice.php
+++ b/managerservice.php
@@ -23,42 +23,83 @@
*/
require_once(__DIR__ . "/../../config.php");
+require_once($CFG->libdir . "/tablelib.php");
+
$deleteservice = optional_param("deleteservice", 0, PARAM_INT);
require_login();
-$baseurl = new moodle_url("/local/webhooks/managerservice.php");
+
+/* Link generation */
+$managerservice = "/local/webhooks/managerservice.php";
+$editservice = "/local/webhooks/editservice.php";
+$baseurl = new moodle_url($managerservice);
$PAGE->set_url($baseurl);
+/* Configure the context of the page */
$context = context_system::instance();
$PAGE->set_context($context);
/* Delete the service */
if ($deleteservice && confirm_sesskey()) {
$DB->delete_records("local_webhooks_service", array("id" => $deleteservice));
- redirect($PAGE->url, new lang_string("servicedeleted", "local_webhooks"));
+ redirect($PAGE->url, new lang_string("deleted", "moodle"));
}
/* Retrieving a list of services */
$select = null;
-$callbacks = $DB->get_records_select("local_webhooks_service", $select, null, $DB->sql_order_by_text("title"));
+$callbacks = $DB->get_records_select("local_webhooks_service", $select, null, $DB->sql_order_by_text("id"));
/* Page template */
-$titlepage = new lang_string("managementmanager", "local_webhooks");
+$titlepage = new lang_string("managerservice", "local_webhooks");
$PAGE->set_pagelayout("standard");
$PAGE->set_title($titlepage);
$PAGE->set_heading($titlepage);
/* The page title */
-$PAGE->navbar->add(new lang_string("local"));
+$PAGE->navbar->add(new lang_string("local", "moodle"));
$PAGE->navbar->add(new lang_string("pluginname", "local_webhooks"));
$PAGE->navbar->add($titlepage, $baseurl);
echo $OUTPUT->header();
-/* @todo: Place the formation table */
+/* Table declaration */
+$table = new flexible_table("callbacks-table");
+
+/* Customize the table */
+$table->define_columns(array("title", "url", "actions"));
+$table->define_headers(array(
+ new lang_string("name", "moodle"),
+ new lang_string("url", "moodle"),
+ new lang_string("actions", "moodle")));
+$table->define_baseurl($baseurl);
+$table->setup();
+
+foreach ($callbacks as $callback) {
+ /* Filling of information columns */
+ $titlecallback = html_writer::div($callback->title, "title");
+ $urlcallback = html_writer::div($callback->url, "url");
+
+ /* Link for editing */
+ $editlink = new moodle_url($editservice,
+ array("idservice" => $callback->id));
+ $edititem = $OUTPUT->action_icon($editlink,
+ new pix_icon("t/edit", get_string("edit")));
+
+ /* Link to remove */
+ $deletelink = new moodle_url($managerservice,
+ array("deleteservice" => $callback->id, "sesskey" => sesskey()));
+ $deleteitem = $OUTPUT->action_icon($deletelink,
+ new pix_icon("t/delete", get_string("delete")));
+
+ /* Adding data to the table */
+ $table->add_data(array($titlecallback, $urlcallback, $edititem . $deleteitem));
+}
+
+/* Display the table */
+$table->print_html();
/* Add service button */
$addurl = new moodle_url("/local/webhooks/editservice.php");
-$addurltext = new lang_string("managementmanageradd", "local_webhooks");
-echo "<div class=\"actionbuttons\">" . $OUTPUT->single_button($addurl, $addurltext, "get") . "</div>";
+echo $OUTPUT->single_button($addurl,
+ new lang_string("addaservice", "webservice"), "get");
echo $OUTPUT->footer(); \ No newline at end of file