From 86ce28346cd5ff7d73006b61a279c9c0e15467d5 Mon Sep 17 00:00:00 2001 From: Angelika Tyborska Date: Mon, 1 Jul 2024 14:59:38 +0200 Subject: [PATCH] Add color and variant to button --- lib/bitstyles_phoenix/component/button.ex | 197 ++++++++++++++---- .../component/button_test.exs | 23 ++ 2 files changed, 177 insertions(+), 43 deletions(-) diff --git a/lib/bitstyles_phoenix/component/button.ex b/lib/bitstyles_phoenix/component/button.ex index 26802b6..e11734a 100644 --- a/lib/bitstyles_phoenix/component/button.ex +++ b/lib/bitstyles_phoenix/component/button.ex @@ -1,5 +1,6 @@ defmodule BitstylesPhoenix.Component.Button do use BitstylesPhoenix.Component + alias BitstylesPhoenix.Bitstyles @moduledoc """ The button component. @@ -12,7 +13,9 @@ defmodule BitstylesPhoenix.Component.Button do @doc """ Renders anchor or button elements that look like a button — using the `a-button` classes. - `href`, `navigate`, `patch` - if there’s one of these, you’ll get an anchor element, otherwise a button element. (See Phoenix.Component.link/1) - - `variant` - specifies which visual variant of button you want, from those available in the CSS classes e.g. `ui`, `danger` + - `color` - specifies the color of the button, e.g `secondary`, `transparent`. Leave empty for default color. Introduced in Bitstyles 5.0.0. + - `shape` - specifies the color of the button, e.g `square`, `small`. Leave empty for default color. Introduced in Bitstyles 5.0.0. + - `variant` - specifies which visual variant of button you want, from those available in the CSS classes e.g. `ui`, `danger`. Deprecated in favor of `color` and `shape` in Bitstyles 5.0.0. - `class` - Extra classes to pass to the badge. See `BitstylesPhoenix.Helper.classnames/1` for usage. - `icon` - An icon name as string or a tuple with `{icon_name, icon_opts}` which is passed to `BitstylesPhoenix.Component.Icon.ui_icon/1` as attributes. Additionally it is possible to pass `after: true` to the icon_opts, to make the icon appear after the button label instead of in @@ -50,14 +53,14 @@ defmodule BitstylesPhoenix.Component.Button do ''' iex> assigns = %{} ...> render ~H""" - ...> <.ui_button href="/" variant="ui"> + ...> <.ui_button href="/"> ...> Publish ...> ...> """ ''', ''' """ - + Publish """ @@ -69,14 +72,14 @@ defmodule BitstylesPhoenix.Component.Button do ''' iex> assigns = %{} ...> render ~H""" - ...> <.ui_button href="/" variant="ui" disabled> + ...> <.ui_button href="/" disabled> ...> Publish ...> ...> """ ''', ''' """ - """ @@ -122,18 +125,37 @@ defmodule BitstylesPhoenix.Component.Button do ) story( - "UI button", + "Secondary button", ''' iex> assigns = %{} ...> render ~H""" - ...> <.ui_button type="submit" variant={:ui}> + ...> <.ui_button type="submit" color={:secondary}> ...> Save ...> ...> """ ''', ''' """ - + """ + ''' + ) + + story( + "Small button", + ''' + iex> assigns = %{} + ...> render ~H""" + ...> <.ui_button type="submit" shape={:small}> + ...> Save + ...> + ...> """ + ''', + ''' + """ + """ @@ -145,7 +167,7 @@ defmodule BitstylesPhoenix.Component.Button do ''' iex> assigns = %{} ...> render ~H""" - ...> <.ui_button type="submit" variant={:danger}> + ...> <.ui_button type="submit" color={:danger}> ...> Save ...> ...> """ @@ -262,9 +284,27 @@ defmodule BitstylesPhoenix.Component.Button do ) def ui_button(assigns) do - extra = assigns_to_attributes(assigns, [:icon, :class, :variant]) + extra = assigns_to_attributes(assigns, [:icon, :class, :color, :shape, :variant]) + + assigns = + if Bitstyles.version() >= "5.0.0" && assigns[:variant] do + IO.warn("Attribute `variant` is deprecated in ui_button/1! Change to `color` and `shape`") + + assigns + |> assign(:color, variant_to_color(assigns[:variant])) + |> assign(:shape, variant_to_shape(assigns[:variant])) + else + assigns + end + + classes = + if Bitstyles.version() >= "5.0.0" do + color_and_shape_classes(assigns[:color], assigns[:shape]) + else + variant_classes(assigns[:variant]) + end - class = classnames(["a-button"] ++ variant_classes(assigns[:variant]) ++ [assigns[:class]]) + class = classnames(["a-button"] ++ classes ++ [assigns[:class]]) assigns = assigns @@ -317,6 +357,27 @@ defmodule BitstylesPhoenix.Component.Button do """ end + defp variant_to_color("danger"), do: "danger" + defp variant_to_color("icon-reversed"), do: "transparent" + defp variant_to_color("icon"), do: "secondary" + defp variant_to_color("nav-large"), do: "transparent" + defp variant_to_color("nav"), do: "transparent" + defp variant_to_color("tab"), do: "tab" + defp variant_to_color("ui"), do: "secondary" + defp variant_to_color(_), do: "" + + defp variant_to_shape("icon-reversed"), do: "square" + defp variant_to_shape("icon"), do: "square" + defp variant_to_shape("small"), do: "small" + defp variant_to_shape("tab"), do: "tab" + defp variant_to_shape(_), do: "" + + defp color_and_shape_classes(color, shape) do + [color, shape] + |> Enum.filter(&(&1 not in ["", nil])) + |> Enum.map(&"a-button--#{&1}") + end + defp variant_classes(nil), do: [] defp variant_classes(variant) when is_binary(variant) or is_atom(variant), @@ -368,19 +429,34 @@ defmodule BitstylesPhoenix.Component.Button do ...> <.ui_icon_button icon="plus" label="Add" href="#"/> ...> """ ''', - ''' - """ - - - - Add - - - """ - ''', + [ + "5.0.1": ''' + """ + + + + Add + + + """ + ''', + "4.3.0": ''' + """ + + + + Add + + + """ + ''' + ], extra_html: """ - Show - - - """ - ''', + [ + "5.0.1": ''' + """ + + + + Show + + + """ + ''', + "4.3.0": ''' + """ + + + + Show + + + """ + ''' + ], extra_html: """ <%= @label %> diff --git a/test/bitstyles_phoenix/component/button_test.exs b/test/bitstyles_phoenix/component/button_test.exs index e757446..6906d9b 100644 --- a/test/bitstyles_phoenix/component/button_test.exs +++ b/test/bitstyles_phoenix/component/button_test.exs @@ -26,5 +26,28 @@ defmodule BitstylesPhoenix.Component.ButtonTest do assert String.contains?(warning, "deprecated") end + + test "deprecate :variant" do + warning = + ExUnit.CaptureIO.capture_io(:stderr, fn -> + assigns = %{} + + result = + render(~H""" + <.ui_button variant="ui"> + Show + + """) + + assert result == + """ + + """ + end) + + assert String.contains?(warning, "deprecated") + end end end