Useful AMD modules for custom question types
cbj
This is simply jQuery, which CB loads AMD style without global namespace (to avoid version issues with 3rd party vendors).
Example:
cbrequire(['cbj'], function($) {
$('.something');
});
// or in your custom js module
define(['cbj', 'otherModule'], function($, otherModule) {
});
configbox/configurator.sendSelectionToServer()
With this method you send the user’s selection to the backend for processing. You react to responses from the server with the methods of your JS Question Type Object.
cbrequire(['configbox/configurator'], function(configurator) {
configurator.sendSelectionToServer(questionId, selection);
});
Parameters
questionId (Number)
The ID of the question. Within JS you get the ID from data-attribute ‘question-id’ in the wrapper div of your question template.
selection (Number, String, null)
The selection that the user has made. The CB backend will store any value. It will be sanitized as string (HTML tags stripped). If your question type uses predefined answers, then they need to be the ID of the answer).
The value will be available to you in your view template as $this->selection.
Example during question type init:
define(['cbj', 'configbox/configurator'], function($, configurator) {
var customType = {
..
initEach: function() {
$('.question.type-customtype').on('click', '.some-button', function() {
let questionId = $(this).parent('.question').data('questionId');
let selection = $(this).data('some-data-attribute');
configurator.sendSelectionToServer(questionId, selection);
});
}
..
}
...
configurator.registerQuestionType('customtype', customType);
});
configbox/server.makeRequest()
Use this method to retrieve JSON data from any CB controller task (built-in or custom).
Parameters
controller (String)
Name of the controller to use. See KenedoController on how to add a custom controller to act as backend.
task (String)
Task name, essentially the name of a public method in your controller class.
data (Plain object or Array)
Any data you need to send to the controller task. You have key/value pairs of strings or JS File/Filelist.
Return value
Return value is jQuery’s jqXHR, so you chain done(), error(), always() providing callback functions.
configbox/server.injectHtml()
Use this method to fetch HTML from a KenedoController (typically it fetches a view) and it to the target HTML element.
The framework will inject the HTML and in case the HTML contains a KenedoView, it’s JS initEach and initOnce methods will be called.
Parameters
target (String or jQuery Collection)
Provide either a CSS selector to your target element or a jQuery collection. The fetches HTML will be injected there.
controller (String)
Name of the controller to use. See KenedoController on how to add a custom controller to act as backend.
task (String)
Task name, essentially the public method’s name to call within your controller
data (Plain object or Array) - optional
Any data you need to send to the controller task. You have key/value pairs of strings.
callback (Function) - optional
A callback function that will get called once the HTML is injected.