mirror of
https://github.com/s00500/ESPUI.git
synced 2024-11-21 22:50:55 +00:00
Cleaned up git status, cleaned prepare_static_ui_sources.py, mentioned the latter in README
This commit is contained in:
parent
1c17252b93
commit
3aae5954f2
7
.gitignore
vendored
7
.gitignore
vendored
@ -26,3 +26,10 @@
|
|||||||
Network Trash Folder
|
Network Trash Folder
|
||||||
Temporary Items
|
Temporary Items
|
||||||
.apdisk
|
.apdisk
|
||||||
|
|
||||||
|
# Linux
|
||||||
|
# =========================
|
||||||
|
|
||||||
|
# Backup files produced by some editors
|
||||||
|
*~
|
||||||
|
*.bak
|
||||||
|
@ -159,7 +159,7 @@ The library is designed to be easy to use and can still be extended with a lot o
|
|||||||
|
|
||||||
|
|
||||||
# Notes for Development
|
# Notes for Development
|
||||||
All changes to the client side files can be made in the examples/gui/data directory. Using the file uploader thin can be used for development. After this you have to compress them and then you can gzip them. I wrote a little useful jsfiddle for this, [CHECK IT OUT](https://jsfiddle.net/s00500/yvLbhuuv/)
|
All changes to the client side files can be made in the `examples/gui/data` directory. Using the file uploader then can be used for development. After this you have to compress them and then you can gzip them. I wrote a little useful jsfiddle for this, [CHECK IT OUT](https://jsfiddle.net/s00500/yvLbhuuv/)... or there is the `prepare_static_ui_sources.py` script in the `tools` directory, if you have a python3 environment available (you also need the modules jsmin, htmlmin and csscompressor).
|
||||||
|
|
||||||
# Contribute
|
# Contribute
|
||||||
Liked this Library? You can **support** me by sending me a :coffee: [Coffee](https://paypal.me/lukasbachschwell/3).
|
Liked this Library? You can **support** me by sending me a :coffee: [Coffee](https://paypal.me/lukasbachschwell/3).
|
||||||
|
1
examples/gui/data/index.min.htm
Normal file
1
examples/gui/data/index.min.htm
Normal file
@ -0,0 +1 @@
|
|||||||
|
<!DOCTYPE html><html> <head><meta charset=utf-8><title>Control</title><meta name=viewport content="width=device-width, initial-scale=1"><link rel="shortcut icon" href=data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAMAAAAoLQ9TAAAABGdBTUEAALGPC/xhBQAAACBjSFJNAAB6JgAAgIQAAPoAAACA6AAAdTAAAOpgAAA6mAAAF3CculE8AAAAPFBMVEUAAACA1VWR21qQ2liR3FqR3FqS3VuR3VqR3VuR3VqO21mS21uS3FqS3FqS21uJ2GKQ21qR3FuR3FoAAAB/3Gu7AAAAEnRSTlMABoA3kPBwz8i5Kzioxg4NVcU3uEJHAAAAAWJLR0QAiAUdSAAAAAlwSFlzAAAN1wAADdcBQiibeAAAAAd0SU1FB+EFEhcEM+HpYwQAAABYSURBVBjThY/JDsAgCESt4lpX/v9jLQZJ6qF9t3khAyj1xXUKbQ4BVowDwqOYgExkkW4iY6lPaF06RqM8YItOuRbMaz6xjbsusDAW/drplBg47jP696cXE8bPA1eUDeK2AAAAJXRFWHRkYXRlOmNyZWF0ZQAyMDE3LTA1LTE4VDIzOjA0OjUxKzAyOjAwxE59ewAAACV0RVh0ZGF0ZTptb2RpZnkAMjAxNy0wNS0xOFQyMzowNDo1MSswMjowMLUTxccAAAAZdEVYdFNvZnR3YXJlAHd3dy5pbmtzY2FwZS5vcmeb7jwaAAAAAElFTkSuQmCC><link rel=stylesheet href=/css/normalize.css><link rel=stylesheet href=/css/style.css><script src=/js/zepto.min.js></script><script src=/js/slider.js></script><script src=/js/controls.js></script></head> <body onload=javascript:start();> <div> <h4><div id=mainHeader>Control</div> <span id=conStatus class=label>Offline</span></h4></div> <hr> <div class=container> <div id=row class="row u-full-width"> </div> </div> </body> </html>
|
@ -19,21 +19,27 @@ const uint8_t {constant}_GZIP[{gziplen}] PROGMEM = {{ {gzipdata} }};
|
|||||||
|
|
||||||
def parse_arguments(args=None):
|
def parse_arguments(args=None):
|
||||||
parser = argparse.ArgumentParser(
|
parser = argparse.ArgumentParser(
|
||||||
description="Prepares ESPUI header files by minifying and gzipping JS and CSS source files.")
|
description="Prepares ESPUI header files by minifying and gzipping HTML, JS and CSS source files.")
|
||||||
parser.add_argument("--sources", "-s", dest="sources", default="../examples/gui/data",
|
parser.add_argument("--auto", "--all", "-a", dest="auto", action="store_true",
|
||||||
help="Sources directory containing CSS or JS files")
|
help="Automatically find all source files in examples/gui/data/ and write C header files to src/")
|
||||||
parser.add_argument("--target", "-t", dest="target", default="../src",
|
parser.add_argument("--source", "--sources", "-s", dest="sources", default=None,
|
||||||
help="Target directory containing header files")
|
help="Sources directory containing CSS or JS files OR one specific file to minify")
|
||||||
|
parser.add_argument("--target", "-t", dest="target", default=None,
|
||||||
|
help="Target directory containing C header files OR one C header file")
|
||||||
parser.add_argument("--nostoremini", "-m", action="store_false", dest="storemini",
|
parser.add_argument("--nostoremini", "-m", action="store_false", dest="storemini",
|
||||||
help="Store intermediate minified files")
|
help="Do not store intermediate minified (but not gzipped) files next to the originals")
|
||||||
args = parser.parse_args(args)
|
args = parser.parse_args(args)
|
||||||
|
if not args.auto and (not args.sources or not args.target):
|
||||||
|
print("ERROR: You need to specify either --auto or both --source and --target\n")
|
||||||
|
parser.print_help()
|
||||||
|
sys.exit(1)
|
||||||
return args
|
return args
|
||||||
|
|
||||||
def get_context(infile, outfile):
|
def get_context(infile, outfile):
|
||||||
infile = os.path.realpath(infile)
|
infile = os.path.realpath(infile)
|
||||||
dir, name, type = (os.path.basename(os.path.dirname(infile)), os.path.basename(infile).split(os.path.extsep)[0], os.path.basename(infile).split(os.path.extsep)[-1] )
|
dir, name, type = (os.path.basename(os.path.dirname(infile)), os.path.basename(infile).split(os.path.extsep)[0], os.path.basename(infile).split(os.path.extsep)[-1] )
|
||||||
type = type.strip(".")
|
type = type.strip(".").lower()
|
||||||
if dir == type:
|
if dir.lower() == type:
|
||||||
dir = os.path.basename(os.path.dirname(os.path.dirname(infile)))
|
dir = os.path.basename(os.path.dirname(os.path.dirname(infile)))
|
||||||
if type == "htm":
|
if type == "htm":
|
||||||
type = 'html'
|
type = 'html'
|
||||||
@ -60,7 +66,11 @@ def perform_gzip(c):
|
|||||||
|
|
||||||
def perform_minify(c):
|
def perform_minify(c):
|
||||||
with open(c['infile']) as infile:
|
with open(c['infile']) as infile:
|
||||||
minifier = cssminify if c['type'] == 'css' else jsminify if c['type'] == 'js' else htmlminify
|
minifier = {
|
||||||
|
'css': cssminify,
|
||||||
|
'js': jsminify,
|
||||||
|
'html': htmlminify
|
||||||
|
}.get(c['type']) or htmlminify
|
||||||
print(" Using %s minifier" % c['type'])
|
print(" Using %s minifier" % c['type'])
|
||||||
c['minidata'] = minifier(infile.read())
|
c['minidata'] = minifier(infile.read())
|
||||||
return perform_gzip(c)
|
return perform_gzip(c)
|
||||||
@ -93,15 +103,32 @@ def process_dir(sourcedir, outdir, recursive=True, storemini=True):
|
|||||||
process_file(f, outdir, storemini)
|
process_file(f, outdir, storemini)
|
||||||
elif not os.path.isfile(f.replace(".min.", ".")):
|
elif not os.path.isfile(f.replace(".min.", ".")):
|
||||||
process_file(f, outdir, storemini)
|
process_file(f, outdir, storemini)
|
||||||
|
|
||||||
|
def check_args(args):
|
||||||
|
abort = 0
|
||||||
|
if not os.path.exists(args.sources):
|
||||||
|
print("ERROR: Source %s does not exist" % args.sources)
|
||||||
|
abort += 2
|
||||||
|
if not os.path.isdir(os.path.dirname(args.target)):
|
||||||
|
print("ERROR: Parent directory of target %s does not exist" % args.target)
|
||||||
|
abort += 4
|
||||||
|
if os.path.isdir(args.sources) and not os.path.isdir(args.target):
|
||||||
|
print("ERROR: Source %s is a directory, target %s is not" % (args.sources, args.target))
|
||||||
|
abort += 8
|
||||||
|
if abort > 0:
|
||||||
|
print("Aborting.")
|
||||||
|
sys.exit(abort)
|
||||||
|
|
||||||
def main(args):
|
def main(args):
|
||||||
if not args.sources is None:
|
args.sources = os.path.realpath(args.sources or os.sep.join((os.path.dirname(os.path.realpath(__file__)), "..", "examples", "gui", "data")))
|
||||||
if os.path.isfile(args.sources):
|
args.target = os.path.realpath(args.target or os.sep.join((os.path.dirname(os.path.realpath(__file__)), "..", "src")))
|
||||||
print("Source %s is a file, will process one file only." % args.sources)
|
check_args(args)
|
||||||
process_file(args.sources, args.target, storemini = args.storemini)
|
if os.path.isfile(args.sources):
|
||||||
elif os.path.isdir(args.sources):
|
print("Source %s is a file, will process one file only." % args.sources)
|
||||||
print("Source %s is a directory, searching for files recursively..." % args.sources)
|
process_file(args.sources, args.target, storemini = args.storemini)
|
||||||
process_dir(args.sources, args.target, recursive = True, storemini = args.storemini)
|
elif os.path.isdir(args.sources):
|
||||||
|
print("Source %s is a directory, searching for files recursively..." % args.sources)
|
||||||
|
process_dir(args.sources, args.target, recursive = True, storemini = args.storemini)
|
||||||
|
|
||||||
if __name__ == "__main__" and "get_ipython" not in dir():
|
if __name__ == "__main__" and "get_ipython" not in dir():
|
||||||
main(parse_arguments())
|
main(parse_arguments())
|
||||||
|
Loading…
Reference in New Issue
Block a user