Files
Facilitor/APPL/SCF/scaffolding_list.inc
Jos Groot Lipman 175ebc3dc7 FSN#35817 Autorisaties via API2/Scaffolding mutli edit
svn path=/Website/trunk/; revision=28692
2016-03-30 15:53:31 +00:00

361 lines
15 KiB
PHP

<% /*
$Revision$
$Id$
File: scaffolding_list.asp
Description: Toont een lijst
Parameters:
Context: Vanuit scaffolding.inc
Note: model variabele is globaal beschikbaar
*/
%>
<%
function scaffolding_list(model, scf_params)
{
scf_params.list = scf_params.list || {};
scf_params.list.columns = scf_params.list.columns || [];
scf_params.list.groupby = scf_params.list.groupby || [];
scf_params.list.orderby = scf_params.list.orderby || [];
var transit = scf_transit2url(scf_params);
var cols = getQParamArray("columns", []);
if (cols.length && cols[0])
scf_params.list.columns = cols;
var grps = getQParamArray("groupby", []);
if (grps.length)
scf_params.list.groupby = grps;
if (!scf_params.list.columns.length && "list" in model)
{
scf_params.list.columns = model.list.columns;
scf_params.list.groupby = model.list.groupby;
}
var modal = model.edit.modal || scf_params.edit && scf_params.edit.modal; // dan doen we een detailrecord altijd modal
FCLTHeader.Requires({js: ["jquery-ui.js"]});
if ("requires" in scf_params.list)
FCLTHeader.Requires(scf_params.list.requires);
if (model.autfunction)
var authparams = user.checkAutorisation(model.autfunction);
else
var authparams = { PRSreadlevel: -1, ALGreadlevel: -1, PRSwritelevel: -1, ALGwritelevel: -1 };
var showAll = getQParamInt("showall", 0) == 1;
var outputmode = getQParamInt("outputmode", 0)
var nobuttons = getQParamInt("nobuttons", 0) == 1;
var filter = shared.qs2json(model);
if (scf_params.incsetting && scf_params.incsetting.joinfield in filter) // Zijn we eigenlijk een include?
{
transit += "&" + scf_params.incsetting.joinfield + "=" + filter[scf_params.incsetting.joinfield]; // parentkey doorgeven
}
var default_url = model.list.default_url;
if (!default_url && ("show" in model || model["REST_PUT"] || model["REST_DELETE"]))
{
if (modal)
default_url = scf_params.this_fullpath + "?mode=edit" + transit + "&id=";
else
default_url = scf_params.this_path + "?mode=wrap" + transit + "&id=";
}
if (default_url && default_url.indexOf("{0}") == -1)
default_url += "{0}";
%>
<html>
<head>
<% FCLTHeader.Generate({ outputmode: outputmode }); %>
<script>
function scf_show(row)
{
var key = row.getAttribute("ROWKEY");
var url = "<%= default_url %>".format(key);
<% if (modal) { %>
FcltMgr.openModalDetail(url, "<%=safe.jsstring(model.record_title)%>", { callback: FcltMgr.reload });
<% } else { %>
$(row).addClass('dirty');
FcltMgr.openDetail(url, "<%=safe.jsstring(model.record_title)%>");
<% } %>
}
function scf_add()
{
var url = "<%= scf_params.this_fullpath + "?mode=wrap" + transit %>";
<%
if (modal) {
%>
FcltMgr.openModalDetail("<%= scf_params.this_fullpath + "?mode=edit" + transit %>", "<%=L("lcl_add") + " " + safe.jsstring(model.record_title)%>", { callback: FcltMgr.reload });
<% } else { %>
FcltMgr.openDetail("<%= scf_params.this_path + "?mode=wrap" + transit %>", "<%=L("lcl_add") + " " + safe.jsstring(model.record_title)%>");
<% } %>
}
// Sorteren door drag-and-drop experiment (niet actief)
// Return a helper with preserved width of cells
var fixHelper = function(e, ui) {
ui.children().each(function() {
$(this).width($(this).width());
});
ui.css('left', "-2px");
return ui;
};
if (window.$ && 0) // TODO: nog even uit, misschien if ("sequence" in fields)
$(function () {
$("#<%=model.table%> tbody").sortable({
axis: "y",
helper: fixHelper,
stop: function( event, ui ) {
//ui.item.children('td').css('color', 'red');
var rows = [];
$("#<%=model.table%> tbody tr").each(function()
{
rows.push(this.getAttribute("ROWKEY"));
}
);
alert(rows);
}
}).disableSelection() });;
<%= scf_params.list.script %>
</script>
</head>
<body id="listbody">
<%
// doe maar niet. Headers zijn dan de deur te vroeg uit
// en we kunnen geen 500-status meer doen? busyLoading(); // via ResultsetTable is te laat (na REST_GET) dus maar zelf
buttons = [];
if (!nobuttons)
buttons.push({ icon: "page_refresh.png", title: L("lcl_refresh"), action: "FcltMgr.reload()", id: "btn_scf_refresh" });
if (model["REST_POST"] && authparams.PRSwritelevel < 9 && authparams.ALGwritelevel < 9)
{
var addurl = scf_params.this_path + "?mode=wrap" + transit;
buttons.push({ icon: "plus.png", title: L("lcl_add"), action: "scf_add()", id: "btn_scf_add" });
}
var xxx_params = { filter : scf_params.filter || shared.qs2json(model),
columns: scf_params.list.columns,
orderby: scf_params.list.orderby,
groupby: scf_params.list.groupby };
if (!("limit" in xxx_params.filter))
{
xxx_params.filter.limit = showAll?S("qp_maxrows2"):S("qp_maxrows")
}
var isExcel = ((outputmode==2 || outputmode==6) ); // && (S("excel_mode")==0));
var isCSV = ((outputmode==2 || outputmode==6 || outputmode==4) ); // && (S("excel_mode")==1));
xxx_params.filter.nolimit = (isExcel || isCSV);
if (scf_params.incsetting) // Zijn we eigenlijk een include? Dan halen we de
{ // echte data op via (ons als include van) de 'parent'
xxx_params.filter.id = xxx_params.filter[scf_params.incsetting.joinfield]; // Die zal er dan zijn
xxx_params.include = [ getQParam("model") ];
// xxx_params.columns = []; // De kolommen van de parent hebben we niet nodig
var xxx_array = scf_params.orgmodel.REST_GET(xxx_params);
if (xxx_array.length)
xxx_array = xxx_array[0][getQParam("model")];
}
else
{
xxx_params.include = xxx_params.include || [];
for (i in scf_params.list.columns)
{
var xmodel = model;
var fld = scf_params.list.columns[i];
if (fld.indexOf(".") > 0) // Bij res_ruimte configurations.res_opstelling_key ofwel <include>.<field>
{
var inctable = fld.split(".")[0];
xxx_params.include.push(inctable);
}
}
var xxx_array = model.REST_GET(xxx_params);
}
var rst = new ResultsetTable({ dataset: xxx_array,
hasMore: model.total_count > xxx_array.length,
keyColumn: ("id" in model.fields?"id":null),
ID: model.table,
title: model.records_title,
showAll: showAll,
canCSV: !nobuttons && model.list.canCSV,
rowClass: model.list.rowClass,
rowData: scf_params.list.fnRowData,
outputmode: outputmode,
noPrint: nobuttons,
noExcel: nobuttons,
buttons: buttons,
filterParams: xxx_array.filterstring, // Filter parameters in de printafdruk weergeven.
noLoading: true // hebben we al eerder gedaan
});
function fnfncolCheck(fld)
{
return function (oRs)
{
if (oRs.Fields(fld).Value == 1)
return L("lcl_Yes")
else
return L("lcl_No")
}
}
function fnfncolTranslatable(fld)
{
return function (oRs)
{
var plabel = oRs.Fields(fld).Value;
var fn = "FcltMgr.stopPropagation(event);iface.translate('{0}', {1}, this.innerText, '{2}', 'input')".format(model.fields[fld].dbs, oRs.Fields("id").Value, safe.jsstring(plabel))
return "<span class='facmgtmultilang' onclick='"+safe.htmlattr(fn)+"'>" + safe.html(plabel) + "</span>";
}
}
function fnfncolFunction(fn)
{
return function (oRs)
{
return fn(oRs);
}
}
function fnfncolInclude(inctable, fld)
{
return function (oRs)
{
var incdata = oRs.Fields(inctable).Value;
var safebuilder = [];
var done = {};
// Het sorteren in de query is ondoenlijk (door de foreigns) dus maar hier
incdata.sort(function (a, b) {
var valA = a[fld];
if (valA && typeof valA == "object" && "name" in valA)
valA = valA["name"];
var valB = b[fld];
if (valB && typeof valB == "object" && "name" in valB)
valB = valB["name"];
return valA <= valB? -1: 1
});
var maxinline = 99; // hardcoded om te grote pagina's te voorkomen
if (incdata.length < maxinline)
for (var i = 0; i < incdata.length && i < maxinline; i++)
{
var val = incdata[i][fld];
if (val && typeof val == "object" && "name" in val)
val = val["name"];
if (!(val in done)) // Voorkom dubbelen (opstelling/ruimte)
{
safebuilder.push(val);
done[val] = 1;
}
}
if (incdata.length > maxinline)
safebuilder.push("More than {0}".format(maxinline));
return safebuilder.join("<br>");
}
}
function fnfnmyFloat(kolom)
{
return function (oRs)
{
var v = oRs.Fields(kolom).Value;
return safe.displayfloat(v, 2, true); // true voor trimZeros, we weten helemaal niet of die 2 zo bedoeld was
}
}
function fntotalShow(column, nrlines)
{
if (column.datatype == 'currency')
return safe.curr(column.totalsum);
else
return safe.displayfloat(column.totalsum, 2, true);
}
function fnfnmyVal(kolom)
{
return function (oRs)
{
return oRs.Fields(kolom).Value;
}
}
for (i in scf_params.list.columns)
{
var xmodel = model;
var fld = scf_params.list.columns[i];
var inctable = null;
if (fld.indexOf(".") > 0) // Bij res_ruimte configurations.res_opstelling_key ofwel <include>.<field>
{
inctable = fld.split(".")[0];
if (model.includes && inctable in model.includes)
{
xmodel = model.includes[inctable].model;
var fld = fld.split(".")[1];
}
else
inctable = null;
}
if (!(fld in xmodel.fields)) // Tijdens ontwikkeling vaak fout
{
__DoLog(model.fields);
__DoLog(scf_params.list.columns);
abort_with_warning("Field '{0}' not found in model '{1}'".format(fld, model.table));
}
var field = xmodel.fields[fld];
if (field.hidden) // Bij een detailrecord is de parent_key op hidden gezet
continue;
var coldata = { caption: field.orglabel? field.orglabel: field.label, content: fld, datatype: field.typ, total: field.total };
if (outputmode == 4)
{
coldata.caption = fld; // Naar csv altijd veldnaam
coldata.caption = coldata.caption.replace(/^(HIDE_F_|FCLT_X_|FCLT_3D_|FCLT_KEY|FCLT_F_|HTML_|FCLT_D_|FCLT_C_)/i, "");
}
if (field.foreign || field.LOV) // Foreign en LOV zijn effectief altijd tekst
coldata.datatype = 'varchar';
else
if (field.typ == 'number' || field.typ == 'key')
coldata.datatype = 'number'; // Zo verwacht resultsettable dat
if (field.autofloat) // Vanuit model_reports hebben we niet altijd correct autodetect
{ // van het datatype 'float' gedaan. Daarom hier autofloat
coldata.amount = fnfnmyVal(fld); // voor optellen
coldata.content = fnfnmyFloat(fld);
rst.totalShow = fntotalShow;
}
if (field.typ == 'check' || field.typ == 'check0')
{
coldata.content = fnfncolCheck(fld);
}
if (field.listfunction)
{
coldata.content = fnfncolFunction(field.listfunction);
}
// Child tabellen kunnen we inline localizen
if (field.translate && S("multi_language_option") && model.edit.modal)
coldata.content = fnfncolTranslatable(fld);
if (inctable)
{
coldata.content = fnfncolInclude(inctable, fld);
}
rst.addColumn(new Column(coldata));
}
if (scf_params.list.default_action || default_url)
rst.addAction({ action: scf_params.list.default_action||"scf_show", caption: L("lcl_edit"), isDefault: true } );
if (scf_params.list.actions)
{
for (var i = 0; i < scf_params.list.actions.length; i++)
rst.addAction(scf_params.list.actions[i]);
}
var cnt = rst.processResultset();
%>
</body>
</html>
<%
}
%>