class FrxSkin in Forena Reports 7.3
Same name and namespace in other branches
- 7.4 FrxSkin.inc \FrxSkin
@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"
Hierarchy
- class \FrxSkin
Expanded class hierarchy of FrxSkin
File
- ./
FrxSkin.inc, line 15 - FrxSkin.inc Skinning
View source
class FrxSkin {
public $name = '';
public $stylesheets = array();
public $scripts = array();
public $default_skin = '';
public $info = '';
/**
* 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 (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 (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'));
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');
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
FrxSkin:: |
public | property | ||
FrxSkin:: |
public | property | ||
FrxSkin:: |
public | property | ||
FrxSkin:: |
public | property | ||
FrxSkin:: |
public | property | ||
FrxSkin:: |
public | function | Add CSS Files | |
FrxSkin:: |
public | function | ||
FrxSkin:: |
public | function | Load the skin based on the name. | |
FrxSkin:: |
public | function | Adds on report specific skin files to | |
FrxSkin:: |
public | function | Method constructor. |