diff options
| -rw-r--r-- | mod/embed/start.php | 5 | ||||
| -rw-r--r-- | mod/embed/views/default/embed/embed.php | 21 | ||||
| -rw-r--r-- | mod/embed/views/default/embed/upload/content.php | 47 | 
3 files changed, 67 insertions, 6 deletions
| diff --git a/mod/embed/start.php b/mod/embed/start.php index eb6f6d4a6..a3b811371 100644 --- a/mod/embed/start.php +++ b/mod/embed/start.php @@ -49,12 +49,15 @@ function embed_page_handler($page) {  			// @todo trigger for all right now. If we categorize these later we can trigger  			// for certain categories.  			$sections = trigger_plugin_hook('embed_get_sections', 'all', NULL, array()); +			$upload_sections = trigger_plugin_hook('embed_get_upload_sections', 'all', NULL, array());  			asort($sections, SORT_LOCALE_STRING); +			asort($upload_sections, SORT_LOCALE_STRING);  			$active_section = get_input('active_section', NULL);  			echo elgg_view('embed/embed', array(  				'sections' => $sections, -				'active_section' => $active_section +				'active_section' => $active_section, +				'upload_sections' => $upload_sections  			));  			break; diff --git a/mod/embed/views/default/embed/embed.php b/mod/embed/views/default/embed/embed.php index 4a14543d3..70241609b 100644 --- a/mod/embed/views/default/embed/embed.php +++ b/mod/embed/views/default/embed/embed.php @@ -9,8 +9,9 @@   * @uses string $vars['active_section'] Currently selected section_id   */ -$sections = (isset($vars['sections'])) ? $vars['sections'] : array(); -$active_section = (isset($vars['active_section'])) ? $vars['active_section'] : array_shift(array_keys($sections)); +$sections = elgg_get_array_value('sections', $vars, array()); +$active_section = elgg_get_array_value('active_section', $vars, array_shift(array_keys($sections))); +$upload_sections = elgg_get_array_value('upload_sections', $vars, array());  if (!$sections) {  	$content = elgg_echo('embed:no_sections'); @@ -38,11 +39,21 @@ if (!$sections) {  		$tabs[] = $tab;  	} +	// make sure upload is always the last tab +	if ($upload_sections) { +		$tabs[] = array( +			'title' => elgg_echo('embed:upload'), +			'url' => '#', +			'url_class' => 'embed_section', +			'url_js' => 'id="upload"', +		); +	} +  	$tabs_html = elgg_view('navigation/tabs', array('tabs' => $tabs));  	$content .= $tabs_html;  	// build the items and layout. -	if (array_key_exists($active_section, $sections)) { +	if ($section != 'upload' || array_key_exists($active_section, $sections)) {  		$section_info = $sections[$active_section];  		$layout = isset($section_info['layout']) ? $section_info['layout'] : 'list'; @@ -51,7 +62,8 @@ if (!$sections) {  			//'subtype'	=> $subtype,  			'offset' => $offset,  			'limit' => $limit, -			'section' => $active_section +			'section' => $active_section, +			'upload_sections' => $upload_sections  		);  		// allow full override for this section @@ -99,7 +111,6 @@ if (!$sections) {  	} else {  		$content .= elgg_echo('embed:invalid_section');  	} -  }  echo $content;  ?> diff --git a/mod/embed/views/default/embed/upload/content.php b/mod/embed/views/default/embed/upload/content.php new file mode 100644 index 000000000..089e417c5 --- /dev/null +++ b/mod/embed/views/default/embed/upload/content.php @@ -0,0 +1,47 @@ +<?php +/** + * Special upload form for + */ +$upload_sections = elgg_get_array_value('upload_sections', $vars, array()); +$active_section = get_input('active_upload_section', array_shift(array_keys($upload_sections))); + +$options = array(); + +if ($upload_sections) { +	foreach ($upload_sections as $id => $info) { +		$options[$id] = $info['name']; +	} + +	$input = elgg_view('input/pulldown', array( +		'name' => 'download_section', +		'options_values' => $options, +		'internalid' => 'embed_upload', +		'value' => $active_section +	)); + +	echo "<p>$input</p>"; + +	if (!$upload_content = elgg_view($upload_sections[$active_section]['view'])) { +		$upload_content = elgg_echo('embed:no_upload_content'); +	} + +	echo $upload_content; + +?> +	<script type="text/javascript"> +	$(document).ready(function() { + +		// change for pulldown +		$('#embed_upload').change(function() { +			var upload_section = $(this).val(); +			var url = '<?php echo $vars['url']; ?>pg/embed/embed?active_section=upload&active_upload_section=' + upload_section; +			$('#facebox .body .content').load(url); +		}); + +	}); +	</script> +<?php + +} else { +	echo elgg_echo('embed:no_upload_sections'); +} | 
