FrxSkin.inc in Forena Reports 7.4
Same filename and directory in other branches
FrxSkin.inc Skinning
A skin is a collectio of css and js files that need to get used by an application or reports. Skins are idntified by .fri files contained in the report directory.
Skins can specify external JS Libraries as well as
Used to be called a "form"
File
FrxSkin.incView source
<?php
/**
* @file FrxSkin.inc
* Skinning
*
* A skin is a collectio of css and js files that need to get used by
* an application or reports. Skins are idntified by .fri files contained
* in the report directory.
*
* Skins can specify external JS Libraries as well as
*
* Used to be called a "form"
*/
class FrxSkin {
public $name = '';
public $stylesheets = array();
public $scripts = array();
public $default_skin = '';
public $info = array();
/**
* Method constructor.
*/
public function __construct() {
$this->default_skin = variable_get('forena_default_form', 'default_skin');
}
/**
* Add CSS Files
* @param $type
* @param $sheet
*/
public function addCSS($type, $sheet) {
if (strpos($sheet, 'http:') === 0 || strpos($sheet, 'https:') === 0) {
$this->stylesheets[$type][] = $sheet;
}
elseif (Frx::File()
->exists($sheet)) {
$this->stylesheets[$type][] = Frx::File()
->path($sheet);
}
elseif (file_exists($sheet)) {
$this->stylesheets[$type][] = $sheet;
}
}
/**
*
* @param unknown_type $script
*/
public function addJS($script) {
if (strpos($script, 'http:') === 0 || strpos($script, 'https:') === 0) {
$this->scripts[] = $script;
}
elseif (Frx::File()
->exists($script)) {
$this->scripts[] = Frx::File()
->path($script);
}
elseif (file_exists('sites/all/libraries/' . $script)) {
$this->scripts[] = 'sites/all/libraries/' . $script;
}
elseif (file_exists($script)) {
$this->scripts[] = $script;
}
}
/**
* Load the skin based on the name.
* @param $name path/name of skin.
*/
public function load($name) {
if (!$name) {
$name = $this->default_skin;
}
if ($this->name != $name) {
//Check for an info file
if (Frx::File()
->exists($name . '.skinfo')) {
// Parse the info file using drupals stock version
$this->info = drupal_parse_info_format(Frx::File()
->contents($name . '.skinfo'));
$path_info = Frx::File()
->pathinfo($name . '.skinfo');
$this->info['base_path'] = base_path() . $path_info['dirname'];
$this->info['dir'] = base_path() . $path_info['dirname'];
Frx::Data()
->setContext('skin', $this->info);
if (isset($this->info['stylesheets'])) {
foreach ($this->info['stylesheets'] as $type => $sheets) {
if ($sheets) {
foreach ($sheets as $sheet) {
$this
->addCSS($type, $sheet);
}
}
}
}
// Add the javascript files
if (@is_array($this->info['scripts'])) {
foreach ($this->info['scripts'] as $script) {
$this
->addJS($script);
}
}
}
else {
$this->info = array(
'name' => $name,
);
//Perform the legacy detection of css and pdf files.
$this
->addCSS('all', $name . '.css');
$this
->addJS($name . '.js');
}
$this->name = $name;
}
return $this;
}
/**
* Adds on report specific skin files to
* @param $name name of report to add.
*/
public function loadSkinFiles($name) {
$this
->addCSS('all', $name . '.css');
foreach (Frx::Menu()->doc_formats as $ext) {
$this
->addCSS($ext, $name . '-' . $ext . '.css');
}
$this
->addJS($name . '.js');
}
/**
* Merge the skin definiitons.
* @param array $definition
* Definintion overriedes for skin.
*/
public function merge($definition) {
if (!is_array($definition)) {
$definition = json_decode($definition, TRUE);
}
if (is_array($definition)) {
foreach ($definition as $key => $value) {
if (isset($this->info[$key])) {
$this->info[$key] = array_merge($this->info[$key], $value);
}
else {
$this->info[$key] = $value;
}
}
}
}
/**
* @param string $data Data to be parsed
*/
public static function parseJSON($data) {
$parsed = json_decode($data, TRUE);
return $parsed;
}
}
Classes
Name | Description |
---|---|
FrxSkin | @file FrxSkin.inc Skinning |