diff --git a/assets/css/app.scss b/assets/css/app.scss
index 282239bd43..b7e142d981 100644
--- a/assets/css/app.scss
+++ b/assets/css/app.scss
@@ -11,6 +11,8 @@
--tw-content: '' !important;
}
+@import "../../deps/mbta_metro/priv/static/assets/variables.light.css" (prefers-color-scheme: light);
+@import "../../deps/mbta_metro/priv/static/assets/variables.dark.css" (prefers-color-scheme: dark);
@import '../../deps/mbta_metro/priv/static/assets/default.css';
////////////////////////////////////////////////////////////////////////////////////////
diff --git a/assets/package-lock.json b/assets/package-lock.json
index 4d14171fdf..06f283117e 100644
--- a/assets/package-lock.json
+++ b/assets/package-lock.json
@@ -4998,6 +4998,12 @@
"resolved": "https://registry.npmjs.org/quickselect/-/quickselect-2.0.0.tgz",
"integrity": "sha512-RKJ22hX8mHe3Y6wH/N3wCM6BWtjaxIyyUIkpHOvfFnxdI4yD4tBXEBKSbriGujF6jnSVkJrffuo6vxACiSSxIw=="
},
+ "node_modules/@mbta/rider-design-system": {
+ "name": "rider-design-system",
+ "version": "0.5.0",
+ "resolved": "git+ssh://git@github.com/mbta/rider-design-system.git#c9589af1a5c1b6734ffb786f5f8b9ba993662f9c",
+ "license": "ISC"
+ },
"node_modules/@nodelib/fs.scandir": {
"version": "2.1.5",
"license": "MIT",
@@ -15831,6 +15837,7 @@
"resolved": "file:../deps/mbta_metro/priv",
"license": "GPL-3.0-or-later",
"dependencies": {
+ "@mbta/rider-design-system": "github:mbta/rider-design-system",
"@tailwindcss/forms": "0.5.9",
"camelcase-keys": "9.1.3",
"date-fns": "4.1.0",
diff --git a/assets/tailwind.config.js b/assets/tailwind.config.js
index a2e619f98e..f49cefe512 100644
--- a/assets/tailwind.config.js
+++ b/assets/tailwind.config.js
@@ -2,14 +2,35 @@
// https://tailwindcss.com/docs/configuration
const plugin = require("tailwindcss/plugin");
+const { content, plugins, safelist } = require("mbta_metro");
+const { theme: tailwindTheme } = require("mbta_metro/tailwindTheme");
-const {
- colors,
- content,
- fontFamily,
- plugins,
- safelist
-} = require("mbta_metro");
+const moreColors = {
+ ...tailwindTheme.colors,
+ gray: {
+ DEFAULT: "#494f5c",
+ dark: "#1c1e23",
+ light: "#788093",
+ lighter: "#b0b5c0",
+ lightest: "#e9eaed",
+ "bordered-background": "#f2f3f5"
+ },
+ "brand-primary": {
+ DEFAULT: "#165c96",
+ darkest: "#0b2f4c",
+ lightest: "#cee0f4"
+ },
+ "logan-express": {
+ BB: "#f16823",
+ BT: "#0066cc",
+ DV: "#704c9f",
+ FH: "#e81d2d",
+ WO: "#00954c"
+ },
+ massport: "#104c8f",
+ subway: "#494f5c"
+};
+tailwindTheme.colors = moreColors;
module.exports = {
corePlugins: {
@@ -31,45 +52,7 @@ module.exports = {
}
],
theme: {
- extend: {
- colors: {
- ...colors,
- gray: {
- DEFAULT: "#494f5c",
- dark: "#1c1e23",
- light: "#788093",
- lighter: "#b0b5c0",
- lightest: "#e9eaed",
- "bordered-background": "#f2f3f5"
- },
- "brand-primary": {
- DEFAULT: "#165c96",
- darkest: "#0b2f4c",
- lightest: "#cee0f4"
- },
- "logan-express": {
- BB: "#f16823",
- BT: "#0066cc",
- DV: "#704c9f",
- FH: "#e81d2d",
- WO: "#00954c"
- },
- massport: "#104c8f",
- subway: "#494f5c",
- // These will come from the design system someday
- "blue-line": "#003da5",
- "green-line": "#00843d",
- "orange-line": "#ed8b00",
- "red-line": "#da291c",
- "silver-line": "#7c878e",
- "commuter-rail": "#80276c",
- bus: "#ffc72c",
- ferry: "#008eaa"
- }
- },
- fontFamily: {
- ...fontFamily
- },
+ extend: tailwindTheme,
// match screens to Bootstrap's breakpoints for now
// matched from $container-max-widths
screens: {
diff --git a/lib/dotcom_web/components/route_symbols.ex b/lib/dotcom_web/components/route_symbols.ex
index fed21a67ed..29793d909a 100644
--- a/lib/dotcom_web/components/route_symbols.ex
+++ b/lib/dotcom_web/components/route_symbols.ex
@@ -55,7 +55,7 @@ defmodule DotcomWeb.Components.RouteSymbols do
route_class =
if(Routes.Route.silver_line?(assigns.route),
do: "bg-silver-line text-white",
- else: "bg-bus text-black"
+ else: "bg-brand-bus text-black"
)
assigns = update(assigns, :class, &"#{&1} #{route_class}")
diff --git a/lib/dotcom_web/components/trip_planner/itinerary_detail.ex b/lib/dotcom_web/components/trip_planner/itinerary_detail.ex
index f27f1f9ec0..0b667781db 100644
--- a/lib/dotcom_web/components/trip_planner/itinerary_detail.ex
+++ b/lib/dotcom_web/components/trip_planner/itinerary_detail.ex
@@ -38,41 +38,22 @@ defmodule DotcomWeb.Components.TripPlanner.ItineraryDetail do
1}>
Depart at
- <.depart_at_button
+ <.button
:for={{itinerary, index} <- Enum.with_index(@itineraries)}
- active={@itinerary_selection == index}
+ type="button"
+ class={if(@itinerary_selection == index, do: "bg-brand-primary-lightest")}
+ size="small"
+ variant="secondary"
phx-click="select_itinerary"
phx-value-index={index}
>
{Timex.format!(itinerary.start, "%-I:%M%p", :strftime)}
-
+
"""
end
- attr :active, :boolean
- attr :rest, :global
- slot :inner_block
-
- defp depart_at_button(%{active: active} = assigns) do
- background_class = if active, do: "bg-brand-primary-lightest", else: "bg-transparent"
- assigns = assign(assigns, :background_class, background_class)
-
- ~H"""
-
- """
- end
-
defp specific_itinerary_detail(assigns) do
assigns =
assigns
diff --git a/mix.exs b/mix.exs
index c27badacd3..4dc704ccd5 100644
--- a/mix.exs
+++ b/mix.exs
@@ -78,7 +78,7 @@ defmodule DotCom.Mixfile do
{:crc, "0.10.5"},
{:credo, "1.7.8", only: [:dev, :test]},
{:csv, "3.2.1"},
- {:cva, "0.2.1"},
+ {:cva, "0.2.2"},
{:decorator, "1.4.0"},
{:dialyxir, "1.4.4", [only: [:dev, :test], runtime: false]},
{:diskusage_logger, "0.2.0"},
@@ -106,7 +106,7 @@ defmodule DotCom.Mixfile do
{:jason, "1.4.4", override: true},
{:logster, "1.1.1"},
{:mail, "0.3.1"},
- {:mbta_metro, "0.0.65"},
+ {:mbta_metro, "0.1.11"},
{:mock, "0.3.8", [only: :test]},
{:mox, "1.2.0", [only: :test]},
{:nebulex, "2.6.4"},
diff --git a/mix.lock b/mix.lock
index c11e653a67..8d11718e0d 100644
--- a/mix.lock
+++ b/mix.lock
@@ -14,7 +14,7 @@
"crc": {:hex, :crc, "0.10.5", "ee12a7c056ac498ef2ea985ecdc9fa53c1bfb4e53a484d9f17ff94803707dfd8", [:mix, :rebar3], [{:elixir_make, "~> 0.6", [hex: :elixir_make, repo: "hexpm", optional: false]}], "hexpm", "3e673b6495a9525c5c641585af1accba59a1eb33de697bedf341e247012c2c7f"},
"credo": {:hex, :credo, "1.7.8", "9722ba1681e973025908d542ec3d95db5f9c549251ba5b028e251ad8c24ab8c5", [:mix], [{:bunt, "~> 0.2.1 or ~> 1.0", [hex: :bunt, repo: "hexpm", optional: false]}, {:file_system, "~> 0.2 or ~> 1.0", [hex: :file_system, repo: "hexpm", optional: false]}, {:jason, "~> 1.0", [hex: :jason, repo: "hexpm", optional: false]}], "hexpm", "cb9e87cc64f152f3ed1c6e325e7b894dea8f5ef2e41123bd864e3cd5ceb44968"},
"csv": {:hex, :csv, "3.2.1", "6d401f1ed33acb2627682a9ab6021e96d33ca6c1c6bccc243d8f7e2197d032f5", [:mix], [], "hexpm", "8f55a0524923ae49e97ff2642122a2ce7c61e159e7fe1184670b2ce847aee6c8"},
- "cva": {:hex, :cva, "0.2.1", "fe8acf9c6031714c9b671d80fc7728bd1cc9f5df7708669cdb9682856d352f71", [:mix], [{:phoenix_live_view, "~> 0.18", [hex: :phoenix_live_view, repo: "hexpm", optional: false]}], "hexpm", "f913a0367e1aed19df18fbfd0672e0abf48b1ac387432b9b4c32883cd4b0341d"},
+ "cva": {:hex, :cva, "0.2.2", "19ff3fe93c796250f2a3946930e5be62e73019e927aa21c70fcd3c64e9b58466", [:mix], [{:phoenix_live_view, ">= 0.18.0", [hex: :phoenix_live_view, repo: "hexpm", optional: false]}], "hexpm", "cb494f3df0bf4a8c1b3652d052d0c4dc5111ef6981f542cc22210f639bfbfcda"},
"decimal": {:hex, :decimal, "2.3.0", "3ad6255aa77b4a3c4f818171b12d237500e63525c2fd056699967a3e7ea20f62", [:mix], [], "hexpm", "a4d66355cb29cb47c3cf30e71329e58361cfcb37c34235ef3bf1d7bf3773aeac"},
"decorator": {:hex, :decorator, "1.4.0", "a57ac32c823ea7e4e67f5af56412d12b33274661bb7640ec7fc882f8d23ac419", [:mix], [], "hexpm", "0a07cedd9083da875c7418dea95b78361197cf2bf3211d743f6f7ce39656597f"},
"dialyxir": {:hex, :dialyxir, "1.4.4", "fb3ce8741edeaea59c9ae84d5cec75da00fa89fe401c72d6e047d11a61f65f70", [:mix], [{:erlex, ">= 0.2.7", [hex: :erlex, repo: "hexpm", optional: false]}], "hexpm", "cd6111e8017ccd563e65621a4d9a4a1c5cd333df30cebc7face8029cacb4eff6"},
@@ -55,7 +55,7 @@
"makeup_elixir": {:hex, :makeup_elixir, "1.0.1", "e928a4f984e795e41e3abd27bfc09f51db16ab8ba1aebdba2b3a575437efafc2", [:mix], [{:makeup, "~> 1.0", [hex: :makeup, repo: "hexpm", optional: false]}, {:nimble_parsec, "~> 1.2.3 or ~> 1.3", [hex: :nimble_parsec, repo: "hexpm", optional: false]}], "hexpm", "7284900d412a3e5cfd97fdaed4f5ed389b8f2b4cb49efc0eb3bd10e2febf9507"},
"makeup_erlang": {:hex, :makeup_erlang, "1.0.1", "c7f58c120b2b5aa5fd80d540a89fdf866ed42f1f3994e4fe189abebeab610839", [:mix], [{:makeup, "~> 1.0", [hex: :makeup, repo: "hexpm", optional: false]}], "hexpm", "8a89a1eeccc2d798d6ea15496a6e4870b75e014d1af514b1b71fa33134f57814"},
"makeup_html": {:hex, :makeup_html, "0.1.2", "19d4050c0978a4f1618ffe43054c0049f91fe5feeb9ae8d845b5dc79c6008ae5", [:mix], [{:makeup, "~> 1.2", [hex: :makeup, repo: "hexpm", optional: false]}], "hexpm", "b7fb9afedd617d167e6644a0430e49c1279764bfd3153da716d4d2459b0998c5"},
- "mbta_metro": {:hex, :mbta_metro, "0.0.65", "add029569a8e386f66c08d001e7fb11a14e26c2308e3f47a14baebde4822769c", [:mix], [{:floki, "~> 0.36", [hex: :floki, repo: "hexpm", optional: false]}, {:heroicons, "0.5.6", [hex: :heroicons, repo: "hexpm", optional: true]}, {:jason, "1.4.4", [hex: :jason, repo: "hexpm", optional: false]}, {:phoenix, "1.7.14", [hex: :phoenix, repo: "hexpm", optional: false]}, {:phoenix_live_view, "1.0.0-rc.6", [hex: :phoenix_live_view, repo: "hexpm", optional: false]}, {:phoenix_storybook, "0.6.4", [hex: :phoenix_storybook, repo: "hexpm", optional: false]}, {:timex, "3.7.11", [hex: :timex, repo: "hexpm", optional: false]}], "hexpm", "22b4488c60c48b5638a617a8375fe2c3f27dd9b37452669c00f7a0d55abe7157"},
+ "mbta_metro": {:hex, :mbta_metro, "0.1.11", "1ab2cfef7e80594e9f5d3d3239b16e6061cba7b09e893a3ec49c80073422c446", [:mix], [{:cva, "0.2.2", [hex: :cva, repo: "hexpm", optional: false]}, {:floki, "~> 0.36", [hex: :floki, repo: "hexpm", optional: false]}, {:heroicons, "0.5.6", [hex: :heroicons, repo: "hexpm", optional: true]}, {:jason, "1.4.4", [hex: :jason, repo: "hexpm", optional: false]}, {:phoenix, "1.7.14", [hex: :phoenix, repo: "hexpm", optional: false]}, {:phoenix_live_view, "1.0.0-rc.6", [hex: :phoenix_live_view, repo: "hexpm", optional: false]}, {:phoenix_storybook, "0.6.4", [hex: :phoenix_storybook, repo: "hexpm", optional: false]}, {:timex, "3.7.11", [hex: :timex, repo: "hexpm", optional: false]}], "hexpm", "99c31966dc0322a171e3715dcbbc41b185998dc0f1ded906b0d4680f1b9ac19b"},
"meck": {:hex, :meck, "0.9.2", "85ccbab053f1db86c7ca240e9fc718170ee5bda03810a6292b5306bf31bae5f5", [:rebar3], [], "hexpm", "81344f561357dc40a8344afa53767c32669153355b626ea9fcbc8da6b3045826"},
"metrics": {:hex, :metrics, "1.0.1", "25f094dea2cda98213cecc3aeff09e940299d950904393b2a29d191c346a8486", [:rebar3], [], "hexpm", "69b09adddc4f74a40716ae54d140f93beb0fb8978d8636eaded0c31b6f099f16"},
"mime": {:hex, :mime, "2.0.6", "8f18486773d9b15f95f4f4f1e39b710045fa1de891fada4516559967276e4dc2", [:mix], [], "hexpm", "c9945363a6b26d747389aac3643f8e0e09d30499a138ad64fe8fd1d13d9b153e"},