drupal/modules/story.module

94 lines
3.8 KiB
Plaintext
Raw Normal View History

<?php
// $Id$
function story_help($section = "admin/help#story") {
$output = "";
switch ($section) {
case 'admin/system/modules#description':
$output = t("Enables users to submit stories, articles or similar content.");
break;
case 'admin/system/modules/story':
$output = t("Stories are like newspaper articles. They tend to follow a publishing flow of <strong>submit -&gt; moderate -&gt; post to the main page -&gt; comments</strong>. Below you may fix a minimum word count for stories and also write some submission or content guidelines for users wanting to post a story.");
break;
case 'admin/help#story':
$output = t("
<p>The story module lets your users submit articles for consideration by the rest of the community, who can vote on them if moderation is enabled. Stories usually follow a publishing flow of <strong>submit -&gt; moderate -&gt; post to the main page -&gt; comments</strong>. Administrators are able to shortcut this flow as desired.</p>
In <a href=\"%story-config\">administer &raquo; configuration &raquo; modules &raquo; story</a> you can set up an introductory text for story authors, and a floor on the number of words which may be included in a story. This is designed to help discourage the submission of trivially short stories.", array("%story-config" => url("admin/system/modules/story")));
break;
case 'node/add/story':
$output = variable_get('story_help', '');
break;
}
return $output;
}
function story_settings() {
$output .= form_textarea("Explanation or submission guidelines", "story_help", variable_get("story_help", ""), 70, 5, "This text will be displayed at the top of the story submission form. It is useful for helping or instructing your users.");
$output .= form_select(t("Minimum number of words"), "minimum_story_size", variable_get("minimum_story_size", 0), array(0 => "0 words", 10 => "10 words", 25 => "25 words", 50 => "50 words", 75 => "75 words", 100 => "100 words", 125 => "125 words", 150 => "150 words", 175 => "175 words", 200 => "200 words"), t("The minimum number of words a story must be to be considered valid. This can be useful to rule out submissions that do not meet the site's standards, such as short test posts."));
return $output;
}
function story_node($field) {
$info["name"] = t("story");
$info["description"] = t("A story is a post that is submitted to the attention of other users and is queued in the submission queue. Users and moderators vote on the posts they like or dislike, promoting or demoting them. When a post gets above a certain threshold it automatically gets promoted to the front page.");
return $info[$field];
}
function story_perm() {
return array("create stories");
}
function story_access($op, $node) {
if ($op == "view") {
return $node->status;
}
if ($op == "create") {
return user_access("create stories");
}
}
function story_link($type) {
2003-04-21 14:55:03 +00:00
$links = array();
if ($type == "system") {
if (user_access("create stories")) {
menu("node/add/story", t("story"), "node_page", 0);
}
}
2003-04-21 14:55:03 +00:00
return $links;
}
function story_validate(&$node) {
/*
** Validate the size of the story:
*/
if (isset($node->body) && count(explode(" ", $node->body)) < variable_get("minimum_story_size", 0)) {
$error["body"] = "<div class=\"error\">". t("The body of your story is too short.") ."</div>";
}
return $error;
}
function story_form(&$node, &$error) {
if (function_exists("taxonomy_node_form")) {
$output .= implode("", taxonomy_node_form("story", $node));
}
$output .= form_textarea(t("Body"), "body", $node->body, 60, 15, $error["body"] ? $error["body"] : form_allowed_tags_text());
return $output;
}
function story_content($node, $main = 0) {
return node_prepare($node, $main);
}
?>