diff options
author | ewinslow <ewinslow@36083f99-b078-4883-b0ff-0f9b5a30f544> | 2011-02-21 20:25:58 +0000 |
---|---|---|
committer | ewinslow <ewinslow@36083f99-b078-4883-b0ff-0f9b5a30f544> | 2011-02-21 20:25:58 +0000 |
commit | eb1f78b48658b9ffaac228652a390102ab886dea (patch) | |
tree | 985f28bd36fd4a0c64086cf6950d0f61272f175c /views/default/object/widget.php | |
parent | 2160d5f11f95f81299ae44ece4819c144467d07f (diff) | |
download | elgg-eb1f78b48658b9ffaac228652a390102ab886dea.tar.gz elgg-eb1f78b48658b9ffaac228652a390102ab886dea.tar.bz2 |
Refs #2950: Moved widget code to object/widget/*
git-svn-id: http://code.elgg.org/elgg/trunk@8386 36083f99-b078-4883-b0ff-0f9b5a30f544
Diffstat (limited to 'views/default/object/widget.php')
-rw-r--r-- | views/default/object/widget.php | 73 |
1 files changed, 69 insertions, 4 deletions
diff --git a/views/default/object/widget.php b/views/default/object/widget.php index efc8ef9ae..ce2dc33da 100644 --- a/views/default/object/widget.php +++ b/views/default/object/widget.php @@ -1,9 +1,74 @@ <?php /** - * Elgg default widget view + * Widget object * - * @package Elgg - * @subpackage Core + * @uses $vars['entity'] ElggWidget + * @uses $vars['show_access'] Show the access control in edit area? (true) */ -echo elgg_view('page/components/widget', $vars); +$widget = $vars['entity']; +if (!elgg_instanceof($widget, 'object', 'widget')) { + return true; +} + +$show_access = elgg_extract('show_access', $vars, true); + +// @todo catch for disabled plugins +$widget_types = elgg_get_widget_types('all'); + +$handler = $widget->handler; + +$title = $widget->getTitle(); + +$edit_area = ''; +$can_edit = $widget->canEdit(); +if ($can_edit) { + $edit_area = elgg_view('object/widget/elements/settings', array( + 'widget' => $widget, + 'show_access' => $show_access, + )); +} +$controls = elgg_view('object/widget/elements/controls', array( + 'widget' => $widget, + 'show_edit' => $edit_area != '', +)); + +// don't show content for default widgets +if (elgg_in_context('default_widgets')) { + $content = ''; +} else { + if (elgg_view_exists("widgets/$handler/content")) { + $content = elgg_view("widgets/$handler/content", $vars); + } else { + elgg_deprecated_notice("widgets use content as the display view", 1.8); + $content = elgg_view("widgets/$handler/view", $vars); + } +} + +$widget_id = "elgg-widget-$widget->guid"; +$widget_instance = "elgg-widget-instance-$handler"; +$widget_class = "elgg-module elgg-module-widget"; +if ($can_edit) { + $widget_class .= " elgg-state-draggable $widget_instance"; +} else { + $widget_class .= " elgg-state-fixed $widget_instance"; +} + +$widget_header = <<<HEADER + <h3>$title</h3> + $controls +HEADER; + +$widget_body = <<<BODY + $edit_area + <div class="elgg-widget-content"> + $content + </div> +BODY; + +echo elgg_view('page/components/module', array( + 'class' => $widget_class, + 'id' => $widget_id, + 'body' => $widget_body, + 'header' => $widget_header, +)); |