This commit is contained in:
2024-04-27 09:23:34 +02:00
commit 11e713ca6f
11884 changed files with 3263371 additions and 0 deletions

View File

@@ -0,0 +1,350 @@
//var ajax_url = "index.php?module=EcmReports&action=summary_javahelper&to_pdf=1";
var isHide = true;
var vatIsHide = true;
var showAndHideButton;
$(document).ready(function(){
$.blockUI({ css: {
border: 'none',
padding: '15px',
backgroundColor: '#000',
'-webkit-border-radius': '10px',
'-moz-border-radius': '10px',
opacity: .5,
'font-weight': 'bold',
'font-size': '16px',
color: '#fff',
},
message: "Trwa generowanie pliku..."
});
showAndHideButton = $( "#showGroupButton" );
showAndHideVatButton = $("#showVatButton");
hideGroups();
hideVats();
showAndHideButton.click(showOrHideGroups);
showAndHideVatButton.click(showOrHideVats);
$("#excelEksport").click( excelExport );
$("#pdfEksport").click( pdfExport );
$.tablesorter.addParser({
// use a unique id
id: 'saas',
is: function(s, table, cell) {
// s is the text from the cell
// table is the current table (as a DOM element; not jQuery object)
// cell is the current table cell (DOM element)
// return false if you don't want this parser to be auto detected
return false;
},
format: function(s, table, cell, cellIndex) {
// s is the text from the cell
// table is the current table (as a DOM element; not jQuery object)
// cell is the current table cell (DOM element)
// cellIndex is the current cell's column index
// format your data for normalization
// (i.e. do something to get and/or modify your data, then return it)
return s.replace('.', '').replace(',', '.');
},
// flag for filter widget (true = ALWAYS search parsed values; false = search cell text)
parsed: false,
// set the type to either numeric or text (text uses a natural sort function
// so it will work for everything, but numeric is faster for numbers
type: 'numeric'
});
// call the tablesorter plugin
$("table").tablesorter({
// extra css class applied to the table row containing the filters & the inputs within that row
filter_cssFilter : '',
// If there are child rows in the table (rows with class name from "cssChildRow" option)
// and this option is true and a match is found anywhere in the child row, then it will make that row
// visible; default is false
filter_childRows : false,
// if true, filters are collapsed initially, but can be revealed by hovering over the grey bar immediately
// below the header row. Additionally, tabbing through the document will open the filter row when an input gets focus
filter_hideFilters : false,
// Set this option to false to make the searches case sensitive
filter_ignoreCase : true,
// jQuery selector string of an element used to reset the filters
filter_reset : '.reset',
// Use the $.tablesorter.storage utility to save the most recent filters
filter_saveFilters : true,
// Delay in milliseconds before the filter widget starts searching; This option prevents searching for
// every character while typing and should make searching large tables faster.
filter_searchDelay : 300,
// Set this option to true to use the filter to find text from the start of the column
// So typing in "a" will find "albert" but not "frank", both have a's; default is false
filter_startsWith : false,
// if false, filters are collapsed initially, but can be revealed by hovering over the grey bar immediately
// below the header row. Additionally, tabbing through the document will open the filter row when an input gets focus
filter_hideFilters : false,
theme: 'blue',
widthFixed : false,
// initialize zebra striping of the table
widgets: ['zebra','stickyHeaders', 'filter'],
// change the default striping class names
// updated in v2.1 to use widgetOptions.zebra = ["even", "odd"]
// widgetZebra: { css: [ "normal-row", "alt-row" ] } still works
widgetOptions : {
zebra : [ "normal-row", "alt-row" ]
}
});
function KeyPress(e) {
var evtobj = window.event? event : e
if (evtobj.keyCode == 68 && evtobj.ctrlKey && evtobj.altKey)
{
$.blockUI({ css: {
border: 'none',
padding: '15px',
backgroundColor: '#000',
'-webkit-border-radius': '10px',
'-moz-border-radius': '10px',
opacity: .5,
'font-weight': 'bold',
'font-size': '16px',
color: '#fff',
},
message: "Sprawdzam wartości..."
});
setTimeout( function() {
check();
}, 1000 );
}
}
document.onkeydown = KeyPress;
});
// Sprawdza poprawność wyników
function check() {
var sum = $('#myTable > tbody > tr').children(".gs");
var summ = 0;
var gs1 = 0;
var gs2 = 0;
var gs3 = 0;
for( var i = 0; i < sum.length; i++ ) {
summ = parseFloat( $(sum[i]).html().replace('.','').replace(',','.') );
gs1 = parseFloat( $(sum[i]).next().html().replace('.','').replace(',','.') );
gs2 = parseFloat( $(sum[i]).next().next().html().replace('.','').replace(',','.') );
gs3 = parseFloat( $(sum[i]).next().next().next().html().replace('.','').replace(',','.') );
gs4 = parseFloat( $(sum[i]).next().next().next().next().html().replace('.','').replace(',','.') );
if( Math.round(summ) == Math.round((gs1+gs2+gs3+gs4)))
{
$(sum[i]).css("background-color", "#CDE28B")
}
else
{
$(sum[i]).css("background-color", "#FF5C3E")
}
}
// Sprawdzanie kosztów
sum = $('#myTable > tbody > tr').children(".gc");
for( var i = 0; i < sum.length; i++ ) {
summ = parseFloat( $(sum[i]).html().replace('.','').replace(',','.') );
gs1 = parseFloat( $(sum[i]).next().html().replace('.','').replace(',','.') );
gs2 = parseFloat( $(sum[i]).next().next().html().replace('.','').replace(',','.') );
gs3 = parseFloat( $(sum[i]).next().next().next().html().replace('.','').replace(',','.') );
gs4 = parseFloat( $(sum[i]).next().next().next().next().html().replace('.','').replace(',','.') );
if( Math.round(summ) == Math.round((gs1+gs2+gs3)))
{
$(sum[i]).css("background-color", "#CDE28B")
}
else
{
$(sum[i]).css("background-color", "#FF5C3E")
}
}
$.unblockUI();
};
function excelExport() {
var url = $(location).attr('href').replace("ListDailySales", "ListDailySalesToExcelFile");
url = url + "&to_pdf=1";
console.log(url);
var fileUrl = url.slice(0, url.indexOf("index")) + "modules/EcmReports/ExcelFiles/DailySales.xls";
/*
$.blockUI({ css: {
border: 'none',
padding: '15px',
backgroundColor: '#000',
'-webkit-border-radius': '10px',
'-moz-border-radius': '10px',
opacity: .5,
'font-weight': 'bold',
'font-size': '16px',
color: '#fff',
},
message: "Trwa generowanie pliku..."
});
*/
$.ajax({
url: url,
success: function(data){
//$.unblockUI();
window.location.href = fileUrl
},
error: function(){
// $.unblockUI();
alert('Eksport zakończony niepowodzeniem!');
}
});
}
function pdfExport() {
var url = $(location).attr('href');
url = url + "&toPDF=1&to_pdf=1";
window.location.href = url;
}
//------------------------------------------------------------------------------
function showOrHideGroups() {
if( isHide == true ) {
showGroups();
isHide = false;
} else {
hideGroups();
isHide = true;
}
}
function showGroups() {
$(".columnSpectrum").show();
$(".nettoValue").addClass("groupActive");
$(".nettoValueG").addClass("groupActiveG");
$(".nettoValueGL").addClass("groupActiveGL");
$("#showGroupButton").attr("value", "Ukryj podział na grupy produktowe");
var filter_row = $("#myTable thead");
var child = $(filter_row).children("tr");
$(filters).find("[data-column='6']").parent().css("border", "1px solid red");
var filters = $(child).next();
$(filters).find("[data-column='6']").parent().show();
$(filters).find("[data-column='7']").parent().show();
$(filters).find("[data-column='8']").parent().show();
$(filters).find("[data-column='12']").parent().show();
$(filters).find("[data-column='15']").parent().show();
$(filters).find("[data-column='16']").parent().show();
$(filters).find("[data-column='17']").parent().show();
$(filters).find("[data-column='18']").parent().show();
}
function hideGroups() {
$(".columnSpectrum").hide();
$(".nettoValue").removeClass("groupActive");
$(".nettoValue").removeClass("groupActive");
$(".nettoValueG").removeClass("groupActiveG");
$(".nettoValueGL").removeClass("groupActiveGL");
$("#showGroupButton").attr("value", "Pokaż podział na grupy produktowe")
if( vatIsHide == false )
$(".nettoValueVat").addClass("groupActive");
var filter_row = $("#myTable thead");
var child = $(filter_row).children("tr");
setTimeout(function(){
var filters = $(child).next();
$(filters).find("[data-column='6']").parent().hide();
$(filters).find("[data-column='7']").parent().hide();
$(filters).find("[data-column='8']").parent().hide();
$(filters).find("[data-column='12']").parent().hide();
$(filters).find("[data-column='15']").parent().hide();
$(filters).find("[data-column='16']").parent().hide();
$(filters).find("[data-column='17']").parent().hide();
$(filters).find("[data-column='18']").parent().hide();
}, 700);
}
//-----------------------------------------------------------------------------
//-----------------------------------------------------------------------------
function showOrHideVats() {
if( vatIsHide == true ) {
showVats();
vatIsHide = false;
} else {
hideVats();
vatIsHide = true;
}
}
function showVats() {
$(".columnVatSpectrum").show();
$(".nettoValueVat").addClass("groupActive");
$(".vataValue").addClass("groupActiveG");
$(".vatbValue").addClass("groupActiveG");
$(".vatcValue").addClass("groupActiveGL");
$("#showVatButton").attr("value", "Ukryj kolumny z VAT");
var filter_row = $("#myTable thead");
var child = $(filter_row).children("tr");
var filters = $(child).next();
$(filters).find("[data-column='9']").parent().show();
$(filters).find("[data-column='10']").parent().show();
$(filters).find("[data-column='11']").parent().show();
}
function hideVats() {
$(".columnVatSpectrum").hide();
$(".vataValue").removeClass("groupActive");
$(".vatbValue").removeClass("groupActiveG");
$(".vatcValue").removeClass("groupActiveGL");
$("#showVatButton").attr("value", "Pokaż kolumny z VAT");
if(isHide != false)
$(".nettoValueVat").removeClass("groupActive");
var filter_row = $("#myTable thead");
var child = $(filter_row).children("tr");
setTimeout(function(){
var filters = $(child).next();
$(filters).find("[data-column='9']").parent().hide();
$(filters).find("[data-column='10']").parent().hide();
$(filters).find("[data-column='11']").parent().hide();
}, 700);
$.unblockUI();
}
//-----------------------------------------------------------------------------

View File

@@ -0,0 +1,405 @@
$(document)
.ready(
function() {
$(".rowShowHide").hide();
$(".tablesShowHide").hide();
// Listener odpowiadający za akcje po kliknięciu na przycisk
// "Exportuj do programu Excel"
$("#excelEksport").click(excelExport);
$("#pdfEksport").click(pdfExport);
function pdfExport() {
var url = $(location).attr('href');
url = url + "&toPDF=1&to_pdf=1";
window.location.href = url;
}
$(".showTables")
.bind(
"click",
function() {
if ($(this).attr("class") == "plusStyle showTables") {
// pobieramy następny wiersz tabeli
// którą chcemy pokazac po czym go
// wyswietlamy
var nextTBody = $(this).parent()
.parent().parent().next();
while ($(nextTBody).attr("id") != "stopTables") {
// sprawdzamy czy kategoria
if ($(nextTBody).attr("class") == "tablesorter-infoOnly tablesShowHide") {
$(nextTBody).show();
}
nextTBody = $(nextTBody).next();
}
$(this).html("[-]");
$(this).attr("class",
"plusStyle hideTables");
} else if ($(this).attr("class") == "plusStyle hideTables") {
// pobieramy następny wiersz tabeli
// którą chcemy schowac po czym go
// chowamy
var nextTBody = $(this).parent()
.parent().parent().next();
while ($(nextTBody).attr("id") != "stopTables") {
// tu chowamy wszystko więc nie
// sprawdzamy kategori
$(nextTBody).hide();
var changePlusMinus = $(
nextTBody).children()
.children();
if ($(changePlusMinus[0])
.children("a").attr(
"class") == "hideRows") {
$(changePlusMinus[0])
.children("a")
.attr("class",
"showRows");
$(changePlusMinus[0])
.children("a")
.html("[+]");
}
nextTBody = $(nextTBody).next();
}
$(this).html("[+]");
$(this).attr("class",
"plusStyle showTables");
}
});
$(".showRows")
.bind(
"click",
function() {
if ($(this).attr("class") == "showRows") {
// pobieramy następny wiersz tabeli
// którą chcemy pokazac po czym go
// wyswietlamy
var nextTBody = $(this).parent()
.parent().parent().next();
while ($(nextTBody).attr("id") != "stopRows") {
$(nextTBody).show();
nextTBody = $(nextTBody).next();
}
$(this).html("[-]");
$(this).attr("class", "hideRows");
} else if ($(this).attr("class") == "hideRows") {
// pobieramy następny wiersz tabeli
// którą chcemy schowac po czym go
// chowamy
var nextTBody = $(this).parent()
.parent().parent().next();
while ($(nextTBody).attr("id") != "stopRows") {
$(nextTBody).hide();
nextTBody = $(nextTBody).next();
}
$(this).html("[+]");
$(this).attr("class", "showRows");
}
});
// dodatkowe dane dla kontrahenta
$(".showProducts")
.click(
function() {
if ($(this).attr("class") === "showProducts") {
var parent = $(this).parent();
var children = $(parent).children();
var contractor = $(children[1])
.attr("contractor");
var category = $(this).attr(
"category");
var subcategory = $(this).attr(
"subcategory");
var date_from = $("#date_from")
.attr("value");
var date_to = $("#date_to").attr(
"value");
var type = $(
"#type option:selected")
.attr("value");
var user = $(
"#user option:selected")
.attr("value");
var pdf_type = $(
"#pdf_type option:selected")
.attr("value");
var group_ks = $(
"#group_ks option:selected")
.attr("value");
var Con = {
contractor : contractor,
date_from : date_from,
date_to : date_to,
type : type,
category : category,
subcategory : subcategory,
user : user,
pdf_type : pdf_type,
group_ks : group_ks
};
$(this).attr("class",
"hideProducts");
var ajax_url = "index.php?module=EcmReports&action=ReportSalesByProducts&to_pdf=1";
$
.blockUI({
css : {
border : 'none',
padding : '15px',
backgroundColor : '#000',
'-webkit-border-radius' : '10px',
'-moz-border-radius' : '10px',
opacity : .5,
'font-weight' : 'bold',
'font-size' : '16px',
color : '#fff',
},
message : "Proszę czekać..."
});
$
.ajax({
type : "POST",
url : ajax_url,
dataType : "text",
success : function(data) {
var parparent = $(
parent)
.parent();
parparent
.after("<tr class='productsTable'><td colspan='8'>"
+ data
+ "</td></tr>");
$.unblockUI();
},
data : Con
});
} else if ($(this).attr("class") === "hideProducts") {
var parent = $(this).parent()
.parent();
$(parent).next().remove(
".productsTable");
$(this).attr("class",
"showProducts");
}
});
// dodatkowe dane dla produktu
$(".showContractors")
.click(
function() {
if ($(this).attr("class") === "showContractors") {
var parent = $(this).parent();
var children = $(parent).children();
var date_from = $("#date_from")
.attr("value");
var date_to = $("#date_to").attr(
"value");
var type = $(
"#type option:selected")
.attr("value");
var productid = $(this).data(
"productid");
var pdf_type = $(
"#pdf_type option:selected")
.attr("value");
var group_ks = $(
"#group_ks option:selected")
.attr("value");
var Con = {
date_from : date_from,
date_to : date_to,
type : type,
pdf_type : pdf_type,
group_ks : group_ks,
productid : productid
};
$(this).attr("class",
"hideContractors");
var ajax_url = "index.php?module=EcmReports&action=getContractorsByProduct&to_pdf=1";
$
.blockUI({
css : {
border : 'none',
padding : '15px',
backgroundColor : '#000',
'-webkit-border-radius' : '10px',
'-moz-border-radius' : '10px',
opacity : .5,
'font-weight' : 'bold',
'font-size' : '16px',
color : '#fff',
},
message : "Proszę czekać..."
});
$
.ajax({
type : "POST",
url : ajax_url,
dataType : "text",
success : function(data) {
var parparent = $(
parent)
.parent();
parparent
.after("<tr class='productsTable'><td colspan='8'>"
+ data
+ "</td></tr>");
$.unblockUI();
},
data : Con
});
} else if ($(this).attr("class") === "hideContractors") {
var parent = $(this).parent()
.parent();
$(parent).next().remove(
".productsTable");
$(this).attr("class",
"showContractors");
}
});
function excelExport() {
var url = $(location).attr('href').replace(
"ReportSales", "ReportSalesToExcelFile");
url = url + "&to_pdf=1";
var fileUrl = url.slice(0, url.indexOf("index"))
+ "modules/EcmReports/ExcelFiles/ReportSales.xls";
$.blockUI({
css : {
border : 'none',
padding : '15px',
backgroundColor : '#000',
'-webkit-border-radius' : '10px',
'-moz-border-radius' : '10px',
opacity : .5,
'font-weight' : 'bold',
'font-size' : '16px',
color : '#fff',
},
message : "Trwa generowanie pliku..."
});
$.ajax({
url : url,
success : function(data) {
$.unblockUI();
window.location.href = fileUrl
},
error : function() {
$.unblockUI();
alert('Eksport zakończony niepowodzeniem!');
}
});
}
$.tablesorter.addParser({
// use a unique id
id : 'number',
is : function(s, table, cell) {
// s is the text from the cell
// table is the current table (as a DOM element; not
// jQuery object)
// cell is the current table cell (DOM element)
// return false if you don't want this parser to be
// auto detected
return false;
},
format : function(s, table, cell, cellIndex) {
// s is the text from the cell
// table is the current table (as a DOM element; not
// jQuery object)
// cell is the current table cell (DOM element)
// cellIndex is the current cell's column index
// format your data for normalization
// (i.e. do something to get and/or modify your
// data, then return it)
return $(cell).attr('data-value');
},
// flag for filter widget (true = ALWAYS search parsed
// values; false = search cell text)
parsed : false,
// set the type to either numeric or text (text uses a
// natural sort function
// so it will work for everything, but numeric is faster
// for numbers
type : 'numeric'
});
// assign the sortStart event
$("#myTable thead").click(function() {
// alert($(this).attr("id"));
$(".productsTable").remove();
var minus = $(".hideProducts");
$.each(minus, function() {
$(this).html("[+]");
$(this).attr("class", "showProducts");
});
});
});
function getProductOrders(pid, date,element) {
var params = {
job : 'getProductOrders',
id : pid,
date : date,
type: $('#date_type').val(),
wz: $('#no_wz').is(':checked')
};
$.ajax({
type : "POST",
url : 'index.php?module=EcmReports&action=javahelper&to_pdf=1',
dataType : "json",
async : false,
success : function(data) {
if (data !== undefined) {
var content = "<table><tr><td>Numer zamówienia</td><td>Kontrahent</td><td>Ilość</td><td>Status</td></tr>"
for ( var key in data.items) {
content += '<tr><td><a href="index.php?module=EcmSales&action=DetailView&record=' + data.items[key].id +'" target="_blank">' + data.items[key].document_no +'</a></td><td>' + data.items[key].parent_name +'</td><td style="text-align:right;"><b>' + data.items[key].quantity +'</b></td><td>' + data.items[key].status +'</td></tr>';
}
content += "</table><br>";
content += "<table style='width:100%;'>";
content += '<tr><td style="width:50%;">Stan magazynowy:</td><td style="text-align:right;width:50%;"><b>' + data.stock +'</b></td></tr>';
content += "</table><br><span onclick='$(\"#"+element+"\").tooltip(\"close\");$(\"#"+element+"\").tooltip(\"destroy\");'>Zamknij okno</span>";
$('#'+element).attr("data-content",content);
var tooltip = $( "#"+element ).tooltip({
items: "[data-content]",
disabled: true,
content: function() {
var current = $( this );
if ($(current).attr( "data-content" )!==undefined) {
return $(current).attr( "data-content" );
}
if ( current.is( "[title]" ) ) {
return current.attr( "title" );
}
}}).on('mouseout focusout', function(event) {
event.stopImmediatePropagation();
});
tooltip.tooltip('open');
}
},
data : params
});
$('#'+element).data('status','show');
}

View File

@@ -0,0 +1,76 @@
var isHide = true;
var vatIsHide = true;
var showAndHideButton;
$(document).ready(function () {
// $.blockUI({ css: {
// border: 'none',
// padding: '15px',
// backgroundColor: '#000',
// '-webkit-border-radius': '10px',
// '-moz-border-radius': '10px',
// opacity: .5,
// 'font-weight': 'bold',
// 'font-size': '16px',
// color: '#fff',
// },
// message: "Trwa generowanie pliku..."
// });
$("#pdfEksport").click(pdfExport);
//var fileUrl = url.slice(0, url.indexOf("index")) + "modules/EcmReports/ExcelFiles/ReportBuyesByVat.xls";
$("table").tablesorter({
theme: 'blue',
widgets: ['zebra', 'staticRow', 'filter'],
widgetOptions: {
zebra: ["normal-row", "alt-row"]
}
});
});
function excelExport() {
var url = $(location).attr('href').replace("ReportBuyesByVat", "ReportBuyesByVatToExcell");
url = url + "&to_pdf=1";
console.log(url);
var fileUrl = url.slice(0, url.indexOf("index")) + "modules/EcmReports/ExcelFiles/RaportZakupu.xls";
$.blockUI({css: {
border: 'none',
padding: '15px',
backgroundColor: '#000',
'-webkit-border-radius': '10px',
'-moz-border-radius': '10px',
opacity: .5,
'font-weight': 'bold',
'font-size': '16px',
color: '#fff',
},
message: "Trwa generowanie pliku..."
});
$.ajax({
url: url,
data: {
date_from: $('#date_from').val(),
date_to: $('#date_to').val(),
},
success: function (data) {
$.unblockUI();
window.location.href = fileUrl
},
error: function () {
$.unblockUI();
alert('Eksport zakończony niepowodzeniem!');
}
});
}
function pdfExport() {
var url = $(location).attr('href');
url = url + "&to_pdf=1";
window.open(url, '_blank');
console.log('cos');
}

View File

@@ -0,0 +1,64 @@
$(document).ready(function () {
$("table").tablesorter({
theme: 'blue',
widgets: ['zebra', 'staticRow'],
widgetOptions: {
zebra: ["normal-row", "alt-row"]
}
});
});
function showHide(id) {
$('[name=child_' + id + ']').toggle(0);
console.log($('#span_' + id).html());
if ($('#span_' + id).html() == '[+]') {
$('#span_' + id).html('[-]');
} else {
$('#span_' + id).html('[+]');
}
}
function pdfExport() {
var url = $(location).attr('href');
url = url + "&toPDF=1&to_pdf=1";
window.location.href = url;
console.log('work');
}
function excelExport() {
var url = $(location).attr('href').replace("ReportEcmWorkCards", "ReportEcmWorkCardsToExcelFile");
url = url + "&to_pdf=1";
var fileUrl = url.slice(0, url.indexOf("index")) + "modules/EcmReports/ExcelFiles/ReportEcmWorkCards.xls";
$.blockUI({css: {
border: 'none',
padding: '15px',
backgroundColor: '#000',
'-webkit-border-radius': '10px',
'-moz-border-radius': '10px',
opacity: .5,
'font-weight': 'bold',
'font-size': '16px',
color: '#fff',
},
message: "Trwa generowanie pliku..."
});
$.ajax({
url: url,
data: {
date_from: $('#date_from').val(),
date_to: $('#date_to').val(),
},
success: function (data) {
$.unblockUI();
window.location.href = fileUrl
},
error: function () {
$.unblockUI();
alert('Eksport zakończony niepowodzeniem!');
}
});
}

View File

@@ -0,0 +1,62 @@
$(document).ready(function () {
$("table").tablesorter({
theme: 'blue',
widgets: ['zebra', 'staticRow'],
widgetOptions: {
zebra: ["normal-row", "alt-row"]
}
});
});
function showHide(id) {
$('[name=child_' + id + ']').toggle(0);
if ($('#span_' + id).html() == '[+]') {
$('#span_' + id).html('[-]');
} else {
$('#span_' + id).html('[+]');
}
}
function pdfExport() {
var url = $(location).attr('href');
url = url + "&toPDF=1&to_pdf=1";
window.location.href = url;
console.log('work');
}
function excelExport() {
var url = $(location).attr('href').replace("ReportEcmWorkCardsEcmProduct", "ReportEcmWorkCardsToExcelFile");
url = url + "&to_pdf=1";
var fileUrl = url.slice(0, url.indexOf("index")) + "modules/EcmReports/ExcelFiles/ReportEcmWorkCards.xls";
$.blockUI({css: {
border: 'none',
padding: '15px',
backgroundColor: '#000',
'-webkit-border-radius': '10px',
'-moz-border-radius': '10px',
opacity: .5,
'font-weight': 'bold',
'font-size': '16px',
color: '#fff',
},
message: "Trwa generowanie pliku..."
});
$.ajax({
url: url,
data: {
date_from: $('#date_from').val(),
date_to: $('#date_to').val(),
},
success: function (data) {
$.unblockUI();
window.location.href = fileUrl
},
error: function () {
$.unblockUI();
alert('Eksport zakończony niepowodzeniem!');
}
});
}

View File

@@ -0,0 +1,281 @@
$(document).ready(function(){
$(".rowShowHide").hide();
$(".tablesShowHide").hide();
// Listener odpowiadający za akcje po kliknięciu na przycisk "Exportuj do programu Excel"
$("#excelEksport").click( excelExport );
$("#pdfEksport").click( pdfExport );
function pdfExport() {
var url = $(location).attr('href');
url = url + "&toPDF=1&to_pdf=1";
window.location.href = url;
}
$(".showTables").bind("click",function(){
if($(this).attr("class")=="plusStyle showTables")
{
//pobieramy następny wiersz tabeli którą chcemy pokazac po czym go wyswietlamy
var nextTBody = $(this).parent().parent().parent().next();
while($(nextTBody).attr("id")!="stopTables")
{
//sprawdzamy czy kategoria
if($(nextTBody).attr("class")=="tablesorter-infoOnly tablesShowHide")
{
$(nextTBody).show();
}
nextTBody=$(nextTBody).next();
}
$(this).html("[-]");
$(this).attr("class","plusStyle hideTables");
}else if($(this).attr("class")=="plusStyle hideTables")
{
//pobieramy następny wiersz tabeli którą chcemy schowac po czym go chowamy
var nextTBody = $(this).parent().parent().parent().next();
while($(nextTBody).attr("id")!="stopTables")
{
//tu chowamy wszystko więc nie sprawdzamy kategori
$(nextTBody).hide();
var changePlusMinus = $(nextTBody).children().children();
if($(changePlusMinus[0]).children("a").attr("class")=="hideRows")
{
$(changePlusMinus[0]).children("a").attr("class","showRows");
$(changePlusMinus[0]).children("a").html("[+]");
}
nextTBody=$(nextTBody).next();
}
$(this).html("[+]");
$(this).attr("class","plusStyle showTables");
}
});
$(".showRows").bind("click",function(){
if($(this).attr("class")=="showRows")
{
//pobieramy następny wiersz tabeli którą chcemy pokazac po czym go wyswietlamy
var nextTBody = $(this).parent().parent().parent().next();
while($(nextTBody).attr("id")!="stopRows")
{
$(nextTBody).show();
nextTBody=$(nextTBody).next();
}
$(this).html("[-]");
$(this).attr("class","hideRows");
}else if($(this).attr("class")=="hideRows")
{
//pobieramy następny wiersz tabeli którą chcemy schowac po czym go chowamy
var nextTBody = $(this).parent().parent().parent().next();
while($(nextTBody).attr("id")!="stopRows")
{
$(nextTBody).hide();
nextTBody=$(nextTBody).next();
}
$(this).html("[+]");
$(this).attr("class","showRows");
}
});
//dodatkowe dane dla kontrahenta
$(".showProducts").click(function(){
if($(this).attr("class")==="showProducts")
{
var parent = $(this).parent();
var children = $(parent).children();
var contractor = $(children[1]).attr("contractor");
var category = $(this).attr("category");
var subcategory = $(this).attr("subcategory");
var date_from = $("#date_from").attr("value");
var date_to = $("#date_to").attr("value");
var type = $("#type option:selected").attr("value");
var user = $("#user option:selected").attr("value");
var pdf_type = $("#pdf_type option:selected").attr("value");
var group_ks = $("#group_ks option:selected").attr("value");
var Con = {
contractor: contractor,
date_from: date_from,
date_to: date_to,
type: type,
category: category,
subcategory: subcategory,
user: user,
pdf_type: pdf_type,
group_ks: group_ks
};
$(this).attr("class","hideProducts");
var ajax_url = "index.php?module=EcmReports&action=ReportSalesByProducts&to_pdf=1";
$.blockUI({ css: {
border: 'none',
padding: '15px',
backgroundColor: '#000',
'-webkit-border-radius': '10px',
'-moz-border-radius': '10px',
opacity: .5,
'font-weight': 'bold',
'font-size': '16px',
color: '#fff',
},
message: "Proszę czekać..."
});
$.ajax({
type : "POST",
url : ajax_url,
dataType : "text",
success : function(data) {
var parparent = $(parent).parent();
parparent.after("<tr class='productsTable'><td colspan='8'>"+data+"</td></tr>");
$.unblockUI();
},
data : Con
});
}else if($(this).attr("class")==="hideProducts")
{
var parent = $(this).parent().parent();
$(parent).next().remove(".productsTable");
$(this).attr("class","showProducts");
}
});
//dodatkowe dane dla produktu
$(".showContractors").click(function(){
if($(this).attr("class")==="showContractors")
{
var parent = $(this).parent();
var children = $(parent).children();
var date_from = $("#date_from").attr("value");
var date_to = $("#date_to").attr("value");
var type = $("#type option:selected").attr("value");
var productid = $( this ).data("productid");
var pdf_type = $("#pdf_type option:selected").attr("value");
var group_ks = $("#group_ks option:selected").attr("value");
var Con = {
date_from: date_from,
date_to: date_to,
type: type,
pdf_type: pdf_type,
group_ks: group_ks,
productid: productid
};
$(this).attr("class","hideContractors");
var ajax_url = "index.php?module=EcmReports&action=getContractorsByProduct&to_pdf=1";
$.blockUI({ css: {
border: 'none',
padding: '15px',
backgroundColor: '#000',
'-webkit-border-radius': '10px',
'-moz-border-radius': '10px',
opacity: .5,
'font-weight': 'bold',
'font-size': '16px',
color: '#fff',
},
message: "Proszę czekać..."
});
$.ajax({
type : "POST",
url : ajax_url,
dataType : "text",
success : function(data) {
var parparent = $(parent).parent();
parparent.after("<tr class='productsTable'><td colspan='8'>"+data+"</td></tr>");
$.unblockUI();
},
data : Con
});
}else if($(this).attr("class")==="hideContractors")
{
var parent = $(this).parent().parent();
$(parent).next().remove(".productsTable");
$(this).attr("class","showContractors");
}
});
function excelExport() {
var url = $(location).attr('href').replace("ReportSales", "ReportSalesToExcelFile");
url = url + "&to_pdf=1";
var fileUrl = url.slice(0, url.indexOf("index")) + "modules/EcmReports/ExcelFiles/ReportSales.xls";
$.blockUI({ css: {
border: 'none',
padding: '15px',
backgroundColor: '#000',
'-webkit-border-radius': '10px',
'-moz-border-radius': '10px',
opacity: .5,
'font-weight': 'bold',
'font-size': '16px',
color: '#fff',
},
message: "Trwa generowanie pliku..."
});
$.ajax({
url: url,
success: function(data){
$.unblockUI();
window.location.href = fileUrl
},
error: function(){
$.unblockUI();
alert('Eksport zakończony niepowodzeniem!');
}
});
}
$.tablesorter.addParser({
// use a unique id
id: 'saas',
is: function(s, table, cell) {
// s is the text from the cell
// table is the current table (as a DOM element; not jQuery object)
// cell is the current table cell (DOM element)
// return false if you don't want this parser to be auto detected
return false;
},
format: function(s, table, cell, cellIndex) {
// s is the text from the cell
// table is the current table (as a DOM element; not jQuery object)
// cell is the current table cell (DOM element)
// cellIndex is the current cell's column index
// format your data for normalization
// (i.e. do something to get and/or modify your data, then return it)
return s.replace('.', '').replace(',', '.').replace('%', '');
},
// flag for filter widget (true = ALWAYS search parsed values; false = search cell text)
parsed: false,
// set the type to either numeric or text (text uses a natural sort function
// so it will work for everything, but numeric is faster for numbers
type: 'numeric'
});
//assign the sortStart event
$("#myTable thead").click(function() {
//alert($(this).attr("id"));
$(".productsTable").remove();
var minus = $(".hideProducts");
$.each(minus,function(){
$(this).html("[+]");
$(this).attr("class","showProducts");
});
});
// call the tablesorter plugin
$("table").tablesorter({
theme: 'blue',
// initialize zebra striping of the table
widgets: ['zebra','staticRow'],
// change the default striping class names
// updated in v2.1 to use widgetOptions.zebra = ["even", "odd"]
// widgetZebra: { css: [ "normal-row", "alt-row" ] } still works
widgetOptions : {
zebra : [ "normal-row", "alt-row" ]
}
});
});

View File

@@ -0,0 +1,203 @@
$(document).ready(function(){
$(".rowShowHide").hide();
$(".tablesShowHide").hide();
$(".categoryShowHide").hide();
// Listener odpowiadający za akcje po kliknięciu na przycisk "Exportuj do programu Excel"
$("#excelEksport").click( excelExport );
$("#pdfEksport").click( pdfExport );
function pdfExport() {
var url = $(location).attr('href');
url = url + "&toPDF=1&to_pdf=1";
window.location.href = url;
}
function excelExport() {
var url = $(location).attr('href').replace("ReportSalesByContractor", "ReportSalesByContractorToExcelFile");
var fileUrl = url.slice(0, url.indexOf("index")) + "modules/EcmReports/ExcelFiles/ReportSalesByContractor.xls";
url = url + "&to_pdf=1";
$.blockUI({ css: {
border: 'none',
padding: '15px',
backgroundColor: '#000',
'-webkit-border-radius': '10px',
'-moz-border-radius': '10px',
opacity: .5,
'font-weight': 'bold',
'font-size': '16px',
color: '#fff',
},
message: "Trwa generowanie pliku..."
});
$.ajax({
url: url,
success: function(data){
$.unblockUI();
window.location.href = fileUrl
},
error: function(){
$.unblockUI();
alert('Eksport zakończony niepowodzeniem!');
}
});
}
$(".showTablesContractor").bind("click",function(){
if($(this).attr("class")=="plusStyle showTablesContractor")
{
//pobieramy następny wiersz tabeli którą chcemy pokazac po czym go wyswietlamy
var nextTBody = $(this).parent().parent().parent().next();
while($(nextTBody).attr("id")!="stopCategory")
{
//sprawdzamy czy kategoria
if($(nextTBody).attr("class")=="tablesorter-infoOnly categoryShowHide")
{
$(nextTBody).show();
}
nextTBody=$(nextTBody).next();
}
$(this).html("[-]");
$(this).attr("class","plusStyle hideTablesContractor");
}else if($(this).attr("class")=="plusStyle hideTablesContractor")
{
//pobieramy następny wiersz tabeli którą chcemy schowac po czym go chowamy
var nextTBody = $(this).parent().parent().parent().next();
while($(nextTBody).attr("id")!="stopCategory")
{
//tu chowamy wszystko więc nie sprawdzamy kategori
$(nextTBody).hide();
var changePlusMinus = $(nextTBody).children().children();
if($(changePlusMinus[0]).children("a").attr("class")=="hideRows")
{
$(changePlusMinus[0]).children("a").attr("class","showRows");
$(changePlusMinus[0]).children("a").html("[+]");
}else if($(changePlusMinus[0]).children("a").attr("class")=="plusStyle hideTables")
{
$(changePlusMinus[0]).children("a").attr("class","plusStyle showTables");
$(changePlusMinus[0]).children("a").html("[+]");
}
nextTBody=$(nextTBody).next();
}
$(this).html("[+]");
$(this).attr("class","plusStyle showTablesContractor");
}
});
$(".showTables").bind("click",function(){
if($(this).attr("class")=="plusStyle showTables")
{
//pobieramy następny wiersz tabeli którą chcemy pokazac po czym go wyswietlamy
var nextTBody = $(this).parent().parent().parent().next();
while($(nextTBody).attr("id")!="stopTables")
{
//sprawdzamy czy kategoria
if($(nextTBody).attr("class")=="tablesorter-infoOnly tablesShowHide")
{
$(nextTBody).show();
}
nextTBody=$(nextTBody).next();
}
$(this).html("[-]");
$(this).attr("class","plusStyle hideTables");
}else if($(this).attr("class")=="plusStyle hideTables")
{
//pobieramy następny wiersz tabeli którą chcemy schowac po czym go chowamy
var nextTBody = $(this).parent().parent().parent().next();
while($(nextTBody).attr("id")!="stopTables")
{
//tu chowamy wszystko więc nie sprawdzamy kategori
$(nextTBody).hide();
var changePlusMinus = $(nextTBody).children().children();
if($(changePlusMinus[0]).children("a").attr("class")=="hideRows")
{
$(changePlusMinus[0]).children("a").attr("class","showRows");
$(changePlusMinus[0]).children("a").html("[+]");
}
nextTBody=$(nextTBody).next();
}
$(this).html("[+]");
$(this).attr("class","plusStyle showTables");
}
});
$(".showRows").bind("click",function(){
if($(this).attr("class")=="showRows")
{
//pobieramy następny wiersz tabeli którą chcemy pokazac po czym go wyswietlamy
var nextTBody = $(this).parent().parent().parent().next();
while($(nextTBody).attr("id")!="stopRows")
{
$(nextTBody).show();
nextTBody=$(nextTBody).next();
}
$(this).html("[-]");
$(this).attr("class","hideRows");
}else if($(this).attr("class")=="hideRows")
{
//pobieramy następny wiersz tabeli którą chcemy schowac po czym go chowamy
var nextTBody = $(this).parent().parent().parent().next();
while($(nextTBody).attr("id")!="stopRows")
{
$(nextTBody).hide();
nextTBody=$(nextTBody).next();
}
$(this).html("[+]");
$(this).attr("class","showRows");
}
});
$.tablesorter.addParser({
// use a unique id
id: 'saas',
is: function(s, table, cell) {
// s is the text from the cell
// table is the current table (as a DOM element; not jQuery object)
// cell is the current table cell (DOM element)
// return false if you don't want this parser to be auto detected
return false;
},
format: function(s, table, cell, cellIndex) {
// s is the text from the cell
// table is the current table (as a DOM element; not jQuery object)
// cell is the current table cell (DOM element)
// cellIndex is the current cell's column index
// format your data for normalization
// (i.e. do something to get and/or modify your data, then return it)
return s.replace('.', '').replace(',', '.').replace('%', '');
},
// flag for filter widget (true = ALWAYS search parsed values; false = search cell text)
parsed: false,
// set the type to either numeric or text (text uses a natural sort function
// so it will work for everything, but numeric is faster for numbers
type: 'numeric'
});
//assign the sortStart event
$("#myTable thead").click(function() {
//alert($(this).attr("id"));
$(".productsTable").remove();
var minus = $(".hideProducts");
$.each(minus,function(){
$(this).html("[+]");
$(this).attr("class","showProducts");
});
});
// call the tablesorter plugin
$("table").tablesorter({
theme: 'blue',
// initialize zebra striping of the table
widgets: ['zebra','staticRow'],
// change the default striping class names
// updated in v2.1 to use widgetOptions.zebra = ["even", "odd"]
// widgetZebra: { css: [ "normal-row", "alt-row" ] } still works
widgetOptions : {
zebra : [ "normal-row", "alt-row" ]
}
});
});

View File

@@ -0,0 +1,194 @@
$(document).ready(function () {
$("select[name='documentsSelected']").on('change', documentsSelectedChange);
$("#clear").on('click', clearAccount);
$("#clearCat").on('click', clearCat);
$("#selectAccount").on('click', selectAccount);
$("#selectProductCategory").on('click', selectProductCategory);
documentsSelectedChange($("[name='documentsSelected']").val());
$.tablesorter.addParser({
// use a unique id
id : 'number',
is : function(s, table, cell) {
// s is the text from the cell
// table is the current table (as a DOM element; not
// jQuery object)
// cell is the current table cell (DOM element)
// return false if you don't want this parser to be
// auto detected
return false;
},
format : function(s, table, cell, cellIndex) {
// s is the text from the cell
// table is the current table (as a DOM element; not
// jQuery object)
// cell is the current table cell (DOM element)
// cellIndex is the current cell's column index
// format your data for normalization
// (i.e. do something to get and/or modify your
// data, then return it)
return $(cell).attr('data-value');
},
// flag for filter widget (true = ALWAYS search parsed
// values; false = search cell text)
parsed : false,
// set the type to either numeric or text (text uses a
// natural sort function
// so it will work for everything, but numeric is faster
// for numbers
type : 'numeric'
});
$("#myTable").tablesorter({
theme: 'blue',
// initialize zebra striping of the table
widthFixed : false,
// initialize zebra striping of the table
widgets: ['zebra','stickyHeaders'],
// change the default striping class names
// updated in v2.1 to use widgetOptions.zebra = ["even", "odd"]
// widgetZebra: { css: [ "normal-row", "alt-row" ] } still works
widgetOptions : {
zebra : [ "normal-row", "alt-row" ]
},
headers : {
3 : { sorter: 'number' },
4 : { sorter: 'number' },
},
});
});
function pdfExport() {
var url = $(location).attr('href');
url = url + "&toPDF=1&to_pdf=1";
window.open(url);
}
function xlsExport() {
var url = $(location).attr('href');
url = url + "&toPDF=1&to_pdf=1&to_xls=1";
window.open(url);
}
function excelExport() {
var url = $(location).attr('href').replace("ReportStocks", "ReportStocksToExcelFile");
url = url + "&to_pdf=1";
var fileUrl = url.slice(0, url.indexOf("index")) + "modules/EcmReports/ExcelFiles/ReportStocks.xls";
$.blockUI({css: {
border: 'none',
padding: '15px',
backgroundColor: '#000',
'-webkit-border-radius': '10px',
'-moz-border-radius': '10px',
opacity: .5,
'font-weight': 'bold',
'font-size': '16px',
color: '#fff',
},
message: "Trwa generowanie pliku..."
});
$.ajax({
url: url,
success: function (data) {
$.unblockUI();
window.location.href = fileUrl
},
error: function () {
$.unblockUI();
alert('Eksport zakończony niepowodzeniem!');
}
});
}
function selectAccount() {
open_popup('Accounts', 600, 400, '', true, false, {'call_back_function': 'set_return', 'form_name': 'ReportStockDocMoves', 'field_to_name_array': {'id': 'accountId', 'name': 'accountName'}}, 'single', true);
}
function selectProductCategory() {
open_popup('EcmProductCategories', 600, 400, '', true, false, {'call_back_function': 'set_return', 'form_name': 'ReportStockDocMoves', 'field_to_name_array': {'id': 'productCategoryId', 'name': 'productCategoryName'}}, 'single', true);
}
function clearAccount() {
console.log('Czyszczenie zaznaczonego kontrahenta');
$('#accountId').val('');
$('#accountName').val('');
}
function clearCat() {
console.log('Czyszczenie zaznaczonego kontrahenta');
$('#productCategoryId').val('');
$('#productCategoryName').val('');
}
function documentsSelectedChange(documentsSelected) {
//Sprawdzanie czy wywolano funkcje przez parametr, czy tez przez event onchange
if (typeof documentsSelected != 'string') {
documentsSelected = $(this).val();
clearAccount();
//usuwanie zaznaczonych opcji
$(".changebox option:selected").removeAttr("selected");
}
$("#stockSelectedspan").html('Magazyn');
$('.changebox').hide();
console.log('Przy switchu: ' + documentsSelected);
switch (documentsSelected) {
case 'EcmStockDocInsideOuts':
console.log('Zmieniono dokument na: EcmStockDocInsideOuts');
$("#myTable").show();
$("#info").hide();
$('.kartotekamaterialowa').show();
break;
case 'EcmStockDocInsideIns':
console.log('Zmieniono dokument na: EcmStockDocInsideIns');
$("#myTable").show();
$("#info").hide();
$('.kartotekamaterialowa').show();
break;
case 'EcmStockDocCorrects':
console.log('Zmieniono dokument na: EcmStockDocCorrects');
$("#myTable").show();
$("#info").hide();
$('.kartotekamaterialowa').show();
break;
case 'EcmStockDocMoves':
console.log('Zmieniono dokument na: EcmStockDocMoves');
$("#stockSelectedspan").html('Z magazynu:')
$("#myTable").show();
$("#info").hide();
$('.magazyndocelowy').show();
break;
case 'EcmStockDocIns':
console.log('Zmieniono dokument na: EcmStockDocIns');
$("#myTable").show();
$("#info").hide();
$('.kontrahent').show();
break;
case 'EcmStockDocOuts':
console.log('Zmieniono dokument na: EcmStockDocOuts');
$("#myTable").show();
$("#info").hide();
$('.kontrahent').show();
$('.kategoriawz').show();
break;
case 'EcmInvoiceOuts':
console.log('Zmieniono dokument na: EcmInvoiceOuts');
$("#myTable").show();
$("#info").hide();
$('.kontrahent').show();
break;
case 'EcmReceipts':
console.log('Zmieniono dokument na: EcmReceipts');
$("#myTable").show();
$("#info").hide();
$('.kontrahent').show();
break;
default:
console.log('Zmieniono dokument na: default');
$("#myTable").hide();
$("#info").show();
break;
}
}

View File

@@ -0,0 +1,213 @@
$(document).ready(function(){
$(".rowShowHide").hide();
$(".tablesShowHide").hide();
// Listener odpowiadający za akcje po kliknięciu na przycisk "Exportuj do programu Excel"
$("#excelEksport").click( excelExport );
$(".showTables").bind("click",function(){
if($(this).attr("class")=="plusStyle showTables")
{
//pobieramy następny wiersz tabeli którą chcemy pokazac po czym go wyswietlamy
var nextTBody = $(this).parent().parent().parent().next();
while($(nextTBody).attr("id")!="stopTables")
{
//sprawdzamy czy kategoria
if($(nextTBody).attr("class")=="tablesorter-infoOnly tablesShowHide")
{
$(nextTBody).show();
}
nextTBody=$(nextTBody).next();
}
$(this).html("[-]");
$(this).attr("class","plusStyle hideTables");
}else if($(this).attr("class")=="plusStyle hideTables")
{
//pobieramy następny wiersz tabeli którą chcemy schowac po czym go chowamy
var nextTBody = $(this).parent().parent().parent().next();
while($(nextTBody).attr("id")!="stopTables")
{
//tu chowamy wszystko więc nie sprawdzamy kategori
$(nextTBody).hide();
var changePlusMinus = $(nextTBody).children().children();
if($(changePlusMinus[0]).children("a").attr("class")=="hideRows")
{
$(changePlusMinus[0]).children("a").attr("class","showRows");
$(changePlusMinus[0]).children("a").html("[+]");
}
nextTBody=$(nextTBody).next();
}
$(this).html("[+]");
$(this).attr("class","plusStyle showTables");
}
});
$(".showRows").bind("click",function(){
if($(this).attr("class")=="showRows")
{
//pobieramy następny wiersz tabeli którą chcemy pokazac po czym go wyswietlamy
var nextTBody = $(this).parent().parent().parent().next();
while($(nextTBody).attr("id")!="stopRows")
{
$(nextTBody).show();
nextTBody=$(nextTBody).next();
}
$(this).html("[-]");
$(this).attr("class","hideRows");
}else if($(this).attr("class")=="hideRows")
{
//pobieramy następny wiersz tabeli którą chcemy schowac po czym go chowamy
var nextTBody = $(this).parent().parent().parent().next();
while($(nextTBody).attr("id")!="stopRows")
{
$(nextTBody).hide();
nextTBody=$(nextTBody).next();
}
$(this).html("[+]");
$(this).attr("class","showRows");
}
});
//dodatkowe dane dla kontrahenta
$(".showProducts").click(function(){
if($(this).attr("class")==="showProducts")
{
var parent = $(this).parent();
var children = $(parent).children();
var contractor = $(children[1]).attr("contractor");
var category = $(this).attr("category");
var subcategory = $(this).attr("subcategory");
var date_from = $("#date_from").attr("value");
var date_to = $("#date_to").attr("value");
var type = $("#type option:selected").attr("value");
var user = $("#user option:selected").attr("value");
var Con = {
contractor: contractor,
date_from: date_from,
date_to: date_to,
type: type,
category: category,
subcategory: subcategory,
user: user
};
$(this).attr("class","hideProducts");
var ajax_url = "index.php?module=EcmReports&action=ReportSalesByProducts&to_pdf=1";
$.blockUI({ css: {
border: 'none',
padding: '15px',
backgroundColor: '#000',
'-webkit-border-radius': '10px',
'-moz-border-radius': '10px',
opacity: .5,
'font-weight': 'bold',
'font-size': '16px',
color: '#fff',
},
message: "Proszę czekać..."
});
$.ajax({
type : "POST",
url : ajax_url,
dataType : "text",
success : function(data) {
var parparent = $(parent).parent();
parparent.after("<tr class='productsTable'><td colspan='8'>"+data+"</td></tr>");
$.unblockUI();
},
data : Con
});
}else if($(this).attr("class")==="hideProducts")
{
var parent = $(this).parent().parent();
$(parent).next().remove(".productsTable");
$(this).attr("class","showProducts");
}
});
function excelExport() {
var url = $(location).attr('href').replace("ReportStocks", "ReportStocksToExcelFile");
url = url + "&to_pdf=1";
var fileUrl = url.slice(0, url.indexOf("index")) + "modules/EcmReports/ExcelFiles/ReportStocks.xls";
$.blockUI({ css: {
border: 'none',
padding: '15px',
backgroundColor: '#000',
'-webkit-border-radius': '10px',
'-moz-border-radius': '10px',
opacity: .5,
'font-weight': 'bold',
'font-size': '16px',
color: '#fff',
},
message: "Trwa generowanie pliku..."
});
$.ajax({
url: url,
success: function(data){
$.unblockUI();
window.location.href = fileUrl
},
error: function(){
$.unblockUI();
alert('Eksport zakończony niepowodzeniem!');
}
});
}
$.tablesorter.addParser({
// use a unique id
id: 'saas',
is: function(s, table, cell) {
// s is the text from the cell
// table is the current table (as a DOM element; not jQuery object)
// cell is the current table cell (DOM element)
// return false if you don't want this parser to be auto detected
return false;
},
format: function(s, table, cell, cellIndex) {
// s is the text from the cell
// table is the current table (as a DOM element; not jQuery object)
// cell is the current table cell (DOM element)
// cellIndex is the current cell's column index
// format your data for normalization
// (i.e. do something to get and/or modify your data, then return it)
return s.replace('.', '').replace(',', '.').replace('%', '');
},
// flag for filter widget (true = ALWAYS search parsed values; false = search cell text)
parsed: false,
// set the type to either numeric or text (text uses a natural sort function
// so it will work for everything, but numeric is faster for numbers
type: 'numeric'
});
//assign the sortStart event
$("#myTable thead").click(function() {
//alert($(this).attr("id"));
$(".productsTable").remove();
var minus = $(".hideProducts");
$.each(minus,function(){
$(this).html("[+]");
$(this).attr("class","showProducts");
});
});
// call the tablesorter plugin
$("table").tablesorter({
theme: 'blue',
// initialize zebra striping of the table
widgets: ['zebra','staticRow'],
// change the default striping class names
// updated in v2.1 to use widgetOptions.zebra = ["even", "odd"]
// widgetZebra: { css: [ "normal-row", "alt-row" ] } still works
widgetOptions : {
zebra : [ "normal-row", "alt-row" ]
}
});
});

View File

@@ -0,0 +1,43 @@
$(document).ready(function(){
$.tablesorter.addParser({
// use a unique id
id: 'saas',
is: function(s, table, cell) {
// s is the text from the cell
// table is the current table (as a DOM element; not jQuery object)
// cell is the current table cell (DOM element)
// return false if you don't want this parser to be auto detected
return false;
},
format: function(s, table, cell, cellIndex) {
// s is the text from the cell
// table is the current table (as a DOM element; not jQuery object)
// cell is the current table cell (DOM element)
// cellIndex is the current cell's column index
// format your data for normalization
// (i.e. do something to get and/or modify your data, then return it)
return s.replace('.', '').replace(',', '.').replace('%', '');
},
// flag for filter widget (true = ALWAYS search parsed values; false = search cell text)
parsed: false,
// set the type to either numeric or text (text uses a natural sort function
// so it will work for everything, but numeric is faster for numbers
type: 'numeric'
});
// call the tablesorter plugin
$("table").tablesorter({
theme : 'blue2',
// initialize zebra striping of the table
widgets: ['zebra','staticRow'],
// change the default striping class names
// updated in v2.1 to use widgetOptions.zebra = ["even", "odd"]
// widgetZebra: { css: [ "normal-row", "alt-row" ] } still works
widgetOptions : {
zebra : [ "normal-row", "alt-row" ]
}
});
});

View File

@@ -0,0 +1,41 @@
<?php
if (! defined ( 'sugarEntry' ) || ! sugarEntry)
die ( '-1' );
if (! $_POST ['job'] || $_POST ['job'] == '')
die ( '-1' );
switch ($_POST ['job']) {
case 'getProductOrders' :
getProductOrders ( $_POST ['id'], $_POST ['date'],$_POST ['wz'],$_POST ['type']);
break;
}
function getProductOrders($id,$date,$wz,$type){
$docDate=DateTime::createFromFormat ( 'Y-m-d', $date);
if($wz=='true'){
$qwz="and z.id not in (select ecmsale_id from ecmstockdocouts where ecmsale_id=z.id)";
} else {
$qwz="";
}
$query="select z.id,z.document_no,z.parent_name,sum(p.quantity) as quantity,z.status from ecmsaleitems p inner join ecmsales z on z.id=p.ecmsale_id where p.ecmproduct_id='$id' and z.".$type."='".$docDate->format("Y-m-d")."' ".$qwz." group by z.id";
global $app_list_strings;
$db=$GLOBALS['db'];
$res= $db->query($query);
$data=[];
while($return=$db->fetchByAssoc($res)){
$return['quantity']=number_format($return['quantity'],2);
$return['status']=$app_list_strings['ecmsales_status_dom'][$return['status']];
$data['items'][]=$return;
}
$ecmStockOperations = new EcmStockOperation();
$data['stock']=number_format($ecmStockOperations->getRealStock($id),2);
echo json_encode($data);
return;
}

View File

@@ -0,0 +1,619 @@
/*!
* jQuery blockUI plugin
* Version 2.66.0-2013.10.09
* Requires jQuery v1.7 or later
*
* Examples at: http://malsup.com/jquery/block/
* Copyright (c) 2007-2013 M. Alsup
* Dual licensed under the MIT and GPL licenses:
* http://www.opensource.org/licenses/mit-license.php
* http://www.gnu.org/licenses/gpl.html
*
* Thanks to Amir-Hossein Sobhi for some excellent contributions!
*/
;(function() {
/*jshint eqeqeq:false curly:false latedef:false */
"use strict";
function setup($) {
$.fn._fadeIn = $.fn.fadeIn;
var noOp = $.noop || function() {};
// this bit is to ensure we don't call setExpression when we shouldn't (with extra muscle to handle
// confusing userAgent strings on Vista)
var msie = /MSIE/.test(navigator.userAgent);
var ie6 = /MSIE 6.0/.test(navigator.userAgent) && ! /MSIE 8.0/.test(navigator.userAgent);
var mode = document.documentMode || 0;
var setExpr = $.isFunction( document.createElement('div').style.setExpression );
// global $ methods for blocking/unblocking the entire page
$.blockUI = function(opts) { install(window, opts); };
$.unblockUI = function(opts) { remove(window, opts); };
// convenience method for quick growl-like notifications (http://www.google.com/search?q=growl)
$.growlUI = function(title, message, timeout, onClose) {
var $m = $('<div class="growlUI"></div>');
if (title) $m.append('<h1>'+title+'</h1>');
if (message) $m.append('<h2>'+message+'</h2>');
if (timeout === undefined) timeout = 3000;
// Added by konapun: Set timeout to 30 seconds if this growl is moused over, like normal toast notifications
var callBlock = function(opts) {
opts = opts || {};
$.blockUI({
message: $m,
fadeIn : typeof opts.fadeIn !== 'undefined' ? opts.fadeIn : 700,
fadeOut: typeof opts.fadeOut !== 'undefined' ? opts.fadeOut : 1000,
timeout: typeof opts.timeout !== 'undefined' ? opts.timeout : timeout,
centerY: false,
showOverlay: false,
onUnblock: onClose,
css: $.blockUI.defaults.growlCSS
});
};
callBlock();
var nonmousedOpacity = $m.css('opacity');
$m.mouseover(function() {
callBlock({
fadeIn: 0,
timeout: 30000
});
var displayBlock = $('.blockMsg');
displayBlock.stop(); // cancel fadeout if it has started
displayBlock.fadeTo(300, 1); // make it easier to read the message by removing transparency
}).mouseout(function() {
$('.blockMsg').fadeOut(1000);
});
// End konapun additions
};
// plugin method for blocking element content
$.fn.block = function(opts) {
if ( this[0] === window ) {
$.blockUI( opts );
return this;
}
var fullOpts = $.extend({}, $.blockUI.defaults, opts || {});
this.each(function() {
var $el = $(this);
if (fullOpts.ignoreIfBlocked && $el.data('blockUI.isBlocked'))
return;
$el.unblock({ fadeOut: 0 });
});
return this.each(function() {
if ($.css(this,'position') == 'static') {
this.style.position = 'relative';
$(this).data('blockUI.static', true);
}
this.style.zoom = 1; // force 'hasLayout' in ie
install(this, opts);
});
};
// plugin method for unblocking element content
$.fn.unblock = function(opts) {
if ( this[0] === window ) {
$.unblockUI( opts );
return this;
}
return this.each(function() {
remove(this, opts);
});
};
$.blockUI.version = 2.66; // 2nd generation blocking at no extra cost!
// override these in your code to change the default behavior and style
$.blockUI.defaults = {
// message displayed when blocking (use null for no message)
message: '<h1>Please wait...</h1>',
title: null, // title string; only used when theme == true
draggable: true, // only used when theme == true (requires jquery-ui.js to be loaded)
theme: false, // set to true to use with jQuery UI themes
// styles for the message when blocking; if you wish to disable
// these and use an external stylesheet then do this in your code:
// $.blockUI.defaults.css = {};
css: {
padding: 0,
margin: 0,
width: '30%',
top: '40%',
left: '35%',
textAlign: 'center',
color: '#000',
border: '3px solid #aaa',
backgroundColor:'#fff',
cursor: 'wait'
},
// minimal style set used when themes are used
themedCSS: {
width: '30%',
top: '40%',
left: '35%'
},
// styles for the overlay
overlayCSS: {
backgroundColor: '#000',
opacity: 0.6,
cursor: 'wait'
},
// style to replace wait cursor before unblocking to correct issue
// of lingering wait cursor
cursorReset: 'default',
// styles applied when using $.growlUI
growlCSS: {
width: '350px',
top: '10px',
left: '',
right: '10px',
border: 'none',
padding: '5px',
opacity: 0.6,
cursor: 'default',
color: '#fff',
backgroundColor: '#000',
'-webkit-border-radius':'10px',
'-moz-border-radius': '10px',
'border-radius': '10px'
},
// IE issues: 'about:blank' fails on HTTPS and javascript:false is s-l-o-w
// (hat tip to Jorge H. N. de Vasconcelos)
/*jshint scripturl:true */
iframeSrc: /^https/i.test(window.location.href || '') ? 'javascript:false' : 'about:blank',
// force usage of iframe in non-IE browsers (handy for blocking applets)
forceIframe: false,
// z-index for the blocking overlay
baseZ: 1000,
// set these to true to have the message automatically centered
centerX: true, // <-- only effects element blocking (page block controlled via css above)
centerY: true,
// allow body element to be stetched in ie6; this makes blocking look better
// on "short" pages. disable if you wish to prevent changes to the body height
allowBodyStretch: true,
// enable if you want key and mouse events to be disabled for content that is blocked
bindEvents: true,
// be default blockUI will supress tab navigation from leaving blocking content
// (if bindEvents is true)
constrainTabKey: true,
// fadeIn time in millis; set to 0 to disable fadeIn on block
fadeIn: 200,
// fadeOut time in millis; set to 0 to disable fadeOut on unblock
fadeOut: 400,
// time in millis to wait before auto-unblocking; set to 0 to disable auto-unblock
timeout: 0,
// disable if you don't want to show the overlay
showOverlay: true,
// if true, focus will be placed in the first available input field when
// page blocking
focusInput: true,
// elements that can receive focus
focusableElements: ':input:enabled:visible',
// suppresses the use of overlay styles on FF/Linux (due to performance issues with opacity)
// no longer needed in 2012
// applyPlatformOpacityRules: true,
// callback method invoked when fadeIn has completed and blocking message is visible
onBlock: null,
// callback method invoked when unblocking has completed; the callback is
// passed the element that has been unblocked (which is the window object for page
// blocks) and the options that were passed to the unblock call:
// onUnblock(element, options)
onUnblock: null,
// callback method invoked when the overlay area is clicked.
// setting this will turn the cursor to a pointer, otherwise cursor defined in overlayCss will be used.
onOverlayClick: null,
// don't ask; if you really must know: http://groups.google.com/group/jquery-en/browse_thread/thread/36640a8730503595/2f6a79a77a78e493#2f6a79a77a78e493
quirksmodeOffsetHack: 4,
// class name of the message block
blockMsgClass: 'blockMsg',
// if it is already blocked, then ignore it (don't unblock and reblock)
ignoreIfBlocked: false
};
// private data and functions follow...
var pageBlock = null;
var pageBlockEls = [];
function install(el, opts) {
var css, themedCSS;
var full = (el == window);
var msg = (opts && opts.message !== undefined ? opts.message : undefined);
opts = $.extend({}, $.blockUI.defaults, opts || {});
if (opts.ignoreIfBlocked && $(el).data('blockUI.isBlocked'))
return;
opts.overlayCSS = $.extend({}, $.blockUI.defaults.overlayCSS, opts.overlayCSS || {});
css = $.extend({}, $.blockUI.defaults.css, opts.css || {});
if (opts.onOverlayClick)
opts.overlayCSS.cursor = 'pointer';
themedCSS = $.extend({}, $.blockUI.defaults.themedCSS, opts.themedCSS || {});
msg = msg === undefined ? opts.message : msg;
// remove the current block (if there is one)
if (full && pageBlock)
remove(window, {fadeOut:0});
// if an existing element is being used as the blocking content then we capture
// its current place in the DOM (and current display style) so we can restore
// it when we unblock
if (msg && typeof msg != 'string' && (msg.parentNode || msg.jquery)) {
var node = msg.jquery ? msg[0] : msg;
var data = {};
$(el).data('blockUI.history', data);
data.el = node;
data.parent = node.parentNode;
data.display = node.style.display;
data.position = node.style.position;
if (data.parent)
data.parent.removeChild(node);
}
$(el).data('blockUI.onUnblock', opts.onUnblock);
var z = opts.baseZ;
// blockUI uses 3 layers for blocking, for simplicity they are all used on every platform;
// layer1 is the iframe layer which is used to supress bleed through of underlying content
// layer2 is the overlay layer which has opacity and a wait cursor (by default)
// layer3 is the message content that is displayed while blocking
var lyr1, lyr2, lyr3, s;
if (msie || opts.forceIframe)
lyr1 = $('<iframe class="blockUI" style="z-index:'+ (z++) +';display:none;border:none;margin:0;padding:0;position:absolute;width:100%;height:100%;top:0;left:0" src="'+opts.iframeSrc+'"></iframe>');
else
lyr1 = $('<div class="blockUI" style="display:none"></div>');
if (opts.theme)
lyr2 = $('<div class="blockUI blockOverlay ui-widget-overlay" style="z-index:'+ (z++) +';display:none"></div>');
else
lyr2 = $('<div class="blockUI blockOverlay" style="z-index:'+ (z++) +';display:none;border:none;margin:0;padding:0;width:100%;height:100%;top:0;left:0"></div>');
if (opts.theme && full) {
s = '<div class="blockUI ' + opts.blockMsgClass + ' blockPage ui-dialog ui-widget ui-corner-all" style="z-index:'+(z+10)+';display:none;position:fixed">';
if ( opts.title ) {
s += '<div class="ui-widget-header ui-dialog-titlebar ui-corner-all blockTitle">'+(opts.title || '&nbsp;')+'</div>';
}
s += '<div class="ui-widget-content ui-dialog-content"></div>';
s += '</div>';
}
else if (opts.theme) {
s = '<div class="blockUI ' + opts.blockMsgClass + ' blockElement ui-dialog ui-widget ui-corner-all" style="z-index:'+(z+10)+';display:none;position:absolute">';
if ( opts.title ) {
s += '<div class="ui-widget-header ui-dialog-titlebar ui-corner-all blockTitle">'+(opts.title || '&nbsp;')+'</div>';
}
s += '<div class="ui-widget-content ui-dialog-content"></div>';
s += '</div>';
}
else if (full) {
s = '<div class="blockUI ' + opts.blockMsgClass + ' blockPage" style="z-index:'+(z+10)+';display:none;position:fixed"></div>';
}
else {
s = '<div class="blockUI ' + opts.blockMsgClass + ' blockElement" style="z-index:'+(z+10)+';display:none;position:absolute"></div>';
}
lyr3 = $(s);
// if we have a message, style it
if (msg) {
if (opts.theme) {
lyr3.css(themedCSS);
lyr3.addClass('ui-widget-content');
}
else
lyr3.css(css);
}
// style the overlay
if (!opts.theme /*&& (!opts.applyPlatformOpacityRules)*/)
lyr2.css(opts.overlayCSS);
lyr2.css('position', full ? 'fixed' : 'absolute');
// make iframe layer transparent in IE
if (msie || opts.forceIframe)
lyr1.css('opacity',0.0);
//$([lyr1[0],lyr2[0],lyr3[0]]).appendTo(full ? 'body' : el);
var layers = [lyr1,lyr2,lyr3], $par = full ? $('body') : $(el);
$.each(layers, function() {
this.appendTo($par);
});
if (opts.theme && opts.draggable && $.fn.draggable) {
lyr3.draggable({
handle: '.ui-dialog-titlebar',
cancel: 'li'
});
}
// ie7 must use absolute positioning in quirks mode and to account for activex issues (when scrolling)
var expr = setExpr && (!$.support.boxModel || $('object,embed', full ? null : el).length > 0);
if (ie6 || expr) {
// give body 100% height
if (full && opts.allowBodyStretch && $.support.boxModel)
$('html,body').css('height','100%');
// fix ie6 issue when blocked element has a border width
if ((ie6 || !$.support.boxModel) && !full) {
var t = sz(el,'borderTopWidth'), l = sz(el,'borderLeftWidth');
var fixT = t ? '(0 - '+t+')' : 0;
var fixL = l ? '(0 - '+l+')' : 0;
}
// simulate fixed position
$.each(layers, function(i,o) {
var s = o[0].style;
s.position = 'absolute';
if (i < 2) {
if (full)
s.setExpression('height','Math.max(document.body.scrollHeight, document.body.offsetHeight) - (jQuery.support.boxModel?0:'+opts.quirksmodeOffsetHack+') + "px"');
else
s.setExpression('height','this.parentNode.offsetHeight + "px"');
if (full)
s.setExpression('width','jQuery.support.boxModel && document.documentElement.clientWidth || document.body.clientWidth + "px"');
else
s.setExpression('width','this.parentNode.offsetWidth + "px"');
if (fixL) s.setExpression('left', fixL);
if (fixT) s.setExpression('top', fixT);
}
else if (opts.centerY) {
if (full) s.setExpression('top','(document.documentElement.clientHeight || document.body.clientHeight) / 2 - (this.offsetHeight / 2) + (blah = document.documentElement.scrollTop ? document.documentElement.scrollTop : document.body.scrollTop) + "px"');
s.marginTop = 0;
}
else if (!opts.centerY && full) {
var top = (opts.css && opts.css.top) ? parseInt(opts.css.top, 10) : 0;
var expression = '((document.documentElement.scrollTop ? document.documentElement.scrollTop : document.body.scrollTop) + '+top+') + "px"';
s.setExpression('top',expression);
}
});
}
// show the message
if (msg) {
if (opts.theme)
lyr3.find('.ui-widget-content').append(msg);
else
lyr3.append(msg);
if (msg.jquery || msg.nodeType)
$(msg).show();
}
if ((msie || opts.forceIframe) && opts.showOverlay)
lyr1.show(); // opacity is zero
if (opts.fadeIn) {
var cb = opts.onBlock ? opts.onBlock : noOp;
var cb1 = (opts.showOverlay && !msg) ? cb : noOp;
var cb2 = msg ? cb : noOp;
if (opts.showOverlay)
lyr2._fadeIn(opts.fadeIn, cb1);
if (msg)
lyr3._fadeIn(opts.fadeIn, cb2);
}
else {
if (opts.showOverlay)
lyr2.show();
if (msg)
lyr3.show();
if (opts.onBlock)
opts.onBlock();
}
// bind key and mouse events
bind(1, el, opts);
if (full) {
pageBlock = lyr3[0];
pageBlockEls = $(opts.focusableElements,pageBlock);
if (opts.focusInput)
setTimeout(focus, 20);
}
else
center(lyr3[0], opts.centerX, opts.centerY);
if (opts.timeout) {
// auto-unblock
var to = setTimeout(function() {
if (full)
$.unblockUI(opts);
else
$(el).unblock(opts);
}, opts.timeout);
$(el).data('blockUI.timeout', to);
}
}
// remove the block
function remove(el, opts) {
var count;
var full = (el == window);
var $el = $(el);
var data = $el.data('blockUI.history');
var to = $el.data('blockUI.timeout');
if (to) {
clearTimeout(to);
$el.removeData('blockUI.timeout');
}
opts = $.extend({}, $.blockUI.defaults, opts || {});
bind(0, el, opts); // unbind events
if (opts.onUnblock === null) {
opts.onUnblock = $el.data('blockUI.onUnblock');
$el.removeData('blockUI.onUnblock');
}
var els;
if (full) // crazy selector to handle odd field errors in ie6/7
els = $('body').children().filter('.blockUI').add('body > .blockUI');
else
els = $el.find('>.blockUI');
// fix cursor issue
if ( opts.cursorReset ) {
if ( els.length > 1 )
els[1].style.cursor = opts.cursorReset;
if ( els.length > 2 )
els[2].style.cursor = opts.cursorReset;
}
if (full)
pageBlock = pageBlockEls = null;
if (opts.fadeOut) {
count = els.length;
els.stop().fadeOut(opts.fadeOut, function() {
if ( --count === 0)
reset(els,data,opts,el);
});
}
else
reset(els, data, opts, el);
}
// move blocking element back into the DOM where it started
function reset(els,data,opts,el) {
var $el = $(el);
if ( $el.data('blockUI.isBlocked') )
return;
els.each(function(i,o) {
// remove via DOM calls so we don't lose event handlers
if (this.parentNode)
this.parentNode.removeChild(this);
});
if (data && data.el) {
data.el.style.display = data.display;
data.el.style.position = data.position;
if (data.parent)
data.parent.appendChild(data.el);
$el.removeData('blockUI.history');
}
if ($el.data('blockUI.static')) {
$el.css('position', 'static'); // #22
}
if (typeof opts.onUnblock == 'function')
opts.onUnblock(el,opts);
// fix issue in Safari 6 where block artifacts remain until reflow
var body = $(document.body), w = body.width(), cssW = body[0].style.width;
body.width(w-1).width(w);
body[0].style.width = cssW;
}
// bind/unbind the handler
function bind(b, el, opts) {
var full = el == window, $el = $(el);
// don't bother unbinding if there is nothing to unbind
if (!b && (full && !pageBlock || !full && !$el.data('blockUI.isBlocked')))
return;
$el.data('blockUI.isBlocked', b);
// don't bind events when overlay is not in use or if bindEvents is false
if (!full || !opts.bindEvents || (b && !opts.showOverlay))
return;
// bind anchors and inputs for mouse and key events
var events = 'mousedown mouseup keydown keypress keyup touchstart touchend touchmove';
if (b)
$(document).bind(events, opts, handler);
else
$(document).unbind(events, handler);
// former impl...
// var $e = $('a,:input');
// b ? $e.bind(events, opts, handler) : $e.unbind(events, handler);
}
// event handler to suppress keyboard/mouse events when blocking
function handler(e) {
// allow tab navigation (conditionally)
if (e.type === 'keydown' && e.keyCode && e.keyCode == 9) {
if (pageBlock && e.data.constrainTabKey) {
var els = pageBlockEls;
var fwd = !e.shiftKey && e.target === els[els.length-1];
var back = e.shiftKey && e.target === els[0];
if (fwd || back) {
setTimeout(function(){focus(back);},10);
return false;
}
}
}
var opts = e.data;
var target = $(e.target);
if (target.hasClass('blockOverlay') && opts.onOverlayClick)
opts.onOverlayClick(e);
// allow events within the message content
if (target.parents('div.' + opts.blockMsgClass).length > 0)
return true;
// allow events for content that is not being blocked
return target.parents().children().filter('div.blockUI').length === 0;
}
function focus(back) {
if (!pageBlockEls)
return;
var e = pageBlockEls[back===true ? pageBlockEls.length-1 : 0];
if (e)
e.focus();
}
function center(el, x, y) {
var p = el.parentNode, s = el.style;
var l = ((p.offsetWidth - el.offsetWidth)/2) - sz(p,'borderLeftWidth');
var t = ((p.offsetHeight - el.offsetHeight)/2) - sz(p,'borderTopWidth');
if (x) s.left = l > 0 ? (l+'px') : '0';
if (y) s.top = t > 0 ? (t+'px') : '0';
}
function sz(el, p) {
return parseInt($.css(el,p),10)||0;
}
}
/*global define:true */
if (typeof define === 'function' && define.amd && define.amd.jQuery) {
define(['jquery'], setup);
} else {
setup(jQuery);
}
})();

File diff suppressed because one or more lines are too long

View File

@@ -0,0 +1,190 @@
$(document).ready(function () {
$.tablesorter.addParser({
// use a unique id
id : 'number',
is : function(s, table, cell) {
// s is the text from the cell
// table is the current table (as a DOM element; not
// jQuery object)
// cell is the current table cell (DOM element)
// return false if you don't want this parser to be
// auto detected
return false;
},
format : function(s, table, cell, cellIndex) {
// s is the text from the cell
// table is the current table (as a DOM element; not
// jQuery object)
// cell is the current table cell (DOM element)
// cellIndex is the current cell's column index
// format your data for normalization
// (i.e. do something to get and/or modify your
// data, then return it)
return $(cell).attr('data-value');
},
// flag for filter widget (true = ALWAYS search parsed
// values; false = search cell text)
parsed : false,
// set the type to either numeric or text (text uses a
// natural sort function
// so it will work for everything, but numeric is faster
// for numbers
type : 'numeric'
});
$("#myTable").tablesorter({
theme: 'blue',
// initialize zebra striping of the table
widthFixed : false,
cssChildRow: 'invisible-table-row',
// initialize zebra striping of the table
widgets: ['zebra','stickyHeaders'],
// change the default striping class names
// updated in v2.1 to use widgetOptions.zebra = ["even", "odd"]
// widgetZebra: { css: [ "normal-row", "alt-row" ] } still works
widgetOptions : {
zebra : [ "normal-row", "alt-row" ]
},
headers : {
2 : { sorter: 'number' },
3 : { sorter: 'number' },
},
sortList: [[0,0]]
});
});
function pdfExport() {
var url = $(location).attr('href');
url = url + "&toPDF=1&to_pdf=1";
window.open(url);
}
function xlsExport() {
var url = $(location).attr('href');
url = url + "&toPDF=1&to_pdf=1&to_xls=1";
window.open(url);
}
function excelExport() {
var url = $(location).attr('href').replace("ReportStocks", "ReportStocksToExcelFile");
url = url + "&to_pdf=1";
var fileUrl = url.slice(0, url.indexOf("index")) + "modules/EcmReports/ExcelFiles/ReportStocks.xls";
$.blockUI({css: {
border: 'none',
padding: '15px',
backgroundColor: '#000',
'-webkit-border-radius': '10px',
'-moz-border-radius': '10px',
opacity: .5,
'font-weight': 'bold',
'font-size': '16px',
color: '#fff',
},
message: "Trwa generowanie pliku..."
});
$.ajax({
url: url,
success: function (data) {
$.unblockUI();
window.location.href = fileUrl
},
error: function () {
$.unblockUI();
alert('Eksport zakończony niepowodzeniem!');
}
});
}
function selectAccount() {
open_popup('Accounts', 600, 400, '', true, false, {'call_back_function': 'set_return', 'form_name': 'ReportStockDocMoves', 'field_to_name_array': {'id': 'accountId', 'name': 'accountName'}}, 'single', true);
}
function selectProductCategory() {
open_popup('EcmProductCategories', 600, 400, '', true, false, {'call_back_function': 'set_return', 'form_name': 'ReportStockDocMoves', 'field_to_name_array': {'id': 'productCategoryId', 'name': 'productCategoryName'}}, 'single', true);
}
function clearAccount() {
console.log('Czyszczenie zaznaczonego kontrahenta');
$('#accountId').val('');
$('#accountName').val('');
}
function clearCat() {
console.log('Czyszczenie zaznaczonego kontrahenta');
$('#productCategoryId').val('');
$('#productCategoryName').val('');
}
function documentsSelectedChange(documentsSelected) {
//Sprawdzanie czy wywolano funkcje przez parametr, czy tez przez event onchange
if (typeof documentsSelected != 'string') {
documentsSelected = $(this).val();
clearAccount();
//usuwanie zaznaczonych opcji
$(".changebox option:selected").removeAttr("selected");
}
$("#stockSelectedspan").html('Magazyn');
$('.changebox').hide();
console.log('Przy switchu: ' + documentsSelected);
switch (documentsSelected) {
case 'EcmStockDocInsideOuts':
console.log('Zmieniono dokument na: EcmStockDocInsideOuts');
$("#myTable").show();
$("#info").hide();
$('.kartotekamaterialowa').show();
break;
case 'EcmStockDocInsideIns':
console.log('Zmieniono dokument na: EcmStockDocInsideIns');
$("#myTable").show();
$("#info").hide();
$('.kartotekamaterialowa').show();
break;
case 'EcmStockDocCorrects':
console.log('Zmieniono dokument na: EcmStockDocCorrects');
$("#myTable").show();
$("#info").hide();
$('.kartotekamaterialowa').show();
break;
case 'EcmStockDocMoves':
console.log('Zmieniono dokument na: EcmStockDocMoves');
$("#stockSelectedspan").html('Z magazynu:')
$("#myTable").show();
$("#info").hide();
$('.magazyndocelowy').show();
break;
case 'EcmStockDocIns':
console.log('Zmieniono dokument na: EcmStockDocIns');
$("#myTable").show();
$("#info").hide();
$('.kontrahent').show();
break;
case 'EcmStockDocOuts':
console.log('Zmieniono dokument na: EcmStockDocOuts');
$("#myTable").show();
$("#info").hide();
$('.kontrahent').show();
$('.kategoriawz').show();
break;
case 'EcmInvoiceOuts':
console.log('Zmieniono dokument na: EcmInvoiceOuts');
$("#myTable").show();
$("#info").hide();
$('.kontrahent').show();
break;
case 'EcmReceipts':
console.log('Zmieniono dokument na: EcmReceipts');
$("#myTable").show();
$("#info").hide();
$('.kontrahent').show();
break;
default:
console.log('Zmieniono dokument na: default');
$("#myTable").hide();
$("#info").show();
break;
}
}

View File

@@ -0,0 +1,196 @@
$(document).ready(function(){
$("#clearTrader").on('click', clearTrader);
$("#selectTrader").on('click', selectTrader);
$("#clearAccount").on('click', clearAccount);
$("#clearProduct").on('click', clearProduct);
$("#selectAccount").on('click', selectAccount);
$("#selectProduct").on('click', selectProduct);
Calendar.setup ({
inputField : "date_from",
daFormat : "%d.%m.%Y",
button : "date_from_trigger",
singleClick : true,
dateStr : "",
step : 1
});
Calendar.setup ({
inputField : "date_to",
daFormat : "%d.%m.%Y",
button : "date_to_trigger",
singleClick : true,
dateStr : "",
step : 1
});
$.tablesorter.addParser({
// set a unique id
id: 'money',
is: function(s) {
// return false so this parser is not auto detected
return false;
},
format: function(s) {
// format your data for normalization
return s.replace('.','').replace(',','.');
},
// set type, either numeric or text
type: 'numeric'
});
$.tablesorter.addParser({
// set a unique id
id: 'INCOME_OVERHEAD',
is: function(s) {
// return false so this parser is not auto detected
return false;
},
format: function(s) {
// format your data for normalization
var position = s.indexOf("(");
var cutted_string = trim(s.substring(0,position));
cutted_string = cutted_string.replace('.','').replace(',','.');
return cutted_string;
},
// set type, either numeric or text
type: 'numeric'
});
$("#myTable").tablesorter({
theme: 'blue',
sortList: [[0,0], [4,0]],
textExtraction: getTextExtractor(),
headers: {
4: {
sorter:'money'
},
5: {
sorter:'money'
},
6: {
sorter:'INCOME_OVERHEAD'
},
7: {
sorter:'INCOME_OVERHEAD'
},
}
});
});
function generateXLS(){
var data = {}
$.each($("#SearchTable").find('input, select'), function (key,input){
data[$(input).prop('name')] = $(input).val();
});
$.ajax({
type: "POST",
url: 'index.php?module=EcmReports&action=mzVatPurchases&to_pdf=1&to_xls=1',
dataType: "html",
data: data,
async: false,
success: function(response){
var new_window = window.open(response);
},
// dataType: 'html',
});
}
function generatePDF(){
var data = {}
$.each($("#SearchTable").find('input, select'), function (key,input){
data[$(input).prop('name')] = $(input).val();
});
var sortable={};
$.each($("#myTable").find('.sortby'), function (key,input){
if($(input).hasClass('headerSortDown')){
sortable[$(input).html().trim()] = 'ASC';
}else if($(input).hasClass('headerSortUp')){
sortable[$(input).html().trim()] = 'DESC';
}
});
data['sort']=sortable;
$.ajax({
type: "POST",
url: 'index.php?module=EcmReports&action=mzVatPurchases&to_pdf=1',
dataType: "html",
data: data,
async: false,
success: function(response){
var new_window = window.open(response);
},
// dataType: 'html',
});
}
function clearTrader() {
console.log('Czyszczenie wybranego sprzedawcy');
$('#trader').val('');
console.log('Gotowe!');
}
function selectTrader() {
open_popup('Users', 600, 400, '', true, false, {'call_back_function': 'setTrader', 'form_name': 'ReportSalesByProduct', 'field_to_name_array': {'id': 'id'}}, 'single', true);
}
function setTrader(selectedTrader){
$("#trader").val(selectedTrader.name_to_value_array.id);
}
function clearAccount() {
console.log('Czyszczenie wybranego sprzedawcy');
$('#account_id').val('');
$('#account_name').val('');
console.log('Gotowe!');
}
function clearProduct() {
console.log('Czyszczenie wybranego sprzedawcy');
$('#product_category_id').val('');
$('#product_category_name').val('');
console.log('Gotowe!');
}
function selectAccount() {
open_popup('Accounts', 800, 500, '', true, false, {'call_back_function': 'set_return', 'form_name': 'ReportSalesByProduct', 'field_to_name_array': {"id":"account_id","name":"account_name"}}, 'single', true);
}
function selectProduct() {
open_popup('EcmProductCategories', 800, 500, '', true, false, {'call_back_function': 'set_return', 'form_name': 'ReportSalesByProduct', 'field_to_name_array': {"id":"product_category_id","name":"product_category_name"}}, 'single', true);
}
function getTextExtractor()
{
return (function() {
var patternLetters = /[öäüÖÄÜáàâéèêúùûóòôÁÀÂÉÈÊÚÙÛÓÒÔßąĄśŚćĆęĘńŃłŁ]/g;
var patternDateDmy = /^(?:\D+)?(\d{1,2})\.(\d{1,2})\.(\d{2,4})$/;
var lookupLetters = {
"ä": "a", "ö": "o", "ü": "u",
"Ä": "A", "Ö": "O", "Ü": "U",
"á": "a", "à": "a", "â": "a",
"é": "e", "è": "e", "ê": "e",
"ú": "u", "ù": "u", "û": "u",
"ó": "o", "ò": "o", "ô": "o",
"Á": "A", "À": "A", "Â": "A",
"É": "E", "È": "E", "Ê": "E",
"Ú": "U", "Ù": "U", "Û": "U",
"Ó": "O", "Ò": "O", "Ô": "O",
"ß": "s",'a':'ą','Ą':'A','ś':'s,','Ś':'S','ć':'c','Ć':'C','ę':'e','ń':'n','Ń':'N','ł':'l','Ł':'L','Ę':'E',
};
var letterTranslator = function(match) {
return lookupLetters[match] || match;
}
return function(node) {
var text = $.trim($(node).text());
var date = text.match(patternDateDmy);
if (date)
return [date[3], date[2], date[1]].join("-");
else
return text.replace(patternLetters, letterTranslator);
}
})();
}

File diff suppressed because one or more lines are too long