core/api/modules/a_tovar_cat/mod.js

193 lines
5.9 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/* ----------------------------------------------------------------------
23.02.2023
Создаем новую категорию
---------------------------------------------------------------------- */
$("#formNewCategory").submit(function(event) {
event.preventDefault();
var formData = new FormData(this);
$.ajax({
type: 'POST', // Тип запроса
url: '/act/a_tovar_cat', // Скрипт обработчика
data: formData, // Данные которые мы передаем
cache: false, // В запросах POST отключено по умолчанию, но перестрахуемся
contentType: false, // Тип кодирования данных мы задали в форме, это отключим
processData: false,
success: function(data) {
location="/a_tovar_cat/" + data;
}
});
$(".close").click();
})
/* ----------------------------------------------------------------------
21.12.2022
Обновляем статус категории товара
---------------------------------------------------------------------- */
$(".check-status").click(function(event){
var id=$(this).data("id");
if ($(this).is(':checked'))
var status = 1;
else
var status = 0;
$.ajax({
type: "POST",
url: '/act/a_tovar_cat',
data: "act=updateStatus&id=" + id + "&status=" + status
});
})
/* ----------------------------------------------------------------------
21.12.2022
Пишет настройку отображения не опубликованных товаров и категорий
---------------------------------------------------------------------- */
$("#setShowNoPublic").click(function(event){
if ($(this).is(':checked'))
var status = 1;
else
var status = 0;
$.ajax({
type: "POST",
url: '/act/a_tovar_cat',
data: "act=setSettings&showNoPublic=showNoPublic&val=" + status
});
})
/* ----------------------------------------------------------------------
02.01.2023
Сохраняем мета-теги
---------------------------------------------------------------------- */
$(".save-meta").keyup(function(event){
var id=$(this).data('id');
var txt=$(this).val();
var pole=$(this).data('pole');
$.ajax({
type: "POST",
url: '/act/a_tovar_cat',
data: "act=savemeta&id=" + id + "&pole=" + pole + "&txt=" + txt
});
})
/* ----------------------------------------------------------------------
02.01.2023
Сохраняем заголок категории
---------------------------------------------------------------------- */
$(".save-title").keyup(function(event){
var id=$(this).data('id');
var txt=$(this).val();
$.ajax({
type: "POST",
url: '/act/a_tovar_cat',
data: "act=savetitle&id=" + id + "&txt=" + txt
});
})
// ************************ Drag and drop ***************** //
let dropArea = document.getElementById("drop-area")
// Prevent default drag behaviors
;
['dragenter', 'dragover', 'dragleave', 'drop'].forEach(eventName => {
dropArea.addEventListener(eventName, preventDefaults, false)
document.body.addEventListener(eventName, preventDefaults, false)
})
// Highlight drop area when item is dragged over it
;
['dragenter', 'dragover'].forEach(eventName => {
dropArea.addEventListener(eventName, highlight, false)
})
;
['dragleave', 'drop'].forEach(eventName => {
dropArea.addEventListener(eventName, unhighlight, false)
})
// Handle dropped files
dropArea.addEventListener('drop', handleDrop, false)
function preventDefaults(e) {
e.preventDefault()
e.stopPropagation()
}
function highlight(e) {
dropArea.classList.add('highlight')
}
function unhighlight(e) {
dropArea.classList.remove('active')
}
function handleDrop(e) {
var dt = e.dataTransfer
var files = dt.files
handleFiles(files)
}
let uploadProgress = []
let progressBar = document.getElementById('progress-bar')
function initializeProgress(numFiles) {
progressBar.value = 0
uploadProgress = []
for (let i = numFiles; i > 0; i--) {
uploadProgress.push(0)
}
}
function updateProgress(fileNumber, percent) {
uploadProgress[fileNumber] = percent
let total = uploadProgress.reduce((tot, curr) => tot + curr, 0) / uploadProgress.length
console.debug('update', fileNumber, percent, total)
progressBar.value = total
}
function handleFiles(files) {
files = [...files]
initializeProgress(files.length)
files.forEach(uploadFile)
files.forEach(previewFile)
}
function previewFile(file) {
let reader = new FileReader()
reader.readAsDataURL(file)
reader.onloadend = function() {
let img = document.createElement('img')
img.src = reader.result
document.getElementById('gallery').appendChild(img)
}
}
function uploadFile(file, i) {
var url = '/act/a_tovar_cat'
var xhr = new XMLHttpRequest()
var formData = new FormData()
xhr.open('POST', url, true)
xhr.setRequestHeader('X-Requested-With', 'XMLHttpRequest')
// Update progress (can be used to show progress indicator)
xhr.upload.addEventListener("progress", function(e) {
updateProgress(i, (e.loaded * 100.0 / e.total) || 100)
})
xhr.addEventListener('readystatechange', function(e) {
if (xhr.readyState == 4 && xhr.status == 200) {
updateProgress(i, 100) // <- Add this
} else if (xhr.readyState == 4 && xhr.status != 200) {
// Error. Inform the user
}
})
formData.append('upload_preset', 'ujpu6gyk')
formData.append('act', 'upload')
formData.append('file', file)
xhr.send(formData)
}