]>
Commit | Line | Data |
---|---|---|
7a9e5112 | 1 | SHELL=/bin/bash |
2 | ENV ?= dev | |
3 | export PATH := $(PATH):./node_modules/.bin | |
4 | ||
5 | SRC_DIR=js | |
6 | BUILD_DIR=build/js | |
87b6d05e | 7 | JSX_SRC= header_footer.jsx main.jsx signup.jsx signin.jsx otp.jsx poloniex.jsx password_reset.jsx change_password.jsx |
7a9e5112 | 8 | JS_SRC= cookies.js app.js api.js |
bf5deb87 | 9 | STATIC_FILES= index.html style.css fontello.css |
10 | STATIC_FILES+=$(addprefix fonts/, fontello.eot fontello.svg fontello.ttf fontello.woff fontello.woff2) | |
7a9e5112 | 11 | JSX_OBJS=$(addprefix $(BUILD_DIR)/,$(JSX_SRC:.jsx=.js)) |
12 | JS_OBJS=$(addprefix $(BUILD_DIR)/,$(JS_SRC)) | |
6b3f0ad0 | 13 | ICONS=$(addprefix $(STATIC_BUILD_DIR)/icons/black/, $(notdir $(wildcard static/icons/black/*.svg))) |
14 | ICONS+=$(addprefix $(STATIC_BUILD_DIR)/icons/color/, $(notdir $(wildcard static/icons/color/*.svg))) | |
7a9e5112 | 15 | STATIC_BUILD_DIR=build/static |
16 | ||
17 | install: | |
18 | node --version | |
19 | npm --version | |
20 | yarn --version | |
21 | yarn install | |
22 | ||
6b3f0ad0 | 23 | static: $(STATIC_BUILD_DIR) js $(addprefix $(STATIC_BUILD_DIR)/, $(STATIC_FILES)) $(ICONS) |
7a9e5112 | 24 | |
25 | js: build/static/main.js | |
26 | ||
2f91f20a | 27 | $(STATIC_BUILD_DIR)/%: static/% |
28 | cp $< $@ | |
7a9e5112 | 29 | |
2f91f20a | 30 | $(STATIC_BUILD_DIR): |
31 | mkdir -p $(BUILD_DIR) | |
32 | mkdir -p $@ | |
6b3f0ad0 | 33 | mkdir -p $@/icons/black |
34 | mkdir -p $@/icons/color | |
bf5deb87 | 35 | mkdir -p $@/fonts |
7a9e5112 | 36 | |
37 | $(BUILD_DIR)/%.js: $(SRC_DIR)/%.jsx | |
989fb5c7 | 38 | eslint --fix $< |
39 | cp $< $@ | |
7a9e5112 | 40 | |
41 | $(BUILD_DIR)/%.js: $(SRC_DIR)/%.js | |
989fb5c7 | 42 | eslint $< |
7a9e5112 | 43 | cp $< $@ |
7a9e5112 | 44 | |
6b3f0ad0 | 45 | $(STATIC_BUILD_DIR)/icons/black/%.svg: static/icons/black/%.svg |
46 | cp $< $@ | |
47 | ||
7a9e5112 | 48 | build/static/main.js: $(JSX_OBJS) $(JS_OBJS) env/$(ENV).env |
989fb5c7 | 49 | browserify -t [ babelify --presets [ env react ] --plugins [ transform-class-properties ] ] \ |
50 | -t [ localenvify --envfile env/$(ENV).env ] \ | |
51 | -t [ debowerify ] \ | |
52 | $(BUILD_DIR)/main.js -o $@ | |
7a9e5112 | 53 | |
6b3f0ad0 | 54 | build/webapp.tar.gz: $(addprefix $(STATIC_BUILD_DIR)/, $(STATIC_FILES)) build/static/main.js $(ICONS) |
55 | tar czf $@ --directory=$(dir $<) $(subst $(STATIC_BUILD_DIR)/,,$^) | |
7a9e5112 | 56 | |
2f91f20a | 57 | release: $(STATIC_BUILD_DIR) build/webapp.tar.gz |
7a9e5112 | 58 | |
59 | clean: | |
60 | rm -rf build | |
2f91f20a | 61 | rm -rf node_modules |
bf5deb87 | 62 | |
63 | ||
64 | FONT_DIR = ./static/fontello | |
65 | FONTELLO_HOST ?= http://fontello.com | |
66 | ||
67 | fontopen: | |
68 | @if test ! `which curl` ; then \ | |
69 | echo 'Install curl first.' >&2 ; \ | |
70 | exit 128 ; \ | |
71 | fi | |
72 | curl --silent --show-error --fail --output .fontello \ | |
73 | --form "config=@fontello_config.json" \ | |
74 | ${FONTELLO_HOST} | |
75 | x-www-browser ${FONTELLO_HOST}/`cat .fontello` | |
76 | ||
77 | ||
78 | fontsave: | |
79 | @if test ! `which unzip` ; then \ | |
80 | echo 'Install unzip first.' >&2 ; \ | |
81 | exit 128 ; \ | |
82 | fi | |
83 | @if test ! -e .fontello ; then \ | |
84 | echo 'Run `make fontopen` first.' >&2 ; \ | |
85 | exit 128 ; \ | |
86 | fi | |
87 | rm -rf .fontello.src .fontello.zip | |
88 | curl --silent --show-error --fail --output .fontello.zip \ | |
89 | ${FONTELLO_HOST}/`cat .fontello`/get | |
90 | unzip .fontello.zip -d .fontello.src | |
91 | rm -rf ${FONT_DIR} | |
92 | mv `find ./.fontello.src -maxdepth 1 -name 'fontello-*'` ${FONT_DIR} | |
93 | rm -rf .fontello.src .fontello.zip | |
94 | cp ${FONT_DIR}/font/* static/fonts/ | |
95 | cp ${FONT_DIR}/css/fontello-codes.css static/fontello.css | |
96 | rm -rf ${FONT_DIR} |