var table = document.createElement("table"); table.className = "settings"; document.body.appendChild(table); [ { "name": "blockMode", "title": "block mode", "type": "menulist", "value": "fakeReadout", "options": [ { "value": "blockReadout", "label": "block readout API" }, { "value": "fakeReadout", "label": "fake readout API" }, { "value": "fakeInput", "label": "fake input API" }, { "value": "askReadout", "label": "ask for readout API permission" }, { "value": "", "label": "" }, { "value": "blockEverything", "label": "block everything" }, { "value": "block", "label": "allow only white list" }, { "value": "ask", "label": "ask for permission" }, { "value": "allow", "label": "block only black list" }, { "value": "allowEverything", "label": "allow everything" } ] }, { "name": "whiteList", "title": "White list", "type": "string", "value": "", "displayDependencies": { "blockMode": ["blockReadout", "fakeReadout", "fakeInput", "askReadout", "block", "ask"] } }, { "name": "blackList", "title": "Black list", "type": "string", "value": "", "displayDependencies": { "blockMode": ["blockReadout", "fakeReadout", "fakeInput", "askReadout", "ask", "allow"] } }, { "name": "minFakeSize", "title": "Minimal fake size", "type": "integer", "value": 1, "displayDependencies": { "blockMode": ["fakeReadout", "fakeInput"] } }, { "name": "maxFakeSize", "title": "Maximal fake size", "type": "integer", "value": 0, "displayDependencies": { "blockMode": ["fakeReadout", "fakeInput"] } }, { "name": "rng", "title": "Random number generator", "type": "menulist", "value": "nonPersistent", "options": [ { "value": "nonPersistent", "label": "non persistent" }, { "value": "persistent", "label": "persistent" } ], "displayDependencies": { "blockMode": ["fakeReadout", "fakeInput"] } }, { "name": "storePersistentRnd", "title": "Store persistent data", "type": "bool", "value": false, "displayDependencies": { "blockMode": ["fakeReadout", "fakeInput"], "rng": ["persistent"] } }, { "name": "clearPersistentRnd", "title": "Clear persistent random storage", "type": "control", "label": "Clear", "displayDependencies": { "blockMode": ["fakeReadout", "fakeInput"], "rng": ["persistent"] } }, { "name": "askOnlyOnce", "title": "Ask only once", "type": "bool", "value": true, "displayDependencies": { "blockMode": ["askReadout", "ask"] } }, { "name": "showNotifications", "title": "Show notifications", "type": "bool", "value": true, "displayDependencies": { "blockMode": ["fakeReadout", "fakeInput"] } }, { "name": "storeImageForInspection", "title": "Store image for inspection", "type": "bool", "value": false, "displayDependencies": { "blockMode": ["fakeReadout", "fakeInput"], "showNotifications": [true] } }, // { // "name": "notificationDisplayTime", // "title": "notification display time", // "type": "integer", // "value": 30, // "displayDependencies": { // "blockMode": ["fakeReadout", "fakeInput"] // } // }, { "name": "ignoreList", "title": "Ignore list", "type": "string", "value": "", "displayDependencies": { "blockMode": ["fakeReadout", "fakeInput"], "showNotifications": [true] } }, { "name": "showCallingFile", "title": "Display calling file", "type": "bool", "value": false, "displayDependencies": { "blockMode": ["askReadout", "ask"] } }, { "name": "showCompleteCallingStack", "title": "Display complete calling stack", "type": "bool", "value": false, "displayDependencies": [ { "blockMode": ["fakeReadout", "fakeInput"], "showNotifications": [true] }, { "blockMode": ["askReadout", "ask"] } ] },{ "name": "enableStackList", "title": "Use file specific scoped white list", "type": "bool", "value": false, "displayDependencies": { "blockMode": ["blockReadout", "fakeReadout", "fakeInput", "askReadout", "block", "ask"] } }, { "name": "stackList", "title": "File specific white list", "type": "string", "value": "", "displayDependencies": { "enableStackList": [true] } }, { "name": "showReleaseNotes", "title": "Release notes", "type": "control", "label": "Show" } ].forEach(function(pref){ var html = '
__MSG_' + pref.name + '_title__
__MSG_' + pref.name + '_description__
'; var inputAttributes = ' data-storage-name="' + pref.name + '" data-storage-type="' + pref.type + '" class="setting"' switch (pref.type){ case "integer": html += ''; break; case "string": html += ''; break; case "bool": html += ''; break; case "menulist": html += '' + pref.options.map(function(option){ if (option.value){ return ''; } else { return ''; } }).join("") + ''; break; case "control": html += '__MSG_' + pref.name + '_label__'; break; default: console.log("Unknown preference type: " + pref.type); } html += "
"; var tr = document.createElement("tr"); tr.setting = pref; tr.className = "settingRow"; tr.innerHTML = html; console.log(html); table.appendChild(tr); });