forked from openedx/studio-frontend
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
96 lines (68 loc) · 4.03 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
UNAME := $(shell uname)
i18n = ./src/data/i18n/default
transifex_input = $(i18n)/transifex_input.json
# This directory must match .babelrc .
transifex_temp = ./temp/babel-plugin-react-intl
export TRANSIFEX_RESOURCE = studio-frontend
# Help message borrowed from https://github.com/openedx/devstack, which borrowed it from https://github.com/pydanny/cookiecutter-djangopackage.
help: ## display a help message
@echo $(MAKEFILE_LIST)
@echo "Please use \`make <target>' where <target> is one of"
@perl -nle'print $& if m{^[\.%a-zA-Z_-]+:.*?## .*$$}' $(MAKEFILE_LIST) | sort | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m %-25s\033[0m %s\n", $$1, $$2}'
shell: ## run a shell on the studio-frontend container
docker exec -it dahlia.studio-frontend /bin/bash
attach: ## attach local standard input, output, and error streams to studio-frontend container
docker attach --sig-proxy=false dahlia.studio-frontend
up: ## bring up studio-frontend container
docker-compose up studio-frontend
up-detached: ## bring up studio-frontend container in detached mode
docker-compose up -d studio-frontend
logs: ## show logs for studio-frontend container
docker-compose logs -f studio-frontend
down: ## stop and remove studio-frontend container
docker-compose down
stop: ## stops studio-frontend container
docker-compose stop
requirements:
npm install
npm-install-%: ## install specified % npm package on the studio-frontend container
docker exec dahlia.studio-frontend npm install $* --save-dev
git add package.json
from-scratch: ## start development environment from scratch
make down
docker rmi edxops/studio-frontend
docker build -t edxops/studio-frontend:latest --no-cache .
make up
restart: ## bring container down and back up
make down
make up
restart-detached: ## bring container down and back up in detached mode
make down
make up-detached
devstack.update: ## use this if you don't want to fire up the dedicated asset watching containers
docker exec -t edx.devstack.studio bash -c 'source /edx/app/edxapp/edxapp_env && cd /edx/app/edxapp/edx-platform && paver webpack'
asset-page-flag: ## insert a waffle flag into local docker devstack
docker exec -t edx.devstack.studio bash -c 'source /edx/app/edxapp/edxapp_env && cd /edx/app/edxapp/edx-platform && echo "from cms.djangoapps.contentstore.config.models import NewAssetsPageFlag; NewAssetsPageFlag.objects.all().delete(); NewAssetsPageFlag.objects.create(enabled=True, enabled_for_all_courses=True);" | ./manage.py lms --settings=devstack_docker shell && echo "NewAssetsPageFlag inserted!"'
i18n.docker: ## what devs should do from their host machines
docker exec -t dahlia.studio-frontend bash -c 'make i18n.extract && make i18n.preprocess'
extract_translations: | requirements i18n.extract i18n.preprocess
i18n.extract: ## move display strings from displayMessages.jsx to displayMessages.json
npm run-script i18n_extract
i18n.preprocess: ## gather all display strings into a single file
$$(npm bin)/edx_reactifex $(transifex_temp) $(transifex_input)
i18n.pre_validate: | i18n.extract i18n.preprocess
git diff --exit-code ./src/data/i18n/default/transifex_input.json
tx_url1 = https://www.transifex.com/api/2/project/edx-platform/resource/studio-frontend/translation/en/strings/
tx_url2 = https://www.transifex.com/api/2/project/edx-platform/resource/studio-frontend/source/
# Pushes translations to Transifex. You must run make extract_translations first.
push_translations:
# # Pushing strings to Transifex...
tx push -s
./node_modules/@edx/reactifex/bash_scripts/get_hashed_strings_v3.sh
$$(npm bin)/edx_reactifex $(transifex_temp) --comments --v3-scripts-path
./node_modules/@edx/reactifex/bash_scripts/put_comments_v3.sh
pull_translations: ## must be exactly this name for edx tooling support, see ecommerce-scripts/transifex/pull.py
# explicit list of languages defined here and in currentlySupportedLangs.jsx
tx pull -t -f --mode reviewed --languages="ar,fr,es_419,zh_CN"
copy-dist:
for f in dist/*; do docker cp $$f edx.devstack.studio:/edx/app/edxapp/edx-platform/node_modules/@edx/studio-frontend/dist/; done