2023-08-02 21:24:52 +01:00
|
|
|
{{- $items := split (.Get "items") "," -}}
|
|
|
|
{{- $defaultIndex := int ((.Get "defaultIndex") | default "0") -}}
|
|
|
|
|
|
|
|
{{- if not $items -}}
|
|
|
|
{{ errorf "no items provided" }}
|
|
|
|
{{- end -}}
|
|
|
|
|
2025-03-29 12:51:42 +00:00
|
|
|
<div class="hextra-scrollbar hx:overflow-x-auto hx:overflow-y-hidden hx:overscroll-x-contain">
|
|
|
|
<div class="hx:mt-4 hx:flex hx:w-max hx:min-w-full hx:border-b hx:border-gray-200 hx:pb-px hx:dark:border-neutral-800">
|
2024-07-10 01:11:51 +01:00
|
|
|
{{- range $i, $item := $items -}}
|
|
|
|
<button
|
2025-03-29 12:51:42 +00:00
|
|
|
class="hextra-tabs-toggle hx:cursor-pointer hx:data-[state=selected]:border-primary-500 hx:data-[state=selected]:text-primary-600 hx:data-[state=selected]:dark:border-primary-500 hx:data-[state=selected]:dark:text-primary-600 hx:mr-2 hx:rounded-t hx:p-2 hx:font-medium hx:leading-5 hx:transition-colors hx:-mb-0.5 hx:select-none hx:border-b-2 hx:border-transparent hx:text-gray-600 hx:hover:border-gray-200 hx:hover:text-black hx:dark:text-gray-200 hx:dark:hover:border-neutral-800 hx:dark:hover:text-white"
|
2024-07-10 01:11:51 +01:00
|
|
|
role="tab"
|
|
|
|
type="button"
|
|
|
|
aria-controls="tabs-panel-{{ $i }}"
|
2024-08-18 15:38:06 +01:00
|
|
|
{{- if eq $i $defaultIndex }} aria-selected="true" {{ end -}}
|
|
|
|
{{- if eq $i $defaultIndex }} tabindex="0" {{ end -}}
|
|
|
|
{{- if eq $i $defaultIndex }} data-state="selected"{{ end -}}
|
2024-07-10 01:11:51 +01:00
|
|
|
>
|
|
|
|
{{- $item -}}
|
|
|
|
</button>
|
|
|
|
{{- end -}}
|
|
|
|
</div>
|
2023-08-02 21:24:52 +01:00
|
|
|
</div>
|
|
|
|
<div>
|
2024-08-18 15:38:06 +01:00
|
|
|
{{- .Inner -}}
|
2023-08-02 21:24:52 +01:00
|
|
|
</div>
|
2024-08-18 15:38:06 +01:00
|
|
|
{{- /* Drop trailing newlines */ -}}
|