diff -r d3cdcfac81cb -r ad2e1e3ccaca www/js/rec_edit.js
--- a/www/js/rec_edit.js Thu Jan 31 14:09:54 2019 +0100
+++ b/www/js/rec_edit.js Thu Jan 31 17:16:51 2019 +0100
@@ -335,7 +335,6 @@
var row = rows[i];
if (row.m_name == name) {
found = true;
- $("#miscGrid").jqxGrid('setcellvalue', i, 'm_weight', amount);
$("#miscGrid").jqxGrid('setcellvalue', i, 'm_amount', amount / 1000);
break;
}
@@ -354,8 +353,9 @@
row["m_type"] = record.type;
row["m_use_use"] = record.use_use;
row["m_time"] = 0;
- row["m_weight"] = amount;
row["m_amount_is_weight"] = record.amount_is_weight;
+ row["m_inventory"] = record.inventory;
+ row["m_avail"] = 1;
var commit = $("#miscGrid").jqxGrid('addrow', null, row);
}
}
@@ -1433,7 +1433,7 @@
var fermentableAdapter = new $.jqx.dataAdapter(fermentableSource);
$("#fermentableGrid").jqxGrid({
width: 1240,
- height: 400,
+ height: 450,
source: fermentableAdapter,
theme: theme,
selectionmode: 'singlerow',
@@ -1638,7 +1638,7 @@
var hopAdapter = new $.jqx.dataAdapter(hopSource);
$("#hopGrid").jqxGrid({
width: 1240,
- height: 400,
+ height: 510,
source: hopAdapter,
theme: theme,
selectionmode: 'singlerow',
@@ -1821,7 +1821,8 @@
{ name: 'm_use_use', type: 'int' },
{ name: 'm_time', type: 'float' },
{ name: 'm_amount_is_weight', type: 'int' },
- { name: 'm_weight', type: 'float' }
+ { name: 'm_inventory', type: 'float' },
+ { name: 'm_avail', type: 'int' }
],
addrow: function (rowid, rowdata, position, commit) {
commit(true);
@@ -1835,7 +1836,6 @@
var data = new Array();
for (var i = 0; i < records.length; i++) {
var row = records[i];
- row.m_weight = row.m_amount * 1000;
data.push(row);
// Initial set water agent values.
switch (row.m_name) {
@@ -1892,13 +1892,11 @@
},
});
$("#miscGrid").jqxGrid({
- width: 960,
- height: 400,
+ width: 1240,
+ height: 525,
source: miscAdapter,
theme: theme,
selectionmode: 'singlerow',
- editmode: 'selectedcell',
- editable: true,
localization: getLocalization(),
showtoolbar: true,
rendertoolbar: function (toolbar) {
@@ -1908,11 +1906,12 @@
container.append('
');
container.append('In voorraad:
');
container.append('');
- container.append('');
+ container.append('');
// add misc from dropdownlist.
$("#maddrowbutton").jqxDropDownList({
- placeHolder: "Kies ingredient:",
+ placeHolder: "Kies ingrediënt:",
theme: theme,
+ template: "primary",
source: misclist,
displayMember: "name",
width: 150,
@@ -1931,8 +1930,8 @@
row["m_type"] = datarecord.type;
row["m_use_use"] = datarecord.use_use;
row["m_time"] = 0;
- row["m_weight"] = 0;
row["m_amount_is_weight"] = datarecord.amount_is_weight;
+ row["m_inventory"] = datarecord.inventory;
var commit = $("#miscGrid").jqxGrid('addrow', null, row);
}
});
@@ -1942,12 +1941,12 @@
misclist.dataBind();
});
// delete selected misc.
- $("#mdeleterowbutton").jqxButton({ theme: theme, height: 27, width: 150 });
+ $("#mdeleterowbutton").jqxButton({ template: "danger", theme: theme, height: 27, width: 150 });
$("#mdeleterowbutton").on('click', function () {
var selectedrowindex = $("#miscGrid").jqxGrid('getselectedrowindex');
var rowscount = $("#miscGrid").jqxGrid('getdatainformation').rowscount;
var type = $("#miscGrid").jqxGrid('getcellvalue', selectedrowindex, "m_type");
- if (selectedrowindex >= 0 && selectedrowindex < rowscount && type != "Water agent") {
+ if (selectedrowindex >= 0 && selectedrowindex < rowscount && type != 4) { // Water agent
var id = $("#miscGrid").jqxGrid('getrowid', selectedrowindex);
var commit = $("#miscGrid").jqxGrid('deleterow', id);
}
@@ -1957,84 +1956,64 @@
$('#jqxTabs').jqxTabs('next');
},
columns: [
- { text: 'Ingredient', editable: false, datafield: 'm_name' },
- { text: 'Type', editable: false, width: 120, align: 'center', cellsalign: 'center', datafield: 'm_type' },
- { text: 'Gebruik', width: 110, align: 'center', cellsalign: 'center', datafield: 'm_use_use', columntype: 'dropdownlist',
- createeditor: function (row, column, editor) {
- var srcUseUse = [ "Mash", "Boil", "Primary", "Secondary", "Bottling" ];
- editor.jqxDropDownList({ autoDropDownHeight: true, source: srcUseUse });
- },
- cellvaluechanging: function (row, column, columntype, oldvalue, newvalue) {
- var type = $("#miscGrid").jqxGrid('getcellvalue', row, "m_type");
- if (type == "Water agent")
- return oldvalue;
+ { text: 'Ingredient', datafield: 'm_name' },
+ { text: 'Type', width: 140, datafield: 'm_type',
+ cellsrenderer: function (index, datafield, value, defaultvalue, column, rowdata) {
+ return "" + MiscTypeData[value].nl + "
";
+ }
+ },
+ { text: 'Gebruik', width: 140, datafield: 'm_use_use',
+ cellsrenderer: function (index, datafield, value, defaultvalue, column, rowdata) {
+ return "" + MiscUseData[value].nl + "
";
}
},
- { datafield: 'm_amount_is_weight', hidden: true }, // We need to declare this column
- { datafield: 'm_amount', hidden: true }, // We need to declare this column
- { text: 'Hoeveelheid', datafield: 'm_weight', width: 120, align: 'right', cellsalign: 'right', cellsformat: 'f2',
- columntype: 'numberinput',
+ { text: 'Tijd', datafield: 'm_time', width: 90, align: 'right',
+ cellsrenderer: function (index, datafield, value, defaultvalue, column, rowdata) {
+ if (rowdata.m_use_use == 2) { // Boil
+ return ""+dataAdapter.formatNumber(value, "f0")+" min.
";
+ } else if ((rowdata.m_use_use == 3) || (rowdata.m_use_use == 4)) { // Primary or Secondary
+ return ""+dataAdapter.formatNumber(value/1440, "f0")+" dagen
";
+ } else {
+ var tijd = 0;
+ return "
";
+ }
+ },
+ },
+ { text: 'Hoeveel', datafield: 'm_amount', width: 110, align: 'right',
cellsrenderer: function (index, datafield, value, defaultvalue, column, rowdata) {
var vstr = rowdata.m_amount_is_weight ? "gr":"ml";
- return ""+dataAdapter.formatNumber(value,"f2")+" "+vstr+"
";
+ return ""+dataAdapter.formatNumber(value * 1000,"f2")+" "+vstr+"
";
},
- validation: function (cell, value) {
- var high = parseFloat(dataRecord.boil_size) * 1000;
- if (value < 0 || value > high) {
- return { result: false, message: "Hoeveelheid moet tussen 0 en "+high+" zijn" };
- }
- return true;
- },
- initeditor: function (row, cellvalue, editor) {
- editor.jqxNumberInput({
- inputMode: 'simple', min: 0, max: parseFloat(dataRecord.boil_size) * 1000,
- decimalDigits: 2, spinButtons: false
- });
- },
- cellvaluechanging: function (row, column, columntype, oldvalue, newvalue) {
- var type = $("#miscGrid").jqxGrid('getcellvalue', row, "m_type");
- if (type == "Water agent")
- return oldvalue;
- }
- },
- { text: 'Tijd', datafield: 'm_time', width: 70, align: 'right', cellsalign: 'right', cellsformat: 'f0',
- columntype: 'numberinput',
+ },
+ { text: 'Voorraad', datafield: 'm_inventory', width: 110, align: 'right',
cellsrenderer: function (index, datafield, value, defaultvalue, column, rowdata) {
- if (rowdata.m_use_use == 'Boil') {
- return ""+dataAdapter.formatNumber(value, "f0")+" m
";
- } else if (rowdata.m_use_use == 'Secondary') {
- return ""+dataAdapter.formatNumber(value, "f0")+" d
";
- } else {
- var tijd = 0;
- return "
";
- }
- },
- initeditor: function (row, cellvalue, editor, celltext, pressedChar) {
- editor.jqxNumberInput({ decimalDigits: 0, digits: 3, min: 0, max: parseFloat(dataRecord.boil_time) });
+ var vstr = rowdata.m_amount_is_weight ? "gr":"ml";
+ return ""+dataAdapter.formatNumber(value * 1000,"f2")+" "+vstr+"
";
},
- cellvaluechanging: function (row, column, columntype, oldvalue, newvalue) {
- var use = $("#miscGrid").jqxGrid('getcellvalue', row, "m_use_use");
- if ((use != "Boil") && (use != "Secondary"))
- return oldvalue;
- },
- validation: function (cell, value) {
- var high = parseFloat(dataRecord.boil_time);
- if (value < 0 || value > high ) {
- return { result: false, message: "De tijd moet 0-"+high+" zijn" };
- }
- return true;
- }
- }
+ },
+ { text: 'Wijzig', datafield: 'Edit', columntype: 'button', width: 100, align: 'center', cellsrenderer: function () {
+ return "Wijzig";
+ }, buttonclick: function (row) {
+ miscRow = row;
+ miscData = $("#miscGrid").jqxGrid('getrowdata', miscRow);
+ if (miscData.m_amount_is_weight)
+ $("#wm_pmpt_amount").html("Gewicht gram:");
+ else
+ $("#wm_pmpt_amount").html("Volume ml:");
+ $("#wm_name").val(miscData.m_name);
+ $("#wm_amount").val(miscData.m_amount * 1000);
+ if ((miscData.m_use_use == 3) || (miscData.m_use_use == 4)) // Primary or Secondary
+ $("#wm_time").val(miscData.m_time / 1440);
+ else
+ $("#wm_time").val(miscData.m_time);
+ $("#wm_use_use").val(miscData.m_use_use);
+ // show the popup window.
+ if (miscData.m_type != 4)
+ $("#popupMisc").jqxWindow('open');
+ }
+ }
]
});
- $("#miscGrid").on('cellendedit', function (event) {
- var args = event.args;
- console.log("Event Type: cellendedit, Column: " + args.datafield + ", Row: " + (args.rowindex) + ", Value: " + args.value);
- $("#miscGrid").jqxGrid('setcellvalue', args.rowindex, args.datafield, args.value);
- if (args.datafield == 'm_weight') {
- $("#miscGrid").jqxGrid('setcellvalue', args.rowindex, 'm_amount', parseFloat(args.value) / 1000);
- }
- });
};
// Inline yeasts editor
@@ -2735,7 +2714,6 @@
parseFloat(rowdata.h_alpha), $("#ibu_method").val()
);
rowdata.h_amount = amount;
-// $("#hopGrid").jqxGrid('setcellvalue', hopRow, 'h_amount', amount);
calcIBUs();
});
$("#wh_ibu").jqxNumberInput({ inputMode: 'simple', theme: theme, width: 90, height: 23, decimalDigits: 1, readOnly: true });
@@ -2803,6 +2781,102 @@
});
// Tab 4, Diversen
+ $("#popupMisc").jqxWindow({
+ width: 800,
+ height: 275,
+ position: { x: 230, y: 100 },
+ resizable: false,
+ theme: theme,
+ isModal: true,
+ autoOpen: false,
+ cancelButton: $("#MiscReady"),
+ modalOpacity: 0.40
+ });
+ $("#MiscReady").jqxButton({ template: "success", width: '90px', theme: theme });
+ $("#MiscReady").click(function () {
+ $("#miscGrid").jqxGrid('sortby', 'm_use_use', 'asc');
+ });
+ $("#wm_name").jqxInput({ theme: theme, width: 320, height: 23 });
+ $("#wm_instock").jqxCheckBox({ theme: theme, height: 23 });
+ $("#wm_instock").on('change', function (event) {
+ miscinstock = event.args.checked;
+ misclist.dataBind();
+ });
+ $("#wm_select").jqxDropDownList({
+ placeHolder: "Kies ingrediënt:",
+ theme: theme,
+ source: misclist,
+ displayMember: "name",
+ width: 150,
+ height: 23,
+ dropDownWidth: 500,
+ dropDownHeight: 500
+ });
+ $("#wm_select").on('select', function (event) {
+ if (event.args) {
+ var index = event.args.index;
+ var datarecord = misclist.records[index];
+ var rowdata = $("#miscGrid").jqxGrid('getrowdata', miscRow);
+ $("#wm_name").val(datarecord.name);
+ rowdata.m_name = datarecord.name;
+ rowdata.m_cost = datarecord.cost;
+ rowdata.m_type = datarecord.type;
+ rowdata.m_use_use = datarecord.use_use;
+ rowdata.m_amount_is_weight = datarecord.amount_is_weight;
+ rowdata.m_inventory = datarecord.inventory;
+ }
+ });
+ $("#wm_amount").jqxNumberInput( Spin1dec1 );
+ $('#wm_amount').on('change', function (event) {
+ console.log("amount changed: "+event.args.value);
+ var amount = parseFloat(event.args.value) / 1000;
+ var rowdata = $("#miscGrid").jqxGrid('getrowdata', miscRow);
+ rowdata.m_amount = amount;
+ });
+ $("#wm_time").jqxNumberInput( PosInt );
+ $("#wm_time").on('change', function (event) {
+ console.log("time changed: "+event.args.value);
+ var rowdata = $("#miscGrid").jqxGrid('getrowdata', miscRow);
+ var newtime = parseFloat(event.args.value);
+
+ if (rowdata.m_use_use == 2) { // Boil
+ if (newtime > parseFloat($("#boil_time").jqxNumberInput('decimal'))) {
+ newtime = parseFloat($("#boil_time").jqxNumberInput('decimal'));
+ $("#wm_time").val(newtime);
+ }
+ rowdata.m_time = newtime;
+ } else if ((rowdata.m_use_use == 3) || (rowdata.m_use_use == 4)) { // Primary or Secondary
+ if (newtime > 21) {
+ newtime = 21;
+ $("#wm_time").val(newtime);
+ }
+ rowdata.m_time = newtime * 1440;
+ }
+ });
+ $("#wm_use_use").jqxDropDownList({
+ theme: theme,
+ source: MiscUseAdapter,
+ valueMember: 'id',
+ displayMember: 'nl',
+ width: 180,
+ height: 23,
+ autoDropDownHeight: true,
+ dropDownVerticalAlignment: 'top'
+ });
+ $("#wm_use_use").on('select', function (event) {
+ if (event.args) {
+ var index = event.args.index;
+ var rowdata = $("#miscGrid").jqxGrid('getrowdata', miscRow);
+ rowdata.m_use_use = index;
+ if ((index == 2) || (index == 3) || (index == 4)) { // Boil, Primary or Secondary
+ $("#wm_time").jqxNumberInput({ spinButtons: true, readOnly: false, width: 110 });
+ } else {
+ rowdata.m_time = 0;
+ $("#wm_time").jqxNumberInput({ spinButtons: false, readOnly: true, width: 90 });
+ $("#wm_time").val(0);
+ }
+ }
+ });
// Tab 5, Gist