aboutsummaryrefslogtreecommitdiff
path: root/mod
diff options
context:
space:
mode:
authorbrettp <brettp@36083f99-b078-4883-b0ff-0f9b5a30f544>2010-03-09 04:22:35 +0000
committerbrettp <brettp@36083f99-b078-4883-b0ff-0f9b5a30f544>2010-03-09 04:22:35 +0000
commit9bb993778bc7a0c6f17673e509ed147202e69ee7 (patch)
treeafb5951de431ea1cb5e0e0048d7f120ff28b23ef /mod
parent4e2a58e02ae4fe55ebc801a816c6ddb304df4b18 (diff)
downloadelgg-9bb993778bc7a0c6f17673e509ed147202e69ee7.tar.gz
elgg-9bb993778bc7a0c6f17673e509ed147202e69ee7.tar.bz2
Added dynamic keywords for view and entity.
Separated logged in and logged out front page views. Fixed a problem with saving metatags. Added PHPDoc headers. Updated language strings. git-svn-id: http://code.elgg.org/elgg/trunk@5315 36083f99-b078-4883-b0ff-0f9b5a30f544
Diffstat (limited to 'mod')
-rw-r--r--mod/sitepages/actions/addfront.php9
-rw-r--r--mod/sitepages/actions/addmeta.php4
-rw-r--r--mod/sitepages/languages/en.php34
-rw-r--r--mod/sitepages/sitepages_functions.php107
-rw-r--r--mod/sitepages/start.php37
-rw-r--r--mod/sitepages/views/default/settings/sitepages/edit.php12
-rw-r--r--mod/sitepages/views/default/sitepages/custom_frontpage.php10
-rw-r--r--mod/sitepages/views/default/sitepages/footer_menu.php10
-rw-r--r--mod/sitepages/views/default/sitepages/forms/editfront.php25
-rw-r--r--mod/sitepages/views/default/sitepages/forms/editmeta.php2
-rw-r--r--mod/sitepages/views/default/sitepages/keywords.php3
-rw-r--r--mod/sitepages/views/default/sitepages/metatags.php12
12 files changed, 230 insertions, 35 deletions
diff --git a/mod/sitepages/actions/addfront.php b/mod/sitepages/actions/addfront.php
index 6b8782da7..fd2154cc3 100644
--- a/mod/sitepages/actions/addfront.php
+++ b/mod/sitepages/actions/addfront.php
@@ -12,7 +12,9 @@
admin_gatekeeper();
-$content = get_input('sitepages_content', '', FALSE);
+$logged_in_content = get_input('logged_in_content', '', FALSE);
+$logged_out_content = get_input('logged_out_content', '', FALSE);
+
$css = get_input('css', '', FALSE);
$loggedin_user_guid = get_loggedin_userid();
@@ -25,8 +27,9 @@ if (!$sitepage = sitepages_get_sitepage_object('front')) {
$sitepage = sitepages_create_sitepage_object('front');
}
-$sitepage->title = $css;
-$sitepage->description = $content;
+$sitepage->css = $css;
+$sitepage->logged_in_content = $logged_in_content;
+$sitepage->logged_out_content = $logged_out_content;
if ($sitepage->save()) {
system_message(elgg_echo("sitepages:posted"));
diff --git a/mod/sitepages/actions/addmeta.php b/mod/sitepages/actions/addmeta.php
index e9f40cdb4..e5c947776 100644
--- a/mod/sitepages/actions/addmeta.php
+++ b/mod/sitepages/actions/addmeta.php
@@ -19,8 +19,8 @@ $metatags = get_input('metatags', '', FALSE);
$_SESSION['description'] = $description;
$_SESSION['metatags'] = $metatags;
-if (!$sitepage = sitepages_get_sitepage_object('front')) {
- $sitepage = sitepages_create_sitepage_object('front');
+if (!$sitepage = sitepages_get_sitepage_object('seo')) {
+ $sitepage = sitepages_create_sitepage_object('seo');
}
$sitepage->title = $metatags;
diff --git a/mod/sitepages/languages/en.php b/mod/sitepages/languages/en.php
index ec08493c9..92cddb949 100644
--- a/mod/sitepages/languages/en.php
+++ b/mod/sitepages/languages/en.php
@@ -29,7 +29,8 @@ $english = array(
'sitepages:metadescription' => "Meta description for search engines",
'sitepages:metatags' => "Meta tags for search engines (use a comma)",
'sitepages:seocreated' => "Your search engine information has been added",
- 'sitepages:front_content' => "Frontpage content",
+ 'sitepages:logged_in_front_content' => "Logged in front page content",
+ 'sitepages:logged_out_front_content' => "Logged out front page content",
'sitepages:ownfront' => "Construct your own frontpage for this network. (Note:you will need to know html and css)",
'sitepages:addcontent' => "You can add content here via your admin tools. Look for the external pages link under admin.",
'item:object:front' => 'Front page items',
@@ -45,6 +46,37 @@ $english = array(
*/
'sitepages:deleteerror' => "There was a problem deleting the old page",
'sitepages:error' => "There has been an error, please try again and if the problem persists, contact the administrator",
+
+ /**
+ * Key words
+ */
+ 'sitepages:keywords_title' => 'Keywords',
+ 'sitepages:keywords_instructions' =>
+ 'Keywords are replaced with content when viewed. They must be surrounded by
+ two square brackets ([[ and ]]). You can build your own or use the ones listed below.
+ Hover over a keyword to read its description.',
+
+ 'sitepages:keywords_instructions_more' =>
+ '
+ You can build your own keywords for views and entities.<br /><br />
+
+ [[entity: type=type, subtype=subtype, owner=username, limit=number]]<br />
+
+ EX: To show 5 blog posts by admin:<br />
+ [[entity: type=object, subtype=blog, owner=admin, limit=5]]
+
+ <br /><br />
+
+ You can also specify a valid Elgg view:<br />
+ [[view: elgg_view, name=value]]<br />
+
+ Ex: To show a text input with a default value:<br />
+ [[view: input/text, value=This is a default value]]
+
+ <br /><br />',
+
+ 'sitepages:keywords:login_box' => 'A standard login box. Useful for the logged out content area.',
+ 'sitepages:keywords:site_stats' => 'This does not exist yet.',
);
add_translation('en', $english); \ No newline at end of file
diff --git a/mod/sitepages/sitepages_functions.php b/mod/sitepages/sitepages_functions.php
index 7ffe8df63..0341b590b 100644
--- a/mod/sitepages/sitepages_functions.php
+++ b/mod/sitepages/sitepages_functions.php
@@ -10,10 +10,6 @@
*/
-function sitepages_parse_frontpage($contents){
- echo htmlspecialchars_decode($contents, ENT_NOQUOTES);
-}
-
/**
* Returns a single object that holds information about
* customizations for the $section site page. The object guid
@@ -115,6 +111,109 @@ function sitepages_get_page_content($page_type) {
return $content;
}
+
+/**
+ * Used to determine how to handle special non-static keywords.
+ *
+ * @param unknown_type $matches
+ * @return html
+ */
+function sitepages_parse_view_match($matches) {
+ $keyword = $matches[0];
+ $type = trim($matches[1]);
+ $params_string = trim($matches[2]);
+
+ switch ($type) {
+ case 'entity':
+ $options = sitepages_keywords_parse_entity_params($params_string);
+ // must use this lower-level function because I missed refactoring
+ // the list entity functions for relationships.
+ // (which, since you're here, is the only function that runs through all
+ // possible options for elgg_get_entities*() functions...)
+ $entities = elgg_get_entities_from_relationship($options);
+ $content = elgg_view_entity_list($entities, count($entities), $options['offset'],
+ $options['limit'], $options['full_view'], $options['view_type_toggle'], $options['pagination']);
+ break;
+
+ case 'view':
+ // parses this into an acceptable array for $vars.
+ $info = sitepages_keywords_parse_view_params($params_string);
+ $content = elgg_view($info['view'], $info['vars']);
+
+ break;
+
+ }
+
+ return $content;
+}
+
+/**
+ * Creates an array from a "name=value, name1=value2" string.
+ *
+ * @param $string
+ * @return array
+ */
+function sitepages_keywords_tokenize_params($string) {
+ $pairs = array_map('trim', explode(',', $string));
+
+ $params = array();
+
+ foreach ($pairs as $pair) {
+ list($name, $value) = explode('=', $pair);
+
+ $name = trim($name);
+ $value = trim($value);
+ $params[$name] = $value;
+ }
+
+ return $params;
+}
+
+/**
+ *
+ * @param $string
+ * @return unknown_type
+ */
+function sitepages_keywords_parse_view_params($string) {
+ $vars = sitepages_keywords_tokenize_params($string);
+
+ // the first element key is the view
+ $var_keys = array_keys($vars);
+ $view = $var_keys[0];
+
+ $info = array(
+ 'view' => $view,
+ 'vars' => $vars
+ );
+
+ return $info;
+
+}
+
+/**
+ * Returns an options array suitable for using in elgg_get_entities()
+ *
+ * @param string $string "name=value, name2=value2"
+ * @return array
+ */
+function sitepages_keywords_parse_entity_params($string) {
+ $params = sitepages_keywords_tokenize_params($string);
+
+ // handle some special cases
+ if (isset($params['owner'])) {
+ if ($user = get_user_by_username($params['owner'])) {
+ $options['owner_guid'] = $user->getGUID();
+ }
+ }
+
+ // @todo probably need to add more for
+ // group -> container_guid, etc
+
+ return $params;
+}
+
+
+
/**
* Utility object to store site page information.
*/
diff --git a/mod/sitepages/start.php b/mod/sitepages/start.php
index 186738bab..5be36842a 100644
--- a/mod/sitepages/start.php
+++ b/mod/sitepages/start.php
@@ -11,8 +11,16 @@
* @copyright Curverider Ltd 2008-2010
* @link http://elgg.org/
*
- * @todo Implement sticky pages
- * @todo DRY up actions and views
+ * @todo
+ * Check for SQL injection problems.
+ * Make sure this stuff doesn't show up in search.
+ * Check entity keyword views against fullview. Force to FALSE?
+ * DRY up actions and views
+ * Implement sticky forms
+ * Use $entity->view to redirect to url of page.
+ * The tool settings view is probably not needed as it can be added to the front page edit tab.
+ * You can say pg/sitepages/edit|read/any_page_i_want and it will let you.
+ * Clean up and probably move the docs for keywords.
*/
/**
@@ -93,6 +101,8 @@ function sitepages_custom_index() {
}
set_context($context);
+
+ // return NULL to pass this to next in chain, or back to standard index.php.
return NULL;
}
@@ -161,12 +171,24 @@ function sitepages_page_handler($page) {
page_draw($title, $content);
}
-
+/**
+ * Parses a registered view for supported keywords.
+ *
+ * @param unknown_type $hook
+ * @param unknown_type $entity_type
+ * @param unknown_type $return_value
+ * @param unknown_type $params
+ * @return string
+ */
function sitepages_parse_view($hook, $entity_type, $return_value, $params) {
global $CONFIG;
+ // give me everything that is (string):(any thing that's not a ]) surrounded by [[ ]]s
+ $keyword_regex = '/\[\[([a-z]+):([^\]]+)\]\]/';
+
if (in_array($params['view'], $CONFIG->sitepages_parse_views)) {
$keywords = $CONFIG->sitepages_keywords;
+
$view_options = array(
'view' => $params['view']
);
@@ -176,11 +198,17 @@ function sitepages_parse_view($hook, $entity_type, $return_value, $params) {
$return_value = str_replace("[[$keyword]]", $content, $return_value);
}
}
+
+ // parse for specialized tags:
+ // [[entity: key=value, key=value,etc]]
+ // [[view:viewname, vars_key=value,...]]
+ $return_value = preg_replace_callback($keyword_regex, 'sitepages_parse_view_match', $return_value);
}
return $return_value;
}
+
/**
* Register some default keywords.
*
@@ -191,7 +219,6 @@ function sitepages_parse_view($hook, $entity_type, $return_value, $params) {
* @return unknown_type
*/
function sitepages_keyword_hook($hook, $entity_type, $return_value, $params) {
-
$return_value['login_box'] = array(
'view' => 'account/forms/login',
'description' => elgg_echo('sitepages:keywords:login_box')
@@ -205,7 +232,5 @@ function sitepages_keyword_hook($hook, $entity_type, $return_value, $params) {
return $return_value;
}
-
-
register_elgg_event_handler('init', 'system', 'sitepages_init');
register_elgg_event_handler('pagesetup', 'system', 'sitepages_pagesetup'); \ No newline at end of file
diff --git a/mod/sitepages/views/default/settings/sitepages/edit.php b/mod/sitepages/views/default/settings/sitepages/edit.php
index 22f03abaf..9705aaae5 100644
--- a/mod/sitepages/views/default/settings/sitepages/edit.php
+++ b/mod/sitepages/views/default/settings/sitepages/edit.php
@@ -1,3 +1,15 @@
+<?php
+/**
+ * Settings Site Pages
+ *
+ * @package SitePages
+ * @license http://www.gnu.org/licenses/old-licenses/gpl-2.0.html GNU Public License version 2
+ * @author Curverider Ltd
+ * @copyright Curverider Ltd 2008-2010
+ * @link http://elgg.org/
+ */
+?>
+
<p>
<?php echo elgg_echo('sitepages:ownfront'); ?>
<select name="params[ownfrontpage]">
diff --git a/mod/sitepages/views/default/sitepages/custom_frontpage.php b/mod/sitepages/views/default/sitepages/custom_frontpage.php
index fb0b673cc..429478280 100644
--- a/mod/sitepages/views/default/sitepages/custom_frontpage.php
+++ b/mod/sitepages/views/default/sitepages/custom_frontpage.php
@@ -10,8 +10,12 @@
* @link http://elgg.org/
*/
-$object = sitepages_get_sitepage_object('front');
+$sitepage = sitepages_get_sitepage_object('front');
-if ($object) {
- echo $object->description;
+if ($sitepage) {
+ if (get_loggedin_userid()) {
+ echo $sitepage->logged_in_content;
+ } else {
+ echo $sitepage->logged_out_content;
+ }
} \ No newline at end of file
diff --git a/mod/sitepages/views/default/sitepages/footer_menu.php b/mod/sitepages/views/default/sitepages/footer_menu.php
index 5137e0f21..d0addd3e1 100644
--- a/mod/sitepages/views/default/sitepages/footer_menu.php
+++ b/mod/sitepages/views/default/sitepages/footer_menu.php
@@ -1,10 +1,16 @@
<?php
/**
- * Elgg External pages footer menu
+ * Footer view to add links to the semi-static pages.
+ *
+ * @package SitePages
+ * @license http://www.gnu.org/licenses/old-licenses/gpl-2.0.html GNU Public License version 2
+ * @author Curverider Ltd
+ * @copyright Curverider Ltd 2008-2010
+ * @link http://elgg.org/
*/
?>
-<div class="footer_toolbar_links">|
+<div class="footer_toolbar_links">|
<a href="<?php echo $vars['url']; ?>pg/sitepages/read/About/"><?php echo elgg_echo('sitepages:about'); ?></a> |
<a href="<?php echo $vars['url']; ?>pg/sitepages/read/Terms/"><?php echo elgg_echo('sitepages:terms'); ?></a> |
<a href="<?php echo $vars['url']; ?>pg/sitepages/read/Privacy/"><?php echo elgg_echo('sitepages:privacy'); ?></a> |
diff --git a/mod/sitepages/views/default/sitepages/forms/editfront.php b/mod/sitepages/views/default/sitepages/forms/editfront.php
index cc09b8cc8..e13f16f6e 100644
--- a/mod/sitepages/views/default/sitepages/forms/editfront.php
+++ b/mod/sitepages/views/default/sitepages/forms/editfront.php
@@ -12,21 +12,23 @@
$action = 'sitepages/addfront';
if ($sitepages_object = sitepages_get_sitepage_object('front')) {
- $css = $sitepages_object->title;
- $sitepages_content = $sitepages_object->description;
- $guid = $sitepages_object->guid;
+ $css = $sitepages_object->css;
+ $logged_in_content = $sitepages_object->logged_in_content;
+ $logged_out_content = $sitepages_object->logged_out_content;
} else {
$css = '';
- $sitepages_content = '';
- $guid = '';
+ $logged_in_content = '';
+ $logged_out_content = '';
}
// set the required form variables
$input_css = elgg_view('input/plaintext', array('internalname' => 'css', 'value' => $css));
-$input_sitepages_content = elgg_view('input/plaintext', array('internalname' => 'sitepages_content', 'value' => $sitepages_content));
+$input_logged_in_content = elgg_view('input/plaintext', array('internalname' => 'logged_in_content', 'value' => $logged_in_content ));
+$input_logged_out_content = elgg_view('input/plaintext', array('internalname' => 'logged_out_content', 'value' => $logged_out_content ));
$submit_input = elgg_view('input/submit', array('internalname' => 'submit', 'value' => elgg_echo('save')));
-$pageshell_title = elgg_echo("sitepages:front_content");
+$logged_in_content_title = elgg_echo("sitepages:logged_in_front_content");
+$logged_out_content_title = elgg_echo("sitepages:logged_out_front_content");
$css_title = elgg_echo("sitepages:css");
//preview link
@@ -38,8 +40,13 @@ $form_body = <<<___EOT
<h3 class='settings'>$css_title</h3>
<p class='longtext_editarea'>$input_css</p><br />
- <h3 class='settings'>$pageshell_title</h3>
- <p class='longtext_editarea'>$input_sitepages_content</p>
+
+
+ <h3 class='settings'>$logged_in_content_title</h3>
+ <p class='longtext_editarea'>$input_logged_in_content</p><br />
+
+ <h3 class='settings'>$logged_out_content_title</h3>
+ <p class='longtext_editarea'>$input_logged_out_content</p>
$hidden_guid
<br />
diff --git a/mod/sitepages/views/default/sitepages/forms/editmeta.php b/mod/sitepages/views/default/sitepages/forms/editmeta.php
index d94f32114..84a8297fc 100644
--- a/mod/sitepages/views/default/sitepages/forms/editmeta.php
+++ b/mod/sitepages/views/default/sitepages/forms/editmeta.php
@@ -19,7 +19,7 @@ if ($sitepages_object = sitepages_get_sitepage_object('front')) {
$meta_description = '';
}
-$input_keywords = elgg_view('input/plaintext', array('internalname' => 'metatags', 'value' => $meta_tags));
+$input_keywords = elgg_view('input/text', array('internalname' => 'metatags', 'value' => $meta_tags));
$input_description = elgg_view('input/plaintext', array('internalname' => 'description', 'value' => $meta_description));
$submit_input = elgg_view('input/submit', array('internalname' => 'submit', 'value' => elgg_echo('save')));
diff --git a/mod/sitepages/views/default/sitepages/keywords.php b/mod/sitepages/views/default/sitepages/keywords.php
index e5348678a..d46efb5bc 100644
--- a/mod/sitepages/views/default/sitepages/keywords.php
+++ b/mod/sitepages/views/default/sitepages/keywords.php
@@ -12,6 +12,7 @@
$keywords = $vars['config']->sitepages_keywords;
$title = elgg_echo('sitepages:keywords_title');
$instructions = elgg_echo('sitepages:keywords_instructions');
+$more_info = elgg_echo('sitepages:keywords_instructions_more');
$keywords_html = '';
foreach ($keywords as $keyword => $info) {
@@ -22,6 +23,8 @@ foreach ($keywords as $keyword => $info) {
echo "
<h3>$title</h3>
<p>$instructions</p>
+<span id=\"sitepagesKeywordMoreInfo\" class=\"xhidden\">$more_info</span>
+
<ul>
$keywords_html
</ul>
diff --git a/mod/sitepages/views/default/sitepages/metatags.php b/mod/sitepages/views/default/sitepages/metatags.php
index c536dbe29..107a5871a 100644
--- a/mod/sitepages/views/default/sitepages/metatags.php
+++ b/mod/sitepages/views/default/sitepages/metatags.php
@@ -16,8 +16,10 @@ if ($meta_details) {
$description = $meta_details->description;
echo <<<___END
+
<meta name="description" content="$description" />
<meta name="keywords" content="$metatags" />
+
___END;
}
@@ -25,11 +27,13 @@ ___END;
if (get_context() == 'sitepages:front') {
$custom_css = sitepages_get_sitepage_object('front');
- if ($custom_css && $custom_css->title) {
- echo "
+ if ($custom_css && $custom_css->css) {
+ echo <<<___END
+
<style>
- {$custom_css->title}
+ {$custom_css->css}
</style>
- ";
+
+___END;
}
} \ No newline at end of file