Skip to main content

An opinionated Webassets integration for Morepath.

Project description

Webassets | Morepath

This package is somewhat similar to more.static, which integrates bowerstatic into Morepath. It is currently not really used anywhere, so you should probably stick to more.static.

Now that you are sufficently discouraged from using more.webassets, these are the reasons it might be for you:

  • You don’t have to learn about javascript package managers (i.e. Bower).

  • You can have your assets compiled on the fly.

  • Your stylesheets are rendered at the top, your scripts at the bottom. No configuration necessary.

If you are alreay familiar with webassets: This package might not be as powerful as you’re used to. It currently has little flexibility. It’s also the first time the author uses webassets, so things might be off.

If you’re using Webassets differently than me and you want your ways to work with more.webassets, do open an issue. I’m happy to turn this into something more powerful.

Usage

The following app serves a minified jquery from assets/js/jquery.js (relative to the code):

from more.webassets import WebassetsApp

class App(WebassetsApp):
    pass

@App.webasset_path()
def get_asset_path():
    return 'assets/js'

@App.webasset_output()
def get_output_path():
    return 'assets/bundles'

@App.webasset_filter('js')
def get_js_filter():
    return 'rjsmin'

@App.webasset('jquery')
def get_jquery_asset():
    yield 'jquery.js'

@App.path('')
class Root(object):
    pass

@App.html(model=Root)
def index(self, request):
    request.include('jquery')

    return '<html><head></head><body>hello</body></html>'

This will result in the following html (formatted for readability):

<html>
    <head></head>
    <body>
        hello
        <script type="text/javascript" src="./assets/jquery.bundle.js?1234"></script>
    </body>
</html>

For it to work you need an ‘assets/js’ folder with a ‘jquery.js’ file in the same folder as your python file where ‘MyApp’ is defined.

Debug Mode

To activate webassets debug mode use the following environment variable:

MORE_WEBASSETS_DEBUG=1

Documentation

Most documentation is currently found in source code. Have a look at the comments in the directives file.

Run the Tests

Install tox and run it:

pip install tox
tox

Limit the tests to a specific python version:

tox -e py27

Conventions

More Webassets follows PEP8 as close as possible. To test for it run:

tox -e pep8

More Webassets uses Semantic Versioning

Build Status

Build Status

Coverage

Project Coverage

Latests PyPI Release

Latest PyPI Release

License

more.webassets is released under the revised BSD license

Changelog

0.4.0 (2017-07-10)

  • Adds the ability chain output filters (i.e. jsx -> jss -> minified). [href]

0.3.4 (2017-05-03)

  • Render the script tag inside the body element instead of after it.

    This turns the output into valid HTML. Rendering it outside the body element as it was done before works in practice, but it is technically not valid. [href]

0.3.3 (2016-10-04)

  • Add Python 3.5 and make it the default test environment.

  • Update to work with Morepath 0.16.

0.3.2 (2016-04-11)

  • Ensures that the webasset_path is always an absolute path. [href]

0.3.1 (2016-04-11)

  • Adds a debug environment variable used to activate webasset’s debug mode. [href]

  • Uses a temporary default output directory if none is specified. [href]

0.3.0 (2016-04-08)

  • Breaking Changes - This release changes everything!

    Assets are no longer registerd through special methods on the application. Instead proper Morepath directives are used. This enables better re-use of assets, less verbosity and proper support of inheritance (you can now have applications which define assets and child-applications which use those assets).

    Have a look at the readme and at the comments in the directives file, to get an idea about what has changed.

    Don’t hesitate to open an issue if you need help migrating your existing setup.

0.2.0 (2016-04-06)

  • Adds compatibility with morepath 0.13. [href]

0.1.1 (2016-01-24)

  • Disables webassets url caching if debug mode is active. [href]

0.1.0 (2016-01-24)

  • Support webassets debug mode (before it would trigger an exception). [href]

0.0.3 (2015-08-07)

  • Cache the resource urls for increased speed. Note that with this change a reload of the application is necessary to get the updated javascript files.

    If this is an issue for you, speak up and we might add a debug flag. [href]

0.0.2 (2015-05-18)

  • Adds more checks to ensure we never serve anything outside the assets directory. [href]

0.0.1 (2015-04-29)

  • Initial Release [href]

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

more.webassets-0.4.0.tar.gz (14.0 kB view details)

Uploaded Source

Built Distribution

more.webassets-0.4.0-py3-none-any.whl (20.7 kB view details)

Uploaded Python 3

File details

Details for the file more.webassets-0.4.0.tar.gz.

File metadata

File hashes

Hashes for more.webassets-0.4.0.tar.gz
Algorithm Hash digest
SHA256 cf03581bb14bf60ad23f7fcf115806850724f10c6d4ad2643f796c14ee8078ef
MD5 11999cb4d9b28fe093faea2094f33eaa
BLAKE2b-256 358c1158eea5fed8bcc98582e751b650cd213790ca3c19c297a4a88d5de78204

See more details on using hashes here.

File details

Details for the file more.webassets-0.4.0-py3-none-any.whl.

File metadata

File hashes

Hashes for more.webassets-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 910e5ec5ef3921ca26287d740ddb2868eb9d995d477f4dddaa434d1cfb460c03
MD5 d2544da4289b1cc1d7a7113d88bc0e16
BLAKE2b-256 4e6869c8e8a65129e4a7005ba52cfd0f461e3aa00b050a13fbbf0285f3e2d8ee

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page