File: /var/www/vhost/disk-apps/teamdemo.sports-crowd.com/resources/views/news_club/list.blade.php
@extends('modules.head') @section('contenido')
<style>
    /* Ensure that the demo table scrolls */
    /* th, */
    td {
        white-space: nowrap;
    }
    div.dataTables_wrapper {
        height: fit-content;
        margin: 0px 10px 0px 10px;
    }
    .dataTables_scrollBody {
        max-height: none !important;
    }
    a:hover,
    a:active,
    a:focus {
        outline: none;
        text-decoration: none;
        color: #797D7F !important;
    }
    .expiredDate {
        background-color: #FB5656 !important;
    }
</style>
<div class="box-header">
    <a class="auxiliar-black" href="{{ url('/news/add') }}">
        <button class="btn btnAdd pull-right">
            <i style="margin-right:5px;" class="fa fa-plus"></i>
            {{ Lang::get('messages.news_club.add') }}
        </button></a>
</div>
<!-- List Data -->
<div class="box">
    <div class="box-header with-border">
        <h3 class="box-title">{{ Lang::get('messages.news_club.title') }}</h3>
    </div>
    <!-- /.box-header -->
    <div class="box-body table-responsive ">
        <table id="example2" class="table table-bordered table-hover dataTable" role="grid" aria-describedby="example2_info">
            <thead>
                <tr role="row">
                    <th class="sorting" tabindex="0" aria-controls="example2" rowspan="1" colspan="1" aria-label="Browser: activate to sort column ascending">{{ Lang::get('messages.news_club.name') }}</th>
                    <th class="sorting" tabindex="0" aria-controls="example2" rowspan="1" colspan="1" aria-label="Browser: activate to sort column ascending">{{ Lang::get('messages.news_club.image') }}</th>
                    <th class="sorting" tabindex="0" aria-controls="example2" rowspan="1" colspan="1" aria-label="Browser: activate to sort column ascending">{{ Lang::get('messages.news_club.link') }}</th>
                    <th class="sorting" tabindex="0" aria-controls="example2" rowspan="1" colspan="1" aria-label="Browser: activate to sort column ascending">{{ Lang::get('messages.news_club.init_date') }}</th>
                    <th class="sorting" tabindex="0" aria-controls="example2" rowspan="1" colspan="1" aria-label="Browser: activate to sort column ascending">{{ Lang::get('messages.news_club.end_date') }}</th>
                    <th class="sorting" tabindex="0" aria-controls="example2" rowspan="1" colspan="1" aria-label="Browser: activate to sort column ascending">{{ Lang::get('messages.news_club.description_title') }}</th>
                    <th class="sorting" tabindex="0" aria-controls="example2" rowspan="1" colspan="1" aria-label="Browser: activate to sort column ascending">{{ Lang::get('messages.academy_tournaments.segmentation') }}</th>
                    <th class="sorting" tabindex="0" aria-controls="example2" rowspan="1" colspan="1" aria-label="Browser: activate to sort column ascending">{{ Lang::get('messages.news_club.likes_enabled') }}</th>
                    <th class="sorting" tabindex="0" aria-controls="example2" rowspan="1" colspan="1" aria-label="Browser: activate to sort column ascending">{{ Lang::get('messages.news_club.comments_enabled') }}</th>
                    <th class="sorting" tabindex="0" aria-controls="example2" rowspan="1" colspan="1" aria-label="Browser: activate to sort column ascending">{{ Lang::get('messages.news_club.active') }}</th>
                    <th class="sorting" tabindex="0" aria-controls="example2" rowspan="1" colspan="1" aria-label="Engine version: activate to sort column ascending">{{ Lang::get('messages.news_club.actions') }}</th>
                </tr>
            </thead>
        </table>
    </div>
    <!-- /.box-body -->
</div>
<script src="{{ asset('js/jQuery/jquery-2.2.3.min.js') }}"></script>
<script src="{{ asset('js/crud.js') . '?v=' . time() }}"></script>
<script src="{{ asset('js/news_club.js') . '?v=' . time() }}"></script>
<script src="{{ asset('js/bootstrap/js/bootstrap.min.js') }}"></script>
<script async src="//www.instagram.com/embed.js"></script>
<script type="text/javascript">
    $(document).ready(function() {
        var sort_col = $('#example2').find("th:contains("+ Lang.get('messages.news_club.name')+")")[0].cellIndex;
        _table = $('#example2').DataTable({
            responsive: true,
            processing: true,
            serverSide: true,
            order: [
                [sort_col, 'desc']
            ],
            language: {
                url: window.DATATABLES_LANGUAGE_URL,
            },
            ajax: "{{ route('news.table') }}",
            columns: [
                {
                    data: 'name',
                    name: 'name',
                    render: function(data, type, row) {
                        let initialLength = 20;
                        if (data.length > initialLength) {
                            let substr = data.substring(0, initialLength);
                            let restOfString = data.substring(initialLength);
                            let firstSpaceIndex = restOfString.indexOf(' ');
                            if (firstSpaceIndex !== -1) {
                                let newlineIndex = initialLength + firstSpaceIndex;
                                return data.substring(0, newlineIndex) + '<br>' + data.substring(newlineIndex + 1);
                            }
                        }
                        return data;
                    }
                },
                {
                    data: 'image',
                    name: 'image'
                },
                {
                    data: 'link',
                    name: 'link'
                },
                {
                    data: 'init_date',
                    name: 'init_date'
                },
                {
                    data: 'end_date',
                    name: 'end_date'
                },
                {
                    data: 'description',
                    name: 'description',
                    render: function(data, type, row) {
                        if (!data || data.length === 0) {
                            return '';
                        }
                        let initialLength = 20;
                        let maxLength = 40;
                        let truncatedData = data;
                        if (data.length > maxLength) {
                            truncatedData = data.substring(0, maxLength) + '...';
                        }
                        if (truncatedData.length > initialLength) {
                            let substr = truncatedData.substring(0, initialLength);
                            let restOfString = truncatedData.substring(initialLength);
                            let firstSpaceIndex = restOfString.indexOf(' ');
                            if (firstSpaceIndex !== -1) {
                                let newlineIndex = initialLength + firstSpaceIndex;
                                return truncatedData.substring(0, newlineIndex) + '<br>' + truncatedData.substring(newlineIndex + 1);
                            }
                        }
                        return truncatedData;
                    }
                },
                {
                    data: 'segmentation',
                    render: function(data, type, row) {
                        let tags = '';
                        if (row.segmentation) {
                            let list = row.segmentation.split(',');
                            let data = list.map(function(d) {
                                return '<li>' + d + '</li>';
                            });
                            tags = data.join('');
                        }
                        return tags;
                    },
                    name: 'tags.name'
                },
                {
                    data: 'likes_enabled',
                    name: 'likes_enabled',
                    render: function(data) {
                        return data == 1 ? 'Sí' : 'No';
                    }
                },
                {
                    data: 'comments_enabled',
                    name: 'comments_enabled',
                    render: function(data) {
                        return data == 1 ? 'Sí' : 'No';
                    }
                },
                {
                    data: 'active',
                    name: 'active'
                },
                {
                    data: 'actions',
                    name: 'actions'
                },
            ],
            "createdRow": function(row, data, dataIndex) {
                var currentDate = new Date();
                var endDate = new Date(data.end_date);
                if (endDate < currentDate) {
                    console.log(data, "data");
                    $(row).addClass('expiredDate');
                }
            }
        });
        var info = '<i class="fa  fa-info-circle"  id="btn-info-busqueda"></i><div class="dropdown-menu" id="menuBusqueda" style="left: 50%; padding: 5px; background-color: #f9fb8f;"><p data-toggle="modal">Busqueda por Nombre, Orden y Link</p></div>';
        $('#example2_filter').append(info);
        $('#btn-info-busqueda').on('click', function() {
            $('#menuBusqueda').toggle();
        });
    });
</script>
@endsection