const regex = /(class+)=["']?((?:.(?!["']?\s+(?:\S+)=|[>"']))+.)["']?/gmiu;
// Alternative syntax using RegExp constructor
// const regex = new RegExp('(class+)=["\']?((?:.(?!["\']?\\s+(?:\\S+)=|[>"\']))+.)["\']?', 'gmiu')
const str = `<div>
@if(\$beforeTableSlot)
<div class="mt-8">
@include(\$beforeTableSlot)
</div>
@endif
<div class="relative">
<div class="flex justify-between items-center mb-1">
<div class="flex-grow h-10 flex items-center">
@if(\$this->searchableColumns()->count())
<div class="w-96 flex rounded-lg shadow-sm">
<div class="relative flex-grow focus-within:z-10">
<div class="absolute inset-y-0 left-0 pl-3 flex items-center pointer-events-none">
<svg class="h-5 w-5 text-gray-400" viewBox="0 0 20 20" stroke="currentColor" fill="none">
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z" />
</svg>
</div>
<input wire:model.debounce.500ms="search" class="w-full pl-10 py-3 text-sm leading-4 block rounded-md border-gray-300 shadow-sm focus:border-blue-300 focus:ring focus:ring-blue-200 focus:ring-opacity-50 focus:outline-none" placeholder="{{__('Search in')}} {{ \$this->searchableColumns()->map->label->join(', ') }}" type="text" />
<div class="absolute inset-y-0 right-0 pr-2 flex items-center">
<button wire:click="\$set('search', null)" class="text-gray-300 hover:text-red-600 focus:outline-none">
<x-icons.x-circle class="h-5 w-5 stroke-current" />
</button>
</div>
</div>
</div>
@endif
</div>
<div class="flex items-center space-x-1">
<x-icons.cog wire:loading class="h-9 w-9 animate-spin text-gray-400" />
@if(\$exportable)
<div x-data="{ init() {
window.livewire.on('startDownload', link => window.open(link,'_blank'))
} }" x-init="init">
<button wire:click="export" class="flex items-center space-x-2 px-3 border border-green-400 rounded-md bg-white text-green-500 text-xs leading-4 font-medium uppercase tracking-wider hover:bg-green-200 focus:outline-none"><span>{{ __('Export') }}</span>
<x-icons.excel class="m-2" /></button>
</div>
@endif
@if(\$hideable === 'select')
@include('datatables::hide-column-multiselect')
@endif
</div>
</div>
@if(\$hideable === 'buttons')
<div class="p-2 grid grid-cols-8 gap-2">
@foreach(\$this->columns as \$index => \$column)
<button wire:click.prefetch="toggle('{{ \$index }}')" class="px-3 py-2 rounded text-white text-xs focus:outline-none
{{ \$column['hidden'] ? 'bg-blue-100 hover:bg-blue-300 text-blue-600' : 'bg-blue-500 hover:bg-blue-800' }}">
{{ \$column['label'] }}
</button>
@endforeach
</div>
@endif
<div class="rounded-lg shadow-lg bg-white max-w-screen overflow-auto">
<div class="rounded-lg @unless(\$this->hidePagination) rounded-b-none @endif">
<div class="table align-middle min-w-full">
@unless(\$this->hideHeader)
<div class="table-row divide-x divide-gray-200">
@foreach(\$this->columns as \$index => \$column)
@if(\$hideable === 'inline')
@include('datatables::header-inline-hide', ['column' => \$column, 'sort' => \$sort])
@elseif(\$column['type'] === 'checkbox')
@unless(\$column['hidden'])
<div class="w-32 py-4 flex justify-center overflow-hidden align-top px-6 border-b border-gray-200 bg-gray-50 text-left text-xs leading-4 font-medium text-gray-500 uppercase tracking-wider focus:outline-none">
<div class="px-3 py-1 rounded @if(count(\$selected)) bg-orange-400 @else bg-gray-200 @endif text-white text-center">
{{ count(\$selected) }}
</div>
</div>
@endunless
@else
@include('datatables::header-no-hide', ['column' => \$column, 'sort' => \$sort])
@endif
@endforeach
</div>
<div class="table-row divide-x divide-blue-200 bg-blue-100">
@foreach(\$this->columns as \$index => \$column)
@if(\$column['hidden'])
@if(\$hideable === 'inline')
<div class="table-cell w-5 overflow-hidden align-top bg-blue-100"></div>
@endif
@elseif(\$column['type'] === 'checkbox')
<div class="overflow-hidden align-top bg-blue-100 px-6 py-5 border-b border-gray-200 text-left text-xs leading-4 font-medium text-gray-500 uppercase tracking-wider flex h-full flex-col items-center space-y-2 focus:outline-none">
<div>SELECT ALL</div>
<div>
<input type="checkbox" wire:click="toggleSelectAll" @if(count(\$selected) === \$this->results->total()) checked @endif class="form-checkbox mt-1 h-4 w-4 text-blue-600 transition duration-150 ease-in-out" />
</div>
</div>
@else
<div class="table-cell overflow-hidden align-top">
@isset(\$column['filterable'])
@if( is_iterable(\$column['filterable']) )
<div wire:key="{{ \$index }}">
@include('datatables::filters.select', ['index' => \$index, 'name' => \$column['label'], 'options' => \$column['filterable']])
</div>
@else
<div wire:key="{{ \$index }}">
@include('datatables::filters.' . (\$column['filterView'] ?? \$column['type']), ['index' => \$index, 'name' => \$column['label']])
</div>
@endif
@endisset
</div>
@endif
@endforeach
</div>
@endif
@forelse(\$this->results as \$result)
<div class="table-row p-1 divide-x divide-gray-100 {{ isset(\$result->checkbox_attribute) && in_array(\$result->checkbox_attribute, \$selected) ? 'bg-orange-100' : (\$loop->even ? 'bg-gray-100' : 'bg-gray-50') }}">
@foreach(\$this->columns as \$column)
@if(\$column['hidden'])
@if(\$hideable === 'inline')
<div class="table-cell w-5 overflow-hidden align-top"></div>
@endif
@elseif(\$column['type'] === 'checkbox')
@include('datatables::checkbox', ['value' => \$result->checkbox_attribute])
@else
<div class="px-6 py-2 whitespace-no-wrap text-sm leading-5 text-gray-900 table-cell @if(\$column['align'] === 'right') text-right @elseif(\$column['align'] === 'center') text-center @else text-left @endif">
{!! \$result->{\$column['name']} !!}
</div>
@endif
@endforeach
</div>
@empty
<p class="p-3 text-lg text-teal-600">
{{ __("There's Nothing to show at the moment") }}
</p>
@endforelse
</div>
</div>
@unless(\$this->hidePagination)
<div class="rounded-lg rounded-t-none max-w-screen border-b border-gray-200 bg-white">
<div class="p-2 sm:flex items-center justify-between">
{{-- check if there is any data --}}
@if(count(\$this->results))
<div class="px-8 my-2 sm:my-0 flex items-center">
<select name="perPage" class="custom-select custom-select-sm form-control form-control-sm form-select block w-full leading-6 focus:outline-none" wire:model="perPage">
@foreach(config('livewire-datatables.per_page_options', [ 10, 25, 50, 100 ]) as \$per_page_option)
<option value="{{ \$per_page_option }}">{{ \$per_page_option }}</option>
@endforeach
<option value="99999999">{{__('All')}}</option>
</select>
</div>
<div class="my-4 sm:my-0">
<div class="lg:hidden">
<span class="space-x-2">{{ \$this->results->links('datatables::tailwind-simple-pagination') }}</span>
</div>
<div class="hidden lg:flex justify-center">
<span>{{ \$this->results->links('datatables::tailwind-pagination') }}</span>
</div>
</div>
<div class="flex justify-end text-gray-600">
{{__('Results')}} {{ \$this->results->firstItem() }} - {{ \$this->results->lastItem() }} {{__('of')}}
{{ \$this->results->total() }}
</div>
@endif
</div>
</div>
@endif
</div>
</div>
@if(\$afterTableSlot)
<div class="mt-8">
@include(\$afterTableSlot)
</div>
@endif
</div>
`;
// Reset `lastIndex` if this regex is defined globally
// regex.lastIndex = 0;
let m;
while ((m = regex.exec(str)) !== null) {
// This is necessary to avoid infinite loops with zero-width matches
if (m.index === regex.lastIndex) {
regex.lastIndex++;
}
// The result can be accessed through the `m`-variable.
m.forEach((match, groupIndex) => {
console.log(`Found match, group ${groupIndex}: ${match}`);
});
}
Please keep in mind that these code samples are automatically generated and are not guaranteed to work. If you find any syntax errors, feel free to submit a bug report. For a full regex reference for JavaScript, please visit: https://developer.mozilla.org/en/docs/Web/JavaScript/Guide/Regular_Expressions