define BROWSER_PYSCRIPT
import os, webbrowser, sys

from urllib.request import pathname2url

webbrowser.open("file://" + pathname2url(os.path.abspath(sys.argv[1])))
endef
export BROWSER_PYSCRIPT

define PRINT_HELP_PYSCRIPT
import re, sys

for line in sys.stdin:
	match = re.match(r'^([a-zA-Z_-]+):.*?## (.*)$$', line)
	if match:
		target, help = match.groups()
		print("%-20s %s" % (target, help))
endef
export PRINT_HELP_PYSCRIPT

BROWSER := python -c "$$BROWSER_PYSCRIPT"

help:
	@python -c "$$PRINT_HELP_PYSCRIPT" < $(MAKEFILE_LIST)

.PHONY: docs
docs: ## ๐Ÿ“„ Start Mkdocs Development Server
	poetry run python dev/scripts/api_docs_gen.py && \
	cd docs && poetry run python -m mkdocs serve

code-gen: ## ๐Ÿค– Run Code-Gen Scripts
	poetry run python dev/scripts/app_routes_gen.py

# -----------------------------------------------------------------------------
# Backend makefile

.PHONY: setup
setup: ## ๐Ÿ—  Setup Development Instance
	poetry install && \
	cd frontend && \
	yarn install && \
	cd ..

	poetry run pre-commit install

	cp -n template.env .env || true

	@echo "๐Ÿ—  Development Setup Complete "
	@echo "โ—๏ธ Tips"
	@echo "    1. run 'make backend' to start the API server"
	@echo "    2. run 'make frontend' to start the Node Server"
	@echo "    3. Testing the Natural Language Processor? Try 'make setup-model' to get the most recent model"

setup-model: ## ๐Ÿค– Get the latest NLP CRF++ Model
	@echo Fetching NLP Model - CRF++ is still Required
	curl -L0 https://github.com/mealie-recipes/nlp-model/releases/download/v1.0.0/model.crfmodel --output ./mealie/services/parser_services/crfpp/model.crfmodel


clean-data: ## โš ๏ธ  Removes All Developer Data for a fresh server start
	rm -r ./dev/data/recipes/
	rm -r ./dev/data/users/
	rm -f ./dev/data/mealie*.db
	rm -f ./dev/data/mealie.log
	rm -f ./dev/data/.secret

clean-pyc: ## ๐Ÿงน Remove Python file artifacts
	find ./mealie -name '*.pyc' -exec rm -f {} +
	find ./mealie  -name '*.pyo' -exec rm -f {} +
	find ./mealie  -name '*~' -exec rm -f {} +
	find ./mealie  -name '__pycache__' -exec rm -fr {} +

clean-test: ## ๐Ÿงน Remove test and coverage artifacts
	rm -fr .tox/
	rm -f .coverage
	rm -fr htmlcov/
	rm -fr .pytest_cache

backend-clean: clean-pyc clean-test ## ๐Ÿงน Remove all build, test, coverage and Python artifacts
	rm -fr .mypy_cache

backend-typecheck:
	poetry run mypy mealie

backend-test: ## ๐Ÿงช Run tests quickly with the default Python
	poetry run pytest

backend-format: ## ๐Ÿงบ Format, Check and Flake8
	poetry run isort .
	poetry run black .

backend-lint:
	poetry run flake8 mealie tests

backend-all: backend-format backend-lint backend-typecheck backend-test ## ๐Ÿงช Runs all the backend checks and tests

backend-coverage: ## โ˜‚๏ธ  Check code coverage quickly with the default Python
	poetry run pytest
	poetry run coverage report -m
	poetry run coveragepy-lcov
	poetry run coverage html
	$(BROWSER) htmlcov/index.html

backend: ## ๐ŸŽฌ Start Mealie Backend Development Server
	poetry run python mealie/db/init_db.py && \
	poetry run python mealie/app.py

# -----------------------------------------------------------------------------
# Frontend makefile

.PHONY: frontend
frontend: ## ๐ŸŽฌ Start Mealie Frontend Development Server
	cd frontend && yarn run dev

frontend-build: ## ๐Ÿ—  Build Frontend in frontend/dist
	cd frontend && yarn run build

frontend-generate: ## ๐Ÿ—  Generate Code for Frontend
	poetry run python dev/code-generation/gen_frontend_types.py

frontend-lint: ## ๐Ÿงบ Run yarn lint
	cd frontend && yarn lint

# -----------------------------------------------------------------------------
# Docker makefile

docker-dev: ## ๐Ÿณ Build and Start Docker Development Stack
	docker-compose -f docker-compose.dev.yml -p dev-mealie down && \
	docker-compose -f docker-compose.dev.yml -p dev-mealie up --build

docker-prod: ## ๐Ÿณ Build and Start Docker Production Stack
	docker-compose -f docker-compose.yml -p mealie up --build