76 lines
3.6 KiB
PHP

@props([
// name of the input field for use in forms
'name' => 'input-'.uniqid(),
// label to display on the input box
'label' => '',
// minimum number a user can enter when numeric=true
'min' => 0,
// maximum number a user can enter when numeric=true
'max' => 100,
// by what digit should incrementing be done
'step' => 1,
// is this a required field? Default is false
'required' => false,
// value to set when in edit mode, or if you want to load the input with default text
'selected_value' => null,
// for numeric input only: should the numbers include dots
'with_dots' => config('bladewind.number.with_dots', true),
'size' => config('bladewind.number.size', 'medium'),
'icon_type' => config('bladewind.number.icon_type', 'outline'),
'transparent_icons' => config('bladewind.number.transparent_icons', true),
'class' => '',
])
@php
$name = preg_replace('/[\s-]/', '_', $name);
$transparent_icons = parseBladewindVariable($transparent_icons);
$min = !is_numeric($min) ? 0 : $min;
$max = (!empty($max) && !is_numeric($max)) ? 100 : $max;
$step = !is_numeric($step) ? 1 : $step;
$selected_value = (!empty($selected_value)) ? $selected_value : (($min != 0) ? $min : 0);
$sizes = [
'small' => [ 'icon' => '!size-4', 'text' => '', 'width' => 'w-36', 'alt_width' => 'w-40'],
'regular' => [ 'icon' => '!size-6', 'text' => '', 'width' => 'w-36', 'alt_width' => 'w-40'],
'medium' => [ 'icon' => '!size-8 !stroke-2', 'text' => 'text-3xl tracking-normal leading-none !py-[5px]', 'width' => 'w-40', 'alt_width' => 'w-48'],
'big' => [ 'icon' => '!size-12 !stroke-1', 'text' => 'text-4xl !py-[8.5px]', 'width' => 'w-48', 'alt_width' => 'w-56'],
];
$size = (in_array($size, ['small','medium', 'regular','big'])) ? $size : 'medium';
@endphp
<span class="inline-flex bw-number-{{$name}} place">
<x-bladewind::input
prefix="arrow-down-circle"
:prefix_is_icon="true"
:prefix_icon_type="$icon_type"
prefix_icon_css="{{$sizes[$size]['icon'] ?? 'size-6'}} cursor-pointer"
:transparent_prefix="$transparent_icons"
suffix="arrow-up-circle"
:suffix_is_icon="true"
:suffix_icon_type="$icon_type"
:transparent_suffix="$transparent_icons"
suffix_icon_css="{{$sizes[$size]['icon']}} cursor-pointer"
numeric="true"
:min="$min"
:max="$max"
:label="$label"
:size="$size"
:enforce_limits="true"
:required="$required"
:with_dots="$with_dots"
class="text-center {{$sizes[$size]['text']??''}} font-semibold {{ ($transparent_icons ? $sizes[$size]['width'] : $sizes[$size]['alt_width'])}} {{$class}}"
:selected_value="$selected_value"
:name="$name"/>
</span>
<script>
changeCss('.bw-number-{{$name}} .prefix svg', '!size-4,size-6,!stroke-2', 'remove');
changeCss('.bw-number-{{$name}} .suffix svg', '!size-4,size-6,!stroke-2', 'remove');
domEl('.bw-number-{{$name}} .suffix').addEventListener('click', () => {
domEl('.bw-number-{{$name}} input.{{$name}}').value = parseInt(domEl('.bw-number-{{$name}} input.{{$name}}').value) + parseInt({{$step}});
checkMinMax('{{$min}}', '{{$max}}', '{{$name}}', 1);
});
domEl('.bw-number-{{$name}} .prefix').addEventListener('click', () => {
domEl('.bw-number-{{$name}} input.{{$name}}').value = parseInt(domEl('.bw-number-{{$name}} input.{{$name}}').value) - parseInt({{$step}});
checkMinMax('{{$min}}', '{{$max}}', '{{$name}}', 1);
});
</script>