Added ability to use objects within array options. Added better documentation.

This commit is contained in:
Matt Mo 2021-12-06 23:06:00 -08:00
parent dd4792ed04
commit e56ed8648c

View File

@ -150,10 +150,12 @@ import { IgniteTemplate } from "../ignite-html/ignite-template.js";
}
/**
* Generates a series of options based on key value pairs.
* Generates a series of options from an array of values, or an object of key values pairs.
* @param {Array|Object} options An array of strings or list of key value pairs to create options from.
* @param {*} placeholder The placeholder option, it's value will be 0, if set this text will be shown.
* @returns {IgniteTemplate} This ignite template.
* @example IgniteTemplate.prototype.options([{"Custom value": "Display value"}, "value2", "value3"]);
* @example IgniteTemplate.prototype.options({"value1": "A", "value2": "B"});
*/
IgniteTemplate.prototype.options = function(options, placeholder = null) {
//Generate html and populate the template with it.
@ -165,8 +167,13 @@ import { IgniteTemplate } from "../ignite-html/ignite-template.js";
if (Array.isArray(options)) {
for (var i = 0; i < options.length; i++) {
if (options[i] instanceof Object) {
var keys = Object.keys(options[i]);
html += `<option value='${keys[0]}'>${options[i][keys[0]]}</option>`;
} else {
html += `<option value='${options[i]}'>${options[i]}</option>`;
}
}
} else {
var keys = Object.keys(options);
for (var i = 0; i < keys.length; i++) {