diff options
author | sebdet <sebastien.determe@intl.att.com> | 2019-03-18 16:26:44 +0100 |
---|---|---|
committer | sebdet <sebastien.determe@intl.att.com> | 2019-03-18 16:26:44 +0100 |
commit | 4ff72c3db0f2808d92a9dc20b1feb1cf3462f73c (patch) | |
tree | 6b10380054cb10dd984449b88ddc0077e6a63c09 /src | |
parent | 7fc8fd594dddbd079fcb8419f658e08620eb38c7 (diff) |
Improve Policy window
Improve the policy window in the Clamp UI & update Json-editor lib
Issue-ID: CLAMP-264
Change-Id: I602641f4e849385aecc16b646c0aa4f0dcfbcf12
Signed-off-by: sebdet <sebastien.determe@intl.att.com>
Diffstat (limited to 'src')
-rw-r--r-- | src/main/resources/META-INF/resources/designer/lib/jsoneditor.js | 10236 | ||||
-rw-r--r-- | src/main/resources/META-INF/resources/designer/scripts/ToscaModelCtrl.js | 6 |
2 files changed, 13 insertions, 10229 deletions
diff --git a/src/main/resources/META-INF/resources/designer/lib/jsoneditor.js b/src/main/resources/META-INF/resources/designer/lib/jsoneditor.js index 2966fac9..3d899050 100644 --- a/src/main/resources/META-INF/resources/designer/lib/jsoneditor.js +++ b/src/main/resources/META-INF/resources/designer/lib/jsoneditor.js @@ -1,10235 +1,19 @@ /** * @name JSON Editor * @description JSON Schema Based Editor - * Deprecation notice - * This repo is no longer maintained (see also https://github.com/jdorn/json-editor/issues/800) - * Development is continued at https://github.com/json-editor/json-editor - * For details please visit https://github.com/json-editor/json-editor/issues/5 - * @version 1.1.0-beta.2 + * This library is the continuation of jdorn's great work (see also https://github.com/jdorn/json-editor/issues/800) + * @version 1.3.5 * @author Jeremy Dorn * @see https://github.com/jdorn/json-editor/ * @see https://github.com/json-editor/json-editor * @license MIT * @example see README.md and docs/ for requirements, examples and usage info */ - -(function() { - -/*jshint loopfunc: true */ -/* Simple JavaScript Inheritance - * By John Resig http://ejohn.org/ - * MIT Licensed. - */ -// Inspired by base2 and Prototype -var Class; -(function(){ - var initializing = false, fnTest = /xyz/.test(function(){window.postMessage("xyz");}) ? /\b_super\b/ : /.*/; - - // The base Class implementation (does nothing) - Class = function(){}; - - // Create a new Class that inherits from this class - Class.extend = function extend(prop) { - var _super = this.prototype; - - // Instantiate a base class (but only create the instance, - // don't run the init constructor) - initializing = true; - var prototype = new this(); - initializing = false; - - // Copy the properties over onto the new prototype - for (var name in prop) { - // Check if we're overwriting an existing function - prototype[name] = typeof prop[name] == "function" && - typeof _super[name] == "function" && fnTest.test(prop[name]) ? - (function(name, fn){ - return function() { - var tmp = this._super; - - // Add a new ._super() method that is the same method - // but on the super-class - this._super = _super[name]; - - // The method only need to be bound temporarily, so we - // remove it when we're done executing - var ret = fn.apply(this, arguments); - this._super = tmp; - - return ret; - }; - })(name, prop[name]) : - prop[name]; - } - - // The dummy class constructor - function Class() { - // All construction is actually done in the init method - if ( !initializing && this.init ) - this.init.apply(this, arguments); - } - - // Populate our constructed prototype object - Class.prototype = prototype; - - // Enforce the constructor to be what we expect - Class.prototype.constructor = Class; - - // And make this class extendable - Class.extend = extend; - - return Class; - }; - - return Class; -})(); - -// CustomEvent constructor polyfill -// From MDN -(function () { - function CustomEvent ( event, params ) { - params = params || { bubbles: false, cancelable: false, detail: undefined }; - var evt = document.createEvent( 'CustomEvent' ); - evt.initCustomEvent( event, params.bubbles, params.cancelable, params.detail ); - return evt; - } - - CustomEvent.prototype = window.Event.prototype; - - window.CustomEvent = CustomEvent; -})(); - -// requestAnimationFrame polyfill by Erik Möller. fixes from Paul Irish and Tino Zijdel -// MIT license -(function() { - var lastTime = 0; - var vendors = ['ms', 'moz', 'webkit', 'o']; - for(var x = 0; x < vendors.length && !window.requestAnimationFrame; ++x) { - window.requestAnimationFrame = window[vendors[x]+'RequestAnimationFrame']; - window.cancelAnimationFrame = window[vendors[x]+'CancelAnimationFrame'] || - window[vendors[x]+'CancelRequestAnimationFrame']; - } - - if (!window.requestAnimationFrame) - window.requestAnimationFrame = function(callback, element) { - var currTime = new Date().getTime(); - var timeToCall = Math.max(0, 16 - (currTime - lastTime)); - var id = window.setTimeout(function() { callback(currTime + timeToCall); }, - timeToCall); - lastTime = currTime + timeToCall; - return id; - }; - - if (!window.cancelAnimationFrame) - window.cancelAnimationFrame = function(id) { - clearTimeout(id); - }; -}()); - -// Array.isArray polyfill -// From MDN -(function() { - if(!Array.isArray) { - Array.isArray = function(arg) { - return Object.prototype.toString.call(arg) === '[object Array]'; - }; - } -}()); -/** - * Taken from jQuery 2.1.3 - * - * @param obj - * @returns {boolean} - */ -var $isplainobject = function( obj ) { - // Not plain objects: - // - Any object or value whose internal [[Class]] property is not "[object Object]" - // - DOM nodes - // - window - if (typeof obj !== "object" || obj.nodeType || (obj !== null && obj === obj.window)) { - return false; - } - - if (obj.constructor && !Object.prototype.hasOwnProperty.call(obj.constructor.prototype, "isPrototypeOf")) { - return false; - } - - // If the function hasn't returned already, we're confident that - // |obj| is a plain object, created by {} or constructed with new Object - return true; -}; - -var $extend = function(destination) { - var source, i,property; - for(i=1; i<arguments.length; i++) { - source = arguments[i]; - for (property in source) { - if(!source.hasOwnProperty(property)) continue; - if(source[property] && $isplainobject(source[property])) { - if(!destination.hasOwnProperty(property)) destination[property] = {}; - $extend(destination[property], source[property]); - } - else { - destination[property] = source[property]; - } - } - } - return destination; -}; - -var $each = function(obj,callback) { - if(!obj || typeof obj !== "object") return; - var i; - if(Array.isArray(obj) || (typeof obj.length === 'number' && obj.length > 0 && (obj.length - 1) in obj)) { - for(i=0; i<obj.length; i++) { - if(callback(i,obj[i])===false) return; - } - } - else { - if (Object.keys) { - var keys = Object.keys(obj); - for(i=0; i<keys.length; i++) { - if(callback(keys[i],obj[keys[i]])===false) return; - } - } - else { - for(i in obj) { - if(!obj.hasOwnProperty(i)) continue; - if(callback(i,obj[i])===false) return; - } - } - } -}; - -var $trigger = function(el,event) { - var e = document.createEvent('HTMLEvents'); - e.initEvent(event, true, true); - el.dispatchEvent(e); -}; -var $triggerc = function(el,event) { - var e = new CustomEvent(event,{ - bubbles: true, - cancelable: true - }); - - el.dispatchEvent(e); -}; - -var JSONEditor = function(element,options) { - if (!(element instanceof Element)) { - throw new Error('element should be an instance of Element'); - } - options = $extend({},JSONEditor.defaults.options,options||{}); - this.element = element; - this.options = options; - this.init(); -}; -JSONEditor.prototype = { - // necessary since we remove the ctor property by doing a literal assignment. Without this - // the $isplainobject function will think that this is a plain object. - constructor: JSONEditor, - init: function() { - var self = this; - - this.ready = false; - this.copyClipboard = null; - - var theme_class = JSONEditor.defaults.themes[this.options.theme || JSONEditor.defaults.theme]; - if(!theme_class) throw "Unknown theme " + (this.options.theme || JSONEditor.defaults.theme); - - this.schema = this.options.schema; - this.theme = new theme_class(); - this.template = this.options.template; - this.refs = this.options.refs || {}; - this.uuid = 0; - this.__data = {}; - - var icon_class = JSONEditor.defaults.iconlibs[this.options.iconlib || JSONEditor.defaults.iconlib]; - if(icon_class) this.iconlib = new icon_class(); - - this.root_container = this.theme.getContainer(); - this.element.appendChild(this.root_container); - - this.translate = this.options.translate || JSONEditor.defaults.translate; - - // Fetch all external refs via ajax - this._loadExternalRefs(this.schema, function() { - self._getDefinitions(self.schema); - - // Validator options - var validator_options = {}; - if(self.options.custom_validators) { - validator_options.custom_validators = self.options.custom_validators; - } - self.validator = new JSONEditor.Validator(self,null,validator_options); - - // Create the root editor - var schema = self.expandRefs(self.schema); - var editor_class = self.getEditorClass(schema); - self.root = self.createEditor(editor_class, { - jsoneditor: self, - schema: schema, - required: true, - container: self.root_container - }); - - self.root.preBuild(); - self.root.build(); - self.root.postBuild(); - - // Starting data - if(self.options.hasOwnProperty('startval')) self.root.setValue(self.options.startval, true); - - self.validation_results = self.validator.validate(self.root.getValue()); - self.root.showValidationErrors(self.validation_results); - self.ready = true; - - // Fire ready event asynchronously - window.requestAnimationFrame(function() { - if(!self.ready) return; - self.validation_results = self.validator.validate(self.root.getValue()); - self.root.showValidationErrors(self.validation_results); - self.trigger('ready'); - self.trigger('change'); - }); - }); - }, - getValue: function() { - if(!this.ready) throw "JSON Editor not ready yet. Listen for 'ready' event before getting the value"; - - return this.root.getValue(); - }, - setValue: function(value) { - if(!this.ready) throw "JSON Editor not ready yet. Listen for 'ready' event before setting the value"; - - this.root.setValue(value); - return this; - }, - validate: function(value) { - if(!this.ready) throw "JSON Editor not ready yet. Listen for 'ready' event before validating"; - - // Custom value - if(arguments.length === 1) { - return this.validator.validate(value); - } - // Current value (use cached result) - else { - return this.validation_results; - } - }, - destroy: function() { - if(this.destroyed) return; - if(!this.ready) return; - - this.schema = null; - this.options = null; - this.root.destroy(); - this.root = null; - this.root_container = null; - this.validator = null; - this.validation_results = null; - this.theme = null; - this.iconlib = null; - this.template = null; - this.__data = null; - this.ready = false; - this.element.innerHTML = ''; - - this.destroyed = true; - }, - on: function(event, callback) { - this.callbacks = this.callbacks || {}; - this.callbacks[event] = this.callbacks[event] || []; - this.callbacks[event].push(callback); - - return this; - }, - off: function(event, callback) { - // Specific callback - if(event && callback) { - this.callbacks = this.callbacks || {}; - this.callbacks[event] = this.callbacks[event] || []; - var newcallbacks = []; - for(var i=0; i<this.callbacks[event].length; i++) { - if(this.callbacks[event][i]===callback) continue; - newcallbacks.push(this.callbacks[event][i]); - } - this.callbacks[event] = newcallbacks; - } - // All callbacks for a specific event - else if(event) { - this.callbacks = this.callbacks || {}; - this.callbacks[event] = []; - } - // All callbacks for all events - else { - this.callbacks = {}; - } - - return this; - }, - trigger: function(event) { - if(this.callbacks && this.callbacks[event] && this.callbacks[event].length) { - for(var i=0; i<this.callbacks[event].length; i++) { - this.callbacks[event][i].apply(this, []); - } - } - - return this; - }, - setOption: function(option, value) { - if(option === "show_errors") { - this.options.show_errors = value; - this.onChange(); - } - // Only the `show_errors` option is supported for now - else { - throw "Option "+option+" must be set during instantiation and cannot be changed later"; - } - - return this; - }, - getEditorClass: function(schema) { - var classname; - - schema = this.expandSchema(schema); - - $each(JSONEditor.defaults.resolvers,function(i,resolver) { - var tmp = resolver(schema); - if(tmp) { - if(JSONEditor.defaults.editors[tmp]) { - classname = tmp; - return false; - } - } - }); - - if(!classname) throw "Unknown editor for schema "+JSON.stringify(schema); - if(!JSONEditor.defaults.editors[classname]) throw "Unknown editor "+classname; - - return JSONEditor.defaults.editors[classname]; - }, - createEditor: function(editor_class, options) { - options = $extend({},editor_class.options||{},options); - return new editor_class(options); - }, - onChange: function() { - if(!this.ready) return; - - if(this.firing_change) return; - this.firing_change = true; - - var self = this; - - window.requestAnimationFrame(function() { - self.firing_change = false; - if(!self.ready) return; - - // Validate and cache results - self.validation_results = self.validator.validate(self.root.getValue()); - - if(self.options.show_errors !== "never") { - self.root.showValidationErrors(self.validation_results); - } - else { - self.root.showValidationErrors([]); - } - - // Fire change event - self.trigger('change'); - }); - - return this; - }, - compileTemplate: function(template, name) { - name = name || JSONEditor.defaults.template; - - var engine; - - // Specifying a preset engine - if(typeof name === 'string') { - if(!JSONEditor.defaults.templates[name]) throw "Unknown template engine "+name; - engine = JSONEditor.defaults.templates[name](); - - if(!engine) throw "Template engine "+name+" missing required library."; - } - // Specifying a custom engine - else { - engine = name; - } - - if(!engine) throw "No template engine set"; - if(!engine.compile) throw "Invalid template engine set"; - - return engine.compile(template); - }, - _data: function(el,key,value) { - // Setting data - if(arguments.length === 3) { - var uuid; - if(el.hasAttribute('data-jsoneditor-'+key)) { - uuid = el.getAttribute('data-jsoneditor-'+key); - } - else { - uuid = this.uuid++; - el.setAttribute('data-jsoneditor-'+key,uuid); - } - - this.__data[uuid] = value; - } - // Getting data - else { - // No data stored - if(!el.hasAttribute('data-jsoneditor-'+key)) return null; - - return this.__data[el.getAttribute('data-jsoneditor-'+key)]; - } - }, - registerEditor: function(editor) { - this.editors = this.editors || {}; - this.editors[editor.path] = editor; - return this; - }, - unregisterEditor: function(editor) { - this.editors = this.editors || {}; - this.editors[editor.path] = null; - return this; - }, - getEditor: function(path) { - if(!this.editors) return; - return this.editors[path]; - }, - watch: function(path,callback) { - this.watchlist = this.watchlist || {}; - this.watchlist[path] = this.watchlist[path] || []; - this.watchlist[path].push(callback); - - return this; - }, - unwatch: function(path,callback) { - if(!this.watchlist || !this.watchlist[path]) return this; - // If removing all callbacks for a path - if(!callback) { - this.watchlist[path] = null; - return this; - } - - var newlist = []; - for(var i=0; i<this.watchlist[path].length; i++) { - if(this.watchlist[path][i] === callback) continue; - else newlist.push(this.watchlist[path][i]); - } - this.watchlist[path] = newlist.length? newlist : null; - return this; - }, - notifyWatchers: function(path) { - if(!this.watchlist || !this.watchlist[path]) return this; - for(var i=0; i<this.watchlist[path].length; i++) { - this.watchlist[path][i](); - } - }, - isEnabled: function() { - return !this.root || this.root.isEnabled(); - }, - enable: function() { - this.root.enable(); - }, - disable: function() { - this.root.disable(); - }, - _getDefinitions: function(schema,path) { - path = path || '#/definitions/'; - if(schema.definitions) { - for(var i in schema.definitions) { - if(!schema.definitions.hasOwnProperty(i)) continue; - this.refs[path+i] = schema.definitions[i]; - if(schema.definitions[i].definitions) { - this._getDefinitions(schema.definitions[i],path+i+'/definitions/'); - } - } - } - }, - _getExternalRefs: function(schema) { - var refs = {}; - var merge_refs = function(newrefs) { - for(var i in newrefs) { - if(newrefs.hasOwnProperty(i)) { - refs[i] = true; - } - } - }; - - if(schema.$ref && typeof schema.$ref !== "object" && schema.$ref.substr(0,1) !== "#" && !this.refs[schema.$ref]) { - refs[schema.$ref] = true; - } - - for(var i in schema) { - if(!schema.hasOwnProperty(i)) continue; - if(schema[i] && typeof schema[i] === "object" && Array.isArray(schema[i])) { - for(var j=0; j<schema[i].length; j++) { - if(schema[i][j] && typeof schema[i][j]==="object") { - merge_refs(this._getExternalRefs(schema[i][j])); - } - } - } - else if(schema[i] && typeof schema[i] === "object") { - merge_refs(this._getExternalRefs(schema[i])); - } - } - - return refs; - }, - _loadExternalRefs: function(schema, callback) { - var self = this; - var refs = this._getExternalRefs(schema); - - var done = 0, waiting = 0, callback_fired = false; - - $each(refs,function(url) { - if(self.refs[url]) return; - if(!self.options.ajax) throw "Must set ajax option to true to load external ref "+url; - self.refs[url] = 'loading'; - waiting++; - - var fetchUrl=url; - if( self.options.ajaxBase && self.options.ajaxBase!=url.substr(0,self.options.ajaxBase.length) && "http"!=url.substr(0,4)) fetchUrl=self.options.ajaxBase+url; - - var r = new XMLHttpRequest(); - r.open("GET", fetchUrl, true); - if(self.options.ajaxCredentials) r.withCredentials=self.options.ajaxCredentials; - r.onreadystatechange = function () { - if (r.readyState != 4) return; - // Request succeeded - if(r.status === 200) { - var response; - try { - response = JSON.parse(r.responseText); - } - catch(e) { - window.console.log(e); - throw "Failed to parse external ref "+fetchUrl; - } - if(!response || typeof response !== "object") throw "External ref does not contain a valid schema - "+fetchUrl; - - self.refs[url] = response; - self._loadExternalRefs(response,function() { - done++; - if(done >= waiting && !callback_fired) { - callback_fired = true; - callback(); - } - }); - } - // Request failed - else { - window.console.log(r); - throw "Failed to fetch ref via ajax- "+url; - } - }; - r.send(); - }); - - if(!waiting) { - callback(); - } - }, - expandRefs: function(schema) { - schema = $extend({},schema); - - while (schema.$ref) { - var ref = schema.$ref; - delete schema.$ref; - - if(!this.refs[ref]) ref = decodeURIComponent(ref); - - schema = this.extendSchemas(schema,this.refs[ref]); - } - return schema; - }, - expandSchema: function(schema) { - var self = this; - var extended = $extend({},schema); - var i; - - // Version 3 `type` - if(typeof schema.type === 'object') { - // Array of types - if(Array.isArray(schema.type)) { - $each(schema.type, function(key,value) { - // Schema - if(typeof value === 'object') { - schema.type[key] = self.expandSchema(value); - } - }); - } - // Schema - else { - schema.type = self.expandSchema(schema.type); - } - } - // Version 3 `disallow` - if(typeof schema.disallow === 'object') { - // Array of types - if(Array.isArray(schema.disallow)) { - $each(schema.disallow, function(key,value) { - // Schema - if(typeof value === 'object') { - schema.disallow[key] = self.expandSchema(value); - } - }); - } - // Schema - else { - schema.disallow = self.expandSchema(schema.disallow); - } - } - // Version 4 `anyOf` - if(schema.anyOf) { - $each(schema.anyOf, function(key,value) { - schema.anyOf[key] = self.expandSchema(value); - }); - } - // Version 4 `dependencies` (schema dependencies) - if(schema.dependencies) { - $each(schema.dependencies,function(key,value) { - if(typeof value === "object" && !(Array.isArray(value))) { - schema.dependencies[key] = self.expandSchema(value); - } - }); - } - // Version 4 `not` - if(schema.not) { - schema.not = this.expandSchema(schema.not); - } - - // allOf schemas should be merged into the parent - if(schema.allOf) { - for(i=0; i<schema.allOf.length; i++) { - extended = this.extendSchemas(extended,this.expandSchema(schema.allOf[i])); - } - delete extended.allOf; - } - // extends schemas should be merged into parent - if(schema["extends"]) { - // If extends is a schema - if(!(Array.isArray(schema["extends"]))) { - extended = this.extendSchemas(extended,this.expandSchema(schema["extends"])); - } - // If extends is an array of schemas - else { - for(i=0; i<schema["extends"].length; i++) { - extended = this.extendSchemas(extended,this.expandSchema(schema["extends"][i])); - } - } - delete extended["extends"]; - } - // parent should be merged into oneOf schemas - if(schema.oneOf) { - var tmp = $extend({},extended); - delete tmp.oneOf; - for(i=0; i<schema.oneOf.length; i++) { - extended.oneOf[i] = this.extendSchemas(this.expandSchema(schema.oneOf[i]),tmp); - } - } - - return this.expandRefs(extended); - }, - extendSchemas: function(obj1, obj2) { - obj1 = $extend({},obj1); - obj2 = $extend({},obj2); - - var self = this; - var extended = {}; - $each(obj1, function(prop,val) { - // If this key is also defined in obj2, merge them - if(typeof obj2[prop] !== "undefined") { - // Required and defaultProperties arrays should be unioned together - if((prop === 'required'||prop === 'defaultProperties') && typeof val === "object" && Array.isArray(val)) { - // Union arrays and unique - extended[prop] = val.concat(obj2[prop]).reduce(function(p, c) { - if (p.indexOf(c) < 0) p.push(c); - return p; - }, []); - } - // Type should be intersected and is either an array or string - else if(prop === 'type' && (typeof val === "string" || Array.isArray(val))) { - // Make sure we're dealing with arrays - if(typeof val === "string") val = [val]; - if(typeof obj2.type === "string") obj2.type = [obj2.type]; - - // If type is only defined in the first schema, keep it - if(!obj2.type || !obj2.type.length) { - extended.type = val; - } - // If type is defined in both schemas, do an intersect - else { - extended.type = val.filter(function(n) { - return obj2.type.indexOf(n) !== -1; - }); - } - - // If there's only 1 type and it's a primitive, use a string instead of array - if(extended.type.length === 1 && typeof extended.type[0] === "string") { - extended.type = extended.type[0]; - } - // Remove the type property if it's empty - else if(extended.type.length === 0) { - delete extended.type; - } - } - // All other arrays should be intersected (enum, etc.) - else if(typeof val === "object" && Array.isArray(val)){ - extended[prop] = val.filter(function(n) { - return obj2[prop].indexOf(n) !== -1; - }); - } - // Objects should be recursively merged - else if(typeof val === "object" && val !== null) { - extended[prop] = self.extendSchemas(val,obj2[prop]); - } - // Otherwise, use the first value - else { - extended[prop] = val; - } - } - // Otherwise, just use the one in obj1 - else { - extended[prop] = val; - } - }); - // Properties in obj2 that aren't in obj1 - $each(obj2, function(prop,val) { - if(typeof obj1[prop] === "undefined") { - extended[prop] = val; - } - }); - - return extended; - }, - setCopyClipboardContents: function(value) { - this.copyClipboard = value; - }, - getCopyClipboardContents: function() { - return this.copyClipboard; - } -}; - -JSONEditor.defaults = { - themes: {}, - templates: {}, - iconlibs: {}, - editors: {}, - languages: {}, - resolvers: [], - custom_validators: [] -}; - -JSONEditor.Validator = Class.extend({ - init: function(jsoneditor,schema,options) { - this.jsoneditor = jsoneditor; - this.schema = schema || this.jsoneditor.schema; - this.options = options || {}; - this.translate = this.jsoneditor.translate || JSONEditor.defaults.translate; - }, - validate: function(value) { - return this._validateSchema(this.schema, value); - }, - _validateSchema: function(schema,value,path) { - var self = this; - var errors = []; - var valid, i, j; - var stringified = JSON.stringify(value); - - path = path || 'root'; - - // Work on a copy of the schema - schema = $extend({},this.jsoneditor.expandRefs(schema)); - - /* - * Type Agnostic Validation - */ - - // Version 3 `required` and `required_by_default` - if(typeof value === "undefined" || value === null) { - if((typeof schema.required !== "undefined" && schema.required === true) || (typeof schema.required === "undefined" && this.jsoneditor.options.required_by_default === true)) { - errors.push({ - path: path, - property: 'required', - message: this.translate("error_notset", [schema.title ? schema.title : path.split('-').pop().trim()]) - }); - } - - return errors; - } - - // `enum` - if(schema["enum"]) { - valid = false; - for(i=0; i<schema["enum"].length; i++) { - if(stringified === JSON.stringify(schema["enum"][i])) valid = true; - } - if(!valid) { - errors.push({ - path: path, - property: 'enum', - message: this.translate("error_enum", [schema.title ? schema.title : path.split('-').pop().trim()]) - }); - } - } - - // `extends` (version 3) - if(schema["extends"]) { - for(i=0; i<schema["extends"].length; i++) { - errors = errors.concat(this._validateSchema(schema["extends"][i],value,path)); - } - } - - // `allOf` - if(schema.allOf) { - for(i=0; i<schema.allOf.length; i++) { - errors = errors.concat(this._validateSchema(schema.allOf[i],value,path)); - } - } - - // `anyOf` - if(schema.anyOf) { - valid = false; - for(i=0; i<schema.anyOf.length; i++) { - if(!this._validateSchema(schema.anyOf[i],value,path).length) { - valid = true; - break; - } - } - if(!valid) { - errors.push({ - path: path, - property: 'anyOf', - message: this.translate('error_anyOf') - }); - } - } - - // `oneOf` - if(schema.oneOf) { - valid = 0; - var oneof_errors = []; - for(i=0; i<schema.oneOf.length; i++) { - // Set the error paths to be path.oneOf[i].rest.of.path - var tmp = this._validateSchema(schema.oneOf[i],value,path); - if(!tmp.length) { - valid++; - } - - for(j=0; j<tmp.length; j++) { - tmp[j].path = path+'.oneOf['+i+']'+tmp[j].path.substr(path.length); - } - oneof_errors = oneof_errors.concat(tmp); - - } - if(valid !== 1) { - errors.push({ - path: path, - property: 'oneOf', - message: this.translate('error_oneOf', [valid]) - }); - errors = errors.concat(oneof_errors); - } - } - - // `not` - if(schema.not) { - if(!this._validateSchema(schema.not,value,path).length) { - errors.push({ - path: path, - property: 'not', - message: this.translate('error_not') - }); - } - } - - // `type` (both Version 3 and Version 4 support) - if(schema.type) { - // Union type - if(Array.isArray(schema.type)) { - valid = false; - for(i=0;i<schema.type.length;i++) { - if(this._checkType(schema.type[i], value)) { - valid = true; - break; - } - } - if(!valid) { - errors.push({ - path: path, - property: 'type', - message: this.translate('error_type_union') - }); - } - } - // Simple type - else { - if(!this._checkType(schema.type, value)) { - errors.push({ - path: path, - property: 'type', - message: this.translate('error_type', [schema.type]) - }); - } - } - } - - - // `disallow` (version 3) - if(schema.disallow) { - // Union type - if(Array.isArray(schema.disallow)) { - valid = true; - for(i=0;i<schema.disallow.length;i++) { - if(this._checkType(schema.disallow[i], value)) { - valid = false; - break; - } - } - if(!valid) { - errors.push({ - path: path, - property: 'disallow', - message: this.translate('error_disallow_union') - }); - } - } - // Simple type - else { - if(this._checkType(schema.disallow, value)) { - errors.push({ - path: path, - property: 'disallow', - message: this.translate('error_disallow', [schema.disallow]) - }); - } - } - } - - /* - * Type Specific Validation - */ - - // Number Specific Validation - if(typeof value === "number") { - // `multipleOf` and `divisibleBy` - if(schema.multipleOf || schema.divisibleBy) { - var divisor = schema.multipleOf || schema.divisibleBy; - // Vanilla JS, prone to floating point rounding errors (e.g. 1.14 / .01 == 113.99999) - valid = (value/divisor === Math.floor(value/divisor)); - - // Use math.js is available - if(window.math) { - valid = window.math.mod(window.math.bignumber(value), window.math.bignumber(divisor)).equals(0); - } - // Use decimal.js is available - else if(window.Decimal) { - valid = (new window.Decimal(value)).mod(new window.Decimal(divisor)).equals(0); - } - - if(!valid) { - errors.push({ - path: path, - property: schema.multipleOf? 'multipleOf' : 'divisibleBy', - message: this.translate('error_multipleOf', [divisor]) - }); - } - } - - // `maximum` - if(schema.hasOwnProperty('maximum')) { - // Vanilla JS, prone to floating point rounding errors (e.g. .999999999999999 == 1) - valid = schema.exclusiveMaximum? (value < schema.maximum) : (value <= schema.maximum); - - // Use math.js is available - if(window.math) { - valid = window.math[schema.exclusiveMaximum?'smaller':'smallerEq']( - window.math.bignumber(value), - window.math.bignumber(schema.maximum) - ); - } - // Use Decimal.js if available - else if(window.Decimal) { - valid = (new window.Decimal(value))[schema.exclusiveMaximum?'lt':'lte'](new window.Decimal(schema.maximum)); - } - - if(!valid) { - errors.push({ - path: path, - property: 'maximum', - message: this.translate( - (schema.exclusiveMaximum?'error_maximum_excl':'error_maximum_incl'), - [schema.title ? schema.title : path.split('-').pop().trim(), schema.maximum] - ) - }); - } - } - - // `minimum` - if(schema.hasOwnProperty('minimum')) { - // Vanilla JS, prone to floating point rounding errors (e.g. .999999999999999 == 1) - valid = schema.exclusiveMinimum? (value > schema.minimum) : (value >= schema.minimum); - - // Use math.js is available - if(window.math) { - valid = window.math[schema.exclusiveMinimum?'larger':'largerEq']( - window.math.bignumber(value), - window.math.bignumber(schema.minimum) - ); - } - // Use Decimal.js if available - else if(window.Decimal) { - valid = (new window.Decimal(value))[schema.exclusiveMinimum?'gt':'gte'](new window.Decimal(schema.minimum)); - } - - if(!valid) { - errors.push({ - path: path, - property: 'minimum', - message: this.translate( - (schema.exclusiveMinimum?'error_minimum_excl':'error_minimum_incl'), - [schema.title ? schema.title : path.split('-').pop().trim(), schema.minimum] - ) - }); - } - } - } - // String specific validation - else if(typeof value === "string") { - // `maxLength` - if(schema.maxLength) { - if((value+"").length > schema.maxLength) { - errors.push({ - path: path, - property: 'maxLength', - message: this.translate('error_maxLength', - [schema.title ? schema.title : path.split('-').pop().trim(), schema.maxLength]) - }); - } - } - - // `minLength` -- Commented because we are validating required field. - if(schema.minLength) { - if((value+"").length < schema.minLength) { - errors.push({ - path: path, - property: 'minLength', - message: this.translate((schema.minLength===1?'error_notempty':'error_minLength'), - [schema.title ? schema.title : path.split('-').pop().trim(), schema.minLength]) - }); - } - } - - // `pattern` - if(schema.pattern) { - if(!(new RegExp(schema.pattern)).test(value)) { - errors.push({ - path: path, - property: 'pattern', - message: this.translate('error_pattern', - [schema.title ? schema.title : path.split('-').pop().trim(), schema.pattern]) - }); - } - } - } - // Array specific validation - else if(typeof value === "object" && value !== null && Array.isArray(value)) { - // `items` and `additionalItems` - if(schema.items) { - // `items` is an array - if(Array.isArray(schema.items)) { - for(i=0; i<value.length; i++) { - // If this item has a specific schema tied to it - // Validate against it - if(schema.items[i]) { - errors = errors.concat(this._validateSchema(schema.items[i],value[i],path+'.'+i)); - } - // If all additional items are allowed - else if(schema.additionalItems === true) { - break; - } - // If additional items is a schema - // TODO: Incompatibility between version 3 and 4 of the spec - else if(schema.additionalItems) { - errors = errors.concat(this._validateSchema(schema.additionalItems,value[i],path+'.'+i)); - } - // If no additional items are allowed - else if(schema.additionalItems === false) { - errors.push({ - path: path, - property: 'additionalItems', - message: this.translate('error_additionalItems') - }); - break; - } - // Default for `additionalItems` is an empty schema - else { - break; - } - } - } - // `items` is a schema - else { - // Each item in the array must validate against the schema - for(i=0; i<value.length; i++) { - errors = errors.concat(this._validateSchema(schema.items,value[i],path+'.'+i)); - } - } - } - - // `maxItems` - if(schema.maxItems) { - if(value.length > schema.maxItems) { - errors.push({ - path: path, - property: 'maxItems', - message: this.translate('error_maxItems', [schema.maxItems]) - }); - } - } - - // `minItems` - if(schema.minItems) { - if(value.length < schema.minItems) { - errors.push({ - path: path, - property: 'minItems', - message: this.translate('error_minItems', [schema.minItems]) - }); - } - } - - // `uniqueItems` - if(schema.uniqueItems) { - var seen = {}; - for(i=0; i<value.length; i++) { - valid = JSON.stringify(value[i]); - if(seen[valid]) { - errors.push({ - path: path, - property: 'uniqueItems', - message: this.translate('error_uniqueItems', - [schema.title ? schema.title : path.split('-').pop().trim()]) - }); - break; - } - seen[valid] = true; - } - } - } - // Object specific validation - else if(typeof value === "object" && value !== null) { - // `maxProperties` - if(schema.maxProperties) { - valid = 0; - for(i in value) { - if(!value.hasOwnProperty(i)) continue; - valid++; - } - if(valid > schema.maxProperties) { - errors.push({ - path: path, - property: 'maxProperties', - message: this.translate('error_maxProperties', [schema.maxProperties]) - }); - } - } - - // `minProperties` - if(schema.minProperties) { - valid = 0; - for(i in value) { - if(!value.hasOwnProperty(i)) continue; - valid++; - } - if(valid < schema.minProperties) { - errors.push({ - path: path, - property: 'minProperties', - message: this.translate('error_minProperties', [schema.minProperties]) - }); - } - } - - // Version 4 `required` - if(typeof schema.required !== "undefined" && Array.isArray(schema.required)) { - for(i=0; i<schema.required.length; i++) { - // Arrays are the only missing "required" thing we report in the "object" - // level control group error message area; all others appear in their own form control - // control message area. - if((typeof value[schema.required[i]] === "undefined") || - (Array.isArray(value[schema.required[i]]) && value[schema.required[i]].length == 0)) { - var parm_name; - if(typeof schema.properties[schema.required[i]].title !== "undefined") { - parm_name = schema.properties[schema.required[i]].title; - } - else { - parm_name = schema.required[i]; - } - errors.push({ - path: path, - property: 'required', - message: this.translate('error_required', [parm_name]) - }); - } - } - } - - // `properties` - var validated_properties = {}; - if(schema.properties) { - if(typeof schema.required !== "undefined" && Array.isArray(schema.required)) { - for(i=0; i<schema.required.length; i++) { - var property = schema.required[i]; - validated_properties[property] = true; - errors = errors.concat(this._validateSchema(schema.properties[property],value[property],path+'.'+property)); - } - } - - // If an optional property is not an object and is not empty, we must run validation - // on it as the user may have entered some data into it. - - for(i in schema.properties) { - if(!schema.properties.hasOwnProperty(i) || validated_properties[i] === true) continue; - if((typeof value[i] !== "object" && typeof value[i] !== "undefined" && value[i] !== null) || - (schema.properties[i].type === "array" && Array.isArray(value[i]) && value[i].length > 0)) { - - errors = errors.concat(this._validateSchema(schema.properties[i],value[i],path+'.'+i)); - } - validated_properties[i] = true; - } - } - - // `patternProperties` - if(schema.patternProperties) { - for(i in schema.patternProperties) { - if(!schema.patternProperties.hasOwnProperty(i)) continue; - var regex = new RegExp(i); - - // Check which properties match - for(j in value) { - if(!value.hasOwnProperty(j)) continue; - if(regex.test(j)) { - validated_properties[j] = true; - errors = errors.concat(this._validateSchema(schema.patternProperties[i],value[j],path+'.'+j)); - } - } - } - } - - // The no_additional_properties option currently doesn't work with extended schemas that use oneOf or anyOf - if(typeof schema.additionalProperties === "undefined" && this.jsoneditor.options.no_additional_properties && !schema.oneOf && !schema.anyOf) { - schema.additionalProperties = false; - } - - // `additionalProperties` - if(typeof schema.additionalProperties !== "undefined") { - for(i in value) { - if(!value.hasOwnProperty(i)) continue; - if(!validated_properties[i]) { - // No extra properties allowed - if(!schema.additionalProperties) { - errors.push({ - path: path, - property: 'additionalProperties', - message: this.translate('error_additional_properties', [i]) - }); - break; - } - // Allowed - else if(schema.additionalProperties === true) { - break; - } - // Must match schema - // TODO: incompatibility between version 3 and 4 of the spec - else { - errors = errors.concat(this._validateSchema(schema.additionalProperties,value[i],path+'.'+i)); - } - } - } - } - - // `dependencies` - if(schema.dependencies) { - for(i in schema.dependencies) { - if(!schema.dependencies.hasOwnProperty(i)) continue; - - // Doesn't need to meet the dependency - if(typeof value[i] === "undefined") continue; - - // Property dependency - if(Array.isArray(schema.dependencies[i])) { - for(j=0; j<schema.dependencies[i].length; j++) { - if(typeof value[schema.dependencies[i][j]] === "undefined") { - errors.push({ - path: path, - property: 'dependencies', - message: this.translate('error_dependency', [schema.dependencies[i][j]]) - }); - } - } - } - // Schema dependency - else { - errors = errors.concat(this._validateSchema(schema.dependencies[i],value,path)); - } - } - } - } - - // Custom type validation (global) - $each(JSONEditor.defaults.custom_validators,function(i,validator) { - errors = errors.concat(validator.call(self,schema,value,path)); - }); - // Custom type validation (instance specific) - if(this.options.custom_validators) { - $each(this.options.custom_validators,function(i,validator) { - errors = errors.concat(validator.call(self,schema,value,path)); - }); - } - - return errors; - }, - _checkType: function(type, value) { - // Simple types - if(typeof type === "string") { - if(type==="string") return typeof value === "string"; - else if(type==="number") return typeof value === "number"; - else if(type==="qbldr") return typeof value === "string"; - else if(type==="integer") return typeof value === "number" && value === Math.floor(value); - else if(type==="boolean") return typeof value === "boolean"; - else if(type==="array") return Array.isArray(value); - else if(type === "object") return value !== null && !(Array.isArray(value)) && typeof value === "object"; - else if(type === "null") return value === null; - else return true; - } - // Schema - else { - return !this._validateSchema(type,value).length; - } - } -}); - -/** - * All editors should extend from this class - */ -JSONEditor.AbstractEditor = Class.extend({ - onChildEditorChange: function(editor) { - this.onChange(true); - }, - notify: function() { - if(this.path) this.jsoneditor.notifyWatchers(this.path); - }, - change: function() { - if(this.parent) this.parent.onChildEditorChange(this); - else if(this.jsoneditor) this.jsoneditor.onChange(); - }, - onChange: function(bubble) { - this.notify(); - if(this.watch_listener) this.watch_listener(); - if(bubble) this.change(); - }, - register: function() { - this.jsoneditor.registerEditor(this); - this.onChange(); - }, - unregister: function() { - if(!this.jsoneditor) return; - this.jsoneditor.unregisterEditor(this); - }, - getNumColumns: function() { - return 12; - }, - init: function(options) { - this.jsoneditor = options.jsoneditor; - - this.theme = this.jsoneditor.theme; - this.template_engine = this.jsoneditor.template; - this.iconlib = this.jsoneditor.iconlib; - - this.translate = this.jsoneditor.translate || JSONEditor.defaults.translate; - - this.original_schema = options.schema; - this.schema = this.jsoneditor.expandSchema(this.original_schema); - - this.options = $extend({}, (this.options || {}), (this.schema.options || {}), (options.schema.options || {}), options); - - if(!options.path && !this.schema.id) this.schema.id = 'root'; - this.path = options.path || 'root'; - this.formname = options.formname || this.path.replace(/\.([^.]+)/g,'[$1]'); - if(this.jsoneditor.options.form_name_root) this.formname = this.formname.replace(/^root\[/,this.jsoneditor.options.form_name_root+'['); - this.key = this.path.split('.').pop(); - this.parent = options.parent; - - this.link_watchers = []; - - if(options.container) this.setContainer(options.container); - this.registerDependencies(); - }, - registerDependencies: function() { - this.dependenciesFulfilled = true; - var deps = this.options.dependencies; - if (!deps) { - return; - } - - var self = this; - Object.keys(deps).forEach(function(dependency) { - var path = self.path.split('.'); - path[path.length - 1] = dependency; - path = path.join('.'); - var choices = deps[dependency]; - self.jsoneditor.watch(path, function() { - self.checkDependency(path, choices); - }); - }); - }, - checkDependency: function(path, choices) { - var wrapper = this.control || this.container; - if (this.path === path || !wrapper) { - return; - } - - var self = this; - var editor = this.jsoneditor.getEditor(path); - var value = editor ? editor.getValue() : undefined; - var previousStatus = this.dependenciesFulfilled; - this.dependenciesFulfilled = false; - - if (!editor || !editor.dependenciesFulfilled) { - this.dependenciesFulfilled = false; - } else if (Array.isArray(choices)) { - choices.some(function(choice) { - if (value === choice) { - self.dependenciesFulfilled = true; - return true; - } - }); - } else if (typeof choices === 'object') { - if (typeof value !== 'object') { - this.dependenciesFulfilled = choices === value; - } else { - Object.keys(choices).some(function(key) { - if (!choices.hasOwnProperty(key)) { - return false; - } - if (!value.hasOwnProperty(key) || choices[key] !== value[key]) { - self.dependenciesFulfilled = false; - return true; - } - self.dependenciesFulfilled = true; - }); - } - } else if (typeof choices === 'string' || typeof choices === 'number') { - this.dependenciesFulfilled = value === choices; - } else if (typeof choices === 'boolean') { - if (choices) { - this.dependenciesFulfilled = value && value.length > 0; - } else { - this.dependenciesFulfilled = !value || value.length === 0; - } - } - - if (this.dependenciesFulfilled !== previousStatus) { - this.notify(); - } - - if (this.dependenciesFulfilled) { - wrapper.style.display = 'block'; - } else { - wrapper.style.display = 'none'; - } - }, - setContainer: function(container) { - this.container = container; - if(this.schema.id) this.container.setAttribute('data-schemaid',this.schema.id); - if(this.schema.type && typeof this.schema.type === "string") this.container.setAttribute('data-schematype',this.schema.type); - this.container.setAttribute('data-schemapath',this.path); - this.container.style.padding = '4px'; - }, - - preBuild: function() { - - }, - build: function() { - - }, - postBuild: function() { - this.setupWatchListeners(); - this.addLinks(); - this.setValue(this.getDefault(), true); - this.updateHeaderText(); - this.register(); - this.onWatchedFieldChange(); - }, - - setupWatchListeners: function() { - var self = this; - - // Watched fields - this.watched = {}; - if(this.schema.vars) this.schema.watch = this.schema.vars; - this.watched_values = {}; - this.watch_listener = function() { - if(self.refreshWatchedFieldValues()) { - self.onWatchedFieldChange(); - } - }; - - if(this.schema.hasOwnProperty('watch')) { - var path,path_parts,first,root,adjusted_path; - - for(var name in this.schema.watch) { - if(!this.schema.watch.hasOwnProperty(name)) continue; - path = this.schema.watch[name]; - - if(Array.isArray(path)) { - if(path.length<2) continue; - path_parts = [path[0]].concat(path[1].split('.')); - } - else { - path_parts = path.split('.'); - if(!self.theme.closest(self.container,'[data-schemaid="'+path_parts[0]+'"]')) path_parts.unshift('#'); - } - first = path_parts.shift(); - - if(first === '#') first = self.jsoneditor.schema.id || 'root'; - - // Find the root node for this template variable - root = self.theme.closest(self.container,'[data-schemaid="'+first+'"]'); - if(!root) throw "Could not find ancestor node with id "+first; - - // Keep track of the root node and path for use when rendering the template - adjusted_path = root.getAttribute('data-schemapath') + '.' + path_parts.join('.'); - - self.jsoneditor.watch(adjusted_path,self.watch_listener); - - self.watched[name] = adjusted_path; - } - } - - // Dynamic header - if(this.schema.headerTemplate) { - this.header_template = this.jsoneditor.compileTemplate(this.schema.headerTemplate, this.template_engine); - } - }, - - addLinks: function() { - // Add links - if(!this.no_link_holder) { - this.link_holder = this.theme.getLinksHolder(); - this.container.appendChild(this.link_holder); - if(this.schema.links) { - for(var i=0; i<this.schema.links.length; i++) { - this.addLink(this.getLink(this.schema.links[i])); - } - } - } - }, - - - getButton: function(text, icon, title) { - var btnClass = 'json-editor-btn-'+icon; - if(!this.iconlib) icon = null; - else icon = this.iconlib.getIcon(icon); - - if(!icon && title) { - text = title; - title = null; - } - - var btn = this.theme.getButton(text, icon, title); - btn.className += ' ' + btnClass + ' '; - return btn; - }, - setButtonText: function(button, text, icon, title) { - if(!this.iconlib) icon = null; - else icon = this.iconlib.getIcon(icon); - - if(!icon && title) { - text = title; - title = null; - } - - return this.theme.setButtonText(button, text, icon, title); - }, - addLink: function(link) { - if(this.link_holder) this.link_holder.appendChild(link); - }, - getLink: function(data) { - var holder, link; - - // Get mime type of the link - var mime = data.mediaType || 'application/javascript'; - var type = mime.split('/')[0]; - - // Template to generate the link href - var href = this.jsoneditor.compileTemplate(data.href,this.template_engine); - var relTemplate = this.jsoneditor.compileTemplate(data.rel ? data.rel : data.href,this.template_engine); - - // Template to generate the link's download attribute - var download = null; - if(data.download) download = data.download; - - if(download && download !== true) { - download = this.jsoneditor.compileTemplate(download, this.template_engine); - } - - // Image links - if(type === 'image') { - holder = this.theme.getBlockLinkHolder(); - link = document.createElement('a'); - link.setAttribute('target','_blank'); - var image = document.createElement('img'); - - this.theme.createImageLink(holder,link,image); - - // When a watched field changes, update the url - this.link_watchers.push(function(vars) { - var url = href(vars); - var rel = relTemplate(vars); - link.setAttribute('href',url); - link.setAttribute('title',rel || url); - image.setAttribute('src',url); - }); - } - // Audio/Video links - else if(['audio','video'].indexOf(type) >=0) { - holder = this.theme.getBlockLinkHolder(); - - link = this.theme.getBlockLink(); - link.setAttribute('target','_blank'); - - var media = document.createElement(type); - media.setAttribute('controls','controls'); - - this.theme.createMediaLink(holder,link,media); - - // When a watched field changes, update the url - this.link_watchers.push(function(vars) { - var url = href(vars); - var rel = relTemplate(vars); - link.setAttribute('href',url); - link.textContent = rel || url; - media.setAttribute('src',url); - }); - } - // Text links - else { - link = holder = this.theme.getBlockLink(); - holder.setAttribute('target','_blank'); - holder.textContent = data.rel; - - // When a watched field changes, update the url - this.link_watchers.push(function(vars) { - var url = href(vars); - var rel = relTemplate(vars); - holder.setAttribute('href',url); - holder.textContent = rel || url; - }); - } - - if(download && link) { - if(download === true) { - link.setAttribute('download',''); - } - else { - this.link_watchers.push(function(vars) { - link.setAttribute('download',download(vars)); - }); - } - } - - if(data.class) link.className = link.className + ' ' + data.class; - - return holder; - }, - refreshWatchedFieldValues: function() { - if(!this.watched_values) return; - var watched = {}; - var changed = false; - var self = this; - - if(this.watched) { - var val,editor; - for(var name in this.watched) { - if(!this.watched.hasOwnProperty(name)) continue; - editor = self.jsoneditor.getEditor(this.watched[name]); - val = editor? editor.getValue() : null; - if(self.watched_values[name] !== val) changed = true; - watched[name] = val; - } - } - - watched.self = this.getValue(); - if(this.watched_values.self !== watched.self) changed = true; - - this.watched_values = watched; - - return changed; - }, - getWatchedFieldValues: function() { - return this.watched_values; - }, - updateHeaderText: function() { - if(this.header) { - // If the header has children, only update the text node's value - if(this.header.children.length) { - for(var i=0; i<this.header.childNodes.length; i++) { - if(this.header.childNodes[i].nodeType===3) { - this.header.childNodes[i].nodeValue = this.getHeaderText(); - break; - } - } - } - // Otherwise, just update the entire node - else { - this.header.textContent = this.getHeaderText(); - } - } - }, - getHeaderText: function(title_only) { - if(this.header_text) return this.header_text; - else if(title_only) return this.schema.title; - else return this.getTitle(); - }, - onWatchedFieldChange: function() { - var vars; - if(this.header_template) { - vars = $extend(this.getWatchedFieldValues(),{ - key: this.key, - i: this.key, - i0: (this.key*1), - i1: (this.key*1+1), - title: this.getTitle() - }); - var header_text = this.header_template(vars); - - if(header_text !== this.header_text) { - this.header_text = header_text; - this.updateHeaderText(); - this.notify(); - //this.fireChangeHeaderEvent(); - } - } - if(this.link_watchers.length) { - vars = this.getWatchedFieldValues(); - for(var i=0; i<this.link_watchers.length; i++) { - this.link_watchers[i](vars); - } - } - }, - setValue: function(value) { - this.value = value; - }, - getValue: function() { - if (!this.dependenciesFulfilled) { - return undefined; - } - return this.value; - }, - refreshValue: function() { - - }, - getChildEditors: function() { - return false; - }, - destroy: function() { - var self = this; - this.unregister(this); - $each(this.watched,function(name,adjusted_path) { - self.jsoneditor.unwatch(adjusted_path,self.watch_listener); - }); - this.watched = null; - this.watched_values = null; - this.watch_listener = null; - this.header_text = null; - this.header_template = null; - this.value = null; - if(this.container && this.container.parentNode) this.container.parentNode.removeChild(this.container); - this.container = null; - this.jsoneditor = null; - this.schema = null; - this.path = null; - this.key = null; - this.parent = null; - }, - getDefault: function() { - if (typeof this.schema["default"] !== 'undefined') { - return this.schema["default"]; - } - - if (typeof this.schema["enum"] !== 'undefined') { - return this.schema["enum"][0]; - } - - var type = this.schema.type || this.schema.oneOf; - if(type && Array.isArray(type)) type = type[0]; - if(type && typeof type === "object") type = type.type; - if(type && Array.isArray(type)) type = type[0]; - - if(typeof type === "string") { - if(type === "number") return 0.0; - if(type === "boolean") return false; - if(type === "integer") return 0; - if(type === "string") return ""; - if(type === "object") return {}; - if(type === "array") return []; - } - - return null; - }, - getTitle: function() { - return this.schema.title || this.key; - }, - enable: function() { - this.disabled = false; - }, - disable: function() { - this.disabled = true; - }, - isEnabled: function() { - return !this.disabled; - }, - isRequired: function() { - if(typeof this.schema.required === "boolean") return this.schema.required; - else if(this.parent && this.parent.schema && Array.isArray(this.parent.schema.required)) return this.parent.schema.required.indexOf(this.key) > -1; - else if(this.jsoneditor.options.required_by_default) return true; - else return false; - }, - getDisplayText: function(arr) { - var disp = []; - var used = {}; - - // Determine how many times each attribute name is used. - // This helps us pick the most distinct display text for the schemas. - $each(arr,function(i,el) { - if(el.title) { - used[el.title] = used[el.title] || 0; - used[el.title]++; - } - if(el.description) { - used[el.description] = used[el.description] || 0; - used[el.description]++; - } - if(el.format) { - used[el.format] = used[el.format] || 0; - used[el.format]++; - } - if(el.type) { - used[el.type] = used[el.type] || 0; - used[el.type]++; - } - }); - - // Determine display text for each element of the array - $each(arr,function(i,el) { - var name; - - // If it's a simple string - if(typeof el === "string") name = el; - // Object - else if(el.title && used[el.title]<=1) name = el.title; - else if(el.format && used[el.format]<=1) name = el.format; - else if(el.type && used[el.type]<=1) name = el.type; - else if(el.description && used[el.description]<=1) name = el.descripton; - else if(el.title) name = el.title; - else if(el.format) name = el.format; - else if(el.type) name = el.type; - else if(el.description) name = el.description; - else if(JSON.stringify(el).length < 50) name = JSON.stringify(el); - else name = "type"; - - disp.push(name); - }); - - // Replace identical display text with "text 1", "text 2", etc. - var inc = {}; - $each(disp,function(i,name) { - inc[name] = inc[name] || 0; - inc[name]++; - - if(used[name] > 1) disp[i] = name + " " + inc[name]; - }); - - return disp; - }, - getOption: function(key) { - try { - throw "getOption is deprecated"; - } - catch(e) { - window.console.error(e); - } - - return this.options[key]; - }, - showValidationErrors: function(errors) { - - } -}); - -JSONEditor.defaults.editors["null"] = JSONEditor.AbstractEditor.extend({ - getValue: function() { - if (!this.dependenciesFulfilled) { - return undefined; - } - return null; - }, - setValue: function() { - this.onChange(); - }, - getNumColumns: function() { - return 2; - } -}); - -JSONEditor.defaults.editors.qbldr = JSONEditor.AbstractEditor.extend({ - register: function() { - this._super(); - if(!this.input) return; - this.input.setAttribute('name',this.formname); - }, - unregister: function() { - this._super(); - if(!this.input) return; - this.input.removeAttribute('name'); - }, - setValue: function(value, initial) { - var self = this; - - if(typeof value === "undefined" || typeof this.jqbldrId === "undefined" || value === this.value) { - return; - } - - if ((initial === true) && (value !== "") && (value !== null)) { - $(this.jqbldrId).queryBuilder('off','rulesChanged'); - $(this.jqbldrId).queryBuilder('setRulesFromSQL', value); - var filter_result = $(this.jqbldrId).queryBuilder('getSQL'); - value = filter_result === null ? null : filter_result.sql; - $(this.jqbldrId).queryBuilder('on', 'rulesChanged', this.qbldrRulesChangedCb.bind(this)); - } - - this.input.value = value; - this.value = value; - - // Bubble this setValue to parents if the value changed - this.onChange(true); - }, - getValue: function() { - var self = this; - - if (this.value === "" || this.value === null) { - return undefined; - } else { - return this.value; - } - }, - - getNumColumns: function() { - return 12; - }, - - qbldrRulesChangedCb: function(eventObj) { - var self = this; - - $(this.jqbldrId).queryBuilder('off','rulesChanged'); - - var filter_result = $(this.jqbldrId).queryBuilder('getSQL'); - - if (filter_result !== null) { - this.setValue(filter_result.sql); - } - - $(this.jqbldrId).queryBuilder('on', 'rulesChanged', this.qbldrRulesChangedCb.bind(this)); - - return; - }, - preBuild: function() { - var self = this; - this._super(); - }, - build: function() { - var self = this; - - this.qschema = this.schema.qschema; - this.qbldrId = this.path; - this.jqbldrId = '#' + this.qbldrId; - this.jqbldrId = this.jqbldrId.replace(/\./g,'\\.'); - - this.qgrid = this.theme.getGridContainer(); - this.qgrid.style.padding = '4px'; - this.qgrid.style.border = '1px solid #e3e3e3'; - - this.gridrow1 = this.theme.getGridRow(); - this.gridrow1.style.padding = '4px'; - - this.gridrow2 = this.theme.getGridRow(); - this.gridrow2.style.padding = '4px'; - - this.title = this.getTitle(); - this.label = this.theme.getFormInputLabel(this.title); - - this.input = this.theme.getTextareaInput(); - this.input.disabled = 'true'; - - this.control = this.theme.getFormControl(this.label, this.input, this.description); - - this.gridrow2.setAttribute('id',this.qbldrId); - - this.container.appendChild(this.qgrid); // attach the grid to container - - this.qgrid.appendChild(this.gridrow1); // attach gridrow1 to grid - this.gridrow1.appendChild(this.control); // attach control form to gridrow1 - - this.qgrid.appendChild(this.gridrow2); - - var options = { conditions: [ 'AND', 'OR'], sort_filters: true }; - - $.extend(this.qschema, options); - - $(this.jqbldrId).queryBuilder(this.qschema); - - //$(this.jqbldrId).queryBuilder('on', 'rulesChanged', this.qbldrRulesChangedCb.bind(this)); - //$(this.jqbldrId).queryBuilder('on', 'afterUpdateRuleValue', this.qbldrRulesChangedCb.bind(this)); - $(this.jqbldrId).queryBuilder('on', 'rulesChanged', this.qbldrRulesChangedCb.bind(this)); - }, - enable: function() { - this._super(); - }, - disable: function() { - this._super(); - }, - afterInputReady: function() { - var self = this, options; - self.theme.afterInputReady(self.input); - }, - refreshValue: function() { - this.value = this.input.value; - if(typeof this.value !== "string") this.value = ''; - }, - destroy: function() { - var self = this; - this._super(); - }, - /** - * This is overridden in derivative editors - */ - sanitize: function(value) { - return value; - }, - /** - * Re-calculates the value if needed - */ - onWatchedFieldChange: function() { - var self = this, vars, j; - - this._super(); - }, - showValidationErrors: function(errors) { - var self = this; - - if(this.jsoneditor.options.show_errors === "always") {} - else if(this.previous_error_setting===this.jsoneditor.options.show_errors) return; - - this.previous_error_setting = this.jsoneditor.options.show_errors; - - var messages = []; - $each(errors,function(i,error) { - if(error.path === self.path) { - messages.push(error.message); - } - }); - - this.input.controlgroup = this.control; - - if(messages.length) { - this.theme.addInputError(this.input, messages.join('. ')+'.'); - } - else { - this.theme.removeInputError(this.input); - } - } -}); - -JSONEditor.defaults.editors.string = JSONEditor.AbstractEditor.extend({ - register: function() { - this._super(); - if(!this.input) return; - this.input.setAttribute('name',this.formname); - }, - unregister: function() { - this._super(); - if(!this.input) return; - this.input.removeAttribute('name'); - }, - setValue: function(value,initial,from_template) { - var self = this; - - if(this.template && !from_template) { - return; - } - - if(value === null || typeof value === 'undefined') value = ""; - else if(typeof value === "object") value = JSON.stringify(value); - else if(typeof value !== "string") value = ""+value; - - if(value === this.serialized) return; - - // Sanitize value before setting it - var sanitized = this.sanitize(value); - - if(this.input.value === sanitized) { - return; - } - - this.input.value = sanitized; - - // If using SCEditor, update the WYSIWYG - if(this.sceditor_instance) { - this.sceditor_instance.val(sanitized); - } - else if(this.SimpleMDE) { - this.SimpleMDE.value(sanitized); - } - else if(this.ace_editor) { - this.ace_editor.setValue(sanitized); - } - - var changed = from_template || this.getValue() !== value; - - this.refreshValue(); - - if(initial) this.is_dirty = false; - else if(this.jsoneditor.options.show_errors === "change") this.is_dirty = true; - - if(this.adjust_height) this.adjust_height(this.input); - - // Bubble this setValue to parents if the value changed - this.onChange(changed); - }, - getNumColumns: function() { - var min = Math.ceil(Math.max(this.getTitle().length,this.schema.maxLength||0,this.schema.minLength||0)/5); - var num; - - if(this.input_type === 'textarea') num = 6; - else if(['text','email'].indexOf(this.input_type) >= 0) num = 4; - else num = 2; - - return Math.min(12,Math.max(min,num)); - }, - build: function() { - var self = this, i; - if(!this.options.compact) this.header = this.label = this.theme.getFormInputLabel(this.getTitle()); - if(this.schema.description) this.description = this.theme.getFormInputDescription(this.schema.description); - if(this.options.infoText) this.infoButton = this.theme.getInfoButton(this.options.infoText); - - this.format = this.schema.format; - if(!this.format && this.schema.media && this.schema.media.type) { - this.format = this.schema.media.type.replace(/(^(application|text)\/(x-)?(script\.)?)|(-source$)/g,''); - } - if(!this.format && this.options.default_format) { - this.format = this.options.default_format; - } - if(this.options.format) { - this.format = this.options.format; - } - - // Specific format - if(this.format) { - // Text Area - if(this.format === 'textarea') { - this.input_type = 'textarea'; - this.input = this.theme.getTextareaInput(); - } - // Range Input - else if(this.format === 'range') { - this.input_type = 'range'; - var min = this.schema.minimum || 0; - var max = this.schema.maximum || Math.max(100,min+1); - var step = 1; - if(this.schema.multipleOf) { - if(min%this.schema.multipleOf) min = Math.ceil(min/this.schema.multipleOf)*this.schema.multipleOf; - if(max%this.schema.multipleOf) max = Math.floor(max/this.schema.multipleOf)*this.schema.multipleOf; - step = this.schema.multipleOf; - } - - this.input = this.theme.getRangeInput(min,max,step); - } - // Source Code - else if([ - 'actionscript', - 'batchfile', - 'bbcode', - 'c', - 'c++', - 'cpp', - 'coffee', - 'csharp', - 'css', - 'dart', - 'django', - 'ejs', - 'erlang', - 'golang', - 'groovy', - 'handlebars', - 'haskell', - 'haxe', - 'html', - 'ini', - 'jade', - 'java', - 'javascript', - 'json', - 'less', - 'lisp', - 'lua', - 'makefile', - 'markdown', - 'matlab', - 'mysql', - 'objectivec', - 'pascal', - 'perl', - 'pgsql', - 'php', - 'python', - 'r', - 'ruby', - 'sass', - 'scala', - 'scss', - 'smarty', - 'sql', - 'stylus', - 'svg', - 'twig', - 'vbscript', - 'xml', - 'yaml' - ].indexOf(this.format) >= 0 - ) { - this.input_type = this.format; - this.source_code = true; - - this.input = this.theme.getTextareaInput(); - } - // HTML5 Input type - else { - this.input_type = this.format; - this.input = this.theme.getFormInputField(this.input_type); - } - } - // Normal text input - else { - this.input_type = 'text'; - this.input = this.theme.getFormInputField(this.input_type); - } - - // minLength, maxLength, and pattern - if(typeof this.schema.maxLength !== "undefined") this.input.setAttribute('maxlength',this.schema.maxLength); - if(typeof this.schema.pattern !== "undefined") this.input.setAttribute('pattern',this.schema.pattern); - else if(typeof this.schema.minLength !== "undefined") this.input.setAttribute('pattern','.{'+this.schema.minLength+',}'); - - if(this.options.compact) { - this.container.className += ' compact'; - } - else { - if(this.options.input_width) this.input.style.width = this.options.input_width; - } - - if(this.schema.readOnly || this.schema.readonly || this.schema.template) { - this.always_disabled = true; - this.input.disabled = true; - } - - this.input - .addEventListener('change',function(e) { - e.preventDefault(); - e.stopPropagation(); - - // Don't allow changing if this field is a template - if(self.schema.template) { - this.value = self.value; - return; - } - - var val = this.value; - - // sanitize value - var sanitized = self.sanitize(val); - if(val !== sanitized) { - this.value = sanitized; - } - - self.is_dirty = true; - - self.refreshValue(); - self.onChange(true); - }); - - if(this.options.input_height) this.input.style.height = this.options.input_height; - if(this.options.expand_height) { - this.adjust_height = function(el) { - if(!el) return; - var i, ch=el.offsetHeight; - // Input too short - if(el.offsetHeight < el.scrollHeight) { - i=0; - while(el.offsetHeight < el.scrollHeight+3) { - if(i>100) break; - i++; - ch++; - el.style.height = ch+'px'; - } - } - else { - i=0; - while(el.offsetHeight >= el.scrollHeight+3) { - if(i>100) break; - i++; - ch--; - el.style.height = ch+'px'; - } - el.style.height = (ch+1)+'px'; - } - }; - - this.input.addEventListener('keyup',function(e) { - self.adjust_height(this); - }); - this.input.addEventListener('change',function(e) { - self.adjust_height(this); - }); - this.adjust_height(); - } - - if(this.format) this.input.setAttribute('data-schemaformat',this.format); - - this.control = this.theme.getFormControl(this.label, this.input, this.description, this.infoButton); - this.container.appendChild(this.control); - - // Any special formatting that needs to happen after the input is added to the dom - window.requestAnimationFrame(function() { - // Skip in case the input is only a temporary editor, - // otherwise, in the case of an ace_editor creation, - // it will generate an error trying to append it to the missing parentNode - if(self.input.parentNode) self.afterInputReady(); - if(self.adjust_height) self.adjust_height(self.input); - }); - - // Compile and store the template - if(this.schema.template) { - this.template = this.jsoneditor.compileTemplate(this.schema.template, this.template_engine); - this.refreshValue(); - } - else { - this.refreshValue(); - } - }, - enable: function() { - if(!this.always_disabled) { - this.input.disabled = false; - // TODO: WYSIWYG and Markdown editors - this._super(); - } - }, - disable: function(always_disabled) { - if(always_disabled) this.always_disabled = true; - this.input.disabled = true; - // TODO: WYSIWYG and Markdown editors - this._super(); - }, - afterInputReady: function() { - var self = this, options; - - // Code editor - if(this.source_code) { - // WYSIWYG html and bbcode editor - if(this.options.wysiwyg && - ['html','bbcode'].indexOf(this.input_type) >= 0 && - window.jQuery && window.jQuery.fn && window.jQuery.fn.sceditor - ) { - options = $extend({},{ - plugins: self.input_type==='html'? 'xhtml' : 'bbcode', - emoticonsEnabled: false, - width: '100%', - height: 300 - },JSONEditor.plugins.sceditor,self.options.sceditor_options||{}); - - window.jQuery(self.input).sceditor(options); - - self.sceditor_instance = window.jQuery(self.input).sceditor('instance'); - - self.sceditor_instance.blur(function() { - // Get editor's value - var val = window.jQuery("<div>"+self.sceditor_instance.val()+"</div>"); - // Remove sceditor spans/divs - window.jQuery('#sceditor-start-marker,#sceditor-end-marker,.sceditor-nlf',val).remove(); - // Set the value and update - self.input.value = val.html(); - self.value = self.input.value; - self.is_dirty = true; - self.onChange(true); - }); - } - // SimpleMDE for markdown (if it's loaded) - else if (this.input_type === 'markdown' && window.SimpleMDE) { - options = $extend({},JSONEditor.plugins.SimpleMDE,{ - element: this.input - }); - - this.SimpleMDE = new window.SimpleMDE((options)); - - this.SimpleMDE.codemirror.on("change",function() { - self.value = self.SimpleMDE.value(); - self.is_dirty = true; - self.onChange(true); - }); - } - // ACE editor for everything else - else if(window.ace) { - var mode = this.input_type; - // aliases for c/cpp - if(mode === 'cpp' || mode === 'c++' || mode === 'c') { - mode = 'c_cpp'; - } - - this.ace_container = document.createElement('div'); - this.ace_container.style.width = '100%'; - this.ace_container.style.position = 'relative'; - this.ace_container.style.height = '400px'; - this.input.parentNode.insertBefore(this.ace_container,this.input); - this.input.style.display = 'none'; - this.ace_editor = window.ace.edit(this.ace_container); - - this.ace_editor.setValue(this.getValue()); - - // The theme - if(JSONEditor.plugins.ace.theme) this.ace_editor.setTheme('ace/theme/'+JSONEditor.plugins.ace.theme); - // The mode - this.ace_editor.getSession().setMode('ace/mode/' + this.schema.format); - - // Listen for changes - this.ace_editor.on('change',function() { - var val = self.ace_editor.getValue(); - self.input.value = val; - self.refreshValue(); - self.is_dirty = true; - self.onChange(true); - }); - } - } - - self.theme.afterInputReady(self.input); - }, - refreshValue: function() { - this.value = this.input.value; - if(typeof this.value !== "string") this.value = ''; - this.serialized = this.value; - }, - destroy: function() { - // If using SCEditor, destroy the editor instance - if(this.sceditor_instance) { - this.sceditor_instance.destroy(); - } - else if(this.SimpleMDE) { - this.SimpleMDE.destroy(); - } - else if(this.ace_editor) { - this.ace_editor.destroy(); - } - - - this.template = null; - if(this.input && this.input.parentNode) this.input.parentNode.removeChild(this.input); - if(this.label && this.label.parentNode) this.label.parentNode.removeChild(this.label); - if(this.description && this.description.parentNode) this.description.parentNode.removeChild(this.description); - - this._super(); - }, - /** - * This is overridden in derivative editors - */ - sanitize: function(value) { - return value; - }, - /** - * Re-calculates the value if needed - */ - onWatchedFieldChange: function() { - var self = this, vars, j; - - // If this editor needs to be rendered by a macro template - if(this.template) { - vars = this.getWatchedFieldValues(); - this.setValue(this.template(vars),false,true); - } - - this._super(); - }, - showValidationErrors: function(errors) { - var self = this; - - if(this.jsoneditor.options.show_errors === "always") {} - else if(!this.is_dirty && this.previous_error_setting===this.jsoneditor.options.show_errors) return; - - this.previous_error_setting = this.jsoneditor.options.show_errors; - - var messages = []; - $each(errors,function(i,error) { - if(error.path === self.path) { - messages.push(error.message); - } - }); - - this.input.controlgroup = this.control; - - if(messages.length) { - this.theme.addInputError(this.input, messages.join('. ')+'.'); - } - else { - this.theme.removeInputError(this.input); - } - } -}); - -/** - * Created by Mehmet Baker on 12.04.2017 - */ -JSONEditor.defaults.editors.hidden = JSONEditor.AbstractEditor.extend({ - register: function () { - this._super(); - if (!this.input) return; - this.input.setAttribute('name', this.formname); - }, - unregister: function () { - this._super(); - if (!this.input) return; - this.input.removeAttribute('name'); - }, - setValue: function (value, initial, from_template) { - var self = this; - - if(this.template && !from_template) { - return; - } - - if(value === null || typeof value === 'undefined') value = ""; - else if(typeof value === "object") value = JSON.stringify(value); - else if(typeof value !== "string") value = ""+value; - - if(value === this.serialized) return; - - // Sanitize value before setting it - var sanitized = this.sanitize(value); - - if(this.input.value === sanitized) { - return; - } - - this.input.value = sanitized; - - var changed = from_template || this.getValue() !== value; - - this.refreshValue(); - - if(initial) this.is_dirty = false; - else if(this.jsoneditor.options.show_errors === "change") this.is_dirty = true; - - if(this.adjust_height) this.adjust_height(this.input); - - // Bubble this setValue to parents if the value changed - this.onChange(changed); - }, - getNumColumns: function () { - return 2; - }, - enable: function () { - this._super(); - }, - disable: function () { - this._super(); - }, - refreshValue: function () { - this.value = this.input.value; - if (typeof this.value !== "string") this.value = ''; - this.serialized = this.value; - }, - destroy: function () { - this.template = null; - if (this.input && this.input.parentNode) this.input.parentNode.removeChild(this.input); - if (this.label && this.label.parentNode) this.label.parentNode.removeChild(this.label); - if (this.description && this.description.parentNode) this.description.parentNode.removeChild(this.description); - - this._super(); - }, - /** - * This is overridden in derivative editors - */ - sanitize: function (value) { - return value; - }, - /** - * Re-calculates the value if needed - */ - onWatchedFieldChange: function () { - var self = this, vars, j; - - // If this editor needs to be rendered by a macro template - if (this.template) { - vars = this.getWatchedFieldValues(); - this.setValue(this.template(vars), false, true); - } - - this._super(); - }, - build: function () { - var self = this; - - this.format = this.schema.format; - if (!this.format && this.options.default_format) { - this.format = this.options.default_format; - } - if (this.options.format) { - this.format = this.options.format; - } - - this.input_type = 'hidden'; - this.input = this.theme.getFormInputField(this.input_type); - - if (this.format) this.input.setAttribute('data-schemaformat', this.format); - - this.container.appendChild(this.input); - - // Compile and store the template - if (this.schema.template) { - this.template = this.jsoneditor.compileTemplate(this.schema.template, this.template_engine); - this.refreshValue(); - } - else { - this.refreshValue(); - } - } -}); -JSONEditor.defaults.editors.number = JSONEditor.defaults.editors.string.extend({ - build: function() { - this._super(); - - if (typeof this.schema.minimum !== "undefined") { - var minimum = this.schema.minimum; - - if (typeof this.schema.exclusiveMinimum !== "undefined") { - minimum += 1; - } - - this.input.setAttribute("min", minimum); - } - - if (typeof this.schema.maximum !== "undefined") { - var maximum = this.schema.maximum; - - if (typeof this.schema.exclusiveMaximum !== "undefined") { - maximum -= 1; - } - - this.input.setAttribute("max", maximum); - } - - if (typeof this.schema.step !== "undefined") { - var step = this.schema.step || 1; - this.input.setAttribute("step", step); - } - - }, - sanitize: function(value) { - return (value+"").replace(/[^0-9\.\-eE]/g,''); - }, - getNumColumns: function() { - return 2; - }, - getValue: function() { - if (!this.dependenciesFulfilled) { - return undefined; - } - return this.value===''?undefined:this.value*1; - } -}); - -JSONEditor.defaults.editors.integer = JSONEditor.defaults.editors.number.extend({ - sanitize: function(value) { - value = value + ""; - return value.replace(/[^0-9\-]/g,''); - }, - getNumColumns: function() { - return 2; - } -}); - -JSONEditor.defaults.editors.rating = JSONEditor.defaults.editors.integer.extend({ - build: function() { - var self = this, i; - if(!this.options.compact) this.header = this.label = this.theme.getFormInputLabel(this.getTitle()); - if(this.schema.description) this.description = this.theme.getFormInputDescription(this.schema.description); - - // Dynamically add the required CSS the first time this editor is used - var styleId = 'json-editor-style-rating'; - var styles = document.getElementById(styleId); - if (!styles) { - var style = document.createElement('style'); - style.id = styleId; - style.type = 'text/css'; - style.innerHTML = - ' .rating-container {' + - ' display: inline-block;' + - ' clear: both;' + - ' }' + - ' ' + - ' .rating {' + - ' float:left;' + - ' }' + - ' ' + - ' /* :not(:checked) is a filter, so that browsers that don’t support :checked don’t' + - ' follow these rules. Every browser that supports :checked also supports :not(), so' + - ' it doesn’t make the test unnecessarily selective */' + - ' .rating:not(:checked) > input {' + - ' position:absolute;' + - ' top:-9999px;' + - ' clip:rect(0,0,0,0);' + - ' }' + - ' ' + - ' .rating:not(:checked) > label {' + - ' float:right;' + - ' width:1em;' + - ' padding:0 .1em;' + - ' overflow:hidden;' + - ' white-space:nowrap;' + - ' cursor:pointer;' + - ' color:#ddd;' + - ' }' + - ' ' + - ' .rating:not(:checked) > label:before {' + - ' content: \'★ \';' + - ' }' + - ' ' + - ' .rating > input:checked ~ label {' + - ' color: #FFB200;' + - ' }' + - ' ' + - ' .rating:not([readOnly]):not(:checked) > label:hover,' + - ' .rating:not([readOnly]):not(:checked) > label:hover ~ label {' + - ' color: #FFDA00;' + - ' }' + - ' ' + - ' .rating:not([readOnly]) > input:checked + label:hover,' + - ' .rating:not([readOnly]) > input:checked + label:hover ~ label,' + - ' .rating:not([readOnly]) > input:checked ~ label:hover,' + - ' .rating:not([readOnly]) > input:checked ~ label:hover ~ label,' + - ' .rating:not([readOnly]) > label:hover ~ input:checked ~ label {' + - ' color: #FF8C0D;' + - ' }' + - ' ' + - ' .rating:not([readOnly]) > label:active {' + - ' position:relative;' + - ' top:2px;' + - ' left:2px;' + - ' }'; - document.getElementsByTagName('head')[0].appendChild(style); - } - - this.input = this.theme.getFormInputField('hidden'); - this.container.appendChild(this.input); - - // Required to keep height - var ratingContainer = document.createElement('div'); - ratingContainer.className = 'rating-container'; - - // Contains options for rating - var group = document.createElement('div'); - group.setAttribute('name', this.formname); - group.className = 'rating'; - ratingContainer.appendChild(group); - - if(this.options.compact) this.container.setAttribute('class',this.container.getAttribute('class')+' compact'); - - var max = this.schema.maximum ? this.schema.maximum : 5; - if (this.schema.exclusiveMaximum) max--; - - this.inputs = []; - for(i=max; i>0; i--) { - var id = this.formname + i; - var radioInput = this.theme.getFormInputField('radio'); - radioInput.setAttribute('id', id); - radioInput.setAttribute('value', i); - radioInput.setAttribute('name', this.formname); - group.appendChild(radioInput); - this.inputs.push(radioInput); - - var label = document.createElement('label'); - label.setAttribute('for', id); - label.appendChild(document.createTextNode(i + (i == 1 ? ' star' : ' stars'))); - group.appendChild(label); - } - - if(this.schema.readOnly || this.schema.readonly) { - this.always_disabled = true; - $each(this.inputs,function(i,input) { - group.setAttribute("readOnly", "readOnly"); - input.disabled = true; - }); - } - - ratingContainer - .addEventListener('change',function(e) { - e.preventDefault(); - e.stopPropagation(); - - self.input.value = e.srcElement.value; - - self.is_dirty = true; - - self.refreshValue(); - self.watch_listener(); - self.jsoneditor.notifyWatchers(self.path); - if(self.parent) self.parent.onChildEditorChange(self); - else self.jsoneditor.onChange(); - }); - - this.control = this.theme.getFormControl(this.label, ratingContainer, this.description); - this.container.appendChild(this.control); - - this.refreshValue(); - }, - setValue: function(val) { - var sanitized = this.sanitize(val); - if(this.value === sanitized) { - return; - } - var self = this; - $each(this.inputs,function(i,input) { - if (input.value === sanitized) { - input.checked = true; - self.value = sanitized; - self.input.value = self.value; - self.watch_listener(); - self.jsoneditor.notifyWatchers(self.path); - return false; - } - }); - } -}); - -JSONEditor.defaults.editors.object = JSONEditor.AbstractEditor.extend({ - getDefault: function() { - return $extend({},this.schema["default"] || {}); - }, - getChildEditors: function() { - return this.editors; - }, - register: function() { - this._super(); - if(this.editors) { - for(var i in this.editors) { - if(!this.editors.hasOwnProperty(i)) continue; - this.editors[i].register(); - } - } - }, - unregister: function() { - this._super(); - if(this.editors) { - for(var i in this.editors) { - if(!this.editors.hasOwnProperty(i)) continue; - this.editors[i].unregister(); - } - } - }, - getNumColumns: function() { - return Math.max(Math.min(12,this.maxwidth),3); - }, - enable: function() { - if(!this.always_disabled) { - if(this.editjson_button) this.editjson_button.disabled = false; - if(this.addproperty_button) this.addproperty_button.disabled = false; - - this._super(); - if(this.editors) { - for(var i in this.editors) { - if(!this.editors.hasOwnProperty(i)) continue; - this.editors[i].enable(); - } - } - } - }, - disable: function(always_disabled) { - if(always_disabled) this.always_disabled = true; - if(this.editjson_button) this.editjson_button.disabled = true; - if(this.addproperty_button) this.addproperty_button.disabled = true; - this.hideEditJSON(); - - this._super(); - if(this.editors) { - for(var i in this.editors) { - if(!this.editors.hasOwnProperty(i)) continue; - this.editors[i].disable(always_disabled); - } - } - }, - layoutEditors: function() { - var self = this, i, j; - - if(!this.row_container) return; - - // Sort editors by propertyOrder - this.property_order = Object.keys(this.editors); - this.property_order = this.property_order.sort(function(a,b) { - var ordera = self.editors[a].schema.propertyOrder; - var orderb = self.editors[b].schema.propertyOrder; - if(typeof ordera !== "number") ordera = 1000; - if(typeof orderb !== "number") orderb = 1000; - - return ordera - orderb; - }); - - var container = document.createElement('div'); - var isCategoriesFormat = (this.format === 'categories'); - - if(this.format === 'grid') { - var rows = []; - $each(this.property_order, function(j,key) { - var editor = self.editors[key]; - if(editor.property_removed) return; - var found = false; - var width = editor.options.hidden? 0 : (editor.options.grid_columns || editor.getNumColumns()); - var height = editor.options.hidden? 0 : editor.container.offsetHeight; - // See if the editor will fit in any of the existing rows first - for(var i=0; i<rows.length; i++) { - // If the editor will fit in the row horizontally - if(rows[i].width + width <= 12) { - // If the editor is close to the other elements in height - // i.e. Don't put a really tall editor in an otherwise short row or vice versa - if(!height || (rows[i].minh*0.5 < height && rows[i].maxh*2 > height)) { - found = i; - } - } - } - - // If there isn't a spot in any of the existing rows, start a new row - if(found === false) { - rows.push({ - width: 0, - minh: 999999, - maxh: 0, - editors: [] - }); - found = rows.length-1; - } - - rows[found].editors.push({ - key: key, - //editor: editor, - width: width, - height: height - }); - rows[found].width += width; - rows[found].minh = Math.min(rows[found].minh,height); - rows[found].maxh = Math.max(rows[found].maxh,height); - }); - - // Make almost full rows width 12 - // Do this by increasing all editors' sizes proprotionately - // Any left over space goes to the biggest editor - // Don't touch rows with a width of 6 or less - for(i=0; i<rows.length; i++) { - if(rows[i].width < 12) { - var biggest = false; - var new_width = 0; - for(j=0; j<rows[i].editors.length; j++) { - if(biggest === false) biggest = j; - else if(rows[i].editors[j].width > rows[i].editors[biggest].width) biggest = j; - rows[i].editors[j].width *= 12/rows[i].width; - rows[i].editors[j].width = Math.floor(rows[i].editors[j].width); - new_width += rows[i].editors[j].width; - } - if(new_width < 12) rows[i].editors[biggest].width += 12-new_width; - rows[i].width = 12; - } - } - - // layout hasn't changed - if(this.layout === JSON.stringify(rows)) return false; - this.layout = JSON.stringify(rows); - - // Layout the form - for(i=0; i<rows.length; i++) { - var row = this.theme.getGridRow(); - container.appendChild(row); - for(j=0; j<rows[i].editors.length; j++) { - var key = rows[i].editors[j].key; - var editor = this.editors[key]; - - if(editor.options.hidden) editor.container.style.display = 'none'; - else this.theme.setGridColumnSize(editor.container,rows[i].editors[j].width); - row.appendChild(editor.container); - } - } - } - // Normal layout - else if(isCategoriesFormat) { - //A container for properties not object nor arrays - var containerSimple = document.createElement('div'); - //This will be the place to (re)build tabs and panes - //tabs_holder has 2 childs, [0]: ul.nav.nav-tabs and [1]: div.tab-content - var newTabs_holder = this.theme.getTopTabHolder(this.schema.title); - //child [1] of previous, stores panes - var newTabPanesContainer = this.theme.getTopTabContentHolder(newTabs_holder); - - $each(this.property_order, function(i,key){ - var editor = self.editors[key]; - if(editor.property_removed) return; - var aPane = self.theme.getTabContent(); - var isObjOrArray = editor.schema && (editor.schema.type === "object" || editor.schema.type === "array"); - //mark the pane - aPane.isObjOrArray = isObjOrArray; - var gridRow = self.theme.getGridRow(); - - //this happens with added properties, they don't have a tab - if(!editor.tab){ - //Pass the pane which holds the editor - if(typeof self.basicPane === 'undefined'){ - //There is no basicPane yet, so aPane will be it - self.addRow(editor,newTabs_holder, aPane); - } - else { - self.addRow(editor,newTabs_holder, self.basicPane); - } - } - - aPane.id = editor.tab_text.textContent; - - //For simple properties, add them on the same panel (Basic) - if(!isObjOrArray){ - containerSimple.appendChild(gridRow); - //There is already some panes - if(newTabPanesContainer.childElementCount > 0){ - //If first pane is object or array, insert before a simple pane - if(newTabPanesContainer.firstChild.isObjOrArray){ - //Append pane for simple properties - aPane.appendChild(containerSimple); - newTabPanesContainer.insertBefore(aPane,newTabPanesContainer.firstChild); - //Add "Basic" tab - self.theme.insertBasicTopTab(editor.tab,newTabs_holder); - //newTabs_holder.firstChild.insertBefore(editor.tab,newTabs_holder.firstChild.firstChild); - //Update the basicPane - editor.basicPane = aPane; - } - else { - //We already have a first "Basic" pane, just add the new property to it, so - //do nothing; - } - } - //There is no pane, so add the first (simple) pane - else { - //Append pane for simple properties - aPane.appendChild(containerSimple); - newTabPanesContainer.appendChild(aPane); - //Add "Basic" tab - //newTabs_holder.firstChild.appendChild(editor.tab); - self.theme.addTopTab(newTabs_holder,editor.tab); - //Update the basicPane - editor.basicPane = aPane; - } - } - //Objects and arrays earn it's own panes - else { - aPane.appendChild(gridRow); - newTabPanesContainer.appendChild(aPane); - //newTabs_holder.firstChild.appendChild(editor.tab); - self.theme.addTopTab(newTabs_holder,editor.tab); - } - - if(editor.options.hidden) editor.container.style.display = 'none'; - else self.theme.setGridColumnSize(editor.container,12); - //Now, add the property editor to the row - gridRow.appendChild(editor.container); - //Update the container (same as self.rows[x].container) - editor.container = aPane; - - }); - - //Erase old panes - while (this.tabPanesContainer.firstChild) { - this.tabPanesContainer.removeChild(this.tabPanesContainer.firstChild); - } - - //Erase old tabs and set the new ones - var parentTabs_holder = this.tabs_holder.parentNode; - parentTabs_holder.removeChild(parentTabs_holder.firstChild); - parentTabs_holder.appendChild(newTabs_holder); - - this.tabPanesContainer = newTabPanesContainer; - this.tabs_holder = newTabs_holder; - - //Activate the first tab - var firstTab = this.theme.getFirstTab(this.tabs_holder); - if(firstTab){ - $trigger(firstTab,'click'); - } - return; - } - // !isCategoriesFormat - else { - $each(this.property_order, function(i,key) { - var editor = self.editors[key]; - if(editor.property_removed) return; - var row = self.theme.getGridRow(); - container.appendChild(row); - - if(editor.options.hidden) editor.container.style.display = 'none'; - else self.theme.setGridColumnSize(editor.container,12); - row.appendChild(editor.container); - }); - } - //for grid and normal layout - while (this.row_container.firstChild) { - this.row_container.removeChild(this.row_container.firstChild); - } - this.row_container.appendChild(container); - }, - getPropertySchema: function(key) { - // Schema declared directly in properties - var schema = this.schema.properties[key] || {}; - schema = $extend({},schema); - var matched = this.schema.properties[key]? true : false; - - // Any matching patternProperties should be merged in - if(this.schema.patternProperties) { - for(var i in this.schema.patternProperties) { - if(!this.schema.patternProperties.hasOwnProperty(i)) continue; - var regex = new RegExp(i); - if(regex.test(key)) { - schema.allOf = schema.allOf || []; - schema.allOf.push(this.schema.patternProperties[i]); - matched = true; - } - } - } - - // Hasn't matched other rules, use additionalProperties schema - if(!matched && this.schema.additionalProperties && typeof this.schema.additionalProperties === "object") { - schema = $extend({},this.schema.additionalProperties); - } - - return schema; - }, - preBuild: function() { - this._super(); - - this.editors = {}; - this.cached_editors = {}; - var self = this; - - this.format = this.options.layout || this.options.object_layout || this.schema.format || this.jsoneditor.options.object_layout || 'normal'; - - this.schema.properties = this.schema.properties || {}; - - this.minwidth = 0; - this.maxwidth = 0; - - // If the object should be rendered as a table row - if(this.options.table_row) { - $each(this.schema.properties, function(key,schema) { - var editor = self.jsoneditor.getEditorClass(schema); - self.editors[key] = self.jsoneditor.createEditor(editor,{ - jsoneditor: self.jsoneditor, - schema: schema, - path: self.path+'.'+key, - parent: self, - compact: true, - required: true - }); - self.editors[key].preBuild(); - - var width = self.editors[key].options.hidden? 0 : (self.editors[key].options.grid_columns || self.editors[key].getNumColumns()); - - self.minwidth += width; - self.maxwidth += width; - }); - this.no_link_holder = true; - } - // If the object should be rendered as a table - else if(this.options.table) { - // TODO: table display format - throw "Not supported yet"; - } - // If the object should be rendered as a div - else { - if(!this.schema.defaultProperties) { - if(this.jsoneditor.options.display_required_only || this.options.display_required_only) { - this.schema.defaultProperties = []; - $each(this.schema.properties, function(k,s) { - if(self.isRequired({key: k, schema: s})) { - self.schema.defaultProperties.push(k); - } - }); - } - else { - self.schema.defaultProperties = Object.keys(self.schema.properties); - } - } - - // Increase the grid width to account for padding - self.maxwidth += 1; - - $each(this.schema.defaultProperties, function(i,key) { - self.addObjectProperty(key, true); - - if(self.editors[key]) { - self.minwidth = Math.max(self.minwidth,(self.editors[key].options.grid_columns || self.editors[key].getNumColumns())); - self.maxwidth += (self.editors[key].options.grid_columns || self.editors[key].getNumColumns()); - } - }); - } - - // Sort editors by propertyOrder - this.property_order = Object.keys(this.editors); - this.property_order = this.property_order.sort(function(a,b) { - var ordera = self.editors[a].schema.propertyOrder; - var orderb = self.editors[b].schema.propertyOrder; - if(typeof ordera !== "number") ordera = 1000; - if(typeof orderb !== "number") orderb = 1000; - - return ordera - orderb; - }); - }, - //"Borrow" from arrays code - addTab: function(idx){ - var self = this; - var isObjOrArray = self.rows[idx].schema && (self.rows[idx].schema.type === "object" || self.rows[idx].schema.type === "array"); - if(self.tabs_holder) { - self.rows[idx].tab_text = document.createElement('span'); - - if(!isObjOrArray){ - self.rows[idx].tab_text.textContent = (typeof self.schema.basicCategoryTitle === 'undefined') ? "Basic" : self.schema.basicCategoryTitle; - } else { - self.rows[idx].tab_text.textContent = self.rows[idx].getHeaderText(); - } - self.rows[idx].tab = self.theme.getTopTab(self.rows[idx].tab_text,self.rows[idx].tab_text.textContent); - self.rows[idx].tab.addEventListener('click', function(e) { - self.active_tab = self.rows[idx].tab; - self.refreshTabs(); - e.preventDefault(); - e.stopPropagation(); - }); - - } - - }, - addRow: function(editor, tabHolder, holder) { - var self = this; - var rowsLen = this.rows.length; - var isObjOrArray = editor.schema.type === "object" || editor.schema.type === "array"; - - //Add a row - self.rows[rowsLen] = editor; - //container stores the editor corresponding pane to set the display style when refreshing Tabs - self.rows[rowsLen].container = holder; - - if(!isObjOrArray){ - - //This is the first simple property to be added, - //add a ("Basic") tab for it and save it's row number - if(typeof self.basicTab === "undefined"){ - self.addTab(rowsLen); - //Store the index row of the first simple property added - self.basicTab = rowsLen; - self.basicPane = holder; - self.theme.addTopTab(tabHolder, self.rows[rowsLen].tab); - } - - else { - //Any other simple property gets the same tab (and the same pane) as the first one, - //so, when 'click' event is fired from a row, it gets the correct ("Basic") tab - self.rows[rowsLen].tab = self.rows[self.basicTab].tab; - self.rows[rowsLen].tab_text = self.rows[self.basicTab].tab_text; - self.rows[rowsLen].container = self.rows[self.basicTab].container; - } - } - else { - self.addTab(rowsLen); - self.theme.addTopTab(tabHolder, self.rows[rowsLen].tab); - } - }, - //Mark the active tab and make visible the corresponding pane, hide others - refreshTabs: function(refresh_headers) { - var self = this; - var basicTabPresent = typeof self.basicTab !== 'undefined'; - var basicTabRefreshed = false; - - $each(this.rows, function(i,row) { - //If it's an orphan row (some property which has been deleted), return - if(!row.tab || !row.container || !row.container.parentNode) return; - - if(basicTabPresent && row.tab == self.rows[self.basicTab].tab && basicTabRefreshed) return; - - if(refresh_headers) { - row.tab_text.textContent = row.getHeaderText(); - } - else { - //All rows of simple properties point to the same tab, so refresh just once - if(basicTabPresent && row.tab == self.rows[self.basicTab].tab) basicTabRefreshed = true; - - if(row.tab === self.active_tab) { - self.theme.markTabActive(row); - } - else { - self.theme.markTabInactive(row); - } - } - }); - }, - build: function() { - var self = this; - - var isCategoriesFormat = (this.format === 'categories'); - this.rows=[]; - this.active_tab = null; - - // If the object should be rendered as a table row - if(this.options.table_row) { - this.editor_holder = this.container; - $each(this.editors, function(key,editor) { - var holder = self.theme.getTableCell(); - self.editor_holder.appendChild(holder); - - editor.setContainer(holder); - editor.build(); - editor.postBuild(); - - if(self.editors[key].options.hidden) { - holder.style.display = 'none'; - } - if(self.editors[key].options.input_width) { - holder.style.width = self.editors[key].options.input_width; - } - }); - } - // If the object should be rendered as a table - else if(this.options.table) { - // TODO: table display format - throw "Not supported yet"; - } - // If the object should be rendered as a div - else { - this.header = document.createElement('span'); - this.header.textContent = this.getTitle(); - this.title = this.theme.getHeader(this.header); - this.container.appendChild(this.title); - this.container.style.position = 'relative'; - - // Edit JSON modal - this.editjson_holder = this.theme.getModal(); - this.editjson_textarea = this.theme.getTextareaInput(); - this.editjson_textarea.style.height = '170px'; - this.editjson_textarea.style.width = '300px'; - this.editjson_textarea.style.display = 'block'; - this.editjson_save = this.getButton('Save','save','Save'); - this.editjson_save.addEventListener('click',function(e) { - e.preventDefault(); - e.stopPropagation(); - self.saveJSON(); - }); - this.editjson_cancel = this.getButton('Cancel','cancel','Cancel'); - this.editjson_cancel.addEventListener('click',function(e) { - e.preventDefault(); - e.stopPropagation(); - self.hideEditJSON(); - }); - this.editjson_holder.appendChild(this.editjson_textarea); - this.editjson_holder.appendChild(this.editjson_save); - this.editjson_holder.appendChild(this.editjson_cancel); - - // Manage Properties modal - this.addproperty_holder = this.theme.getModal(); - this.addproperty_list = document.createElement('div'); - this.addproperty_list.style.width = '295px'; - this.addproperty_list.style.maxHeight = '160px'; - this.addproperty_list.style.padding = '5px 0'; - this.addproperty_list.style.overflowY = 'auto'; - this.addproperty_list.style.overflowX = 'hidden'; - this.addproperty_list.style.paddingLeft = '5px'; - this.addproperty_list.setAttribute('class', 'property-selector'); - this.addproperty_add = this.getButton('add','add','add'); - this.addproperty_input = this.theme.getFormInputField('text'); - this.addproperty_input.setAttribute('placeholder','Property name...'); - this.addproperty_input.style.width = '220px'; - this.addproperty_input.style.marginBottom = '0'; - this.addproperty_input.style.display = 'inline-block'; - this.addproperty_add.addEventListener('click',function(e) { - e.preventDefault(); - e.stopPropagation(); - if(self.addproperty_input.value) { - if(self.editors[self.addproperty_input.value]) { - window.alert('there is already a property with that name'); - return; - } - - self.addObjectProperty(self.addproperty_input.value); - if(self.editors[self.addproperty_input.value]) { - self.editors[self.addproperty_input.value].disable(); - } - self.onChange(true); - } - }); - this.addproperty_holder.appendChild(this.addproperty_list); - this.addproperty_holder.appendChild(this.addproperty_input); - this.addproperty_holder.appendChild(this.addproperty_add); - var spacer = document.createElement('div'); - spacer.style.clear = 'both'; - this.addproperty_holder.appendChild(spacer); - - - // Description - if(this.schema.description) { - this.description = this.theme.getDescription(this.schema.description); - this.container.appendChild(this.description); - } - - // Validation error placeholder area - this.error_holder = document.createElement('div'); - this.container.appendChild(this.error_holder); - - // Container for child editor area - this.editor_holder = this.theme.getIndentedPanel(); - this.container.appendChild(this.editor_holder); - - // Container for rows of child editors - this.row_container = this.theme.getGridContainer(); - - if(isCategoriesFormat) { - this.tabs_holder = this.theme.getTopTabHolder(this.schema.title); - this.tabPanesContainer = this.theme.getTopTabContentHolder(this.tabs_holder); - this.editor_holder.appendChild(this.tabs_holder); - } - else { - this.tabs_holder = this.theme.getTabHolder(this.schema.title); - this.tabPanesContainer = this.theme.getTabContentHolder(this.tabs_holder); - this.editor_holder.appendChild(this.row_container); - } - - $each(this.editors, function(key,editor) { - var aPane = self.theme.getTabContent(); - var holder = self.theme.getGridColumn(); - var isObjOrArray = (editor.schema && (editor.schema.type === 'object' || editor.schema.type === 'array')) ? true : false; - aPane.isObjOrArray = isObjOrArray; - - if(isCategoriesFormat){ - if(isObjOrArray) { - var single_row_container = self.theme.getGridContainer(); - single_row_container.appendChild(holder); - aPane.appendChild(single_row_container); - self.tabPanesContainer.appendChild(aPane); - self.row_container = single_row_container; - } - else { - if(typeof self.row_container_basic === 'undefined'){ - self.row_container_basic = self.theme.getGridContainer(); - aPane.appendChild(self.row_container_basic); - if(self.tabPanesContainer.childElementCount == 0){ - self.tabPanesContainer.appendChild(aPane); - } - else { - self.tabPanesContainer.insertBefore(aPane,self.tabPanesContainer.childNodes[1]); - } - } - self.row_container_basic.appendChild(holder); - } - - self.addRow(editor,self.tabs_holder,aPane); - - aPane.id = editor.schema.title; //editor.schema.path//tab_text.textContent - - } - else { - self.row_container.appendChild(holder); - } - - editor.setContainer(holder); - editor.build(); - editor.postBuild(); - }); - - if(this.rows[0]){ - $trigger(this.rows[0].tab,'click'); - } - - // Control buttons - this.title_controls = this.theme.getHeaderButtonHolder(); - this.editjson_controls = this.theme.getHeaderButtonHolder(); - this.addproperty_controls = this.theme.getHeaderButtonHolder(); - this.title.appendChild(this.title_controls); - this.title.appendChild(this.editjson_controls); - this.title.appendChild(this.addproperty_controls); - - // Show/Hide button - this.collapsed = false; - this.toggle_button = this.getButton('', 'collapse', this.translate('button_collapse')); - this.title_controls.appendChild(this.toggle_button); - this.toggle_button.addEventListener('click',function(e) { - e.preventDefault(); - e.stopPropagation(); - if(self.collapsed) { - self.editor_holder.style.display = ''; - self.collapsed = false; - self.setButtonText(self.toggle_button,'','collapse',self.translate('button_collapse')); - } - else { - self.editor_holder.style.display = 'none'; - self.collapsed = true; - self.setButtonText(self.toggle_button,'','expand',self.translate('button_expand')); - } - }); - - // If it should start collapsed - if(this.options.collapsed) { - $trigger(this.toggle_button,'click'); - } - - // Collapse button disabled - if(this.schema.options && typeof this.schema.options.disable_collapse !== "undefined") { - if(this.schema.options.disable_collapse) this.toggle_button.style.display = 'none'; - } - else if(this.jsoneditor.options.disable_collapse) { - this.toggle_button.style.display = 'none'; - } - - // Edit JSON Button - this.editjson_button = this.getButton('JSON','edit','Edit JSON'); - this.editjson_button.addEventListener('click',function(e) { - e.preventDefault(); - e.stopPropagation(); - self.toggleEditJSON(); - }); - this.editjson_controls.appendChild(this.editjson_button); - this.editjson_controls.appendChild(this.editjson_holder); - - // Edit JSON Buttton disabled - if(this.schema.options && typeof this.schema.options.disable_edit_json !== "undefined") { - if(this.schema.options.disable_edit_json) this.editjson_button.style.display = 'none'; - } - else if(this.jsoneditor.options.disable_edit_json) { - this.editjson_button.style.display = 'none'; - } - - // Object Properties Button - this.addproperty_button = this.getButton('Properties','edit','Object Properties'); - this.addproperty_button.addEventListener('click',function(e) { - e.preventDefault(); - e.stopPropagation(); - self.toggleAddProperty(); - }); - this.addproperty_controls.appendChild(this.addproperty_button); - this.addproperty_controls.appendChild(this.addproperty_holder); - this.refreshAddProperties(); - } - - // Fix table cell ordering - if(this.options.table_row) { - this.editor_holder = this.container; - $each(this.property_order,function(i,key) { - self.editor_holder.appendChild(self.editors[key].container); - }); - } - // Layout object editors in grid if needed - else { - // Initial layout - this.layoutEditors(); - // Do it again now that we know the approximate heights of elements - this.layoutEditors(); - } - }, - showEditJSON: function() { - if(!this.editjson_holder) return; - this.hideAddProperty(); - - // Position the form directly beneath the button - // TODO: edge detection - this.editjson_holder.style.left = this.editjson_button.offsetLeft+"px"; - this.editjson_holder.style.top = this.editjson_button.offsetTop + this.editjson_button.offsetHeight+"px"; - - // Start the textarea with the current value - this.editjson_textarea.value = JSON.stringify(this.getValue(),null,2); - - // Disable the rest of the form while editing JSON - this.disable(); - - this.editjson_holder.style.display = ''; - this.editjson_button.disabled = false; - this.editing_json = true; - }, - hideEditJSON: function() { - if(!this.editjson_holder) return; - if(!this.editing_json) return; - - this.editjson_holder.style.display = 'none'; - this.enable(); - this.editing_json = false; - }, - saveJSON: function() { - if(!this.editjson_holder) return; - - try { - var json = JSON.parse(this.editjson_textarea.value); - this.setValue(json); - this.hideEditJSON(); - } - catch(e) { - window.alert('invalid JSON'); - throw e; - } - }, - toggleEditJSON: function() { - if(this.editing_json) this.hideEditJSON(); - else this.showEditJSON(); - }, - insertPropertyControlUsingPropertyOrder: function (property, control, container) { - var propertyOrder; - if (this.schema.properties[property]) - propertyOrder = this.schema.properties[property].propertyOrder; - if (typeof propertyOrder !== "number") propertyOrder = 1000; - control.propertyOrder = propertyOrder; - - for (var i = 0; i < container.childNodes.length; i++) { - var child = container.childNodes[i]; - if (control.propertyOrder < child.propertyOrder) { - this.addproperty_list.insertBefore(control, child); - control = null; - break; - } - } - if (control) { - this.addproperty_list.appendChild(control); - } - }, - addPropertyCheckbox: function(key) { - var self = this; - var checkbox, label, labelText, control; - - checkbox = self.theme.getCheckbox(); - checkbox.style.width = 'auto'; - - if (this.schema.properties[key] && this.schema.properties[key].title) - labelText = this.schema.properties[key].title; - else - labelText = key; - - label = self.theme.getCheckboxLabel(labelText); - - control = self.theme.getFormControl(label,checkbox); - control.style.paddingBottom = control.style.marginBottom = control.style.paddingTop = control.style.marginTop = 0; - control.style.height = 'auto'; - //control.style.overflowY = 'hidden'; - - this.insertPropertyControlUsingPropertyOrder(key, control, this.addproperty_list); - - checkbox.checked = key in this.editors; - checkbox.addEventListener('change',function() { - if(checkbox.checked) { - self.addObjectProperty(key); - } - else { - self.removeObjectProperty(key); - } - self.onChange(true); - }); - self.addproperty_checkboxes[key] = checkbox; - - return checkbox; - }, - showAddProperty: function() { - if(!this.addproperty_holder) return; - this.hideEditJSON(); - - // Position the form directly beneath the button - // TODO: edge detection - this.addproperty_holder.style.left = this.addproperty_button.offsetLeft+"px"; - this.addproperty_holder.style.top = this.addproperty_button.offsetTop + this.addproperty_button.offsetHeight+"px"; - - // Disable the rest of the form while editing JSON - this.disable(); - - this.adding_property = true; - this.addproperty_button.disabled = false; - this.addproperty_holder.style.display = ''; - this.refreshAddProperties(); - }, - hideAddProperty: function() { - if(!this.addproperty_holder) return; - if(!this.adding_property) return; - - this.addproperty_holder.style.display = 'none'; - this.enable(); - - this.adding_property = false; - }, - toggleAddProperty: function() { - if(this.adding_property) this.hideAddProperty(); - else this.showAddProperty(); - }, - removeObjectProperty: function(property) { - if(this.editors[property]) { - this.editors[property].unregister(); - delete this.editors[property]; - - this.refreshValue(); - this.layoutEditors(); - } - }, - addObjectProperty: function(name, prebuild_only) { - var self = this; - - // Property is already added - if(this.editors[name]) return; - - // Property was added before and is cached - if(this.cached_editors[name]) { - this.editors[name] = this.cached_editors[name]; - if(prebuild_only) return; - this.editors[name].register(); - } - // New property - else { - if(!this.canHaveAdditionalProperties() && (!this.schema.properties || !this.schema.properties[name])) { - return; - } - - var schema = self.getPropertySchema(name); - if(typeof schema.propertyOrder !== 'number'){ - // if the propertyOrder undefined, then set a smart default value. - schema.propertyOrder = Object.keys(self.editors).length + 1000; - } - - - // Add the property - var editor = self.jsoneditor.getEditorClass(schema); - - self.editors[name] = self.jsoneditor.createEditor(editor,{ - jsoneditor: self.jsoneditor, - schema: schema, - path: self.path+'.'+name, - parent: self - }); - self.editors[name].preBuild(); - - if(!prebuild_only) { - var holder = self.theme.getChildEditorHolder(); - self.editor_holder.appendChild(holder); - self.editors[name].setContainer(holder); - self.editors[name].build(); - self.editors[name].postBuild(); - } - - self.cached_editors[name] = self.editors[name]; - } - - // If we're only prebuilding the editors, don't refresh values - if(!prebuild_only) { - self.refreshValue(); - self.layoutEditors(); - } - }, - onChildEditorChange: function(editor) { - this.refreshValue(); - this._super(editor); - }, - canHaveAdditionalProperties: function() { - if (typeof this.schema.additionalProperties === "boolean") {//# sourceMappingURL=jsoneditor.js.map - return this.schema.additionalProperties; - } - return !this.jsoneditor.options.no_additional_properties; - }, - destroy: function() { - $each(this.cached_editors, function(i,el) { - el.destroy(); - }); - if(this.editor_holder) this.editor_holder.innerHTML = ''; - if(this.title && this.title.parentNode) this.title.parentNode.removeChild(this.title); - if(this.error_holder && this.error_holder.parentNode) this.error_holder.parentNode.removeChild(this.error_holder); - - this.editors = null; - this.cached_editors = null; - if(this.editor_holder && this.editor_holder.parentNode) this.editor_holder.parentNode.removeChild(this.editor_holder); - this.editor_holder = null; - - this._super(); - }, - getValue: function() { - if (!this.dependenciesFulfilled) { - return undefined; - } - var result = this._super(); - if(this.jsoneditor.options.remove_empty_properties || this.options.remove_empty_properties) { - for (var i in result) { - if (result.hasOwnProperty(i)) { - if ((typeof result[i] === 'undefined' || result[i] === '') || - (Object.keys(result[i]).length == 0 && result[i].constructor == Object) || - (Array.isArray(result[i]) && result[i].length == 0)) { - delete result[i]; - } - } - } - } - - return result; - }, - refreshValue: function() { - this.value = {}; - var self = this; - - for(var i in this.editors) { - if(!this.editors.hasOwnProperty(i)) continue; - this.value[i] = this.editors[i].getValue(); - } - - if(this.adding_property) this.refreshAddProperties(); - }, - refreshAddProperties: function() { - if(this.options.disable_properties || (this.options.disable_properties !== false && this.jsoneditor.options.disable_properties)) { - this.addproperty_controls.style.display = 'none'; - return; - } - - var can_add = false, can_remove = false, num_props = 0, i, show_modal = false; - - // Get number of editors - for(i in this.editors) { - if(!this.editors.hasOwnProperty(i)) continue; - num_props++; - } - - // Determine if we can add back removed properties - can_add = this.canHaveAdditionalProperties() && !(typeof this.schema.maxProperties !== "undefined" && num_props >= this.schema.maxProperties); - - if(this.addproperty_checkboxes) { - this.addproperty_list.innerHTML = ''; - } - this.addproperty_checkboxes = {}; - - // Check for which editors can't be removed or added back - for(i in this.cached_editors) { - if(!this.cached_editors.hasOwnProperty(i)) continue; - - this.addPropertyCheckbox(i); - - if(this.isRequired(this.cached_editors[i]) && i in this.editors) { - this.addproperty_checkboxes[i].disabled = true; - } - - if(typeof this.schema.minProperties !== "undefined" && num_props <= this.schema.minProperties) { - this.addproperty_checkboxes[i].disabled = this.addproperty_checkboxes[i].checked; - if(!this.addproperty_checkboxes[i].checked) show_modal = true; - } - else if(!(i in this.editors)) { - if(!can_add && !this.schema.properties.hasOwnProperty(i)) { - this.addproperty_checkboxes[i].disabled = true; - } - else { - this.addproperty_checkboxes[i].disabled = false; - show_modal = true; - } - } - else { - show_modal = true; - can_remove = true; - } - } - - if(this.canHaveAdditionalProperties()) { - show_modal = true; - } - - // Additional addproperty checkboxes not tied to a current editor - for(i in this.schema.properties) { - if(!this.schema.properties.hasOwnProperty(i)) continue; - if(this.cached_editors[i]) continue; - show_modal = true; - this.addPropertyCheckbox(i); - } - - // If no editors can be added or removed, hide the modal button - if(!show_modal) { - this.hideAddProperty(); - this.addproperty_controls.style.display = 'none'; - } - // If additional properties are disabled - else if(!this.canHaveAdditionalProperties()) { - this.addproperty_add.style.display = 'none'; - this.addproperty_input.style.display = 'none'; - } - // If no new properties can be added - else if(!can_add) { - this.addproperty_add.disabled = true; - } - // If new properties can be added - else { - this.addproperty_add.disabled = false; - } - }, - isRequired: function(editor) { - if(typeof editor.schema.required === "boolean") return editor.schema.required; - else if(Array.isArray(this.schema.required)) return this.schema.required.indexOf(editor.key) > -1; - else if(this.jsoneditor.options.required_by_default) return true; - else return false; - }, - setValue: function(value, initial) { - var self = this; - value = value || {}; - - if(typeof value !== "object" || Array.isArray(value)) value = {}; - - // First, set the values for all of the defined properties - $each(this.cached_editors, function(i,editor) { - // Value explicitly set - if(typeof value[i] !== "undefined") { - self.addObjectProperty(i); - editor.setValue(value[i],initial); - } - // Otherwise, remove value unless this is the initial set or it's required - else if(!initial && !self.isRequired(editor)) { - self.removeObjectProperty(i); - } - // Otherwise, set the value to the default - else { - editor.setValue(editor.getDefault(),initial); - } - }); - - $each(value, function(i,val) { - if(!self.cached_editors[i]) { - self.addObjectProperty(i); - if(self.editors[i]) self.editors[i].setValue(val,initial); - } - }); - - this.refreshValue(); - this.layoutEditors(); - this.onChange(); - }, - showValidationErrors: function(errors) { - var self = this; - - // Get all the errors that pertain to this editor - var my_errors = []; - var other_errors = []; - $each(errors, function(i,error) { - if(error.path === self.path) { - my_errors.push(error); - } - else { - other_errors.push(error); - } - }); - - // Show errors for this editor - if(this.error_holder) { - if(my_errors.length) { - var message = []; - this.error_holder.innerHTML = ''; - this.error_holder.style.display = ''; - $each(my_errors, function(i,error) { - self.error_holder.appendChild(self.theme.getErrorMessage(error.message)); - }); - } - // Hide error area - else { - this.error_holder.style.display = 'none'; - } - } - - // Show error for the table row if this is inside a table - if(this.options.table_row) { - if(my_errors.length) { - this.theme.addTableRowError(this.container); - } - else { - this.theme.removeTableRowError(this.container); - } - } - - // Show errors for child editors - $each(this.editors, function(i,editor) { - editor.showValidationErrors(other_errors); - }); - } -}); - -JSONEditor.defaults.editors.array = JSONEditor.AbstractEditor.extend({ - getDefault: function() { - return this.schema["default"] || []; - }, - register: function() { - this._super(); - if(this.rows) { - for(var i=0; i<this.rows.length; i++) { - this.rows[i].register(); - } - } - }, - unregister: function() { - this._super(); - if(this.rows) { - for(var i=0; i<this.rows.length; i++) { - this.rows[i].unregister(); - } - } - }, - getNumColumns: function() { - var info = this.getItemInfo(0); - // Tabs require extra horizontal space - if(this.tabs_holder && this.schema.format !== 'tabs-top') { - return Math.max(Math.min(12,info.width+2),4); - } - else { - return info.width; - } - }, - enable: function() { - if(!this.always_disabled) { - if(this.add_row_button) this.add_row_button.disabled = false; - if(this.remove_all_rows_button) this.remove_all_rows_button.disabled = false; - if(this.delete_last_row_button) this.delete_last_row_button.disabled = false; - - if(this.rows) { - for(var i=0; i<this.rows.length; i++) { - this.rows[i].enable(); - - if(this.rows[i].moveup_button) this.rows[i].moveup_button.disabled = false; - if(this.rows[i].movedown_button) this.rows[i].movedown_button.disabled = false; - if(this.rows[i].delete_button) this.rows[i].delete_button.disabled = false; - } - } - this._super(); - } - }, - disable: function(always_disabled) { - if(always_disabled) this.always_disabled = true; - if(this.add_row_button) this.add_row_button.disabled = true; - if(this.remove_all_rows_button) this.remove_all_rows_button.disabled = true; - if(this.delete_last_row_button) this.delete_last_row_button.disabled = true; - - if(this.rows) { - for(var i=0; i<this.rows.length; i++) { - this.rows[i].disable(always_disabled); - - if(this.rows[i].moveup_button) this.rows[i].moveup_button.disabled = true; - if(this.rows[i].movedown_button) this.rows[i].movedown_button.disabled = true; - if(this.rows[i].delete_button) this.rows[i].delete_button.disabled = true; - } - } - this._super(); - }, - preBuild: function() { - this._super(); - - this.rows = []; - this.row_cache = []; - - this.hide_delete_buttons = this.options.disable_array_delete || this.jsoneditor.options.disable_array_delete; - this.hide_delete_all_rows_buttons = this.hide_delete_buttons || this.options.disable_array_delete_all_rows || this.jsoneditor.options.disable_array_delete_all_rows; - this.hide_delete_last_row_buttons = this.hide_delete_buttons || this.options.disable_array_delete_last_row || this.jsoneditor.options.disable_array_delete_last_row; - this.hide_move_buttons = this.options.disable_array_reorder || this.jsoneditor.options.disable_array_reorder; - this.hide_add_button = this.options.disable_array_add || this.jsoneditor.options.disable_array_add; - this.show_copy_button = this.options.enable_array_copy || this.jsoneditor.options.enable_array_copy; - }, - build: function() { - var self = this; - - if(!this.options.compact) { - this.header = document.createElement('span'); - this.header.textContent = this.getTitle(); - this.title = this.theme.getHeader(this.header); - this.container.appendChild(this.title); - this.title_controls = this.theme.getHeaderButtonHolder(); - this.title.appendChild(this.title_controls); - if(this.schema.description) { - this.description = this.theme.getDescription(this.schema.description); - this.container.appendChild(this.description); - } - this.error_holder = document.createElement('div'); - this.container.appendChild(this.error_holder); - - if(this.schema.format === 'tabs-top') { - this.controls = this.theme.getHeaderButtonHolder(); - this.title.appendChild(this.controls); - this.tabs_holder = this.theme.getTopTabHolder(this.getItemTitle()); - this.container.appendChild(this.tabs_holder); - this.row_holder = this.theme.getTopTabContentHolder(this.tabs_holder); - - this.active_tab = null; - } - else if(this.schema.format === 'tabs') { - this.controls = this.theme.getHeaderButtonHolder(); - this.title.appendChild(this.controls); - this.tabs_holder = this.theme.getTabHolder(this.getItemTitle()); - this.container.appendChild(this.tabs_holder); - this.row_holder = this.theme.getTabContentHolder(this.tabs_holder); - - this.active_tab = null; - } - else { - this.panel = this.theme.getIndentedPanel(); - this.container.appendChild(this.panel); - this.row_holder = document.createElement('div'); - this.panel.appendChild(this.row_holder); - this.controls = this.theme.getButtonHolder(); - this.panel.appendChild(this.controls); - } - } - else { - this.panel = this.theme.getIndentedPanel(); - this.container.appendChild(this.panel); - this.controls = this.theme.getButtonHolder(); - this.panel.appendChild(this.controls); - this.row_holder = document.createElement('div'); - this.panel.appendChild(this.row_holder); - } - - // Add controls - this.addControls(); - }, - onChildEditorChange: function(editor) { - this.refreshValue(); - this.refreshTabs(true); - this._super(editor); - }, - getItemTitle: function() { - if(!this.item_title) { - if(this.schema.items && !Array.isArray(this.schema.items)) { - var tmp = this.jsoneditor.expandRefs(this.schema.items); - this.item_title = tmp.title || 'item'; - } - else { - this.item_title = 'item'; - } - } - return this.item_title; - }, - getItemSchema: function(i) { - if(Array.isArray(this.schema.items)) { - if(i >= this.schema.items.length) { - if(this.schema.additionalItems===true) { - return {}; - } - else if(this.schema.additionalItems) { - return $extend({},this.schema.additionalItems); - } - } - else { - return $extend({},this.schema.items[i]); - } - } - else if(this.schema.items) { - return $extend({},this.schema.items); - } - else { - return {}; - } - }, - getItemInfo: function(i) { - var schema = this.getItemSchema(i); - - // Check if it's cached - this.item_info = this.item_info || {}; - var stringified = JSON.stringify(schema); - if(typeof this.item_info[stringified] !== "undefined") return this.item_info[stringified]; - - // Get the schema for this item - schema = this.jsoneditor.expandRefs(schema); - - this.item_info[stringified] = { - title: schema.title || "item", - 'default': schema["default"], - width: 12, - child_editors: schema.properties || schema.items - }; - - return this.item_info[stringified]; - }, - getElementEditor: function(i) { - var item_info = this.getItemInfo(i); - var schema = this.getItemSchema(i); - schema = this.jsoneditor.expandRefs(schema); - schema.title = item_info.title+' '+(i+1); - - var editor = this.jsoneditor.getEditorClass(schema); - - var holder; - if(this.tabs_holder) { - if(this.schema.format === 'tabs-top') { - holder = this.theme.getTopTabContent(); - } - else { - holder = this.theme.getTabContent(); - } - holder.id = this.path+'.'+i; - } - else if(item_info.child_editors) { - holder = this.theme.getChildEditorHolder(); - } - else { - holder = this.theme.getIndentedPanel(); - } - - this.row_holder.appendChild(holder); - - var ret = this.jsoneditor.createEditor(editor,{ - jsoneditor: this.jsoneditor, - schema: schema, - container: holder, - path: this.path+'.'+i, - parent: this, - required: true - }); - ret.preBuild(); - ret.build(); - ret.postBuild(); - - if(!ret.title_controls) { - ret.array_controls = this.theme.getButtonHolder(); - holder.appendChild(ret.array_controls); - } - - return ret; - }, - destroy: function() { - this.empty(true); - if(this.title && this.title.parentNode) this.title.parentNode.removeChild(this.title); - if(this.description && this.description.parentNode) this.description.parentNode.removeChild(this.description); - if(this.row_holder && this.row_holder.parentNode) this.row_holder.parentNode.removeChild(this.row_holder); - if(this.controls && this.controls.parentNode) this.controls.parentNode.removeChild(this.controls); - if(this.panel && this.panel.parentNode) this.panel.parentNode.removeChild(this.panel); - - this.rows = this.row_cache = this.title = this.description = this.row_holder = this.panel = this.controls = null; - - this._super(); - }, - empty: function(hard) { - if(!this.rows) return; - var self = this; - $each(this.rows,function(i,row) { - if(hard) { - if(row.tab && row.tab.parentNode) row.tab.parentNode.removeChild(row.tab); - self.destroyRow(row,true); - self.row_cache[i] = null; - } - self.rows[i] = null; - }); - self.rows = []; - if(hard) self.row_cache = []; - }, - destroyRow: function(row,hard) { - var holder = row.container; - if(hard) { - row.destroy(); - if(holder.parentNode) holder.parentNode.removeChild(holder); - if(row.tab && row.tab.parentNode) row.tab.parentNode.removeChild(row.tab); - } - else { - if(row.tab) row.tab.style.display = 'none'; - holder.style.display = 'none'; - row.unregister(); - } - }, - getMax: function() { - if((Array.isArray(this.schema.items)) && this.schema.additionalItems === false) { - return Math.min(this.schema.items.length,this.schema.maxItems || Infinity); - } - else { - return this.schema.maxItems || Infinity; - } - }, - refreshTabs: function(refresh_headers) { - var self = this; - $each(this.rows, function(i,row) { - if(!row.tab) return; - - if(refresh_headers) { - row.tab_text.textContent = row.getHeaderText(); - } - else { - if(row.tab === self.active_tab) { - self.theme.markTabActive(row); - } - else { - self.theme.markTabInactive(row); - } - } - }); - }, - setValue: function(value, initial) { - // Update the array's value, adding/removing rows when necessary - value = value || []; - - if(!(Array.isArray(value))) value = [value]; - - var serialized = JSON.stringify(value); - if(serialized === this.serialized) return; - - // Make sure value has between minItems and maxItems items in it - if(this.schema.minItems) { - while(value.length < this.schema.minItems) { - value.push(this.getItemInfo(value.length)["default"]); - } - } - if(this.getMax() && value.length > this.getMax()) { - value = value.slice(0,this.getMax()); - } - - var self = this; - $each(value,function(i,val) { - if(self.rows[i]) { - // TODO: don't set the row's value if it hasn't changed - self.rows[i].setValue(val,initial); - } - else if(self.row_cache[i]) { - self.rows[i] = self.row_cache[i]; - self.rows[i].setValue(val,initial); - self.rows[i].container.style.display = ''; - if(self.rows[i].tab) self.rows[i].tab.style.display = ''; - self.rows[i].register(); - } - else { - self.addRow(val,initial); - } - }); - - for(var j=value.length; j<self.rows.length; j++) { - self.destroyRow(self.rows[j]); - self.rows[j] = null; - } - self.rows = self.rows.slice(0,value.length); - - // Set the active tab - var new_active_tab = null; - $each(self.rows, function(i,row) { - if(row.tab === self.active_tab) { - new_active_tab = row.tab; - return false; - } - }); - if(!new_active_tab && self.rows.length) new_active_tab = self.rows[0].tab; - - self.active_tab = new_active_tab; - - self.refreshValue(initial); - self.refreshTabs(true); - self.refreshTabs(); - - self.onChange(); - - // TODO: sortable - }, - refreshValue: function(force) { - var self = this; - var oldi = this.value? this.value.length : 0; - this.value = []; - - $each(this.rows,function(i,editor) { - // Get the value for this editor - self.value[i] = editor.getValue(); - }); - - if(oldi !== this.value.length || force) { - // If we currently have minItems items in the array - var minItems = this.schema.minItems && this.schema.minItems >= this.rows.length; - - $each(this.rows,function(i,editor) { - // Hide the move down button for the last row - if(editor.movedown_button) { - if(i === self.rows.length - 1) { - editor.movedown_button.style.display = 'none'; - } - else { - editor.movedown_button.style.display = ''; - } - } - - // Hide the delete button if we have minItems items - if(editor.delete_button) { - if(minItems) { - editor.delete_button.style.display = 'none'; - } - else { - editor.delete_button.style.display = ''; - } - } - - // Get the value for this editor - self.value[i] = editor.getValue(); - }); - - var controls_needed = false; - - if(!this.value.length) { - this.delete_last_row_button.style.display = 'none'; - this.remove_all_rows_button.style.display = 'none'; - } - else if(this.value.length === 1) { - this.remove_all_rows_button.style.display = 'none'; - - // If there are minItems items in the array, or configured to hide the delete_last_row button, hide the delete button beneath the rows - if(minItems || this.hide_delete_last_row_buttons) { - this.delete_last_row_button.style.display = 'none'; - } - else { - this.delete_last_row_button.style.display = ''; - controls_needed = true; - } - } - else { - if(minItems || this.hide_delete_last_row_buttons) { - this.delete_last_row_button.style.display = 'none'; - } - else { - this.delete_last_row_button.style.display = ''; - controls_needed = true; - } - - if(minItems || this.hide_delete_all_rows_buttons) { - this.remove_all_rows_button.style.display = 'none'; - } - else { - this.remove_all_rows_button.style.display = ''; - controls_needed = true; - } - } - - // If there are maxItems in the array, hide the add button beneath the rows - if((this.getMax() && this.getMax() <= this.rows.length) || this.hide_add_button){ - this.add_row_button.style.display = 'none'; - } - else { - this.add_row_button.style.display = ''; - controls_needed = true; - } - - if(!this.collapsed && controls_needed) { - this.controls.style.display = 'inline-block'; - } - else { - this.controls.style.display = 'none'; - } - } - }, - addRow: function(value, initial) { - var self = this; - var i = this.rows.length; - - self.rows[i] = this.getElementEditor(i); - self.row_cache[i] = self.rows[i]; - - if(self.tabs_holder) { - self.rows[i].tab_text = document.createElement('span'); - self.rows[i].tab_text.textContent = self.rows[i].getHeaderText(); - if(self.schema.format === 'tabs-top'){ - self.rows[i].tab = self.theme.getTopTab(self.rows[i].tab_text,self.rows[i].path); - self.theme.addTopTab(self.tabs_holder, self.rows[i].tab); - } - else { - self.rows[i].tab = self.theme.getTab(self.rows[i].tab_text,self.rows[i].path); - self.theme.addTab(self.tabs_holder, self.rows[i].tab); - } - self.rows[i].tab.addEventListener('click', function(e) { - self.active_tab = self.rows[i].tab; - self.refreshTabs(); - e.preventDefault(); - e.stopPropagation(); - }); - - } - - var controls_holder = self.rows[i].title_controls || self.rows[i].array_controls; - - // Buttons to delete row, move row up, and move row down - if(!self.hide_delete_buttons) { - self.rows[i].delete_button = this.getButton(self.getItemTitle(),'delete',this.translate('button_delete_row_title',[self.getItemTitle()])); - self.rows[i].delete_button.className += ' delete'; - self.rows[i].delete_button.setAttribute('data-i',i); - self.rows[i].delete_button.addEventListener('click',function(e) { - e.preventDefault(); - e.stopPropagation(); - - if (self.jsoneditor.options.prompt_before_delete === true) { - if (confirm("Confirm to remove.") === false) { - return false; - } - } - - var i = this.getAttribute('data-i')*1; - - var value = self.getValue(); - - var newval = []; - var new_active_tab = null; - $each(value,function(j,row) { - if(j===i) { - // If the one we're deleting is the active tab - if(self.rows[j].tab === self.active_tab) { - // Make the next tab active if there is one - // Note: the next tab is going to be the current tab after deletion - if(self.rows[j+1]) new_active_tab = self.rows[j].tab; - // Otherwise, make the previous tab active if there is one - else if(j) new_active_tab = self.rows[j-1].tab; - } - - return; // If this is the one we're deleting - } - newval.push(row); - }); - self.setValue(newval); - if(new_active_tab) { - self.active_tab = new_active_tab; - self.refreshTabs(); - } - - self.onChange(true); - }); - - if(controls_holder) { - controls_holder.appendChild(self.rows[i].delete_button); - } - } - - //Button to copy an array element and add it as last element - if(self.show_copy_button){ - self.rows[i].copy_button = this.getButton(self.getItemTitle(),'copy','Copy '+self.getItemTitle()); - self.rows[i].copy_button.className += ' copy'; - self.rows[i].copy_button.setAttribute('data-i',i); - self.rows[i].copy_button.addEventListener('click',function(e) { - var value = self.getValue(); - e.preventDefault(); - e.stopPropagation(); - var i = this.getAttribute('data-i')*1; - - $each(value,function(j,row) { - if(j===i) { - value.push(row); - return; - } - }); - - self.setValue(value); - self.refreshValue(true); - self.onChange(true); - - }); - - controls_holder.appendChild(self.rows[i].copy_button); - } - - - if(i && !self.hide_move_buttons) { - self.rows[i].moveup_button = this.getButton('','moveup',this.translate('button_move_up_title')); - self.rows[i].moveup_button.className += ' moveup'; - self.rows[i].moveup_button.setAttribute('data-i',i); - self.rows[i].moveup_button.addEventListener('click',function(e) { - e.preventDefault(); - e.stopPropagation(); - var i = this.getAttribute('data-i')*1; - - if(i<=0) return; - var rows = self.getValue(); - var tmp = rows[i-1]; - rows[i-1] = rows[i]; - rows[i] = tmp; - - self.setValue(rows); - self.active_tab = self.rows[i-1].tab; - self.refreshTabs(); - - self.onChange(true); - }); - - if(controls_holder) { - controls_holder.appendChild(self.rows[i].moveup_button); - } - } - - if(!self.hide_move_buttons) { - self.rows[i].movedown_button = this.getButton('','movedown',this.translate('button_move_down_title')); - self.rows[i].movedown_button.className += ' movedown'; - self.rows[i].movedown_button.setAttribute('data-i',i); - self.rows[i].movedown_button.addEventListener('click',function(e) { - e.preventDefault(); - e.stopPropagation(); - var i = this.getAttribute('data-i')*1; - - var rows = self.getValue(); - if(i>=rows.length-1) return; - var tmp = rows[i+1]; - rows[i+1] = rows[i]; - rows[i] = tmp; - - self.setValue(rows); - self.active_tab = self.rows[i+1].tab; - self.refreshTabs(); - self.onChange(true); - }); - - if(controls_holder) { - controls_holder.appendChild(self.rows[i].movedown_button); - } - } - - if(value) self.rows[i].setValue(value, initial); - self.refreshTabs(); - }, - addControls: function() { - var self = this; - - this.collapsed = false; - this.toggle_button = this.getButton('','collapse',this.translate('button_collapse')); - this.title_controls.appendChild(this.toggle_button); - var row_holder_display = self.row_holder.style.display; - var controls_display = self.controls.style.display; - this.toggle_button.addEventListener('click',function(e) { - e.preventDefault(); - e.stopPropagation(); - if(self.collapsed) { - self.collapsed = false; - if(self.panel) self.panel.style.display = ''; - self.row_holder.style.display = row_holder_display; - if(self.tabs_holder) self.tabs_holder.style.display = ''; - self.controls.style.display = controls_display; - self.setButtonText(this,'','collapse',self.translate('button_collapse')); - } - else { - self.collapsed = true; - self.row_holder.style.display = 'none'; - if(self.tabs_holder) self.tabs_holder.style.display = 'none'; - self.controls.style.display = 'none'; - if(self.panel) self.panel.style.display = 'none'; - self.setButtonText(this,'','expand',self.translate('button_expand')); - } - }); - - // If it should start collapsed - if(this.options.collapsed) { - $trigger(this.toggle_button,'click'); - } - - // Collapse button disabled - if(this.schema.options && typeof this.schema.options.disable_collapse !== "undefined") { - if(this.schema.options.disable_collapse) this.toggle_button.style.display = 'none'; - } - else if(this.jsoneditor.options.disable_collapse) { - this.toggle_button.style.display = 'none'; - } - - // Add "new row" and "delete last" buttons below editor - this.add_row_button = this.getButton(this.getItemTitle(),'add',this.translate('button_add_row_title',[this.getItemTitle()])); - - this.add_row_button.addEventListener('click',function(e) { - e.preventDefault(); - e.stopPropagation(); - var i = self.rows.length; - if(self.row_cache[i]) { - self.rows[i] = self.row_cache[i]; - self.rows[i].setValue(self.rows[i].getDefault(), true); - self.rows[i].container.style.display = ''; - if(self.rows[i].tab) self.rows[i].tab.style.display = ''; - self.rows[i].register(); - } - else { - self.addRow(); - } - self.active_tab = self.rows[i].tab; - self.refreshTabs(); - self.refreshValue(); - self.onChange(true); - }); - self.controls.appendChild(this.add_row_button); - - this.delete_last_row_button = this.getButton(this.translate('button_delete_last',[this.getItemTitle()]),'delete',this.translate('button_delete_last_title',[this.getItemTitle()])); - this.delete_last_row_button.addEventListener('click',function(e) { - e.preventDefault(); - e.stopPropagation(); - - if (self.jsoneditor.options.prompt_before_delete === true) { - if (confirm("Confirm to remove.") === false) { - return false; - } - } - - var rows = self.getValue(); - - var new_active_tab = null; - if(self.rows.length > 1 && self.rows[self.rows.length-1].tab === self.active_tab) new_active_tab = self.rows[self.rows.length-2].tab; - - rows.pop(); - self.setValue(rows); - if(new_active_tab) { - self.active_tab = new_active_tab; - self.refreshTabs(); - } - self.onChange(true); - }); - self.controls.appendChild(this.delete_last_row_button); - - this.remove_all_rows_button = this.getButton(this.translate('button_delete_all'),'delete',this.translate('button_delete_all_title')); - this.remove_all_rows_button.addEventListener('click',function(e) { - e.preventDefault(); - e.stopPropagation(); - - if (self.jsoneditor.options.prompt_before_delete === true) { - if (confirm("Confirm to remove.") === false) { - return false; - } - } - - self.setValue([]); - self.onChange(true); - }); - self.controls.appendChild(this.remove_all_rows_button); - - if(self.tabs) { - this.add_row_button.style.width = '100%'; - this.add_row_button.style.textAlign = 'left'; - this.add_row_button.style.marginBottom = '3px'; - - this.delete_last_row_button.style.width = '100%'; - this.delete_last_row_button.style.textAlign = 'left'; - this.delete_last_row_button.style.marginBottom = '3px'; - - this.remove_all_rows_button.style.width = '100%'; - this.remove_all_rows_button.style.textAlign = 'left'; - this.remove_all_rows_button.style.marginBottom = '3px'; - } - }, - showValidationErrors: function(errors) { - var self = this; - - // Get all the errors that pertain to this editor - var my_errors = []; - var other_errors = []; - $each(errors, function(i,error) { - if(error.path === self.path) { - my_errors.push(error); - } - else { - other_errors.push(error); - } - }); - - // Show errors for this editor - if(this.error_holder) { - if(my_errors.length) { - var message = []; - this.error_holder.innerHTML = ''; - this.error_holder.style.display = ''; - $each(my_errors, function(i,error) { - self.error_holder.appendChild(self.theme.getErrorMessage(error.message)); - }); - } - // Hide error area - else { - this.error_holder.style.display = 'none'; - } - } - - // Show errors for child editors - $each(this.rows, function(i,row) { - row.showValidationErrors(other_errors); - }); - } -}); - -JSONEditor.defaults.editors.table = JSONEditor.defaults.editors.array.extend({ - register: function() { - this._super(); - if(this.rows) { - for(var i=0; i<this.rows.length; i++) { - this.rows[i].register(); - } - } - }, - unregister: function() { - this._super(); - if(this.rows) { - for(var i=0; i<this.rows.length; i++) { - this.rows[i].unregister(); - } - } - }, - getNumColumns: function() { - return Math.max(Math.min(12,this.width),3); - }, - preBuild: function() { - var item_schema = this.jsoneditor.expandRefs(this.schema.items || {}); - - this.item_title = item_schema.title || 'row'; - this.item_default = item_schema["default"] || null; - this.item_has_child_editors = item_schema.properties || item_schema.items; - this.width = 12; - this._super(); - }, - build: function() { - var self = this; - this.table = this.theme.getTable(); - this.container.appendChild(this.table); - this.thead = this.theme.getTableHead(); - this.table.appendChild(this.thead); - this.header_row = this.theme.getTableRow(); - this.thead.appendChild(this.header_row); - this.row_holder = this.theme.getTableBody(); - this.table.appendChild(this.row_holder); - - // Determine the default value of array element - var tmp = this.getElementEditor(0,true); - this.item_default = tmp.getDefault(); - this.width = tmp.getNumColumns() + 2; - - if(!this.options.compact) { - this.title = this.theme.getHeader(this.getTitle()); - this.container.appendChild(this.title); - this.title_controls = this.theme.getHeaderButtonHolder(); - this.title.appendChild(this.title_controls); - if(this.schema.description) { - this.description = this.theme.getDescription(this.schema.description); - this.container.appendChild(this.description); - } - this.panel = this.theme.getIndentedPanel(); - this.container.appendChild(this.panel); - this.error_holder = document.createElement('div'); - this.panel.appendChild(this.error_holder); - } - else { - this.panel = document.createElement('div'); - this.container.appendChild(this.panel); - } - - this.panel.appendChild(this.table); - this.controls = this.theme.getButtonHolder(); - this.panel.appendChild(this.controls); - - if(this.item_has_child_editors) { - var ce = tmp.getChildEditors(); - var order = tmp.property_order || Object.keys(ce); - for(var i=0; i<order.length; i++) { - var th = self.theme.getTableHeaderCell(ce[order[i]].getTitle()); - if(ce[order[i]].options.hidden) th.style.display = 'none'; - self.header_row.appendChild(th); - } - } - else { - self.header_row.appendChild(self.theme.getTableHeaderCell(this.item_title)); - } - - tmp.destroy(); - this.row_holder.innerHTML = ''; - - // Row Controls column - this.controls_header_cell = self.theme.getTableHeaderCell(" "); - self.header_row.appendChild(this.controls_header_cell); - - // Add controls - this.addControls(); - }, - onChildEditorChange: function(editor) { - this.refreshValue(); - this._super(); - }, - getItemDefault: function() { - return $extend({},{"default":this.item_default})["default"]; - }, - getItemTitle: function() { - return this.item_title; - }, - getElementEditor: function(i,ignore) { - var schema_copy = $extend({},this.schema.items); - var editor = this.jsoneditor.getEditorClass(schema_copy, this.jsoneditor); - var row = this.row_holder.appendChild(this.theme.getTableRow()); - var holder = row; - if(!this.item_has_child_editors) { - holder = this.theme.getTableCell(); - row.appendChild(holder); - } - - var ret = this.jsoneditor.createEditor(editor,{ - jsoneditor: this.jsoneditor, - schema: schema_copy, - container: holder, - path: this.path+'.'+i, - parent: this, - compact: true, - table_row: true - }); - - ret.preBuild(); - if(!ignore) { - ret.build(); - ret.postBuild(); - - ret.controls_cell = row.appendChild(this.theme.getTableCell()); - ret.row = row; - ret.table_controls = this.theme.getButtonHolder(); - ret.controls_cell.appendChild(ret.table_controls); - ret.table_controls.style.margin = 0; - ret.table_controls.style.padding = 0; - } - - return ret; - }, - destroy: function() { - this.innerHTML = ''; - if(this.title && this.title.parentNode) this.title.parentNode.removeChild(this.title); - if(this.description && this.description.parentNode) this.description.parentNode.removeChild(this.description); - if(this.row_holder && this.row_holder.parentNode) this.row_holder.parentNode.removeChild(this.row_holder); - if(this.table && this.table.parentNode) this.table.parentNode.removeChild(this.table); - if(this.panel && this.panel.parentNode) this.panel.parentNode.removeChild(this.panel); - - this.rows = this.title = this.description = this.row_holder = this.table = this.panel = null; - - this._super(); - }, - setValue: function(value, initial) { - // Update the array's value, adding/removing rows when necessary - value = value || []; - - // Make sure value has between minItems and maxItems items in it - if(this.schema.minItems) { - while(value.length < this.schema.minItems) { - value.push(this.getItemDefault()); - } - } - if(this.schema.maxItems && value.length > this.schema.maxItems) { - value = value.slice(0,this.schema.maxItems); - } - - var serialized = JSON.stringify(value); - if(serialized === this.serialized) return; - - var numrows_changed = false; - - var self = this; - $each(value,function(i,val) { - if(self.rows[i]) { - // TODO: don't set the row's value if it hasn't changed - self.rows[i].setValue(val); - } - else { - self.addRow(val); - numrows_changed = true; - } - }); - - for(var j=value.length; j<self.rows.length; j++) { - var holder = self.rows[j].container; - if(!self.item_has_child_editors) { - self.rows[j].row.parentNode.removeChild(self.rows[j].row); - } - self.rows[j].destroy(); - if(holder.parentNode) holder.parentNode.removeChild(holder); - self.rows[j] = null; - numrows_changed = true; - } - self.rows = self.rows.slice(0,value.length); - - self.refreshValue(); - if(numrows_changed || initial) self.refreshRowButtons(); - - self.onChange(); - - // TODO: sortable - }, - refreshRowButtons: function() { - var self = this; - - // If we currently have minItems items in the array - var minItems = this.schema.minItems && this.schema.minItems >= this.rows.length; - - var need_row_buttons = false; - $each(this.rows,function(i,editor) { - // Hide the move down button for the last row - if(editor.movedown_button) { - if(i === self.rows.length - 1) { - editor.movedown_button.style.display = 'none'; - } - else { - need_row_buttons = true; - editor.movedown_button.style.display = ''; - } - } - - // Hide the delete button if we have minItems items - if(editor.delete_button) { - if(minItems) { - editor.delete_button.style.display = 'none'; - } - else { - need_row_buttons = true; - editor.delete_button.style.display = ''; - } - } - - if(editor.moveup_button) { - need_row_buttons = true; - } - }); - - // Show/hide controls column in table - $each(this.rows,function(i,editor) { - if(need_row_buttons) { - editor.controls_cell.style.display = ''; - } - else { - editor.controls_cell.style.display = 'none'; - } - }); - if(need_row_buttons) { - this.controls_header_cell.style.display = ''; - } - else { - this.controls_header_cell.style.display = 'none'; - } - - var controls_needed = false; - - if(!this.value.length) { - this.delete_last_row_button.style.display = 'none'; - this.remove_all_rows_button.style.display = 'none'; - this.table.style.display = 'none'; - } - else if(this.value.length === 1) { - this.table.style.display = ''; - this.remove_all_rows_button.style.display = 'none'; - - // If there are minItems items in the array, or configured to hide the delete_last_row button, hide the delete button beneath the rows - if(minItems || this.hide_delete_last_row_buttons) { - this.delete_last_row_button.style.display = 'none'; - } - else { - this.delete_last_row_button.style.display = ''; - controls_needed = true; - } - } - else { - this.table.style.display = ''; - - if(minItems || this.hide_delete_last_row_buttons) { - this.delete_last_row_button.style.display = 'none'; - } - else { - this.delete_last_row_button.style.display = ''; - controls_needed = true; - } - - if(minItems || this.hide_delete_all_rows_buttons) { - this.remove_all_rows_button.style.display = 'none'; - } - else { - this.remove_all_rows_button.style.display = ''; - controls_needed = true; - } - } - - // If there are maxItems in the array, hide the add button beneath the rows - if((this.schema.maxItems && this.schema.maxItems <= this.rows.length) || this.hide_add_button) { - this.add_row_button.style.display = 'none'; - } - else { - this.add_row_button.style.display = ''; - controls_needed = true; - } - - if(!controls_needed) { - this.controls.style.display = 'none'; - } - else { - this.controls.style.display = ''; - } - }, - refreshValue: function() { - var self = this; - this.value = []; - - $each(this.rows,function(i,editor) { - // Get the value for this editor - self.value[i] = editor.getValue(); - }); - this.serialized = JSON.stringify(this.value); - }, - addRow: function(value) { - var self = this; - var i = this.rows.length; - - self.rows[i] = this.getElementEditor(i); - - var controls_holder = self.rows[i].table_controls; - - // Buttons to delete row, move row up, and move row down - if(!this.hide_delete_buttons) { - self.rows[i].delete_button = this.getButton('','delete',this.translate('button_delete_row_title_short')); - self.rows[i].delete_button.className += ' delete'; - self.rows[i].delete_button.setAttribute('data-i',i); - self.rows[i].delete_button.addEventListener('click',function(e) { - e.preventDefault(); - e.stopPropagation(); - var i = this.getAttribute('data-i')*1; - - var value = self.getValue(); - - var newval = []; - $each(value,function(j,row) { - if(j===i) return; // If this is the one we're deleting - newval.push(row); - }); - self.setValue(newval); - self.onChange(true); - }); - controls_holder.appendChild(self.rows[i].delete_button); - } - - - if(i && !this.hide_move_buttons) { - self.rows[i].moveup_button = this.getButton('','moveup',this.translate('button_move_up_title')); - self.rows[i].moveup_button.className += ' moveup'; - self.rows[i].moveup_button.setAttribute('data-i',i); - self.rows[i].moveup_button.addEventListener('click',function(e) { - e.preventDefault(); - e.stopPropagation(); - var i = this.getAttribute('data-i')*1; - - if(i<=0) return; - var rows = self.getValue(); - var tmp = rows[i-1]; - rows[i-1] = rows[i]; - rows[i] = tmp; - - self.setValue(rows); - self.onChange(true); - }); - controls_holder.appendChild(self.rows[i].moveup_button); - } - - if(!this.hide_move_buttons) { - self.rows[i].movedown_button = this.getButton('','movedown',this.translate('button_move_down_title')); - self.rows[i].movedown_button.className += ' movedown'; - self.rows[i].movedown_button.setAttribute('data-i',i); - self.rows[i].movedown_button.addEventListener('click',function(e) { - e.preventDefault(); - e.stopPropagation(); - var i = this.getAttribute('data-i')*1; - var rows = self.getValue(); - if(i>=rows.length-1) return; - var tmp = rows[i+1]; - rows[i+1] = rows[i]; - rows[i] = tmp; - - self.setValue(rows); - self.onChange(true); - }); - controls_holder.appendChild(self.rows[i].movedown_button); - } - - if(value) self.rows[i].setValue(value); - }, - addControls: function() { - var self = this; - - this.collapsed = false; - this.toggle_button = this.getButton('','collapse',this.translate('button_collapse')); - if(this.title_controls) { - this.title_controls.appendChild(this.toggle_button); - this.toggle_button.addEventListener('click',function(e) { - e.preventDefault(); - e.stopPropagation(); - - if(self.collapsed) { - self.collapsed = false; - self.panel.style.display = ''; - self.setButtonText(this,'','collapse',self.translate('button_collapse')); - } - else { - self.collapsed = true; - self.panel.style.display = 'none'; - self.setButtonText(this,'','expand',self.translate('button_expand')); - } - }); - - // If it should start collapsed - if(this.options.collapsed) { - $trigger(this.toggle_button,'click'); - } - - // Collapse button disabled - if(this.schema.options && typeof this.schema.options.disable_collapse !== "undefined") { - if(this.schema.options.disable_collapse) this.toggle_button.style.display = 'none'; - } - else if(this.jsoneditor.options.disable_collapse) { - this.toggle_button.style.display = 'none'; - } - } - - // Add "new row" and "delete last" buttons below editor - this.add_row_button = this.getButton(this.getItemTitle(),'add',this.translate('button_add_row_title',[this.getItemTitle()])); - this.add_row_button.addEventListener('click',function(e) { - e.preventDefault(); - e.stopPropagation(); - - self.addRow(); - self.refreshValue(); - self.refreshRowButtons(); - self.onChange(true); - }); - self.controls.appendChild(this.add_row_button); - - this.delete_last_row_button = this.getButton(this.translate('button_delete_last',[this.getItemTitle()]),'delete',this.translate('button_delete_last_title',[this.getItemTitle()])); - this.delete_last_row_button.addEventListener('click',function(e) { - e.preventDefault(); - e.stopPropagation(); - - var rows = self.getValue(); - rows.pop(); - self.setValue(rows); - self.onChange(true); - }); - self.controls.appendChild(this.delete_last_row_button); - - this.remove_all_rows_button = this.getButton(this.translate('button_delete_all'),'delete',this.translate('button_delete_all_title')); - this.remove_all_rows_button.addEventListener('click',function(e) { - e.preventDefault(); - e.stopPropagation(); - - self.setValue([]); - self.onChange(true); - }); - self.controls.appendChild(this.remove_all_rows_button); - } -}); - -// Multiple Editor (for when `type` is an array, also when `oneOf` is present) -JSONEditor.defaults.editors.multiple = JSONEditor.AbstractEditor.extend({ - register: function() { - if(this.editors) { - for(var i=0; i<this.editors.length; i++) { - if(!this.editors[i]) continue; - this.editors[i].unregister(); - } - if(this.editors[this.type]) this.editors[this.type].register(); - } - this._super(); - }, - unregister: function() { - this._super(); - if(this.editors) { - for(var i=0; i<this.editors.length; i++) { - if(!this.editors[i]) continue; - this.editors[i].unregister(); - } - } - }, - getNumColumns: function() { - if(!this.editors[this.type]) return 4; - return Math.max(this.editors[this.type].getNumColumns(),4); - }, - enable: function() { - if(!this.always_disabled) { - if(this.editors) { - for(var i=0; i<this.editors.length; i++) { - if(!this.editors[i]) continue; - this.editors[i].enable(); - } - } - this.switcher.disabled = false; - this._super(); - } - }, - disable: function(always_disabled) { - if(always_disabled) this.always_disabled = true; - if(this.editors) { - for(var i=0; i<this.editors.length; i++) { - if(!this.editors[i]) continue; - this.editors[i].disable(always_disabled); - } - } - this.switcher.disabled = true; - this._super(); - }, - switchEditor: function(i) { - var self = this; - - if(!this.editors[i]) { - this.buildChildEditor(i); - } - - var current_value = self.getValue(); - - self.type = i; - - self.register(); - - $each(self.editors,function(type,editor) { - if(!editor) return; - if(self.type === type) { - if(self.keep_values) editor.setValue(current_value,true); - editor.container.style.display = ''; - } - else editor.container.style.display = 'none'; - }); - self.refreshValue(); - self.refreshHeaderText(); - }, - buildChildEditor: function(i) { - var self = this; - var type = this.types[i]; - var holder = self.theme.getChildEditorHolder(); - self.editor_holder.appendChild(holder); - - var schema; - - if(typeof type === "string") { - schema = $extend({},self.schema); - schema.type = type; - } - else { - schema = $extend({},self.schema,type); - schema = self.jsoneditor.expandRefs(schema); - - // If we need to merge `required` arrays - if(type && type.required && Array.isArray(type.required) && self.schema.required && Array.isArray(self.schema.required)) { - schema.required = self.schema.required.concat(type.required); - } - } - - var editor = self.jsoneditor.getEditorClass(schema); - - self.editors[i] = self.jsoneditor.createEditor(editor,{ - jsoneditor: self.jsoneditor, - schema: schema, - container: holder, - path: self.path, - parent: self, - required: true - }); - self.editors[i].preBuild(); - self.editors[i].build(); - self.editors[i].postBuild(); - - if(self.editors[i].header) self.editors[i].header.style.display = 'none'; - - self.editors[i].option = self.switcher_options[i]; - - holder.addEventListener('change_header_text',function() { - self.refreshHeaderText(); - }); - - if(i !== self.type) holder.style.display = 'none'; - }, - preBuild: function() { - var self = this; - - this.types = []; - this.type = 0; - this.editors = []; - this.validators = []; - - this.keep_values = true; - if(typeof this.jsoneditor.options.keep_oneof_values !== "undefined") this.keep_values = this.jsoneditor.options.keep_oneof_values; - if(typeof this.options.keep_oneof_values !== "undefined") this.keep_values = this.options.keep_oneof_values; - - if(this.schema.oneOf) { - this.oneOf = true; - this.types = this.schema.oneOf; - delete this.schema.oneOf; - } - else if(this.schema.anyOf) { - this.anyOf = true; - this.types = this.schema.anyOf; - delete this.schema.anyOf; - } - else { - if(!this.schema.type || this.schema.type === "any") { - this.types = ['string','number','integer','boolean','object','array','null']; - - // If any of these primitive types are disallowed - if(this.schema.disallow) { - var disallow = this.schema.disallow; - if(typeof disallow !== 'object' || !(Array.isArray(disallow))) { - disallow = [disallow]; - } - var allowed_types = []; - $each(this.types,function(i,type) { - if(disallow.indexOf(type) === -1) allowed_types.push(type); - }); - this.types = allowed_types; - } - } - else if(Array.isArray(this.schema.type)) { - this.types = this.schema.type; - } - else { - this.types = [this.schema.type]; - } - delete this.schema.type; - } - - this.display_text = this.getDisplayText(this.types); - }, - build: function() { - var self = this; - var container = this.container; - - this.header = this.label = this.theme.getFormInputLabel(this.getTitle()); - this.container.appendChild(this.header); - - this.switcher = this.theme.getSwitcher(this.display_text); - container.appendChild(this.switcher); - this.switcher.addEventListener('change',function(e) { - e.preventDefault(); - e.stopPropagation(); - - self.switchEditor(self.display_text.indexOf(this.value)); - self.onChange(true); - }); - - this.editor_holder = document.createElement('div'); - container.appendChild(this.editor_holder); - - - var validator_options = {}; - if(self.jsoneditor.options.custom_validators) { - validator_options.custom_validators = self.jsoneditor.options.custom_validators; - } - - this.switcher_options = this.theme.getSwitcherOptions(this.switcher); - $each(this.types,function(i,type) { - self.editors[i] = false; - - var schema; - - if(typeof type === "string") { - schema = $extend({},self.schema); - schema.type = type; - } - else { - schema = $extend({},self.schema,type); - - // If we need to merge `required` arrays - if(type.required && Array.isArray(type.required) && self.schema.required && Array.isArray(self.schema.required)) { - schema.required = self.schema.required.concat(type.required); - } - } - - self.validators[i] = new JSONEditor.Validator(self.jsoneditor,schema,validator_options); - }); - - this.switchEditor(0); - }, - onChildEditorChange: function(editor) { - if(this.editors[this.type]) { - this.refreshValue(); - this.refreshHeaderText(); - } - - this._super(); - }, - refreshHeaderText: function() { - var display_text = this.getDisplayText(this.types); - $each(this.switcher_options, function(i,option) { - option.textContent = display_text[i]; - }); - }, - refreshValue: function() { - this.value = this.editors[this.type].getValue(); - }, - setValue: function(val,initial) { - // Determine type by getting the first one that validates - var self = this; - var prev_type = this.type; - $each(this.validators, function(i,validator) { - if(!validator.validate(val).length) { - self.type = i; - self.switcher.value = self.display_text[i]; - return false; - } - }); - - var type_changed = this.type != prev_type; - if (type_changed) { - this.switchEditor(this.type); - } - - this.editors[this.type].setValue(val,initial); - - this.refreshValue(); - self.onChange(type_changed); - }, - destroy: function() { - $each(this.editors, function(type,editor) { - if(editor) editor.destroy(); - }); - if(this.editor_holder && this.editor_holder.parentNode) this.editor_holder.parentNode.removeChild(this.editor_holder); - if(this.switcher && this.switcher.parentNode) this.switcher.parentNode.removeChild(this.switcher); - this._super(); - }, - showValidationErrors: function(errors) { - var self = this; - - // oneOf and anyOf error paths need to remove the oneOf[i] part before passing to child editors - if(this.oneOf || this.anyOf) { - var check_part = this.oneOf? 'oneOf' : 'anyOf'; - $each(this.editors,function(i,editor) { - if(!editor) return; - var check = self.path+'.'+check_part+'['+i+']'; - var new_errors = []; - $each(errors, function(j,error) { - if(error.path.substr(0,check.length)===check) { - var new_error = $extend({},error); - new_error.path = self.path+new_error.path.substr(check.length); - new_errors.push(new_error); - } - }); - - editor.showValidationErrors(new_errors); - }); - } - else { - $each(this.editors,function(type,editor) { - if(!editor) return; - editor.showValidationErrors(errors); - }); - } - } -}); - -// Enum Editor (used for objects and arrays with enumerated values) -JSONEditor.defaults.editors["enum"] = JSONEditor.AbstractEditor.extend({ - getNumColumns: function() { - return 4; - }, - build: function() { - var container = this.container; - this.title = this.header = this.label = this.theme.getFormInputLabel(this.getTitle()); - this.container.appendChild(this.title); - - this.options.enum_titles = this.options.enum_titles || []; - - this["enum"] = this.schema["enum"]; - this.selected = 0; - this.select_options = []; - this.html_values = []; - - var self = this; - for(var i=0; i<this["enum"].length; i++) { - this.select_options[i] = this.options.enum_titles[i] || "Value "+(i+1); - this.html_values[i] = this.getHTML(this["enum"][i]); - } - - // Switcher - this.switcher = this.theme.getSwitcher(this.select_options); - this.container.appendChild(this.switcher); - - // Display area - this.display_area = this.theme.getIndentedPanel(); - this.container.appendChild(this.display_area); - - if(this.options.hide_display) this.display_area.style.display = "none"; - - this.switcher.addEventListener('change',function() { - self.selected = self.select_options.indexOf(this.value); - self.value = self["enum"][self.selected]; - self.refreshValue(); - self.onChange(true); - }); - this.value = this["enum"][0]; - this.refreshValue(); - - if(this["enum"].length === 1) this.switcher.style.display = 'none'; - }, - refreshValue: function() { - var self = this; - self.selected = -1; - var stringified = JSON.stringify(this.value); - $each(this["enum"], function(i, el) { - if(stringified === JSON.stringify(el)) { - self.selected = i; - return false; - } - }); - - if(self.selected<0) { - self.setValue(self["enum"][0]); - return; - } - - this.switcher.value = this.select_options[this.selected]; - this.display_area.innerHTML = this.html_values[this.selected]; - }, - enable: function() { - if(!this.always_disabled) { - this.switcher.disabled = false; - this._super(); - } - }, - disable: function(always_disabled) { - if(always_disabled) this.always_disabled = true; - this.switcher.disabled = true; - this._super(); - }, - getHTML: function(el) { - var self = this; - - if(el === null) { - return '<em>null</em>'; - } - // Array or Object - else if(typeof el === "object") { - // TODO: use theme - var ret = ''; - - $each(el,function(i,child) { - var html = self.getHTML(child); - - // Add the keys to object children - if(!(Array.isArray(el))) { - // TODO: use theme - html = '<div><em>'+i+'</em>: '+html+'</div>'; - } - - // TODO: use theme - ret += '<li>'+html+'</li>'; - }); - - if(Array.isArray(el)) ret = '<ol>'+ret+'</ol>'; - else ret = "<ul style='margin-top:0;margin-bottom:0;padding-top:0;padding-bottom:0;'>"+ret+'</ul>'; - - return ret; - } - // Boolean - else if(typeof el === "boolean") { - return el? 'true' : 'false'; - } - // String - else if(typeof el === "string") { - return el.replace(/&/g,'&').replace(/</g,'<').replace(/>/g,'>'); - } - // Number - else { - return el; - } - }, - setValue: function(val) { - if(this.value !== val) { - this.value = val; - this.refreshValue(); - this.onChange(); - } - }, - destroy: function() { - if(this.display_area && this.display_area.parentNode) this.display_area.parentNode.removeChild(this.display_area); - if(this.title && this.title.parentNode) this.title.parentNode.removeChild(this.title); - if(this.switcher && this.switcher.parentNode) this.switcher.parentNode.removeChild(this.switcher); - - this._super(); - } -}); - -JSONEditor.defaults.editors.select = JSONEditor.AbstractEditor.extend({ - setValue: function(value,initial) { - value = this.typecast(value||''); - - // Sanitize value before setting it - var sanitized = value; - if(this.enum_values.indexOf(sanitized) < 0) { - sanitized = this.enum_values[0]; - } - - if(this.value === sanitized) { - return; - } - - this.input.value = this.enum_options[this.enum_values.indexOf(sanitized)]; - if(this.select2) { - if(this.select2v4) - this.select2.val(this.input.value).trigger("change"); - else - this.select2.select2('val',this.input.value); - } - this.value = sanitized; - this.onChange(); - this.change(); - }, - register: function() { - this._super(); - if(!this.input) return; - this.input.setAttribute('name',this.formname); - }, - unregister: function() { - this._super(); - if(!this.input) return; - this.input.removeAttribute('name'); - }, - getNumColumns: function() { - if(!this.enum_options) return 3; - var longest_text = this.getTitle().length; - for(var i=0; i<this.enum_options.length; i++) { - longest_text = Math.max(longest_text,this.enum_options[i].length+4); - } - return Math.min(12,Math.max(longest_text/7,2)); - }, - typecast: function(value) { - if(this.schema.type === "boolean") { - return !!value; - } - else if(this.schema.type === "number") { - return 1*value; - } - else if(this.schema.type === "integer") { - return Math.floor(value*1); - } - else { - return ""+value; - } - }, - getValue: function() { - if (!this.dependenciesFulfilled) { - return undefined; - } - return this.typecast(this.value); - }, - preBuild: function() { - var self = this; - this.input_type = 'select'; - this.enum_options = []; - this.enum_values = []; - this.enum_display = []; - var i; - - // Enum options enumerated - if(this.schema["enum"]) { - var display = this.schema.options && this.schema.options.enum_titles || []; - - $each(this.schema["enum"],function(i,option) { - self.enum_options[i] = ""+option; - self.enum_display[i] = ""+(display[i] || option); - self.enum_values[i] = self.typecast(option); - }); - - if(!this.isRequired()){ - self.enum_display.unshift(' '); - self.enum_options.unshift('undefined'); - self.enum_values.unshift(undefined); - } - - } - // Boolean - else if(this.schema.type === "boolean") { - self.enum_display = this.schema.options && this.schema.options.enum_titles || ['true','false']; - self.enum_options = ['1','']; - self.enum_values = [true,false]; - - if(!this.isRequired()){ - self.enum_display.unshift(' '); - self.enum_options.unshift('undefined'); - self.enum_values.unshift(undefined); - } - - } - // Dynamic Enum - else if(this.schema.enumSource) { - this.enumSource = []; - this.enum_display = []; - this.enum_options = []; - this.enum_values = []; - - // Shortcut declaration for using a single array - if(!(Array.isArray(this.schema.enumSource))) { - if(this.schema.enumValue) { - this.enumSource = [ - { - source: this.schema.enumSource, - value: this.schema.enumValue - } - ]; - } - else { - this.enumSource = [ - { - source: this.schema.enumSource - } - ]; - } - } - else { - for(i=0; i<this.schema.enumSource.length; i++) { - // Shorthand for watched variable - if(typeof this.schema.enumSource[i] === "string") { - this.enumSource[i] = { - source: this.schema.enumSource[i] - }; - } - // Make a copy of the schema - else if(!(Array.isArray(this.schema.enumSource[i]))) { - this.enumSource[i] = $extend({},this.schema.enumSource[i]); - } - else { - this.enumSource[i] = this.schema.enumSource[i]; - } - } - } - - // Now, enumSource is an array of sources - // Walk through this array and fix up the values - for(i=0; i<this.enumSource.length; i++) { - if(this.enumSource[i].value) { - this.enumSource[i].value = this.jsoneditor.compileTemplate(this.enumSource[i].value, this.template_engine); - } - if(this.enumSource[i].title) { - this.enumSource[i].title = this.jsoneditor.compileTemplate(this.enumSource[i].title, this.template_engine); - } - if(this.enumSource[i].filter) { - this.enumSource[i].filter = this.jsoneditor.compileTemplate(this.enumSource[i].filter, this.template_engine); - } - } - } - // Other, not supported - else { - throw "'select' editor requires the enum property to be set."; - } - }, - build: function() { - var self = this; - if(!this.options.compact) this.header = this.label = this.theme.getFormInputLabel(this.getTitle()); - if(this.schema.description) this.description = this.theme.getFormInputDescription(this.schema.description); - if(this.options.infoText) this.infoButton = this.theme.getInfoButton(this.options.infoText); - if(this.options.compact) this.container.className += ' compact'; - - this.input = this.theme.getSelectInput(this.enum_options); - this.theme.setSelectOptions(this.input,this.enum_options,this.enum_display); - - if(this.schema.readOnly || this.schema.readonly) { - this.always_disabled = true; - this.input.disabled = true; - } - - this.input.addEventListener('change',function(e) { - e.preventDefault(); - e.stopPropagation(); - self.onInputChange(); - }); - - this.control = this.theme.getFormControl(this.label, this.input, this.description, this.infoButton); - this.input.controlgroup = this.control; - this.container.appendChild(this.control); - - this.value = this.enum_values[0]; - }, - onInputChange: function() { - var val = this.typecast(this.input.value); - - var new_val; - // Invalid option, use first option instead - if(this.enum_options.indexOf(val) === -1) { - new_val = this.enum_values[0]; - } - else { - new_val = this.enum_values[this.enum_options.indexOf(val)]; - } - - // If valid hasn't changed - if(new_val === this.value) return; - - // Store new value and propogate change event - this.value = new_val; - this.onChange(true); - }, - setupSelect2: function() { - // If the Select2 library is loaded use it when we have lots of items - if(window.jQuery && window.jQuery.fn && window.jQuery.fn.select2 && (this.enum_options.length > 2 || (this.enum_options.length && this.enumSource))) { - var options = $extend({},JSONEditor.plugins.select2); - if(this.schema.options && this.schema.options.select2_options) options = $extend(options,this.schema.options.select2_options); - this.select2 = window.jQuery(this.input).select2(options); - this.select2v4 = this.select2.select2.hasOwnProperty("amd"); - - var self = this; - this.select2.on('select2-blur',function() { - if(self.select2v4) - self.input.value = self.select2.val(); - else - self.input.value = self.select2.select2('val'); - - self.onInputChange(); - }); - - this.select2.on('change',function() { - if(self.select2v4) - self.input.value = self.select2.val(); - else - self.input.value = self.select2.select2('val'); - - self.onInputChange(); - }); - } - else { - this.select2 = null; - } - }, - postBuild: function() { - this._super(); - this.theme.afterInputReady(this.input); - this.setupSelect2(); - }, - onWatchedFieldChange: function() { - var self = this, vars, j; - - // If this editor uses a dynamic select box - if(this.enumSource) { - vars = this.getWatchedFieldValues(); - var select_options = []; - var select_titles = []; - - for(var i=0; i<this.enumSource.length; i++) { - // Constant values - if(Array.isArray(this.enumSource[i])) { - select_options = select_options.concat(this.enumSource[i]); - select_titles = select_titles.concat(this.enumSource[i]); - } - else { - var items = []; - // Static list of items - if(Array.isArray(this.enumSource[i].source)) { - items = this.enumSource[i].source; - // A watched field - } else { - items = vars[this.enumSource[i].source]; - } - - if(items) { - // Only use a predefined part of the array - if(this.enumSource[i].slice) { - items = Array.prototype.slice.apply(items,this.enumSource[i].slice); - } - // Filter the items - if(this.enumSource[i].filter) { - var new_items = []; - for(j=0; j<items.length; j++) { - if(this.enumSource[i].filter({i:j,item:items[j],watched:vars})) new_items.push(items[j]); - } - items = new_items; - } - - var item_titles = []; - var item_values = []; - for(j=0; j<items.length; j++) { - var item = items[j]; - - // Rendered value - if(this.enumSource[i].value) { - item_values[j] = this.enumSource[i].value({ - i: j, - item: item - }); - } - // Use value directly - else { - item_values[j] = items[j]; - } - - // Rendered title - if(this.enumSource[i].title) { - item_titles[j] = this.enumSource[i].title({ - i: j, - item: item - }); - } - // Use value as the title also - else { - item_titles[j] = item_values[j]; - } - } - - // TODO: sort - - select_options = select_options.concat(item_values); - select_titles = select_titles.concat(item_titles); - } - } - } - - var prev_value = this.value; - - this.theme.setSelectOptions(this.input, select_options, select_titles); - this.enum_options = select_options; - this.enum_display = select_titles; - this.enum_values = select_options; - - if(this.select2) { - this.select2.select2('destroy'); - } - - // If the previous value is still in the new select options, stick with it - if(select_options.indexOf(prev_value) !== -1) { - this.input.value = prev_value; - this.value = prev_value; - } - // Otherwise, set the value to the first select option - else { - this.input.value = select_options[0]; - this.value = this.typecast(select_options[0] || ""); - if(this.parent) this.parent.onChildEditorChange(this); - else this.jsoneditor.onChange(); - this.jsoneditor.notifyWatchers(this.path); - } - - this.setupSelect2(); - } - - this._super(); - }, - enable: function() { - if(!this.always_disabled) { - this.input.disabled = false; - if(this.select2) { - if(this.select2v4) - this.select2.prop("disabled",false); - else - this.select2.select2("enable",true); - } - } - this._super(); - }, - disable: function(always_disabled) { - if(always_disabled) this.always_disabled = true; - this.input.disabled = true; - if(this.select2) { - if(this.select2v4) - this.select2.prop("disabled",true); - else - this.select2.select2("enable",false); - } - this._super(); - }, - destroy: function() { - if(this.label && this.label.parentNode) this.label.parentNode.removeChild(this.label); - if(this.description && this.description.parentNode) this.description.parentNode.removeChild(this.description); - if(this.input && this.input.parentNode) this.input.parentNode.removeChild(this.input); - if(this.select2) { - this.select2.select2('destroy'); - this.select2 = null; - } - - this._super(); - }, - showValidationErrors: function (errors) { - var self = this; - - if (this.jsoneditor.options.show_errors === "always") {} - else if (!this.is_dirty && this.previous_error_setting === this.jsoneditor.options.show_errors) { - return; - } - - this.previous_error_setting = this.jsoneditor.options.show_errors; - - var messages = []; - $each(errors, function (i, error) { - if (error.path === self.path) { - messages.push(error.message); - } - }); - - this.input.controlgroup = this.control; - - if (messages.length) { - this.theme.addInputError(this.input, messages.join('. ') + '.'); - } - else { - this.theme.removeInputError(this.input); - } - } -}); - -JSONEditor.defaults.editors.selectize = JSONEditor.AbstractEditor.extend({ - setValue: function(value,initial) { - value = this.typecast(value||''); - - // Sanitize value before setting it - var sanitized = value; - if(this.enum_values.indexOf(sanitized) < 0) { - sanitized = this.enum_values[0]; - } - - if(this.value === sanitized) { - return; - } - - this.input.value = this.enum_options[this.enum_values.indexOf(sanitized)]; - - if(this.selectize) { - this.selectize[0].selectize.addItem(sanitized); - } - - this.value = sanitized; - this.onChange(); - }, - register: function() { - this._super(); - if(!this.input) return; - this.input.setAttribute('name',this.formname); - }, - unregister: function() { - this._super(); - if(!this.input) return; - this.input.removeAttribute('name'); - }, - getNumColumns: function() { - if(!this.enum_options) return 3; - var longest_text = this.getTitle().length; - for(var i=0; i<this.enum_options.length; i++) { - longest_text = Math.max(longest_text,this.enum_options[i].length+4); - } - return Math.min(12,Math.max(longest_text/7,2)); - }, - typecast: function(value) { - if(this.schema.type === "boolean") { - return !!value; - } - else if(this.schema.type === "number") { - return 1*value; - } - else if(this.schema.type === "integer") { - return Math.floor(value*1); - } - else { - return ""+value; - } - }, - getValue: function() { - if (!this.dependenciesFulfilled) { - return undefined; - } - return this.value; - }, - preBuild: function() { - var self = this; - this.input_type = 'select'; - this.enum_options = []; - this.enum_values = []; - this.enum_display = []; - var i; - - // Enum options enumerated - if(this.schema.enum) { - var display = this.schema.options && this.schema.options.enum_titles || []; - - $each(this.schema.enum,function(i,option) { - self.enum_options[i] = ""+option; - self.enum_display[i] = ""+(display[i] || option); - self.enum_values[i] = self.typecast(option); - }); - } - // Boolean - else if(this.schema.type === "boolean") { - self.enum_display = this.schema.options && this.schema.options.enum_titles || ['true','false']; - self.enum_options = ['1','0']; - self.enum_values = [true,false]; - } - // Dynamic Enum - else if(this.schema.enumSource) { - this.enumSource = []; - this.enum_display = []; - this.enum_options = []; - this.enum_values = []; - - // Shortcut declaration for using a single array - if(!(Array.isArray(this.schema.enumSource))) { - if(this.schema.enumValue) { - this.enumSource = [ - { - source: this.schema.enumSource, - value: this.schema.enumValue - } - ]; - } - else { - this.enumSource = [ - { - source: this.schema.enumSource - } - ]; - } - } - else { - for(i=0; i<this.schema.enumSource.length; i++) { - // Shorthand for watched variable - if(typeof this.schema.enumSource[i] === "string") { - this.enumSource[i] = { - source: this.schema.enumSource[i] - }; - } - // Make a copy of the schema - else if(!(Array.isArray(this.schema.enumSource[i]))) { - this.enumSource[i] = $extend({},this.schema.enumSource[i]); - } - else { - this.enumSource[i] = this.schema.enumSource[i]; - } - } - } - - // Now, enumSource is an array of sources - // Walk through this array and fix up the values - for(i=0; i<this.enumSource.length; i++) { - if(this.enumSource[i].value) { - this.enumSource[i].value = this.jsoneditor.compileTemplate(this.enumSource[i].value, this.template_engine); - } - if(this.enumSource[i].title) { - this.enumSource[i].title = this.jsoneditor.compileTemplate(this.enumSource[i].title, this.template_engine); - } - if(this.enumSource[i].filter) { - this.enumSource[i].filter = this.jsoneditor.compileTemplate(this.enumSource[i].filter, this.template_engine); - } - } - } - // Other, not supported - else { - throw "'select' editor requires the enum property to be set."; - } - }, - build: function() { - var self = this; - if(!this.options.compact) this.header = this.label = this.theme.getFormInputLabel(this.getTitle()); - if(this.schema.description) this.description = this.theme.getFormInputDescription(this.schema.description); - if(this.options.infoText) this.infoButton = this.theme.getInfoButton(this.options.infoText); - - if(this.options.compact) this.container.className += ' compact'; - - this.input = this.theme.getSelectInput(this.enum_options); - this.theme.setSelectOptions(this.input,this.enum_options,this.enum_display); - - if(this.schema.readOnly || this.schema.readonly) { - this.always_disabled = true; - this.input.disabled = true; - } - - this.input.addEventListener('change',function(e) { - e.preventDefault(); - e.stopPropagation(); - self.onInputChange(); - }); - - this.control = this.theme.getFormControl(this.label, this.input, this.description, this.infoButton); - this.container.appendChild(this.control); - - this.value = this.enum_values[0]; - }, - onInputChange: function() { - //console.log("onInputChange"); - var val = this.input.value; - - var sanitized = val; - if(this.enum_options.indexOf(val) === -1) { - sanitized = this.enum_options[0]; - } - - //this.value = this.enum_values[this.enum_options.indexOf(val)]; - this.value = val; - this.onChange(true); - }, - setupSelectize: function() { - // If the Selectize library is loaded use it when we have lots of items - var self = this; - if(window.jQuery && window.jQuery.fn && window.jQuery.fn.selectize && (this.enum_options.length >= 2 || (this.enum_options.length && this.enumSource))) { - var options = $extend({},JSONEditor.plugins.selectize); - if(this.schema.options && this.schema.options.selectize_options) options = $extend(options,this.schema.options.selectize_options); - this.selectize = window.jQuery(this.input).selectize($extend(options, - { - // set the create option to true by default, or to the user specified value if defined - create: ( options.create === undefined ? true : options.create), - onChange : function() { - self.onInputChange(); - } - })); - } - else { - this.selectize = null; - } - }, - postBuild: function() { - this._super(); - this.theme.afterInputReady(this.input); - this.setupSelectize(); - }, - onWatchedFieldChange: function() { - var self = this, vars, j; - - // If this editor uses a dynamic select box - if(this.enumSource) { - vars = this.getWatchedFieldValues(); - var select_options = []; - var select_titles = []; - - for(var i=0; i<this.enumSource.length; i++) { - // Constant values - if(Array.isArray(this.enumSource[i])) { - select_options = select_options.concat(this.enumSource[i]); - select_titles = select_titles.concat(this.enumSource[i]); - } - // A watched field - else if(vars[this.enumSource[i].source]) { - var items = vars[this.enumSource[i].source]; - - // Only use a predefined part of the array - if(this.enumSource[i].slice) { - items = Array.prototype.slice.apply(items,this.enumSource[i].slice); - } - // Filter the items - if(this.enumSource[i].filter) { - var new_items = []; - for(j=0; j<items.length; j++) { - if(this.enumSource[i].filter({i:j,item:items[j]})) new_items.push(items[j]); - } - items = new_items; - } - - var item_titles = []; - var item_values = []; - for(j=0; j<items.length; j++) { - var item = items[j]; - - // Rendered value - if(this.enumSource[i].value) { - item_values[j] = this.enumSource[i].value({ - i: j, - item: item - }); - } - // Use value directly - else { - item_values[j] = items[j]; - } - - // Rendered title - if(this.enumSource[i].title) { - item_titles[j] = this.enumSource[i].title({ - i: j, - item: item - }); - } - // Use value as the title also - else { - item_titles[j] = item_values[j]; - } - } - - // TODO: sort - - select_options = select_options.concat(item_values); - select_titles = select_titles.concat(item_titles); - } - } - - var prev_value = this.value; - - // Check to see if this item is in the list - // Note: We have to skip empty string for watch lists to work properly - if ((prev_value !== undefined) && (prev_value !== "") && (select_options.indexOf(prev_value) === -1)) { - // item is not in the list. Add it. - select_options = select_options.concat(prev_value); - select_titles = select_titles.concat(prev_value); - } - - this.theme.setSelectOptions(this.input, select_options, select_titles); - this.enum_options = select_options; - this.enum_display = select_titles; - this.enum_values = select_options; - - // If the previous value is still in the new select options, stick with it - if(select_options.indexOf(prev_value) !== -1) { - this.input.value = prev_value; - this.value = prev_value; - } - - // Otherwise, set the value to the first select option - else { - this.input.value = select_options[0]; - this.value = select_options[0] || ""; - if(this.parent) this.parent.onChildEditorChange(this); - else this.jsoneditor.onChange(); - this.jsoneditor.notifyWatchers(this.path); - } - - if(this.selectize) { - // Update the Selectize options - this.updateSelectizeOptions(select_options); - } - else { - this.setupSelectize(); - } - - this._super(); - } - }, - updateSelectizeOptions: function(select_options) { - var selectized = this.selectize[0].selectize, - self = this; - - selectized.off(); - selectized.clearOptions(); - for(var n in select_options) { - selectized.addOption({value:select_options[n],text:select_options[n]}); - } - selectized.addItem(this.value); - selectized.on('change',function() { - self.onInputChange(); - }); - }, - enable: function() { - if(!this.always_disabled) { - this.input.disabled = false; - if(this.selectize) { - this.selectize[0].selectize.unlock(); - } - this._super(); - } - }, - disable: function(always_disabled) { - if(always_disabled) this.always_disabled = true; - this.input.disabled = true; - if(this.selectize) { - this.selectize[0].selectize.lock(); - } - this._super(); - }, - destroy: function() { - if(this.label && this.label.parentNode) this.label.parentNode.removeChild(this.label); - if(this.description && this.description.parentNode) this.description.parentNode.removeChild(this.description); - if(this.input && this.input.parentNode) this.input.parentNode.removeChild(this.input); - if(this.selectize) { - this.selectize[0].selectize.destroy(); - this.selectize = null; - } - this._super(); - } -}); - -JSONEditor.defaults.editors.multiselect = JSONEditor.AbstractEditor.extend({ - preBuild: function() { - this._super(); - var i; - - this.select_options = {}; - this.select_values = {}; - - var items_schema = this.jsoneditor.expandRefs(this.schema.items || {}); - - var e = items_schema["enum"] || []; - var t = items_schema.options? items_schema.options.enum_titles || [] : []; - this.option_keys = []; - this.option_titles = []; - for(i=0; i<e.length; i++) { - // If the sanitized value is different from the enum value, don't include it - if(this.sanitize(e[i]) !== e[i]) continue; - - this.option_keys.push(e[i]+""); - this.option_titles.push((t[i]||e[i])+""); - this.select_values[e[i]+""] = e[i]; - } - }, - build: function() { - var self = this, i; - if(!this.options.compact) this.header = this.label = this.theme.getFormInputLabel(this.getTitle()); - if(this.schema.description) this.description = this.theme.getFormInputDescription(this.schema.description); - - if((!this.schema.format && this.option_keys.length < 8) || this.schema.format === "checkbox") { - this.input_type = 'checkboxes'; - - this.inputs = {}; - this.controls = {}; - for(i=0; i<this.option_keys.length; i++) { - this.inputs[this.option_keys[i]] = this.theme.getCheckbox(); - this.select_options[this.option_keys[i]] = this.inputs[this.option_keys[i]]; - var label = this.theme.getCheckboxLabel(this.option_titles[i]); - this.controls[this.option_keys[i]] = this.theme.getFormControl(label, this.inputs[this.option_keys[i]]); - } - - this.control = this.theme.getMultiCheckboxHolder(this.controls,this.label,this.description); - } - else { - this.input_type = 'select'; - this.input = this.theme.getSelectInput(this.option_keys); - this.theme.setSelectOptions(this.input,this.option_keys,this.option_titles); - this.input.multiple = true; - this.input.size = Math.min(10,this.option_keys.length); - - for(i=0; i<this.option_keys.length; i++) { - this.select_options[this.option_keys[i]] = this.input.children[i]; - } - - if(this.schema.readOnly || this.schema.readonly) { - this.always_disabled = true; - this.input.disabled = true; - } - - this.control = this.theme.getFormControl(this.label, this.input, this.description); - } - - this.container.appendChild(this.control); - this.control.addEventListener('change',function(e) { - e.preventDefault(); - e.stopPropagation(); - - var new_value = []; - for(i = 0; i<self.option_keys.length; i++) { - if(self.select_options[self.option_keys[i]].selected || self.select_options[self.option_keys[i]].checked) new_value.push(self.select_values[self.option_keys[i]]); - } - - self.updateValue(new_value); - self.onChange(true); - }); - }, - setValue: function(value, initial) { - var i; - value = value || []; - if(typeof value !== "object") value = [value]; - else if(!(Array.isArray(value))) value = []; - - // Make sure we are dealing with an array of strings so we can check for strict equality - for(i=0; i<value.length; i++) { - if(typeof value[i] !== "string") value[i] += ""; - } - - // Update selected status of options - for(i in this.select_options) { - if(!this.select_options.hasOwnProperty(i)) continue; - - this.select_options[i][this.input_type === "select"? "selected" : "checked"] = (value.indexOf(i) !== -1); - } - - this.updateValue(value); - this.onChange(); - }, - setupSelect2: function() { - if(window.jQuery && window.jQuery.fn && window.jQuery.fn.select2) { - var options = window.jQuery.extend({},JSONEditor.plugins.select2); - if(this.schema.options && this.schema.options.select2_options) options = $extend(options,this.schema.options.select2_options); - this.select2 = window.jQuery(this.input).select2(options); - this.select2v4 = this.select2.select2.hasOwnProperty("amd"); - - var self = this; - this.select2.on('select2-blur',function() { - if(self.select2v4) - self.value = self.select2.val(); - else - self.value = self.select2.select2('val'); - - self.onChange(true); - }); - - this.select2.on('change',function() { - if(self.select2v4) - self.value = self.select2.val(); - else - self.value = self.select2.select2('val'); - - self.onChange(true); - }); - } - else { - this.select2 = null; - } - }, - onInputChange: function() { - this.value = this.input.value; - this.onChange(true); - }, - postBuild: function() { - this._super(); - this.setupSelect2(); - }, - register: function() { - this._super(); - if(!this.input) return; - this.input.setAttribute('name',this.formname); - }, - unregister: function() { - this._super(); - if(!this.input) return; - this.input.removeAttribute('name'); - }, - getNumColumns: function() { - var longest_text = this.getTitle().length; - for(var i in this.select_values) { - if(!this.select_values.hasOwnProperty(i)) continue; - longest_text = Math.max(longest_text,(this.select_values[i]+"").length+4); - } - - return Math.min(12,Math.max(longest_text/7,2)); - }, - updateValue: function(value) { - var changed = false; - var new_value = []; - for(var i=0; i<value.length; i++) { - if(!this.select_options[value[i]+""]) { - changed = true; - continue; - } - var sanitized = this.sanitize(this.select_values[value[i]]); - new_value.push(sanitized); - if(sanitized !== value[i]) changed = true; - } - this.value = new_value; - - if(this.select2) { - if(this.select2v4) - this.select2.val(this.value).trigger("change"); - else - this.select2.select2('val',this.value); - } - - return changed; - }, - sanitize: function(value) { - if(this.schema.items.type === "number") { - return 1*value; - } - else if(this.schema.items.type === "integer") { - return Math.floor(value*1); - } - else { - return ""+value; - } - }, - enable: function() { - if(!this.always_disabled) { - if(this.input) { - this.input.disabled = false; - } - else if(this.inputs) { - for(var i in this.inputs) { - if(!this.inputs.hasOwnProperty(i)) continue; - this.inputs[i].disabled = false; - } - } - if(this.select2) { - if(this.select2v4) - this.select2.prop("disabled",false); - else - this.select2.select2("enable",true); - } - this._super(); - } - }, - disable: function(always_disabled) { - if(always_disabled) this.always_disabled = true; - if(this.input) { - this.input.disabled = true; - } - else if(this.inputs) { - for(var i in this.inputs) { - if(!this.inputs.hasOwnProperty(i)) continue; - this.inputs[i].disabled = true; - } - } - if(this.select2) { - if(this.select2v4) - this.select2.prop("disabled",true); - else - this.select2.select2("enable",false); - } - this._super(); - }, - destroy: function() { - if(this.select2) { - this.select2.select2('destroy'); - this.select2 = null; - } - this._super(); - } -}); - -JSONEditor.defaults.editors.base64 = JSONEditor.AbstractEditor.extend({ - getNumColumns: function() { - return 4; - }, - build: function() { - var self = this; - this.title = this.header = this.label = this.theme.getFormInputLabel(this.getTitle()); - if(this.options.infoText) this.infoButton = this.theme.getInfoButton(this.options.infoText); - - // Input that holds the base64 string - this.input = this.theme.getFormInputField('hidden'); - this.container.appendChild(this.input); - - // Don't show uploader if this is readonly - if(!this.schema.readOnly && !this.schema.readonly) { - if(!window.FileReader) throw "FileReader required for base64 editor"; - - // File uploader - this.uploader = this.theme.getFormInputField('file'); - - this.uploader.addEventListener('change',function(e) { - e.preventDefault(); - e.stopPropagation(); - - if(this.files && this.files.length) { - var fr = new FileReader(); - fr.onload = function(evt) { - self.value = evt.target.result; - self.refreshPreview(); - self.onChange(true); - fr = null; - }; - fr.readAsDataURL(this.files[0]); - } - }); - } - - this.preview = this.theme.getFormInputDescription(this.schema.description); - this.container.appendChild(this.preview); - - this.control = this.theme.getFormControl(this.label, this.uploader||this.input, this.preview, this.infoButton); - this.container.appendChild(this.control); - }, - refreshPreview: function() { - if(this.last_preview === this.value) return; - this.last_preview = this.value; - - this.preview.innerHTML = ''; - - if(!this.value) return; - - var mime = this.value.match(/^data:([^;,]+)[;,]/); - if(mime) mime = mime[1]; - - if(!mime) { - this.preview.innerHTML = '<em>Invalid data URI</em>'; - } - else { - this.preview.innerHTML = '<strong>Type:</strong> '+mime+', <strong>Size:</strong> '+Math.floor((this.value.length-this.value.split(',')[0].length-1)/1.33333)+' bytes'; - if(mime.substr(0,5)==="image") { - this.preview.innerHTML += '<br>'; - var img = document.createElement('img'); - img.style.maxWidth = '100%'; - img.style.maxHeight = '100px'; - img.src = this.value; - this.preview.appendChild(img); - } - } - }, - enable: function() { - if(!this.always_disabled) { - if(this.uploader) this.uploader.disabled = false; - this._super(); - } - }, - disable: function(always_disabled) { - if(always_disabled) this.always_disabled = true; - if(this.uploader) this.uploader.disabled = true; - this._super(); - }, - setValue: function(val) { - if(this.value !== val) { - this.value = val; - this.input.value = this.value; - this.refreshPreview(); - this.onChange(); - } - }, - destroy: function() { - if(this.preview && this.preview.parentNode) this.preview.parentNode.removeChild(this.preview); - if(this.title && this.title.parentNode) this.title.parentNode.removeChild(this.title); - if(this.input && this.input.parentNode) this.input.parentNode.removeChild(this.input); - if(this.uploader && this.uploader.parentNode) this.uploader.parentNode.removeChild(this.uploader); - - this._super(); - } -}); - -JSONEditor.defaults.editors.upload = JSONEditor.AbstractEditor.extend({ - getNumColumns: function() { - return 4; - }, - build: function() { - var self = this; - this.title = this.header = this.label = this.theme.getFormInputLabel(this.getTitle()); - - // Input that holds the base64 string - this.input = this.theme.getFormInputField('hidden'); - this.container.appendChild(this.input); - - // Don't show uploader if this is readonly - if(!this.schema.readOnly && !this.schema.readonly) { - - if(!this.jsoneditor.options.upload) throw "Upload handler required for upload editor"; - - // File uploader - this.uploader = this.theme.getFormInputField('file'); - - this.uploader.addEventListener('change',function(e) { - e.preventDefault(); - e.stopPropagation(); - - if(this.files && this.files.length) { - var fr = new FileReader(); - fr.onload = function(evt) { - self.preview_value = evt.target.result; - self.refreshPreview(); - self.onChange(true); - fr = null; - }; - fr.readAsDataURL(this.files[0]); - } - }); - } - - var description = this.schema.description; - if (!description) description = ''; - - this.preview = this.theme.getFormInputDescription(description); - this.container.appendChild(this.preview); - - this.control = this.theme.getFormControl(this.label, this.uploader||this.input, this.preview); - this.container.appendChild(this.control); - }, - refreshPreview: function() { - if(this.last_preview === this.preview_value) return; - this.last_preview = this.preview_value; - - this.preview.innerHTML = ''; - - if(!this.preview_value) return; - - var self = this; - - var mime = this.preview_value.match(/^data:([^;,]+)[;,]/); - if(mime) mime = mime[1]; - if(!mime) mime = 'unknown'; - - var file = this.uploader.files[0]; - - this.preview.innerHTML = '<strong>Type:</strong> '+mime+', <strong>Size:</strong> '+file.size+' bytes'; - if(mime.substr(0,5)==="image") { - this.preview.innerHTML += '<br>'; - var img = document.createElement('img'); - img.style.maxWidth = '100%'; - img.style.maxHeight = '100px'; - img.src = this.preview_value; - this.preview.appendChild(img); - } - - this.preview.innerHTML += '<br>'; - var uploadButton = this.getButton('Upload', 'upload', 'Upload'); - this.preview.appendChild(uploadButton); - uploadButton.addEventListener('click',function(event) { - event.preventDefault(); - - uploadButton.setAttribute("disabled", "disabled"); - self.theme.removeInputError(self.uploader); - - if (self.theme.getProgressBar) { - self.progressBar = self.theme.getProgressBar(); - self.preview.appendChild(self.progressBar); - } - - self.jsoneditor.options.upload(self.path, file, { - success: function(url) { - self.setValue(url); - - if(self.parent) self.parent.onChildEditorChange(self); - else self.jsoneditor.onChange(); - - if (self.progressBar) self.preview.removeChild(self.progressBar); - uploadButton.removeAttribute("disabled"); - }, - failure: function(error) { - self.theme.addInputError(self.uploader, error); - if (self.progressBar) self.preview.removeChild(self.progressBar); - uploadButton.removeAttribute("disabled"); - }, - updateProgress: function(progress) { - if (self.progressBar) { - if (progress) self.theme.updateProgressBar(self.progressBar, progress); - else self.theme.updateProgressBarUnknown(self.progressBar); - } - } - }); - }); - - if(this.jsoneditor.options.auto_upload || this.schema.options.auto_upload) { - uploadButton.dispatchEvent(new MouseEvent('click')); - this.preview.removeChild(uploadButton); - } - }, - enable: function() { - if(!this.always_disabled) { - if(this.uploader) this.uploader.disabled = false; - this._super(); - } - }, - disable: function(always_disabled) { - if(always_disabled) this.always_disabled = true; - if(this.uploader) this.uploader.disabled = true; - this._super(); - }, - setValue: function(val) { - if(this.value !== val) { - this.value = val; - this.input.value = this.value; - this.onChange(); - } - }, - destroy: function() { - if(this.preview && this.preview.parentNode) this.preview.parentNode.removeChild(this.preview); - if(this.title && this.title.parentNode) this.title.parentNode.removeChild(this.title); - if(this.input && this.input.parentNode) this.input.parentNode.removeChild(this.input); - if(this.uploader && this.uploader.parentNode) this.uploader.parentNode.removeChild(this.uploader); - - this._super(); - } -}); - -JSONEditor.defaults.editors.checkbox = JSONEditor.AbstractEditor.extend({ - setValue: function(value,initial) { - this.value = !!value; - this.input.checked = this.value; - this.onChange(); - }, - register: function() { - this._super(); - if(!this.input) return; - this.input.setAttribute('name',this.formname); - }, - unregister: function() { - this._super(); - if(!this.input) return; - this.input.removeAttribute('name'); - }, - getNumColumns: function() { - return Math.min(12,Math.max(this.getTitle().length/7,2)); - }, - build: function() { - var self = this; - if(!this.options.compact) { - this.label = this.header = this.theme.getCheckboxLabel(this.getTitle()); - } - if(this.schema.description) this.description = this.theme.getFormInputDescription(this.schema.description); - if(this.options.infoText) this.infoButton = this.theme.getInfoButton(this.options.infoText); - if(this.options.compact) this.container.className += ' compact'; - - this.input = this.theme.getCheckbox(); - this.control = this.theme.getFormControl(this.label, this.input, this.description, this.infoButton); - - if(this.schema.readOnly || this.schema.readonly) { - this.always_disabled = true; - this.input.disabled = true; - } - - this.input.addEventListener('change',function(e) { - e.preventDefault(); - e.stopPropagation(); - self.value = this.checked; - self.onChange(true); - }); - - this.container.appendChild(this.control); - }, - enable: function() { - if(!this.always_disabled) { - this.input.disabled = false; - this._super(); - } - }, - disable: function(always_disabled) { - if(always_disabled) this.always_disabled = true; - this.input.disabled = true; - this._super(); - }, - destroy: function() { - if(this.label && this.label.parentNode) this.label.parentNode.removeChild(this.label); - if(this.description && this.description.parentNode) this.description.parentNode.removeChild(this.description); - if(this.input && this.input.parentNode) this.input.parentNode.removeChild(this.input); - this._super(); - }, - showValidationErrors: function (errors) { - var self = this; - - if (this.jsoneditor.options.show_errors === "always") {} - - else if (!this.is_dirty && this.previous_error_setting === this.jsoneditor.options.show_errors) { - return; - } - - this.previous_error_setting = this.jsoneditor.options.show_errors; - - var messages = []; - $each(errors, function (i, error) { - if (error.path === self.path) { - messages.push(error.message); - } - }); - - this.input.controlgroup = this.control; - - if (messages.length) { - this.theme.addInputError(this.input, messages.join('. ') + '.'); - } - else { - this.theme.removeInputError(this.input); - } - } -}); - -JSONEditor.defaults.editors.arraySelectize = JSONEditor.AbstractEditor.extend({ - build: function() { - this.title = this.theme.getFormInputLabel(this.getTitle()); - - this.title_controls = this.theme.getHeaderButtonHolder(); - this.title.appendChild(this.title_controls); - this.error_holder = document.createElement('div'); - - if(this.schema.description) { - this.description = this.theme.getDescription(this.schema.description); - } - - this.input = document.createElement('select'); - this.input.setAttribute('multiple', 'multiple'); - - var group = this.theme.getFormControl(this.title, this.input, this.description); - - this.container.appendChild(group); - this.container.appendChild(this.error_holder); - - window.jQuery(this.input).selectize({ - delimiter: false, - createOnBlur: true, - create: true - }); - }, - postBuild: function() { - var self = this; - this.input.selectize.on('change', function(event) { - self.refreshValue(); - self.onChange(true); - }); - }, - destroy: function() { - this.empty(true); - if(this.title && this.title.parentNode) this.title.parentNode.removeChild(this.title); - if(this.description && this.description.parentNode) this.description.parentNode.removeChild(this.description); - if(this.input && this.input.parentNode) this.input.parentNode.removeChild(this.input); - - this._super(); - }, - empty: function(hard) {}, - setValue: function(value, initial) { - var self = this; - // Update the array's value, adding/removing rows when necessary - value = value || []; - if(!(Array.isArray(value))) value = [value]; - - this.input.selectize.clearOptions(); - this.input.selectize.clear(true); - - value.forEach(function(item) { - self.input.selectize.addOption({text: item, value: item}); - }); - this.input.selectize.setValue(value); - - this.refreshValue(initial); - }, - refreshValue: function(force) { - this.value = this.input.selectize.getValue(); - }, - showValidationErrors: function(errors) { - var self = this; - - // Get all the errors that pertain to this editor - var my_errors = []; - var other_errors = []; - $each(errors, function(i,error) { - if(error.path === self.path) { - my_errors.push(error); - } - else { - other_errors.push(error); - } - }); - - // Show errors for this editor - if(this.error_holder) { - - if(my_errors.length) { - var message = []; - this.error_holder.innerHTML = ''; - this.error_holder.style.display = ''; - $each(my_errors, function(i,error) { - self.error_holder.appendChild(self.theme.getErrorMessage(error.message)); - }); - } - // Hide error area - else { - this.error_holder.style.display = 'none'; - } - } - } -}); - -var matchKey = (function () { - var elem = document.documentElement; - - if (elem.matches) return 'matches'; - else if (elem.webkitMatchesSelector) return 'webkitMatchesSelector'; - else if (elem.mozMatchesSelector) return 'mozMatchesSelector'; - else if (elem.msMatchesSelector) return 'msMatchesSelector'; - else if (elem.oMatchesSelector) return 'oMatchesSelector'; -})(); - -JSONEditor.AbstractTheme = Class.extend({ - getContainer: function() { - return document.createElement('div'); - }, - getFloatRightLinkHolder: function() { - var el = document.createElement('div'); - el.style = el.style || {}; - el.style.cssFloat = 'right'; - el.style.marginLeft = '10px'; - return el; - }, - getModal: function() { - var el = document.createElement('div'); - el.style.backgroundColor = 'white'; - el.style.border = '1px solid black'; - el.style.boxShadow = '3px 3px black'; - el.style.position = 'absolute'; - el.style.zIndex = '10'; - el.style.display = 'none'; - return el; - }, - getGridContainer: function() { - var el = document.createElement('div'); - return el; - }, - getGridRow: function() { - var el = document.createElement('div'); - el.className = 'row'; - return el; - }, - getGridColumn: function() { - var el = document.createElement('div'); - return el; - }, - setGridColumnSize: function(el,size) { - - }, - getLink: function(text) { - var el = document.createElement('a'); - el.setAttribute('href','#'); - el.appendChild(document.createTextNode(text)); - return el; - }, - disableHeader: function(header) { - header.style.color = '#ccc'; - }, - disableLabel: function(label) { - label.style.color = '#ccc'; - }, - enableHeader: function(header) { - header.style.color = ''; - }, - enableLabel: function(label) { - label.style.color = ''; - }, - getInfoButton: function(text) { - var icon = document.createElement('span'); - icon.innerText = "ⓘ"; - icon.style.fontSize = "16px"; - icon.style.fontWeight = "bold"; - icon.style.padding = ".25rem"; - icon.style.position = "relative"; - icon.style.display = "inline-block"; - - var tooltip = document.createElement('span'); - tooltip.style.fontSize = "12px"; - icon.style.fontWeight = "normal"; - tooltip.style["font-family"] = "sans-serif"; - tooltip.style.visibility = "hidden"; - tooltip.style["background-color"] = "rgba(50, 50, 50, .75)"; - tooltip.style.margin = "0 .25rem"; - tooltip.style.color = "#FAFAFA"; - tooltip.style.padding = ".5rem 1rem"; - tooltip.style["border-radius"] = ".25rem"; - tooltip.style.width = "20rem"; - tooltip.style.position = "absolute"; - tooltip.innerText = text; - icon.onmouseover = function() { - tooltip.style.visibility = "visible"; - }; - icon.onmouseleave = function() { - tooltip.style.visibility = "hidden"; - }; - - icon.appendChild(tooltip); - - return icon; - }, - getFormInputLabel: function(text) { - var el = document.createElement('label'); - el.appendChild(document.createTextNode(text)); - return el; - }, - getCheckboxLabel: function(text) { - var el = this.getFormInputLabel(text); - el.style.fontWeight = 'normal'; - return el; - }, - getHeader: function(text) { - var el = document.createElement('h3'); - if(typeof text === "string") { - el.textContent = text; - el.style.fontWeight = 'bold'; - el.style.fontSize = '12px'; - el.style.padding = '4px'; - } - else { - el.appendChild(text); - } - - return el; - }, - getCheckbox: function() { - var el = this.getFormInputField('checkbox'); - el.style.display = 'inline-block'; - el.style.width = 'auto'; - return el; - }, - getMultiCheckboxHolder: function(controls,label,description) { - var el = document.createElement('div'); - - if(label) { - label.style.display = 'block'; - el.appendChild(label); - } - - for(var i in controls) { - if(!controls.hasOwnProperty(i)) continue; - controls[i].style.display = 'inline-block'; - controls[i].style.marginRight = '20px'; - el.appendChild(controls[i]); - } - - if(description) el.appendChild(description); - - return el; - }, - getSelectInput: function(options) { - var select = document.createElement('select'); - if(options) this.setSelectOptions(select, options); - return select; - }, - getSwitcher: function(options) { - var switcher = this.getSelectInput(options); - switcher.style.backgroundColor = 'transparent'; - switcher.style.display = 'inline-block'; - switcher.style.fontStyle = 'italic'; - switcher.style.fontWeight = 'normal'; - switcher.style.height = 'auto'; - switcher.style.marginBottom = 0; - switcher.style.marginLeft = '5px'; - switcher.style.padding = '0 0 0 3px'; - switcher.style.width = 'auto'; - return switcher; - }, - getSwitcherOptions: function(switcher) { - return switcher.getElementsByTagName('option'); - }, - setSwitcherOptions: function(switcher, options, titles) { - this.setSelectOptions(switcher, options, titles); - }, - setSelectOptions: function(select, options, titles) { - titles = titles || []; - select.innerHTML = ''; - for(var i=0; i<options.length; i++) { - var option = document.createElement('option'); - option.setAttribute('value',options[i]); - option.textContent = titles[i] || options[i]; - select.appendChild(option); - } - }, - getTextareaInput: function(rows, cols) { - var el = document.createElement('textarea'); - el.style = el.style || {}; - el.style.width = '100%'; - el.style.height = '50px'; - el.style.fontWeight = 'bold'; - el.style.fontSize = '1em'; - el.style.boxSizing = 'border-box'; - if(typeof rows === undefined) { rows = 1 }; - if(typeof cols === undefined) { cols = 80 }; - el.rows = rows; - el.cols = cols; - el.wrap = 'soft'; - el.readonly = 'true'; - return el; - }, - getRangeInput: function(min,max,step) { - var el = this.getFormInputField('range'); - el.setAttribute('min',min); - el.setAttribute('max',max); - el.setAttribute('step',step); - return el; - }, - getFormInputField: function(type) { - var el = document.createElement('input'); - el.setAttribute('type',type); - return el; - }, - afterInputReady: function(input) { - - }, - getFormControl: function(label, input, description, infoText) { - var el = document.createElement('div'); - el.className = 'form-control'; - if(label) el.appendChild(label); - if(input.type === 'checkbox' && label) { - label.insertBefore(input,label.firstChild); - if(infoText) label.appendChild(infoText); - } - else { - if(infoText) label.appendChild(infoText); - el.appendChild(input); - } - - if(description) el.appendChild(description); - return el; - }, - getIndentedPanel: function() { - var el = document.createElement('div'); - el.style = el.style || {}; - el.style.paddingLeft = '10px'; - el.style.marginLeft = '10px'; - el.style.borderLeft = '1px solid #ccc'; - return el; - }, - getTopIndentedPanel: function() { - var el = document.createElement('div'); - el.style = el.style || {}; - el.style.paddingLeft = '10px'; - el.style.marginLeft = '10px'; - return el; - }, - getChildEditorHolder: function() { - return document.createElement('div'); - }, - getDescription: function(text) { - var el = document.createElement('p'); - el.innerHTML = text; - return el; - }, - getCheckboxDescription: function(text) { - return this.getDescription(text); - }, - getFormInputDescription: function(text) { - return this.getDescription(text); - }, - getHeaderButtonHolder: function() { - return this.getButtonHolder(); - }, - getButtonHolder: function() { - return document.createElement('div'); - }, - getButton: function(text, icon, title) { - var el = document.createElement('button'); - el.type = 'button'; - this.setButtonText(el,text,icon,title); - return el; - }, - setButtonText: function(button, text, icon, title) { - button.innerHTML = ''; - if(icon) { - button.appendChild(icon); - button.innerHTML += ' '; - } - button.appendChild(document.createTextNode(text)); - if(title) button.setAttribute('title',title); - }, - getTable: function() { - return document.createElement('table'); - }, - getTableRow: function() { - return document.createElement('tr'); - }, - getTableHead: function() { - return document.createElement('thead'); - }, - getTableBody: function() { - return document.createElement('tbody'); - }, - getTableHeaderCell: function(text) { - var el = document.createElement('th'); - el.textContent = text; - return el; - }, - getTableCell: function() { - var el = document.createElement('td'); - return el; - }, - getErrorMessage: function(text) { - var el = document.createElement('p'); - el.style = el.style || {}; - el.style.color = 'red'; - el.appendChild(document.createTextNode(text)); - return el; - }, - addInputError: function(input, text) { - }, - removeInputError: function(input) { - }, - addTableRowError: function(row) { - }, - removeTableRowError: function(row) { - }, - getTabHolder: function(propertyName) { - var pName = (typeof propertyName === 'undefined')? "" : propertyName; - var el = document.createElement('div'); - el.innerHTML = "<div style='float: left; width: 130px;' class='tabs' id='" + pName + "'></div><div class='content' style='margin-left: 120px;' id='" + pName + "'></div><div style='clear:both;'></div>"; - return el; - }, - getTopTabHolder: function(propertyName) { - var pName = (typeof propertyName === 'undefined')? "" : propertyName; - var el = document.createElement('div'); - el.innerHTML = "<div class='tabs' style='margin-left: 10px;' id='" + pName + "'></div><div style='clear:both;'></div><div class='content' id='" + pName + "'></div>"; - return el; - }, - applyStyles: function(el,styles) { - for(var i in styles) { - if(!styles.hasOwnProperty(i)) continue; - el.style[i] = styles[i]; - } - }, - closest: function(elem, selector) { - while (elem && elem !== document) { - if (elem[matchKey]) { - if (elem[matchKey](selector)) { - return elem; - } else { - elem = elem.parentNode; - } - } - else { - return false; - } - } - return false; - }, - insertBasicTopTab: function(tab, newTabs_holder ) { - newTabs_holder.firstChild.insertBefore(tab,newTabs_holder.firstChild.firstChild); - }, - getTab: function(span, tabId) { - var el = document.createElement('div'); - el.appendChild(span); - el.id = tabId; - el.style = el.style || {}; - this.applyStyles(el,{ - border: '1px solid #ccc', - borderWidth: '1px 0 1px 1px', - textAlign: 'center', - lineHeight: '30px', - borderRadius: '5px', - borderBottomRightRadius: 0, - borderTopRightRadius: 0, - fontWeight: 'bold', - cursor: 'pointer' - }); - return el; - }, - getTopTab: function(span, tabId) { - var el = document.createElement('div'); - el.id = tabId; - el.appendChild(span); - el.style = el.style || {}; - this.applyStyles(el,{ - float: 'left', - border: '1px solid #ccc', - borderWidth: '1px 1px 0px 1px', - textAlign: 'center', - lineHeight: '30px', - borderRadius: '5px', - paddingLeft:'5px', - paddingRight:'5px', - borderBottomRightRadius: 0, - borderBottomLeftRadius: 0, - fontWeight: 'bold', - cursor: 'pointer' - }); - return el; - }, - getTabContentHolder: function(tab_holder) { - return tab_holder.children[1]; - }, - getTopTabContentHolder: function(tab_holder) { - return tab_holder.children[1]; - }, - getTabContent: function() { - return this.getIndentedPanel(); - }, - getTopTabContent: function() { - return this.getTopIndentedPanel(); - }, - markTabActive: function(row) { - this.applyStyles(row.tab,{ - opacity: 1, - background: 'white' - }); - row.container.style.display = ''; - }, - markTabInactive: function(row) { - this.applyStyles(row.tab,{ - opacity:0.5, - background: '' - }); - row.container.style.display = 'none'; - }, - addTab: function(holder, tab) { - holder.children[0].appendChild(tab); - }, - addTopTab: function(holder, tab) { - holder.children[0].appendChild(tab); - }, - getBlockLink: function() { - var link = document.createElement('a'); - link.style.display = 'block'; - return link; - }, - getBlockLinkHolder: function() { - var el = document.createElement('div'); - return el; - }, - getLinksHolder: function() { - var el = document.createElement('div'); - return el; - }, - createMediaLink: function(holder,link,media) { - holder.appendChild(link); - media.style.width='100%'; - holder.appendChild(media); - }, - createImageLink: function(holder,link,image) { - holder.appendChild(link); - link.appendChild(image); - }, - getFirstTab: function(holder){ - return holder.firstChild.firstChild; - } -}); - -JSONEditor.defaults.themes.bootstrap2 = JSONEditor.AbstractTheme.extend({ - getRangeInput: function(min, max, step) { - // TODO: use bootstrap slider - return this._super(min, max, step); - }, - getGridContainer: function() { - var el = document.createElement('div'); - el.className = 'container-fluid'; - el.style.padding = '4px'; - return el; - }, - getGridRow: function() { - var el = document.createElement('div'); - el.className = 'row-fluid'; - return el; - }, - getFormInputLabel: function(text) { - var el = this._super(text); - el.style.display = 'inline-block'; - el.style.fontWeight = 'bold'; - return el; - }, - setGridColumnSize: function(el,size) { - el.className = 'span'+size; - }, - getSelectInput: function(options) { - var input = this._super(options); - input.style.width = 'auto'; - input.style.maxWidth = '98%'; - return input; - }, - getFormInputField: function(type) { - var el = this._super(type); - el.style.width = '98%'; - return el; - }, - afterInputReady: function(input) { - if(input.controlgroup) return; - input.controlgroup = this.closest(input,'.control-group'); - input.controls = this.closest(input,'.controls'); - if(this.closest(input,'.compact')) { - input.controlgroup.className = input.controlgroup.className.replace(/control-group/g,'').replace(/[ ]{2,}/g,' '); - input.controls.className = input.controlgroup.className.replace(/controls/g,'').replace(/[ ]{2,}/g,' '); - input.style.marginBottom = 0; - } - if (this.queuedInputErrorText) { - var text = this.queuedInputErrorText; - delete this.queuedInputErrorText; - this.addInputError(input,text); - } - - // TODO: use bootstrap slider - }, - getIndentedPanel: function() { - var el = document.createElement('div'); - el.className = 'well well-small'; - el.style.padding = '4px'; - return el; - }, - getInfoButton: function(text) { - var icon = document.createElement('span'); - icon.className = "icon-info-sign pull-right"; - icon.style.padding = ".25rem"; - icon.style.position = "relative"; - icon.style.display = "inline-block"; - - var tooltip = document.createElement('span'); - tooltip.style["font-family"] = "sans-serif"; - tooltip.style.visibility = "hidden"; - tooltip.style["background-color"] = "rgba(50, 50, 50, .75)"; - tooltip.style.margin = "0 .25rem"; - tooltip.style.color = "#FAFAFA"; - tooltip.style.padding = ".5rem 1rem"; - tooltip.style["border-radius"] = ".25rem"; - tooltip.style.width = "25rem"; - tooltip.style.transform = "translateX(-27rem) translateY(-.5rem)"; - tooltip.style.position = "absolute"; - tooltip.innerText = text; - icon.onmouseover = function() { - tooltip.style.visibility = "visible"; - }; - icon.onmouseleave = function() { - tooltip.style.visibility = "hidden"; - }; - - icon.appendChild(tooltip); - - return icon; - }, - getFormInputDescription: function(text) { - var el = document.createElement('p'); - el.className = 'help-inline'; - el.textContent = text; - return el; - }, - getFormControl: function(label, input, description, infoText) { - var ret = document.createElement('div'); - ret.className = 'control-group'; - - var controls = document.createElement('div'); - controls.className = 'controls'; - - if(label && input.getAttribute('type') === 'checkbox') { - ret.appendChild(controls); - label.className += ' checkbox'; - label.appendChild(input); - controls.appendChild(label); - if(infoText) controls.appendChild(infoText); - controls.style.height = '30px'; - } - else { - if(label) { - label.className += ' control-label'; - ret.appendChild(label); - } - if(infoText) controls.appendChild(infoText); - controls.appendChild(input); - ret.appendChild(controls); - } - - if(description) controls.appendChild(description); - - return ret; - }, - getHeaderButtonHolder: function() { - var el = this.getButtonHolder(); - el.style.marginLeft = '10px'; - return el; - }, - getButtonHolder: function() { - var el = document.createElement('div'); - el.className = 'btn-group'; - return el; - }, - getButton: function(text, icon, title) { - var el = this._super(text, icon, title); - el.className += ' btn btn-default'; - el.style.backgroundColor = '#f2bfab'; - el.style.border = '1px solid #ddd'; - return el; - }, - getTable: function() { - var el = document.createElement('table'); - el.className = 'table table-bordered'; - el.style.width = 'auto'; - el.style.maxWidth = 'none'; - return el; - }, - addInputError: function(input,text) { - if(!input.controlgroup) { - this.queuedInputErrorText = text; - return; - } - if(!input.controlgroup || !input.controls) return; - input.controlgroup.className += ' error'; - if(!input.errmsg) { - input.errmsg = document.createElement('p'); - input.errmsg.className = 'help-block errormsg'; - input.controls.appendChild(input.errmsg); - } - else { - input.errmsg.style.display = ''; - } - - input.errmsg.textContent = text; - }, - removeInputError: function(input) { - if(!input.controlgroup) { - delete this.queuedInputErrorText; - } - if(!input.errmsg) return; - input.errmsg.style.display = 'none'; - input.controlgroup.className = input.controlgroup.className.replace(/\s?error/g,''); - }, - getTabHolder: function(propertyName) { - var pName = (typeof propertyName === 'undefined')? "" : propertyName; - var el = document.createElement('div'); - el.className = 'tabbable tabs-left'; - el.innerHTML = "<ul class='nav nav-tabs' id='" + pName + "'></ul><div class='tab-content well well-small' id='" + pName + "'></div>"; - return el; - }, - getTopTabHolder: function(propertyName) { - var pName = (typeof propertyName === 'undefined')? "" : propertyName; - var el = document.createElement('div'); - el.className = 'tabbable tabs-over'; - el.innerHTML = "<ul class='nav nav-tabs' id='" + pName + "'></ul><div class='tab-content well well-small' id='" + pName + "'></div>"; - return el; - }, - getTab: function(text,tabId) { - var el = document.createElement('li'); - el.className = 'nav-item'; - var a = document.createElement('a'); - a.setAttribute('href','#' + tabId); - a.appendChild(text); - el.appendChild(a); - return el; - }, - getTopTab: function(text,tabId) { - var el = document.createElement('li'); - el.className = 'nav-item'; - var a = document.createElement('a'); - a.setAttribute('href','#' + tabId); - a.appendChild(text); - el.appendChild(a); - return el; - }, - getTabContentHolder: function(tab_holder) { - return tab_holder.children[1]; - }, - getTopTabContentHolder: function(tab_holder) { - return tab_holder.children[1]; - }, - getTabContent: function() { - var el = document.createElement('div'); - el.className = 'tab-pane'; - return el; - }, - getTopTabContent: function() { - var el = document.createElement('div'); - el.className = 'tab-pane'; - return el; - }, - markTabActive: function(row) { - row.tab.className = row.tab.className.replace(/\s?active/g,''); - row.tab.className += ' active'; - row.container.className = row.container.className.replace(/\s?active/g,''); - row.container.className += ' active'; - }, - markTabInactive: function(row) { - row.tab.className = row.tab.className.replace(/\s?active/g,''); - row.container.className = row.container.className.replace(/\s?active/g,''); - }, - addTab: function(holder, tab) { - holder.children[0].appendChild(tab); - }, - addTopTab: function(holder, tab) { - holder.children[0].appendChild(tab); - }, - getProgressBar: function() { - var container = document.createElement('div'); - container.className = 'progress'; - - var bar = document.createElement('div'); - bar.className = 'bar'; - bar.style.width = '0%'; - container.appendChild(bar); - - return container; - }, - updateProgressBar: function(progressBar, progress) { - if (!progressBar) return; - - progressBar.firstChild.style.width = progress + "%"; - }, - updateProgressBarUnknown: function(progressBar) { - if (!progressBar) return; - - progressBar.className = 'progress progress-striped active'; - progressBar.firstChild.style.width = '100%'; - } -}); - -JSONEditor.defaults.themes.bootstrap3 = JSONEditor.AbstractTheme.extend({ - getSelectInput: function(options) { - var el = this._super(options); - el.className += 'form-control'; - //el.style.width = 'auto'; - return el; - }, - getGridContainer: function() { - var el = document.createElement('div'); - el.className = 'container-fluid'; - el.style.padding = '4px'; - return el; - }, - getGridRow: function() { - var el = document.createElement('div'); - el.className = 'row-fluid'; - el.style.padding = '4px'; - return el; - }, - setGridColumnSize: function(el,size) { - el.className = 'col-md-'+size; - }, - afterInputReady: function(input) { - if(input.controlgroup) return; - input.controlgroup = this.closest(input,'.form-group'); - if(this.closest(input,'.compact')) { - input.controlgroup.style.marginBottom = 0; - } - if (this.queuedInputErrorText) { - var text = this.queuedInputErrorText; - delete this.queuedInputErrorText; - this.addInputError(input,text); - } - - // TODO: use bootstrap slider - }, - getRangeInput: function(min, max, step) { - // TODO: use better slider - return this._super(min, max, step); - }, - getFormInputField: function(type) { - var el = this._super(type); - if(type !== 'checkbox') { - el.className += 'form-control'; - } - return el; - }, - getFormControl: function(label, input, description, infoText) { - var group = document.createElement('div'); - - if(label && input.type === 'checkbox') { - group.className += ' checkbox'; - label.appendChild(input); - label.style.fontSize = '12px'; - group.style.marginTop = '0'; - if(infoText) group.appendChild(infoText); - group.appendChild(label); - input.style.position = 'relative'; - input.style.cssFloat = 'left'; - } - else { - group.className += ' form-group'; - if(label) { - label.className += ' control-label'; - group.appendChild(label); - } - - if(infoText) group.appendChild(infoText); - group.appendChild(input); - } - - if(description) group.appendChild(description); - - return group; - }, - getIndentedPanel: function() { - var el = document.createElement('div'); - el.className = 'well well-sm'; - el.style.padding = '4px'; - return el; - }, - getInfoButton: function(text) { - var icon = document.createElement('span'); - icon.className = "glyphicon glyphicon-info-sign pull-right"; - icon.style.padding = ".25rem"; - icon.style.position = "relative"; - icon.style.display = "inline-block"; - - var tooltip = document.createElement('span'); - tooltip.style["font-family"] = "sans-serif"; - tooltip.style.visibility = "hidden"; - tooltip.style["background-color"] = "rgba(50, 50, 50, .75)"; - tooltip.style.margin = "0 .25rem"; - tooltip.style.color = "#FAFAFA"; - tooltip.style.padding = ".5rem 1rem"; - tooltip.style["border-radius"] = ".25rem"; - tooltip.style.width = "25rem"; - tooltip.style.transform = "translateX(-27rem) translateY(-.5rem)"; - tooltip.style.position = "absolute"; - tooltip.innerText = text; - icon.onmouseover = function() { - tooltip.style.visibility = "visible"; - }; - icon.onmouseleave = function() { - tooltip.style.visibility = "hidden"; - }; - - icon.appendChild(tooltip); - - return icon; - }, - getFormInputDescription: function(text) { - var el = document.createElement('p'); - el.className = 'help-block'; - el.innerHTML = text; - return el; - }, - getHeaderButtonHolder: function() { - var el = this.getButtonHolder(); - el.style.marginLeft = '5px'; - return el; - }, - getButtonHolder: function() { - var el = document.createElement('div'); - el.className = 'btn-group'; - return el; - }, - getButton: function(text, icon, title) { - var el = this._super(text, icon, title); - el.className += ' btn btn-default'; - el.style.backgroundColor = '#f2bfab'; - el.style.border = '1px solid #ddd'; - return el; - }, - getTable: function() { - var el = document.createElement('table'); - el.className = 'table table-bordered'; - el.style.width = 'auto'; - el.style.maxWidth = 'none'; - return el; - }, - - addInputError: function(input,text) { - if(!input.controlgroup) { - this.queuedInputErrorText = text; - return; - } - input.controlgroup.className = input.controlgroup.className.replace(/\s?has-error/g,''); - input.controlgroup.className += ' has-error'; - if(!input.errmsg) { - input.errmsg = document.createElement('p'); - input.errmsg.className = 'help-block errormsg'; - input.controlgroup.appendChild(input.errmsg); - } - else { - input.errmsg.style.display = ''; - } - - input.errmsg.textContent = text; - }, - removeInputError: function(input) { - if(!input.controlgroup) { - delete this.queuedInputErrorText; - } - if(!input.errmsg) return; - input.errmsg.style.display = 'none'; - input.controlgroup.className = input.controlgroup.className.replace(/\s?has-error/g,''); - }, - getTabHolder: function(propertyName) { - var pName = (typeof propertyName === 'undefined')? "" : propertyName; - var el = document.createElement('div'); - el.innerHTML = "<div class='list-group pull-left' id='" + pName + "'></div><div class='col-sm-10 pull-left' id='" + pName + "'></div>"; - return el; - }, - getTopTabHolder: function(propertyName) { - var pName = (typeof propertyName === 'undefined')? "" : propertyName; - var el = document.createElement('div'); - el.innerHTML = "<ul class='nav nav-tabs' style='padding: 4px;' id='" + pName + "'></ul><div class='tab-content' style='overflow:visible;' id='" + pName + "'></div>"; - return el; - }, - getTab: function(text, tabId) { - var el = document.createElement('a'); - el.className = 'list-group-item'; - el.setAttribute('href','#'+tabId); - el.appendChild(text); - return el; - }, - getTopTab: function(text, tabId) { - var el = document.createElement('li'); - var a = document.createElement('a'); - a.setAttribute('href','#'+tabId); - a.appendChild(text); - el.appendChild(a); - return el; - }, - markTabActive: function(row) { - row.tab.className = row.tab.className.replace(/\s?active/g,''); - row.tab.className += ' active'; - row.container.style.display = ''; - }, - markTabInactive: function(row) { - row.tab.className = row.tab.className.replace(/\s?active/g,''); - row.container.style.display = 'none'; - }, - getProgressBar: function() { - var min = 0, max = 100, start = 0; - - var container = document.createElement('div'); - container.className = 'progress'; - - var bar = document.createElement('div'); - bar.className = 'progress-bar'; - bar.setAttribute('role', 'progressbar'); - bar.setAttribute('aria-valuenow', start); - bar.setAttribute('aria-valuemin', min); - bar.setAttribute('aria-valuenax', max); - bar.innerHTML = start + "%"; - container.appendChild(bar); - - return container; - }, - updateProgressBar: function(progressBar, progress) { - if (!progressBar) return; - - var bar = progressBar.firstChild; - var percentage = progress + "%"; - bar.setAttribute('aria-valuenow', progress); - bar.style.width = percentage; - bar.innerHTML = percentage; - }, - updateProgressBarUnknown: function(progressBar) { - if (!progressBar) return; - - var bar = progressBar.firstChild; - progressBar.className = 'progress progress-striped active'; - bar.removeAttribute('aria-valuenow'); - bar.style.width = '100%'; - bar.innerHTML = ''; - } -}); - -JSONEditor.defaults.themes.bootstrap4 = JSONEditor.AbstractTheme.extend({ - getSelectInput: function(options) { - var el = this._super(options); - el.className += "form-control"; - //el.style.width = 'auto'; - return el; - }, - setGridColumnSize: function(el, size) { - el.className = "col-md-" + size; - }, - afterInputReady: function(input) { - if (input.controlgroup) return; - input.controlgroup = this.closest(input, ".form-group"); - if (this.closest(input, ".compact")) { - input.controlgroup.style.marginBottom = 0; - } - - // TODO: use bootstrap slider - }, - getTextareaInput: function() { - var el = document.createElement("textarea"); - el.className = "form-control"; - return el; - }, - getRangeInput: function(min, max, step) { - // TODO: use better slider - return this._super(min, max, step); - }, - getFormInputField: function(type) { - var el = this._super(type); - if (type !== "checkbox") { - el.className += "form-control"; - } - return el; - }, - getFormControl: function(label, input, description) { - var group = document.createElement("div"); - - if (label && input.type === "checkbox") { - group.className += " checkbox"; - label.appendChild(input); - label.style.fontSize = "12px"; - group.style.marginTop = "0"; - group.appendChild(label); - input.style.position = "relative"; - input.style.cssFloat = "left"; - } else { - group.className += " form-group"; - if (label) { - label.className += " form-control-label"; - group.appendChild(label); - } - group.appendChild(input); - } - - if (description) group.appendChild(description); - - return group; - }, - getIndentedPanel: function() { - var el = document.createElement("div"); - el.className = "card card-body bg-light"; - return el; - }, - getFormInputDescription: function(text) { - var el = document.createElement("p"); - el.className = "form-text"; - el.innerHTML = text; - return el; - }, - getHeaderButtonHolder: function() { - var el = this.getButtonHolder(); - el.style.marginLeft = "10px"; - return el; - }, - getButtonHolder: function() { - var el = document.createElement("div"); - el.className = "btn-group"; - return el; - }, - getButton: function(text, icon, title) { - var el = this._super(text, icon, title); - el.className += "btn btn-secondary"; - return el; - }, - getTable: function() { - var el = document.createElement("table"); - el.className = "table-bordered table-sm"; - el.style.width = "auto"; - el.style.maxWidth = "none"; - return el; - }, - - addInputError: function(input, text) { - if (!input.controlgroup) return; - input.controlgroup.className += " has-error"; - if (!input.errmsg) { - input.errmsg = document.createElement("p"); - input.errmsg.className = "form-text errormsg"; - input.controlgroup.appendChild(input.errmsg); - } else { - input.errmsg.style.display = ""; - } - - input.errmsg.textContent = text; - }, - removeInputError: function(input) { - if (!input.errmsg) return; - input.errmsg.style.display = "none"; - input.controlgroup.className = input.controlgroup.className.replace( - /\s?has-error/g, - "" - ); - }, - getTabHolder: function(propertyName) { - var el = document.createElement("div"); - var pName = (typeof propertyName === 'undefined')? "" : propertyName; - el.innerHTML = - "<ul class='nav flex-column nav-pills col-md-2' style='padding: 0px;' id='" + pName + "'></ul><div class='tab-content col-md-10' style='padding:5px;' id='" + pName + "'></div>"; -el.className = "row"; - return el; - }, - getTopTabHolder: function(propertyName) { - var pName = (typeof propertyName === 'undefined')? "" : propertyName; - var el = document.createElement('div'); - el.innerHTML = "<ul class='nav nav-tabs' id='" + pName + "'></ul><div class='card-body' id='" + pName + "'></div>"; - return el; - }, - getTab: function(text,tabId) { - var liel = document.createElement('li'); - liel.className = 'nav-item'; - var ael = document.createElement("a"); - ael.className = "nav-link"; - ael.setAttribute("style",'padding:10px;'); - ael.setAttribute("href", "#" + tabId); - ael.appendChild(text); - liel.appendChild(ael); - return liel; - }, - getTopTab: function(text, tabId) { - var el = document.createElement('li'); - el.className = 'nav-item'; - var a = document.createElement('a'); - a.className = 'nav-link'; - a.setAttribute('href','#'+tabId); - a.appendChild(text); - el.appendChild(a); - return el; - }, - markTabActive: function(row) { - var el = row.tab.firstChild; - el.className = el.className.replace(/\s?active/g,''); - el.className += " active"; - row.container.style.display = ''; - }, - markTabInactive: function(row) { - var el = row.tab.firstChild; - el.className = el.className.replace(/\s?active/g,''); - row.container.style.display = 'none'; - }, - getProgressBar: function() { - var min = 0, - max = 100, - start = 0; - - var container = document.createElement("div"); - container.className = "progress"; - - var bar = document.createElement("div"); - bar.className = "progress-bar"; - bar.setAttribute("role", "progressbar"); - bar.setAttribute("aria-valuenow", start); - bar.setAttribute("aria-valuemin", min); - bar.setAttribute("aria-valuenax", max); - bar.innerHTML = start + "%"; - container.appendChild(bar); - - return container; - }, - updateProgressBar: function(progressBar, progress) { - if (!progressBar) return; - - var bar = progressBar.firstChild; - var percentage = progress + "%"; - bar.setAttribute("aria-valuenow", progress); - bar.style.width = percentage; - bar.innerHTML = percentage; - }, - updateProgressBarUnknown: function(progressBar) { - if (!progressBar) return; - - var bar = progressBar.firstChild; - progressBar.className = "progress progress-striped active"; - bar.removeAttribute("aria-valuenow"); - bar.style.width = "100%"; - bar.innerHTML = ""; - } -}); - -// Base Foundation theme -JSONEditor.defaults.themes.foundation = JSONEditor.AbstractTheme.extend({ - getChildEditorHolder: function() { - var el = document.createElement('div'); - el.style.marginBottom = '15px'; - return el; - }, - getSelectInput: function(options) { - var el = this._super(options); - el.style.minWidth = 'none'; - el.style.padding = '5px'; - el.style.marginTop = '3px'; - return el; - }, - getSwitcher: function(options) { - var el = this._super(options); - el.style.paddingRight = '8px'; - return el; - }, - afterInputReady: function(input) { - if(input.group) return; - if(this.closest(input,'.compact')) { - input.style.marginBottom = 0; - } - input.group = this.closest(input,'.form-control'); - if (this.queuedInputErrorText) { - var text = this.queuedInputErrorText; - delete this.queuedInputErrorText; - this.addInputError(input,text); - } - }, - getFormInputLabel: function(text) { - var el = this._super(text); - el.style.display = 'inline-block'; - return el; - }, - getFormInputField: function(type) { - var el = this._super(type); - el.style.width = '100%'; - el.style.marginBottom = type==='checkbox'? '0' : '12px'; - return el; - }, - getFormInputDescription: function(text) { - var el = document.createElement('p'); - el.textContent = text; - el.style.marginTop = '-10px'; - el.style.fontStyle = 'italic'; - return el; - }, - getIndentedPanel: function() { - var el = document.createElement('div'); - el.className = 'panel'; - el.style.paddingBottom = 0; - return el; - }, - getHeaderButtonHolder: function() { - var el = this.getButtonHolder(); - el.style.display = 'inline-block'; - el.style.marginLeft = '10px'; - el.style.verticalAlign = 'middle'; - return el; - }, - getButtonHolder: function() { - var el = document.createElement('div'); - el.className = 'button-group'; - return el; - }, - getButton: function(text, icon, title) { - var el = this._super(text, icon, title); - el.className += ' small button'; - return el; - }, - addInputError: function(input,text) { - if(!input.group) { - this.queuedInputErrorText = text; - return; - } - input.group.className += ' error'; - - if(!input.errmsg) { - input.insertAdjacentHTML('afterend','<small class="error"></small>'); - input.errmsg = input.parentNode.getElementsByClassName('error')[0]; - } - else { - input.errmsg.style.display = ''; - } - - input.errmsg.textContent = text; - }, - removeInputError: function(input) { - if(!input.group) { - delete this.queuedInputErrorText; - } - if(!input.errmsg) return; - input.group.className = input.group.className.replace(/ error/g,''); - input.errmsg.style.display = 'none'; - }, - getProgressBar: function() { - var progressBar = document.createElement('div'); - progressBar.className = 'progress'; - - var meter = document.createElement('span'); - meter.className = 'meter'; - meter.style.width = '0%'; - progressBar.appendChild(meter); - return progressBar; - }, - updateProgressBar: function(progressBar, progress) { - if (!progressBar) return; - progressBar.firstChild.style.width = progress + '%'; - }, - updateProgressBarUnknown: function(progressBar) { - if (!progressBar) return; - progressBar.firstChild.style.width = '100%'; - } -}); - -// Foundation 3 Specific Theme -JSONEditor.defaults.themes.foundation3 = JSONEditor.defaults.themes.foundation.extend({ - getHeaderButtonHolder: function() { - var el = this._super(); - el.style.fontSize = '.6em'; - return el; - }, - getFormInputLabel: function(text) { - var el = this._super(text); - el.style.fontWeight = 'bold'; - return el; - }, - getTabHolder: function(propertyName) { - var pName = (typeof propertyName === 'undefined')? "" : propertyName; - var el = document.createElement('div'); - el.className = 'row'; - el.innerHTML = '<dl class="tabs vertical two columns" id="' + pName + '"></dl><div class="tabs-content ten columns" id="' + pName + '"></div>'; - return el; - }, - getTopTabHolder: function(propertyName) { - var pName = (typeof propertyName === 'undefined')? "" : propertyName; - var el = document.createElement('div'); - el.className = 'row'; - el.innerHTML = '<dl class="tabs horizontal" style="padding-left: 10px; margin-left: 10px;" id="' + pName + '"></dl><div class="tabs-content twelve columns" style="padding: 10px; margin-left: 10px;" id="' + pName + '"></div>'; - return el; - }, - setGridColumnSize: function(el,size) { - var sizes = ['zero','one','two','three','four','five','six','seven','eight','nine','ten','eleven','twelve']; - el.className = 'columns '+sizes[size]; - }, - getTab: function(text, tabId) { - var el = document.createElement('dd'); - var a = document.createElement('a'); - a.setAttribute('href','#'+tabId); - a.appendChild(text); - el.appendChild(a); - return el; - }, - getTopTab: function(text, tabId) { - var el = document.createElement('dd'); - var a = document.createElement('a'); - a.setAttribute('href','#'+tabId); - a.appendChild(text); - el.appendChild(a); - return el; - }, - getTabContentHolder: function(tab_holder) { - return tab_holder.children[1]; - }, - getTopTabContentHolder: function(tab_holder) { - return tab_holder.children[1]; - }, - getTabContent: function() { - var el = document.createElement('div'); - el.className = 'content active'; - el.style.paddingLeft = '5px'; - return el; - }, - getTopTabContent: function() { - var el = document.createElement('div'); - el.className = 'content active'; - el.style.paddingLeft = '5px'; - return el; - }, - markTabActive: function(row) { - row.tab.className = row.tab.className.replace(/\s?active/g,''); - row.tab.className += ' active'; - row.container.style.display = ''; - }, - markTabInactive: function(row) { - row.tab.className = row.tab.className.replace(/\s?active/g,''); - row.container.style.display = 'none'; - }, - addTab: function(holder, tab) { - holder.children[0].appendChild(tab); - }, - addTopTab: function(holder, tab) { - holder.children[0].appendChild(tab); - } -}); - -// Foundation 4 Specific Theme -JSONEditor.defaults.themes.foundation4 = JSONEditor.defaults.themes.foundation.extend({ - getHeaderButtonHolder: function() { - var el = this._super(); - el.style.fontSize = '.6em'; - return el; - }, - setGridColumnSize: function(el,size) { - el.className = 'columns large-'+size; - }, - getFormInputDescription: function(text) { - var el = this._super(text); - el.style.fontSize = '.8rem'; - return el; - }, - getFormInputLabel: function(text) { - var el = this._super(text); - el.style.fontWeight = 'bold'; - return el; - } -}); - -// Foundation 5 Specific Theme -JSONEditor.defaults.themes.foundation5 = JSONEditor.defaults.themes.foundation.extend({ - getFormInputDescription: function(text) { - var el = this._super(text); - el.style.fontSize = '.8rem'; - return el; - }, - setGridColumnSize: function(el,size) { - el.className = 'columns medium-'+size; - }, - getButton: function(text, icon, title) { - var el = this._super(text,icon,title); - el.className = el.className.replace(/\s*small/g,'') + ' tiny'; - return el; - }, - getTabHolder: function(propertyName) { - var pName = (typeof propertyName === 'undefined')? "" : propertyName; - var el = document.createElement('div'); - el.innerHTML = '<dl class="tabs vertical" id="' + pName + '"></dl><div class="tabs-content vertical" id="' + pName + '"></div>'; - return el; - }, - getTopTabHolder: function(propertyName) { - var pName = (typeof propertyName === 'undefined')? "" : propertyName; - var el = document.createElement('div'); - el.className = 'row'; - el.innerHTML = '<dl class="tabs horizontal" style="padding-left: 10px;" id="' + pName + '"></dl><div class="tabs-content horizontal" style="padding: 10px;" id="' + pName + '"></div>'; - return el; - }, - getTab: function(text, tabId) { - var el = document.createElement('dd'); - var a = document.createElement('a'); - a.setAttribute('href','#'+tabId); - a.appendChild(text); - el.appendChild(a); - return el; - }, - getTopTab: function(text, tabId) { - var el = document.createElement('dd'); - var a = document.createElement('a'); - a.setAttribute('href','#'+tabId); - a.appendChild(text); - el.appendChild(a); - return el; - }, - getTabContentHolder: function(tab_holder) { - return tab_holder.children[1]; - }, - getTopTabContentHolder: function(tab_holder) { - return tab_holder.children[1]; - }, - getTabContent: function() { - var el = document.createElement('div'); - el.className = 'tab-content active'; - el.style.paddingLeft = '5px'; - return el; - }, - getTopTabContent: function() { - var el = document.createElement('div'); - el.className = 'tab-content active'; - el.style.paddingLeft = '5px'; - return el; - }, - markTabActive: function(row) { - row.tab.className = row.tab.className.replace(/\s?active/g,''); - row.tab.className += ' active'; - row.container.style.display = ''; - }, - markTabInactive: function(row) { - row.tab.className = row.tab.className.replace(/\s?active/g,''); - row.container.style.display = 'none'; - }, - addTab: function(holder, tab) { - holder.children[0].appendChild(tab); - }, - addTopTab: function(holder, tab) { - holder.children[0].appendChild(tab); - } - -}); - -JSONEditor.defaults.themes.foundation6 = JSONEditor.defaults.themes.foundation5.extend({ - getIndentedPanel: function() { - var el = document.createElement('div'); - el.className = 'callout secondary'; - el.className.style = 'padding-left: 10px; margin-left: 10px;'; - return el; - }, - getButtonHolder: function() { - var el = document.createElement('div'); - el.className = 'button-group tiny'; - el.style.marginBottom = 0; - return el; - }, - getFormInputLabel: function(text) { - var el = this._super(text); - el.style.display = 'block'; - return el; - }, - getFormControl: function(label, input, description, infoText) { - var el = document.createElement('div'); - el.className = 'form-control'; - if(label) el.appendChild(label); - if(input.type === 'checkbox') { - label.insertBefore(input,label.firstChild); - } - else if (label) { - if(infoText) label.appendChild(infoText); - label.appendChild(input); - } else { - if(infoText) el.appendChild(infoText); - el.appendChild(input); - } - - if(description) label.appendChild(description); - return el; - }, - addInputError: function(input,text) { - if(!input.group) return; - input.group.className += ' error'; - - if(!input.errmsg) { - var errorEl = document.createElement('span'); - errorEl.className = 'form-error is-visible'; - input.group.getElementsByTagName('label')[0].appendChild(errorEl); - - input.className = input.className + ' is-invalid-input'; - - input.errmsg = errorEl; - } - else { - input.errmsg.style.display = ''; - input.className = ''; - } - - input.errmsg.textContent = text; - }, - removeInputError: function(input) { - if(!input.errmsg) return; - input.className = input.className.replace(/ is-invalid-input/g,''); - if(input.errmsg.parentNode) { - input.errmsg.parentNode.removeChild(input.errmsg); - } - }, - getTabHolder: function(propertyName) { - var pName = (typeof propertyName === 'undefined')? "" : propertyName; - var el = document.createElement('div'); - el.className = 'grid-x'; - el.innerHTML = '<div class="medium-2 cell" style="float: left;"><ul class="vertical tabs" data-tabs id="' + pName + '"></ul></div><div class="medium-10 cell" style="float: left;"><div class="tabs-content" data-tabs-content="'+pName+'"></div></div>'; - return el; - }, - getTopTabHolder: function(propertyName) { - var pName = (typeof propertyName === 'undefined')? "" : propertyName; - var el = document.createElement('div'); - el.className = 'grid-y'; - el.innerHTML = '<div className="cell"><ul class="tabs" data-tabs id="' + pName + '"></ul><div class="tabs-content" data-tabs-content="' + pName + '"></div></div>'; - return el; - - - }, - insertBasicTopTab: function(tab, newTabs_holder ) { - newTabs_holder.firstChild.firstChild.insertBefore(tab,newTabs_holder.firstChild.firstChild.firstChild); - }, - getTab: function(text, tabId) { - var el = document.createElement('li'); - el.className = 'tabs-title'; - var a = document.createElement('a'); - a.setAttribute('href','#'+tabId); - a.appendChild(text); - el.appendChild(a); - return el; - }, - getTopTab: function(text, tabId) { - var el = document.createElement('li'); - el.className = 'tabs-title'; - var a = document.createElement('a'); - a.setAttribute('href','#' + tabId); - a.appendChild(text); - el.appendChild(a); - return el; - }, - getTabContentHolder: function(tab_holder) { - return tab_holder.children[1].firstChild; - }, - getTopTabContentHolder: function(tab_holder) { - return tab_holder.firstChild.children[1]; - }, - getTabContent: function() { - var el = document.createElement('div'); - el.className = 'tabs-panel'; - el.style.paddingLeft = '5px'; - return el; - }, - getTopTabContent: function() { - var el = document.createElement('div'); - el.className = 'tabs-panel'; - el.style.paddingLeft = '5px'; - return el; - }, - markTabActive: function(row) { - row.tab.className = row.tab.className.replace(/\s?is-active/g,''); - row.tab.className += ' is-active'; - row.tab.firstChild.setAttribute('aria-selected', 'true'); - - row.container.className = row.container.className.replace(/\s?is-active/g,''); - row.container.className += ' is-active'; - row.container.setAttribute('aria-selected', 'true'); - }, - markTabInactive: function(row) { - row.tab.className = row.tab.className.replace(/\s?is-active/g,''); - row.tab.firstChild.removeAttribute('aria-selected'); - - row.container.className = row.container.className.replace(/\s?is-active/g,''); - row.container.removeAttribute('aria-selected'); - }, - addTab: function(holder, tab) { - holder.children[0].firstChild.appendChild(tab); - }, - addTopTab: function(holder, tab) { - holder.firstChild.children[0].appendChild(tab); - }, - getFirstTab: function(holder){ - return holder.firstChild.firstChild.firstChild; - } -}); - -JSONEditor.defaults.themes.html = JSONEditor.AbstractTheme.extend({ - getFormInputLabel: function(text) { - var el = this._super(text); - el.style.display = 'block'; - el.style.marginBottom = '3px'; - el.style.fontWeight = 'bold'; - return el; - }, - getFormInputDescription: function(text) { - var el = this._super(text); - el.style.fontSize = '.8em'; - el.style.margin = 0; - el.style.display = 'inline-block'; - el.style.fontStyle = 'italic'; - return el; - }, - getIndentedPanel: function() { - var el = this._super(); - el.style.border = '1px solid #ddd'; - el.style.padding = '5px'; - el.style.margin = '10px'; - el.style.borderRadius = '3px'; - return el; - }, - getTopIndentedPanel: function() { - return this.getIndentedPanel(); - }, - getChildEditorHolder: function() { - var el = this._super(); - el.style.marginBottom = '8px'; - return el; - }, - getHeaderButtonHolder: function() { - var el = this.getButtonHolder(); - el.style.display = 'inline-block'; - el.style.marginLeft = '10px'; - el.style.fontSize = '.8em'; - el.style.verticalAlign = 'middle'; - return el; - }, - getTable: function() { - var el = this._super(); - el.style.borderBottom = '1px solid #ccc'; - el.style.marginBottom = '5px'; - return el; - }, - addInputError: function(input, text) { - input.style.borderColor = 'red'; - - if(!input.errmsg) { - var group = this.closest(input,'.form-control'); - input.errmsg = document.createElement('div'); - input.errmsg.setAttribute('class','errmsg'); - input.errmsg.style = input.errmsg.style || {}; - input.errmsg.style.color = 'red'; - group.appendChild(input.errmsg); - } - else { - input.errmsg.style.display = 'block'; - } - - input.errmsg.innerHTML = ''; - input.errmsg.appendChild(document.createTextNode(text)); - }, - removeInputError: function(input) { - input.style.borderColor = ''; - if(input.errmsg) input.errmsg.style.display = 'none'; - }, - getProgressBar: function() { - var max = 100, start = 0; - - var progressBar = document.createElement('progress'); - progressBar.setAttribute('max', max); - progressBar.setAttribute('value', start); - return progressBar; - }, - updateProgressBar: function(progressBar, progress) { - if (!progressBar) return; - progressBar.setAttribute('value', progress); - }, - updateProgressBarUnknown: function(progressBar) { - if (!progressBar) return; - progressBar.removeAttribute('value'); - } -}); - -JSONEditor.defaults.themes.jqueryui = JSONEditor.AbstractTheme.extend({ - getTable: function() { - var el = this._super(); - el.setAttribute('cellpadding',5); - el.setAttribute('cellspacing',0); - return el; - }, - getTableHeaderCell: function(text) { - var el = this._super(text); - el.className = 'ui-state-active'; - el.style.fontWeight = 'bold'; - return el; - }, - getTableCell: function() { - var el = this._super(); - el.className = 'ui-widget-content'; - return el; - }, - getHeaderButtonHolder: function() { - var el = this.getButtonHolder(); - el.style.marginLeft = '10px'; - el.style.fontSize = '.6em'; - el.style.display = 'inline-block'; - return el; - }, - getFormInputDescription: function(text) { - var el = this.getDescription(text); - el.style.marginLeft = '10px'; - el.style.display = 'inline-block'; - return el; - }, - getFormControl: function(label, input, description, infoText) { - var el = this._super(label,input,description, infoText); - if(input.type === 'checkbox') { - el.style.lineHeight = '25px'; - - el.style.padding = '3px 0'; - } - else { - el.style.padding = '4px'; - } - return el; - }, - getDescription: function(text) { - var el = document.createElement('span'); - el.style.fontSize = '.8em'; - el.style.fontStyle = 'italic'; - el.textContent = text; - return el; - }, - getButtonHolder: function() { - var el = document.createElement('div'); - el.className = 'ui-buttonset'; - el.style.fontSize = '.7em'; - return el; - }, - getFormInputLabel: function(text) { - var el = document.createElement('label'); - el.style.fontWeight = 'bold'; - el.style.display = 'block'; - el.textContent = text; - return el; - }, - getButton: function(text, icon, title) { - var button = document.createElement("button"); - button.className = 'ui-button ui-widget ui-state-default ui-corner-all'; - - // Icon only - if(icon && !text) { - button.className += ' ui-button-icon-only'; - icon.className += ' ui-button-icon-primary ui-icon-primary'; - button.appendChild(icon); - } - // Icon and Text - else if(icon) { - button.className += ' ui-button-text-icon-primary'; - icon.className += ' ui-button-icon-primary ui-icon-primary'; - button.appendChild(icon); - } - // Text only - else { - button.className += ' ui-button-text-only'; - } - - var el = document.createElement('span'); - el.className = 'ui-button-text'; - el.textContent = text||title||"."; - button.appendChild(el); - - button.setAttribute('title',title); - - return button; - }, - setButtonText: function(button,text, icon, title) { - button.innerHTML = ''; - button.className = 'ui-button ui-widget ui-state-default ui-corner-all'; - - // Icon only - if(icon && !text) { - button.className += ' ui-button-icon-only'; - icon.className += ' ui-button-icon-primary ui-icon-primary'; - button.appendChild(icon); - } - // Icon and Text - else if(icon) { - button.className += ' ui-button-text-icon-primary'; - icon.className += ' ui-button-icon-primary ui-icon-primary'; - button.appendChild(icon); - } - // Text only - else { - button.className += ' ui-button-text-only'; - } - - var el = document.createElement('span'); - el.className = 'ui-button-text'; - el.textContent = text||title||"."; - button.appendChild(el); - - button.setAttribute('title',title); - }, - getIndentedPanel: function() { - var el = document.createElement('div'); - el.className = 'ui-widget-content ui-corner-all'; - el.style.padding = '1em 1.4em'; - el.style.marginBottom = '20px'; - return el; - }, - afterInputReady: function(input) { - if(input.controls) return; - input.controls = this.closest(input,'.form-control'); - if (this.queuedInputErrorText) { - var text = this.queuedInputErrorText; - delete this.queuedInputErrorText; - this.addInputError(input,text); - } - }, - addInputError: function(input,text) { - if(!input.controls) { - this.queuedInputErrorText = text; - return; - } - if(!input.errmsg) { - input.errmsg = document.createElement('div'); - input.errmsg.className = 'ui-state-error'; - input.controls.appendChild(input.errmsg); - } - else { - input.errmsg.style.display = ''; - } - - input.errmsg.textContent = text; - }, - removeInputError: function(input) { - if(!input.controls) { - delete this.queuedInputErrorText; - } - if(!input.errmsg) return; - input.errmsg.style.display = 'none'; - }, - markTabActive: function(row) { - row.tab.className = row.tab.className.replace(/\s?ui-widget-header/g,'').replace(/\s?ui-state-active/g,'')+' ui-state-active'; - row.container.style.display = ''; - }, - markTabInactive: function(row) { - row.tab.className = row.tab.className.replace(/\s?ui-state-active/g,'').replace(/\s?ui-widget-header/g,'')+' ui-widget-header'; - row.container.style.display = 'none'; - } -}); - -JSONEditor.defaults.themes.barebones = JSONEditor.AbstractTheme.extend({ - getFormInputLabel: function (text) { - var el = this._super(text); - return el; - }, - getFormInputDescription: function (text) { - var el = this._super(text); - return el; - }, - getIndentedPanel: function () { - var el = this._super(); - return el; - }, - getChildEditorHolder: function () { - var el = this._super(); - return el; - }, - getHeaderButtonHolder: function () { - var el = this.getButtonHolder(); - return el; - }, - getTable: function () { - var el = this._super(); - return el; - }, - addInputError: function (input, text) { - if (!input.errmsg) { - var group = this.closest(input, '.form-control'); - input.errmsg = document.createElement('div'); - input.errmsg.setAttribute('class', 'errmsg'); - group.appendChild(input.errmsg); - } - else { - input.errmsg.style.display = 'block'; - } - - input.errmsg.innerHTML = ''; - input.errmsg.appendChild(document.createTextNode(text)); - }, - removeInputError: function (input) { - input.style.borderColor = ''; - if (input.errmsg) input.errmsg.style.display = 'none'; - }, - getProgressBar: function () { - var max = 100, start = 0; - - var progressBar = document.createElement('progress'); - progressBar.setAttribute('max', max); - progressBar.setAttribute('value', start); - return progressBar; - }, - updateProgressBar: function (progressBar, progress) { - if (!progressBar) return; - progressBar.setAttribute('value', progress); - }, - updateProgressBarUnknown: function (progressBar) { - if (!progressBar) return; - progressBar.removeAttribute('value'); - } -}); - -JSONEditor.defaults.themes.materialize = JSONEditor.AbstractTheme.extend({ - - /** - * Applies grid size to specified element. - * - * @param {HTMLElement} el The DOM element to have specified size applied. - * @param {int} size The grid column size. - * @see http://materializecss.com/grid.html - */ - setGridColumnSize: function(el, size) { - el.className = 'col s' + size; - }, - - /** - * Gets a wrapped button element for a header. - * - * @returns {HTMLElement} The wrapped button element. - */ - getHeaderButtonHolder: function() { - return this.getButtonHolder(); - }, - - /** - * Gets a wrapped button element. - * - * @returns {HTMLElement} The wrapped button element. - */ - getButtonHolder: function() { - return document.createElement('span'); - }, - - /** - * Gets a single button element. - * - * @param {string} text The button text. - * @param {HTMLElement} icon The icon object. - * @param {string} title The button title. - * @returns {HTMLElement} The button object. - * @see http://materializecss.com/buttons.html - */ - getButton: function(text, icon, title) { - - // Prepare icon. - if (text) { - icon.className += ' left'; - icon.style.marginRight = '5px'; - } - - // Create and return button. - var el = this._super(text, icon, title); - el.className = 'waves-effect waves-light btn'; - el.style.fontSize = '0.75rem'; - el.style.height = '20px'; - el.style.lineHeight = '20px'; - el.style.marginLeft = '4px'; - el.style.padding = '0 0.5rem'; - return el; - - }, - - /** - * Gets a form control object consisiting of several sub objects. - * - * @param {HTMLElement} label The label element. - * @param {HTMLElement} input The input element. - * @param {string} description The element description. - * @param {string} infoText The element information text. - * @returns {HTMLElement} The assembled DOM element. - * @see http://materializecss.com/forms.html - */ - getFormControl: function(label, input, description, infoText) { - - var ctrl, - type = input.type; - - // Checkboxes get wrapped in p elements. - if (type && type === 'checkbox') { - - ctrl = document.createElement('p'); - ctrl.appendChild(input); - if (label) { - label.setAttribute('for', input.id); - ctrl.appendChild(label); - } - return ctrl; - - } - - // Anything else gets wrapped in divs. - ctrl = this._super(label, input, description, infoText); - - // Not .input-field for select wrappers. - if (!type || !type.startsWith('select')) - ctrl.className = 'input-field'; - - // Color needs special attention. - if (type && type === 'color') { - input.style.height = '3rem'; - input.style.width = '100%'; - input.style.margin = '5px 0 20px 0'; - input.style.padding = '3px'; - - if (label) { - label.style.transform = 'translateY(-14px) scale(0.8)'; - label.style['-webkit-transform'] = 'translateY(-14px) scale(0.8)'; - label.style['-webkit-transform-origin'] = '0 0'; - label.style['transform-origin'] = '0 0'; - } - } - - return ctrl; - - }, - - getDescription: function(text) { - var el = document.createElement('div'); - el.className = 'grey-text'; - el.style.marginTop = '-15px'; - el.innerHTML = text; - return el; - }, - - /** - * Gets a header element. - * - * @param {string|HTMLElement} text The header text or element. - * @returns {HTMLElement} The header element. - */ - getHeader: function(text) { - - var el = document.createElement('h5'); - - if (typeof text === 'string') { - el.textContent = text; - } else { - el.appendChild(text); - } - - return el; - - }, - - getChildEditorHolder: function() { - - var el = document.createElement('div'); - el.marginBottom = '10px'; - return el; - - }, - - getIndentedPanel: function() { - var el = document.createElement("div"); - el.className = "card-panel"; - return el; - }, - - getTable: function() { - - var el = document.createElement('table'); - el.className = 'striped bordered'; - el.style.marginBottom = '10px'; - return el; - - }, - - getTableRow: function() { - return document.createElement('tr'); - }, - - getTableHead: function() { - return document.createElement('thead'); - }, - - getTableBody: function() { - return document.createElement('tbody'); - }, - - getTableHeaderCell: function(text) { - - var el = document.createElement('th'); - el.textContent = text; - return el; - - }, - - getTableCell: function() { - - var el = document.createElement('td'); - return el; - - }, - - /** - * Gets the tab holder element. - * - * @returns {HTMLElement} The tab holder component. - * @see https://github.com/Dogfalo/materialize/issues/2542#issuecomment-233458602 - */ - getTabHolder: function() { - - var html = [ - '<div class="col s2">', - ' <ul class="tabs" style="height: auto; margin-top: 0.82rem; -ms-flex-direction: column; -webkit-flex-direction: column; flex-direction: column; display: -webkit-flex; display: flex;">', - ' </ul>', - '</div>', - '<div class="col s10">', - '<div>' - ].join("\n"); - - var el = document.createElement('div'); - el.className = 'row card-panel'; - el.innerHTML = html; - return el; - - }, - - /** - * Add specified tab to specified holder element. - * - * @param {HTMLElement} holder The tab holder element. - * @param {HTMLElement} tab The tab to add. - */ - addTab: function(holder, tab) { - holder.children[0].children[0].appendChild(tab); - }, - - /** - * Gets a single tab element. - * - * @param {HTMLElement} span The tab's content. - * @returns {HTMLElement} The tab element. - * @see https://github.com/Dogfalo/materialize/issues/2542#issuecomment-233458602 - */ - getTab: function(span) { - - var el = document.createElement('li'); - el.className = 'tab'; - this.applyStyles(el, { - width: '100%', - textAlign: 'left', - lineHeight: '24px', - height: '24px', - fontSize: '14px', - cursor: 'pointer' - }); - el.appendChild(span); - return el; - }, - - /** - * Marks specified tab as active. - * - * @returns {HTMLElement} The tab element. - * @see https://github.com/Dogfalo/materialize/issues/2542#issuecomment-233458602 - */ - markTabActive: function(tab) { - - this.applyStyles(tab, { - width: '100%', - textAlign: 'left', - lineHeight: '24px', - height: '24px', - fontSize: '14px', - cursor: 'pointer', - color: 'rgba(238,110,115,1)', - transition: 'border-color .5s ease', - borderRight: '3px solid #424242' - }); - - }, - - /** - * Marks specified tab as inactive. - * - * @returns {HTMLElement} The tab element. - * @see https://github.com/Dogfalo/materialize/issues/2542#issuecomment-233458602 - */ - markTabInactive: function(tab) { - - this.applyStyles(tab, { - width: '100%', - textAlign: 'left', - lineHeight: '24px', - height: '24px', - fontSize: '14px', - cursor: 'pointer', - color: 'rgba(238,110,115,0.7)' - }); - - }, - - /** - * Returns the element that holds the tab contents. - * - * @param {HTMLElement} tabHolder The full tab holder element. - * @returns {HTMLElement} The content element inside specified tab holder. - */ - getTabContentHolder: function(tabHolder) { - return tabHolder.children[1]; - }, - - /** - * Creates and returns a tab content element. - * - * @returns {HTMLElement} The new tab content element. - */ - getTabContent: function() { - return document.createElement('div'); - }, - - /** - * Adds an error message to the specified input element. - * - * @param {HTMLElement} input The input element that caused the error. - * @param {string} text The error message. - */ - addInputError: function(input, text) { - - // Get the parent element. Should most likely be a <div class="input-field" ... />. - var parent = input.parentNode, - el; - - if (!parent) return; - - // Remove any previous error. - this.removeInputError(input); - - // Append an error message div. - el = document.createElement('div'); - el.className = 'error-text red-text'; - el.textContent = text; - parent.appendChild(el); - - }, - - /** - * Removes any error message from the specified input element. - * - * @param {HTMLElement} input The input element that previously caused the error. - */ - removeInputError: function(input) { - - // Get the parent element. Should most likely be a <div class="input-field" ... />. - var parent = input.parentElement, - els; - - if (!parent) return; - - // Remove all elements having class .error-text. - els = parent.getElementsByClassName('error-text'); - for (var i = 0; i < els.length; i++) - parent.removeChild(els[i]); - - }, - - addTableRowError: function(row) { - }, - - removeTableRowError: function(row) { - }, - - /** - * Gets a select DOM element. - * - * @param {object} options The option values. - * @return {HTMLElement} The DOM element. - * @see http://materializecss.com/forms.html#select - */ - getSelectInput: function(options) { - - var select = this._super(options); - select.className = 'browser-default'; - return select; - - }, - - /** - * Gets a textarea DOM element. - * - * @returns {HTMLElement} The DOM element. - * @see http://materializecss.com/forms.html#textarea - */ - getTextareaInput: function() { - var el = document.createElement('textarea'); - el.style.marginBottom = '5px'; - el.style.fontSize = '1rem'; - el.style.fontFamily = 'monospace'; - return el; - }, - - getCheckbox: function() { - - var el = this.getFormInputField('checkbox'); - el.id = this.createUuid(); - return el; - - }, - - /** - * Gets the modal element for displaying Edit JSON and Properties dialogs. - * - * @returns {HTMLElement} The modal DOM element. - * @see http://materializecss.com/cards.html - */ - getModal: function() { - - var el = document.createElement('div'); - el.className = 'card-panel z-depth-3'; - el.style.padding = '5px'; - el.style.position = 'absolute'; - el.style.zIndex = '10'; - el.style.display = 'none'; - return el; - - }, - - /** - * Creates and returns a RFC4122 version 4 compliant unique id. - * - * @returns {string} A GUID. - * @see https://stackoverflow.com/a/2117523 - */ - createUuid: function() { - - return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function(c) { - var r = Math.random() * 16 | 0, v = c == 'x' ? r : (r & 0x3 | 0x8); - return v.toString(16); - }); - - } - -}); - -JSONEditor.AbstractIconLib = Class.extend({ - mapping: { - collapse: '', - expand: '', - "delete": '', - edit: '', - add: '', - cancel: '', - save: '', - moveup: '', - movedown: '' - }, - icon_prefix: '', - getIconClass: function(key) { - if(this.mapping[key]) return this.icon_prefix+this.mapping[key]; - else return null; - }, - getIcon: function(key) { - var iconclass = this.getIconClass(key); - - if(!iconclass) return null; - - var i = document.createElement('i'); - i.className = iconclass; - return i; - } -}); - -JSONEditor.defaults.iconlibs.bootstrap2 = JSONEditor.AbstractIconLib.extend({ - mapping: { - collapse: 'chevron-down', - expand: 'chevron-up', - "delete": 'trash', - edit: 'pencil', - add: 'plus', - cancel: 'ban-circle', - save: 'ok', - moveup: 'arrow-up', - movedown: 'arrow-down' - }, - icon_prefix: 'glyphicon glyphicon-' -}); - -JSONEditor.defaults.iconlibs.bootstrap3 = JSONEditor.AbstractIconLib.extend({ - mapping: { - collapse: 'chevron-down', - expand: 'chevron-right', - "delete": 'remove', - edit: 'pencil', - add: 'plus', - cancel: 'floppy-remove', - save: 'floppy-saved', - moveup: 'arrow-up', - movedown: 'arrow-down' - }, - icon_prefix: 'glyphicon glyphicon-' -}); - -JSONEditor.defaults.iconlibs.fontawesome3 = JSONEditor.AbstractIconLib.extend({ - mapping: { - collapse: 'chevron-down', - expand: 'chevron-right', - "delete": 'remove', - edit: 'pencil', - add: 'plus', - cancel: 'ban-circle', - save: 'save', - moveup: 'arrow-up', - movedown: 'arrow-down' - }, - icon_prefix: 'icon-' -}); - -JSONEditor.defaults.iconlibs.fontawesome4 = JSONEditor.AbstractIconLib.extend({ - mapping: { - collapse: 'caret-square-o-down', - expand: 'caret-square-o-right', - "delete": 'times', - edit: 'pencil', - add: 'plus', - cancel: 'ban', - save: 'save', - moveup: 'arrow-up', - movedown: 'arrow-down', - copy: 'files-o' - }, - icon_prefix: 'fa fa-' -}); - -JSONEditor.defaults.iconlibs.foundation2 = JSONEditor.AbstractIconLib.extend({ - mapping: { - collapse: 'minus', - expand: 'plus', - "delete": 'remove', - edit: 'edit', - add: 'add-doc', - cancel: 'error', - save: 'checkmark', - moveup: 'up-arrow', - movedown: 'down-arrow' - }, - icon_prefix: 'foundicon-' -}); - -JSONEditor.defaults.iconlibs.foundation3 = JSONEditor.AbstractIconLib.extend({ - mapping: { - collapse: 'minus', - expand: 'plus', - "delete": 'x', - edit: 'pencil', - add: 'page-add', - cancel: 'x-circle', - save: 'save', - moveup: 'arrow-up', - movedown: 'arrow-down' - }, - icon_prefix: 'fi-' -}); - -JSONEditor.defaults.iconlibs.jqueryui = JSONEditor.AbstractIconLib.extend({ - mapping: { - collapse: 'triangle-1-s', - expand: 'triangle-1-e', - "delete": 'trash', - edit: 'pencil', - add: 'plusthick', - cancel: 'closethick', - save: 'disk', - moveup: 'arrowthick-1-n', - movedown: 'arrowthick-1-s' - }, - icon_prefix: 'ui-icon ui-icon-' -}); - -JSONEditor.defaults.iconlibs.materialicons = JSONEditor.AbstractIconLib.extend({ - - mapping: { - collapse: 'arrow_drop_up', - expand: 'arrow_drop_down', - "delete": 'delete', - edit: 'edit', - add: 'add', - cancel: 'cancel', - save: 'save', - moveup: 'arrow_upward', - movedown: 'arrow_downward', - copy: 'content_copy' - }, - - icon_class: 'material-icons', - icon_prefix: '', - - getIconClass: function(key) { - - // This method is unused. - - return this.icon_class; - }, - - getIcon: function(key) { - - // Get the mapping. - var mapping = this.mapping[key]; - if (!mapping) return null; - - // @see http://materializecss.com/icons.html - var i = document.createElement('i'); - i.className = this.icon_class; - var t = document.createTextNode(mapping); - i.appendChild(t); - return i; - - } -}); - -JSONEditor.defaults.templates["default"] = function() { - return { - compile: function(template) { - var matches = template.match(/{{\s*([a-zA-Z0-9\-_ \.]+)\s*}}/g); - var l = matches && matches.length; - - // Shortcut if the template contains no variables - if(!l) return function() { return template; }; - - // Pre-compute the search/replace functions - // This drastically speeds up template execution - var replacements = []; - var get_replacement = function(i) { - var p = matches[i].replace(/[{}]+/g,'').trim().split('.'); - var n = p.length; - var func; - - if(n > 1) { - var cur; - func = function(vars) { - cur = vars; - for(i=0; i<n; i++) { - cur = cur[p[i]]; - if(!cur) break; - } - return cur; - }; - } - else { - p = p[0]; - func = function(vars) { - return vars[p]; - }; - } - - replacements.push({ - s: matches[i], - r: func - }); - }; - for(var i=0; i<l; i++) { - get_replacement(i); - } - - // The compiled function - return function(vars) { - var ret = template+""; - var r; - for(i=0; i<l; i++) { - r = replacements[i]; - ret = ret.replace(r.s, r.r(vars)); - } - return ret; - }; - } - }; -}; - -JSONEditor.defaults.templates.ejs = function() { - if(!window.EJS) return false; - - return { - compile: function(template) { - var compiled = new window.EJS({ - text: template - }); - - return function(context) { - return compiled.render(context); - }; - } - }; -}; - -JSONEditor.defaults.templates.handlebars = function() { - return window.Handlebars; -}; - -JSONEditor.defaults.templates.hogan = function() { - if(!window.Hogan) return false; - - return { - compile: function(template) { - var compiled = window.Hogan.compile(template); - return function(context) { - return compiled.render(context); - }; - } - }; -}; - -JSONEditor.defaults.templates.lodash = function() { - if(!window._) return false; - - return { - compile: function(template) { - return function(context) { - return window._.template(template)(context); - }; - } - }; -}; - -JSONEditor.defaults.templates.markup = function() { - if(!window.Mark || !window.Mark.up) return false; - - return { - compile: function(template) { - return function(context) { - return window.Mark.up(template,context); - }; - } - }; -}; - -JSONEditor.defaults.templates.mustache = function() { - if(!window.Mustache) return false; - - return { - compile: function(template) { - return function(view) { - return window.Mustache.render(template, view); - }; - } - }; -}; - -JSONEditor.defaults.templates.swig = function() { - return window.swig; -}; - -JSONEditor.defaults.templates.underscore = function() { - if(!window._) return false; - - return { - compile: function(template) { - return function(context) { - return window._.template(template, context); - }; - } - }; -}; - -// Set the default theme -JSONEditor.defaults.theme = 'html'; - -// Set the default template engine -JSONEditor.defaults.template = 'default'; - -// Default options when initializing JSON Editor -JSONEditor.defaults.options = {}; - -JSONEditor.defaults.options.prompt_before_delete = true; - -// String translate function -JSONEditor.defaults.translate = function(key, variables) { - var lang = JSONEditor.defaults.languages[JSONEditor.defaults.language]; - if(!lang) throw "Unknown language "+JSONEditor.defaults.language; - - var string = lang[key] || JSONEditor.defaults.languages[JSONEditor.defaults.default_language][key]; - - if(typeof string === "undefined") throw "Unknown translate string "+key; - - if(variables) { - for(var i=0; i<variables.length; i++) { - string = string.replace(new RegExp('\\{\\{'+i+'}}','g'),variables[i]); - } - } - - return string; -}; - -// Translation strings and default languages -JSONEditor.defaults.default_language = 'en'; -JSONEditor.defaults.language = JSONEditor.defaults.default_language; -JSONEditor.defaults.languages.en = { - /** - * When a property is not set - */ - error_notset: 'Please populate the required property "{{0}}"', - /** - * When a string must not be empty - */ - error_notempty: 'Please populate the required property "{{0}}"', - /** - * When a value is not one of the enumerated values - */ - error_enum: "{{0}} must be one of the enumerated values", - /** - * When a value doesn't validate any schema of a 'anyOf' combination - */ - error_anyOf: "Value must validate against at least one of the provided schemas", - /** - * When a value doesn't validate - * @variables This key takes one variable: The number of schemas the value does not validate - */ - error_oneOf: 'Value must validate against exactly one of the provided schemas. It currently validates against {{0}} of the schemas.', - /** - * When a value does not validate a 'not' schema - */ - error_not: "Value must not validate against the provided schema", - /** - * When a value does not match any of the provided types - */ - error_type_union: "Value must be one of the provided types", - /** - * When a value does not match the given type - * @variables This key takes one variable: The type the value should be of - */ - error_type: "Value must be of type {{0}}", - /** - * When the value validates one of the disallowed types - */ - error_disallow_union: "Value must not be one of the provided disallowed types", - /** - * When the value validates a disallowed type - * @variables This key takes one variable: The type the value should not be of - */ - error_disallow: "Value must not be of type {{0}}", - /** - * When a value is not a multiple of or divisible by a given number - * @variables This key takes one variable: The number mentioned above - */ - error_multipleOf: "Value must be a multiple of {{0}}", - /** - * When a value is greater than it's supposed to be (exclusive) - * @variables This key takes one variable: The maximum - */ - error_maximum_excl: "{{0}} must be less than {{1}}", - /** - * When a value is greater than it's supposed to be (inclusive) - * @variables This key takes one variable: The maximum - */ - error_maximum_incl: "{{0}} must be at most {{1}}", - /** - * When a value is lesser than it's supposed to be (exclusive) - * @variables This key takes one variable: The minimum - */ - error_minimum_excl: "{{0}} must be greater than {{1}}", - /** - * When a value is lesser than it's supposed to be (inclusive) - * @variables This key takes one variable: The minimum - */ - error_minimum_incl: "{{0}} must be at least {{1}}", - /** - * When a value have too many characters - * @variables This key takes one variable: The maximum character count - */ - error_maxLength: "{{0}} must be at most {{1}} characters long", - /** - * When a value does not have enough characters - * @variables This key takes one variable: The minimum character count - */ - error_minLength: "{{0}} must be at least {{1}} characters long", - /** - * When a value does not match a given pattern - */ - error_pattern: "{{0}} must match the pattern {{1}}", - /** - * When an array has additional items whereas it is not supposed to - */ - error_additionalItems: "No additional items allowed in this array", - /** - * When there are to many items in an array - * @variables This key takes one variable: The maximum item count - */ - error_maxItems: "{{0}} must have at most {{1}} items", - /** - * When there are not enough items in an array - * @variables This key takes one variable: The minimum item count - */ - error_minItems: "{{0}} must have at least {{1}} items", - /** - * When an array is supposed to have unique items but has duplicates - */ - error_uniqueItems: "Each tab of {{0}} must specify a unique combination of parameters", - /** - * When there are too many properties in an object - * @variables This key takes one variable: The maximum property count - */ - error_maxProperties: "Object must have at most {{0}} properties", - /** - * When there are not enough properties in an object - * @variables This key takes one variable: The minimum property count - */ - error_minProperties: "Object must have at least {{0}} properties", - /** - * When a required property is not defined - * @variables This key takes one variable: The name of the missing property - */ - error_required: 'Please populate the required property "{{0}}"', - /** - * When there is an additional property is set whereas there should be none - * @variables This key takes one variable: The name of the additional property - */ - error_additional_properties: "No additional properties allowed, but property {{0}} is set", - /** - * When a dependency is not resolved - * @variables This key takes one variable: The name of the missing property for the dependency - */ - error_dependency: "Must have property {{0}}", - /** - * Text on Delete All buttons - */ - button_delete_all: "All", - /** - * Title on Delete All buttons - */ - button_delete_all_title: "Delete All", - /** - * Text on Delete Last buttons - * @variable This key takes one variable: The title of object to delete - */ - button_delete_last: "Last {{0}}", - /** - * Title on Delete Last buttons - * @variable This key takes one variable: The title of object to delete - */ - button_delete_last_title: "Delete Last {{0}}", - /** - * Title on Add Row buttons - * @variable This key takes one variable: The title of object to add - */ - button_add_row_title: "Add {{0}}", - /** - * Title on Move Down buttons - */ - button_move_down_title: "Move down", - /** - * Title on Move Up buttons - */ - button_move_up_title: "Move up", - /** - * Title on Delete Row buttons - * @variable This key takes one variable: The title of object to delete - */ - button_delete_row_title: "Delete {{0}}", - /** - * Title on Delete Row buttons, short version (no parameter with the object title) - */ - button_delete_row_title_short: "Delete", - /** - * Title on Collapse buttons - */ - button_collapse: "Collapse", - /** - * Title on Expand buttons - */ - button_expand: "Expand" -}; - -// Miscellaneous Plugin Settings -JSONEditor.plugins = { - ace: { - theme: '' - }, - SimpleMDE: { - - }, - sceditor: { - - }, - select2: { - - }, - selectize: { - } -}; - -// Default per-editor options -$each(JSONEditor.defaults.editors, function(i,editor) { - JSONEditor.defaults.editors[i].options = editor.options || {}; -}); - -// Set the default resolvers -// Use "multiple" as a fall back for everything -JSONEditor.defaults.resolvers.unshift(function(schema) { - if(schema.type === "qbldr") return "qbldr"; -}); -JSONEditor.defaults.resolvers.unshift(function(schema) { - if(typeof schema.type !== "string") return "multiple"; -}); -// If the type is not set but properties are defined, we can infer the type is actually object -JSONEditor.defaults.resolvers.unshift(function(schema) { - // If the schema is a simple type - if(!schema.type && schema.properties ) return "object"; -}); -// If the type is set and it's a basic type, use the primitive editor -JSONEditor.defaults.resolvers.unshift(function(schema) { - // If the schema is a simple type - if(typeof schema.type === "string") return schema.type; -}); -// Use a specialized editor for ratings -JSONEditor.defaults.resolvers.unshift(function(schema) { - if(schema.type === "integer" && schema.format === "rating") return "rating"; -}); -// Use the select editor for all boolean values -JSONEditor.defaults.resolvers.unshift(function(schema) { - if(schema.type === 'boolean') { - // If explicitly set to 'checkbox', use that - if(schema.format === "checkbox" || (schema.options && schema.options.checkbox)) { - return "checkbox"; - } - // Otherwise, default to select menu - return (JSONEditor.plugins.selectize.enable) ? 'selectize' : 'select'; - } -}); -// Use the multiple editor for schemas where the `type` is set to "any" -JSONEditor.defaults.resolvers.unshift(function(schema) { - // If the schema can be of any type - if(schema.type === "any") return "multiple"; -}); -// Editor for base64 encoded files -JSONEditor.defaults.resolvers.unshift(function(schema) { - // If the schema can be of any type - if(schema.type === "string" && schema.media && schema.media.binaryEncoding==="base64") { - return "base64"; - } -}); -// Editor for uploading files -JSONEditor.defaults.resolvers.unshift(function(schema) { - if(schema.type === "string" && schema.format === "url" && schema.options && schema.options.upload === true) { - if(window.FileReader) return "upload"; - } -}); -// Use the table editor for arrays with the format set to `table` -JSONEditor.defaults.resolvers.unshift(function(schema) { - // Type `array` with format set to `table` - if(schema.type === "array" && schema.format === "table") { - return "table"; - } -}); -// Use the `select` editor for dynamic enumSource enums -JSONEditor.defaults.resolvers.unshift(function(schema) { - if(schema.enumSource) return (JSONEditor.plugins.selectize.enable) ? 'selectize' : 'select'; -}); -// Use the `enum` or `select` editors for schemas with enumerated properties -JSONEditor.defaults.resolvers.unshift(function(schema) { - if(schema["enum"]) { - if(schema.type === "array" || schema.type === "object") { - return "enum"; - } - else if(schema.type === "number" || schema.type === "integer" || schema.type === "string") { - return (JSONEditor.plugins.selectize.enable) ? 'selectize' : 'select'; - } - } -}); -// Specialized editors for arrays of strings -JSONEditor.defaults.resolvers.unshift(function(schema) { - if(schema.type === "array" && schema.items && !(Array.isArray(schema.items)) && schema.uniqueItems && ['string','number','integer'].indexOf(schema.items.type) >= 0) { - // For enumerated strings, number, or integers - if(schema.items.enum) { - return 'multiselect'; - } - // For non-enumerated strings (tag editor) - else if(JSONEditor.plugins.selectize.enable && schema.items.type === "string") { - return 'arraySelectize'; - } - } -}); -// Use the multiple editor for schemas with `oneOf` set -JSONEditor.defaults.resolvers.unshift(function(schema) { - // If this schema uses `oneOf` or `anyOf` - if(schema.oneOf || schema.anyOf) return "multiple"; -}); - -/** - * This is a small wrapper for using JSON Editor like a typical jQuery plugin. - */ -(function() { - if(window.jQuery || window.Zepto) { - var $ = window.jQuery || window.Zepto; - $.jsoneditor = JSONEditor.defaults; - - $.fn.jsoneditor = function(options) { - var self = this; - var editor = this.data('jsoneditor'); - if(options === 'value') { - if(!editor) throw "Must initialize jsoneditor before getting/setting the value"; - - // Set value - if(arguments.length > 1) { - editor.setValue(arguments[1]); - } - // Get value - else { - return editor.getValue(); - } - } - else if(options === 'validate') { - if(!editor) throw "Must initialize jsoneditor before validating"; - - // Validate a specific value - if(arguments.length > 1) { - return editor.validate(arguments[1]); - } - // Validate current value - else { - return editor.validate(); - } - } - else if(options === 'destroy') { - if(editor) { - editor.destroy(); - this.data('jsoneditor',null); - } - } - else { - // Destroy first - if(editor) { - editor.destroy(); - } - - // Create editor - editor = new JSONEditor(this.get(0),options); - this.data('jsoneditor',editor); - - // Setup event listeners - editor.on('change',function() { - self.trigger('change'); - }); - editor.on('ready',function() { - self.trigger('ready'); - }); - } - - return this; - }; - } -})(); - - window.JSONEditor = JSONEditor; -})(); +!function(a,b){"use strict";var c=b(a);"object"==typeof module&&null!=module&&module.exports?module.exports=c:"function"==typeof define&&define.amd?define(function(){return c}):a.JSONEditor=c}("undefined"!=typeof window?window:this,function(a,b){var c;!function(){var a=!1,b=/xyz/.test(function(){window.postMessage("xyz")})?/\b_super\b/:/.*/;return c=function(){},c.extend=function d(c){function e(){!a&&this.init&&this.init.apply(this,arguments)}var f=this.prototype;a=!0;var g=new this;a=!1;for(var h in c)g[h]="function"==typeof c[h]&&"function"==typeof f[h]&&b.test(c[h])?function(a,b){return function(){var c=this._super;this._super=f[a];var d=b.apply(this,arguments);return this._super=c,d}}(h,c[h]):c[h];return e.prototype=g,e.prototype.constructor=e,e.extend=d,e},c}(),function(){function a(a,c){c=c||{bubbles:!1,cancelable:!1,detail:b};var d=document.createEvent("CustomEvent");return d.initCustomEvent(a,c.bubbles,c.cancelable,c.detail),d}a.prototype=window.Event.prototype,window.CustomEvent=a}(),function(){for(var a=0,b=["ms","moz","webkit","o"],c=0;c<b.length&&!window.requestAnimationFrame;++c)window.requestAnimationFrame=window[b[c]+"RequestAnimationFrame"],window.cancelAnimationFrame=window[b[c]+"CancelAnimationFrame"]||window[b[c]+"CancelRequestAnimationFrame"];window.requestAnimationFrame||(window.requestAnimationFrame=function(b,c){var d=(new Date).getTime(),e=Math.max(0,16-(d-a)),f=window.setTimeout(function(){b(d+e)},e);return a=d+e,f}),window.cancelAnimationFrame||(window.cancelAnimationFrame=function(a){clearTimeout(a)})}(),function(){Array.isArray||(Array.isArray=function(a){return"[object Array]"===Object.prototype.toString.call(a)})}();var d=function(a){return!("object"!=typeof a||a.nodeType||null!==a&&a===a.window)&&!(a.constructor&&!Object.prototype.hasOwnProperty.call(a.constructor.prototype,"isPrototypeOf"))},e=function(a){var b,c,f;for(c=1;c<arguments.length;c++){b=arguments[c];for(f in b)b.hasOwnProperty(f)&&(b[f]&&d(b[f])?(a.hasOwnProperty(f)||(a[f]={}),e(a[f],b[f])):a[f]=b[f])}return a},f=function(a,b){if(a&&"object"==typeof a){var c;if(Array.isArray(a)||"number"==typeof a.length&&a.length>0&&a.length-1 in a){for(c=0;c<a.length;c++)if(b(c,a[c])===!1)return}else if(Object.keys){var d=Object.keys(a);for(c=0;c<d.length;c++)if(b(d[c],a[d[c]])===!1)return}else for(c in a)if(a.hasOwnProperty(c)&&b(c,a[c])===!1)return}},g=function(a,b){var c=document.createEvent("HTMLEvents");c.initEvent(b,!0,!0),a.dispatchEvent(c)},h=function(a,b){if(!(a instanceof Element))throw new Error("element should be an instance of Element");b=e({},h.defaults.options,b||{}),this.element=a,this.options=b,this.init()};h.prototype={constructor:h,init:function(){var a=this;this.ready=!1,this.copyClipboard=null,this.refs_with_info={},this.refs_prefix="#/counter/",this.refs_counter=1;var b=h.defaults.themes[this.options.theme||h.defaults.theme];if(!b)throw"Unknown theme "+(this.options.theme||h.defaults.theme);this.schema=this.options.schema,this.theme=new b,this.template=this.options.template,this.refs=this.options.refs||{},this.uuid=0,this.__data={};var c=h.defaults.iconlibs[this.options.iconlib||h.defaults.iconlib];c&&(this.iconlib=new c),this.root_container=this.theme.getContainer(),this.element.appendChild(this.root_container),this.translate=this.options.translate||h.defaults.translate;var d=document.location.toString(),e=this._getFileBase();this._loadExternalRefs(this.schema,function(){a._getDefinitions(a.schema,d+"#/definitions/");var b={};a.options.custom_validators&&(b.custom_validators=a.options.custom_validators),a.validator=new h.Validator(a,null,b);var c=a.expandRefs(a.schema),e=a.getEditorClass(c);a.root=a.createEditor(e,{jsoneditor:a,schema:c,required:!0,container:a.root_container}),a.root.preBuild(),a.root.build(),a.root.postBuild(),a.options.hasOwnProperty("startval")&&a.root.setValue(a.options.startval),a.validation_results=a.validator.validate(a.root.getValue()),a.root.showValidationErrors(a.validation_results),a.ready=!0,window.requestAnimationFrame(function(){a.ready&&(a.validation_results=a.validator.validate(a.root.getValue()),a.root.showValidationErrors(a.validation_results),a.trigger("ready"),a.trigger("change"))})},d,e)},getValue:function(){if(!this.ready)throw"JSON Editor not ready yet. Listen for 'ready' event before getting the value";return this.root.getValue()},setValue:function(a){if(!this.ready)throw"JSON Editor not ready yet. Listen for 'ready' event before setting the value";return this.root.setValue(a),this},validate:function(a){if(!this.ready)throw"JSON Editor not ready yet. Listen for 'ready' event before validating";return 1===arguments.length?this.validator.validate(a):this.validation_results},destroy:function(){this.destroyed||this.ready&&(this.schema=null,this.options=null,this.root.destroy(),this.root=null,this.root_container=null,this.validator=null,this.validation_results=null,this.theme=null,this.iconlib=null,this.template=null,this.__data=null,this.ready=!1,this.element.innerHTML="",this.destroyed=!0)},on:function(a,b){return this.callbacks=this.callbacks||{},this.callbacks[a]=this.callbacks[a]||[],this.callbacks[a].push(b),this},off:function(a,b){if(a&&b){this.callbacks=this.callbacks||{},this.callbacks[a]=this.callbacks[a]||[];for(var c=[],d=0;d<this.callbacks[a].length;d++)this.callbacks[a][d]!==b&&c.push(this.callbacks[a][d]);this.callbacks[a]=c}else a?(this.callbacks=this.callbacks||{},this.callbacks[a]=[]):this.callbacks={};return this},trigger:function(a){if(this.callbacks&&this.callbacks[a]&&this.callbacks[a].length)for(var b=0;b<this.callbacks[a].length;b++)this.callbacks[a][b].apply(this,[]);return this},setOption:function(a,b){if("show_errors"!==a)throw"Option "+a+" must be set during instantiation and cannot be changed later";return this.options.show_errors=b,this.onChange(),this},getEditorClass:function(a){var b;if(a=this.expandSchema(a),f(h.defaults.resolvers,function(c,d){var e=d(a);if(e&&h.defaults.editors[e])return b=e,!1}),!b)throw"Unknown editor for schema "+JSON.stringify(a);if(!h.defaults.editors[b])throw"Unknown editor "+b;return h.defaults.editors[b]},createEditor:function(a,b){return b=e({},a.options||{},b),new a(b)},onChange:function(){if(this.ready&&!this.firing_change){this.firing_change=!0;var a=this;return window.requestAnimationFrame(function(){a.firing_change=!1,a.ready&&(a.validation_results=a.validator.validate(a.root.getValue()),"never"!==a.options.show_errors?a.root.showValidationErrors(a.validation_results):a.root.showValidationErrors([]),a.trigger("change"))}),this}},compileTemplate:function(a,b){b=b||h.defaults.template;var c;if("string"==typeof b){if(!h.defaults.templates[b])throw"Unknown template engine "+b;if(c=h.defaults.templates[b](),!c)throw"Template engine "+b+" missing required library."}else c=b;if(!c)throw"No template engine set";if(!c.compile)throw"Invalid template engine set";return c.compile(a)},_data:function(a,b,c){if(3!==arguments.length)return a.hasAttribute("data-jsoneditor-"+b)?this.__data[a.getAttribute("data-jsoneditor-"+b)]:null;var d;a.hasAttribute("data-jsoneditor-"+b)?d=a.getAttribute("data-jsoneditor-"+b):(d=this.uuid++,a.setAttribute("data-jsoneditor-"+b,d)),this.__data[d]=c},registerEditor:function(a){return this.editors=this.editors||{},this.editors[a.path]=a,this},unregisterEditor:function(a){return this.editors=this.editors||{},this.editors[a.path]=null,this},getEditor:function(a){if(this.editors)return this.editors[a]},watch:function(a,b){return this.watchlist=this.watchlist||{},this.watchlist[a]=this.watchlist[a]||[],this.watchlist[a].push(b),this},unwatch:function(a,b){if(!this.watchlist||!this.watchlist[a])return this;if(!b)return this.watchlist[a]=null,this;for(var c=[],d=0;d<this.watchlist[a].length;d++)this.watchlist[a][d]!==b&&c.push(this.watchlist[a][d]);return this.watchlist[a]=c.length?c:null,this},notifyWatchers:function(a){if(!this.watchlist||!this.watchlist[a])return this;for(var b=0;b<this.watchlist[a].length;b++)this.watchlist[a][b]()},isEnabled:function(){return!this.root||this.root.isEnabled()},enable:function(){this.root.enable()},disable:function(){this.root.disable()},_getDefinitions:function(a,b){if(a.definitions)for(var c in a.definitions)a.definitions.hasOwnProperty(c)&&(this.refs[b+c]=a.definitions[c],a.definitions[c].definitions&&this._getDefinitions(a.definitions[c],b+c+"/definitions/"))},_getExternalRefs:function(a,b){var c={},d=function(a){for(var b in a)a.hasOwnProperty(b)&&(c[b]=!0)};if(a.$ref&&"object"!=typeof a.$ref){var e=this.refs_prefix+this.refs_counter++;"#"===a.$ref.substr(0,1)||this.refs[a.$ref]||(c[a.$ref]=!0),this.refs_with_info[e]={fetchUrl:b,$ref:a.$ref},a.$ref=e}for(var f in a)if(a.hasOwnProperty(f)&&a[f]&&"object"==typeof a[f])if(Array.isArray(a[f]))for(var g=0;g<a[f].length;g++)a[f][g]&&"object"==typeof a[f][g]&&d(this._getExternalRefs(a[f][g],b));else d(this._getExternalRefs(a[f],b));return c},_getFileBase:function(){var a=this.options.ajaxBase;return"undefined"==typeof a&&(a=this._getFileBaseFromFileLocation(document.location.toString())),a},_getFileBaseFromFileLocation:function(a){var b=a.split("/");return b.pop(),b.join("/")+"/"},_loadExternalRefs:function(a,b,c,d){var e=this,g=this._getExternalRefs(a,c),h=0,i=0,j=!1;f(g,function(a){if(!e.refs[a]){if(!e.options.ajax)throw"Must set ajax option to true to load external ref "+a;e.refs[a]="loading",i++;var c=a;d!=a.substr(0,d.length)&&"http"!=a.substr(0,4)&&"/"!=a.substr(0,1)&&(c=d+a);var f=new XMLHttpRequest;f.overrideMimeType("application/json"),f.open("GET",c,!0),e.options.ajaxCredentials&&(f.withCredentials=e.options.ajaxCredentials),f.onreadystatechange=function(){if(4==f.readyState){if(200!==f.status)throw window.console.log(f),"Failed to fetch ref via ajax- "+a;var d;try{d=JSON.parse(f.responseText)}catch(g){throw window.console.log(g),"Failed to parse external ref "+c}if("boolean"!=typeof d&&"object"!=typeof d||null===d||Array.isArray(d))throw"External ref does not contain a valid schema - "+c;e.refs[a]=d;var k=e._getFileBaseFromFileLocation(c);e._getDefinitions(d,c+"#/definitions/"),e._loadExternalRefs(d,function(){h++,h>=i&&!j&&(j=!0,b())},c,k)}},f.send()}}),i||b()},expandRefs:function(a){for(a=e({},a);a.$ref;){var b=this.refs_with_info[a.$ref];delete a.$ref;var c="";b.$ref.startsWith("#")&&(c=b.fetchUrl);var d=c+b.$ref;this.refs[d]||(d=c+decodeURIComponent(b.$ref)),a=this.extendSchemas(a,e({},this.refs[d]))}return a},expandSchema:function(a,b){var c,d=this,g=e({},a);if("object"==typeof a.type&&(Array.isArray(a.type)?f(a.type,function(b,c){"object"==typeof c&&(a.type[b]=d.expandSchema(c))}):a.type=d.expandSchema(a.type)),"object"==typeof a.disallow&&(Array.isArray(a.disallow)?f(a.disallow,function(b,c){"object"==typeof c&&(a.disallow[b]=d.expandSchema(c))}):a.disallow=d.expandSchema(a.disallow)),a.anyOf&&f(a.anyOf,function(b,c){a.anyOf[b]=d.expandSchema(c)}),a.dependencies&&f(a.dependencies,function(b,c){"object"!=typeof c||Array.isArray(c)||(a.dependencies[b]=d.expandSchema(c))}),a.not&&(a.not=this.expandSchema(a.not)),a.allOf){for(c=0;c<a.allOf.length;c++)g=this.extendSchemas(g,this.expandSchema(a.allOf[c]));delete g.allOf}if(a["extends"]){if(Array.isArray(a["extends"]))for(c=0;c<a["extends"].length;c++)g=this.extendSchemas(g,this.expandSchema(a["extends"][c]));else g=this.extendSchemas(g,this.expandSchema(a["extends"]));delete g["extends"]}if(a.oneOf){var h=e({},g);for(delete h.oneOf,c=0;c<a.oneOf.length;c++)g.oneOf[c]=this.extendSchemas(this.expandSchema(a.oneOf[c]),h)}return this.expandRefs(g)},extendSchemas:function(a,b){a=e({},a),b=e({},b);var c=this,d={};return f(a,function(a,e){"undefined"!=typeof b[a]?"required"!==a&&"defaultProperties"!==a||"object"!=typeof e||!Array.isArray(e)?"type"!==a||"string"!=typeof e&&!Array.isArray(e)?"object"==typeof e&&Array.isArray(e)?d[a]=e.filter(function(c){return b[a].indexOf(c)!==-1}):"object"==typeof e&&null!==e?d[a]=c.extendSchemas(e,b[a]):d[a]=e:("string"==typeof e&&(e=[e]),"string"==typeof b.type&&(b.type=[b.type]),b.type&&b.type.length?d.type=e.filter(function(a){return b.type.indexOf(a)!==-1}):d.type=e,1===d.type.length&&"string"==typeof d.type[0]?d.type=d.type[0]:0===d.type.length&&delete d.type):d[a]=e.concat(b[a]).reduce(function(a,b){return a.indexOf(b)<0&&a.push(b),a},[]):d[a]=e}),f(b,function(b,c){"undefined"==typeof a[b]&&(d[b]=c)}),d},setCopyClipboardContents:function(a){this.copyClipboard=a},getCopyClipboardContents:function(){return this.copyClipboard}},h.defaults={themes:{},templates:{},iconlibs:{},editors:{},languages:{},resolvers:[],custom_validators:[]},h.Validator=c.extend({init:function(a,b,c){this.jsoneditor=a,this.schema=b||this.jsoneditor.schema,this.options=c||{},this.translate=this.jsoneditor.translate||h.defaults.translate},validate:function(a){return this._validateSchema(this.schema,a)},_validateSchema:function(a,c,d){var g,i,j,k=this,l=[],m=JSON.stringify(c);if(d=d||"root",a=e({},this.jsoneditor.expandRefs(a)),"undefined"==typeof c)return("undefined"!=typeof a.required&&a.required===!0||"undefined"==typeof a.required&&this.jsoneditor.options.required_by_default===!0)&&l.push({path:d,property:"required",message:this.translate("error_notset")}),l;if(a["enum"]){for(g=!1,i=0;i<a["enum"].length;i++)m===JSON.stringify(a["enum"][i])&&(g=!0);g||l.push({path:d,property:"enum",message:this.translate("error_enum")})}if(a["extends"])for(i=0;i<a["extends"].length;i++)l=l.concat(this._validateSchema(a["extends"][i],c,d));if(a.allOf)for(i=0;i<a.allOf.length;i++)l=l.concat(this._validateSchema(a.allOf[i],c,d));if(a.anyOf){for(g=!1,i=0;i<a.anyOf.length;i++)if(!this._validateSchema(a.anyOf[i],c,d).length){g=!0;break}g||l.push({path:d,property:"anyOf",message:this.translate("error_anyOf")})}if(a.oneOf){g=0;var n=[];for(i=0;i<a.oneOf.length;i++){var o=this._validateSchema(a.oneOf[i],c,d);for(o.length||g++,j=0;j<o.length;j++)o[j].path=d+".oneOf["+i+"]"+o[j].path.substr(d.length);n=n.concat(o)}1!==g&&(l.push({path:d,property:"oneOf",message:this.translate("error_oneOf",[g])}),l=l.concat(n))}if(a.not&&(this._validateSchema(a.not,c,d).length||l.push({path:d,property:"not",message:this.translate("error_not")})),a.type)if(Array.isArray(a.type)){for(g=!1,i=0;i<a.type.length;i++)if(this._checkType(a.type[i],c)){g=!0;break}g||l.push({path:d,property:"type",message:this.translate("error_type_union")})}else["date","time","datetime-local"].indexOf(a.format)!=-1&&"integer"==a.type?this._checkType("string",""+c)||l.push({path:d,property:"type",message:this.translate("error_type",[a.format])}):this._checkType(a.type,c)||l.push({path:d,property:"type",message:this.translate("error_type",[a.type])});if(a.disallow)if(Array.isArray(a.disallow)){for(g=!0,i=0;i<a.disallow.length;i++)if(this._checkType(a.disallow[i],c)){g=!1;break}g||l.push({path:d,property:"disallow",message:this.translate("error_disallow_union")})}else this._checkType(a.disallow,c)&&l.push({path:d,property:"disallow",message:this.translate("error_disallow",[a.disallow])});if("number"==typeof c){if(a.multipleOf||a.divisibleBy){var p=a.multipleOf||a.divisibleBy;g=c/p===Math.floor(c/p),window.math?g=window.math.mod(window.math.bignumber(c),window.math.bignumber(p)).equals(0):window.Decimal&&(g=new window.Decimal(c).mod(new window.Decimal(p)).equals(0)),g||l.push({path:d,property:a.multipleOf?"multipleOf":"divisibleBy",message:this.translate("error_multipleOf",[p])})}a.hasOwnProperty("maximum")&&(g=a.exclusiveMaximum?c<a.maximum:c<=a.maximum,window.math?g=window.math[a.exclusiveMaximum?"smaller":"smallerEq"](window.math.bignumber(c),window.math.bignumber(a.maximum)):window.Decimal&&(g=new window.Decimal(c)[a.exclusiveMaximum?"lt":"lte"](new window.Decimal(a.maximum))),g||l.push({path:d,property:"maximum",message:this.translate(a.exclusiveMaximum?"error_maximum_excl":"error_maximum_incl",[a.maximum])})),a.hasOwnProperty("minimum")&&(g=a.exclusiveMinimum?c>a.minimum:c>=a.minimum,window.math?g=window.math[a.exclusiveMinimum?"larger":"largerEq"](window.math.bignumber(c),window.math.bignumber(a.minimum)):window.Decimal&&(g=new window.Decimal(c)[a.exclusiveMinimum?"gt":"gte"](new window.Decimal(a.minimum))),g||l.push({path:d,property:"minimum",message:this.translate(a.exclusiveMinimum?"error_minimum_excl":"error_minimum_incl",[a.minimum])}))}else if("string"==typeof c)a.maxLength&&(c+"").length>a.maxLength&&l.push({path:d,property:"maxLength",message:this.translate("error_maxLength",[a.maxLength])}),a.minLength&&(c+"").length<a.minLength&&l.push({path:d,property:"minLength",message:this.translate(1===a.minLength?"error_notempty":"error_minLength",[a.minLength])}),a.pattern&&(new RegExp(a.pattern).test(c)||l.push({path:d,property:"pattern",message:this.translate("error_pattern",[a.pattern])}));else if("object"==typeof c&&null!==c&&Array.isArray(c)){if(a.items)if(Array.isArray(a.items))for(i=0;i<c.length;i++)if(a.items[i])l=l.concat(this._validateSchema(a.items[i],c[i],d+"."+i));else{if(a.additionalItems===!0)break;if(!a.additionalItems){if(a.additionalItems===!1){l.push({path:d,property:"additionalItems",message:this.translate("error_additionalItems")});break}break}l=l.concat(this._validateSchema(a.additionalItems,c[i],d+"."+i))}else for(i=0;i<c.length;i++)l=l.concat(this._validateSchema(a.items,c[i],d+"."+i));if(a.maxItems&&c.length>a.maxItems&&l.push({path:d,property:"maxItems",message:this.translate("error_maxItems",[a.maxItems])}),a.minItems&&c.length<a.minItems&&l.push({path:d,property:"minItems",message:this.translate("error_minItems",[a.minItems])}),a.uniqueItems){var q={};for(i=0;i<c.length;i++){if(g=JSON.stringify(c[i]),q[g]){l.push({path:d,property:"uniqueItems",message:this.translate("error_uniqueItems")});break}q[g]=!0}}}else if("object"==typeof c&&null!==c){if(a.maxProperties){g=0;for(i in c)c.hasOwnProperty(i)&&g++;g>a.maxProperties&&l.push({path:d,property:"maxProperties",message:this.translate("error_maxProperties",[a.maxProperties])})}if(a.minProperties){g=0;for(i in c)c.hasOwnProperty(i)&&g++;g<a.minProperties&&l.push({path:d,property:"minProperties",message:this.translate("error_minProperties",[a.minProperties])})}if("undefined"!=typeof a.required&&Array.isArray(a.required))for(i=0;i<a.required.length;i++)"undefined"==typeof c[a.required[i]]&&l.push({path:d,property:"required",message:this.translate("error_required",[a.required[i]])});var r={};for(i in a.properties)a.properties.hasOwnProperty(i)&&(r[i]=!0,l=l.concat(this._validateSchema(a.properties[i],c[i],d+"."+i)));if(a.patternProperties)for(i in a.patternProperties)if(a.patternProperties.hasOwnProperty(i)){var s=new RegExp(i);for(j in c)c.hasOwnProperty(j)&&s.test(j)&&(r[j]=!0,l=l.concat(this._validateSchema(a.patternProperties[i],c[j],d+"."+j)))}if("undefined"!=typeof a.additionalProperties||!this.jsoneditor.options.no_additional_properties||a.oneOf||a.anyOf||(a.additionalProperties=!1),"undefined"!=typeof a.additionalProperties)for(i in c)if(c.hasOwnProperty(i)&&!r[i]){if(!a.additionalProperties){l.push({path:d,property:"additionalProperties",message:this.translate("error_additional_properties",[i])});break}if(a.additionalProperties===!0)break;l=l.concat(this._validateSchema(a.additionalProperties,c[i],d+"."+i))}if(a.dependencies)for(i in a.dependencies)if(a.dependencies.hasOwnProperty(i)&&"undefined"!=typeof c[i])if(Array.isArray(a.dependencies[i]))for(j=0;j<a.dependencies[i].length;j++)"undefined"==typeof c[a.dependencies[i][j]]&&l.push({path:d,property:"dependencies",message:this.translate("error_dependency",[a.dependencies[i][j]])});else l=l.concat(this._validateSchema(a.dependencies[i],c,d))}if(["date","time","datetime-local"].indexOf(a.format)!=-1){var t={date:/^(\d{4}\D\d{2}\D\d{2})?$/,time:/^(\d{2}:\d{2}(?::\d{2})?)?$/,"datetime-local":/^(\d{4}\D\d{2}\D\d{2} \d{2}:\d{2}(?::\d{2})?)?$/},u={date:'"YYYY-MM-DD"',time:'"HH:MM"',"datetime-local":'"YYYY-MM-DD HH:MM"'},v=this.jsoneditor.getEditor(d),w=v.flatpickr?v.flatpickr.config.dateFormat:u[v.format];if("integer"==a.type)1*c<1?l.push({path:d,property:"format",message:this.translate("error_invalid_epoch")}):c!=Math.abs(parseInt(c))&&l.push({path:d,property:"format",message:this.translate("error_"+v.format.replace(/-/g,"_"),[w])});else if(v.flatpickr){if(""!==c){var x;if("single"!=v.flatpickr.config.mode){var y="range"==v.flatpickr.config.mode?v.flatpickr.l10n.rangeSeparator:", ",z=v.flatpickr.selectedDates.map(function(a){return v.flatpickr.formatDate(a,v.flatpickr.config.dateFormat)});x=z.join(y)}try{if(x){if(x!=c)throw v.flatpickr.config.mode+" mismatch"}else if(v.flatpickr.formatDate(v.flatpickr.parseDate(c,v.flatpickr.config.dateFormat),v.flatpickr.config.dateFormat)!=c)throw"mismatch"}catch(A){var B=v.flatpickr.config.errorDateFormat!==b?v.flatpickr.config.errorDateFormat:v.flatpickr.config.dateFormat;l.push({path:d,property:"format",message:this.translate("error_"+v.format.replace(/-/g,"_"),[B])})}}}else t[v.format].test(c)||l.push({path:d,property:"format",message:this.translate("error_"+v.format.replace(/-/g,"_"),[u[v.format]])})}return f(h.defaults.custom_validators,function(b,e){l=l.concat(e.call(k,a,c,d))}),this.options.custom_validators&&f(this.options.custom_validators,function(b,e){l=l.concat(e.call(k,a,c,d))}),l},_checkType:function(a,b){return"string"==typeof a?"string"===a?"string"==typeof b:"number"===a?"number"==typeof b:"integer"===a?"number"==typeof b&&b===Math.floor(b):"boolean"===a?"boolean"==typeof b:"array"===a?Array.isArray(b):"object"===a?null!==b&&!Array.isArray(b)&&"object"==typeof b:"null"!==a||null===b:!this._validateSchema(a,b).length}}),h.AbstractEditor=c.extend({onChildEditorChange:function(a){this.onChange(!0)},notify:function(){this.path&&this.jsoneditor.notifyWatchers(this.path)},change:function(){this.parent?this.parent.onChildEditorChange(this):this.jsoneditor&&this.jsoneditor.onChange()},onChange:function(a){this.notify(),this.watch_listener&&this.watch_listener(),a&&this.change()},register:function(){this.jsoneditor.registerEditor(this),this.onChange()},unregister:function(){this.jsoneditor&&this.jsoneditor.unregisterEditor(this)},getNumColumns:function(){return 12},init:function(a){this.jsoneditor=a.jsoneditor,this.theme=this.jsoneditor.theme,this.template_engine=this.jsoneditor.template,this.iconlib=this.jsoneditor.iconlib,this.translate=this.jsoneditor.translate||h.defaults.translate,this.original_schema=a.schema,this.schema=this.jsoneditor.expandSchema(this.original_schema),this.options=e({},this.options||{},this.schema.options||{},a.schema.options||{},a),a.path||this.schema.id||(this.schema.id="root"),this.path=a.path||"root",this.formname=a.formname||this.path.replace(/\.([^.]+)/g,"[$1]"),this.jsoneditor.options.form_name_root&&(this.formname=this.formname.replace(/^root\[/,this.jsoneditor.options.form_name_root+"[")),this.key=this.path.split(".").pop(),this.parent=a.parent,this.link_watchers=[],a.container&&this.setContainer(a.container),this.registerDependencies()},registerDependencies:function(){this.dependenciesFulfilled=!0;var a=this.options.dependencies;if(a){var b=this;Object.keys(a).forEach(function(c){var d=b.path.split(".");d[d.length-1]=c,d=d.join(".");var e=a[c];b.jsoneditor.watch(d,function(){b.checkDependency(d,e)})})}},checkDependency:function(a,c){var d=this.control||this.container;if(this.path!==a&&d){var e=this,f=this.jsoneditor.getEditor(a),g=f?f.getValue():b,h=this.dependenciesFulfilled;this.dependenciesFulfilled=!1,f&&f.dependenciesFulfilled?Array.isArray(c)?c.some(function(a){if(g===a)return e.dependenciesFulfilled=!0,!0}):"object"==typeof c?"object"!=typeof g?this.dependenciesFulfilled=c===g:Object.keys(c).some(function(a){return!!c.hasOwnProperty(a)&&(g.hasOwnProperty(a)&&c[a]===g[a]?void(e.dependenciesFulfilled=!0):(e.dependenciesFulfilled=!1,!0))}):"string"==typeof c||"number"==typeof c?this.dependenciesFulfilled=g===c:"boolean"==typeof c&&(c?this.dependenciesFulfilled=g&&g.length>0:this.dependenciesFulfilled=!g||0===g.length):this.dependenciesFulfilled=!1,this.dependenciesFulfilled!==h&&this.notify(),this.dependenciesFulfilled?d.style.display="block":d.style.display="none"}},setContainer:function(a){this.container=a,this.schema.id&&this.container.setAttribute("data-schemaid",this.schema.id),this.schema.type&&"string"==typeof this.schema.type&&this.container.setAttribute("data-schematype",this.schema.type),this.container.setAttribute("data-schemapath",this.path)},preBuild:function(){},build:function(){},postBuild:function(){this.setupWatchListeners(),this.addLinks(),this.setValue(this.getDefault(),!0),this.updateHeaderText(),this.register(),this.onWatchedFieldChange()},setupWatchListeners:function(){var a=this;if(this.watched={},this.schema.vars&&(this.schema.watch=this.schema.vars),this.watched_values={},this.watch_listener=function(){a.refreshWatchedFieldValues()&&a.onWatchedFieldChange()},this.schema.hasOwnProperty("watch")){var b,c,d,e,f;for(var g in this.schema.watch)if(this.schema.watch.hasOwnProperty(g)){if(b=this.schema.watch[g],Array.isArray(b)){if(b.length<2)continue;c=[b[0]].concat(b[1].split("."))}else c=b.split("."),a.theme.closest(a.container,'[data-schemaid="'+c[0]+'"]')||c.unshift("#");if(d=c.shift(),"#"===d&&(d=a.jsoneditor.schema.id||"root"),e=a.theme.closest(a.container,'[data-schemaid="'+d+'"]'),!e)throw"Could not find ancestor node with id "+d;f=e.getAttribute("data-schemapath")+"."+c.join("."),a.jsoneditor.watch(f,a.watch_listener),a.watched[g]=f}}this.schema.headerTemplate&&(this.header_template=this.jsoneditor.compileTemplate(this.schema.headerTemplate,this.template_engine))},addLinks:function(){if(!this.no_link_holder&&(this.link_holder=this.theme.getLinksHolder(),this.container.appendChild(this.link_holder),this.schema.links))for(var a=0;a<this.schema.links.length;a++)this.addLink(this.getLink(this.schema.links[a]))},onMove:function(){},getButton:function(a,b,c){var d="json-editor-btn-"+b;b=this.iconlib?this.iconlib.getIcon(b):null,!b&&c&&(a=c,c=null);var e=this.theme.getButton(a,b,c);return e.classList.add(d),e},setButtonText:function(a,b,c,d){return c=this.iconlib?this.iconlib.getIcon(c):null,!c&&d&&(b=d,d=null),this.theme.setButtonText(a,b,c,d)},addLink:function(a){this.link_holder&&this.link_holder.appendChild(a)},getLink:function(a){var b,c,d=a.mediaType||"application/javascript",e=d.split("/")[0],f=this.jsoneditor.compileTemplate(a.href,this.template_engine),g=this.jsoneditor.compileTemplate(a.rel?a.rel:a.href,this.template_engine),h=null;if(a.download&&(h=a.download),h&&h!==!0&&(h=this.jsoneditor.compileTemplate(h,this.template_engine)),"image"===e){b=this.theme.getBlockLinkHolder(),c=document.createElement("a"),c.setAttribute("target","_blank");var i=document.createElement("img");this.theme.createImageLink(b,c,i),this.link_watchers.push(function(a){var b=f(a),d=g(a);c.setAttribute("href",b),c.setAttribute("title",d||b),i.setAttribute("src",b)})}else if(["audio","video"].indexOf(e)>=0){b=this.theme.getBlockLinkHolder(),c=this.theme.getBlockLink(),c.setAttribute("target","_blank");var j=document.createElement(e);j.setAttribute("controls","controls"),this.theme.createMediaLink(b,c,j),this.link_watchers.push(function(a){var b=f(a),d=g(a);c.setAttribute("href",b),c.textContent=d||b,j.setAttribute("src",b)})}else c=b=this.theme.getBlockLink(),b.setAttribute("target","_blank"),b.textContent=a.rel,this.link_watchers.push(function(a){var c=f(a),d=g(a);b.setAttribute("href",c),b.textContent=d||c});return h&&c&&(h===!0?c.setAttribute("download",""):this.link_watchers.push(function(a){c.setAttribute("download",h(a))})),a["class"]&&c.classList.add(a["class"]),b},refreshWatchedFieldValues:function(){if(this.watched_values){var a={},b=!1,c=this;if(this.watched){var d,e;for(var f in this.watched)this.watched.hasOwnProperty(f)&&(e=c.jsoneditor.getEditor(this.watched[f]),d=e?e.getValue():null,c.watched_values[f]!==d&&(b=!0),a[f]=d)}return a.self=this.getValue(),this.watched_values.self!==a.self&&(b=!0),this.watched_values=a,b}},getWatchedFieldValues:function(){return this.watched_values},updateHeaderText:function(){if(this.header)if(this.header.children.length){for(var a=0;a<this.header.childNodes.length;a++)if(3===this.header.childNodes[a].nodeType){this.header.childNodes[a].nodeValue=this.getHeaderText();break}}else this.header.textContent=this.getHeaderText()},getHeaderText:function(a){return this.header_text?this.header_text:a?this.schema.title:this.getTitle()},onWatchedFieldChange:function(){var a;if(this.header_template){a=e(this.getWatchedFieldValues(),{key:this.key,i:this.key,i0:1*this.key,i1:1*this.key+1,title:this.getTitle()});var b=this.header_template(a);b!==this.header_text&&(this.header_text=b,this.updateHeaderText(),this.notify())}if(this.link_watchers.length){a=this.getWatchedFieldValues();for(var c=0;c<this.link_watchers.length;c++)this.link_watchers[c](a)}},setValue:function(a){this.value=a},getValue:function(){return this.dependenciesFulfilled?this.value:b},refreshValue:function(){},getChildEditors:function(){return!1},destroy:function(){var a=this;this.unregister(this),f(this.watched,function(b,c){a.jsoneditor.unwatch(c,a.watch_listener)}),this.watched=null,this.watched_values=null,this.watch_listener=null,this.header_text=null,this.header_template=null,this.value=null,this.container&&this.container.parentNode&&this.container.parentNode.removeChild(this.container),this.container=null,this.jsoneditor=null,this.schema=null,this.path=null,this.key=null,this.parent=null},getDefault:function(){if("undefined"!=typeof this.schema["default"])return this.schema["default"];if("undefined"!=typeof this.schema["enum"])return this.schema["enum"][0];var a=this.schema.type||this.schema.oneOf;if(a&&Array.isArray(a)&&(a=a[0]),a&&"object"==typeof a&&(a=a.type),a&&Array.isArray(a)&&(a=a[0]),"string"==typeof a){if("number"===a)return 0;if("boolean"===a)return!1;if("integer"===a)return 0;if("string"===a)return"";if("object"===a)return{};if("array"===a)return[]}return null},getTitle:function(){return this.schema.title||this.key},enable:function(){this.disabled=!1},disable:function(){this.disabled=!0},isEnabled:function(){return!this.disabled},isRequired:function(){return"boolean"==typeof this.schema.required?this.schema.required:this.parent&&this.parent.schema&&Array.isArray(this.parent.schema.required)?this.parent.schema.required.indexOf(this.key)>-1:!!this.jsoneditor.options.required_by_default},getDisplayText:function(a){var b=[],c={};f(a,function(a,b){b.title&&(c[b.title]=c[b.title]||0,c[b.title]++),b.description&&(c[b.description]=c[b.description]||0,c[b.description]++),b.format&&(c[b.format]=c[b.format]||0,c[b.format]++),b.type&&(c[b.type]=c[b.type]||0,c[b.type]++)}),f(a,function(a,d){var e;e="string"==typeof d?d:d.title&&c[d.title]<=1?d.title:d.format&&c[d.format]<=1?d.format:d.type&&c[d.type]<=1?d.type:d.description&&c[d.description]<=1?d.descripton:d.title?d.title:d.format?d.format:d.type?d.type:d.description?d.description:JSON.stringify(d).length<500?JSON.stringify(d):"type",b.push(e)});var d={};return f(b,function(a,e){d[e]=d[e]||0,d[e]++,c[e]>1&&(b[a]=e+" "+d[e])}),b},getValidId:function(a){return a=a===b?"":a.toString(),a.replace(/\s+/g,"-")},setInputAttributes:function(a){if(this.schema.options&&this.schema.options.inputAttributes){var b=this.schema.options.inputAttributes,c=["name","type"].concat(a);for(var d in b)b.hasOwnProperty(d)&&c.indexOf(d.toLowerCase())==-1&&this.input.setAttribute(d,b[d])}},getOption:function(a){try{throw"getOption is deprecated"}catch(b){window.console.error(b)}return this.options[a]},showValidationErrors:function(a){}}),h.defaults.editors["null"]=h.AbstractEditor.extend({getValue:function(){return this.dependenciesFulfilled?null:b},setValue:function(){this.onChange()},getNumColumns:function(){return 2}}),h.defaults.editors.string=h.AbstractEditor.extend({register:function(){this._super(),this.input&&this.input.setAttribute("name",this.formname)},unregister:function(){this._super(),this.input&&this.input.removeAttribute("name")},setValue:function(a,b,c){if((!this.template||c)&&(null===a||"undefined"==typeof a?a="":"object"==typeof a?a=JSON.stringify(a):"string"!=typeof a&&(a=""+a), +a!==this.serialized)){var d=this.sanitize(a);if(this.input.value!==d){this.input.value=d,this.sceditor_instance?this.sceditor_instance.val(d):this.SimpleMDE?this.SimpleMDE.value(d):this.ace_editor&&(this.ace_editor.setValue(d),this.ace_editor.session.getSelection().clearSelection(),this.ace_editor.resize());var e=c||this.getValue()!==a;this.refreshValue(),b?this.is_dirty=!1:"change"===this.jsoneditor.options.show_errors&&(this.is_dirty=!0),this.adjust_height&&this.adjust_height(this.input),this.onChange(e)}}},getNumColumns:function(){var a,b=Math.ceil(Math.max(this.getTitle().length,this.schema.maxLength||0,this.schema.minLength||0)/5);return a="textarea"===this.input_type?6:["text","email"].indexOf(this.input_type)>=0?4:2,Math.min(12,Math.max(b,a))},build:function(){var a=this;if(this.options.compact||(this.header=this.label=this.theme.getFormInputLabel(this.getTitle())),this.schema.description&&(this.description=this.theme.getFormInputDescription(this.schema.description)),this.options.infoText&&(this.infoButton=this.theme.getInfoButton(this.options.infoText)),this.format=this.schema.format,!this.format&&this.schema.media&&this.schema.media.type&&(this.format=this.schema.media.type.replace(/(^(application|text)\/(x-)?(script\.)?)|(-source$)/g,"")),!this.format&&this.options.default_format&&(this.format=this.options.default_format),this.options.format&&(this.format=this.options.format),this.format)if("textarea"===this.format)this.input_type="textarea",this.input=this.theme.getTextareaInput();else if("range"===this.format){this.input_type="range";var b=this.schema.minimum||0,c=this.schema.maximum||Math.max(100,b+1),d=1;this.schema.multipleOf&&(b%this.schema.multipleOf&&(b=Math.ceil(b/this.schema.multipleOf)*this.schema.multipleOf),c%this.schema.multipleOf&&(c=Math.floor(c/this.schema.multipleOf)*this.schema.multipleOf),d=this.schema.multipleOf),this.input=this.theme.getRangeInput(b,c,d)}else["actionscript","batchfile","bbcode","c","c++","cpp","coffee","csharp","css","dart","django","ejs","erlang","golang","groovy","handlebars","haskell","haxe","html","ini","jade","java","javascript","json","less","lisp","lua","makefile","markdown","matlab","mysql","objectivec","pascal","perl","pgsql","php","python","r","ruby","sass","scala","scss","smarty","sql","sqlserver","stylus","svg","twig","vbscript","xml","yaml"].indexOf(this.format)>=0?(this.input_type=this.format,this.source_code=!0,this.input=this.theme.getTextareaInput()):(this.input_type=this.format,this.input=this.theme.getFormInputField(this.input_type));else this.input_type="text",this.input=this.theme.getFormInputField(this.input_type);if("undefined"!=typeof this.schema.maxLength&&this.input.setAttribute("maxlength",this.schema.maxLength),"undefined"!=typeof this.schema.pattern?this.input.setAttribute("pattern",this.schema.pattern):"undefined"!=typeof this.schema.minLength&&this.input.setAttribute("pattern",".{"+this.schema.minLength+",}"),this.options.compact?this.container.classList.add("compact"):this.options.input_width&&(this.input.style.width=this.options.input_width),(this.schema.readOnly||this.schema.readonly||this.schema.template)&&(this.always_disabled=!0,this.input.setAttribute("readonly","true")),this.setInputAttributes(["maxlength","pattern","readonly","min","max","step"]),this.input.addEventListener("change",function(b){if(b.preventDefault(),b.stopPropagation(),a.schema.template)return void(this.value=a.value);var c=this.value,d=a.sanitize(c);c!==d&&(this.value=d),a.is_dirty=!0,a.refreshValue(),a.onChange(!0)}),this.options.input_height&&(this.input.style.height=this.options.input_height),this.options.expand_height&&(this.adjust_height=function(a){if(a){var b,c=a.offsetHeight;if(a.offsetHeight<a.scrollHeight)for(b=0;a.offsetHeight<a.scrollHeight+3&&!(b>100);)b++,c++,a.style.height=c+"px";else{for(b=0;a.offsetHeight>=a.scrollHeight+3&&!(b>100);)b++,c--,a.style.height=c+"px";a.style.height=c+1+"px"}}},this.input.addEventListener("keyup",function(b){a.adjust_height(this)}),this.input.addEventListener("change",function(b){a.adjust_height(this)}),this.adjust_height()),this.format&&this.input.setAttribute("data-schemaformat",this.format),this.control=this.theme.getFormControl(this.label,this.input,this.description,this.infoButton),"range"===this.format){var e=document.createElement("output");e.setAttribute("class","range-output"),this.control.appendChild(e),e.value=this.schema["default"],this.input.addEventListener("change",function(){e.value=a.input.value}),this.input.addEventListener("input",function(){e.value=a.input.value})}this.container.appendChild(this.control),window.requestAnimationFrame(function(){a.input.parentNode&&a.afterInputReady(),a.adjust_height&&a.adjust_height(a.input)}),this.schema.template?(this.template=this.jsoneditor.compileTemplate(this.schema.template,this.template_engine),this.refreshValue()):this.refreshValue()},postBuild:function(){this._super(),window.Cleave&&this.schema.options&&"object"==typeof this.schema.options.cleave&&(this.cleave=new window.Cleave(this.input,this.schema.options.cleave))},enable:function(){this.always_disabled||(this.input.disabled=!1,this._super())},disable:function(a){a&&(this.always_disabled=!0),this.input.disabled=!0,this._super()},afterInputReady:function(){var a,b=this;if(this.source_code)if(this.options.wysiwyg&&["html","bbcode"].indexOf(this.input_type)>=0&&window.jQuery&&window.jQuery.fn&&window.jQuery.fn.sceditor)a=e({},{plugins:"html"===b.input_type?"xhtml":"bbcode",emoticonsEnabled:!1,width:"100%",height:300},h.plugins.sceditor,b.options.sceditor_options||{}),window.jQuery(b.input).sceditor(a),b.sceditor_instance=window.jQuery(b.input).sceditor("instance"),b.sceditor_instance.blur(function(){var a=window.jQuery("<div>"+b.sceditor_instance.val()+"</div>");window.jQuery("#sceditor-start-marker,#sceditor-end-marker,.sceditor-nlf",a).remove(),b.input.value=a.html(),b.value=b.input.value,b.is_dirty=!0,b.onChange(!0)});else if("markdown"===this.input_type&&window.SimpleMDE)a=e({},h.plugins.SimpleMDE,{element:this.input}),this.SimpleMDE=new window.SimpleMDE(a),this.SimpleMDE.codemirror.on("change",function(){b.value=b.SimpleMDE.value(),b.is_dirty=!0,b.onChange(!0)});else if(window.ace){var c=this.input_type;"cpp"!==c&&"c++"!==c&&"c"!==c||(c="c_cpp"),this.ace_container=document.createElement("div"),this.ace_container.style.width="100%",this.ace_container.style.position="relative",this.ace_container.style.height="400px",this.input.parentNode.insertBefore(this.ace_container,this.input),this.input.style.display="none",this.ace_editor=window.ace.edit(this.ace_container);var d=this.schema.options&&this.schema.options.ace;d&&this.ace_editor.setOptions(d),this.ace_editor.setValue(this.getValue()),this.ace_editor.session.getSelection().clearSelection(),this.ace_editor.resize(),h.plugins.ace.theme&&this.ace_editor.setTheme("ace/theme/"+h.plugins.ace.theme),this.ace_editor.getSession().setMode("ace/mode/"+this.schema.format),this.ace_editor.on("change",function(){var a=b.ace_editor.getValue();b.input.value=a,b.refreshValue(),b.is_dirty=!0,b.onChange(!0)})}b.theme.afterInputReady(b.input)},refreshValue:function(){this.value=this.input.value,"string"!=typeof this.value&&(this.value=""),this.serialized=this.value},destroy:function(){this.sceditor_instance?this.sceditor_instance.destroy():this.SimpleMDE?(this.SimpleMDE.toTextArea(),this.SimpleMDE=null):this.ace_editor&&this.ace_editor.destroy(),this.cleave&&this.cleave.destroy(),this.template=null,this.input&&this.input.parentNode&&this.input.parentNode.removeChild(this.input),this.label&&this.label.parentNode&&this.label.parentNode.removeChild(this.label),this.description&&this.description.parentNode&&this.description.parentNode.removeChild(this.description),this._super()},sanitize:function(a){return a},onWatchedFieldChange:function(){var a;this.template&&(a=this.getWatchedFieldValues(),this.setValue(this.template(a),!1,!0)),this._super()},showValidationErrors:function(a){var b=this;if("always"===this.jsoneditor.options.show_errors);else if(!this.is_dirty&&this.previous_error_setting===this.jsoneditor.options.show_errors)return;this.previous_error_setting=this.jsoneditor.options.show_errors;var c=[];f(a,function(a,d){d.path===b.path&&c.push(d.message)}),c.length?this.theme.addInputError(this.input,c.join(". ")+"."):this.theme.removeInputError(this.input)}}),h.defaults.editors.hidden=h.AbstractEditor.extend({register:function(){this._super(),this.input&&this.input.setAttribute("name",this.formname)},unregister:function(){this._super(),this.input&&this.input.removeAttribute("name")},setValue:function(a,b,c){if((!this.template||c)&&(null===a||"undefined"==typeof a?a="":"object"==typeof a?a=JSON.stringify(a):"string"!=typeof a&&(a=""+a),a!==this.serialized)){var d=this.sanitize(a);if(this.input.value!==d){this.input.value=d;var e=c||this.getValue()!==a;this.refreshValue(),b?this.is_dirty=!1:"change"===this.jsoneditor.options.show_errors&&(this.is_dirty=!0),this.adjust_height&&this.adjust_height(this.input),this.onChange(e)}}},getNumColumns:function(){return 2},enable:function(){this._super()},disable:function(){this._super()},refreshValue:function(){this.value=this.input.value,"string"!=typeof this.value&&(this.value=""),this.serialized=this.value},destroy:function(){this.template=null,this.input&&this.input.parentNode&&this.input.parentNode.removeChild(this.input),this.label&&this.label.parentNode&&this.label.parentNode.removeChild(this.label),this.description&&this.description.parentNode&&this.description.parentNode.removeChild(this.description),this._super()},sanitize:function(a){return a},onWatchedFieldChange:function(){var a;this.template&&(a=this.getWatchedFieldValues(),this.setValue(this.template(a),!1,!0)),this._super()},build:function(){this.format=this.schema.format,!this.format&&this.options.default_format&&(this.format=this.options.default_format),this.options.format&&(this.format=this.options.format),this.input_type="hidden",this.input=this.theme.getFormInputField(this.input_type),this.format&&this.input.setAttribute("data-schemaformat",this.format),this.container.appendChild(this.input),this.schema.template?(this.template=this.jsoneditor.compileTemplate(this.schema.template,this.template_engine),this.refreshValue()):this.refreshValue()}}),h.defaults.editors.number=h.defaults.editors.string.extend({build:function(){if(this._super(),"undefined"!=typeof this.schema.minimum){var a=this.schema.minimum;"undefined"!=typeof this.schema.exclusiveMinimum&&(a+=1),this.input.setAttribute("min",a)}if("undefined"!=typeof this.schema.maximum){var b=this.schema.maximum;"undefined"!=typeof this.schema.exclusiveMaximum&&(b-=1),this.input.setAttribute("max",b)}if("undefined"!=typeof this.schema.step){var c=this.schema.step||1;this.input.setAttribute("step",c)}this.setInputAttributes(["maxlength","pattern","readonly","min","max","step"])},sanitize:function(a){return(a+"").replace(/[^0-9\.\-eE]/g,"")},getNumColumns:function(){return 2},getValue:function(){return this.dependenciesFulfilled?""===this.value?b:1*this.value:b}}),h.defaults.editors.integer=h.defaults.editors.number.extend({sanitize:function(a){return a+="",a.replace(/[^0-9\-]/g,"")},getNumColumns:function(){return 2}}),h.defaults.editors.rating=h.defaults.editors.integer.extend({build:function(){var a,b=this;this.options.compact||(this.header=this.label=this.theme.getFormInputLabel(this.getTitle())),this.schema.description&&(this.description=this.theme.getFormInputDescription(this.schema.description));var c="json-editor-style-rating",d=document.getElementById(c);if(!d){var e=document.createElement("style");e.id=c,e.type="text/css",e.innerHTML=" .rating-container { display: inline-block; clear: both; } .rating { float:left; } /* :not(:checked) is a filter, so that browsers that don’t support :checked don’t follow these rules. Every browser that supports :checked also supports :not(), so it doesn’t make the test unnecessarily selective */ .rating:not(:checked) > input { position:absolute; top:-9999px; clip:rect(0,0,0,0); } .rating:not(:checked) > label { float:right; width:1em; padding:0 .1em; overflow:hidden; white-space:nowrap; cursor:pointer; color:#ddd; } .rating:not(:checked) > label:before { content: '★ '; } .rating > input:checked ~ label { color: #FFB200; } .rating:not([readOnly]):not(:checked) > label:hover, .rating:not([readOnly]):not(:checked) > label:hover ~ label { color: #FFDA00; } .rating:not([readOnly]) > input:checked + label:hover, .rating:not([readOnly]) > input:checked + label:hover ~ label, .rating:not([readOnly]) > input:checked ~ label:hover, .rating:not([readOnly]) > input:checked ~ label:hover ~ label, .rating:not([readOnly]) > label:hover ~ input:checked ~ label { color: #FF8C0D; } .rating:not([readOnly]) > label:active { position:relative; top:2px; left:2px; }",document.getElementsByTagName("head")[0].appendChild(e)}this.input=this.theme.getFormInputField("hidden"),this.container.appendChild(this.input);var g=document.createElement("div");g.classList.add("rating-container");var h=document.createElement("div");h.setAttribute("name",this.formname),h.classList.add("rating"),g.appendChild(h),this.options.compact&&this.container.setAttribute("class",this.container.getAttribute("class")+" compact");var i=this.schema.maximum?this.schema.maximum:5;for(this.schema.exclusiveMaximum&&i--,this.inputs=[],a=i;a>0;a--){var j=this.formname+a,k=this.theme.getFormInputField("radio");k.setAttribute("id",j),k.setAttribute("value",a),k.setAttribute("name",this.formname),h.appendChild(k),this.inputs.push(k);var l=document.createElement("label");l.setAttribute("for",j),l.appendChild(document.createTextNode(a+(1==a?" star":" stars"))),h.appendChild(l)}(this.schema.readOnly||this.schema.readonly)&&(this.always_disabled=!0,f(this.inputs,function(a,b){h.setAttribute("readOnly","readOnly"),b.disabled=!0})),g.addEventListener("change",function(a){a.preventDefault(),a.stopPropagation(),b.input.value=a.srcElement.value,b.is_dirty=!0,b.refreshValue(),b.watch_listener(),b.jsoneditor.notifyWatchers(b.path),b.parent?b.parent.onChildEditorChange(b):b.jsoneditor.onChange()}),this.control=this.theme.getFormControl(this.label,g,this.description),this.container.appendChild(this.control),this.refreshValue()},setValue:function(a){var b=this.sanitize(a);if(this.value!==b){var c=this;f(this.inputs,function(a,d){if(d.value===b)return d.checked=!0,c.value=b,c.input.value=c.value,c.watch_listener(),c.jsoneditor.notifyWatchers(c.path),!1})}}}),h.defaults.editors.object=h.AbstractEditor.extend({getDefault:function(){return e({},this.schema["default"]||{})},getChildEditors:function(){return this.editors},register:function(){if(this._super(),this.editors)for(var a in this.editors)this.editors.hasOwnProperty(a)&&this.editors[a].register()},unregister:function(){if(this._super(),this.editors)for(var a in this.editors)this.editors.hasOwnProperty(a)&&this.editors[a].unregister()},getNumColumns:function(){return Math.max(Math.min(12,this.maxwidth),3)},enable:function(){if(!this.always_disabled&&(this.editjson_button&&(this.editjson_button.disabled=!1),this.addproperty_button&&(this.addproperty_button.disabled=!1),this._super(),this.editors))for(var a in this.editors)this.editors.hasOwnProperty(a)&&this.editors[a].enable()},disable:function(a){if(a&&(this.always_disabled=!0),this.editjson_button&&(this.editjson_button.disabled=!0),this.addproperty_button&&(this.addproperty_button.disabled=!0),this.hideEditJSON(),this._super(),this.editors)for(var b in this.editors)this.editors.hasOwnProperty(b)&&this.editors[b].disable(a)},layoutEditors:function(){var a,b,c=this;if(this.row_container){this.property_order=Object.keys(this.editors),this.property_order=this.property_order.sort(function(a,b){var d=c.editors[a].schema.propertyOrder,e=c.editors[b].schema.propertyOrder;return"number"!=typeof d&&(d=1e3),"number"!=typeof e&&(e=1e3),d-e});var d,e="categories"===this.format;if("grid"===this.format){var h=[];for(f(this.property_order,function(a,b){var d=c.editors[b];if(!d.property_removed){for(var e=!1,f=d.options.hidden?0:d.options.grid_columns||d.getNumColumns(),g=d.options.hidden?0:d.container.offsetHeight,i=0;i<h.length;i++)h[i].width+f<=12&&(!g||.5*h[i].minh<g&&2*h[i].maxh>g)&&(e=i);e===!1&&(h.push({width:0,minh:999999,maxh:0,editors:[]}),e=h.length-1),h[e].editors.push({key:b,width:f,height:g}),h[e].width+=f,h[e].minh=Math.min(h[e].minh,g),h[e].maxh=Math.max(h[e].maxh,g)}}),a=0;a<h.length;a++)if(h[a].width<12){var i=!1,j=0;for(b=0;b<h[a].editors.length;b++)i===!1?i=b:h[a].editors[b].width>h[a].editors[i].width&&(i=b),h[a].editors[b].width*=12/h[a].width,h[a].editors[b].width=Math.floor(h[a].editors[b].width),j+=h[a].editors[b].width;j<12&&(h[a].editors[i].width+=12-j),h[a].width=12}if(this.layout===JSON.stringify(h))return!1;for(this.layout=JSON.stringify(h),d=document.createElement("div"),a=0;a<h.length;a++){var k=this.theme.getGridRow();for(d.appendChild(k),b=0;b<h[a].editors.length;b++){var l=h[a].editors[b].key,m=this.editors[l];m.options.hidden?m.container.style.display="none":this.theme.setGridColumnSize(m.container,h[a].editors[b].width),k.appendChild(m.container)}}}else{if(d=document.createElement("div"),e){var n=document.createElement("div"),o=this.theme.getTopTabHolder(this.schema.title),p=this.theme.getTopTabContentHolder(o);for(f(this.property_order,function(a,b){var d=c.editors[b];if(!d.property_removed){var e=c.theme.getTabContent(),f=d.schema&&("object"===d.schema.type||"array"===d.schema.type);e.isObjOrArray=f;var g=c.theme.getGridRow();d.tab||("undefined"==typeof c.basicPane?c.addRow(d,o,e):c.addRow(d,o,c.basicPane)),e.id=c.getValidId(d.tab_text.textContent),f?(e.appendChild(g),p.appendChild(e),c.theme.addTopTab(o,d.tab)):(n.appendChild(g),p.childElementCount>0?p.firstChild.isObjOrArray&&(e.appendChild(n),p.insertBefore(e,p.firstChild),c.theme.insertBasicTopTab(d.tab,o),d.basicPane=e):(e.appendChild(n),p.appendChild(e),c.theme.addTopTab(o,d.tab),d.basicPane=e)),d.options.hidden?d.container.style.display="none":c.theme.setGridColumnSize(d.container,12),g.appendChild(d.container),d.rowPane=e}});this.tabPanesContainer.firstChild;)this.tabPanesContainer.removeChild(this.tabPanesContainer.firstChild);var q=this.tabs_holder.parentNode;q.removeChild(q.firstChild),q.appendChild(o),this.tabPanesContainer=p,this.tabs_holder=o;var r=this.theme.getFirstTab(this.tabs_holder);return void(r&&g(r,"click"))}f(this.property_order,function(a,b){var e=c.editors[b];if(!e.property_removed){var f=c.theme.getGridRow();d.appendChild(f),e.options.hidden?e.container.style.display="none":c.theme.setGridColumnSize(e.container,12),f.appendChild(e.container)}})}for(;this.row_container.firstChild;)this.row_container.removeChild(this.row_container.firstChild);this.row_container.appendChild(d)}},getPropertySchema:function(a){var b=this.schema.properties[a]||{};b=e({},b);var c=!!this.schema.properties[a];if(this.schema.patternProperties)for(var d in this.schema.patternProperties)if(this.schema.patternProperties.hasOwnProperty(d)){var f=new RegExp(d);f.test(a)&&(b.allOf=b.allOf||[],b.allOf.push(this.schema.patternProperties[d]),c=!0)}return!c&&this.schema.additionalProperties&&"object"==typeof this.schema.additionalProperties&&(b=e({},this.schema.additionalProperties)),b},preBuild:function(){this._super(),this.editors={},this.cached_editors={};var a=this;if(this.format=this.options.layout||this.options.object_layout||this.schema.format||this.jsoneditor.options.object_layout||"normal",this.schema.properties=this.schema.properties||{},this.minwidth=0,this.maxwidth=0,this.options.table_row)f(this.schema.properties,function(b,c){var d=a.jsoneditor.getEditorClass(c);a.editors[b]=a.jsoneditor.createEditor(d,{jsoneditor:a.jsoneditor,schema:c,path:a.path+"."+b,parent:a,compact:!0,required:!0}),a.editors[b].preBuild();var e=a.editors[b].options.hidden?0:a.editors[b].options.grid_columns||a.editors[b].getNumColumns();a.minwidth+=e,a.maxwidth+=e}),this.no_link_holder=!0;else{if(this.options.table)throw"Not supported yet";this.schema.defaultProperties||(this.jsoneditor.options.display_required_only||this.options.display_required_only?(this.schema.defaultProperties=[],f(this.schema.properties,function(b,c){a.isRequired({key:b,schema:c})&&a.schema.defaultProperties.push(b)})):a.schema.defaultProperties=Object.keys(a.schema.properties)),a.maxwidth+=1,f(this.schema.defaultProperties,function(b,c){a.addObjectProperty(c,!0),a.editors[c]&&(a.minwidth=Math.max(a.minwidth,a.editors[c].options.grid_columns||a.editors[c].getNumColumns()),a.maxwidth+=a.editors[c].options.grid_columns||a.editors[c].getNumColumns())})}this.property_order=Object.keys(this.editors),this.property_order=this.property_order.sort(function(b,c){var d=a.editors[b].schema.propertyOrder,e=a.editors[c].schema.propertyOrder;return"number"!=typeof d&&(d=1e3),"number"!=typeof e&&(e=1e3),d-e})},addTab:function(a){var b=this,c=b.rows[a].schema&&("object"===b.rows[a].schema.type||"array"===b.rows[a].schema.type);b.tabs_holder&&(b.rows[a].tab_text=document.createElement("span"),c?b.rows[a].tab_text.textContent=b.rows[a].getHeaderText():b.rows[a].tab_text.textContent="undefined"==typeof b.schema.basicCategoryTitle?"Basic":b.schema.basicCategoryTitle,b.rows[a].tab=b.theme.getTopTab(b.rows[a].tab_text,this.getValidId(b.rows[a].tab_text.textContent)),b.rows[a].tab.addEventListener("click",function(c){b.active_tab=b.rows[a].tab,b.refreshTabs(),c.preventDefault(),c.stopPropagation()}))},addRow:function(a,b,c){var d=this,e=this.rows.length,f="object"===a.schema.type||"array"===a.schema.type;d.rows[e]=a,d.rows[e].rowPane=c,f?(d.addTab(e),d.theme.addTopTab(b,d.rows[e].tab)):"undefined"==typeof d.basicTab?(d.addTab(e),d.basicTab=e,d.basicPane=c,d.theme.addTopTab(b,d.rows[e].tab)):(d.rows[e].tab=d.rows[d.basicTab].tab,d.rows[e].tab_text=d.rows[d.basicTab].tab_text,d.rows[e].rowPane=d.rows[d.basicTab].rowPane)},refreshTabs:function(a){var b=this,c="undefined"!=typeof b.basicTab,d=!1;f(this.rows,function(e,f){f.tab&&f.rowPane&&f.rowPane.parentNode&&(c&&f.tab==b.rows[b.basicTab].tab&&d||(a?f.tab_text.textContent=f.getHeaderText():(c&&f.tab==b.rows[b.basicTab].tab&&(d=!0),f.tab===b.active_tab?b.theme.markTabActive(f):b.theme.markTabInactive(f))))})},build:function(){var a=this,b="categories"===this.format;if(this.rows=[],this.active_tab=null,this.options.table_row)this.editor_holder=this.container,f(this.editors,function(b,c){var d=a.theme.getTableCell();a.editor_holder.appendChild(d),c.setContainer(d),c.build(),c.postBuild(),a.editors[b].options.hidden&&(d.style.display="none"),a.editors[b].options.input_width&&(d.style.width=a.editors[b].options.input_width)});else{if(this.options.table)throw"Not supported yet";this.header=document.createElement("span"),this.header.textContent=this.getTitle(),this.title=this.theme.getHeader(this.header),this.container.appendChild(this.title),this.container.style.position="relative",this.editjson_holder=this.theme.getModal(),this.editjson_textarea=this.theme.getTextareaInput(),this.editjson_textarea.style.height="170px",this.editjson_textarea.style.width="300px",this.editjson_textarea.style.display="block",this.editjson_save=this.getButton("Save","save","Save"),this.editjson_save.classList.add("json-editor-btntype-save"),this.editjson_save.addEventListener("click",function(b){b.preventDefault(),b.stopPropagation(),a.saveJSON()}),this.editjson_copy=this.getButton("Copy","copy","Copy"),this.editjson_copy.classList.add("json-editor-btntype-copy"),this.editjson_copy.addEventListener("click",function(b){b.preventDefault(),b.stopPropagation(),a.copyJSON()}),this.editjson_cancel=this.getButton("Cancel","cancel","Cancel"),this.editjson_cancel.classList.add("json-editor-btntype-cancel"),this.editjson_cancel.addEventListener("click",function(b){b.preventDefault(),b.stopPropagation(),a.hideEditJSON()}),this.editjson_holder.appendChild(this.editjson_textarea),this.editjson_holder.appendChild(this.editjson_save),this.editjson_holder.appendChild(this.editjson_copy),this.editjson_holder.appendChild(this.editjson_cancel),this.addproperty_holder=this.theme.getModal(),this.addproperty_list=document.createElement("div"),this.addproperty_list.style.width="295px",this.addproperty_list.style.maxHeight="160px",this.addproperty_list.style.padding="5px 0",this.addproperty_list.style.overflowY="auto",this.addproperty_list.style.overflowX="hidden",this.addproperty_list.style.paddingLeft="5px",this.addproperty_list.setAttribute("class","property-selector"),this.addproperty_add=this.getButton("add","add","add"),this.addproperty_add.classList.add("json-editor-btntype-add"),this.addproperty_input=this.theme.getFormInputField("text"),this.addproperty_input.setAttribute("placeholder","Property name..."),this.addproperty_input.style.width="220px",this.addproperty_input.style.marginBottom="0",this.addproperty_input.style.display="inline-block",this.addproperty_add.addEventListener("click",function(b){if(b.preventDefault(),b.stopPropagation(),a.addproperty_input.value){if(a.editors[a.addproperty_input.value])return void window.alert("there is already a property with that name");a.addObjectProperty(a.addproperty_input.value),a.editors[a.addproperty_input.value]&&a.editors[a.addproperty_input.value].disable(),a.onChange(!0)}}),this.addproperty_holder.appendChild(this.addproperty_list),this.addproperty_holder.appendChild(this.addproperty_input),this.addproperty_holder.appendChild(this.addproperty_add);var c=document.createElement("div");c.style.clear="both",this.addproperty_holder.appendChild(c),document.addEventListener("click",function(a){!this.addproperty_holder.contains(a.target)&&this.adding_property&&(a.preventDefault(),a.stopPropagation(),this.toggleAddProperty())}.bind(this)),this.schema.description&&(this.description=this.theme.getDescription(this.schema.description),this.container.appendChild(this.description)),this.error_holder=document.createElement("div"),this.container.appendChild(this.error_holder),this.editor_holder=this.theme.getIndentedPanel(),this.container.appendChild(this.editor_holder),this.row_container=this.theme.getGridContainer(),b?(this.tabs_holder=this.theme.getTopTabHolder(this.getValidId(this.schema.title)),this.tabPanesContainer=this.theme.getTopTabContentHolder(this.tabs_holder),this.editor_holder.appendChild(this.tabs_holder)):(this.tabs_holder=this.theme.getTabHolder(this.getValidId(this.schema.title)),this.tabPanesContainer=this.theme.getTabContentHolder(this.tabs_holder),this.editor_holder.appendChild(this.row_container)),f(this.editors,function(c,d){var e=a.theme.getTabContent(),f=a.theme.getGridColumn(),g=!(!d.schema||"object"!==d.schema.type&&"array"!==d.schema.type);if(e.isObjOrArray=g,b){if(g){var h=a.theme.getGridContainer();h.appendChild(f),e.appendChild(h),a.tabPanesContainer.appendChild(e),a.row_container=h}else"undefined"==typeof a.row_container_basic&&(a.row_container_basic=a.theme.getGridContainer(),e.appendChild(a.row_container_basic),0==a.tabPanesContainer.childElementCount?a.tabPanesContainer.appendChild(e):a.tabPanesContainer.insertBefore(e,a.tabPanesContainer.childNodes[1])),a.row_container_basic.appendChild(f);a.addRow(d,a.tabs_holder,e),e.id=a.getValidId(d.schema.title)}else a.row_container.appendChild(f);d.setContainer(f),d.build(),d.postBuild()}),this.rows[0]&&g(this.rows[0].tab,"click"),this.title_controls=this.theme.getHeaderButtonHolder(),this.editjson_controls=this.theme.getHeaderButtonHolder(),this.addproperty_controls=this.theme.getHeaderButtonHolder(),this.title.appendChild(this.title_controls),this.title.appendChild(this.editjson_controls),this.title.appendChild(this.addproperty_controls),this.collapsed=!1,this.toggle_button=this.getButton("","collapse",this.translate("button_collapse")),this.toggle_button.classList.add("json-editor-btntype-toggle"),this.title_controls.appendChild(this.toggle_button),this.toggle_button.addEventListener("click",function(b){b.preventDefault(),b.stopPropagation(),a.collapsed?(a.editor_holder.style.display="",a.collapsed=!1,a.setButtonText(a.toggle_button,"","collapse",a.translate("button_collapse"))):(a.editor_holder.style.display="none",a.collapsed=!0,a.setButtonText(a.toggle_button,"","expand",a.translate("button_expand")))}),this.options.collapsed&&g(this.toggle_button,"click"),this.schema.options&&"undefined"!=typeof this.schema.options.disable_collapse?this.schema.options.disable_collapse&&(this.toggle_button.style.display="none"):this.jsoneditor.options.disable_collapse&&(this.toggle_button.style.display="none"),this.editjson_button=this.getButton("JSON","edit","Edit JSON"),this.editjson_button.classList.add("json-editor-btntype-editjson"),this.editjson_button.addEventListener("click",function(b){b.preventDefault(),b.stopPropagation(),a.toggleEditJSON()}),this.editjson_controls.appendChild(this.editjson_button),this.editjson_controls.appendChild(this.editjson_holder),this.schema.options&&"undefined"!=typeof this.schema.options.disable_edit_json?this.schema.options.disable_edit_json&&(this.editjson_button.style.display="none"):this.jsoneditor.options.disable_edit_json&&(this.editjson_button.style.display="none"),this.addproperty_button=this.getButton("Properties","edit","Object Properties"),this.addproperty_button.classList.add("json-editor-btntype-properties"),this.addproperty_button.addEventListener("click",function(b){b.preventDefault(),b.stopPropagation(),a.toggleAddProperty()}),this.addproperty_controls.appendChild(this.addproperty_button),this.addproperty_controls.appendChild(this.addproperty_holder),this.refreshAddProperties()}this.options.table_row?(this.editor_holder=this.container,f(this.property_order,function(b,c){a.editor_holder.appendChild(a.editors[c].container)})):(this.layoutEditors(),this.layoutEditors())},showEditJSON:function(){this.editjson_holder&&(this.hideAddProperty(),this.editjson_holder.style.left=this.editjson_button.offsetLeft+"px",this.editjson_holder.style.top=this.editjson_button.offsetTop+this.editjson_button.offsetHeight+"px",this.editjson_textarea.value=JSON.stringify(this.getValue(),null,2),this.disable(),this.editjson_holder.style.display="",this.editjson_button.disabled=!1,this.editing_json=!0)},hideEditJSON:function(){this.editjson_holder&&this.editing_json&&(this.editjson_holder.style.display="none",this.enable(),this.editing_json=!1)},copyJSON:function(){if(this.editjson_holder){var a=document.createElement("textarea");a.value=this.editjson_textarea.value,a.setAttribute("readonly",""),a.style.position="absolute",a.style.left="-9999px",document.body.appendChild(a),a.select(),document.execCommand("copy"),document.body.removeChild(a)}},saveJSON:function(){if(this.editjson_holder)try{var a=JSON.parse(this.editjson_textarea.value);this.setValue(a),this.hideEditJSON(),this.onChange(!0)}catch(b){throw window.alert("invalid JSON"),b}},toggleEditJSON:function(){this.editing_json?this.hideEditJSON():this.showEditJSON()},insertPropertyControlUsingPropertyOrder:function(a,b,c){var d;this.schema.properties[a]&&(d=this.schema.properties[a].propertyOrder),"number"!=typeof d&&(d=1e3),b.propertyOrder=d;for(var e=0;e<c.childNodes.length;e++){var f=c.childNodes[e];if(b.propertyOrder<f.propertyOrder){this.addproperty_list.insertBefore(b,f),b=null;break}}b&&this.addproperty_list.appendChild(b)},addPropertyCheckbox:function(a){var b,c,d,e,f=this;return b=f.theme.getCheckbox(),b.style.width="auto",d=this.schema.properties[a]&&this.schema.properties[a].title?this.schema.properties[a].title:a,c=f.theme.getCheckboxLabel(d),e=f.theme.getFormControl(c,b),e.style.paddingBottom=e.style.marginBottom=e.style.paddingTop=e.style.marginTop=0,e.style.height="auto",this.insertPropertyControlUsingPropertyOrder(a,e,this.addproperty_list), +b.checked=a in this.editors,b.addEventListener("change",function(){b.checked?f.addObjectProperty(a):f.removeObjectProperty(a),f.onChange(!0)}),f.addproperty_checkboxes[a]=b,b},showAddProperty:function(){this.addproperty_holder&&(this.hideEditJSON(),this.addproperty_holder.style.left=this.addproperty_button.offsetLeft+"px",this.addproperty_holder.style.top=this.addproperty_button.offsetTop+this.addproperty_button.offsetHeight+"px",this.disable(),this.adding_property=!0,this.addproperty_button.disabled=!1,this.addproperty_holder.style.display="",this.refreshAddProperties())},hideAddProperty:function(){this.addproperty_holder&&this.adding_property&&(this.addproperty_holder.style.display="none",this.enable(),this.adding_property=!1)},toggleAddProperty:function(){this.adding_property?this.hideAddProperty():this.showAddProperty()},removeObjectProperty:function(a){this.editors[a]&&(this.editors[a].unregister(),delete this.editors[a],this.refreshValue(),this.layoutEditors())},addObjectProperty:function(a,b){var c=this;if(!this.editors[a]){if(this.cached_editors[a]){if(this.editors[a]=this.cached_editors[a],b)return;this.editors[a].register()}else{if(!(this.canHaveAdditionalProperties()||this.schema.properties&&this.schema.properties[a]))return;var d=c.getPropertySchema(a);"number"!=typeof d.propertyOrder&&(d.propertyOrder=Object.keys(c.editors).length+1e3);var e=c.jsoneditor.getEditorClass(d);if(c.editors[a]=c.jsoneditor.createEditor(e,{jsoneditor:c.jsoneditor,schema:d,path:c.path+"."+a,parent:c}),c.editors[a].preBuild(),!b){var f=c.theme.getChildEditorHolder();c.editor_holder.appendChild(f),c.editors[a].setContainer(f),c.editors[a].build(),c.editors[a].postBuild()}c.cached_editors[a]=c.editors[a]}b||(c.refreshValue(),c.layoutEditors())}},onChildEditorChange:function(a){this.refreshValue(),this._super(a)},canHaveAdditionalProperties:function(){return"boolean"==typeof this.schema.additionalProperties?this.schema.additionalProperties:!this.jsoneditor.options.no_additional_properties},destroy:function(){f(this.cached_editors,function(a,b){b.destroy()}),this.editor_holder&&(this.editor_holder.innerHTML=""),this.title&&this.title.parentNode&&this.title.parentNode.removeChild(this.title),this.error_holder&&this.error_holder.parentNode&&this.error_holder.parentNode.removeChild(this.error_holder),this.editors=null,this.cached_editors=null,this.editor_holder&&this.editor_holder.parentNode&&this.editor_holder.parentNode.removeChild(this.editor_holder),this.editor_holder=null,this._super()},getValue:function(){if(!this.dependenciesFulfilled)return b;var a=this._super();if(this.jsoneditor.options.remove_empty_properties||this.options.remove_empty_properties)for(var c in a)a.hasOwnProperty(c)&&("undefined"==typeof a[c]||""===a[c]||a[c]===Object(a[c])&&0==Object.keys(a[c]).length&&a[c].constructor==Object)&&delete a[c];return a},refreshValue:function(){this.value={};for(var a in this.editors)this.editors.hasOwnProperty(a)&&(this.value[a]=this.editors[a].getValue());this.adding_property&&this.refreshAddProperties()},refreshAddProperties:function(){if(this.options.disable_properties||this.options.disable_properties!==!1&&this.jsoneditor.options.disable_properties)return void(this.addproperty_controls.style.display="none");var a,b=!1,c=!1,d=0,e=!1;for(a in this.editors)this.editors.hasOwnProperty(a)&&d++;b=this.canHaveAdditionalProperties()&&!("undefined"!=typeof this.schema.maxProperties&&d>=this.schema.maxProperties),this.addproperty_checkboxes&&(this.addproperty_list.innerHTML=""),this.addproperty_checkboxes={};for(a in this.cached_editors)this.cached_editors.hasOwnProperty(a)&&(this.addPropertyCheckbox(a),this.isRequired(this.cached_editors[a])&&a in this.editors&&(this.addproperty_checkboxes[a].disabled=!0),"undefined"!=typeof this.schema.minProperties&&d<=this.schema.minProperties?(this.addproperty_checkboxes[a].disabled=this.addproperty_checkboxes[a].checked,this.addproperty_checkboxes[a].checked||(e=!0)):a in this.editors?(e=!0,c=!0):b||this.schema.properties.hasOwnProperty(a)?(this.addproperty_checkboxes[a].disabled=!1,e=!0):this.addproperty_checkboxes[a].disabled=!0);this.canHaveAdditionalProperties()&&(e=!0);for(a in this.schema.properties)this.schema.properties.hasOwnProperty(a)&&(this.cached_editors[a]||(e=!0,this.addPropertyCheckbox(a)));e?this.canHaveAdditionalProperties()?b?this.addproperty_add.disabled=!1:this.addproperty_add.disabled=!0:(this.addproperty_add.style.display="none",this.addproperty_input.style.display="none"):(this.hideAddProperty(),this.addproperty_controls.style.display="none")},isRequired:function(a){return"boolean"==typeof a.schema.required?a.schema.required:Array.isArray(this.schema.required)?this.schema.required.indexOf(a.key)>-1:!!this.jsoneditor.options.required_by_default},setValue:function(a,b){var c=this;a=a||{},("object"!=typeof a||Array.isArray(a))&&(a={}),f(this.cached_editors,function(d,e){"undefined"!=typeof a[d]?(c.addObjectProperty(d),e.setValue(a[d],b)):b||c.isRequired(e)?e.setValue(e.getDefault(),b):c.removeObjectProperty(d)}),f(a,function(a,d){c.cached_editors[a]||(c.addObjectProperty(a),c.editors[a]&&c.editors[a].setValue(d,b))}),this.refreshValue(),this.layoutEditors(),this.onChange()},showValidationErrors:function(a){var b=this,c=[],d=[];if(f(a,function(a,e){e.path===b.path?c.push(e):d.push(e)}),this.error_holder)if(c.length){this.error_holder.innerHTML="",this.error_holder.style.display="",f(c,function(a,c){b.error_holder.appendChild(b.theme.getErrorMessage(c.message))})}else this.error_holder.style.display="none";this.options.table_row&&(c.length?this.theme.addTableRowError(this.container):this.theme.removeTableRowError(this.container)),f(this.editors,function(a,b){b.showValidationErrors(d)})}}),h.defaults.editors.array=h.AbstractEditor.extend({askConfirmation:function(){return this.jsoneditor.options.prompt_before_delete!==!0||confirm("Are you sure you want to remove this node?")!==!1},getDefault:function(){return this.schema["default"]||[]},register:function(){if(this._super(),this.rows)for(var a=0;a<this.rows.length;a++)this.rows[a].register()},unregister:function(){if(this._super(),this.rows)for(var a=0;a<this.rows.length;a++)this.rows[a].unregister()},getNumColumns:function(){var a=this.getItemInfo(0);return this.tabs_holder&&"tabs-top"!==this.schema.format?Math.max(Math.min(12,a.width+2),4):a.width},enable:function(){if(!this.always_disabled){if(this.add_row_button&&(this.add_row_button.disabled=!1),this.remove_all_rows_button&&(this.remove_all_rows_button.disabled=!1),this.delete_last_row_button&&(this.delete_last_row_button.disabled=!1),this.rows)for(var a=0;a<this.rows.length;a++)this.rows[a].enable(),this.rows[a].moveup_button&&(this.rows[a].moveup_button.disabled=!1),this.rows[a].movedown_button&&(this.rows[a].movedown_button.disabled=!1),this.rows[a].delete_button&&(this.rows[a].delete_button.disabled=!1);this._super()}},disable:function(a){if(a&&(this.always_disabled=!0),this.add_row_button&&(this.add_row_button.disabled=!0),this.remove_all_rows_button&&(this.remove_all_rows_button.disabled=!0),this.delete_last_row_button&&(this.delete_last_row_button.disabled=!0),this.rows)for(var b=0;b<this.rows.length;b++)this.rows[b].disable(a),this.rows[b].moveup_button&&(this.rows[b].moveup_button.disabled=!0),this.rows[b].movedown_button&&(this.rows[b].movedown_button.disabled=!0),this.rows[b].delete_button&&(this.rows[b].delete_button.disabled=!0);this._super()},preBuild:function(){this._super(),this.rows=[],this.row_cache=[],this.hide_delete_buttons=this.options.disable_array_delete||this.jsoneditor.options.disable_array_delete,this.hide_delete_all_rows_buttons=this.hide_delete_buttons||this.options.disable_array_delete_all_rows||this.jsoneditor.options.disable_array_delete_all_rows,this.hide_delete_last_row_buttons=this.hide_delete_buttons||this.options.disable_array_delete_last_row||this.jsoneditor.options.disable_array_delete_last_row,this.hide_move_buttons=this.options.disable_array_reorder||this.jsoneditor.options.disable_array_reorder,this.hide_add_button=this.options.disable_array_add||this.jsoneditor.options.disable_array_add,this.show_copy_button=this.options.enable_array_copy||this.jsoneditor.options.enable_array_copy,this.array_controls_top=this.options.array_controls_top||this.jsoneditor.options.array_controls_top},build:function(){this.options.compact?(this.panel=this.theme.getIndentedPanel(),this.container.appendChild(this.panel),this.title_controls=this.theme.getHeaderButtonHolder(),this.panel.appendChild(this.title_controls),this.controls=this.theme.getButtonHolder(),this.panel.appendChild(this.controls),this.row_holder=document.createElement("div"),this.panel.appendChild(this.row_holder)):(this.header=document.createElement("span"),this.header.textContent=this.getTitle(),this.title=this.theme.getHeader(this.header),this.container.appendChild(this.title),this.title_controls=this.theme.getHeaderButtonHolder(),this.title.appendChild(this.title_controls),this.schema.description&&(this.description=this.theme.getDescription(this.schema.description),this.container.appendChild(this.description)),this.error_holder=document.createElement("div"),this.container.appendChild(this.error_holder),"tabs-top"===this.schema.format?(this.controls=this.theme.getHeaderButtonHolder(),this.title.appendChild(this.controls),this.tabs_holder=this.theme.getTopTabHolder(this.getValidId(this.getItemTitle())),this.container.appendChild(this.tabs_holder),this.row_holder=this.theme.getTopTabContentHolder(this.tabs_holder),this.active_tab=null):"tabs"===this.schema.format?(this.controls=this.theme.getHeaderButtonHolder(),this.title.appendChild(this.controls),this.tabs_holder=this.theme.getTabHolder(this.getValidId(this.getItemTitle())),this.container.appendChild(this.tabs_holder),this.row_holder=this.theme.getTabContentHolder(this.tabs_holder),this.active_tab=null):(this.panel=this.theme.getIndentedPanel(),this.container.appendChild(this.panel),this.row_holder=document.createElement("div"),this.panel.appendChild(this.row_holder),this.controls=this.theme.getButtonHolder(),this.array_controls_top?this.title.appendChild(this.controls):this.panel.appendChild(this.controls))),this.addControls()},onChildEditorChange:function(a){this.refreshValue(),this.refreshTabs(!0),this._super(a)},getItemTitle:function(){if(!this.item_title)if(this.schema.items&&!Array.isArray(this.schema.items)){var a=this.jsoneditor.expandRefs(this.schema.items);this.item_title=a.title||"item"}else this.item_title="item";return this.item_title},getItemSchema:function(a){return Array.isArray(this.schema.items)?a>=this.schema.items.length?this.schema.additionalItems===!0?{}:this.schema.additionalItems?e({},this.schema.additionalItems):void 0:e({},this.schema.items[a]):this.schema.items?e({},this.schema.items):{}},getItemInfo:function(a){var b=this.getItemSchema(a);this.item_info=this.item_info||{};var c=JSON.stringify(b);return"undefined"!=typeof this.item_info[c]?this.item_info[c]:(b=this.jsoneditor.expandRefs(b),this.item_info[c]={title:b.title||"item","default":b["default"],width:12,child_editors:b.properties||b.items},this.item_info[c])},getElementEditor:function(a){var b=this.getItemInfo(a),c=this.getItemSchema(a);c=this.jsoneditor.expandRefs(c),c.title=b.title+" "+(a+1);var d,e=this.jsoneditor.getEditorClass(c);this.tabs_holder?(d="tabs-top"===this.schema.format?this.theme.getTopTabContent():this.theme.getTabContent(),d.id=this.path+"."+a):d=b.child_editors?this.theme.getChildEditorHolder():this.theme.getIndentedPanel(),this.row_holder.appendChild(d);var f=this.jsoneditor.createEditor(e,{jsoneditor:this.jsoneditor,schema:c,container:d,path:this.path+"."+a,parent:this,required:!0});return f.preBuild(),f.build(),f.postBuild(),f.title_controls||(f.array_controls=this.theme.getButtonHolder(),d.appendChild(f.array_controls)),f},destroy:function(){this.empty(!0),this.title&&this.title.parentNode&&this.title.parentNode.removeChild(this.title),this.description&&this.description.parentNode&&this.description.parentNode.removeChild(this.description),this.row_holder&&this.row_holder.parentNode&&this.row_holder.parentNode.removeChild(this.row_holder),this.controls&&this.controls.parentNode&&this.controls.parentNode.removeChild(this.controls),this.panel&&this.panel.parentNode&&this.panel.parentNode.removeChild(this.panel),this.rows=this.row_cache=this.title=this.description=this.row_holder=this.panel=this.controls=null,this._super()},empty:function(a){if(this.rows){var b=this;f(this.rows,function(c,d){a&&(d.tab&&d.tab.parentNode&&d.tab.parentNode.removeChild(d.tab),b.destroyRow(d,!0),b.row_cache[c]=null),b.rows[c]=null}),b.rows=[],a&&(b.row_cache=[])}},destroyRow:function(a,b){var c=a.container;b?(a.destroy(),c.parentNode&&c.parentNode.removeChild(c),a.tab&&a.tab.parentNode&&a.tab.parentNode.removeChild(a.tab)):(a.tab&&(a.tab.style.display="none"),c.style.display="none",a.unregister())},getMax:function(){return Array.isArray(this.schema.items)&&this.schema.additionalItems===!1?Math.min(this.schema.items.length,this.schema.maxItems||1/0):this.schema.maxItems||1/0},refreshTabs:function(a){var b=this;f(this.rows,function(c,d){d.tab&&(a?d.tab_text.textContent=d.getHeaderText():d.tab===b.active_tab?b.theme.markTabActive(d):b.theme.markTabInactive(d))})},setValue:function(a,b){a=a||[],Array.isArray(a)||(a=[a]);var c=JSON.stringify(a);if(c!==this.serialized){if(this.schema.minItems)for(;a.length<this.schema.minItems;)a.push(this.getItemInfo(a.length)["default"]);this.getMax()&&a.length>this.getMax()&&(a=a.slice(0,this.getMax()));var d=this;f(a,function(a,c){d.rows[a]?d.rows[a].setValue(c,b):d.row_cache[a]?(d.rows[a]=d.row_cache[a],d.rows[a].setValue(c,b),d.rows[a].container.style.display="",d.rows[a].tab&&(d.rows[a].tab.style.display=""),d.rows[a].register()):d.addRow(c,b)});for(var e=a.length;e<d.rows.length;e++)d.destroyRow(d.rows[e]),d.rows[e]=null;d.rows=d.rows.slice(0,a.length);var g=null;f(d.rows,function(a,b){if(b.tab===d.active_tab)return g=b.tab,!1}),!g&&d.rows.length&&(g=d.rows[0].tab),d.active_tab=g,d.refreshValue(b),d.refreshTabs(!0),d.refreshTabs(),d.onChange()}},refreshValue:function(a){var b=this,c=this.value?this.value.length:0;if(this.value=[],f(this.rows,function(a,c){b.value[a]=c.getValue()}),c!==this.value.length||a){var d=this.schema.minItems&&this.schema.minItems>=this.rows.length;f(this.rows,function(a,c){c.movedown_button&&(a===b.rows.length-1?c.movedown_button.style.display="none":c.movedown_button.style.display=""),c.delete_button&&(d?c.delete_button.style.display="none":c.delete_button.style.display=""),b.value[a]=c.getValue()});var e=!1;this.value.length?1===this.value.length?(this.remove_all_rows_button.style.display="none",d||this.hide_delete_last_row_buttons?this.delete_last_row_button.style.display="none":(this.delete_last_row_button.style.display="",e=!0)):(d||this.hide_delete_last_row_buttons?this.delete_last_row_button.style.display="none":(this.delete_last_row_button.style.display="",e=!0),d||this.hide_delete_all_rows_buttons?this.remove_all_rows_button.style.display="none":(this.remove_all_rows_button.style.display="",e=!0)):(this.delete_last_row_button.style.display="none",this.remove_all_rows_button.style.display="none"),this.getMax()&&this.getMax()<=this.rows.length||this.hide_add_button?this.add_row_button.style.display="none":(this.add_row_button.style.display="",e=!0),!this.collapsed&&e?this.controls.style.display="inline-block":this.controls.style.display="none"}},addRow:function(a,b){var c=this,d=this.rows.length;c.rows[d]=this.getElementEditor(d),c.row_cache[d]=c.rows[d],c.tabs_holder&&(c.rows[d].tab_text=document.createElement("span"),c.rows[d].tab_text.textContent=c.rows[d].getHeaderText(),"tabs-top"===c.schema.format?(c.rows[d].tab=c.theme.getTopTab(c.rows[d].tab_text,this.getValidId(c.rows[d].path)),c.theme.addTopTab(c.tabs_holder,c.rows[d].tab)):(c.rows[d].tab=c.theme.getTab(c.rows[d].tab_text,this.getValidId(c.rows[d].path)),c.theme.addTab(c.tabs_holder,c.rows[d].tab)),c.rows[d].tab.addEventListener("click",function(a){c.active_tab=c.rows[d].tab,c.refreshTabs(),a.preventDefault(),a.stopPropagation()}));var e=c.rows[d].title_controls||c.rows[d].array_controls;c.hide_delete_buttons||(c.rows[d].delete_button=this.getButton(c.getItemTitle(),"delete",this.translate("button_delete_row_title",[c.getItemTitle()])),c.rows[d].delete_button.classList.add("delete","json-editor-btntype-delete"),c.rows[d].delete_button.setAttribute("data-i",d),c.rows[d].delete_button.addEventListener("click",function(a){if(a.preventDefault(),a.stopPropagation(),!c.askConfirmation())return!1;var b=1*this.getAttribute("data-i"),d=c.getValue(),e=[],g=null;f(d,function(a,c){a!==b&&e.push(c)}),c.empty(!0),c.setValue(e),c.rows[b]?g=c.rows[b].tab:c.rows[b-1]&&(g=c.rows[b-1].tab),g&&(c.active_tab=g,c.refreshTabs()),c.onChange(!0),c.jsoneditor.trigger("deleteRow")}),e&&e.appendChild(c.rows[d].delete_button)),c.show_copy_button&&(c.rows[d].copy_button=this.getButton(c.getItemTitle(),"copy","Copy "+c.getItemTitle()),c.rows[d].copy_button.classList.add("copy","json-editor-btntype-copy"),c.rows[d].copy_button.setAttribute("data-i",d),c.rows[d].copy_button.addEventListener("click",function(a){var b=c.getValue();a.preventDefault(),a.stopPropagation();var d=1*this.getAttribute("data-i");f(b,function(a,c){a===d&&b.push(c)}),c.setValue(b),c.refreshValue(!0),c.onChange(!0)}),e.appendChild(c.rows[d].copy_button)),d&&!c.hide_move_buttons&&(c.rows[d].moveup_button=this.getButton("","moveup",this.translate("button_move_up_title")),c.rows[d].moveup_button.classList.add("moveup","json-editor-btntype-move"),c.rows[d].moveup_button.setAttribute("data-i",d),c.rows[d].moveup_button.addEventListener("click",function(a){a.preventDefault(),a.stopPropagation();var b=1*this.getAttribute("data-i");if(!(b<=0)){var d=c.getValue(),e=d[b-1];d[b-1]=d[b],d[b]=e,c.setValue(d),c.active_tab=c.rows[b-1].tab,c.refreshTabs(),c.onChange(!0),c.jsoneditor.trigger("moveRow")}}),e&&e.appendChild(c.rows[d].moveup_button)),c.hide_move_buttons||(c.rows[d].movedown_button=this.getButton("","movedown",this.translate("button_move_down_title")),c.rows[d].movedown_button.classList.add("movedown","json-editor-btntype-move"),c.rows[d].movedown_button.setAttribute("data-i",d),c.rows[d].movedown_button.addEventListener("click",function(a){a.preventDefault(),a.stopPropagation();var b=1*this.getAttribute("data-i"),d=c.getValue();if(!(b>=d.length-1)){var e=d[b+1];d[b+1]=d[b],d[b]=e,c.setValue(d),c.active_tab=c.rows[b+1].tab,c.refreshTabs(),c.onChange(!0),c.jsoneditor.trigger("moveRow")}}),e&&e.appendChild(c.rows[d].movedown_button)),a&&c.rows[d].setValue(a,b),c.refreshTabs()},addControls:function(){var a=this;this.collapsed=!1,this.toggle_button=this.getButton("","collapse",this.translate("button_collapse")),this.toggle_button.classList.add("json-editor-btntype-toggle"),this.title_controls.appendChild(this.toggle_button);var b=a.row_holder.style.display,c=a.controls.style.display;this.toggle_button.addEventListener("click",function(d){d.preventDefault(),d.stopPropagation(),a.collapsed?(a.collapsed=!1,a.panel&&(a.panel.style.display=""),a.row_holder.style.display=b,a.tabs_holder&&(a.tabs_holder.style.display=""),a.controls.style.display=c,a.setButtonText(this,"","collapse",a.translate("button_collapse"))):(a.collapsed=!0,a.row_holder.style.display="none",a.tabs_holder&&(a.tabs_holder.style.display="none"),a.controls.style.display="none",a.panel&&(a.panel.style.display="none"),a.setButtonText(this,"","expand",a.translate("button_expand")))}),this.options.collapsed&&g(this.toggle_button,"click"),this.schema.options&&"undefined"!=typeof this.schema.options.disable_collapse?this.schema.options.disable_collapse&&(this.toggle_button.style.display="none"):this.jsoneditor.options.disable_collapse&&(this.toggle_button.style.display="none"),this.add_row_button=this.getButton(this.getItemTitle(),"add",this.translate("button_add_row_title",[this.getItemTitle()])),this.add_row_button.classList.add("json-editor-btntype-add"),this.add_row_button.addEventListener("click",function(b){b.preventDefault(),b.stopPropagation();var c=a.rows.length;a.row_cache[c]?(a.rows[c]=a.row_cache[c],a.rows[c].setValue(a.rows[c].getDefault(),!0),a.rows[c].container.style.display="",a.rows[c].tab&&(a.rows[c].tab.style.display=""),a.rows[c].register()):a.addRow(),a.active_tab=a.rows[c].tab,a.refreshTabs(),a.refreshValue(),a.onChange(!0),a.jsoneditor.trigger("addRow")}),a.controls.appendChild(this.add_row_button),this.delete_last_row_button=this.getButton(this.translate("button_delete_last",[this.getItemTitle()]),"delete",this.translate("button_delete_last_title",[this.getItemTitle()])),this.delete_last_row_button.classList.add("json-editor-btntype-deletelast"),this.delete_last_row_button.addEventListener("click",function(b){if(b.preventDefault(),b.stopPropagation(),!a.askConfirmation())return!1;var c=a.getValue(),d=null;c.pop(),a.empty(!0),a.setValue(c),a.rows[a.rows.length-1]&&(d=a.rows[a.rows.length-1].tab),d&&(a.active_tab=d,a.refreshTabs()),a.onChange(!0),a.jsoneditor.trigger("deleteRow")}),a.controls.appendChild(this.delete_last_row_button),this.remove_all_rows_button=this.getButton(this.translate("button_delete_all"),"delete",this.translate("button_delete_all_title")),this.remove_all_rows_button.classList.add("json-editor-btntype-deleteall"),this.remove_all_rows_button.addEventListener("click",function(b){return b.preventDefault(),b.stopPropagation(),!!a.askConfirmation()&&(a.empty(!0),a.setValue([]),a.onChange(!0),void a.jsoneditor.trigger("deleteAllRows"))}),a.controls.appendChild(this.remove_all_rows_button),a.tabs&&(this.add_row_button.style.width="100%",this.add_row_button.style.textAlign="left",this.add_row_button.style.marginBottom="3px",this.delete_last_row_button.style.width="100%",this.delete_last_row_button.style.textAlign="left",this.delete_last_row_button.style.marginBottom="3px",this.remove_all_rows_button.style.width="100%",this.remove_all_rows_button.style.textAlign="left",this.remove_all_rows_button.style.marginBottom="3px")},showValidationErrors:function(a){var b=this,c=[],d=[];if(f(a,function(a,e){e.path===b.path?c.push(e):d.push(e)}),this.error_holder)if(c.length){this.error_holder.innerHTML="",this.error_holder.style.display="",f(c,function(a,c){b.error_holder.appendChild(b.theme.getErrorMessage(c.message))})}else this.error_holder.style.display="none";f(this.rows,function(a,b){b.showValidationErrors(d)})}}),h.defaults.editors.table=h.defaults.editors.array.extend({register:function(){if(this._super(),this.rows)for(var a=0;a<this.rows.length;a++)this.rows[a].register()},unregister:function(){if(this._super(),this.rows)for(var a=0;a<this.rows.length;a++)this.rows[a].unregister()},getNumColumns:function(){return Math.max(Math.min(12,this.width),3)},preBuild:function(){var a=this.jsoneditor.expandRefs(this.schema.items||{});this.item_title=a.title||"row",this.item_default=a["default"]||null,this.item_has_child_editors=a.properties||a.items,this.width=12,this._super()},build:function(){var a=this;this.table=this.theme.getTable(),this.container.appendChild(this.table),this.thead=this.theme.getTableHead(),this.table.appendChild(this.thead),this.header_row=this.theme.getTableRow(),this.thead.appendChild(this.header_row),this.row_holder=this.theme.getTableBody(),this.table.appendChild(this.row_holder);var b=this.getElementEditor(0,!0);if(this.item_default=b.getDefault(),this.width=b.getNumColumns()+2,this.options.compact?(this.panel=document.createElement("div"),this.container.appendChild(this.panel)):(this.title=this.theme.getHeader(this.getTitle()),this.container.appendChild(this.title),this.title_controls=this.theme.getHeaderButtonHolder(),this.title.appendChild(this.title_controls),this.schema.description&&(this.description=this.theme.getDescription(this.schema.description),this.container.appendChild(this.description)),this.panel=this.theme.getIndentedPanel(),this.container.appendChild(this.panel),this.error_holder=document.createElement("div"),this.panel.appendChild(this.error_holder)),this.panel.appendChild(this.table),this.controls=this.theme.getButtonHolder(),this.panel.appendChild(this.controls),this.item_has_child_editors)for(var c=b.getChildEditors(),d=b.property_order||Object.keys(c),e=0;e<d.length;e++){var f=a.theme.getTableHeaderCell(c[d[e]].getTitle());c[d[e]].options.hidden&&(f.style.display="none"),a.header_row.appendChild(f)}else a.header_row.appendChild(a.theme.getTableHeaderCell(this.item_title));b.destroy(),this.row_holder.innerHTML="",this.controls_header_cell=a.theme.getTableHeaderCell(" "),a.header_row.appendChild(this.controls_header_cell),this.addControls()},onChildEditorChange:function(a){this.refreshValue(),this._super()},getItemDefault:function(){return e({},{"default":this.item_default})["default"]},getItemTitle:function(){return this.item_title},getElementEditor:function(a,b){var c=e({},this.schema.items),d=this.jsoneditor.getEditorClass(c,this.jsoneditor),f=this.row_holder.appendChild(this.theme.getTableRow()),g=f;this.item_has_child_editors||(g=this.theme.getTableCell(),f.appendChild(g));var h=this.jsoneditor.createEditor(d,{jsoneditor:this.jsoneditor,schema:c,container:g,path:this.path+"."+a,parent:this,compact:!0,table_row:!0});return h.preBuild(),b||(h.build(),h.postBuild(),h.controls_cell=f.appendChild(this.theme.getTableCell()),h.row=f,h.table_controls=this.theme.getButtonHolder(),h.controls_cell.appendChild(h.table_controls),h.table_controls.style.margin=0,h.table_controls.style.padding=0),h},destroy:function(){this.innerHTML="",this.title&&this.title.parentNode&&this.title.parentNode.removeChild(this.title),this.description&&this.description.parentNode&&this.description.parentNode.removeChild(this.description),this.row_holder&&this.row_holder.parentNode&&this.row_holder.parentNode.removeChild(this.row_holder),this.table&&this.table.parentNode&&this.table.parentNode.removeChild(this.table),this.panel&&this.panel.parentNode&&this.panel.parentNode.removeChild(this.panel),this.rows=this.title=this.description=this.row_holder=this.table=this.panel=null,this._super()},setValue:function(a,b){if(a=a||[],this.schema.minItems)for(;a.length<this.schema.minItems;)a.push(this.getItemDefault());this.schema.maxItems&&a.length>this.schema.maxItems&&(a=a.slice(0,this.schema.maxItems));var c=JSON.stringify(a);if(c!==this.serialized){var d=!1,e=this;f(a,function(a,b){e.rows[a]?e.rows[a].setValue(b):(e.addRow(b),d=!0)});for(var g=a.length;g<e.rows.length;g++){var h=e.rows[g].container;e.item_has_child_editors||e.rows[g].row.parentNode.removeChild(e.rows[g].row),e.rows[g].destroy(),h.parentNode&&h.parentNode.removeChild(h),e.rows[g]=null,d=!0}e.rows=e.rows.slice(0,a.length),e.refreshValue(),(d||b)&&e.refreshRowButtons(),e.onChange()}},refreshRowButtons:function(){var a=this,b=this.schema.minItems&&this.schema.minItems>=this.rows.length,c=!1;f(this.rows,function(d,e){e.movedown_button&&(d===a.rows.length-1?e.movedown_button.style.display="none":(c=!0,e.movedown_button.style.display="")),e.delete_button&&(b?e.delete_button.style.display="none":(c=!0,e.delete_button.style.display="")),e.moveup_button&&(c=!0)}),f(this.rows,function(a,b){c?b.controls_cell.style.display="":b.controls_cell.style.display="none"}),c?this.controls_header_cell.style.display="":this.controls_header_cell.style.display="none";var d=!1;this.value.length?1===this.value.length?(this.table.style.display="",this.remove_all_rows_button.style.display="none",b||this.hide_delete_last_row_buttons?this.delete_last_row_button.style.display="none":(this.delete_last_row_button.style.display="",d=!0)):(this.table.style.display="",b||this.hide_delete_last_row_buttons?this.delete_last_row_button.style.display="none":(this.delete_last_row_button.style.display="",d=!0),b||this.hide_delete_all_rows_buttons?this.remove_all_rows_button.style.display="none":(this.remove_all_rows_button.style.display="",d=!0)):(this.delete_last_row_button.style.display="none",this.remove_all_rows_button.style.display="none",this.table.style.display="none"),this.schema.maxItems&&this.schema.maxItems<=this.rows.length||this.hide_add_button?this.add_row_button.style.display="none":(this.add_row_button.style.display="",d=!0),d?this.controls.style.display="":this.controls.style.display="none"},refreshValue:function(){var a=this;this.value=[],f(this.rows,function(b,c){a.value[b]=c.getValue()}),this.serialized=JSON.stringify(this.value)},addRow:function(a){var b=this,c=this.rows.length;b.rows[c]=this.getElementEditor(c);var d=b.rows[c].table_controls;this.hide_delete_buttons||(b.rows[c].delete_button=this.getButton("","delete",this.translate("button_delete_row_title_short")),b.rows[c].delete_button.classList.add("delete","json-editor-btntype-delete"),b.rows[c].delete_button.setAttribute("data-i",c),b.rows[c].delete_button.addEventListener("click",function(a){if(a.preventDefault(),a.stopPropagation(),!b.askConfirmation())return!1;var c=1*this.getAttribute("data-i"),d=b.getValue(),e=[];f(d,function(a,b){a!==c&&e.push(b)}),b.setValue(e),b.onChange(!0)}),d.appendChild(b.rows[c].delete_button)),c&&!this.hide_move_buttons&&(b.rows[c].moveup_button=this.getButton("","moveup",this.translate("button_move_up_title")),b.rows[c].moveup_button.classList.add("moveup","json-editor-btntype-move"),b.rows[c].moveup_button.setAttribute("data-i",c),b.rows[c].moveup_button.addEventListener("click",function(a){a.preventDefault(),a.stopPropagation();var c=1*this.getAttribute("data-i");if(!(c<=0)){var d=b.getValue(),e=d[c-1];d[c-1]=d[c],d[c]=e,b.setValue(d),b.onChange(!0)}}),d.appendChild(b.rows[c].moveup_button)),this.hide_move_buttons||(b.rows[c].movedown_button=this.getButton("","movedown",this.translate("button_move_down_title")),b.rows[c].movedown_button.classList.add("movedown","json-editor-btntype-move"),b.rows[c].movedown_button.setAttribute("data-i",c),b.rows[c].movedown_button.addEventListener("click",function(a){a.preventDefault(),a.stopPropagation();var c=1*this.getAttribute("data-i"),d=b.getValue();if(!(c>=d.length-1)){var e=d[c+1];d[c+1]=d[c],d[c]=e,b.setValue(d),b.onChange(!0)}}),d.appendChild(b.rows[c].movedown_button)),a&&b.rows[c].setValue(a)},addControls:function(){var a=this;this.collapsed=!1,this.toggle_button=this.getButton("","collapse",this.translate("button_collapse")),this.toggle_button.classList.add("json-editor-btntype-toggle"),this.title_controls&&(this.title_controls.appendChild(this.toggle_button),this.toggle_button.addEventListener("click",function(b){b.preventDefault(),b.stopPropagation(),a.collapsed?(a.collapsed=!1,a.panel.style.display="",a.setButtonText(this,"","collapse",a.translate("button_collapse"))):(a.collapsed=!0,a.panel.style.display="none",a.setButtonText(this,"","expand",a.translate("button_expand")))}),this.options.collapsed&&g(this.toggle_button,"click"),this.schema.options&&"undefined"!=typeof this.schema.options.disable_collapse?this.schema.options.disable_collapse&&(this.toggle_button.style.display="none"):this.jsoneditor.options.disable_collapse&&(this.toggle_button.style.display="none")),this.add_row_button=this.getButton(this.getItemTitle(),"add",this.translate("button_add_row_title",[this.getItemTitle()])),this.add_row_button.classList.add("json-editor-btntype-add"),this.add_row_button.addEventListener("click",function(b){b.preventDefault(),b.stopPropagation(),a.addRow(),a.refreshValue(),a.refreshRowButtons(),a.onChange(!0)}),a.controls.appendChild(this.add_row_button),this.delete_last_row_button=this.getButton(this.translate("button_delete_last",[this.getItemTitle()]),"delete",this.translate("button_delete_last_title",[this.getItemTitle()])),this.delete_last_row_button.classList.add("json-editor-btntype-deletelast"),this.delete_last_row_button.addEventListener("click",function(b){if(b.preventDefault(),b.stopPropagation(),!a.askConfirmation())return!1;var c=a.getValue();c.pop(),a.setValue(c),a.onChange(!0)}),a.controls.appendChild(this.delete_last_row_button),this.remove_all_rows_button=this.getButton(this.translate("button_delete_all"),"delete",this.translate("button_delete_all_title")), +this.remove_all_rows_button.classList.add("json-editor-btntype-deleteall"),this.remove_all_rows_button.addEventListener("click",function(b){return b.preventDefault(),b.stopPropagation(),!!a.askConfirmation()&&(a.setValue([]),void a.onChange(!0))}),a.controls.appendChild(this.remove_all_rows_button)}}),h.defaults.editors.multiple=h.AbstractEditor.extend({register:function(){if(this.editors){for(var a=0;a<this.editors.length;a++)this.editors[a]&&this.editors[a].unregister();this.editors[this.type]&&this.editors[this.type].register()}this._super()},unregister:function(){if(this._super(),this.editors)for(var a=0;a<this.editors.length;a++)this.editors[a]&&this.editors[a].unregister()},getNumColumns:function(){return this.editors[this.type]?Math.max(this.editors[this.type].getNumColumns(),4):4},enable:function(){if(!this.always_disabled){if(this.editors)for(var a=0;a<this.editors.length;a++)this.editors[a]&&this.editors[a].enable();this.switcher.disabled=!1,this._super()}},disable:function(a){if(a&&(this.always_disabled=!0),this.editors)for(var b=0;b<this.editors.length;b++)this.editors[b]&&this.editors[b].disable(a);this.switcher.disabled=!0,this._super()},switchEditor:function(a){var b=this;this.editors[a]||this.buildChildEditor(a);var c=b.getValue();b.type=a,b.register(),f(b.editors,function(a,d){d&&(b.type===a?(b.keep_values&&d.setValue(c,!0),d.container.style.display=""):d.container.style.display="none")}),b.refreshValue(),b.refreshHeaderText()},buildChildEditor:function(a){var b=this,c=this.types[a],d=b.theme.getChildEditorHolder();b.editor_holder.appendChild(d);var f;"string"==typeof c?(f=e({},b.schema),f.type=c):(f=e({},b.schema,c),f=b.jsoneditor.expandRefs(f),c&&c.required&&Array.isArray(c.required)&&b.schema.required&&Array.isArray(b.schema.required)&&(f.required=b.schema.required.concat(c.required)));var g=b.jsoneditor.getEditorClass(f);b.editors[a]=b.jsoneditor.createEditor(g,{jsoneditor:b.jsoneditor,schema:f,container:d,path:b.path,parent:b,required:!0}),b.editors[a].preBuild(),b.editors[a].build(),b.editors[a].postBuild(),b.editors[a].header&&(b.editors[a].header.style.display="none"),b.editors[a].option=b.switcher_options[a],d.addEventListener("change_header_text",function(){b.refreshHeaderText()}),a!==b.type&&(d.style.display="none")},preBuild:function(){if(this.types=[],this.type=0,this.editors=[],this.validators=[],this.keep_values=!0,"undefined"!=typeof this.jsoneditor.options.keep_oneof_values&&(this.keep_values=this.jsoneditor.options.keep_oneof_values),"undefined"!=typeof this.options.keep_oneof_values&&(this.keep_values=this.options.keep_oneof_values),this.schema.oneOf)this.oneOf=!0,this.types=this.schema.oneOf,delete this.schema.oneOf;else if(this.schema.anyOf)this.anyOf=!0,this.types=this.schema.anyOf,delete this.schema.anyOf;else{if(this.schema.type&&"any"!==this.schema.type)Array.isArray(this.schema.type)?this.types=this.schema.type:this.types=[this.schema.type];else if(this.types=["string","number","integer","boolean","object","array","null"],this.schema.disallow){var a=this.schema.disallow;"object"==typeof a&&Array.isArray(a)||(a=[a]);var b=[];f(this.types,function(c,d){a.indexOf(d)===-1&&b.push(d)}),this.types=b}delete this.schema.type}this.display_text=this.getDisplayText(this.types)},build:function(){var a=this,b=this.container;this.header=this.label=this.theme.getFormInputLabel(this.getTitle()),this.container.appendChild(this.header),this.switcher=this.theme.getSwitcher(this.display_text),b.appendChild(this.switcher),this.switcher.addEventListener("change",function(b){b.preventDefault(),b.stopPropagation(),a.switchEditor(a.display_text.indexOf(this.value)),a.onChange(!0)}),this.editor_holder=document.createElement("div"),b.appendChild(this.editor_holder);var c={};a.jsoneditor.options.custom_validators&&(c.custom_validators=a.jsoneditor.options.custom_validators),this.switcher_options=this.theme.getSwitcherOptions(this.switcher),f(this.types,function(b,d){a.editors[b]=!1;var f;"string"==typeof d?(f=e({},a.schema),f.type=d):(f=e({},a.schema,d),d.required&&Array.isArray(d.required)&&a.schema.required&&Array.isArray(a.schema.required)&&(f.required=a.schema.required.concat(d.required))),a.validators[b]=new h.Validator(a.jsoneditor,f,c)}),this.switchEditor(0)},onChildEditorChange:function(a){this.editors[this.type]&&(this.refreshValue(),this.refreshHeaderText()),this._super()},refreshHeaderText:function(){var a=this.getDisplayText(this.types);f(this.switcher_options,function(b,c){c.textContent=a[b]})},refreshValue:function(){this.value=this.editors[this.type].getValue()},setValue:function(a,b){var c=this,d=this.type;f(this.validators,function(b,d){if(!d.validate(a).length)return c.type=b,c.switcher.value=c.display_text[b],!1});var e=this.type!=d;e&&this.switchEditor(this.type),this.editors[this.type].setValue(a,b),this.refreshValue(),c.onChange(e)},destroy:function(){f(this.editors,function(a,b){b&&b.destroy()}),this.editor_holder&&this.editor_holder.parentNode&&this.editor_holder.parentNode.removeChild(this.editor_holder),this.switcher&&this.switcher.parentNode&&this.switcher.parentNode.removeChild(this.switcher),this._super()},showValidationErrors:function(a){var b=this;if(this.oneOf||this.anyOf){var c=this.oneOf?"oneOf":"anyOf";f(this.editors,function(d,g){if(g){var h=b.path+"."+c+"["+d+"]",i=[];f(a,function(a,c){if(c.path.substr(0,h.length)===h){var d=e({},c);d.path=b.path+d.path.substr(h.length),i.push(d)}}),g.showValidationErrors(i)}})}else f(this.editors,function(b,c){c&&c.showValidationErrors(a)})}}),h.defaults.editors["enum"]=h.AbstractEditor.extend({getNumColumns:function(){return 4},build:function(){this.container;this.title=this.header=this.label=this.theme.getFormInputLabel(this.getTitle()),this.container.appendChild(this.title),this.options.enum_titles=this.options.enum_titles||[],this["enum"]=this.schema["enum"],this.selected=0,this.select_options=[],this.html_values=[];for(var a=this,b=0;b<this["enum"].length;b++)this.select_options[b]=this.options.enum_titles[b]||"Value "+(b+1),this.html_values[b]=this.getHTML(this["enum"][b]);this.switcher=this.theme.getSwitcher(this.select_options),this.container.appendChild(this.switcher),this.display_area=this.theme.getIndentedPanel(),this.container.appendChild(this.display_area),this.options.hide_display&&(this.display_area.style.display="none"),this.switcher.addEventListener("change",function(){a.selected=a.select_options.indexOf(this.value),a.value=a["enum"][a.selected],a.refreshValue(),a.onChange(!0)}),this.value=this["enum"][0],this.refreshValue(),1===this["enum"].length&&(this.switcher.style.display="none")},refreshValue:function(){var a=this;a.selected=-1;var b=JSON.stringify(this.value);return f(this["enum"],function(c,d){if(b===JSON.stringify(d))return a.selected=c,!1}),a.selected<0?void a.setValue(a["enum"][0]):(this.switcher.value=this.select_options[this.selected],void(this.display_area.innerHTML=this.html_values[this.selected]))},enable:function(){this.always_disabled||(this.switcher.disabled=!1,this._super())},disable:function(a){a&&(this.always_disabled=!0),this.switcher.disabled=!0,this._super()},getHTML:function(a){var b=this;if(null===a)return"<em>null</em>";if("object"==typeof a){var c="";return f(a,function(d,e){var f=b.getHTML(e);Array.isArray(a)||(f="<div><em>"+d+"</em>: "+f+"</div>"),c+="<li>"+f+"</li>"}),c=Array.isArray(a)?"<ol>"+c+"</ol>":"<ul style='margin-top:0;margin-bottom:0;padding-top:0;padding-bottom:0;'>"+c+"</ul>"}return"boolean"==typeof a?a?"true":"false":"string"==typeof a?a.replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">"):a},setValue:function(a){this.value!==a&&(this.value=a,this.refreshValue(),this.onChange())},destroy:function(){this.display_area&&this.display_area.parentNode&&this.display_area.parentNode.removeChild(this.display_area),this.title&&this.title.parentNode&&this.title.parentNode.removeChild(this.title),this.switcher&&this.switcher.parentNode&&this.switcher.parentNode.removeChild(this.switcher),this._super()}}),h.defaults.editors.select=h.AbstractEditor.extend({setValue:function(a,b){a=this.typecast(a||"");var c=a;this.enum_values.indexOf(c)<0&&(c=this.enum_values[0]),this.value!==c&&(b?this.is_dirty=!1:"change"===this.jsoneditor.options.show_errors&&(this.is_dirty=!0),this.input.value=this.enum_options[this.enum_values.indexOf(c)],this.select2&&(this.select2v4?this.select2.val(this.input.value).trigger("change"):this.select2.select2("val",this.input.value)),this.value=c,this.onChange(),this.change())},register:function(){this._super(),this.input&&this.input.setAttribute("name",this.formname)},unregister:function(){this._super(),this.input&&this.input.removeAttribute("name")},getNumColumns:function(){if(!this.enum_options)return 3;for(var a=this.getTitle().length,b=0;b<this.enum_options.length;b++)a=Math.max(a,this.enum_options[b].length+4);return Math.min(12,Math.max(a/7,2))},typecast:function(a){return"boolean"===this.schema.type?!!a:"number"===this.schema.type?1*a:"integer"===this.schema.type?Math.floor(1*a):""+a},getValue:function(){return this.dependenciesFulfilled?this.typecast(this.value):b},preBuild:function(){var a=this;this.input_type="select",this.enum_options=[],this.enum_values=[],this.enum_display=[];var c;if(this.schema["enum"]){var d=this.schema.options&&this.schema.options.enum_titles||[];f(this.schema["enum"],function(b,c){a.enum_options[b]=""+c,a.enum_display[b]=""+(d[b]||c),a.enum_values[b]=a.typecast(c)}),this.isRequired()||(a.enum_display.unshift(" "),a.enum_options.unshift("undefined"),a.enum_values.unshift(b))}else if("boolean"===this.schema.type)a.enum_display=this.schema.options&&this.schema.options.enum_titles||["true","false"],a.enum_options=["1",""],a.enum_values=[!0,!1],this.isRequired()||(a.enum_display.unshift(" "),a.enum_options.unshift("undefined"),a.enum_values.unshift(b));else{if(!this.schema.enumSource)throw"'select' editor requires the enum property to be set.";if(this.enumSource=[],this.enum_display=[],this.enum_options=[],this.enum_values=[],Array.isArray(this.schema.enumSource))for(c=0;c<this.schema.enumSource.length;c++)"string"==typeof this.schema.enumSource[c]?this.enumSource[c]={source:this.schema.enumSource[c]}:Array.isArray(this.schema.enumSource[c])?this.enumSource[c]=this.schema.enumSource[c]:this.enumSource[c]=e({},this.schema.enumSource[c]);else this.schema.enumValue?this.enumSource=[{source:this.schema.enumSource,value:this.schema.enumValue}]:this.enumSource=[{source:this.schema.enumSource}];for(c=0;c<this.enumSource.length;c++)this.enumSource[c].value&&(this.enumSource[c].value=this.jsoneditor.compileTemplate(this.enumSource[c].value,this.template_engine)),this.enumSource[c].title&&(this.enumSource[c].title=this.jsoneditor.compileTemplate(this.enumSource[c].title,this.template_engine)),this.enumSource[c].filter&&(this.enumSource[c].filter=this.jsoneditor.compileTemplate(this.enumSource[c].filter,this.template_engine))}},build:function(){var a=this;this.options.compact||(this.header=this.label=this.theme.getFormInputLabel(this.getTitle())),this.schema.description&&(this.description=this.theme.getFormInputDescription(this.schema.description)),this.options.infoText&&(this.infoButton=this.theme.getInfoButton(this.options.infoText)),this.options.compact&&this.container.classList.add("compact"),this.input=this.theme.getSelectInput(this.enum_options),this.theme.setSelectOptions(this.input,this.enum_options,this.enum_display),(this.schema.readOnly||this.schema.readonly)&&(this.always_disabled=!0,this.input.disabled=!0),this.setInputAttributes([]),this.input.addEventListener("change",function(b){b.preventDefault(),b.stopPropagation(),a.onInputChange()}),this.control=this.theme.getFormControl(this.label,this.input,this.description,this.infoButton),this.container.appendChild(this.control),this.value=this.enum_values[0]},onInputChange:function(){var a,b=this.typecast(this.input.value);a=this.enum_values.indexOf(b)===-1?this.enum_values[0]:this.enum_values[this.enum_values.indexOf(b)],a!==this.value&&(this.is_dirty=!0,this.value=a,this.onChange(!0))},setupSelect2:function(){if(window.jQuery&&window.jQuery.fn&&window.jQuery.fn.select2&&(this.enum_options.length>2||this.enum_options.length&&this.enumSource)){var a=e({},h.plugins.select2);this.schema.options&&this.schema.options.select2_options&&(a=e(a,this.schema.options.select2_options)),this.select2=window.jQuery(this.input).select2(a),this.select2v4=this.select2.select2.hasOwnProperty("amd");var b=this;this.select2.on("select2-blur",function(){b.select2v4?b.input.value=b.select2.val():b.input.value=b.select2.select2("val"),b.onInputChange()}),this.select2.on("change",function(){b.select2v4?b.input.value=b.select2.val():b.input.value=b.select2.select2("val"),b.onInputChange()})}else this.select2=null},postBuild:function(){this._super(),this.theme.afterInputReady(this.input),this.setupSelect2()},onWatchedFieldChange:function(){var a,b;if(this.enumSource){a=this.getWatchedFieldValues();for(var c=[],d=[],e=0;e<this.enumSource.length;e++)if(Array.isArray(this.enumSource[e]))c=c.concat(this.enumSource[e]),d=d.concat(this.enumSource[e]);else{var f=[];if(f=Array.isArray(this.enumSource[e].source)?this.enumSource[e].source:a[this.enumSource[e].source]){if(this.enumSource[e].slice&&(f=Array.prototype.slice.apply(f,this.enumSource[e].slice)),this.enumSource[e].filter){var g=[];for(b=0;b<f.length;b++)this.enumSource[e].filter({i:b,item:f[b],watched:a})&&g.push(f[b]);f=g}var h=[],i=[];for(b=0;b<f.length;b++){var j=f[b];this.enumSource[e].value?i[b]=this.typecast(this.enumSource[e].value({i:b,item:j})):i[b]=f[b],this.enumSource[e].title?h[b]=this.enumSource[e].title({i:b,item:j}):h[b]=i[b]}c=c.concat(i),d=d.concat(h)}}var k=this.value;this.theme.setSelectOptions(this.input,c,d),this.enum_options=c,this.enum_display=d,this.enum_values=c,this.select2&&this.select2.select2("destroy"),c.indexOf(k)!==-1?(this.input.value=k,this.value=k):(this.input.value=c[0],this.value=this.typecast(c[0]||""),this.parent?this.parent.onChildEditorChange(this):this.jsoneditor.onChange(),this.jsoneditor.notifyWatchers(this.path)),this.setupSelect2()}this._super()},enable:function(){this.always_disabled||(this.input.disabled=!1,this.select2&&(this.select2v4?this.select2.prop("disabled",!1):this.select2.select2("enable",!0))),this._super()},disable:function(a){a&&(this.always_disabled=!0),this.input.disabled=!0,this.select2&&(this.select2v4?this.select2.prop("disabled",!0):this.select2.select2("enable",!1)),this._super()},destroy:function(){this.label&&this.label.parentNode&&this.label.parentNode.removeChild(this.label),this.description&&this.description.parentNode&&this.description.parentNode.removeChild(this.description),this.input&&this.input.parentNode&&this.input.parentNode.removeChild(this.input),this.select2&&(this.select2.select2("destroy"),this.select2=null),this._super()},showValidationErrors:function(a){var b=this;if("always"===this.jsoneditor.options.show_errors);else if(!this.is_dirty&&this.previous_error_setting===this.jsoneditor.options.show_errors)return;this.previous_error_setting=this.jsoneditor.options.show_errors;var c=[];f(a,function(a,d){d.path===b.path&&c.push(d.message)}),c.length?this.theme.addInputError(this.input,c.join(". ")+"."):this.theme.removeInputError(this.input)}}),h.defaults.editors.selectize=h.AbstractEditor.extend({setValue:function(a,b){a=this.typecast(a||"");var c=a;this.enum_values.indexOf(c)<0&&(c=this.enum_values[0]),this.value!==c&&(this.input.value=this.enum_options[this.enum_values.indexOf(c)],this.selectize&&this.selectize[0].selectize.addItem(c),this.value=c,this.onChange())},register:function(){this._super(),this.input&&this.input.setAttribute("name",this.formname)},unregister:function(){this._super(),this.input&&this.input.removeAttribute("name")},getNumColumns:function(){if(!this.enum_options)return 3;for(var a=this.getTitle().length,b=0;b<this.enum_options.length;b++)a=Math.max(a,this.enum_options[b].length+4);return Math.min(12,Math.max(a/7,2))},typecast:function(a){return"boolean"===this.schema.type?!!a:"number"===this.schema.type?1*a:"integer"===this.schema.type?Math.floor(1*a):""+a},getValue:function(){return this.dependenciesFulfilled?this.value:b},preBuild:function(){var a=this;this.input_type="select",this.enum_options=[],this.enum_values=[],this.enum_display=[];var b;if(this.schema["enum"]){var c=this.schema.options&&this.schema.options.enum_titles||[];f(this.schema["enum"],function(b,d){a.enum_options[b]=""+d,a.enum_display[b]=""+(c[b]||d),a.enum_values[b]=a.typecast(d)})}else if("boolean"===this.schema.type)a.enum_display=this.schema.options&&this.schema.options.enum_titles||["true","false"],a.enum_options=["1","0"],a.enum_values=[!0,!1];else{if(!this.schema.enumSource)throw"'select' editor requires the enum property to be set.";if(this.enumSource=[],this.enum_display=[],this.enum_options=[],this.enum_values=[],Array.isArray(this.schema.enumSource))for(b=0;b<this.schema.enumSource.length;b++)"string"==typeof this.schema.enumSource[b]?this.enumSource[b]={source:this.schema.enumSource[b]}:Array.isArray(this.schema.enumSource[b])?this.enumSource[b]=this.schema.enumSource[b]:this.enumSource[b]=e({},this.schema.enumSource[b]);else this.schema.enumValue?this.enumSource=[{source:this.schema.enumSource,value:this.schema.enumValue}]:this.enumSource=[{source:this.schema.enumSource}];for(b=0;b<this.enumSource.length;b++)this.enumSource[b].value&&(this.enumSource[b].value=this.jsoneditor.compileTemplate(this.enumSource[b].value,this.template_engine)),this.enumSource[b].title&&(this.enumSource[b].title=this.jsoneditor.compileTemplate(this.enumSource[b].title,this.template_engine)),this.enumSource[b].filter&&(this.enumSource[b].filter=this.jsoneditor.compileTemplate(this.enumSource[b].filter,this.template_engine))}},build:function(){var a=this;this.options.compact||(this.header=this.label=this.theme.getFormInputLabel(this.getTitle())),this.schema.description&&(this.description=this.theme.getFormInputDescription(this.schema.description)),this.options.infoText&&(this.infoButton=this.theme.getInfoButton(this.options.infoText)),this.options.compact&&this.container.classList.add("compact"),this.input=this.theme.getSelectInput(this.enum_options),this.theme.setSelectOptions(this.input,this.enum_options,this.enum_display),(this.schema.readOnly||this.schema.readonly)&&(this.always_disabled=!0,this.input.disabled=!0),this.input.addEventListener("change",function(b){b.preventDefault(),b.stopPropagation(),a.onInputChange()}),this.control=this.theme.getFormControl(this.label,this.input,this.description,this.infoButton),this.container.appendChild(this.control),this.value=this.enum_values[0]},onInputChange:function(){var a=this.input.value,b=a;this.enum_options.indexOf(a)===-1&&(b=this.enum_options[0]),this.value=a,this.onChange(!0)},setupSelectize:function(){var a=this;if(window.jQuery&&window.jQuery.fn&&window.jQuery.fn.selectize&&(this.enum_options.length>=2||this.enum_options.length&&this.enumSource)){var c=e({},h.plugins.selectize);this.schema.options&&this.schema.options.selectize_options&&(c=e(c,this.schema.options.selectize_options)),this.selectize=window.jQuery(this.input).selectize(e(c,{create:c.create===b||c.create,onChange:function(){a.onInputChange()}}))}else this.selectize=null},postBuild:function(){this._super(),this.theme.afterInputReady(this.input),this.setupSelectize()},onWatchedFieldChange:function(){var a,c;if(this.enumSource){a=this.getWatchedFieldValues();for(var d=[],e=[],f=0;f<this.enumSource.length;f++)if(Array.isArray(this.enumSource[f]))d=d.concat(this.enumSource[f]),e=e.concat(this.enumSource[f]);else if(a[this.enumSource[f].source]){var g=a[this.enumSource[f].source];if(this.enumSource[f].slice&&(g=Array.prototype.slice.apply(g,this.enumSource[f].slice)),this.enumSource[f].filter){var h=[];for(c=0;c<g.length;c++)this.enumSource[f].filter({i:c,item:g[c]})&&h.push(g[c]);g=h}var i=[],j=[];for(c=0;c<g.length;c++){var k=g[c];this.enumSource[f].value?j[c]=this.enumSource[f].value({i:c,item:k}):j[c]=g[c],this.enumSource[f].title?i[c]=this.enumSource[f].title({i:c,item:k}):i[c]=j[c]}d=d.concat(j),e=e.concat(i)}var l=this.value;l!==b&&""!==l&&d.indexOf(l)===-1&&(d=d.concat(l),e=e.concat(l)),this.theme.setSelectOptions(this.input,d,e),this.enum_options=d,this.enum_display=e,this.enum_values=d,d.indexOf(l)!==-1?(this.input.value=l,this.value=l):(this.input.value=d[0],this.value=d[0]||"",this.parent?this.parent.onChildEditorChange(this):this.jsoneditor.onChange(),this.jsoneditor.notifyWatchers(this.path)),this.selectize?this.updateSelectizeOptions(d):this.setupSelectize(),this._super()}},updateSelectizeOptions:function(a){var b=this.selectize[0].selectize,c=this;b.off(),b.clearOptions();for(var d in a)b.addOption({value:a[d],text:a[d]});b.addItem(this.value),b.on("change",function(){c.onInputChange()})},enable:function(){this.always_disabled||(this.input.disabled=!1,this.selectize&&this.selectize[0].selectize.unlock(),this._super())},disable:function(a){a&&(this.always_disabled=!0),this.input.disabled=!0,this.selectize&&this.selectize[0].selectize.lock(),this._super()},destroy:function(){this.label&&this.label.parentNode&&this.label.parentNode.removeChild(this.label),this.description&&this.description.parentNode&&this.description.parentNode.removeChild(this.description),this.input&&this.input.parentNode&&this.input.parentNode.removeChild(this.input),this.selectize&&(this.selectize[0].selectize.destroy(),this.selectize=null),this._super()}}),h.defaults.editors.multiselect=h.AbstractEditor.extend({preBuild:function(){this._super();var a;this.select_options={},this.select_values={};var b=this.jsoneditor.expandRefs(this.schema.items||{}),c=b["enum"]||[],d=b.options?b.options.enum_titles||[]:[];for(this.option_keys=[],this.option_titles=[],a=0;a<c.length;a++)this.sanitize(c[a])===c[a]&&(this.option_keys.push(c[a]+""),this.option_titles.push((d[a]||c[a])+""),this.select_values[c[a]+""]=c[a])},build:function(){var a,b=this;if(this.options.compact||(this.header=this.label=this.theme.getFormInputLabel(this.getTitle())),this.schema.description&&(this.description=this.theme.getFormInputDescription(this.schema.description)),!this.schema.format&&this.option_keys.length<8||"checkbox"===this.schema.format){for(this.input_type="checkboxes",this.inputs={},this.controls={},a=0;a<this.option_keys.length;a++){this.inputs[this.option_keys[a]]=this.theme.getCheckbox(),this.select_options[this.option_keys[a]]=this.inputs[this.option_keys[a]];var c=this.theme.getCheckboxLabel(this.option_titles[a]);this.controls[this.option_keys[a]]=this.theme.getFormControl(c,this.inputs[this.option_keys[a]])}this.control=this.theme.getMultiCheckboxHolder(this.controls,this.label,this.description)}else{for(this.input_type="select",this.input=this.theme.getSelectInput(this.option_keys),this.theme.setSelectOptions(this.input,this.option_keys,this.option_titles),this.input.multiple=!0,this.input.size=Math.min(10,this.option_keys.length),a=0;a<this.option_keys.length;a++)this.select_options[this.option_keys[a]]=this.input.children[a];(this.schema.readOnly||this.schema.readonly)&&(this.always_disabled=!0,this.input.disabled=!0),this.control=this.theme.getFormControl(this.label,this.input,this.description)}this.container.appendChild(this.control),this.control.addEventListener("change",function(c){c.preventDefault(),c.stopPropagation();var d=[];for(a=0;a<b.option_keys.length;a++)(b.select_options[b.option_keys[a]].selected||b.select_options[b.option_keys[a]].checked)&&d.push(b.select_values[b.option_keys[a]]);b.updateValue(d),b.onChange(!0)})},setValue:function(a,b){var c;for(a=a||[],"object"!=typeof a?a=[a]:Array.isArray(a)||(a=[]),c=0;c<a.length;c++)"string"!=typeof a[c]&&(a[c]+="");for(c in this.select_options)this.select_options.hasOwnProperty(c)&&(this.select_options[c]["select"===this.input_type?"selected":"checked"]=a.indexOf(c)!==-1);this.updateValue(a),this.onChange()},setupSelect2:function(){if(window.jQuery&&window.jQuery.fn&&window.jQuery.fn.select2){var a=window.jQuery.extend({},h.plugins.select2);this.schema.options&&this.schema.options.select2_options&&(a=e(a,this.schema.options.select2_options)),this.select2=window.jQuery(this.input).select2(a),this.select2v4=this.select2.select2.hasOwnProperty("amd");var b=this;this.select2.on("select2-blur",function(){b.select2v4?b.value=b.select2.val():b.value=b.select2.select2("val"),b.onChange(!0)}),this.select2.on("change",function(){b.select2v4?b.value=b.select2.val():b.value=b.select2.select2("val"),b.onChange(!0)})}else this.select2=null},onInputChange:function(){this.value=this.input.value,this.onChange(!0)},postBuild:function(){this._super(),this.setupSelect2()},register:function(){this._super(),this.input&&this.input.setAttribute("name",this.formname)},unregister:function(){this._super(),this.input&&this.input.removeAttribute("name")},getNumColumns:function(){var a=this.getTitle().length;for(var b in this.select_values)this.select_values.hasOwnProperty(b)&&(a=Math.max(a,(this.select_values[b]+"").length+4));return Math.min(12,Math.max(a/7,2))},updateValue:function(a){for(var b=!1,c=[],d=0;d<a.length;d++)if(this.select_options[a[d]+""]){var e=this.sanitize(this.select_values[a[d]]);c.push(e),e!==a[d]&&(b=!0)}else b=!0;return this.value=c,this.select2&&(this.select2v4?this.select2.val(this.value).trigger("change"):this.select2.select2("val",this.value)),b},sanitize:function(a){return"number"===this.schema.items.type?1*a:"integer"===this.schema.items.type?Math.floor(1*a):""+a},enable:function(){if(!this.always_disabled){if(this.input)this.input.disabled=!1;else if(this.inputs)for(var a in this.inputs)this.inputs.hasOwnProperty(a)&&(this.inputs[a].disabled=!1);this.select2&&(this.select2v4?this.select2.prop("disabled",!1):this.select2.select2("enable",!0)),this._super()}},disable:function(a){if(a&&(this.always_disabled=!0),this.input)this.input.disabled=!0;else if(this.inputs)for(var b in this.inputs)this.inputs.hasOwnProperty(b)&&(this.inputs[b].disabled=!0);this.select2&&(this.select2v4?this.select2.prop("disabled",!0):this.select2.select2("enable",!1)),this._super()},destroy:function(){this.select2&&(this.select2.select2("destroy"),this.select2=null),this._super()}}),h.defaults.editors.base64=h.AbstractEditor.extend({getNumColumns:function(){return 4},setFileReaderListener:function(a){var b=this;a.addEventListener("load",function(a){if(b.count==b.current_item_index)b.value[b.count][b.key]=a.target.result;else{var c={};for(var d in b.parent.schema.properties)c[d]="";c[b.key]=a.target.result,b.value.splice(b.count,0,c)}b.count+=1,b.count==b.total+b.current_item_index&&b.arrayEditor.setValue(b.value)})},build:function(){var a=this;if(this.title=this.header=this.label=this.theme.getFormInputLabel(this.getTitle()),this.options.infoText&&(this.infoButton=this.theme.getInfoButton(this.options.infoText)),this.input=this.theme.getFormInputField("hidden"),this.container.appendChild(this.input),!this.schema.readOnly&&!this.schema.readonly){if(!window.FileReader)throw"FileReader required for base64 editor";this.uploader=this.theme.getFormInputField("file"),a.schema.options&&a.schema.options.multiple&&1==a.schema.options.multiple&&a.parent&&"object"==a.parent.schema.type&&a.parent.parent&&"array"==a.parent.parent.schema.type&&this.uploader.setAttribute("multiple",""),this.uploader.addEventListener("change",function(b){if(b.preventDefault(),b.stopPropagation(),this.files&&this.files.length)if(this.files.length>1&&a.schema.options&&a.schema.options.multiple&&1==a.schema.options.multiple&&a.parent&&"object"==a.parent.schema.type&&a.parent.parent&&"array"==a.parent.parent.schema.type){a.arrayEditor=a.jsoneditor.getEditor(a.parent.parent.path),a.value=a.arrayEditor.getValue(),a.total=this.files.length,a.current_item_index=parseInt(a.parent.key),a.count=a.current_item_index;for(var c=0;c<a.total;c++){var d=new FileReader;a.setFileReaderListener(d),d.readAsDataURL(this.files[c])}}else{var e=new FileReader;e.onload=function(b){a.value=b.target.result,a.refreshPreview(),a.onChange(!0),e=null},e.readAsDataURL(this.files[0])}})}this.preview=this.theme.getFormInputDescription(this.schema.description),this.container.appendChild(this.preview),this.control=this.theme.getFormControl(this.label,this.uploader||this.input,this.preview,this.infoButton),this.container.appendChild(this.control)},refreshPreview:function(){if(this.last_preview!==this.value&&(this.last_preview=this.value,this.preview.innerHTML="",this.value)){var a=this.value.match(/^data:([^;,]+)[;,]/);if(a&&(a=a[1]),a){if(this.preview.innerHTML="<strong>Type:</strong> "+a+", <strong>Size:</strong> "+Math.floor((this.value.length-this.value.split(",")[0].length-1)/1.33333)+" bytes","image"===a.substr(0,5)){this.preview.innerHTML+="<br>";var b=document.createElement("img");b.style.maxWidth="100%",b.style.maxHeight="100px",b.src=this.value,this.preview.appendChild(b)}}else this.preview.innerHTML="<em>Invalid data URI</em>"}},enable:function(){this.always_disabled||(this.uploader&&(this.uploader.disabled=!1),this._super())},disable:function(a){a&&(this.always_disabled=!0),this.uploader&&(this.uploader.disabled=!0),this._super()},setValue:function(a){this.value!==a&&(this.value=a,this.input.value=this.value,this.refreshPreview(),this.onChange())},destroy:function(){this.preview&&this.preview.parentNode&&this.preview.parentNode.removeChild(this.preview),this.title&&this.title.parentNode&&this.title.parentNode.removeChild(this.title),this.input&&this.input.parentNode&&this.input.parentNode.removeChild(this.input),this.uploader&&this.uploader.parentNode&&this.uploader.parentNode.removeChild(this.uploader),this._super()}}),h.defaults.editors.upload=h.AbstractEditor.extend({getNumColumns:function(){return 4},build:function(){var a=this;if(this.title=this.header=this.label=this.theme.getFormInputLabel(this.getTitle()),this.input=this.theme.getFormInputField("hidden"),this.container.appendChild(this.input),!this.schema.readOnly&&!this.schema.readonly){if(!this.jsoneditor.options.upload)throw"Upload handler required for upload editor";this.uploader=this.theme.getFormInputField("file"),this.uploader.addEventListener("change",function(b){if(b.preventDefault(),b.stopPropagation(),this.files&&this.files.length){var c=new FileReader;c.onload=function(b){a.preview_value=b.target.result,a.refreshPreview(),a.onChange(!0),c=null},c.readAsDataURL(this.files[0])}})}var b=this.schema.description;b||(b=""),this.preview=this.theme.getFormInputDescription(b),this.container.appendChild(this.preview),this.control=this.theme.getFormControl(this.label,this.uploader||this.input,this.preview),this.container.appendChild(this.control),window.requestAnimationFrame(function(){if(a.value){var b=document.createElement("img");b.style.maxWidth="100%",b.style.maxHeight="100px",b.onload=function(c){a.preview.appendChild(b)},b.onerror=function(a){console.error("upload error",a)},b.src=a.container.querySelector("a").href}})},refreshPreview:function(){if(this.last_preview!==this.preview_value&&(this.last_preview=this.preview_value,this.preview.innerHTML="",this.preview_value)){var a=this,b=this.preview_value.match(/^data:([^;,]+)[;,]/);b&&(b=b[1]),b||(b="unknown");var c=this.uploader.files[0];if(this.preview.innerHTML="<strong>Type:</strong> "+b+", <strong>Size:</strong> "+c.size+" bytes","image"===b.substr(0,5)){this.preview.innerHTML+="<br>";var d=document.createElement("img");d.style.maxWidth="100%",d.style.maxHeight="100px",d.src=this.preview_value,this.preview.appendChild(d)}this.preview.innerHTML+="<br>";var e=this.getButton("Upload","upload","Upload");this.preview.appendChild(e),e.addEventListener("click",function(b){b.preventDefault(),e.setAttribute("disabled","disabled"),a.theme.removeInputError(a.uploader),a.theme.getProgressBar&&(a.progressBar=a.theme.getProgressBar(),a.preview.appendChild(a.progressBar)),a.jsoneditor.options.upload(a.path,c,{success:function(b){a.setValue(b),a.parent?a.parent.onChildEditorChange(a):a.jsoneditor.onChange(), +a.progressBar&&a.preview.removeChild(a.progressBar),e.removeAttribute("disabled")},failure:function(b){a.theme.addInputError(a.uploader,b),a.progressBar&&a.preview.removeChild(a.progressBar),e.removeAttribute("disabled")},updateProgress:function(b){a.progressBar&&(b?a.theme.updateProgressBar(a.progressBar,b):a.theme.updateProgressBarUnknown(a.progressBar))}})}),(this.jsoneditor.options.auto_upload||this.schema.options.auto_upload)&&(e.dispatchEvent(new MouseEvent("click")),this.preview.removeChild(e))}},enable:function(){this.always_disabled||(this.uploader&&(this.uploader.disabled=!1),this._super())},disable:function(a){a&&(this.always_disabled=!0),this.uploader&&(this.uploader.disabled=!0),this._super()},setValue:function(a){this.value!==a&&(this.value=a,this.input.value=this.value,this.onChange())},destroy:function(){this.preview&&this.preview.parentNode&&this.preview.parentNode.removeChild(this.preview),this.title&&this.title.parentNode&&this.title.parentNode.removeChild(this.title),this.input&&this.input.parentNode&&this.input.parentNode.removeChild(this.input),this.uploader&&this.uploader.parentNode&&this.uploader.parentNode.removeChild(this.uploader),this._super()}}),h.defaults.editors.checkbox=h.AbstractEditor.extend({setValue:function(a,b){this.value=!!a,this.input.checked=this.value,this.onChange()},register:function(){this._super(),this.input&&this.input.setAttribute("name",this.formname)},unregister:function(){this._super(),this.input&&this.input.removeAttribute("name")},getNumColumns:function(){return Math.min(12,Math.max(this.getTitle().length/7,2))},build:function(){var a=this;this.options.compact||(this.label=this.header=this.theme.getCheckboxLabel(this.getTitle())),this.schema.description&&(this.description=this.theme.getFormInputDescription(this.schema.description)),this.options.infoText&&(this.infoButton=this.theme.getInfoButton(this.options.infoText)),this.options.compact&&this.container.classList.add("compact"),this.input=this.theme.getCheckbox(),this.control=this.theme.getFormControl(this.label,this.input,this.description,this.infoButton),(this.schema.readOnly||this.schema.readonly)&&(this.always_disabled=!0,this.input.disabled=!0),this.input.addEventListener("change",function(b){b.preventDefault(),b.stopPropagation(),a.value=this.checked,a.onChange(!0)}),this.container.appendChild(this.control)},enable:function(){this.always_disabled||(this.input.disabled=!1,this._super())},disable:function(a){a&&(this.always_disabled=!0),this.input.disabled=!0,this._super()},destroy:function(){this.label&&this.label.parentNode&&this.label.parentNode.removeChild(this.label),this.description&&this.description.parentNode&&this.description.parentNode.removeChild(this.description),this.input&&this.input.parentNode&&this.input.parentNode.removeChild(this.input),this._super()},showValidationErrors:function(a){var b=this;if("always"===this.jsoneditor.options.show_errors);else if(!this.is_dirty&&this.previous_error_setting===this.jsoneditor.options.show_errors)return;this.previous_error_setting=this.jsoneditor.options.show_errors;var c=[];f(a,function(a,d){d.path===b.path&&c.push(d.message)}),this.input.controlgroup=this.control,c.length?this.theme.addInputError(this.input,c.join(". ")+"."):this.theme.removeInputError(this.input)}}),h.defaults.editors.arraySelectize=h.AbstractEditor.extend({build:function(){this.title=this.theme.getFormInputLabel(this.getTitle()),this.title_controls=this.theme.getHeaderButtonHolder(),this.title.appendChild(this.title_controls),this.error_holder=document.createElement("div"),this.schema.description&&(this.description=this.theme.getDescription(this.schema.description)),this.input=document.createElement("select"),this.input.setAttribute("multiple","multiple");var a=this.theme.getFormControl(this.title,this.input,this.description);this.container.appendChild(a),this.container.appendChild(this.error_holder),window.jQuery(this.input).selectize({delimiter:!1,createOnBlur:!0,create:!0})},postBuild:function(){var a=this;this.input.selectize.on("change",function(b){a.refreshValue(),a.onChange(!0)})},destroy:function(){this.empty(!0),this.title&&this.title.parentNode&&this.title.parentNode.removeChild(this.title),this.description&&this.description.parentNode&&this.description.parentNode.removeChild(this.description),this.input&&this.input.parentNode&&this.input.parentNode.removeChild(this.input),this._super()},empty:function(a){},setValue:function(a,b){var c=this;a=a||[],Array.isArray(a)||(a=[a]),this.input.selectize.clearOptions(),this.input.selectize.clear(!0),a.forEach(function(a){c.input.selectize.addOption({text:a,value:a})}),this.input.selectize.setValue(a),this.refreshValue(b)},refreshValue:function(a){this.value=this.input.selectize.getValue()},showValidationErrors:function(a){var b=this,c=[],d=[];if(f(a,function(a,e){e.path===b.path?c.push(e):d.push(e)}),this.error_holder)if(c.length){this.error_holder.innerHTML="",this.error_holder.style.display="",f(c,function(a,c){b.error_holder.appendChild(b.theme.getErrorMessage(c.message))})}else this.error_holder.style.display="none"}}),h.defaults.editors.starrating=h.defaults.editors.string.extend({build:function(){var a=this;this.options.compact||(this.header=this.label=this.theme.getFormInputLabel(this.getTitle())),this.schema.description&&(this.description=this.theme.getFormInputDescription(this.schema.description)),this.options.infoText&&(this.infoButton=this.theme.getInfoButton(this.options.infoText)),this.options.compact&&this.container.classList.add("compact"),this.ratingContainer=document.createElement("div"),this.ratingContainer.classList.add("starrating"),this.enum_values=this.schema["enum"],this.radioGroup=[];for(var b=function(b){b.preventDefault(),b.stopPropagation(),a.setValue(this.value),a.onChange(!0)},c=this.enum_values.length-1;c>-1;c--){var d=this.key+"-"+c,e=this.theme.getFormInputField("radio");e.name=this.formname+"[starrating]",e.value=this.enum_values[c],e.id=d,e.addEventListener("change",b,!1),this.radioGroup.push(e);var f=document.createElement("label");f.htmlFor=d,f.title=this.enum_values[c],this.options.displayValue&&f.classList.add("starrating-display-enabled"),this.ratingContainer.appendChild(e),this.ratingContainer.appendChild(f)}if(this.options.displayValue&&(this.displayRating=document.createElement("div"),this.displayRating.classList.add("starrating-display"),this.displayRating.innerText=this.enum_values[0],this.ratingContainer.appendChild(this.displayRating)),this.schema.readOnly||this.schema.readonly){this.always_disabled=!0;for(var g=0;c<this.radioGroup.length;g++)this.radioGroup[g].disabled=!0;this.ratingContainer.classList.add("readonly")}var h=this.theme.getContainer();h.appendChild(this.ratingContainer),this.input=h,this.control=this.theme.getFormControl(this.label,h,this.description,this.infoButton),this.container.appendChild(this.control)},enable:function(){if(!this.always_disabled){for(var a=0;a<this.radioGroup.length;a++)this.radioGroup[a].disabled=!1;this.ratingContainer.classList.remove("readonly"),this._super()}},disable:function(a){a&&(this.always_disabled=!0);for(var b=0;b<this.radioGroup.length;b++)this.radioGroup[b].disabled=!0;this.ratingContainer.classList.add("readonly"),this._super()},destroy:function(){this.ratingContainer.parentNode&&this.ratingContainer.parentNode.parentNode&&this.ratingContainer.parentNode.parentNode.removeChild(this.ratingContainer.parentNode),this.label&&this.label.parentNode&&this.label.parentNode.removeChild(this.label),this.description&&this.description.parentNode&&this.description.parentNode.removeChild(this.description),this._super()},getNumColumns:function(){return 2},setValue:function(a){for(var b=0;b<this.radioGroup.length;b++)if(this.radioGroup[b].value==a){this.radioGroup[b].checked=!0,this.value=a,this.options.displayValue&&(this.displayRating.innerHTML=this.value),this.onChange();break}}}),h.defaults.editors.datetime=h.defaults.editors.string.extend({build:function(){if(this._super(),this.input&&window.flatpickr&&"object"==typeof this.options.flatpickr){this.options.flatpickr.enableTime="date"!=this.schema.format,this.options.flatpickr.noCalendar="time"==this.schema.format,"integer"==this.schema.type&&(this.options.flatpickr.mode="single"),this.input.setAttribute("data-input","");var a=this.input;if(this.options.flatpickr.wrap===!0){var c=[];if(this.options.flatpickr.showToggleButton!==!1){var d=this.getButton("","time"==this.schema.format?"time":"calendar",this.translate("flatpickr_toggle_button"));d.setAttribute("data-toggle",""),c.push(d)}if(this.options.flatpickr.showClearButton!==!1){var e=this.getButton("","clear",this.translate("flatpickr_clear_button"));e.setAttribute("data-clear",""),c.push(e)}var f=this.input.parentNode,g=this.input.nextSibling,h=this.theme.getInputGroup(this.input,c);h!==b?(this.options.flatpickr.inline=!1,f.insertBefore(h,g),a=h):this.options.flatpickr.wrap=!1}this.flatpickr=window.flatpickr(a,this.options.flatpickr),this.options.flatpickr.inline===!0&&this.options.flatpickr.inlineHideInput===!0&&this.input.setAttribute("type","hidden")}},getValue:function(){if(!this.dependenciesFulfilled)return b;if("string"==this.schema.type)return this.value;if(""===this.value||this.value===b)return b;var a="time"==this.schema.format?"1970-01-01 "+this.value:this.value;return parseInt(new Date(a).getTime()/1e3)},setValue:function(a,b,c){if("string"==this.schema.type)this._super(a,b,c),this.flatpickr&&this.flatpickr.setDate(a);else if(a>0){var d=new Date(1e3*a),e=d.getFullYear(),f=this.zeroPad(d.getMonth()+1),g=this.zeroPad(d.getDate()),h=this.zeroPad(d.getHours()),i=this.zeroPad(d.getMinutes()),j=this.zeroPad(d.getSeconds()),k=[e,f,g].join("-"),l=[h,i,j].join(":"),m=k+" "+l;"date"==this.schema.format?m=k:"time"==this.schema.format&&(m=l),this.input.value=m,this.flatpickr&&this.flatpickr.setDate(m)}},destroy:function(){this.flatpickr&&this.flatpickr.destroy(),this.flatpickr=null,this._super()},zeroPad:function(a){return("0"+a).slice(-2)}}),h.defaults.editors.signature=h.defaults.editors.string.extend({build:function(){var a=this;this.options.compact||(this.header=this.label=this.theme.getFormInputLabel(this.getTitle())),this.schema.description&&(this.description=this.theme.getFormInputDescription(this.schema.description));var b=this.formname.replace(/\W/g,"");if("function"==typeof SignaturePad){var c="json-editor-style-signature";document.getElementById(c);this.input=this.theme.getFormInputField("hidden"),this.container.appendChild(this.input);var d=document.createElement("div");d.classList.add("signature-container");var e=document.createElement("canvas");e.setAttribute("name",b),e.classList.add("signature"),d.appendChild(e),a.signaturePad=new window.SignaturePad(e,{onEnd:function(){a.signaturePad.isEmpty()?a.input.value="":a.input.value=a.signaturePad.toDataURL(),a.is_dirty=!0,a.refreshValue(),a.watch_listener(),a.jsoneditor.notifyWatchers(a.path),a.parent?a.parent.onChildEditorChange(a):a.jsoneditor.onChange()}});var g=document.createElement("div"),h=document.createElement("button");h.classList.add("tiny","button"),h.innerHTML="Clear signature",g.appendChild(h),d.appendChild(g),this.options.compact&&this.container.setAttribute("class",this.container.getAttribute("class")+" compact"),(this.schema.readOnly||this.schema.readonly)&&(this.always_disabled=!0,f(this.inputs,function(a,b){e.setAttribute("readOnly","readOnly"),b.disabled=!0})),h.addEventListener("click",function(b){b.preventDefault(),b.stopPropagation(),a.signaturePad.clear(),a.signaturePad.strokeEnd()}),this.control=this.theme.getFormControl(this.label,d,this.description),this.container.appendChild(this.control),this.refreshValue(),e.width=d.offsetWidth,a.options&&a.options.canvas_height?e.height=a.options.canvas_height:e.height="300"}else{var i=document.createElement("p");i.innerHTML="Signature pad is not available, please include SignaturePad from https://github.com/szimek/signature_pad",this.container.appendChild(i)}},setValue:function(a){var b=this;if("function"==typeof SignaturePad){var c=(this.formname.replace(/\W/g,""),this.sanitize(a));if(this.value===c)return;return b.value=c,b.input.value=b.value,b.signaturePad.clear(),a&&""!=a&&b.signaturePad.fromDataURL(a),b.watch_listener(),b.jsoneditor.notifyWatchers(b.path),!1}},destroy:function(){var a=this;this.formname.replace(/\W/g,"");a.signaturePad.off(),delete a.signaturePad}});var i=function(){var a=document.documentElement;return a.matches?"matches":a.webkitMatchesSelector?"webkitMatchesSelector":a.mozMatchesSelector?"mozMatchesSelector":a.msMatchesSelector?"msMatchesSelector":a.oMatchesSelector?"oMatchesSelector":void 0}();return h.AbstractTheme=c.extend({getContainer:function(){return document.createElement("div")},getFloatRightLinkHolder:function(){var a=document.createElement("div");return a.style=a.style||{},a.style.cssFloat="right",a.style.marginLeft="10px",a},getModal:function(){var a=document.createElement("div");return a.style.backgroundColor="white",a.style.border="1px solid black",a.style.boxShadow="3px 3px black",a.style.position="absolute",a.style.zIndex="10",a.style.display="none",a},getGridContainer:function(){var a=document.createElement("div");return a},getGridRow:function(){var a=document.createElement("div");return a.classList.add("row"),a},getGridColumn:function(){var a=document.createElement("div");return a},setGridColumnSize:function(a,b){},getLink:function(a){var b=document.createElement("a");return b.setAttribute("href","#"),b.appendChild(document.createTextNode(a)),b},disableHeader:function(a){a.style.color="#ccc"},disableLabel:function(a){a.style.color="#ccc"},enableHeader:function(a){a.style.color=""},enableLabel:function(a){a.style.color=""},getInfoButton:function(a){var b=document.createElement("span");b.innerText="ⓘ",b.style.fontSize="16px",b.style.fontWeight="bold",b.style.padding=".25rem",b.style.position="relative",b.style.display="inline-block";var c=document.createElement("span");return c.style.fontSize="12px",b.style.fontWeight="normal",c.style["font-family"]="sans-serif",c.style.visibility="hidden",c.style["background-color"]="rgba(50, 50, 50, .75)",c.style.margin="0 .25rem",c.style.color="#FAFAFA",c.style.padding=".5rem 1rem",c.style["border-radius"]=".25rem",c.style.width="20rem",c.style.position="absolute",c.innerText=a,b.onmouseover=function(){c.style.visibility="visible"},b.onmouseleave=function(){c.style.visibility="hidden"},b.appendChild(c),b},getFormInputLabel:function(a){var b=document.createElement("label");return b.appendChild(document.createTextNode(a)),b},getCheckboxLabel:function(a){var b=this.getFormInputLabel(a);return b.style.fontWeight="normal",b},getHeader:function(a){var b=document.createElement("h3");return"string"==typeof a?b.textContent=a:b.appendChild(a),b},getCheckbox:function(){var a=this.getFormInputField("checkbox");return a.style.display="inline-block",a.style.width="auto",a},getMultiCheckboxHolder:function(a,b,c){var d=document.createElement("div");b&&(b.style.display="block",d.appendChild(b));for(var e in a)a.hasOwnProperty(e)&&(a[e].style.display="inline-block",a[e].style.marginRight="20px",d.appendChild(a[e]));return c&&d.appendChild(c),d},getSelectInput:function(a){var b=document.createElement("select");return a&&this.setSelectOptions(b,a),b},getSwitcher:function(a){var b=this.getSelectInput(a);return b.style.backgroundColor="transparent",b.style.display="inline-block",b.style.fontStyle="italic",b.style.fontWeight="normal",b.style.height="auto",b.style.marginBottom=0,b.style.marginLeft="5px",b.style.padding="0 0 0 3px",b.style.width="auto",b},getSwitcherOptions:function(a){return a.getElementsByTagName("option")},setSwitcherOptions:function(a,b,c){this.setSelectOptions(a,b,c)},setSelectOptions:function(a,b,c){c=c||[],a.innerHTML="";for(var d=0;d<b.length;d++){var e=document.createElement("option");e.setAttribute("value",b[d]),e.textContent=c[d]||b[d],a.appendChild(e)}},getTextareaInput:function(){var a=document.createElement("textarea");return a.style=a.style||{},a.style.width="100%",a.style.height="300px",a.style.boxSizing="border-box",a},getRangeInput:function(a,b,c){var d=this.getFormInputField("range");return d.setAttribute("min",a),d.setAttribute("max",b),d.setAttribute("step",c),d},getFormInputField:function(a){var b=document.createElement("input");return b.setAttribute("type",a),b},afterInputReady:function(a){},getFormControl:function(a,b,c,d){var e=document.createElement("div");return e.classList.add("form-control"),a&&e.appendChild(a),"checkbox"===b.type&&a?(a.insertBefore(b,a.firstChild),d&&a.appendChild(d)):(d&&a.appendChild(d),e.appendChild(b)),c&&e.appendChild(c),e},getIndentedPanel:function(){var a=document.createElement("div");return a.style=a.style||{},a.style.paddingLeft="10px",a.style.marginLeft="10px",a.style.borderLeft="1px solid #ccc",a},getTopIndentedPanel:function(){var a=document.createElement("div");return a.style=a.style||{},a.style.paddingLeft="10px",a.style.marginLeft="10px",a},getChildEditorHolder:function(){return document.createElement("div")},getDescription:function(a){var b=document.createElement("p");return b.innerHTML=a,b},getCheckboxDescription:function(a){return this.getDescription(a)},getFormInputDescription:function(a){return this.getDescription(a)},getHeaderButtonHolder:function(){return this.getButtonHolder()},getButtonHolder:function(){return document.createElement("div")},getButton:function(a,b,c){var d=document.createElement("button");return d.type="button",this.setButtonText(d,a,b,c),d},setButtonText:function(a,b,c,d){for(;a.firstChild;)a.removeChild(a.firstChild);c&&(a.appendChild(c),b=" "+b);var e=document.createElement("span");e.appendChild(document.createTextNode(b)),a.appendChild(e),d&&a.setAttribute("title",d)},getTable:function(){return document.createElement("table")},getTableRow:function(){return document.createElement("tr")},getTableHead:function(){return document.createElement("thead")},getTableBody:function(){return document.createElement("tbody")},getTableHeaderCell:function(a){var b=document.createElement("th");return b.textContent=a,b},getTableCell:function(){var a=document.createElement("td");return a},getErrorMessage:function(a){var b=document.createElement("p");return b.style=b.style||{},b.style.color="red",b.appendChild(document.createTextNode(a)),b},addInputError:function(a,b){},removeInputError:function(a){},addTableRowError:function(a){},removeTableRowError:function(a){},getTabHolder:function(a){var b="undefined"==typeof a?"":a,c=document.createElement("div");return c.innerHTML="<div style='float: left; width: 130px;' class='tabs' id='"+b+"'></div><div class='content' style='margin-left: 120px;' id='"+b+"'></div><div style='clear:both;'></div>",c},getTopTabHolder:function(a){var b="undefined"==typeof a?"":a,c=document.createElement("div");return c.innerHTML="<div class='tabs' style='margin-left: 10px;' id='"+b+"'></div><div style='clear:both;'></div><div class='content' id='"+b+"'></div>",c},applyStyles:function(a,b){for(var c in b)b.hasOwnProperty(c)&&(a.style[c]=b[c])},closest:function(a,b){for(;a&&a!==document;){if(!a[i])return!1;if(a[i](b))return a;a=a.parentNode}return!1},insertBasicTopTab:function(a,b){b.firstChild.insertBefore(a,b.firstChild.firstChild)},getTab:function(a,b){var c=document.createElement("div");return c.appendChild(a),c.id=b,c.style=c.style||{},this.applyStyles(c,{border:"1px solid #ccc",borderWidth:"1px 0 1px 1px",textAlign:"center",lineHeight:"30px",borderRadius:"5px",borderBottomRightRadius:0,borderTopRightRadius:0,fontWeight:"bold",cursor:"pointer"}),c},getTopTab:function(a,b){var c=document.createElement("div");return c.id=b,c.appendChild(a),c.style=c.style||{},this.applyStyles(c,{"float":"left",border:"1px solid #ccc",borderWidth:"1px 1px 0px 1px",textAlign:"center",lineHeight:"30px",borderRadius:"5px",paddingLeft:"5px",paddingRight:"5px",borderBottomRightRadius:0,borderBottomLeftRadius:0,fontWeight:"bold",cursor:"pointer"}),c},getTabContentHolder:function(a){return a.children[1]},getTopTabContentHolder:function(a){return a.children[1]},getTabContent:function(){return this.getIndentedPanel()},getTopTabContent:function(){return this.getTopIndentedPanel()},markTabActive:function(a){this.applyStyles(a.tab,{opacity:1,background:"white"}),"undefined"!=typeof a.rowPane?a.rowPane.style.display="":a.container.style.display=""},markTabInactive:function(a){this.applyStyles(a.tab,{opacity:.5,background:""}),"undefined"!=typeof a.rowPane?a.rowPane.style.display="none":a.container.style.display="none"},addTab:function(a,b){a.children[0].appendChild(b)},addTopTab:function(a,b){a.children[0].appendChild(b)},getBlockLink:function(){var a=document.createElement("a");return a.style.display="block",a},getBlockLinkHolder:function(){var a=document.createElement("div");return a},getLinksHolder:function(){var a=document.createElement("div");return a},createMediaLink:function(a,b,c){a.appendChild(b),c.style.width="100%",a.appendChild(c)},createImageLink:function(a,b,c){a.appendChild(b),b.appendChild(c)},getFirstTab:function(a){return a.firstChild.firstChild},getInputGroup:function(a,c){return b}}),h.defaults.themes.bootstrap2=h.AbstractTheme.extend({getRangeInput:function(a,b,c){return this._super(a,b,c)},getGridContainer:function(){var a=document.createElement("div");return a.classList.add("container-fluid"),a},getGridRow:function(){var a=document.createElement("div");return a.classList.add("row-fluid"),a},getFormInputLabel:function(a){var b=this._super(a);return b.style.display="inline-block",b.style.fontWeight="bold",b},setGridColumnSize:function(a,b){a.classList.add("span"+b)},getSelectInput:function(a){var b=this._super(a);return b.style.width="auto",b.style.maxWidth="98%",b},getFormInputField:function(a){var b=this._super(a);return b.style.width="98%",b},afterInputReady:function(a){if(!a.controlgroup&&(a.controlgroup=this.closest(a,".control-group"),a.controls=this.closest(a,".controls"),this.closest(a,".compact")&&(a.controlgroup.className=a.controlgroup.className.replace(/control-group/g,"").replace(/[ ]{2,}/g," "),a.controls.className=a.controlgroup.className.replace(/controls/g,"").replace(/[ ]{2,}/g," "),a.style.marginBottom=0),this.queuedInputErrorText)){var b=this.queuedInputErrorText;delete this.queuedInputErrorText,this.addInputError(a,b)}},getIndentedPanel:function(){var a=document.createElement("div");return a.classList.add("well","well-small"),a.style.paddingBottom=0,a},getInfoButton:function(a){var b=document.createElement("span");b.classList.add("icon-info-sign","pull-right"),b.style.padding=".25rem",b.style.position="relative",b.style.display="inline-block";var c=document.createElement("span");return c.style["font-family"]="sans-serif",c.style.visibility="hidden",c.style["background-color"]="rgba(50, 50, 50, .75)",c.style.margin="0 .25rem",c.style.color="#FAFAFA",c.style.padding=".5rem 1rem",c.style["border-radius"]=".25rem",c.style.width="25rem",c.style.transform="translateX(-27rem) translateY(-.5rem)",c.style.position="absolute",c.innerText=a,b.onmouseover=function(){c.style.visibility="visible"},b.onmouseleave=function(){c.style.visibility="hidden"},b.appendChild(c),b},getFormInputDescription:function(a){var b=document.createElement("p");return b.classList.add("help-inline"),b.textContent=a,b},getFormControl:function(a,b,c,d){var e=document.createElement("div");e.classList.add("control-group");var f=document.createElement("div");return f.classList.add("controls"),a&&"checkbox"===b.getAttribute("type")?(e.appendChild(f),a.classList.add("checkbox"),a.appendChild(b),f.appendChild(a),d&&f.appendChild(d),f.style.height="30px"):(a&&(a.classList.add("control-label"),e.appendChild(a)),d&&f.appendChild(d),f.appendChild(b),e.appendChild(f)),c&&f.appendChild(c),e},getHeaderButtonHolder:function(){var a=this.getButtonHolder();return a.style.marginLeft="10px",a},getButtonHolder:function(){var a=document.createElement("div");return a.classList.add("btn-group"),a},getButton:function(a,b,c){var d=this._super(a,b,c);return d.classList.add("btn","btn-default"),d},getTable:function(){var a=document.createElement("table");return a.classList.add("table","table-bordered"),a.style.width="auto",a.style.maxWidth="none",a},addInputError:function(a,b){return a.controlgroup?void(a.controlgroup&&a.controls&&(a.controlgroup.classList.add("error"),a.errmsg?a.errmsg.style.display="":(a.errmsg=document.createElement("p"),a.errmsg.classList.add("help-block","errormsg"),a.controls.appendChild(a.errmsg)),a.errmsg.textContent=b)):void(this.queuedInputErrorText=b)},removeInputError:function(a){a.controlgroup||delete this.queuedInputErrorText,a.errmsg&&(a.errmsg.style.display="none",a.controlgroup.classList.remove("error"))},getTabHolder:function(a){var b="undefined"==typeof a?"":a,c=document.createElement("div");return c.classList.add("tabbable","tabs-left"),c.innerHTML="<ul class='nav nav-tabs' id='"+b+"'></ul><div class='tab-content well well-small' id='"+b+"'></div>",c},getTopTabHolder:function(a){var b="undefined"==typeof a?"":a,c=document.createElement("div");return c.classList.add("tabbable","tabs-over"),c.innerHTML="<ul class='nav nav-tabs' id='"+b+"'></ul><div class='tab-content well well-small' id='"+b+"'></div>",c},getTab:function(a,b){var c=document.createElement("li");c.classList.add("nav-item");var d=document.createElement("a");return d.setAttribute("href","#"+b),d.appendChild(a),c.appendChild(d),c},getTopTab:function(a,b){var c=document.createElement("li");c.classList.add("nav-item");var d=document.createElement("a");return d.setAttribute("href","#"+b),d.appendChild(a),c.appendChild(d),c},getTabContentHolder:function(a){return a.children[1]},getTopTabContentHolder:function(a){return a.children[1]},getTabContent:function(){var a=document.createElement("div");return a.classList.add("tab-pane"),a},getTopTabContent:function(){var a=document.createElement("div");return a.classList.add("tab-pane"),a},markTabActive:function(a){a.tab.classList.add("active"),"undefined"!=typeof a.rowPane?a.rowPane.classList.add("active"):a.container.classList.add("active")},markTabInactive:function(a){a.tab.classList.remove("active"),"undefined"!=typeof a.rowPane?a.rowPane.classList.remove("active"):a.container.classList.remove("active")},addTab:function(a,b){a.children[0].appendChild(b)},addTopTab:function(a,b){a.children[0].appendChild(b)},getProgressBar:function(){var a=document.createElement("div");a.classList.add("progress");var b=document.createElement("div");return b.classList.add("bar"),b.style.width="0%",a.appendChild(b),a},updateProgressBar:function(a,b){a&&(a.firstChild.style.width=b+"%")},updateProgressBarUnknown:function(a){a&&(a.classList.add("progress","progress-striped","active"),a.firstChild.style.width="100%")},getInputGroup:function(a,b){if(a){var c=document.createElement("div");c.classList.add("input-append"),c.appendChild(a);for(var d=0;d<b.length;d++)b[d].classList.add("btn"),c.appendChild(b[d]);return c}}}),h.defaults.themes.bootstrap3=h.AbstractTheme.extend({getSelectInput:function(a){var b=this._super(a);return b.classList.add("form-control"),b},setGridColumnSize:function(a,b){a.classList.add("col-md-"+b)},afterInputReady:function(a){if(!a.controlgroup&&(a.controlgroup=this.closest(a,".form-group"),this.closest(a,".compact")&&(a.controlgroup.style.marginBottom=0),this.queuedInputErrorText)){var b=this.queuedInputErrorText;delete this.queuedInputErrorText,this.addInputError(a,b)}},getTextareaInput:function(){var a=document.createElement("textarea");return a.classList.add("form-control"),a},getRangeInput:function(a,b,c){return this._super(a,b,c)},getFormInputField:function(a){var b=this._super(a);return"checkbox"!==a&&b.classList.add("form-control"),b},getFormControl:function(a,b,c,d){var e=document.createElement("div");return a&&"checkbox"===b.type?(e.classList.add("checkbox"),a.appendChild(b),a.style.fontSize="14px",e.style.marginTop="0",d&&e.appendChild(d),e.appendChild(a),b.style.position="relative",b.style.cssFloat="left"):(e.classList.add("form-group"),a&&(a.classList.add("control-label"),e.appendChild(a)),d&&e.appendChild(d),e.appendChild(b)),c&&e.appendChild(c),e},getIndentedPanel:function(){var a=document.createElement("div");return a.classList.add("well","well-sm"),a.style.paddingBottom=0,a},getInfoButton:function(a){var b=document.createElement("span");b.classList.add("glyphicon","glyphicon-info-sign","pull-right"),b.style.padding=".25rem",b.style.position="relative",b.style.display="inline-block";var c=document.createElement("span");return c.style["font-family"]="sans-serif",c.style.visibility="hidden",c.style["background-color"]="rgba(50, 50, 50, .75)",c.style.margin="0 .25rem",c.style.color="#FAFAFA",c.style.padding=".5rem 1rem",c.style["border-radius"]=".25rem",c.style.width="25rem",c.style.transform="translateX(-27rem) translateY(-.5rem)",c.style.position="absolute",c.innerText=a,b.onmouseover=function(){c.style.visibility="visible"},b.onmouseleave=function(){c.style.visibility="hidden"},b.appendChild(c),b},getFormInputDescription:function(a){var b=document.createElement("p");return b.classList.add("help-block"),b.innerHTML=a,b},getHeaderButtonHolder:function(){var a=this.getButtonHolder();return a.style.marginLeft="10px",a},getButtonHolder:function(){var a=document.createElement("div");return a.classList.add("btn-group"),a},getButton:function(a,b,c){var d=this._super(a,b,c);return d.classList.add("btn","btn-default"),d},getTable:function(){var a=document.createElement("table");return a.classList.add("table","table-bordered"),a.style.width="auto",a.style.maxWidth="none",a},addInputError:function(a,b){return a.controlgroup?(a.controlgroup.classList.add("has-error"),a.errmsg?a.errmsg.style.display="":(a.errmsg=document.createElement("p"),a.errmsg.classList.add("help-block","errormsg"),a.controlgroup.appendChild(a.errmsg)),void(a.errmsg.textContent=b)):void(this.queuedInputErrorText=b)},removeInputError:function(a){a.controlgroup||delete this.queuedInputErrorText,a.errmsg&&(a.errmsg.style.display="none",a.controlgroup.classList.remove("has-error"))},getTabHolder:function(a){var b="undefined"==typeof a?"":a,c=document.createElement("div");return c.innerHTML="<ul class='col-md-2 nav nav-pills nav-stacked' id='"+b+"' role='tablist'></ul><div class='col-md-10 tab-content well well-small' id='"+b+"'></div>",c},getTopTabHolder:function(a){var b="undefined"==typeof a?"":a,c=document.createElement("div");return c.innerHTML="<ul class='nav nav-tabs' id='"+b+"' role='tablist'></ul><div class='tab-content well well-small' id='"+b+"'></div>",c},getTab:function(a,b){var c=document.createElement("li");c.setAttribute("role","presentation");var d=document.createElement("a");return d.setAttribute("href","#"+b),d.appendChild(a),d.setAttribute("aria-controls",b),d.setAttribute("role","tab"),d.setAttribute("data-toggle","tab"),c.appendChild(d),c},getTopTab:function(a,b){var c=document.createElement("li");c.setAttribute("role","presentation");var d=document.createElement("a");return d.setAttribute("href","#"+b),d.appendChild(a),d.setAttribute("aria-controls",b),d.setAttribute("role","tab"),d.setAttribute("data-toggle","tab"),c.appendChild(d),c},getTabContent:function(){var a=document.createElement("div");return a.classList.add("tab-pane"),a.setAttribute("role","tabpanel"),a},getTopTabContent:function(){var a=document.createElement("div");return a.classList.add("tab-pane"),a.setAttribute("role","tabpanel"),a},markTabActive:function(a){a.tab.classList.add("active"),"undefined"!=typeof a.rowPane?a.rowPane.classList.add("active"):a.container.classList.add("active")},markTabInactive:function(a){a.tab.classList.remove("active"),"undefined"!=typeof a.rowPane?a.rowPane.classList.remove("active"):a.container.classList.remove("active")},getProgressBar:function(){var a=0,b=100,c=0,d=document.createElement("div");d.classList.add("progress");var e=document.createElement("div");return e.classList.add("progress-bar"),e.setAttribute("role","progressbar"),e.setAttribute("aria-valuenow",c), +e.setAttribute("aria-valuemin",a),e.setAttribute("aria-valuenax",b),e.innerHTML=c+"%",d.appendChild(e),d},updateProgressBar:function(a,b){if(a){var c=a.firstChild,d=b+"%";c.setAttribute("aria-valuenow",b),c.style.width=d,c.innerHTML=d}},updateProgressBarUnknown:function(a){if(a){var b=a.firstChild;a.classList.add("progress","progress-striped","active"),b.removeAttribute("aria-valuenow"),b.style.width="100%",b.innerHTML=""}},getInputGroup:function(a,b){if(a){var c=document.createElement("div");c.classList.add("input-group"),c.appendChild(a);var d=document.createElement("div");d.classList.add("input-group-btn"),c.appendChild(d);for(var e=0;e<b.length;e++)d.appendChild(b[e]);return c}}}),h.defaults.themes.bootstrap4=h.AbstractTheme.extend({getSelectInput:function(a){var b=this._super(a);return b.classList.add("form-control"),b},setGridColumnSize:function(a,b){a.classList.add("col-md-"+b)},afterInputReady:function(a){a.controlgroup||(a.controlgroup=this.closest(a,".form-group"),this.closest(a,".compact")&&(a.controlgroup.style.marginBottom=0))},getTextareaInput:function(){var a=document.createElement("textarea");return a.classList.add("form-control"),a},getRangeInput:function(a,b,c){return this._super(a,b,c)},getFormInputField:function(a){var b=this._super(a);return"checkbox"!==a&&b.classList.add("form-control"),b},getFormControl:function(a,b,c){var d=document.createElement("div");return a&&"checkbox"===b.type?(d.classList.add("checkbox"),a.appendChild(b),a.style.fontSize="14px",d.style.marginTop="0",d.appendChild(a),b.style.position="relative",b.style.cssFloat="left"):(d.classList.add("form-group"),a&&(a.classList.add("form-control-label"),d.appendChild(a)),d.appendChild(b)),c&&d.appendChild(c),d},getIndentedPanel:function(){var a=document.createElement("div");return a.classList.add("card","card-body","bg-light"),a},getFormInputDescription:function(a){var b=document.createElement("p");return b.classList.add("form-text"),b.innerHTML=a,b},getHeaderButtonHolder:function(){var a=this.getButtonHolder();return a.style.marginLeft="10px",a},getButtonHolder:function(){var a=document.createElement("div");return a.classList.add("btn-group"),a},getButton:function(a,b,c){var d=this._super(a,b,c);return d.classList.add("btn","btn-secondary"),d},getTable:function(){var a=document.createElement("table");return a.classList.add("table-bordered","table-sm"),a.style.width="auto",a.style.maxWidth="none",a},addInputError:function(a,b){a.controlgroup&&(a.controlgroup.classList.add("has-danger"),a.classList.add("is-invalid"),a.errmsg?a.errmsg.style.display="":(a.errmsg=document.createElement("p"),a.errmsg.classList.add("form-text","invalid-feedback"),a.controlgroup.appendChild(a.errmsg)),a.errmsg.textContent=b)},removeInputError:function(a){a.errmsg&&(a.errmsg.style.display="none",a.classList.remove("is-invalid"),a.controlgroup.classList.remove("has-danger"))},getTabHolder:function(a){var b=document.createElement("div"),c="undefined"==typeof a?"":a;return b.innerHTML="<div class='col-md-2' id='"+c+"'><ul class='nav flex-column nav-pills'></ul></div><div class='tab-content col-md-10' id='"+c+"'></div>",b.classList.add("row"),b},addTab:function(a,b){a.children[0].children[0].appendChild(b)},getTopTabHolder:function(a){var b="undefined"==typeof a?"":a,c=document.createElement("div");return c.innerHTML="<ul class='nav nav-tabs' id='"+b+"'></ul><div class='card-body tab-content' id='"+b+"'></div>",c},getTab:function(a,b){var c=document.createElement("li");c.classList.add("nav-item");var d=document.createElement("a");return d.classList.add("nav-link"),d.setAttribute("style","padding:10px;"),d.setAttribute("href","#"+b),d.setAttribute("data-toggle","tab"),d.appendChild(a),c.appendChild(d),c},getTopTab:function(a,b){var c=document.createElement("li");c.classList.add("nav-item");var d=document.createElement("a");return d.classList.add("nav-link"),d.setAttribute("href","#"+b),d.setAttribute("data-toggle","tab"),d.appendChild(a),c.appendChild(d),c},getTabContent:function(){var a=document.createElement("div");return a.classList.add("tab-pane"),a.setAttribute("role","tabpanel"),a},getTopTabContent:function(){var a=document.createElement("div");return a.classList.add("tab-pane"),a.setAttribute("role","tabpanel"),a},markTabActive:function(a){a.tab.firstChild.classList.add("active"),"undefined"!=typeof a.rowPane?a.rowPane.classList.add("active"):a.container.classList.add("active")},markTabInactive:function(a){a.tab.firstChild.classList.remove("active"),"undefined"!=typeof a.rowPane?a.rowPane.classList.remove("active"):a.container.classList.remove("active")},getProgressBar:function(){var a=0,b=100,c=0,d=document.createElement("div");d.classList.add("progress");var e=document.createElement("div");return e.classList.add("progress-bar"),e.setAttribute("role","progressbar"),e.setAttribute("aria-valuenow",c),e.setAttribute("aria-valuemin",a),e.setAttribute("aria-valuenax",b),e.innerHTML=c+"%",d.appendChild(e),d},updateProgressBar:function(a,b){if(a){var c=a.firstChild,d=b+"%";c.setAttribute("aria-valuenow",b),c.style.width=d,c.innerHTML=d}},updateProgressBarUnknown:function(a){if(a){var b=a.firstChild;a.classList.add("progress","progress-striped","active"),b.removeAttribute("aria-valuenow"),b.style.width="100%",b.innerHTML=""}},getInputGroup:function(a,b){if(a){var c=document.createElement("div");c.classList.add("input-group"),c.appendChild(a);var d=document.createElement("div");d.classList.add("input-group-prepend"),c.appendChild(d);for(var e=0;e<b.length;e++)d.appendChild(b[e]);return c}}}),h.defaults.themes.foundation=h.AbstractTheme.extend({getChildEditorHolder:function(){var a=document.createElement("div");return a.style.marginBottom="15px",a},getSelectInput:function(a){var b=this._super(a);return b.style.minWidth="none",b.style.padding="5px",b.style.marginTop="3px",b},getSwitcher:function(a){var b=this._super(a);return b.style.paddingRight="8px",b},afterInputReady:function(a){if(!a.group&&(this.closest(a,".compact")&&(a.style.marginBottom=0),a.group=this.closest(a,".form-control"),this.queuedInputErrorText)){var b=this.queuedInputErrorText;delete this.queuedInputErrorText,this.addInputError(a,b)}},getFormInputLabel:function(a){var b=this._super(a);return b.style.display="inline-block",b},getFormInputField:function(a){var b=this._super(a);return b.style.width="100%",b.style.marginBottom="checkbox"===a?"0":"12px",b},getFormInputDescription:function(a){var b=document.createElement("p");return b.textContent=a,b.style.marginTop="-10px",b.style.fontStyle="italic",b},getIndentedPanel:function(){var a=document.createElement("div");return a.classList.add("panel"),a.style.paddingBottom=0,a},getHeaderButtonHolder:function(){var a=this.getButtonHolder();return a.style.display="inline-block",a.style.marginLeft="10px",a.style.verticalAlign="middle",a},getButtonHolder:function(){var a=document.createElement("div");return a.classList.add("button-group"),a},getButton:function(a,b,c){var d=this._super(a,b,c);return d.classList.add("small","button"),d},addInputError:function(a,b){return a.group?(a.group.classList.add("error"),a.errmsg?a.errmsg.style.display="":(a.insertAdjacentHTML("afterend",'<small class="error"></small>'),a.errmsg=a.parentNode.getElementsByClassName("error")[0]),void(a.errmsg.textContent=b)):void(this.queuedInputErrorText=b)},removeInputError:function(a){a.group||delete this.queuedInputErrorText,a.errmsg&&(a.group.classList.remove("error"),a.errmsg.style.display="none")},getProgressBar:function(){var a=document.createElement("div");a.classList.add("progress");var b=document.createElement("span");return b.classList.add("meter"),b.style.width="0%",a.appendChild(b),a},updateProgressBar:function(a,b){a&&(a.firstChild.style.width=b+"%")},updateProgressBarUnknown:function(a){a&&(a.firstChild.style.width="100%")},getInputGroup:function(a,c){if(!a)return b;var d=document.createElement("div");d.classList.add("input-group"),a.classList.add("input-group-field"),d.appendChild(a);for(var e=0;e<c.length;e++){var f=document.createElement("div");f.classList.add("input-group-button"),f.style.verticalAlign="top",c[e].classList.remove("small"),f.appendChild(c[e]),d.appendChild(f)}return d}}),h.defaults.themes.foundation3=h.defaults.themes.foundation.extend({getHeaderButtonHolder:function(){var a=this._super();return a.style.fontSize=".6em",a},getFormInputLabel:function(a){var b=this._super(a);return b.style.fontWeight="bold",b},getTabHolder:function(a){var b="undefined"==typeof a?"":a,c=document.createElement("div");return c.classList.add("row"),c.innerHTML='<dl class="tabs vertical two columns" id="'+b+'"></dl><div class="tabs-content ten columns" id="'+b+'"></div>',c},getTopTabHolder:function(a){var b="undefined"==typeof a?"":a,c=document.createElement("div");return c.classList.add("row"),c.innerHTML='<dl class="tabs horizontal" style="padding-left: 10px; margin-left: 10px;" id="'+b+'"></dl><div class="tabs-content twelve columns" style="padding: 10px; margin-left: 10px;" id="'+b+'"></div>',c},setGridColumnSize:function(a,b){var c=["zero","one","two","three","four","five","six","seven","eight","nine","ten","eleven","twelve"];a.classList.add("columns",c[b])},getTab:function(a,b){var c=document.createElement("dd"),d=document.createElement("a");return d.setAttribute("href","#"+b),d.appendChild(a),c.appendChild(d),c},getTopTab:function(a,b){var c=document.createElement("dd"),d=document.createElement("a");return d.setAttribute("href","#"+b),d.appendChild(a),c.appendChild(d),c},getTabContentHolder:function(a){return a.children[1]},getTopTabContentHolder:function(a){return a.children[1]},getTabContent:function(){var a=document.createElement("div");return a.classList.add("content","active"),a.style.paddingLeft="5px",a},getTopTabContent:function(){var a=document.createElement("div");return a.classList.add("content","active"),a.style.paddingLeft="5px",a},markTabActive:function(a){a.tab.classList.add("active"),"undefined"!=typeof a.rowPane?a.rowPane.style.display="":a.container.style.display=""},markTabInactive:function(a){a.tab.classList.remove("active"),"undefined"!=typeof a.rowPane?a.rowPane.style.display="none":a.container.style.display="none"},addTab:function(a,b){a.children[0].appendChild(b)},addTopTab:function(a,b){a.children[0].appendChild(b)}}),h.defaults.themes.foundation4=h.defaults.themes.foundation.extend({getHeaderButtonHolder:function(){var a=this._super();return a.style.fontSize=".6em",a},setGridColumnSize:function(a,b){a.classList.add("columns","large-"+b)},getFormInputDescription:function(a){var b=this._super(a);return b.style.fontSize=".8rem",b},getFormInputLabel:function(a){var b=this._super(a);return b.style.fontWeight="bold",b}}),h.defaults.themes.foundation5=h.defaults.themes.foundation.extend({getFormInputDescription:function(a){var b=this._super(a);return b.style.fontSize=".8rem",b},setGridColumnSize:function(a,b){a.classList.add("columns","medium-"+b)},getButton:function(a,b,c){var d=this._super(a,b,c);return d.className=d.className.replace(/\s*small/g,"")+" tiny",d},getTabHolder:function(a){var b="undefined"==typeof a?"":a,c=document.createElement("div");return c.innerHTML='<dl class="tabs vertical" id="'+b+'"></dl><div class="tabs-content vertical" id="'+b+'"></div>',c},getTopTabHolder:function(a){var b="undefined"==typeof a?"":a,c=document.createElement("div");return c.classList.add("row"),c.innerHTML='<dl class="tabs horizontal" style="padding-left: 10px;" id="'+b+'"></dl><div class="tabs-content horizontal" style="padding: 10px;" id="'+b+'"></div>',c},getTab:function(a,b){var c=document.createElement("dd"),d=document.createElement("a");return d.setAttribute("href","#"+b),d.appendChild(a),c.appendChild(d),c},getTopTab:function(a,b){var c=document.createElement("dd"),d=document.createElement("a");return d.setAttribute("href","#"+b),d.appendChild(a),c.appendChild(d),c},getTabContentHolder:function(a){return a.children[1]},getTopTabContentHolder:function(a){return a.children[1]},getTabContent:function(){var a=document.createElement("div");return a.classList.add("tab-content","active"),a.style.paddingLeft="5px",a},getTopTabContent:function(){var a=document.createElement("div");return a.classList.add("tab-content","active"),a.style.paddingLeft="5px",a},markTabActive:function(a){a.tab.classList.add("active"),"undefined"!=typeof a.rowPane?a.rowPane.style.display="":a.container.style.display=""},markTabInactive:function(a){a.tab.classList.remove("active"),"undefined"!=typeof a.rowPane?a.rowPane.style.display="none":a.container.style.display="none"},addTab:function(a,b){a.children[0].appendChild(b)},addTopTab:function(a,b){a.children[0].appendChild(b)}}),h.defaults.themes.foundation6=h.defaults.themes.foundation5.extend({getIndentedPanel:function(){var a=document.createElement("div");return a.classList.add("callout","secondary"),a.style="padding-left: 10px; margin-left: 10px;",a},getButtonHolder:function(){var a=document.createElement("div");return a.classList.add("button-group","tiny"),a.style.marginBottom=0,a},getFormInputLabel:function(a){var b=this._super(a);return b.style.display="block",b},getFormControl:function(a,b,c,d){var e=document.createElement("div");return e.classList.add("form-control"),a&&e.appendChild(a),"checkbox"===b.type?a.insertBefore(b,a.firstChild):a?(d&&a.appendChild(d),a.appendChild(b)):(d&&e.appendChild(d),e.appendChild(b)),c&&a.appendChild(c),e},addInputError:function(a,b){if(a.group){if(a.group.classList.add("error"),a.errmsg)a.errmsg.style.display="",a.className="";else{var c=document.createElement("span");c.classList.add("form-error","is-visible"),a.group.getElementsByTagName("label")[0].appendChild(c),a.classList.add("is-invalid-input"),a.errmsg=c}a.errmsg.textContent=b}},removeInputError:function(a){a.errmsg&&(a.classList.remove("is-invalid-input"),a.errmsg.parentNode&&a.errmsg.parentNode.removeChild(a.errmsg))},getTabHolder:function(a){var b="undefined"==typeof a?"":a,c=document.createElement("div");return c.classList.add("grid-x"),c.innerHTML='<div class="medium-2 cell" style="float: left;"><ul class="vertical tabs" data-tabs id="'+b+'"></ul></div><div class="medium-10 cell" style="float: left;"><div class="tabs-content" data-tabs-content="'+b+'"></div></div>',c},getTopTabHolder:function(a){var b="undefined"==typeof a?"":a,c=document.createElement("div");return c.classList.add("grid-y"),c.innerHTML='<div className="cell"><ul class="tabs" data-tabs id="'+b+'"></ul><div class="tabs-content" data-tabs-content="'+b+'"></div></div>',c},insertBasicTopTab:function(a,b){b.firstChild.firstChild.insertBefore(a,b.firstChild.firstChild.firstChild)},getTab:function(a,b){var c=document.createElement("li");c.classList.add("tabs-title");var d=document.createElement("a");return d.setAttribute("href","#"+b),d.appendChild(a),c.appendChild(d),c},getTopTab:function(a,b){var c=document.createElement("li");c.classList.add("tabs-title");var d=document.createElement("a");return d.setAttribute("href","#"+b),d.appendChild(a),c.appendChild(d),c},getTabContentHolder:function(a){return a.children[1].firstChild},getTopTabContentHolder:function(a){return a.firstChild.children[1]},getTabContent:function(){var a=document.createElement("div");return a.classList.add("tabs-panel"),a.style.paddingLeft="5px",a},getTopTabContent:function(){var a=document.createElement("div");return a.classList.add("tabs-panel"),a.style.paddingLeft="5px",a},markTabActive:function(a){a.tab.classList.add("is-active"),a.tab.firstChild.setAttribute("aria-selected","true"),"undefined"!=typeof a.rowPane?(a.rowPane.classList.add("is-active"),a.rowPane.setAttribute("aria-selected","true")):(a.container.classList.add("is-active"),a.container.setAttribute("aria-selected","true"))},markTabInactive:function(a){a.tab.classList.remove("is-active"),a.tab.firstChild.removeAttribute("aria-selected"),"undefined"!=typeof a.rowPane?(a.rowPane.classList.remove("is-active"),a.rowPane.removeAttribute("aria-selected")):(a.container.classList.remove("is-active"),a.container.removeAttribute("aria-selected"))},addTab:function(a,b){a.children[0].firstChild.appendChild(b)},addTopTab:function(a,b){a.firstChild.children[0].appendChild(b)},getFirstTab:function(a){return a.firstChild.firstChild.firstChild}}),h.defaults.themes.html=h.AbstractTheme.extend({getFormInputLabel:function(a){var b=this._super(a);return b.style.display="block",b.style.marginBottom="3px",b.style.fontWeight="bold",b},getFormInputDescription:function(a){var b=this._super(a);return b.style.fontSize=".8em",b.style.margin=0,b.style.display="inline-block",b.style.fontStyle="italic",b},getIndentedPanel:function(){var a=this._super();return a.style.border="1px solid #ddd",a.style.padding="5px",a.style.margin="10px",a.style.borderRadius="3px",a},getTopIndentedPanel:function(){return this.getIndentedPanel()},getChildEditorHolder:function(){var a=this._super();return a.style.marginBottom="8px",a},getHeaderButtonHolder:function(){var a=this.getButtonHolder();return a.style.display="inline-block",a.style.marginLeft="10px",a.style.fontSize=".8em",a.style.verticalAlign="middle",a},getTable:function(){var a=this._super();return a.style.borderBottom="1px solid #ccc",a.style.marginBottom="5px",a},addInputError:function(a,b){if(a.style.borderColor="red",a.errmsg)a.errmsg.style.display="block";else{var c=this.closest(a,".form-control");a.errmsg=document.createElement("div"),a.errmsg.setAttribute("class","errmsg"),a.errmsg.style=a.errmsg.style||{},a.errmsg.style.color="red",c.appendChild(a.errmsg)}a.errmsg.innerHTML="",a.errmsg.appendChild(document.createTextNode(b))},removeInputError:function(a){a.style.borderColor="",a.errmsg&&(a.errmsg.style.display="none")},getProgressBar:function(){var a=100,b=0,c=document.createElement("progress");return c.setAttribute("max",a),c.setAttribute("value",b),c},updateProgressBar:function(a,b){a&&a.setAttribute("value",b)},updateProgressBarUnknown:function(a){a&&a.removeAttribute("value")}}),h.defaults.themes.jqueryui=h.AbstractTheme.extend({getTable:function(){var a=this._super();return a.setAttribute("cellpadding",5),a.setAttribute("cellspacing",0),a},getTableHeaderCell:function(a){var b=this._super(a);return b.classList.add("ui-state-active"),b.style.fontWeight="bold",b},getTableCell:function(){var a=this._super();return a.classList.add("ui-widget-content"),a},getHeaderButtonHolder:function(){var a=this.getButtonHolder();return a.style.marginLeft="10px",a.style.fontSize=".6em",a.style.display="inline-block",a},getFormInputDescription:function(a){var b=this.getDescription(a);return b.style.marginLeft="10px",b.style.display="inline-block",b},getFormControl:function(a,b,c,d){var e=this._super(a,b,c,d);return"checkbox"===b.type?(e.style.lineHeight="25px",e.style.padding="3px 0"):e.style.padding="4px 0 8px 0",e},getDescription:function(a){var b=document.createElement("span");return b.style.fontSize=".8em",b.style.fontStyle="italic",b.textContent=a,b},getButtonHolder:function(){var a=document.createElement("div");return a.classList.add("ui-buttonset"),a.style.fontSize=".7em",a},getFormInputLabel:function(a){var b=document.createElement("label");return b.style.fontWeight="bold",b.style.display="block",b.textContent=a,b},getButton:function(a,b,c){var d=document.createElement("button");d.classList.add("ui-button","ui-widget","ui-state-default","ui-corner-all"),b&&!a?(d.classList.add("ui-button-icon-only"),b.classList.add("ui-button-icon-primary","ui-icon-primary"),d.appendChild(b)):b?(d.classList.add("ui-button-text-icon-primary"),b.classList.add("ui-button-icon-primary","ui-icon-primary"),d.appendChild(b)):d.classList.add("ui-button-text-only");var e=document.createElement("span");return e.classList.add("ui-button-text"),e.textContent=a||c||".",d.appendChild(e),d.setAttribute("title",c),d},setButtonText:function(a,b,c,d){a.innerHTML="",a.classList.add("ui-button","ui-widget","ui-state-default","ui-corner-all"),c&&!b?(a.classList.add("ui-button-icon-only"),c.classList.add("ui-button-icon-primary","ui-icon-primary"),a.appendChild(c)):c?(a.classList.add("ui-button-text-icon-primary"),c.classList.add("ui-button-icon-primary","ui-icon-primary"),a.appendChild(c)):a.classList.add("ui-button-text-only");var e=document.createElement("span");e.classList.add("ui-button-text"),e.textContent=b||d||".",a.appendChild(e),a.setAttribute("title",d)},getIndentedPanel:function(){var a=document.createElement("div");return a.classList.add("ui-widget-content","ui-corner-all"),a.style.padding="1em 1.4em",a.style.marginBottom="20px",a},afterInputReady:function(a){if(!a.controls&&(a.controls=this.closest(a,".form-control"),this.queuedInputErrorText)){var b=this.queuedInputErrorText;delete this.queuedInputErrorText,this.addInputError(a,b)}},addInputError:function(a,b){return a.controls?(a.errmsg?a.errmsg.style.display="":(a.errmsg=document.createElement("div"),a.errmsg.classList.add("ui-state-error"),a.controls.appendChild(a.errmsg)),void(a.errmsg.textContent=b)):void(this.queuedInputErrorText=b)},removeInputError:function(a){a.controls||delete this.queuedInputErrorText,a.errmsg&&(a.errmsg.style.display="none")},markTabActive:function(a){a.tab.classList.remove("ui-widget-header"),a.tab.classList.add("ui-state-active"),"undefined"!=typeof a.rowPane?a.rowPane.style.display="":a.container.style.display=""},markTabInactive:function(a){a.tab.classList.add("ui-widget-header"),a.tab.classList.remove("ui-state-active"),"undefined"!=typeof a.rowPane?a.rowPane.style.display="none":a.container.style.display="none"}}),h.defaults.themes.barebones=h.AbstractTheme.extend({getFormInputLabel:function(a){var b=this._super(a);return b},getFormInputDescription:function(a){var b=this._super(a);return b},getIndentedPanel:function(){var a=this._super();return a},getChildEditorHolder:function(){var a=this._super();return a},getHeaderButtonHolder:function(){var a=this.getButtonHolder();return a},getTable:function(){var a=this._super();return a},addInputError:function(a,b){if(a.errmsg)a.errmsg.style.display="block";else{var c=this.closest(a,".form-control");a.errmsg=document.createElement("div"),a.errmsg.setAttribute("class","errmsg"),c.appendChild(a.errmsg)}a.errmsg.innerHTML="",a.errmsg.appendChild(document.createTextNode(b))},removeInputError:function(a){a.style.borderColor="",a.errmsg&&(a.errmsg.style.display="none")},getProgressBar:function(){var a=100,b=0,c=document.createElement("progress");return c.setAttribute("max",a),c.setAttribute("value",b),c},updateProgressBar:function(a,b){a&&a.setAttribute("value",b)},updateProgressBarUnknown:function(a){a&&a.removeAttribute("value")}}),h.defaults.themes.materialize=h.AbstractTheme.extend({setGridColumnSize:function(a,b){a.classList.add("col"),a.classList.add("s"+b)},getHeaderButtonHolder:function(){return this.getButtonHolder()},getButtonHolder:function(){return document.createElement("span")},getButton:function(a,b,c){a&&(b.classList.add("left"),b.style.marginRight="5px");var d=this._super(a,b,c);return d.classList.add("waves-effect","waves-light","btn"),d.style.fontSize="0.75rem",d.style.height="24px",d.style.lineHeight="24px",d.style.marginLeft="5px",d.style.padding="0 0.5rem",d},getFormControl:function(a,b,c,d){var e,f=b.type;if(f&&"checkbox"===f){if(e=document.createElement("p"),a){var g=document.createElement("span");g.innerHTML=a.innerHTML,a.innerHTML="",a.setAttribute("for",b.id),e.appendChild(a),a.appendChild(b),a.appendChild(g)}else e.appendChild(b);return e}return e=this._super(a,b,c,d),f&&f.startsWith("select")||e.classList.add("input-field"),f&&"color"===f&&(b.style.height="3rem",b.style.width="100%",b.style.margin="5px 0 20px 0",b.style.padding="3px",a&&(a.style.transform="translateY(-14px) scale(0.8)",a.style["-webkit-transform"]="translateY(-14px) scale(0.8)",a.style["-webkit-transform-origin"]="0 0",a.style["transform-origin"]="0 0")),e},getDescription:function(a){var b=document.createElement("div");return b.classList.add("grey-text"),b.style.marginTop="-15px",b.innerHTML=a,b},getHeader:function(a){var b=document.createElement("h5");return"string"==typeof a?b.textContent=a:b.appendChild(a),b},getChildEditorHolder:function(){var a=document.createElement("div");return a.marginBottom="10px",a},getIndentedPanel:function(){var a=document.createElement("div");return a.classList.add("card-panel"),a},getTable:function(){var a=document.createElement("table");return a.classList.add("striped","bordered"),a.style.marginBottom="10px",a},getTableRow:function(){return document.createElement("tr")},getTableHead:function(){return document.createElement("thead")},getTableBody:function(){return document.createElement("tbody")},getTableHeaderCell:function(a){var b=document.createElement("th");return b.textContent=a,b},getTableCell:function(){var a=document.createElement("td");return a},getTabHolder:function(){var a=['<div class="col s2">',' <ul class="tabs" style="height: auto; margin-top: 0.82rem; -ms-flex-direction: column; -webkit-flex-direction: column; flex-direction: column; display: -webkit-flex; display: flex;">'," </ul>","</div>",'<div class="col s10">',"<div>"].join("\n"),b=document.createElement("div");return b.classList.add("row","card-panel"),b.innerHTML=a,b},addTab:function(a,b){a.children[0].children[0].appendChild(b)},getTab:function(a){var b=document.createElement("li");return b.classList.add("tab"),b.style=b.style||{},this.applyStyles(b,{width:"100%",textAlign:"left",lineHeight:"24px",height:"24px",fontSize:"14px",cursor:"pointer"}),b.appendChild(a),b},markTabActive:function(a){a.style=a.style||{},this.applyStyles(a,{width:"100%",textAlign:"left",lineHeight:"24px",height:"24px",fontSize:"14px",cursor:"pointer",color:"rgba(238,110,115,1)",transition:"border-color .5s ease",borderRight:"3px solid #424242"})},markTabInactive:function(a){a.style=a.style||{},this.applyStyles(a,{width:"100%",textAlign:"left",lineHeight:"24px",height:"24px",fontSize:"14px",cursor:"pointer",color:"rgba(238,110,115,0.7)"})},getTabContentHolder:function(a){return a.children[1]},getTabContent:function(){return document.createElement("div")},addInputError:function(a,b){var c,d=a.parentNode;d&&(this.removeInputError(a),c=document.createElement("div"),c.classList.add("error-text","red-text"),c.textContent=b,d.appendChild(c))},removeInputError:function(a){var b,c=a.parentElement;if(c){b=c.getElementsByClassName("error-text");for(var d=0;d<b.length;d++)c.removeChild(b[d])}},addTableRowError:function(a){},removeTableRowError:function(a){},getSelectInput:function(a){var b=this._super(a);return b.classList.add("browser-default"),b},getTextareaInput:function(){var a=document.createElement("textarea");return a.style.marginBottom="5px",a.style.fontSize="1rem",a.style.fontFamily="monospace",a},getCheckbox:function(){var a=this.getFormInputField("checkbox");return a.id=this.createUuid(),a},getModal:function(){var a=document.createElement("div");return a.classList.add("card-panel","z-depth-3"),a.style.padding="5px",a.style.position="absolute",a.style.zIndex="10",a.style.display="none",a},createUuid:function(){return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,function(a){var b=16*Math.random()|0,c="x"==a?b:3&b|8;return c.toString(16)})}}),h.AbstractIconLib=c.extend({mapping:{collapse:"",expand:"","delete":"",edit:"",add:"",cancel:"",save:"",moveup:"",movedown:""},icon_prefix:"",getIconClass:function(a){return this.mapping[a]?this.icon_prefix+this.mapping[a]:null},getIcon:function(a){var b=this.getIconClass(a);if(!b)return null;var c=document.createElement("i");return c.classList.add.apply(c.classList,b.split(" ")),c}}),h.defaults.iconlibs.bootstrap2=h.AbstractIconLib.extend({mapping:{collapse:"chevron-down",expand:"chevron-up","delete":"trash",edit:"pencil",add:"plus",cancel:"ban-circle",save:"ok",moveup:"arrow-up",movedown:"arrow-down",clear:"remove-circle",time:"time",calendar:"calendar"},icon_prefix:"icon-"}),h.defaults.iconlibs.bootstrap3=h.AbstractIconLib.extend({mapping:{collapse:"chevron-down",expand:"chevron-right","delete":"remove",edit:"pencil",add:"plus",cancel:"floppy-remove",save:"floppy-saved",moveup:"arrow-up",movedown:"arrow-down",clear:"remove-circle",time:"time",calendar:"calendar"},icon_prefix:"glyphicon glyphicon-"}),h.defaults.iconlibs.fontawesome3=h.AbstractIconLib.extend({mapping:{collapse:"chevron-down",expand:"chevron-right","delete":"remove",edit:"pencil",add:"plus",cancel:"ban-circle",save:"save",moveup:"arrow-up",movedown:"arrow-down",clear:"remove-circle",time:"time",calendar:"calendar"},icon_prefix:"icon-"}),h.defaults.iconlibs.fontawesome4=h.AbstractIconLib.extend({mapping:{collapse:"caret-square-o-down",expand:"caret-square-o-right","delete":"times",edit:"pencil",add:"plus",cancel:"ban",save:"save",moveup:"arrow-up",movedown:"arrow-down",copy:"files-o",clear:"times-circle-o",time:"clock-o",calendar:"calendar"},icon_prefix:"fa fa-"}),h.defaults.iconlibs.fontawesome5=h.AbstractIconLib.extend({mapping:{collapse:"caret-down",expand:"caret-right","delete":"times",edit:"pen",add:"plus",cancel:"ban",save:"save",moveup:"arrow-up",movedown:"arrow-down",copy:"copy",clear:"times-circle",time:"clock",calendar:"calendar"},icon_prefix:"fas fa-"}),h.defaults.iconlibs.foundation2=h.AbstractIconLib.extend({mapping:{collapse:"minus",expand:"plus","delete":"remove",edit:"edit",add:"add-doc",cancel:"error",save:"checkmark",moveup:"up-arrow",movedown:"down-arrow",clear:"remove",time:"clock",calendar:"calendar"},icon_prefix:"foundicon-"}),h.defaults.iconlibs.foundation3=h.AbstractIconLib.extend({mapping:{collapse:"minus",expand:"plus","delete":"x",edit:"pencil",add:"page-add",cancel:"x-circle",save:"save",moveup:"arrow-up",movedown:"arrow-down",clear:"x-circle",time:"clock",calendar:"calendar"},icon_prefix:"fi-"}),h.defaults.iconlibs.jqueryui=h.AbstractIconLib.extend({mapping:{collapse:"triangle-1-s",expand:"triangle-1-e","delete":"trash",edit:"pencil",add:"plusthick",cancel:"closethick",save:"disk",moveup:"arrowthick-1-n",movedown:"arrowthick-1-s",clear:"circle-close",time:"time",calendar:"calendar"},icon_prefix:"ui-icon ui-icon-"}),h.defaults.iconlibs.materialicons=h.AbstractIconLib.extend({mapping:{collapse:"arrow_drop_up",expand:"arrow_drop_down","delete":"delete",edit:"edit",add:"add",cancel:"cancel",save:"save",moveup:"arrow_upward",movedown:"arrow_downward",copy:"content_copy",clear:"highlight_off",time:"access_time",calendar:"calendar_today",upload:"cloud_upload"},icon_class:"material-icons",icon_prefix:"",getIconClass:function(a){return this.icon_class},getIcon:function(a){var b=this.mapping[a];if(!b)return null;var c=document.createElement("i");c.classList.add(this.icon_class);var d=document.createTextNode(b);return c.appendChild(d),c}}),h.defaults.templates["default"]=function(){return{compile:function(a){var b=a.match(/{{\s*([a-zA-Z0-9\-_ \.]+)\s*}}/g),c=b&&b.length;if(!c)return function(){return a};for(var d=[],e=function(a){var c,e=b[a].replace(/[{}]+/g,"").trim().split("."),f=e.length;if(f>1){var g;c=function(b){for(g=b,a=0;a<f&&(g=g[e[a]],g);a++);return g}}else e=e[0],c=function(a){return a[e]};d.push({s:b[a],r:c})},f=0;f<c;f++)e(f);return function(b){var e,g=a+"";for(f=0;f<c;f++)e=d[f],g=g.replace(e.s,e.r(b));return g}}}},h.defaults.templates.ejs=function(){return!!window.EJS&&{compile:function(a){var b=new window.EJS({text:a});return function(a){return b.render(a)}}}},h.defaults.templates.handlebars=function(){return window.Handlebars},h.defaults.templates.hogan=function(){return!!window.Hogan&&{compile:function(a){var b=window.Hogan.compile(a);return function(a){return b.render(a)}}}},h.defaults.templates.lodash=function(){return!!window._&&{compile:function(a){return function(b){return window._.template(a)(b)}}}},h.defaults.templates.markup=function(){return!(!window.Mark||!window.Mark.up)&&{compile:function(a){return function(b){return window.Mark.up(a,b)}}}},h.defaults.templates.mustache=function(){return!!window.Mustache&&{compile:function(a){return function(b){return window.Mustache.render(a,b)}}}},h.defaults.templates.swig=function(){return window.swig},h.defaults.templates.underscore=function(){ +return!!window._&&{compile:function(a){return function(b){return window._.template(a,b)}}}},h.defaults.theme="html",h.defaults.template="default",h.defaults.options={},h.defaults.options.prompt_before_delete=!0,h.defaults.options.upload=function(a,b,c){console.log("Upload handler required for upload editor")},h.defaults.translate=function(a,b){var c=h.defaults.languages[h.defaults.language];if(!c)throw"Unknown language "+h.defaults.language;var d=c[a]||h.defaults.languages[h.defaults.default_language][a];if("undefined"==typeof d)throw"Unknown translate string "+a;if(b)for(var e=0;e<b.length;e++)d=d.replace(new RegExp("\\{\\{"+e+"}}","g"),b[e]);return d},h.defaults.default_language="en",h.defaults.language=h.defaults.default_language,h.defaults.languages.en={error_notset:"Property must be set",error_notempty:"Value required",error_enum:"Value must be one of the enumerated values",error_anyOf:"Value must validate against at least one of the provided schemas",error_oneOf:"Value must validate against exactly one of the provided schemas. It currently validates against {{0}} of the schemas.",error_not:"Value must not validate against the provided schema",error_type_union:"Value must be one of the provided types",error_type:"Value must be of type {{0}}",error_disallow_union:"Value must not be one of the provided disallowed types",error_disallow:"Value must not be of type {{0}}",error_multipleOf:"Value must be a multiple of {{0}}",error_maximum_excl:"Value must be less than {{0}}",error_maximum_incl:"Value must be at most {{0}}",error_minimum_excl:"Value must be greater than {{0}}",error_minimum_incl:"Value must be at least {{0}}",error_maxLength:"Value must be at most {{0}} characters long",error_minLength:"Value must be at least {{0}} characters long",error_pattern:"Value must match the pattern {{0}}",error_additionalItems:"No additional items allowed in this array",error_maxItems:"Value must have at most {{0}} items",error_minItems:"Value must have at least {{0}} items",error_uniqueItems:"Array must have unique items",error_maxProperties:"Object must have at most {{0}} properties",error_minProperties:"Object must have at least {{0}} properties",error_required:"Object is missing the required property '{{0}}'",error_additional_properties:"No additional properties allowed, but property {{0}} is set",error_dependency:"Must have property {{0}}",error_date:"Date must be in the format {{0}}",error_time:"Time must be in the format {{0}}",error_datetime_local:"Datetime must be in the format {{0}}",error_invalid_epoch:"Date must be greater than 1 January 1970",button_delete_all:"All",button_delete_all_title:"Delete All",button_delete_last:"Last {{0}}",button_delete_last_title:"Delete Last {{0}}",button_add_row_title:"Add {{0}}",button_move_down_title:"Move down",button_move_up_title:"Move up",button_delete_row_title:"Delete {{0}}",button_delete_row_title_short:"Delete",button_collapse:"Collapse",button_expand:"Expand",flatpickr_toggle_button:"Toggle",flatpickr_clear_button:"Clear"},h.plugins={ace:{theme:""},SimpleMDE:{},sceditor:{},select2:{},selectize:{}},f(h.defaults.editors,function(a,b){h.defaults.editors[a].options=b.options||{}}),h.defaults.resolvers.unshift(function(a){if("string"!=typeof a.type)return"multiple"}),h.defaults.resolvers.unshift(function(a){if(!a.type&&a.properties)return"object"}),h.defaults.resolvers.unshift(function(a){if("string"==typeof a.type)return a.type}),h.defaults.resolvers.unshift(function(a){if("string"===a.type&&"signature"===a.format)return"signature"}),h.defaults.resolvers.unshift(function(a){if("integer"===a.type&&"rating"===a.format)return"rating"}),h.defaults.resolvers.unshift(function(a){if("boolean"===a.type)return"checkbox"===a.format||a.options&&a.options.checkbox?"checkbox":h.plugins.selectize.enable?"selectize":"select"}),h.defaults.resolvers.unshift(function(a){if("any"===a.type)return"multiple"}),h.defaults.resolvers.unshift(function(a){if("string"===a.type&&a.media&&"base64"===a.media.binaryEncoding)return"base64"}),h.defaults.resolvers.unshift(function(a){if("string"===a.type&&"url"===a.format&&a.options&&a.options.upload===!0&&window.FileReader)return"upload"}),h.defaults.resolvers.unshift(function(a){if("array"===a.type&&"table"===a.format)return"table"}),h.defaults.resolvers.unshift(function(a){if(a.enumSource)return h.plugins.selectize.enable?"selectize":"select"}),h.defaults.resolvers.unshift(function(a){if(a["enum"]){if("array"===a.type||"object"===a.type)return"enum";if("number"===a.type||"integer"===a.type||"string"===a.type)return h.plugins.selectize.enable?"selectize":"select"}}),h.defaults.resolvers.unshift(function(a){if("array"===a.type&&a.items&&!Array.isArray(a.items)&&a.uniqueItems&&["string","number","integer"].indexOf(a.items.type)>=0){if(a.items["enum"])return"multiselect";if(h.plugins.selectize.enable&&"string"===a.items.type)return"arraySelectize"}}),h.defaults.resolvers.unshift(function(a){if(a.oneOf||a.anyOf)return"multiple"}),h.defaults.resolvers.unshift(function(a){if(["string","integer"].indexOf(a.type)!==-1&&["date","time","datetime-local"].indexOf(a.format)!==-1)return"datetime"}),h.defaults.resolvers.unshift(function(a){if("string"===a.type&&"starrating"===a.format)return"starrating"}),function(){if(window.jQuery||window.Zepto){var a=window.jQuery||window.Zepto;a.jsoneditor=h.defaults,a.fn.jsoneditor=function(a){var b=this,c=this.data("jsoneditor");if("value"===a){if(!c)throw"Must initialize jsoneditor before getting/setting the value";if(!(arguments.length>1))return c.getValue();c.setValue(arguments[1])}else{if("validate"===a){if(!c)throw"Must initialize jsoneditor before validating";return arguments.length>1?c.validate(arguments[1]):c.validate()}"destroy"===a?c&&(c.destroy(),this.data("jsoneditor",null)):(c&&c.destroy(),c=new h(this.get(0),a),this.data("jsoneditor",c),c.on("change",function(){b.trigger("change")}),c.on("ready",function(){b.trigger("ready")}))}return this}}}(),h}); +//# sourceMappingURL=jsoneditor.min.js.map
\ No newline at end of file diff --git a/src/main/resources/META-INF/resources/designer/scripts/ToscaModelCtrl.js b/src/main/resources/META-INF/resources/designer/scripts/ToscaModelCtrl.js index 129c5d98..1901d95e 100644 --- a/src/main/resources/META-INF/resources/designer/scripts/ToscaModelCtrl.js +++ b/src/main/resources/META-INF/resources/designer/scripts/ToscaModelCtrl.js @@ -36,11 +36,11 @@ app.controller('ToscaModelCtrl', } var editorData = getMsProperty(selectedPolicy); - JSONEditor.defaults.options.theme = 'bootstrap3'; - JSONEditor.defaults.options.iconlib = 'bootstrap2'; + JSONEditor.defaults.options.theme = 'bootstrap4'; + //JSONEditor.defaults.options.iconlib = 'bootstrap2'; JSONEditor.defaults.options.object_layout = 'grid'; JSONEditor.defaults.options.disable_properties = true; - JSONEditor.defaults.options.disable_edit_json = true; + JSONEditor.defaults.options.disable_edit_json = false; JSONEditor.defaults.options.disable_array_reorder = true; JSONEditor.defaults.options.disable_array_delete_last_row = true; JSONEditor.defaults.options.disable_array_delete_all_rows = false; |