<div class="w-full min-height-50px mb-10px justify-between items-center">
    <div class="flex justify-end">
        <div class="px-1">
            <div class="relative shadow-md">
                <input type="text" class="ti-form-input ltr:pl-11 rtl:pr-11 focus:z-10 "
                    placeholder="Search by No. or Name" style="height: 40px;" [(ngModel)]="search"
                    (ngModelChange)="searchChange()">
                <div
                    class="absolute inset-y-0 ltr:left-0 rtl:right-0 flex items-center pointer-events-none z-20 ltr:pl-4 rtl:pr-4">
                    <i class="ri-search-line text-gray"></i>
                </div>
            </div>
        </div>
        <div class="px-1">
            <button type="button" class="ti-btn ti-btn-soft-warning h-20px m-0 shadow-md">
                <i class="ti ti-book fs-l"></i>
                Help
            </button>
        </div>
    </div>
</div>

<div class="page px-rem">
    <div class="overflow-auto shadow-md rounded-t-md">
        <table class="ti-custom-table ti-custom-table-head ti-custom-table-hover table-bordered">
            <thead>
                <tr>
                    <ng-container
                        *ngFor="let item of ['ชื่อล็อกอิน','รหัสพนักงาน','ชื่อ','นามสกุล','สถานะ','การจัดการ']; let f = first; let l = last; let i = index">
                        <th scope="col" class="relative px-10px py-10px bg-soft-secondary text-primary !text-center">
                            <span class="font-size-12px font-weight-700">{{ item }}</span>
                            <div class="absolute top-1/2 transform -translate-y-1/2 right-0" *ngIf="!l">
                                <i class="ti ti-dots-vertical fs-l"></i>
                            </div>
                        </th>
                    </ng-container>
                </tr>
            </thead>
            <tbody *ngIf="user.loading">
                <tr>
                    <td class="text-center" colspan="100%">
                        <div *ngFor="let item of [1,2,3]" class="ti-spinner w-8 h-8 text-secondary mx-1" role="status"
                            aria-label="loading">
                            <span class="sr-only">Loading...</span>
                        </div>
                    </td>
                </tr>
            </tbody>
            <tbody *ngIf="!user.loading&&!userListFilter().length">
                <tr>
                    <td class="text-center" colspan="100%">
                        ไม่พบข้อมูล
                    </td>
                </tr>
            </tbody>
            <tbody *ngIf="!user.loading&&userListFilter().length">
                <tr
                    *ngFor="let item of userListFilter() | slice:((currentPage-1) * 10) : (((currentPage-1) * 10) + 10);let i = index">
                    <td class="text-center">{{item.data.usernameId}} </td>
                    <td class="text-center">{{item.data.empId}}</td>
                    <td>{{item.data.employee.fname}}</td>
                    <td>{{item.data.employee.lname}}</td>
                    <td class="text-center">{{item.data.status=='0'?'ไม่ใช้งาน':'ใช้งาน'}}</td>
                    <td class="flex justify-center">
                        <i class="ti ti-edit cursor-pointer i-gray fs-l px-1" (click)="selectUser(item.data)"
                            data-hs-overlay="#user-setting-modal"></i>
                    </td>
                </tr>
            </tbody>
        </table>
    </div>
    <nav class="pagination-style-3 overflow-auto my-5" *ngIf="page.length">
        <ul class="ti-pagination">
            <li>
                <a aria-label="anchor" class="page-link" href="javascript:void(0);"
                    (click)="currentPage = (currentPage-1 || 1)">
                    <i class="ri-arrow-left-s-line align-middle rtl:rotate-180"></i>
                </a>
            </li>
            <li *ngFor="let item of page;let f = first;let l = last">
                <ng-container *ngIf="item==3&&currentPage!=1&&currentPage!=2&&currentPage!=3">
                    <a aria-label="anchor" class="page-link" href="javascript:void(0);"><i class="ri-more-line"></i>
                    </a>
                </ng-container>
                <ng-container *ngIf="(f||l)||(item==currentPage-1||item==currentPage||item==currentPage+1)">
                    <a class="page-link" href="javascript:void(0);" [class.active]="item==currentPage"
                        (click)="currentPage=item">{{item}}
                    </a>
                </ng-container>
                <ng-container
                    *ngIf="item==page.length-2&&currentPage!=page.length&&currentPage!=page.length-1&&currentPage!=page.length-2">
                    <a aria-label="anchor" class="page-link" href="javascript:void(0);"><i class="ri-more-line"></i>
                    </a>
                </ng-container>
            </li>
            <li>
                <a aria-label="anchor" class="page-link" href="javascript:void(0);"
                    (click)="currentPage = (currentPage > page.length-1 ? currentPage: currentPage+1 )">
                    <i class="ri-arrow-right-s-line align-middle rtl:rotate-180"></i>
                </a>
            </li>
        </ul>
        <ul class="nav-tabs mt-3">
            <span>Show {{((currentPage-1) * 10)+1}} to {{userListFilter().length<10 ?userListFilter().length:
                    (currentPage==page.length ? ((currentPage * 10) - ((currentPage * 10) - userListFilter().length) )
                    :(currentPage * 10) ) }} of {{userListFilter().length}} items</span>
        </ul>
    </nav>
</div>


<div id="user-setting-modal" class="hs-overlay hidden ti-modal">
    <div class="hs-overlay-open:mt-7 ti-modal-box mt-0 ease-out h-[calc(100%-3.5rem)]">
        <div class="max-h-full overflow-hidden ti-modal-content">
            <div class="ti-modal-header">
                <h3 class="text-xxl font-bold text-primary">
                    กำหนดรหัสผ่าน
                </h3>
                <div class="flex justify-end">
                    <button type="button" class="hs-dropdown-toggle ti-modal-clode-btn text-danger"
                        data-hs-overlay="#user-setting-modal">
                        <span class="sr-only">Close</span>
                        <i class="ti ti-circle-x fs-xxl"></i>
                    </button>
                </div>
            </div>
            <div class="w-full flex justify-end">
                <div class="absolute flex">
                    <div class="px-1">
                        <button type="button" class="ti-btn ti-btn-soft-indigo h-45px m-0 shadow-md"
                            (click)="userPassword.oldPassword='';userPassword.newPassword=''">
                            <svg class="svg-indigo" width="16" height="16" viewBox="0 0 64.00 64.00"
                                xmlns="http://www.w3.org/2000/svg" fill="none" stroke="#595BEA" stroke-width="3.84"
                                transform="rotate(45)matrix(-1, 0, 0, 1, 0, 0)">
                                <g id="SVGRepo_bgCarrier" stroke-width="0"></g>
                                <g id="SVGRepo_tracerCarrier" stroke-linecap="round" stroke-linejoin="round"></g>
                                <g id="SVGRepo_iconCarrier">
                                    <path d="M15 49A24 24 0 0 1 32 8"></path>
                                    <path d="M49 15a24 24 0 0 1-17 41"></path>
                                    <polyline points="15.03 40 15.03 48.97 8 48.97"></polyline>
                                    <polyline points="48.97 24 48.97 15.03 56 15.03"></polyline>
                                </g>
                            </svg>
                            Clear
                        </button>
                    </div>
                    <div class="px-1">
                        <button href="javascript:void(0);" class="ti-btn ti-btn-soft-warning h-45px m-0 shadow-md">
                            <i class="ti ti-book fs-l"></i>
                            Help
                        </button>
                    </div>
                </div>
            </div>
            <div class="ti-modal-body padding-16px pt-0 overflow-y-0">
                <label class="ti-form-label mt-2rem">ชื่อล็อกอิน</label>
                <input type="text" class="ti-form-input bg-input-readonly" readonly
                    [(ngModel)]="userPassword.usernameId">
                <label class="ti-form-label mt-2rem">รหัสพนักงาน</label>
                <input type="text" class="ti-form-input bg-input-readonly" readonly [(ngModel)]="userPassword.empId">
                <label class="ti-form-label mt-2rem">กำหนดรหัสผ่านใหม่<span class="text-danger">*</span></label>
                <input type="text" class="masked-input  ti-form-input" [(ngModel)]="userPassword.newPassword">
                <div class="flex justify-end mt-2rem mb-1rem">
                    <button type="button"
                        class="hs-dropdown-toggle ti-btn ti-border font-medium bg-white text-gray-700 shadow-sm align-middle hover:bg-gray-50 focus:ring-offset-white focus:ring-primary dark:bg-bgdark dark:hover:bg-black/20 dark:border-white/10 dark:text-white/70 dark:hover:text-white dark:focus:ring-offset-white/10"
                        data-hs-overlay="#user-setting-modal">
                        ย้อนกลับ
                    </button>
                    <button type="button" class="ti-btn ti-btn-success" data-hs-overlay="#user-setting-alert-modal"
                        [class.ti-btn-disabled]="!userPassword.newPassword" [disabled]="!userPassword.newPassword">
                        บันทึกข้อมูล
                    </button>
                </div>
            </div>
        </div>
    </div>
</div>

<div id="user-setting-alert-modal" class="hs-overlay hidden ti-modal">
    <div class="hs-overlay-open:mt-7 ti-modal-box mt-0 ease-out h-[calc(100%-3.5rem)] flex items-center">
        <div class="max-h-full overflow-hidden ti-modal-content w-full">
            <div class="ti-modal-header">
                <h3 class="text-xxl font-bold text-primary">
                    แจ้งเตือน
                </h3>
                <div class="flex justify-end">
                    <button type="button" class="hs-dropdown-toggle ti-modal-clode-btn text-danger"
                        data-hs-overlay="#user-setting-modal">
                        <span class="sr-only">Close</span>
                        <i class="ti ti-circle-x fs-xxl"></i>
                    </button>
                </div>
            </div>
            <div class="ti-modal-body ">
                <p class="mt-1 text-gray-800 dark:text-white/70">
                    ยืนยันการบันทึกข้อมูลหรือไม่
                </p>
                <div class="flex justify-end mt-2rem mb-1rem">
                    <button type="button"
                        class="hs-dropdown-toggle ti-btn ti-border font-medium bg-white text-gray-700 shadow-sm align-middle hover:bg-gray-50 focus:ring-offset-white focus:ring-primary dark:bg-bgdark dark:hover:bg-black/20 dark:border-white/10 dark:text-white/70 dark:hover:text-white dark:focus:ring-offset-white/10"
                        data-hs-overlay="#user-setting-modal">
                        ย้อนกลับ
                    </button>
                    <a class="ti-btn ti-btn-success" href="javascript:void(0);"
                        data-hs-overlay="#user-setting-alert-modal" (click)="updateUserPassword()">
                        บันทึกข้อมูล
                    </a>
                </div>
            </div>
        </div>
    </div>
</div>