This package allow theme developers to add LESS stylesheets into a Plone site.
Project description
Introduction
This package allow theme developers to add LESS stylesheets into a Plone site.
LESS
LESS extends CSS with dynamic behavior such as variables, mixins, operations and functions. LESS runs on both the client-side (Chrome, Safari, Firefox) and server-side.
You can find more information about LESS at http://lesscss.org/
Integration with Plone
This package clone the portal_css behavior, extending it to meet both client-side and server-side LESS resources compiling methods.
It adds a portal_less tool to the portal, enables an import/export GS profile lessregistry.xml, overrides the default Products.ResourceRegistries viewlet by adding the LESS resources part for the <head> tag.
Adding LESS resources
This package is intended to be used in conjunction with an user defined Plone Theme package. As a developer, you can include as many LESS resources as you may need to build your theme. You can add LESS resources using a GS profile named lessregistry.xml. The syntax is cloned from cssregistry.xml profile:
<?xml version="1.0"?> <object name="portal_less" meta_type="LESS Stylesheets Registry"> <stylesheet title="++bootstrap++less/bootstrap.less" authenticated="False" enabled="on" id="++bootstrap++less/bootstrap.less" rendering="link"/> </object>
Control Panel
You can manage the way the LESS resources compile by accessing the LESS resources configlet located at the site setup. By default, client-side LESS resources compile mode and minification are enabled.
Client side compiling
Client-side compiling is intended to use while in (theme) development mode.
collective.lesscss will use the standard method for compiling client-side by using the less.js (v1.3, at the time of this writting) and exposing the LESS resources after the portal_css ones:
<link rel="stylesheet/less" type="text/css" href="styles.less"> <!-- Here goes the rest of portal_javascript resources --> <script src="less.js" type="text/javascript"></script>
Server side compiling
Server-side compiled LESS resources are recommended in production mode. By unsetting this option, the site will server-side compile them into CSS resources and enable a volatile cache on them.
IMPORTANT NOTE: Server-side compiling requires to have declared the resources via plone.resource package in your theme package! Example:
<plone:static directory="resources/less" type="bootstrap" name="less" />
And furthermore, if you aren’t using plone.app.theming for develop your theme you should declare the type you are using for your resources by creating this class somewhere in your theme (e.g. traversal.py):
from plone.resource.traversal import ResourceTraverser class BootstrapTraverser(ResourceTraverser): """The theme traverser. Allows traveral to /++bootstrap++<name> using ``plone.resource`` to fetch things stored either on the filesystem or in the ZODB. """ name = 'bootstrap'
and later on, declare the adapter via zcml:
<adapter name="bootstrap" for="* zope.publisher.interfaces.IRequest" provides="zope.traversing.interfaces.ITraversable" factory=".traversal.BootstrapTraverser" />
So, you should now be able to access to the resources inside the resources directory by accessing:
http://localhost/Plone/++bootstrap++less/
Twitter bootstrap integration
You can check out the package https://github.com/sneridagh/example.bootstrap for a full example on how to integrate LESS resources in your theme package.
Contributors
Victor Fernandez de Alba [sneridagh], Author
Sebastian Jordan [seppeljordan]
Leonardo J. Caballero G. [macagua]
Laurent Lasudry [laulaz]
Changelog
2.0.3 (2020-04-06)
Allow browser to cache compiled CSS (compiled_styles.css) while portal_less is not in debug mode [laulaz]
Updated Spanish translation [macagua]
Updated Gettext files [macagua]
Added more keywords and strings classifiers items and updated others items for this package [macagua]
2.0.2 (2017-12-12)
Do not get cached lesscss if debugmode is checked in portal_less. [bsuttor]
2.0.1 (2017-05-17)
Always encode CSS string before LESS compilation to avoid errors [laulaz]
Don’t display info messages if compilation failed [laulaz]
2.0 (2017-03-21)
Use python package lesscpy directly instead of calling a script (#8). This allows to get rid of Node.js in buildout for server-side compiling. [laulaz]
Add (optional) minification of LESS files. Code is based on https://github.com/collective/collective.lesscss/pull/9 but uses lessc script directly (instead of cleancss) with compress option. [laulaz]
Improve server-side compilation when there are references between files. We need to compile the resources all together because otherwise the compiler will fail on unknown variables references between files. [laulaz]
Added Spanish translation [macagua]
Added more improvements about i18n [macagua]
Added Bash script for i18ndude [macagua]
1.3 (2014-07-02)
Update to nodejs v0.10.29 [seppeljordan]
Reworked server-side compilation, should work with an registered LESS resource now [seppeljordan]
1.2 (2014-03-19)
Update to lessjs 1.7.0 [jaroel]
1.1 (2014-03-11)
updated nodejs to version 0.10.26 [seppeljordan]
updated version of less.js to 1.6.3 [jaroel]
1.0b2 (2012-04-14)
Fix pypi distribution [sneridagh]
1.0b1 (2012-04-13)
A portal_less inherited from CSSRegistry [sneridagh]
Import/Export GS profile [sneridagh]
A viewlet to include less files [sneridagh]
Register less.js in portal_javascripts [sneridagh]
A site wide configuration with : transform server side / client wide. [sneridagh]
Provide documented buildout to install nodejs to compile your files server side [sneridagh]
Make the results in cached with memoize [sneridagh]
test with twitter’s bootstrap sources [sneridagh]
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file collective.lesscss-2.0.3.tar.gz
.
File metadata
- Download URL: collective.lesscss-2.0.3.tar.gz
- Upload date:
- Size: 67.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.19.1 setuptools/40.2.0 requests-toolbelt/0.8.0 tqdm/4.25.0 CPython/2.7.15
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | beb76d5ad3df0064b1a32a8c224ee1cc103f299189a77ed5322ab693a1185f5e |
|
MD5 | 96a9aa204d6348f5d8cb2a00474455b1 |
|
BLAKE2b-256 | b2e3f1b6b71cc2dcdced219f9fe95c8ddacfdf99dbf9d2f4614918674ecdb052 |