-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathJLessCClientScript.php
More file actions
81 lines (72 loc) · 3.07 KB
/
JLessCClientScript.php
File metadata and controls
81 lines (72 loc) · 3.07 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
<?php
/**
* LessCompiler class file.
* @author João Parreira <joaofrparreira@gmail.com>
* @copyright Copyright © 2012, João Parreira
* @license http://www.opensource.org/licenses/bsd-license.php New BSD License
* This extension is inspired in LessCompiler made by
* Christoffer Niska <ChristofferNiska@gmail.com>
*
* Created to easily manage less files in Yii and to permit more extensions to
* be implemented like sass or scss
*/
/**
* JLessCClientScript extends CClientScript and manages Less files
*/
Yii::setPathOfAlias('JLess', dirname(__FILE__) . DIRECTORY_SEPARATOR);
class JLessCClientScript extends CClientScript {
/**
* @var array Default JLess options
*/
//Default options to run the parser
private $_jLessOptions = array(
'subfolder' => true,
'vendor' => 'leafo',
'leafo' => array(
'class' => 'JLessLeafo'
),
'agar' => array(
'class' => 'JLessAgar'
),
);
public $jLessOptions;
/**
* Registers a Css file based in a less file
* @param string $url URL of the Less file
* @param string $media media that the Less file should be applied to. If empty, it means all media types.
* @param string $path path to save css file if diferent from the path defined in options
* (Ex: Yii::app()->theme->baseUrl.'/css/' - to save in css folder under current theme)
* Note: Folder must be writable
* @return CClientScript the CClientScript object itself (to support method chaining, available since version 1.1.5).
*/
public function registerLessFile($url, $media = '', $path = '') {
$this->jLessOptions['type'] = 'file';
$this->jLessOptions["url"] = $url;
$this->jLessOptions["path"] = $path;
$this->jLessOptions = CMap::mergeArray($this->_jLessOptions, $this->jLessOptions);
$classa = "JLess\\vendors\\" . $this->jLessOptions[$this->jLessOptions['vendor']]['class'];
$compiler = new $classa($this->jLessOptions);
$compiler->compileFile();
return parent::registerCssFile($compiler->getCss(), $media);
}
/**
* Registers a piece of Less code.
* @param string $id ID that uniquely identifies this piece of Less code
* @param string $less the Less code
* @param string $media media that the CSS code should be applied to. If empty, it means all media types.
* @return CClientScript the CClientScript object itself (to support method chaining, available since version 1.1.5).
*/
public function registerLess($id, $less, $media = '') {
$this->jLessOptions['type'] = 'string';
$this->jLessOptions['string'] = $less;
$this->jLessOptions = CMap::mergeArray($this->_jLessOptions, $this->jLessOptions);
$classa = "JLess\\vendors\\" . $this->jLessOptions[$this->jLessOptions['vendor']]['class'];
$compiler = new $classa($this->jLessOptions);
$compiler->compileString();
return parent::registerCss($id, $compiler->getCss(), $media);
}
/*
* TODO: Extend extension to manage sass and scss files
*/
}
?>