Difference between revisions of "HTML Presentation Object: Search Textbox"
Jump to navigation
Jump to search
| Line 36: | Line 36: | ||
function searchClicked<#uniqueId>() { | function searchClicked<#uniqueId>() { | ||
var textBoxValue = $("#content<#uniqueId>").val(); | var textBoxValue = $("#content<#uniqueId>").val(); | ||
| − | + | qpr.setSessionVariable(variableBinding<#uniqueId>, textBoxValue, "<#uniqueId>"); | |
} | } | ||
Revision as of 13:01, 27 June 2018
This example code is a textbox with the following features:
- Textbox contents can be bound to a definable context variable (line var variableBinding<#uniqueId> = "myVariable1";)
- There is a definable delay after which the typed text is set to the context variable (var inputDelay<#uniqueId> = 1000;)
- Set the delay to 0, to disable it
- There is a magnifier button to "start the search" which stores the text immediately to the bound context variable
- Clicking the Enter key makes the same as clicking the magnifier button
- The magnifier button can be removed, to make the input textbox more generic (remove the line starting with <img)
- Clicking the magnifier button can also change other context variables, such as open a separate view for the search results (add new command to function searchClicked<#uniqueId>)
<input id="content<#uniqueId>" type="text" placeholder="Search" onchange="textboxChanged<#uniqueId>(this);" onkeyup="textboxChanged<#uniqueId>(this);" onpaste="textboxChanged<#uniqueId>(this);" oninput="textboxChanged<#uniqueId>(this);" />
<img id="seachbutton<#uniqueId>" onclick="searchClicked<#uniqueId>();" src="" />
<style>
#content<#uniqueId> {
border-radius: 4px;
border-width: 1px;
width: calc(100% - 20px);
margin: 10px 10px 10px 10px;
padding: 2px 26px 0px 5px;
display: inline;
}
#seachbutton<#uniqueId> {
position: absolute;
top: 17px;
right: 17px;
cursor: pointer;
}
</style>
<script>
var variableBinding<#uniqueId> = "myVariable1";
var inputDelay<#uniqueId> = 1000;
var pendingTimeouts<#uniqueId> = 0;
function searchClicked<#uniqueId>() {
var textBoxValue = $("#content<#uniqueId>").val();
qpr.setSessionVariable(variableBinding<#uniqueId>, textBoxValue, "<#uniqueId>");
}
function <#contextChangeFunction>(changedContextVariables) {
if (changedContextVariables[variableBinding<#uniqueId>] != null && $("#content<#uniqueId>").val() != changedContextVariables[variableBinding<#uniqueId>]) {
$("#content<#uniqueId>").val(changedContextVariables[variableBinding<#uniqueId>]);
}
$("#content<#uniqueId>").keyup(function(event) {
if (event.keyCode == 13) searchClicked<#uniqueId>();
});
}
function textboxChanged<#uniqueId>(evt) {
var textBoxValue = $(evt).val();
if (inputDelay<#uniqueId> > 0) {
pendingTimeouts<#uniqueId>++;
setTimeout(function() {
pendingTimeouts<#uniqueId>--;
if (pendingTimeouts<#uniqueId> > 0) return;
qpr.setSessionVariable(variableBinding<#uniqueId>, textBoxValue, "<#uniqueId>");
}, inputDelay<#uniqueId>);
} else {
qpr.setSessionVariable(variableBinding<#uniqueId>, textBoxValue, "<#uniqueId>");
}
}
</script>