Metadata-Version: 2.1
Name: lektor-jsminify
Version: 1.4.1
Summary: JS minifier for Lektor. Based on rjsmin.
Home-page: https://github.com/maxbachmann/lektor-JSminify
Author: maxbachmann
Author-email: kontakt@maxbachmann.de
License: MIT
Keywords: Lektor plugin
Platform: UNKNOWN
Classifier: Development Status :: 5 - Production/Stable
Classifier: Framework :: Lektor
Classifier: Environment :: Plugins
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Description-Content-Type: text/markdown
Requires-Dist: rjsmin
Requires-Dist: termcolor

# lektor-JSminify
[![PyPI version](https://badge.fury.io/py/lektor-jsminify.svg)](https://badge.fury.io/py/lektor-jsminify) [![Downloads](https://pepy.tech/badge/lektor-jsminify)](https://pepy.tech/project/lektor-jsminify)

JS minifier for Lektor that automatically minifies javascript files

Uses [rjsmin](https://pypi.org/project/rjsmin/)  and looks for .js files,
minifying them as part of the build process. It only rebuilds when it's needed (file changed or the config changed). When starting the the development server it watchs the files for changes in the background and rebuilds them when needed.

## Installing

You can install the plugin with Lektor's installer::
```bash
lektor plugins add lektor-jsminify
```

Or by hand, adding the plugin to the packages section in your lektorproject file::
```bash
[packages]
lektor-jsminify = 1.4.1
```

## Usage
#####

To enable jsminify, pass the `jsminify` flag when starting the development
server or when running a build:
```bash
lektor server -f jsminify
```
```bash
lektor build -f jsminify
```

When the flag is present, jsminify will take all .js files from asset_sources/js, minifies them and places them
in assets/js.


The Plugin has the following settings you can adjust to your needs:

|parameter         |default value      |description                                                                                       |
|------------------|-------------------|--------------------------------------------------------------------------------------------------|
|source_dir        |asset_sources/js/  | the directory in which the plugin searchs for js files (subdirectories are included)             |
|output_dir        |assets/js/         | the directory the minified js files get place at                                                 |
|name_prefix       |                   | prefix for output name e.g. test.js becomes to test<name_prefix>.js                              |
|keep_bang_comments|False              | keep comments starting with an exclamation mark                                                  |
|excluded_assets   |                   | exclude .js files using a comma separated list of unix shell style wildcards ([fnmatch](https://docs.python.org/3/library/fnmatch.html))                                     |
|included_assets   |                   | include .js files using a comma separated list of unix shell style wildcards ([fnmatch](https://docs.python.org/3/library/fnmatch.html)) overrides excluded assets           |

An example config can be found at `configs/jscompile.ini`


