diff --git a/includes/node.inc b/includes/node.inc index d1f8021c883..b3a1fe9c1d2 100644 --- a/includes/node.inc +++ b/includes/node.inc @@ -65,7 +65,7 @@ function node_get_comments($nid) { function node_save($node, $filter) { global $user, $status; - $rows = array(nid, pid, lid, cid, tid, log, type, title, score, votes, author, status, comment, promote, moderate, timestamp); + $rows = array(nid, pid, lid, cid, tid, log, type, title, score, votes, author, status, comment, promote, moderate, attribute, timestamp, timestamp_posted, timestamp_queued, timestamp_hidden); if ($node[nid] > 0) { $n = node_get_object(array("nid" => $node[nid])); diff --git a/modules/forum.module b/modules/forum.module index cf307f4414a..194979ccd44 100644 --- a/modules/forum.module +++ b/modules/forum.module @@ -13,11 +13,11 @@ function forum_view($node) { function forum_form($edit = array()) { global $REQUEST_URI; - $form .= form_textfield(t("Subject"), "title", $edit[title], 50, 64); + $form .= form_textfield("Subject", "title", $edit[title], 50, 64); $form .= structure_form("forum", $edit); - $form .= form_textarea(t("Body"), "body", $edit[body], 50, 10); + $form .= form_textarea("Body", "body", $edit[body], 50, 10); $form .= form_hidden("nid", $edit[nid]); - $form .= form_submit(t("Submit")); + $form .= form_submit("Submit"); return form($REQUEST_URI, $form); } @@ -58,28 +58,4 @@ function forum_page() { $theme->footer(); } -function forum_overview() { - return node_overview(array(0, "WHERE n.type = 'forum' ORDER BY n.title")); -} - -function forum_admin() { - global $id, $op, $edit; - - print "add new forum | overview
\n"; - - switch ($op) { - case "add": - print forum_form(); - break; - case "edit": - print forum_form(node_get_array(array(nid => $id))); - break; - case t("Submit"): - print status(forum_save($edit)); - // fall through: - default: - print forum_overview(); - } -} - ?> \ No newline at end of file diff --git a/modules/forum/forum.module b/modules/forum/forum.module index cf307f4414a..194979ccd44 100644 --- a/modules/forum/forum.module +++ b/modules/forum/forum.module @@ -13,11 +13,11 @@ function forum_view($node) { function forum_form($edit = array()) { global $REQUEST_URI; - $form .= form_textfield(t("Subject"), "title", $edit[title], 50, 64); + $form .= form_textfield("Subject", "title", $edit[title], 50, 64); $form .= structure_form("forum", $edit); - $form .= form_textarea(t("Body"), "body", $edit[body], 50, 10); + $form .= form_textarea("Body", "body", $edit[body], 50, 10); $form .= form_hidden("nid", $edit[nid]); - $form .= form_submit(t("Submit")); + $form .= form_submit("Submit"); return form($REQUEST_URI, $form); } @@ -58,28 +58,4 @@ function forum_page() { $theme->footer(); } -function forum_overview() { - return node_overview(array(0, "WHERE n.type = 'forum' ORDER BY n.title")); -} - -function forum_admin() { - global $id, $op, $edit; - - print "add new forum | overview
\n"; - - switch ($op) { - case "add": - print forum_form(); - break; - case "edit": - print forum_form(node_get_array(array(nid => $id))); - break; - case t("Submit"): - print status(forum_save($edit)); - // fall through: - default: - print forum_overview(); - } -} - ?> \ No newline at end of file diff --git a/modules/index.module b/modules/index.module index 09c8e4abdbe..592eca03814 100644 --- a/modules/index.module +++ b/modules/index.module @@ -77,7 +77,7 @@ function index_test_1() { $form .= index_collection_form($entry->collection); } $form .= "Select around and click the button below:
"; - $form .= form_submit("Click to test"); + $form .= form_submit("Click to test 1"); return form($REQUEST_URI, $form); } @@ -101,11 +101,20 @@ function index_test_2($edit) { return $output; } +function index_test_3() { + global $REQUEST_URI; + + $form .= "Fill out some meta-tags and search for those articles that matches best:
"; + $form .= form_submit("Click to test 2"); + + return form($REQUEST_URI, $form); +} + function index_entry() { $result = db_query("SELECT * FROM entry ORDER BY name"); $output .= "\n"; - $output .= " \n"; + $output .= " \n"; while ($entry = db_fetch_object($result)) { $output .= "\n"; } @@ -117,7 +126,7 @@ function index_entry() { function index_admin() { global $edit, $op, $id; - print "add new entry | entries | collections | help - test
\n"; + print "add new entry | entries | collections | help - test1
\n"; switch ($op) { case "add": @@ -129,12 +138,18 @@ function index_admin() { case "help": print index_help(); break; - case "test": + case "test1": print index_test_1(); break; - case "Click to test": + case "Click to test 1": print index_test_2($edit); break; + case "test2": + print index_test_3(); + break; + case "Click to test 2": + print index_test_4($edit); + break; case "collection": print index_collection(); break; diff --git a/modules/node.module b/modules/node.module index 8222393ed8f..8aeb5715cee 100644 --- a/modules/node.module +++ b/modules/node.module @@ -39,64 +39,111 @@ function node_filter($text) { return $text; } +function node_cron() { + db_query("UPDATE node SET status = '". node_status("posted") ."', timestamp_posted = '' WHERE timestamp_posted > 0 AND timestamp_posted < ". time()); + db_query("UPDATE node SET status = '". node_status("queued") ."', timestamp_posted = '' WHERE timestamp_queued > 0 AND timestamp_queued < ". time()); + db_query("UPDATE node SET status = '". node_status("dumped") ."', timestamp_posted = '' WHERE timestamp_hidden > 0 AND timestamp_hidden < ". time()); +} + function node_overview($query = array()) { global $user; + $colors = array("#ffdc9b", "#dedec4"); + $result = db_query("SELECT n.*, u.userid, c.name AS category FROM node n LEFT JOIN users u ON n.author = u.id LEFT JOIN category c ON n.cid = c.cid $query[1] LIMIT 50"); $output .= status($query[0]); $output .= "
namecollectionkeywords stringoparations
namecollectionmeta attributesoparations
". check_output($entry->name) ."". check_output($entry->collection) ."". check_output($entry->keyword) ."eid\">edit entry
\n"; - $output .= " \n"; + $output .= " \n"; + while ($node = db_fetch_object($result)) { - $output .= " \n"; + unset ($link); + + $link[] = user_access($user, $node->type) ? "type&op=edit&id=$node->nid\">edit content" : "edit content"; + $link[] = user_access($user, "node") ? "nid\">edit options" : "edit options"; + $link[] = user_access($user, "node") ? "nid\">edit status" : "edit status"; + $link[] = user_access($user, "node") ? "nid\">edit attributes" : "edit attributes"; + $link[] = user_access($user, "node") ? "nid\">delete node" : "delete node"; + + $color = $colors[$i++ % sizeof($colors)]; + + $output .= " \n"; + $output .= " \n"; } $output .= "
titlecategorystatusauthordateoperations
titletypestatusmeta attributesauthordate
nid\">". check_output($node->title) ."". check_output($node->category ? $node->category : $node->type) ."". node_status($node->status) ."". format_username($node->userid) ."". format_date($node->timestamp, "small") ."". (user_access($user, "node") ? "nid\">edit node" : "edit node") ."". (user_access($user, $node->type) ? "type&op=edit&id=$node->nid\">edit $node->type" : "edit $node->type") ."
nid\">". check_output($node->title) ."$node->type". node_status($node->status) ."". check_output($node->attribute) ."". format_username($node->userid) ."". format_date($node->timestamp, "small") ."
". implode(", ", $link) ."
\n"; return $output; } -function node_admin_view($id) { - $node = node_get_object(array("nid" => $id)); - - $form .= form_item("Title", check_output($node->title)); - $form .= form_item("Author", format_username($node->userid)); - $form .= form_item("Status", node_status($node->status)); - $form .= form_item("Comment", node_comment_status($node->comment)); - $form .= form_item("Promote", node_promote_status($node->promote)); - $form .= form_item("Moderate", check_output($node->moderate)); - $form .= form_item("Date", format_date($node->timestamp)); - $form .= form_submit("Edit node"); - $form .= form_submit("Delete node"); - - return form("admin.php?mod=node&id=$node->nid", $form); -} - -function node_admin_edit($id) { +function node_edit_option($id) { global $user; $node = node_get_object(array("nid" => $id)); - $form .= form_item("Title", check_output($node->title)); - $form .= form_select("Author", "author", $node->author, array($node->author => $node->userid, $user->id => $user->userid)); - $form .= form_select("Status", "status", $node->status, node_status($node->type)); - $form .= form_select("Comment", "comment", $node->comment, node_comment_status()); - $form .= form_select("Promote", "promote", $node->promote, node_promote_status()); - $form .= form_textfield("Moderate", "moderate", $node->moderate, 35, 255, t("Provide a comma-seperated list of the moderators their usernames.")); - $form .= form_select("Date", "timestamp", $node->timestamp, array($node->timestamp => format_date($node->timestamp) ." (original)", time() => format_date(time()) ." (current)")); + $form .= form_item("Document title", check_output($node->title)); + $form .= form_select("Comment", "comment", $node->comment, node_comment_status(), "Allow users to post comments to this document."); + $form .= form_select("Promote", "promote", $node->promote, node_promote_status(), "Promote this document on the main page."); + $form .= form_textfield("Moderate", "moderate", $node->moderate, 35, 255, t("A comma-seperated list of the moderators their usernames.")); $form .= form_hidden("nid", $node->nid); $form .= form_submit("Save node"); - $form .= form_submit("View node"); return form("admin.php?mod=node&id=$node->nid", $form); } +function node_edit_attribute($id) { + global $user; + + $node = node_get_object(array("nid" => $id)); + + $form .= form_item("Document title", check_output($node->title)); + $form .= form_textfield("Attributes", "attribute", $edit[attribute], 50, 128, htmlentities("A list meta attributes. Format: :;:;. Example: 'software:apache;type:webserver;os:linux;'.")); + $form .= form_hidden("nid", $node->nid); + $form .= form_submit("Save node"); + + return form("admin.php?mod=node&id=$node->nid", $form); +} + +function node_edit_status($id) { + global $REQUEST_URI; + + $node = node_get_object(array("nid" => $id)); + + $form .= form_item("Document title", check_output($node->title)); + $form .= form_select("Current status", "status", $node->status, node_status($node->type)); + $form .= form_textfield("Automatically post document", "timestamp_posted", ($node->timestamp_posted ? format_date($node->timestamp_posted) : ""), 30, 55, "The date at which your document will be automatically posted. Leave empty if you don't want to schedule this document, or fill out a string containing an English date format. Example input: '". date("j F Y G:i") ."', '". date("m/d/y H:i") ."', '". date("F j, Y H:i") ."', ..."); + $form .= form_textfield("Automatically queue document", "timestamp_queued", ($node->timestamp_queued ? format_date($node->timestamp_queued) : ""), 30, 55, "The date at which your document will be automatically queued. Leave empty if you don't want to schedule this document, or fill out a string containing an English date format. Example input: '". date("j F Y G:i") ."', '". date("m/d/y H:i") ."', '". date("F j, Y H:i") ."', ..."); + $form .= form_textfield("Automatically hide document", "timestamp_hidden", ($node->timestamp_hidden ? format_date($node->timestamp_hidden) : ""), 30, 55, "The date at which your document will be automatically hidden. Leave empty if you don't want to schedule this document, or fill out a string containing an English date format. Example input: '". date("j F Y G:i") ."', '". date("m/d/y H:i") ."', '". date("F j, Y H:i") ."', ..."); + $form .= form_hidden("nid", $node->nid); + $form .= form_submit("Save node"); + + return form($REQUEST_URI, $form); +} + function node_delete($id) { return (node_del(array("nid" => $id)) ? "node has been deleted." : "failed to delete node: node must be dumped first."); } function node_query($type = "") { - global $status; - $queries = array(array("recent nodes", "ORDER BY n.timestamp DESC"), array("posted nodes", "WHERE n.status = '$status[posted]' ORDER BY n.timestamp DESC"), array("queued nodes", "WHERE n.status = '$status[queued]' ORDER BY n.timestamp DESC"), array("dumped nodes", "WHERE n.status = '$status[dumped]' ORDER BY n.timestamp DESC")); + $queries[] = array("all nodes: recent additions", "ORDER BY n.timestamp DESC"); + $queries[] = array("all nodes: status set to 'posted'", "WHERE n.status = '". node_status("posted") ."' ORDER BY n.timestamp DESC"); + $queries[] = array("all nodes: status set to 'queued'", "WHERE n.status = '". node_status("queued") ."' ORDER BY n.timestamp DESC"); + $queries[] = array("all nodes: status set to 'dumped'", "WHERE n.status = '". node_status("dumped") ."' ORDER BY n.timestamp DESC"); + $queries[] = array("all nodes: scheduled to be posted", "WHERE n.timestamp_posted > 0 ORDER BY n.timestamp DESC"); + $queries[] = array("all nodes: scheduled to be queued", "WHERE n.timestamp_queued > 0 ORDER BY n.timestamp DESC"); + $queries[] = array("all nodes: scheduled to be hidden", "WHERE n.timestamp_hidden > 0 ORDER BY n.timestamp DESC"); + + foreach (module_list() as $name) { + if (module_hook($name, "user")) { + $queries[] = array("$name: recent additions", "WHERE n.type = '$name' ORDER BY n.timestamp DESC"); + $queries[] = array("$name: status set to 'posted'", "WHERE n.type = '$name' AND n.status = '". node_status("posted") ."' ORDER BY n.timestamp DESC"); + $queries[] = array("$name: status set to 'queued'", "WHERE n.type = '$name' AND n.status = '". node_status("queued") ."' ORDER BY n.timestamp DESC"); + $queries[] = array("$name: status set to 'dumped'", "WHERE n.type = '$name' AND n.status = '". node_status("dumped") ."' ORDER BY n.timestamp DESC"); + $queries[] = array("$name: scheduled to be posted", "WHERE n.type = '$name' AND n.timestamp_posted > 0 ORDER BY n.timestamp DESC"); + $queries[] = array("$name: scheduled to be queued", "WHERE n.type = '$name' AND n.timestamp_queued > 0 ORDER BY n.timestamp DESC"); + $queries[] = array("$name: scheduled to be hidden", "WHERE n.type = '$name' AND n.timestamp_hidden > 0 ORDER BY n.timestamp DESC"); + } + } + return ($queries[$type] ? $queries[$type] : $queries); } @@ -118,13 +165,13 @@ function node_setting() { foreach (module_list() as $name) { if (module_hook($name, "user")) { $form .= "

Default settings for $name nodes

"; - $form .= form_select(t("Comment"), $name ."_comment", variable_get($name ."_comment", 0), node_comment_status(), t("By default, allow or dissallow users to post comments in this category.")); - $form .= form_select(t("Promote"), $name ."_promote", variable_get($name ."_promote", 0), node_promote_status(), t("By default, promote new submissions in this category to the front page.")); - $form .= form_select(t("Status"), $name ."_status", variable_get($name ."_status", node_status("queued")), node_status($name), t("What to do with new submissions in this category?")); - $form .= form_select(t("Post threshold"), $name ."_post", variable_get($name ."_post", 4), $threshold_post, t("If new submissions are subject to moderation, select a post threshold.")); - $form .= form_select(t("Dump threshold"), $name ."_dump", variable_get($name ."_dump", -2), $threshold_dump, t("If new submissions are subject to moderation, select a dump threshold.")); - $form .= form_select(t("Expiration threshold"), $name ."_expire", variable_get($name ."_expire", 8), $threshold_expire, t("If new submissions are subject to moderation, select a expiration threshold.")); - $form .= form_textfield("Moderate", $name ."_moderate", variable_get($name ."_moderate", ""), 35, 255, t("Provide a comma-seperated list of the moderators' usernames.")); + $form .= form_select(t("Comment"), $name ."_comment", variable_get($name ."_comment", 0), node_comment_status(), "By default, allow or dissallow users to post comments in this category."); + $form .= form_select(t("Promote"), $name ."_promote", variable_get($name ."_promote", 0), node_promote_status(), "By default, promote new submissions in this category to the front page."); + $form .= form_select(t("Status"), $name ."_status", variable_get($name ."_status", node_status("queued")), node_status($name), "What to do with new submissions in this category?"); + $form .= form_select(t("Post threshold"), $name ."_post", variable_get($name ."_post", 4), $threshold_post, "If new submissions are subject to moderation, select a post threshold."); + $form .= form_select(t("Dump threshold"), $name ."_dump", variable_get($name ."_dump", -2), $threshold_dump, "If new submissions are subject to moderation, select a dump threshold."); + $form .= form_select(t("Expiration threshold"), $name ."_expire", variable_get($name ."_expire", 8), $threshold_expire, "If new submissions are subject to moderation, select a expiration threshold."); + $form .= form_textfield("Moderate", $name ."_moderate", variable_get($name ."_moderate", ""), 35, 255, "A comma-seperated list of the moderators' usernames."); } } @@ -134,23 +181,83 @@ function node_setting() { return form($REQUEST_URI, $form); } -function node_admin() { - global $op, $id, $edit, $type; +function node_admin_save($edit) { + if (isset($edit[status])) { + $edit[timestamp_posted] = (strtotime($edit[timestamp_posted]) > time()) ? strtotime($edit[timestamp_posted]) : 0; + $edit[timestamp_queued] = (strtotime($edit[timestamp_queued]) > time()) ? strtotime($edit[timestamp_queued]) : 0; + $edit[timestamp_hidden] = (strtotime($edit[timestamp_hidden]) > time()) ? strtotime($edit[timestamp_hidden]) : 0; + node_save($edit, array(status, timestamp_posted, timestamp_queued, timestamp_hidden)); + } + else if (isset($edit[attribute])) { + node_save($edit, array(attribute)); + } + else { + node_save($edit, array(comment, moderate, promote)); + } +} - print "node settings | node listings | overview
\n"; +function node_search() { + global $REQUEST_URI; + + foreach (module_list() as $name) { + if (module_hook($name, "user")) { + $options .= "\n"; + } + } + + $output .= "
\n"; + $output .= " \n"; + $output .= " \n"; + $output .= " \n"; + $output .= "
\n"; + + return $output; +} + +function node_module_edit($edit, $type) { + $edit[type] = $type; + return node_invoke($edit, "form"); +} + +function node_module_save($edit, $type) { + $edit[type] = $type; + return node_invoke($edit, "save"); +} + +function node_admin() { + global $op, $id, $edit, $query, $type, $keys; + + foreach (module_list() as $name) { + if (module_hook($name, "status") && $name != "node") { + $link[] = "add $name"; + } + } + + print "". implode(" | ", $link) ." | node settings | node listings | search node | overview
\n"; $id = check_input($edit[nid] ? $edit[nid] : $id); - $type = ($type ? $type : 0); switch ($op) { - case "Edit node": - case "edit": - print node_admin_edit($id); + case "add": + print module_invoke($type, "form"); + break; + case "search": + print node_search($id); + print search_data($keys, $type); + break; + case "status": + print node_edit_status($id); + break; + case "option": + print node_edit_option($id); + break; + case "attribute": + print node_edit_attribute($id); break; case "default": print node_setting(); break; - case "Delete node": + case "delete": print status(node_delete($id)); print node_overview(); break; @@ -166,15 +273,20 @@ function node_admin() { print node_setting(); break; case "Save node": - node_save($edit, array(author, comment, moderate, promote, status, timestamp)); - print node_admin_view($id); + print node_admin_save($edit); + print node_overview(); break; - case "View node": - case "view": - print node_admin_view($id); + case "edit": + print node_module_edit(node_get_array(array("nid" => $id)), $type); break; + case "Preview": + print node_module_edit($edit, $type); + break; + case "Submit": + print status(node_module_save($edit, $type)); + // fall through: default: - print node_overview(node_query($type)); + print node_overview(node_query($query ? $query : 0)); } } diff --git a/modules/node/node.module b/modules/node/node.module index 8222393ed8f..8aeb5715cee 100644 --- a/modules/node/node.module +++ b/modules/node/node.module @@ -39,64 +39,111 @@ function node_filter($text) { return $text; } +function node_cron() { + db_query("UPDATE node SET status = '". node_status("posted") ."', timestamp_posted = '' WHERE timestamp_posted > 0 AND timestamp_posted < ". time()); + db_query("UPDATE node SET status = '". node_status("queued") ."', timestamp_posted = '' WHERE timestamp_queued > 0 AND timestamp_queued < ". time()); + db_query("UPDATE node SET status = '". node_status("dumped") ."', timestamp_posted = '' WHERE timestamp_hidden > 0 AND timestamp_hidden < ". time()); +} + function node_overview($query = array()) { global $user; + $colors = array("#ffdc9b", "#dedec4"); + $result = db_query("SELECT n.*, u.userid, c.name AS category FROM node n LEFT JOIN users u ON n.author = u.id LEFT JOIN category c ON n.cid = c.cid $query[1] LIMIT 50"); $output .= status($query[0]); $output .= "\n"; - $output .= " \n"; + $output .= " \n"; + while ($node = db_fetch_object($result)) { - $output .= " \n"; + unset ($link); + + $link[] = user_access($user, $node->type) ? "type&op=edit&id=$node->nid\">edit content" : "edit content"; + $link[] = user_access($user, "node") ? "nid\">edit options" : "edit options"; + $link[] = user_access($user, "node") ? "nid\">edit status" : "edit status"; + $link[] = user_access($user, "node") ? "nid\">edit attributes" : "edit attributes"; + $link[] = user_access($user, "node") ? "nid\">delete node" : "delete node"; + + $color = $colors[$i++ % sizeof($colors)]; + + $output .= " \n"; + $output .= " \n"; } $output .= "
titlecategorystatusauthordateoperations
titletypestatusmeta attributesauthordate
nid\">". check_output($node->title) ."". check_output($node->category ? $node->category : $node->type) ."". node_status($node->status) ."". format_username($node->userid) ."". format_date($node->timestamp, "small") ."". (user_access($user, "node") ? "nid\">edit node" : "edit node") ."". (user_access($user, $node->type) ? "type&op=edit&id=$node->nid\">edit $node->type" : "edit $node->type") ."
nid\">". check_output($node->title) ."$node->type". node_status($node->status) ."". check_output($node->attribute) ."". format_username($node->userid) ."". format_date($node->timestamp, "small") ."
". implode(", ", $link) ."
\n"; return $output; } -function node_admin_view($id) { - $node = node_get_object(array("nid" => $id)); - - $form .= form_item("Title", check_output($node->title)); - $form .= form_item("Author", format_username($node->userid)); - $form .= form_item("Status", node_status($node->status)); - $form .= form_item("Comment", node_comment_status($node->comment)); - $form .= form_item("Promote", node_promote_status($node->promote)); - $form .= form_item("Moderate", check_output($node->moderate)); - $form .= form_item("Date", format_date($node->timestamp)); - $form .= form_submit("Edit node"); - $form .= form_submit("Delete node"); - - return form("admin.php?mod=node&id=$node->nid", $form); -} - -function node_admin_edit($id) { +function node_edit_option($id) { global $user; $node = node_get_object(array("nid" => $id)); - $form .= form_item("Title", check_output($node->title)); - $form .= form_select("Author", "author", $node->author, array($node->author => $node->userid, $user->id => $user->userid)); - $form .= form_select("Status", "status", $node->status, node_status($node->type)); - $form .= form_select("Comment", "comment", $node->comment, node_comment_status()); - $form .= form_select("Promote", "promote", $node->promote, node_promote_status()); - $form .= form_textfield("Moderate", "moderate", $node->moderate, 35, 255, t("Provide a comma-seperated list of the moderators their usernames.")); - $form .= form_select("Date", "timestamp", $node->timestamp, array($node->timestamp => format_date($node->timestamp) ." (original)", time() => format_date(time()) ." (current)")); + $form .= form_item("Document title", check_output($node->title)); + $form .= form_select("Comment", "comment", $node->comment, node_comment_status(), "Allow users to post comments to this document."); + $form .= form_select("Promote", "promote", $node->promote, node_promote_status(), "Promote this document on the main page."); + $form .= form_textfield("Moderate", "moderate", $node->moderate, 35, 255, t("A comma-seperated list of the moderators their usernames.")); $form .= form_hidden("nid", $node->nid); $form .= form_submit("Save node"); - $form .= form_submit("View node"); return form("admin.php?mod=node&id=$node->nid", $form); } +function node_edit_attribute($id) { + global $user; + + $node = node_get_object(array("nid" => $id)); + + $form .= form_item("Document title", check_output($node->title)); + $form .= form_textfield("Attributes", "attribute", $edit[attribute], 50, 128, htmlentities("A list meta attributes. Format: :;:;. Example: 'software:apache;type:webserver;os:linux;'.")); + $form .= form_hidden("nid", $node->nid); + $form .= form_submit("Save node"); + + return form("admin.php?mod=node&id=$node->nid", $form); +} + +function node_edit_status($id) { + global $REQUEST_URI; + + $node = node_get_object(array("nid" => $id)); + + $form .= form_item("Document title", check_output($node->title)); + $form .= form_select("Current status", "status", $node->status, node_status($node->type)); + $form .= form_textfield("Automatically post document", "timestamp_posted", ($node->timestamp_posted ? format_date($node->timestamp_posted) : ""), 30, 55, "The date at which your document will be automatically posted. Leave empty if you don't want to schedule this document, or fill out a string containing an English date format. Example input: '". date("j F Y G:i") ."', '". date("m/d/y H:i") ."', '". date("F j, Y H:i") ."', ..."); + $form .= form_textfield("Automatically queue document", "timestamp_queued", ($node->timestamp_queued ? format_date($node->timestamp_queued) : ""), 30, 55, "The date at which your document will be automatically queued. Leave empty if you don't want to schedule this document, or fill out a string containing an English date format. Example input: '". date("j F Y G:i") ."', '". date("m/d/y H:i") ."', '". date("F j, Y H:i") ."', ..."); + $form .= form_textfield("Automatically hide document", "timestamp_hidden", ($node->timestamp_hidden ? format_date($node->timestamp_hidden) : ""), 30, 55, "The date at which your document will be automatically hidden. Leave empty if you don't want to schedule this document, or fill out a string containing an English date format. Example input: '". date("j F Y G:i") ."', '". date("m/d/y H:i") ."', '". date("F j, Y H:i") ."', ..."); + $form .= form_hidden("nid", $node->nid); + $form .= form_submit("Save node"); + + return form($REQUEST_URI, $form); +} + function node_delete($id) { return (node_del(array("nid" => $id)) ? "node has been deleted." : "failed to delete node: node must be dumped first."); } function node_query($type = "") { - global $status; - $queries = array(array("recent nodes", "ORDER BY n.timestamp DESC"), array("posted nodes", "WHERE n.status = '$status[posted]' ORDER BY n.timestamp DESC"), array("queued nodes", "WHERE n.status = '$status[queued]' ORDER BY n.timestamp DESC"), array("dumped nodes", "WHERE n.status = '$status[dumped]' ORDER BY n.timestamp DESC")); + $queries[] = array("all nodes: recent additions", "ORDER BY n.timestamp DESC"); + $queries[] = array("all nodes: status set to 'posted'", "WHERE n.status = '". node_status("posted") ."' ORDER BY n.timestamp DESC"); + $queries[] = array("all nodes: status set to 'queued'", "WHERE n.status = '". node_status("queued") ."' ORDER BY n.timestamp DESC"); + $queries[] = array("all nodes: status set to 'dumped'", "WHERE n.status = '". node_status("dumped") ."' ORDER BY n.timestamp DESC"); + $queries[] = array("all nodes: scheduled to be posted", "WHERE n.timestamp_posted > 0 ORDER BY n.timestamp DESC"); + $queries[] = array("all nodes: scheduled to be queued", "WHERE n.timestamp_queued > 0 ORDER BY n.timestamp DESC"); + $queries[] = array("all nodes: scheduled to be hidden", "WHERE n.timestamp_hidden > 0 ORDER BY n.timestamp DESC"); + + foreach (module_list() as $name) { + if (module_hook($name, "user")) { + $queries[] = array("$name: recent additions", "WHERE n.type = '$name' ORDER BY n.timestamp DESC"); + $queries[] = array("$name: status set to 'posted'", "WHERE n.type = '$name' AND n.status = '". node_status("posted") ."' ORDER BY n.timestamp DESC"); + $queries[] = array("$name: status set to 'queued'", "WHERE n.type = '$name' AND n.status = '". node_status("queued") ."' ORDER BY n.timestamp DESC"); + $queries[] = array("$name: status set to 'dumped'", "WHERE n.type = '$name' AND n.status = '". node_status("dumped") ."' ORDER BY n.timestamp DESC"); + $queries[] = array("$name: scheduled to be posted", "WHERE n.type = '$name' AND n.timestamp_posted > 0 ORDER BY n.timestamp DESC"); + $queries[] = array("$name: scheduled to be queued", "WHERE n.type = '$name' AND n.timestamp_queued > 0 ORDER BY n.timestamp DESC"); + $queries[] = array("$name: scheduled to be hidden", "WHERE n.type = '$name' AND n.timestamp_hidden > 0 ORDER BY n.timestamp DESC"); + } + } + return ($queries[$type] ? $queries[$type] : $queries); } @@ -118,13 +165,13 @@ function node_setting() { foreach (module_list() as $name) { if (module_hook($name, "user")) { $form .= "

Default settings for $name nodes

"; - $form .= form_select(t("Comment"), $name ."_comment", variable_get($name ."_comment", 0), node_comment_status(), t("By default, allow or dissallow users to post comments in this category.")); - $form .= form_select(t("Promote"), $name ."_promote", variable_get($name ."_promote", 0), node_promote_status(), t("By default, promote new submissions in this category to the front page.")); - $form .= form_select(t("Status"), $name ."_status", variable_get($name ."_status", node_status("queued")), node_status($name), t("What to do with new submissions in this category?")); - $form .= form_select(t("Post threshold"), $name ."_post", variable_get($name ."_post", 4), $threshold_post, t("If new submissions are subject to moderation, select a post threshold.")); - $form .= form_select(t("Dump threshold"), $name ."_dump", variable_get($name ."_dump", -2), $threshold_dump, t("If new submissions are subject to moderation, select a dump threshold.")); - $form .= form_select(t("Expiration threshold"), $name ."_expire", variable_get($name ."_expire", 8), $threshold_expire, t("If new submissions are subject to moderation, select a expiration threshold.")); - $form .= form_textfield("Moderate", $name ."_moderate", variable_get($name ."_moderate", ""), 35, 255, t("Provide a comma-seperated list of the moderators' usernames.")); + $form .= form_select(t("Comment"), $name ."_comment", variable_get($name ."_comment", 0), node_comment_status(), "By default, allow or dissallow users to post comments in this category."); + $form .= form_select(t("Promote"), $name ."_promote", variable_get($name ."_promote", 0), node_promote_status(), "By default, promote new submissions in this category to the front page."); + $form .= form_select(t("Status"), $name ."_status", variable_get($name ."_status", node_status("queued")), node_status($name), "What to do with new submissions in this category?"); + $form .= form_select(t("Post threshold"), $name ."_post", variable_get($name ."_post", 4), $threshold_post, "If new submissions are subject to moderation, select a post threshold."); + $form .= form_select(t("Dump threshold"), $name ."_dump", variable_get($name ."_dump", -2), $threshold_dump, "If new submissions are subject to moderation, select a dump threshold."); + $form .= form_select(t("Expiration threshold"), $name ."_expire", variable_get($name ."_expire", 8), $threshold_expire, "If new submissions are subject to moderation, select a expiration threshold."); + $form .= form_textfield("Moderate", $name ."_moderate", variable_get($name ."_moderate", ""), 35, 255, "A comma-seperated list of the moderators' usernames."); } } @@ -134,23 +181,83 @@ function node_setting() { return form($REQUEST_URI, $form); } -function node_admin() { - global $op, $id, $edit, $type; +function node_admin_save($edit) { + if (isset($edit[status])) { + $edit[timestamp_posted] = (strtotime($edit[timestamp_posted]) > time()) ? strtotime($edit[timestamp_posted]) : 0; + $edit[timestamp_queued] = (strtotime($edit[timestamp_queued]) > time()) ? strtotime($edit[timestamp_queued]) : 0; + $edit[timestamp_hidden] = (strtotime($edit[timestamp_hidden]) > time()) ? strtotime($edit[timestamp_hidden]) : 0; + node_save($edit, array(status, timestamp_posted, timestamp_queued, timestamp_hidden)); + } + else if (isset($edit[attribute])) { + node_save($edit, array(attribute)); + } + else { + node_save($edit, array(comment, moderate, promote)); + } +} - print "node settings | node listings | overview
\n"; +function node_search() { + global $REQUEST_URI; + + foreach (module_list() as $name) { + if (module_hook($name, "user")) { + $options .= "\n"; + } + } + + $output .= "
\n"; + $output .= " \n"; + $output .= " \n"; + $output .= " \n"; + $output .= "
\n"; + + return $output; +} + +function node_module_edit($edit, $type) { + $edit[type] = $type; + return node_invoke($edit, "form"); +} + +function node_module_save($edit, $type) { + $edit[type] = $type; + return node_invoke($edit, "save"); +} + +function node_admin() { + global $op, $id, $edit, $query, $type, $keys; + + foreach (module_list() as $name) { + if (module_hook($name, "status") && $name != "node") { + $link[] = "add $name"; + } + } + + print "". implode(" | ", $link) ." | node settings | node listings | search node | overview
\n"; $id = check_input($edit[nid] ? $edit[nid] : $id); - $type = ($type ? $type : 0); switch ($op) { - case "Edit node": - case "edit": - print node_admin_edit($id); + case "add": + print module_invoke($type, "form"); + break; + case "search": + print node_search($id); + print search_data($keys, $type); + break; + case "status": + print node_edit_status($id); + break; + case "option": + print node_edit_option($id); + break; + case "attribute": + print node_edit_attribute($id); break; case "default": print node_setting(); break; - case "Delete node": + case "delete": print status(node_delete($id)); print node_overview(); break; @@ -166,15 +273,20 @@ function node_admin() { print node_setting(); break; case "Save node": - node_save($edit, array(author, comment, moderate, promote, status, timestamp)); - print node_admin_view($id); + print node_admin_save($edit); + print node_overview(); break; - case "View node": - case "view": - print node_admin_view($id); + case "edit": + print node_module_edit(node_get_array(array("nid" => $id)), $type); break; + case "Preview": + print node_module_edit($edit, $type); + break; + case "Submit": + print status(node_module_save($edit, $type)); + // fall through: default: - print node_overview(node_query($type)); + print node_overview(node_query($query ? $query : 0)); } } diff --git a/modules/page.module b/modules/page.module index 9af1b2c9cdd..99b6c7954a3 100644 --- a/modules/page.module +++ b/modules/page.module @@ -26,12 +26,12 @@ function page_status() { function page_form($edit = array()) { global $format, $REQUEST_URI; - $form .= form_textfield(t("Subject"), "title", $edit[title], 50, 64); + $form .= form_textfield("Subject", "title", $edit[title], 50, 64); $form .= structure_form("page", $edit); - $form .= form_textarea(t("Body"), "body", $edit[body], 50, 10); - $form .= form_select(t("Type"), "format", $edit[format], $format); + $form .= form_textarea("Body", "body", $edit[body], 50, 10); + $form .= form_select("Type", "format", $edit[format], $format); $form .= form_hidden("nid", $edit[nid]); - $form .= form_submit(t("Submit")); + $form .= form_submit("Submit"); return form($REQUEST_URI, $form); } @@ -44,39 +44,4 @@ function page_save($edit) { } } -function page_query($type = "") { - global $status; - $queries = array(array("recent pages", "WHERE n.type = 'page' ORDER BY n.timestamp DESC"), array("posted pages", "WHERE n.type = 'page' AND n.status = '$status[posted]' ORDER BY n.timestamp DESC"), array("dumped pages", "WHERE n.type = 'page' AND n.status = '$status[dumped]' ORDER BY n.timestamp DESC")); - return ($queries[$type] ? $queries[$type] : $queries); -} - -function page_overview($query = array()) { - return node_overview($query); -} - -function page_admin() { - global $id, $op, $edit, $type; - - print "add new page | page listing | overview
\n"; - - $type = ($type ? $type : 0); - - switch ($op) { - case "add": - print page_form(); - break; - case "edit": - print page_form(node_get_array(array(nid => $id))); - break; - case "listing": - print node_listing(page_query()); - break; - case t("Submit"): - print status(page_save($edit)); - // fall through: - default: - print page_overview(page_query($type)); - } -} - ?> \ No newline at end of file diff --git a/modules/page/page.module b/modules/page/page.module index 9af1b2c9cdd..99b6c7954a3 100644 --- a/modules/page/page.module +++ b/modules/page/page.module @@ -26,12 +26,12 @@ function page_status() { function page_form($edit = array()) { global $format, $REQUEST_URI; - $form .= form_textfield(t("Subject"), "title", $edit[title], 50, 64); + $form .= form_textfield("Subject", "title", $edit[title], 50, 64); $form .= structure_form("page", $edit); - $form .= form_textarea(t("Body"), "body", $edit[body], 50, 10); - $form .= form_select(t("Type"), "format", $edit[format], $format); + $form .= form_textarea("Body", "body", $edit[body], 50, 10); + $form .= form_select("Type", "format", $edit[format], $format); $form .= form_hidden("nid", $edit[nid]); - $form .= form_submit(t("Submit")); + $form .= form_submit("Submit"); return form($REQUEST_URI, $form); } @@ -44,39 +44,4 @@ function page_save($edit) { } } -function page_query($type = "") { - global $status; - $queries = array(array("recent pages", "WHERE n.type = 'page' ORDER BY n.timestamp DESC"), array("posted pages", "WHERE n.type = 'page' AND n.status = '$status[posted]' ORDER BY n.timestamp DESC"), array("dumped pages", "WHERE n.type = 'page' AND n.status = '$status[dumped]' ORDER BY n.timestamp DESC")); - return ($queries[$type] ? $queries[$type] : $queries); -} - -function page_overview($query = array()) { - return node_overview($query); -} - -function page_admin() { - global $id, $op, $edit, $type; - - print "add new page | page listing | overview
\n"; - - $type = ($type ? $type : 0); - - switch ($op) { - case "add": - print page_form(); - break; - case "edit": - print page_form(node_get_array(array(nid => $id))); - break; - case "listing": - print node_listing(page_query()); - break; - case t("Submit"): - print status(page_save($edit)); - // fall through: - default: - print page_overview(page_query($type)); - } -} - ?> \ No newline at end of file diff --git a/updates/2.00-to-x.xx.sql b/updates/2.00-to-x.xx.sql index 4879a67807c..c0c1890ce1d 100644 --- a/updates/2.00-to-x.xx.sql +++ b/updates/2.00-to-x.xx.sql @@ -209,3 +209,9 @@ CREATE TABLE poll_choices ( PRIMARY KEY (chid) ); +# 04/06/01 + +ALTER TABLE node ADD timestamp_posted int(11) NOT NULL; +ALTER TABLE node ADD timestamp_queued int(11) NOT NULL; +ALTER TABLE node ADD timestamp_hidden int(11) NOT NULL; +ALTER TABLE node ADD attribute varchar(255) DEFAULT '' NOT NULL;