mirror of
https://github.com/kieraneglin/pinchflat.git
synced 2026-01-23 02:24:24 +00:00
52 lines
1.7 KiB
Elixir
52 lines
1.7 KiB
Elixir
defmodule PinchflatWeb.CustomComponents.TabComponents do
|
|
@moduledoc false
|
|
use Phoenix.Component
|
|
|
|
@doc """
|
|
Takes a list of tabs and renders them in a tabbed layout.
|
|
"""
|
|
slot :tab, required: true do
|
|
attr :id, :string, required: true
|
|
attr :title, :string, required: true
|
|
end
|
|
|
|
slot :tab_append, required: false
|
|
|
|
def tabbed_layout(assigns) do
|
|
assigns = Map.put(assigns, :first_tab_id, hd(assigns.tab).id)
|
|
|
|
~H"""
|
|
<div
|
|
x-data={"{
|
|
openTab: getTabFromHash('#{@first_tab_id}', '#{@first_tab_id}'),
|
|
activeClasses: 'text-meta-5 border-meta-5',
|
|
inactiveClasses: 'border-transparent'
|
|
}"}
|
|
@hashchange.window={"openTab = getTabFromHash(openTab, '#{@first_tab_id}')"}
|
|
class="w-full"
|
|
>
|
|
<header class="flex flex-col md:flex-row md:justify-between border-b border-strokedark">
|
|
<div class="flex flex-wrap gap-5 sm:gap-10">
|
|
<a
|
|
:for={tab <- @tab}
|
|
href="#"
|
|
@click.prevent={"openTab = setTabByName('#{tab.id}')"}
|
|
x-bind:class={"openTab === '#{tab.id}' ? activeClasses : inactiveClasses"}
|
|
class="border-b-2 py-4 w-full sm:w-fit text-sm font-medium hover:text-meta-5 md:text-base"
|
|
>
|
|
<span class="text-xl">{tab.title}</span>
|
|
</a>
|
|
</div>
|
|
<div class="mx-4 my-4 lg:my-0 flex gap-5 sm:gap-10 items-center">
|
|
{render_slot(@tab_append)}
|
|
</div>
|
|
</header>
|
|
<div class="mt-4 min-h-60 overflow-x-auto">
|
|
<div :for={tab <- @tab} x-show={"openTab === '#{tab.id}'"} class="font-medium leading-relaxed">
|
|
{render_slot(tab)}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
"""
|
|
end
|
|
end
|