defmodule Livebook.MixProject do use Mix.Project def project do [ app: :livebook, version: "0.1.0", elixir: "~> 1.11", elixirc_paths: elixirc_paths(Mix.env()), compilers: [:phoenix] ++ Mix.compilers(), start_permanent: Mix.env() == :prod, aliases: aliases(), deps: deps(), escript: escript(), preferred_cli_env: preferred_cli_env() ] end # Configuration for the OTP application. # # Type `mix help compile.app` for more information. def application do [ mod: {Livebook.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.5.7"}, # TODO: remove reference to the Git repo once LV 0.15.5 is released {:phoenix_live_view, "~> 0.15.0", github: "phoenixframework/phoenix_live_view", branch: "master"}, {:floki, ">= 0.27.0", only: :test}, {:phoenix_html, "~> 2.11"}, {:phoenix_live_reload, "~> 1.2", only: :dev}, {:telemetry_metrics, "~> 0.4"}, {:telemetry_poller, "~> 0.4"}, {:jason, "~> 1.0"}, {:plug_cowboy, "~> 2.0"}, {:earmark_parser, "~> 1.4"} ] 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", "cmd npm install --prefix assets"], # Update the assets bundle to be committed into the repository # and also builds the Escript. build: ["cmd npm run deploy --prefix ./assets", "escript.build"], "format.all": ["format", "cmd npm run format --prefix ./assets"] ] end defp escript() do [ main_module: LivebookCLI, app: nil ] end defp preferred_cli_env() do [ build: :prod ] end end