lampuotomatis/public/build/js/pages/job-candidate-grid.init.js

184 lines
6.6 KiB
JavaScript

/*
Template Name: Grenviro Monitoring
Author: Themesbrand
Website: https://Themesbrand.com/
Contact: Themesbrand@gmail.com
File: job candidate grid init js
*/
var url = "build/json/";
var allcandidateList = '';
var prevButton = document.getElementById('page-prev');
var nextButton = document.getElementById('page-next');
// configuration variables
var currentPage = 1;
var itemsPerPage = 20;
var getJSON = function (jsonurl, callback) {
var xhr = new XMLHttpRequest();
xhr.open("GET", url + jsonurl, true);
xhr.responseType = "json";
xhr.onload = function () {
var status = xhr.status;
if (status === 200) {
callback(null, xhr.response);
} else {
callback(status, xhr.response);
}
};
xhr.send();
};
// get json
getJSON("job-candidate-list.json", function (err, data) {
if (err !== null) {
console.log("Something went wrong: " + err);
} else {
allcandidateList = data;
loadCandidateListData(allcandidateList, currentPage);
paginationEvents();
}
});
function loadCandidateListData(datas, page) {
var pages = Math.ceil(datas.length / itemsPerPage)
if (page < 1) page = 1
if (page > pages) page = pages
document.querySelector("#candidate-list").innerHTML = '';
for (var i = (page - 1) * itemsPerPage; i < (page * itemsPerPage) && i < datas.length; i++) {
// Array.from(datas).forEach(function (listData, index){
if (datas[i]) {
var isUserProfile = datas[i].userImg ? '<img src="' + datas[i].userImg + '" alt="" class="member-img img-fluid d-block rounded" />'
: '<div class="avatar-title border bg-light text-primary rounded text-uppercase fs-24">' + datas[i].nickname + '</div>';
document.querySelector("#candidate-list").innerHTML += '<div class="col-xxl-3 col-md-6">\
<div class="card">\
<div class="card-body">\
<div class="d-flex align-items-center">\
<div class="flex-shrink-0">\
<div class="avatar-lg rounded">'+ isUserProfile + '</div>\
</div>\
<div class="flex-grow-1 ms-3">\
<a href="pages-profile">\
<h5 class="fs-16 mb-1">'+ datas[i].candidateName + '</h5>\
</a>\
<p class="text-muted mb-2">'+ datas[i].designation + '</p>\
<div class="d-flex flex-wrap gap-2 align-items-center">\
<div class="badge text-bg-success"><i class="mdi mdi-star me-1"></i>'+ datas[i].rating[0] + '</div>\
<div class="text-muted">'+ datas[i].rating[1] + '</div>\
</div>\
<div class="d-flex gap-4 mt-2 text-muted">\
<div>\
<i class="ri-map-pin-2-line text-primary me-1 align-bottom"></i> '+ datas[i].location + '</div>\
<div>\
<i class="ri-time-line text-primary me-1 align-bottom"></i>'+ isStatus(datas[i].type) + '\
</div>\
</div>\
</div>\
</div>\
</div>\
</div>\
</div>';
}
}
selectedPage();
currentPage == 1 ? prevButton.parentNode.classList.add('disabled') : prevButton.parentNode.classList.remove('disabled');
currentPage == pages ? nextButton.parentNode.classList.add('disabled') : nextButton.parentNode.classList.remove('disabled');
}
function isStatus(val) {
switch (val) {
case "Part Time":
return ('<span class="badge bg-danger-subtle text-danger">' + val + "</span>");
case "Full Time":
return ('<span class="badge bg-success-subtle text-success">' + val + "</span>");
case "Freelancer":
return ('<span class="badge bg-secondary-subtle text-secondary">' + val + "</span>");
}
}
function selectedPage() {
var pagenumLink = document.getElementById('page-num').getElementsByClassName('clickPageNumber');
for (var i = 0; i < pagenumLink.length; i++) {
if (i == currentPage - 1) {
pagenumLink[i].parentNode.classList.add("active");
} else {
pagenumLink[i].parentNode.classList.remove("active");
}
}
};
// paginationEvents
function paginationEvents() {
var numPages = function numPages() {
return Math.ceil(allcandidateList.length / itemsPerPage);
};
function clickPage() {
document.addEventListener('click', function (e) {
if (e.target.nodeName == "A" && e.target.classList.contains("clickPageNumber")) {
currentPage = e.target.textContent;
loadCandidateListData(allcandidateList, currentPage);
}
});
};
function pageNumbers() {
var pageNumber = document.getElementById('page-num');
pageNumber.innerHTML = "";
// for each page
for (var i = 1; i < numPages() + 1; i++) {
pageNumber.innerHTML += "<div class='page-item'><a class='page-link clickPageNumber' href='javascript:void(0);'>" + i + "</a></div>";
}
}
prevButton.addEventListener('click', function () {
if (currentPage > 1) {
currentPage--;
loadCandidateListData(allcandidateList, currentPage);
}
});
nextButton.addEventListener('click', function () {
if (currentPage < numPages()) {
currentPage++;
loadCandidateListData(allcandidateList, currentPage);
}
});
pageNumbers();
clickPage();
selectedPage();
}
// Search list
var searchElementList = document.getElementById("searchJob");
searchElementList.addEventListener("keyup", function () {
var inputVal = searchElementList.value.toLowerCase();
function filterItems(arr, query) {
return arr.filter(function (el) {
return el.designation.toLowerCase().indexOf(query.toLowerCase()) !== -1 || el.candidateName.toLowerCase().indexOf(query.toLowerCase()) !== -1
})
}
var filterData = filterItems(allcandidateList, inputVal);
if (filterData.length == 0) {
document.getElementById("pagination-element").style.display = "none";
} else {
document.getElementById("pagination-element").style.display = "flex";
}
var pageNumber = document.getElementById('page-num');
pageNumber.innerHTML = "";
var dataPageNum = Math.ceil(filterData.length / itemsPerPage)
// for each page
for (var i = 1; i < dataPageNum + 1; i++) {
pageNumber.innerHTML += "<div class='page-item'><a class='page-link clickPageNumber' href='javascript:void(0);'>" + i + "</a></div>";
}
loadCandidateListData(filterData, currentPage);
});