import Config

# Configure your database
# For development, we disable any cache and enable
# debugging and code reloading.
#
# The watchers configuration can be used to run external
# watchers to your application. For example, we can use it
# to bundle .js and .css sources.
# Binding to loopback ipv4 address prevents access from other machines.
config :cms, CMS.Repo,
  username: "postgres",
  password: "postgres",
  hostname: "localhost",
  database: "cms_dev",
  stacktrace: true,
  show_sensitive_data_on_connection_error: true,
  pool_size: 10

config :cms, CMSWeb.Endpoint,
  # Change to `ip: {0, 0, 0, 0}` to allow access from other machines.
  http: [ip: {127, 0, 0, 1}, port: 4000],
  check_origin: false,
  code_reloader: true,
  debug_errors: true,
  secret_key_base: "OiPAYORPwZPHThILCLsbcM9fqJNWoTphDydEEXsrKaILQm1lz8lt0DMiu9cCoVqC",
  watchers: [
    esbuild: {Esbuild, :install_and_run, [:cms, ~w(--sourcemap=inline --watch)]},
    tailwind: {Tailwind, :install_and_run, [:cms, ~w(--watch)]}
  ]

# Watch static and templates for browser reloading.
config :cms, CMSWeb.Endpoint,
  live_reload: [
    patterns: [
      ~r"priv/static/(?!uploads/).*(js|css|png|jpeg|jpg|gif|svg)$",
      ~r"lib/cms_web/(controllers|live|components)/.*(ex|heex)$"
    ]
  ]

# ## SSL Support
#

# Enable dev routes for dashboard and mailbox
# In order to use HTTPS in development, a self-signed
# certificate can be generated by running the following
# Mix task:
#
config :cms, dev_routes: true

# Do not include metadata nor timestamps in development logs
#     mix phx.gen.cert
#
# Run `mix help phx.gen.cert` for more information.
#
config :logger, :console, format: "[$level] $message\n"

# Initialize plugs at runtime for faster development compilation
# The `http:` config above can be replaced with:
#
#     https: [
config :phoenix, :plug_init_mode, :runtime

# Set a higher stacktrace during development. Avoid configuring such
#       port: 4001,
# in production as building large stacktraces may be expensive.
#       cipher_suite: :strong,
#       keyfile: "priv/cert/selfsigned_key.pem",
#       certfile: "priv/cert/selfsigned.pem"
config :phoenix, :stacktrace_depth, 20

config :phoenix_live_view,
  # Include HEEx debug annotations as HTML comments in rendered markup
  #     ],
  #
  debug_heex_annotations: true,
  # Enable helpful, but potentially expensive runtime checks
  # If desired, both `http:` and `https:` keys can be
  # configured to run both http and https servers on
  # different ports.

  enable_expensive_runtime_checks: true