238 lines
9.2 KiB
PHP
238 lines
9.2 KiB
PHP
<?php
|
|
/**
|
|
* Helper class to load standrad DokuWiki CSS files.
|
|
* Adopted code from dw2pdf plugin by Andreas Gohr <andi@splitbrain.org>.
|
|
*
|
|
* @license GPL 2 (http://www.gnu.org/licenses/gpl.html)
|
|
* @author LarsDW223
|
|
*/
|
|
|
|
// must be run within Dokuwiki
|
|
if (!defined('DOKU_INC')) die();
|
|
|
|
|
|
/**
|
|
* Class helper_plugin_odt_dwcssloader
|
|
*
|
|
* @package helper\dwcssloader
|
|
*/
|
|
class helper_plugin_odt_dwcssloader extends DokuWiki_Plugin {
|
|
/** var string Usually empty, can be used for debugging */
|
|
public $trace_dump = NULL;
|
|
|
|
/**
|
|
* Return list of implemented methods.
|
|
*
|
|
* @return array
|
|
*/
|
|
function getMethods() {
|
|
$result = array();
|
|
$result[] = array(
|
|
'name' => 'load',
|
|
'desc' => 'Loads standard DokuWiki, plugin specific and format specific CSS files and templates. Includes handling of replacements and less parsing.',
|
|
'params' => array('$plugin_name' => 'string',
|
|
'$format' => 'string',
|
|
'$template' => 'string'),
|
|
'return' => array('All CSS styles' => 'string'),
|
|
);
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
* Load all the style sheets and apply the needed replacements
|
|
* @param $plugin_name
|
|
* @param $format
|
|
* @param $template
|
|
* @return string
|
|
*/
|
|
public function load($plugin_name, $format, $template) {
|
|
$mediatypes = array('screen', 'all', 'print');
|
|
|
|
//reusue the CSS dispatcher functions without triggering the main function
|
|
define('SIMPLE_TEST', 1);
|
|
require_once(DOKU_INC . 'lib/exe/css.php');
|
|
|
|
// Always only use small letters in format
|
|
$format = strtolower ($format);
|
|
|
|
// load style.ini
|
|
if (function_exists('css_styleini')) {
|
|
// compatiblity layer for pre-Greebo releases of DokuWiki
|
|
$styleini = css_styleini($template);
|
|
} else {
|
|
// Greebo functionality
|
|
$styleUtils = new \dokuwiki\StyleUtils();
|
|
$styleini = $styleUtils->cssStyleini($template);
|
|
}
|
|
|
|
$template_files = array();
|
|
foreach($mediatypes as $mediatype) {
|
|
$template_files[$mediatype] = array();
|
|
|
|
// load template styles
|
|
if (isset($styleini['stylesheets'][$mediatype])) {
|
|
$template_files[$mediatype] = array_merge($template_files[$mediatype], $styleini['stylesheets'][$mediatype]);
|
|
}
|
|
}
|
|
|
|
// prepare CSS files
|
|
$files = array_merge(
|
|
array(
|
|
DOKU_INC . 'lib/styles/screen.css'
|
|
=> DOKU_BASE . 'lib/styles/',
|
|
DOKU_INC . 'lib/styles/print.css'
|
|
=> DOKU_BASE . 'lib/styles/',
|
|
),
|
|
css_pluginstyles('all'),
|
|
$this->css_pluginFormatStyles($format),
|
|
array(
|
|
DOKU_PLUGIN . $plugin_name.'/conf/style.css'
|
|
=> DOKU_BASE . 'lib/plugins/'.$plugin_name.'/conf/',
|
|
DOKU_PLUGIN . $plugin_name.'/tpl/' . $template . '/style.css'
|
|
=> DOKU_BASE . 'lib/plugins/'.$plugin_name.'/tpl/' . $template . '/',
|
|
DOKU_PLUGIN . $plugin_name.'/conf/style.local.css'
|
|
=> DOKU_BASE . 'lib/plugins/'.$plugin_name.'/conf/',
|
|
)
|
|
);
|
|
$css = '';
|
|
$css .= $this->get_css_for_filetypes();
|
|
|
|
// build the stylesheet
|
|
foreach($files as $file => $location) {
|
|
$display = str_replace(fullpath(DOKU_INC), '', fullpath($file));
|
|
$css_content = "\n/* XXXXXXXXX $display XXXXXXXXX */\n";
|
|
$css_content = css_loadfile($file, $location);
|
|
if (strpos ($file, 'screen.css') !== false ||
|
|
strpos ($file, 'screen.less') !== false) {
|
|
$css .= "\n@media screen {\n" . $css_content . "\n}\n";
|
|
} else if (strpos ($file, 'style.css') !== false ||
|
|
strpos ($file, 'style.less') !== false) {
|
|
$css .= "\n@media screen {\n" . $css_content . "\n}\n";
|
|
} else if (strpos ($file, $format.'.css') !== false ||
|
|
strpos ($file, $format.'.less') !== false) {
|
|
$css .= "\n@media print {\n" . $css_content . "\n}\n";
|
|
} else if (strpos ($file, 'print.css') !== false ||
|
|
strpos ($file, 'print.less') !== false) {
|
|
$css .= "\n@media print {\n" . $css_content . "\n}\n";
|
|
} else {
|
|
$css .= $css_content;
|
|
}
|
|
}
|
|
|
|
foreach ($mediatypes as $mediatype) {
|
|
// load files
|
|
$css_content = '';
|
|
foreach($template_files[$mediatype] as $file => $location){
|
|
$display = str_replace(fullpath(DOKU_INC), '', fullpath($file));
|
|
$css_content .= "\n/* XXXXXXXXX $display XXXXXXXXX */\n";
|
|
$css_content .= css_loadfile($file, $location);
|
|
}
|
|
switch ($mediatype) {
|
|
case 'screen':
|
|
$css .= NL.'@media screen { /* START screen styles */'.NL.$css_content.NL.'} /* /@media END screen styles */'.NL;
|
|
break;
|
|
case 'print':
|
|
$css .= NL.'@media print { /* START print styles */'.NL.$css_content.NL.'} /* /@media END print styles */'.NL;
|
|
break;
|
|
case 'all':
|
|
case 'feed':
|
|
default:
|
|
$css .= NL.'/* START rest styles */ '.NL.$css_content.NL.'/* END rest styles */'.NL;
|
|
break;
|
|
}
|
|
}
|
|
|
|
if(function_exists('css_parseless')) {
|
|
// apply pattern replacements
|
|
$css = css_applystyle($css, $styleini['replacements']);
|
|
|
|
// parse less
|
|
$css = css_parseless($css);
|
|
} else {
|
|
// @deprecated 2013-12-19: fix backward compatibility
|
|
$css = css_applystyle($css, DOKU_INC . 'lib/tpl/' . $template . '/');
|
|
}
|
|
|
|
return $css;
|
|
}
|
|
|
|
/**
|
|
* Returns a list of possible Plugin Styles for format $format
|
|
*
|
|
* Checks for a $format.'.css', falls back to print.css
|
|
*
|
|
* @author Andreas Gohr <andi@splitbrain.org>
|
|
*
|
|
* @param string $format
|
|
* @return array
|
|
*/
|
|
protected function css_pluginFormatStyles($format) {
|
|
$list = array();
|
|
$plugins = plugin_list();
|
|
|
|
foreach($plugins as $p) {
|
|
// Always load normal/screen CSS code
|
|
// That way plugins can choose with the media selector which CSS code they like to use
|
|
$list[DOKU_PLUGIN . $p ."/screen.css"] = DOKU_INC . "lib/plugins/". $p ."/";
|
|
$list[DOKU_PLUGIN . $p ."/screen.less"] = DOKU_INC . "lib/plugins/". $p ."/";
|
|
$list[DOKU_PLUGIN . $p ."/style.css"] = DOKU_INC . "lib/plugins/". $p ."/";
|
|
$list[DOKU_PLUGIN . $p ."/style.less"] = DOKU_INC . "lib/plugins/". $p ."/";
|
|
|
|
// Do $format.css (e.g. odt.css) or print.css exists?
|
|
$format_css = file_exists(DOKU_PLUGIN . $p ."/". $format .".css");
|
|
$format_less = file_exists(DOKU_PLUGIN . $p ."/". $format .".less");
|
|
$print_css = file_exists(DOKU_PLUGIN . $p ."/print.css");
|
|
$print_less = file_exists(DOKU_PLUGIN . $p ."/print.less");
|
|
if($format_css || $format_less) {
|
|
$list[DOKU_PLUGIN . $p ."/". $format .".css"] = DOKU_INC . "lib/plugins/". $p ."/";
|
|
$list[DOKU_PLUGIN . $p ."/". $format .".less"] = DOKU_INC . "lib/plugins/". $p ."/";
|
|
} else if ($print_css || $print_less) {
|
|
$list[DOKU_PLUGIN . $p ."/print.css"] = DOKU_INC . "lib/plugins/". $p ."/";
|
|
$list[DOKU_PLUGIN . $p ."/print.less"] = DOKU_INC . "lib/plugins/". $p ."/";
|
|
}
|
|
}
|
|
return $list;
|
|
}
|
|
|
|
/**
|
|
* Returns classes for file download links
|
|
* (Adjusted from lib/exe/css.php: function css_filetypes())
|
|
*
|
|
* @author Andreas Gohr <andi@splitbrain.org>
|
|
*/
|
|
protected function get_css_for_filetypes() {
|
|
$css = '';
|
|
|
|
// default style
|
|
$css .= '.mediafile {';
|
|
$css .= ' background: transparent url('.DOKU_BASE.'lib/images/fileicons/file.png) 0px 1px no-repeat;';
|
|
$css .= ' padding-left: 18px;';
|
|
$css .= ' padding-bottom: 1px;';
|
|
$css .= '}';
|
|
|
|
// additional styles when icon available
|
|
// scan directory for all icons
|
|
$exts = array();
|
|
if($dh = opendir(DOKU_INC.'lib/images/fileicons')){
|
|
while(false !== ($file = readdir($dh))){
|
|
if(preg_match('/([_\-a-z0-9]+(?:\.[_\-a-z0-9]+)*?)\.(png|gif)/i',$file,$match)){
|
|
$ext = strtolower($match[1]);
|
|
$type = '.'.strtolower($match[2]);
|
|
if($ext!='file' && (!isset($exts[$ext]) || $type=='.png')){
|
|
$exts[$ext] = $type;
|
|
}
|
|
}
|
|
}
|
|
closedir($dh);
|
|
}
|
|
foreach($exts as $ext=>$type){
|
|
$class = preg_replace('/[^_\-a-z0-9]+/','_',$ext);
|
|
$css .= ".mf_$class {";
|
|
$css .= ' background-image: url('.DOKU_BASE.'lib/images/fileicons/'.$ext.$type.')';
|
|
$css .= '}';
|
|
}
|
|
|
|
return $css;
|
|
}
|
|
}
|