HEX
Server: Apache/2.4.58 (Ubuntu)
System: Linux ip-172-26-0-120 6.17.0-1009-aws #9~24.04.2-Ubuntu SMP Fri Mar 6 23:50:29 UTC 2026 x86_64
User: ubuntu (1000)
PHP: 8.3.6
Disabled: NONE
Upload Files
File: /var/www/html/owlcrm/resources/views/admin/modules/index.blade.php
@extends('adminlte::page')

@section('title', 'OWL CRM Dashboard')
@section('content_header')
    <h1>Modules</h1>
    <small>Manage Modules</small>
@stop

@section('content')
    <div class="card card-dark">
        <div class="card-header">
            <h3 class="card-title"></h3>
            <div class="card-tools">
                <a href="{{ route('module.create') }}" class="btn btn-dark"><i class="fas fa-plus"></i> Add
                    Modules</a>
            </div>
        </div>

        <div class="card-body">
            @if (session('success'))
                <h6 class="alert alert-success">
                    {{ session('success') }}
                </h6>
            @endif
            <form method="POST" id="search-form" role="form">

                <div class="form-group">
                    <label for="search">Search</label>
                    <x-adminlte-input class="form-control" id="search_keyword" name="search_keyword"
                        placeholder="Enter Name" />

                </div>
                <div class="form-group">
                    <label for="search">Status</label>
                    @php
                        $options = ['all' => 'All', STATUS_DISABLED => 'Disabled', STATUS_ENABLED => 'Active'];
                    @endphp
                    <x-adminlte-select name="status_filter" id="status_filter">
                        <x-adminlte-options :options="$options" empty-option="Select an option..." />
                    </x-adminlte-select>

                </div>




            </form>
            <table class="table table-bordered yajra-datatable">
                <thead>
                    <tr>

                        <th>Name</th>
                        <th>Status</th>
                        <th>Actions</th>
                    </tr>
                </thead>
                <tbody>
                </tbody>
            </table>
        </div>
    </div>
@stop

@section('js')


    <script type="text/javascript">
        $(function() {

            var dataTable = $('.yajra-datatable').DataTable({
                processing: true,
                serverSide: true,
                pageLength: 10,
                searching: false,
                'ajax': {
                    'url': "{{ route('module.index') }}",
                    'data': function(data) {
                        // Read values
                        var search_keyword = $('#search_keyword').val();
                        var shop_filter = $('#shop_filter option:selected').val();
                        var status_filter = $('#status_filter option:selected').val();


                        // Append to data
                        data.search_keyword = search_keyword;
                        data.shop_filter = shop_filter;
                        data.status_filter = status_filter;

                    }
                },
                columns: [
                    /*{data: 'checkbox', name: 'checkbox', orderable: false, searchable: false},*/
                    /*  {data: 'id', name: 'ID'},  */
                    {
                        data: 'name',
                        name: 'name'
                    },

                    {
                        data: 'status',
                        name: 'status'
                    },

                    {
                        data: 'action',
                        name: 'action',

                    },
                ]
            });

            $('#search_keyword').keyup(function() {
                dataTable.draw();
            });
            $('#shop_filter').on('change', function() {
                dataTable.draw();
            });
            $('#status_filter').on('change', function() {
                dataTable.draw();
            });



            $(document).on('click', '.update_status', function(e) {
                e.preventDefault();
                var $statusLink = $(this);
                var current_status = $statusLink.data('current-status');
                var new_status = current_status == 0 ? 1 : 0;
                var new_status_label = new_status == 1 ? 'Active' : 'Inactive';
                var url = $statusLink.data('update-url');

                axios.put(url, {
                        new_status: new_status
                    })
                    .then(response => {
                        // Handle success response
                        if (response.data.status === 'success') {
                            $statusLink.hide();
                            $statusLink.siblings('.update_status').show();
                            $statusLink.data('current-status', new_status);
                            $('#success-container').html(response.data.message).show('slow');
                            // Hide success message after 5 seconds
                            setTimeout(function() {
                                $('#success-container').hide('slow');
                            }, 5000);
                        } else {
                            $('#error-container').html(response.data.message).show('slow');
                            // Hide error message after 5 seconds
                            setTimeout(function() {
                                $('#error-container').hide('slow');
                            }, 5000);
                        }
                    })
                    .catch(error => {
                        console.error(error);
                    });
            });


        });
    </script>
    </script>
@stop