171 lines
8.4 KiB
C++
171 lines
8.4 KiB
C++
<% /*
|
|
$Revision$
|
|
$Id$
|
|
|
|
File: srtdeelselector.inc
|
|
Description: Algemene interface functie om een standaard srtdeel suggestbox te maken
|
|
|
|
parameters: fieldName: veldnaam van het key veld. Dit veld wordt gesubmit.
|
|
objectName: naam van het suggest object dat wordt aangemaakt.
|
|
params: object met meegegeven parameters.
|
|
srtdeel_key Initiële key waarde van de srtgroep die ingevuld moet worden.
|
|
srtgroep_key: Srtgroep key (parent)
|
|
multitoggle: Sta multi-toggle toe
|
|
sgRelType: De onderliggende multiSuggest-types die afhankelijk zijn van deze FCLTsrtdeelselector, gescheiden door komma's.
|
|
De eerstvolgende afhankelijke als eerste vermelden (bijv. "srtgroep, srtdeel").
|
|
module: Verplicht: module waarvan de srtdelen zijn
|
|
autfunction Verplicht autfunction (fac_function_code)
|
|
label: label dat voor het veld wordt weergegeven.
|
|
filtercode: extra filtercode voor de query die gebruikt wordt voor de suggest.
|
|
binding: binding waarden
|
|
onChange: onchange op het textveld.
|
|
trclass: wordt ook op de <tr> gezet.
|
|
autlevel: autorisatie niveau voor de query die gebruikt wordt voor de suggest.
|
|
extraParamField: veldnaam voor een extra hidden parameter veld.
|
|
isBad: boolean die aangeeft dat het veld als ongeldig
|
|
en leeg weergegeven moet worden (true|false(default)).
|
|
readonly: geeft aan of het veld readonly weergegeven moet worden (true|false(default)).
|
|
*/ %>
|
|
<!-- #include file="./Suggest/srtdeelFilter.inc" -->
|
|
|
|
<%
|
|
FCLTHeader.Requires({ plugins: ["suggest", "jQuery"], js: [] });
|
|
|
|
function FCLTsrtdeelselector(fieldName, objectName, params)
|
|
{
|
|
var sgType = "srtdeel";
|
|
params = params || {};
|
|
|
|
var lwhenEmpty = (params.whenEmpty != null ? params.whenEmpty : (params.readonly ? L("lcl_select_readonly") : L("lcl_select_srtdeel")));
|
|
var lsrtdeelName = "";
|
|
var lextraInit = "";
|
|
var filtClause = getFiltClauseSrtdeel(params.filtercode, params);
|
|
var orgmodule = params.module || "INS"; // geldige waarden: INS, BES, SLE
|
|
var module = (orgmodule == "SLE" ? "INS" : orgmodule); // module SLE wordt verder behandled als INS.
|
|
|
|
if (orgmodule != "INS" && orgmodule != "BES" && orgmodule != "SLE")
|
|
shared.internal_error(L("lcl_obj_bad_value") + " module={0}.".format(orgmodule));
|
|
|
|
if (params.readonly && params.srtdeel_key && params.srtdeel_key > 0)
|
|
{
|
|
var sql = "SELECT "
|
|
+ lcl.xsql ("sd." + module + "_srtdeel_omschrijving", "sd." + module + "_srtdeel_key") + " srtdeel_omschrijving"
|
|
+ getExtraInfSrtdeel(params.extracode, module)
|
|
+ " FROM " + module + "_srtdeel sd"
|
|
+ " WHERE " + module + "_srtdeel_key = " + params.srtdeel_key;
|
|
var oRs = Oracle.Execute(sql);
|
|
lsrtdeelName = oRs("srtdeel_omschrijving").value;
|
|
lextraInit = oRs("extra").value;
|
|
oRs.Close();
|
|
}
|
|
else
|
|
{
|
|
var sql = "SELECT COUNT(distinct sd." + module + "_srtdeel_key) aantal"
|
|
+ " FROM " + module + "_srtdeel sd"
|
|
+ " , " + module + "_v_aanwezigsrtgroep sg"
|
|
+ filtClause.from
|
|
+ " WHERE sg." + module + "_srtgroep_key = sd." + module + "_srtgroep_key"
|
|
+ filtClause.where;
|
|
var oRs = Oracle.Execute(sql);
|
|
var aantalsrtdelen = oRs("aantal").value;
|
|
oRs.Close();
|
|
// Als er maar één srtdeel is, dan deze selecteren.
|
|
if (aantalsrtdelen == 1)
|
|
{
|
|
sql = "SELECT sd." + module + "_srtdeel_key srtdeel_key"
|
|
+ ", CASE"
|
|
+ " WHEN sd." + module + "_srtdeel_nr IS NULL"
|
|
+ " THEN ''"
|
|
+ " ELSE sd." + module + "_srtdeel_nr || ' '"
|
|
+ " END ||"
|
|
+ lcl.xsql ("sd." + module + "_srtdeel_omschrijving", "sd." + module + "_srtdeel_key") + " srtdeel_omschrijving"
|
|
+ getExtraInfSrtdeel(params.extracode, module)
|
|
+ " FROM " + module + "_srtdeel sd"
|
|
+ ", " + module + "_v_aanwezigsrtgroep sg"
|
|
+ filtClause.from
|
|
+ " WHERE sg." + module + "_srtgroep_key = sd." + module + "_srtgroep_key"
|
|
+ " AND sg." + module + "_srtgroep_verwijder IS NULL"
|
|
+ filtClause.where;
|
|
oRs = Oracle.Execute(sql);
|
|
lsrtdeelName = oRs("srtdeel_omschrijving").value; // bes_srtdeel_omschrijving
|
|
lextraInit = oRs("extra").value;
|
|
params.srtdeel_key = oRs("srtdeel_key").value;
|
|
oRs.Close();
|
|
}
|
|
}
|
|
|
|
// Bouw de url voor de srtdeel query op
|
|
var srtdeelQueryUrl = rooturl + "/appl/shared/suggest/SuggestSrtdeel.asp"
|
|
+ "?autfunction=" + params.autfunction
|
|
+ (params.srtgroep_key? "&srtgroep_key=" + params.srtgroep_key : "")
|
|
+ (params.module? "&module=" + params.module : "")
|
|
+ (params.extracode? "&extracode=" + params.extracode : "")
|
|
+ (params.filtercode? "&filtcode=" + params.filtercode : "")
|
|
+ (params.binding? "&binding=" + params.binding : "");
|
|
if (params.label)
|
|
{ %>
|
|
<tr <%=params.trclass ? "class='"+params.trclass+"'" : ""%>><td class="label">
|
|
<label for="<%=fieldName%>_show"><%=params.label%></label>
|
|
</td>
|
|
<td>
|
|
<%
|
|
}
|
|
if (params.readonly) { %>
|
|
<span id="<%=fieldName%>_show">
|
|
<%=safe.html(lsrtdeelName)%>
|
|
</span>
|
|
<% } else {
|
|
%>
|
|
<input id="<%=fieldName%>_show" class="fld<%=params.required ? " required" : ""%>" value="<%=safe.htmlattr(lsrtdeelName)%>" placeholder="<%=safe.htmlattr(lwhenEmpty)%>"
|
|
sgType="<%=sgType%>" <%=params.onChange ? " sgonChange='" + params.onChange + "'":""%>>
|
|
<% } %>
|
|
<input type="hidden" id="<%=fieldName%>" name="<%=fieldName%>" value="<%=params.srtdeel_key%>">
|
|
<%
|
|
if (params.extraParamField)
|
|
{ /* het extra parameter veld wordt door suggest object gevuld */%>
|
|
<input type="hidden" id="<%=params.extraParamField%>" name="<%=params.extraParamField%>" value="<%=safe.htmlattr(lextraInit)%>">
|
|
<%
|
|
}
|
|
|
|
if (params.label)
|
|
{ %>
|
|
</td></tr>
|
|
<%
|
|
}
|
|
|
|
if (!params.readonly)
|
|
{
|
|
if (params.urlAdd)
|
|
{
|
|
var urlAddTxt = "[";
|
|
for (var i = 0; i < params.urlAdd.length; i++)
|
|
{
|
|
urlAddTxt += (i > 0? ", " : "") + "{ urlParam: \"" + params.urlAdd[i].urlParam + "\", field: \"" + params.urlAdd[i].field + "\" }";
|
|
}
|
|
urlAddTxt += "]"
|
|
}
|
|
%>
|
|
<script type="text/javascript">
|
|
$(function()
|
|
{
|
|
<%=objectName%> = new Suggest({ objectName: "<%=objectName%>",
|
|
sgType: "<%=sgType%>",
|
|
queryField: $("#<%=fieldName%>_show")[0],
|
|
queryUrl: "<%=srtdeelQueryUrl%>",
|
|
initKey: <%=params.srtdeel_key? params.srtdeel_key : -1%>,
|
|
icon: "fa-tag",
|
|
keyField: $("#<%=fieldName%>")[0]
|
|
<%=params.multitoggle? ", multitoggle: true" : ""%>
|
|
<%=params.urlAdd? ", urlAdd: " + urlAddTxt : ""%>
|
|
<%=params.extraParamField? ", extraParamField: $(\"" + "#" + params.extraParamField + "\")[0]" : ""%>
|
|
<%=params.extraParamField? ", initExtraParam: \"" + safe.jsstring("" + lextraInit) + "\"": ""%>
|
|
<%=params.isBad? ", isBad: true": ""%>
|
|
<%=params.readonly? ", fieldReadonly: true": ""%>
|
|
,highlightDescript: true
|
|
});
|
|
});
|
|
</script>
|
|
<%
|
|
}
|
|
}
|
|
%> |