diff options
Diffstat (limited to 'engine/lib/views.php')
| -rw-r--r-- | engine/lib/views.php | 52 | 
1 files changed, 42 insertions, 10 deletions
| diff --git a/engine/lib/views.php b/engine/lib/views.php index 6c4cec0f2..e0e10bcb7 100644 --- a/engine/lib/views.php +++ b/engine/lib/views.php @@ -399,7 +399,7 @@ function elgg_view_exists($view, $viewtype = '', $recurse = true) {   * @warning Simple cached views must take no parameters and return   * the same content no matter who is logged in.   * - * @note CSS and the basic JS views are automatically cached. + * @note CSS and the basic JS views are cached by the engine.   *   * @param string $viewname View name   * @@ -422,6 +422,27 @@ function elgg_view_register_simplecache($viewname) {  }  /** + * Get the URL for the cached file + * + * @param string $type The file type: css or js + * @param string $view The view name + * @return string + * @since 1.8.0 + */ +function elgg_view_get_simplecache_url($type, $view) { +	global $CONFIG; +	$lastcache = $CONFIG->lastcache; +	 +	if (elgg_view_is_simplecache_enabled()) { +		$viewtype = elgg_get_viewtype(); +		$url = elgg_get_site_url() . "cache/$type/$view/$viewtype/$view.$lastcache.$type"; +	} else { +		$url = elgg_get_site_url() . "pg/$type/$view.$lastcache.$type"; +	} +	return $url; +} + +/**   * Regenerates the simple cache.   *   * @warning This does not invalidate the cache, but actively resets it. @@ -484,6 +505,22 @@ function elgg_view_regenerate_simplecache($viewtype = NULL) {  }  /** + * Is simple cache enabled + * + * @return bool + * @since 1.8.0 + */ +function elgg_view_is_simplecache_enabled() { +	global $CONFIG; + +	if ($CONFIG->simplecache_enabled) { +		return true; +	} + +	return false; +} + +/**   * Enables the simple cache.   *   * @access private @@ -1329,17 +1366,10 @@ function elgg_is_valid_view_type($view_type) {   * Add the core Elgg head elements that could be cached   */  function elgg_views_register_core_head_elements() { -	global $CONFIG; - -	$base = elgg_get_site_url(); -	$lastcache = $CONFIG->lastcache; -	$viewtype = elgg_get_viewtype(); - -	//$url = "{$base}_css/js.php?lastcache=$lastcache&js=initialise_elgg&viewtype=$viewtype"; -	$url = "{$base}cache/js/initialise_elgg/$viewtype/initialise_elgg.$lastcache.js"; +	$url = elgg_view_get_simplecache_url('js', 'initialise_elgg');  	elgg_register_js($url, 'initialise_elgg'); -	$url = "{$base}cache/css/elgg/$viewtype/elgg.$lastcache.css"; +	$url = elgg_view_get_simplecache_url('css', 'elgg');  	elgg_register_css($url, 'elgg');  } @@ -1355,6 +1385,8 @@ function elgg_views_boot() {  	global $CONFIG;  	elgg_view_register_simplecache('css/elgg'); +	elgg_view_register_simplecache('ie/elgg'); +	elgg_view_register_simplecache('ie6/elgg');  	elgg_view_register_simplecache('js/friendsPickerv1');  	elgg_view_register_simplecache('js/initialise_elgg'); | 
