-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathmix.exs
117 lines (107 loc) · 3.36 KB
/
mix.exs
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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
defmodule Recognizer.MixProject do
use Mix.Project
def project do
[
app: :recognizer,
version: "0.6.0",
elixir: "~> 1.14",
elixirc_paths: elixirc_paths(Mix.env()),
start_permanent: Mix.env() == :prod,
aliases: aliases(),
deps: deps(),
# dialyzer
dialyzer: [
plt_local_path: "_dialyzer",
plt_core_path: "_dialyzer"
]
]
end
# Configuration for the OTP application.
#
# Type `mix help compile.app` for more information.
def application do
[
mod: {Recognizer.Application, []},
extra_applications: [:logger, :runtime_tools]
]
end
# Specifies which paths to compile per environment.
defp elixirc_paths(:test), do: ["lib", "test/support"]
defp elixirc_paths(_), do: ["lib"]
# Specifies your project dependencies.
#
# Type `mix help deps` for examples and options.
defp deps do
[
{:phoenix, "~> 1.7.10"},
{:phoenix_html, "~> 3.3"},
{:phoenix_live_reload, "~> 1.2", only: :dev},
{:phoenix_live_view, "~> 0.20.1"},
{:floki, ">= 0.30.0", only: :test},
{:phoenix_live_dashboard, "~> 0.8.2"},
{:esbuild, "~> 0.8", runtime: Mix.env() == :dev},
{:tailwind, "~> 0.2.0", runtime: Mix.env() == :dev},
{:heroicons,
github: "tailwindlabs/heroicons",
tag: "v2.1.1",
sparse: "optimized",
app: false,
compile: false,
depth: 1},
{:telemetry_metrics, "~> 0.6"},
{:telemetry_poller, "~> 1.0"},
{:jason, "~> 1.2"},
{:dns_cluster, "~> 0.1.1"},
{:plug_cowboy, "~> 2.5"},
{:ex_webrtc, "~> 0.8.0"},
{:ex_webrtc_dashboard, "~> 0.8.0"},
{:xav, "~> 0.8.0"},
{:bumblebee, "~> 0.5.3"},
{:exla, "~> 0.7.1"},
# Dialyzer and credo
{:dialyxir, ">= 0.0.0", only: :dev, runtime: false},
{:credo, ">= 0.0.0", only: :dev, runtime: false}
]
end
# Aliases are shortcuts or tasks specific to the current project.
# For example, to install project dependencies and perform other setup tasks, run:
#
# $ mix setup
#
# See the documentation for `Mix` for more info on aliases.
defp aliases do
[
setup: ["deps.get", "assets.setup", "assets.build"],
"assets.setup": ["tailwind.install --if-missing", "esbuild.install --if-missing"],
"assets.build": ["tailwind default", "esbuild default"],
"assets.deploy": ["tailwind default --minify", "esbuild default --minify", "phx.digest"],
"assets.format": &lint_and_format_assets/1,
"assets.check": &check_assets/1
]
end
defp lint_and_format_assets(_args) do
with {_, 0} <- execute_npm_command(["ci"]),
{_, 0} <- execute_npm_command(["run", "lint"]),
{_, 0} <- execute_npm_command(["run", "format"]) do
:ok
else
{cmd, rc} ->
Mix.shell().error("npm command `#{Enum.join(cmd, " ")}` failed with code #{rc}")
exit({:shutdown, rc})
end
end
defp check_assets(_args) do
with {_, 0} <- execute_npm_command(["ci"]),
{_, 0} <- execute_npm_command(["run", "check"]) do
:ok
else
{cmd, rc} ->
Mix.shell().error("npm command `#{Enum.join(cmd, " ")}` failed with code #{rc}")
exit({:shutdown, rc})
end
end
defp execute_npm_command(command) do
{_stream, rc} = System.cmd("npm", ["--prefix=assets"] ++ command, into: IO.stream())
{command, rc}
end
end