class CCPInputWidgetEditorController extends HTMLElement{ #input = null #index = null #type = null #delete_icon = ` ` constructor(){ super(); } connectedCallback(){ } get index(){ return this.#index } render(input, i){ this.#index = i this.#input = input this.#type = input.schema.enum ? "enum" : "string" this.innerHTML = ` ${this.#delete_icon} Type String Enum Min Max Format None Date Time Date time Code Secret Mime Comma separated list of options ` this.addEventListener("input", ev=>{ const val = ev.target.value const ename = ev.target.getAttribute("name") if(ename === "id"){ this.#input.id = val } else if(ename === "title"){ this.#input.title = val } else if(ename === "description"){ this.#input.description = val } else if(ename === "minOccurs"){ this.#input.minOccurs = val } else if(ename === "maxOccurs"){ this.#input.maxOccurs = val } else if(ename === "format"){ this.#input.schema.format = val if(this.#input.schema.format === "secret"){ this.querySelector("div[name=input-default] input[name=default]").type = "password" } } else if(ename === "contentMediaType"){ this.#input.schema.contentMediaType = val } else if(ename === "options"){ this.#input.schema.enum = val.split(",") } else if(ename === "default"){ this.#input.schema.default = val } else if(ename === "type"){ this.#type = ev.target.value if(this.#type === "enum"){ this.querySelector("div[name=string-input]").classList.add("d-none") this.querySelector("div[name=enum-input]").classList.remove("d-none") this.#input.schema.enum = this.querySelector("input[name=options]").value.split(",") }else if(this.#type === "string"){ this.querySelector("div[name=enum-input]").classList.add("d-none") this.querySelector("div[name=string-input]").classList.remove("d-none") delete this.#input.schema['enum'] } } }) } } window.customElements.define('d4s-ccp-input-editor', CCPInputWidgetEditorController);