!function(y, X, R) { "use strict"; var E = "ht" , L = E + ".widget." , p = y[E] , Q = p.Color , i = p.widget , l = Q.widgetBorder , G = Q.widgetBackground , M = Q.widgetIconBorder , w = Q.transparent , f = Q.background , P = Q.highlight , $ = p.Default , q = $.def , B = $.widgetRowHeight , o = $.removeHTML , e = $.drawText , s = $.getTextSize , J = $.isLeftButton , j = $.getWindowInfo , V = $.getImage , S = $.drawCenterImage , C = $.preventDefault , Y = $.getLogicalPoint , Z = $.labelFont , W = $.labelColor , r = $.labelSelectColor , T = $.widgetIndent , g = $.startDragging , d = $.createElement , v = $.getClientPoint , N = $.scrollBarInteractiveSize , k = $.getInternal() , u = (k.createView, k.createDiv) , h = k.createCanvas , c = k.createImage , F = k.setCanvas , A = k.initContext , z = k.translateAndScale , O = k.isString , m = k.drawBorder , I = k.getImageWidth , U = k.getImageHeight , t = k.fillRect , x = k.layout , H = k.formatNumber , _ = k.addMethod , n = k.isH , b = $.isTouchable , K = Math.round , D = "readonly" , a = b ? "touchstart" : "mousedown" , oe = { x: 0, y: 0, width: 0, height: 0 } , vg = function(c) { var $ = c.touches[0]; return $ ? $ : c.changedTouches[0] } , ap = function(m, G) { return m.querySelector(G) } , jj = function(H, x) { var y = $.getLogicalPoint(x, H._canvas || H._view); return y.x >= 0 && y.y >= 0 && y.x <= H.getWidth() && y.y <= H.getHeight() }; _($, { textFieldFont: Z, textFieldColor: W, textFieldBorderColor: l, textAreaFont: Z, textAreaColor: W, textAreaBorderColor: l, radioButtonLabelFont: Z, radioButtonLabelColor: W, radioButtonPressBackground: l, checkBoxLabelFont: Z, checkBoxLabelColor: W, checkBoxPressBackground: l, buttonLabelFont: Z, buttonLabelColor: W, buttonLabelSelectColor: r, buttonBackground: G, buttonBorderColor: l, buttonSelectBackground: P, sliderBackground: Q.widgetIconBackground, sliderLeftBackground: Q.widgetIconHighlight, sliderThickness: 3, sliderPadding: 4, sliderButton: c(14, 14, { type: "circle", rect: [0, 0, 14, 14], borderWidth: 1, borderColor: M, gradient: "linear.northeast", gradientColor: Q.widgetIconGradient, background: G }), comboBoxMaxHeight: -1, comboBoxLabelFont: Z, comboBoxLabelColor: W, comboBoxLabelSelectColor: r, comboBoxShadowColor: w, comboBoxBorderColor: l, comboBoxBackground: f, comboBoxSelectBackground: P, comboBoxDropDownIcon: c(12, 16, { type: "shape", points: [1, 5, 6, 11, 11, 5], borderWidth: 2, borderColor: M }), imageBorderColor: R, imageBackground: R, formPaneLabelColor: W, formPaneLabelFont: Z, formPaneLabelAlign: "left", formPaneLabelVAlign: "middle", formPaneHPadding: 8, formPaneVPadding: 8, formPaneLabelHPadding: 2, formPaneLabelVPadding: 0, formPaneHGap: 6, formPaneVGap: 6 }, !0); var rk = function(W, J) { var U = this; (U._view = k.createView(null, U)).appendChild(U._element = d(W, J)), U.setHeight(B), U.setWidth(80), U.iv() }; q(rk, X, { ms_v: 1, ms_fire: 1, ms_tip: 1, ms_ac: ["toolTip"], onPropertyChanged: function() { this.iv() }, getToolTip: function() { return this._toolTip || this.getText() }, getElement: function() { return this._element }, getText: function() { return this._element.value }, setText: function(l) { this._element.value = l }, getValue: function() { return this.getText() }, setValue: function(S) { this.setText(S) }, getColor: function() { return this._element.style.color }, setColor: function(g) { this._element.style.color = g }, getBackground: function() { return this._element.style.background }, setBackground: function(g) { this._element.style.background = g }, getBorder: function() { return this._element.style.border }, setBorder: function(o) { this._element.style.border = o }, getFont: function() { return this._element.style.font }, setFont: function(A) { this._element.style.font = A }, isEditable: function() { return this._element.hasAttribute(D) }, setEditable: function(l) { var g = this._element; l ? g.removeAttribute(D) : g.setAttribute(D, !0) }, validateImpl: function() { var y = this; x(y._element, 0, 0, y.getWidth(), y.getHeight()) }, setFocus: function() { return $.setFocus(this._element), this.fireViewEvent("focus"), !0 } }), i.TextField = function() { i.TextField.superClass.constructor.call(this, "input", $.textFieldBorderColor), this.setColor($.textFieldLabelColor), this.setFont($.textFieldLabelFont) } , q(L + "TextField", rk, { getType: function() { return this._element.getAttribute("type") }, setType: function(x) { var U = this._element , J = $.numberListener; U.setAttribute("type", x), U.removeEventListener("keydown", J, !1), "number" === x && U.addEventListener("keydown", J, !1) } }), i.TextArea = function() { i.TextArea.superClass.constructor.call(this, "textarea", $.textAreaBorderColor), this.setColor($.textAreaLabelColor), this.setFont($.textAreaLabelFont) } , q(L + "TextArea", rk, {}), i.Button = function() { var F = this , A = F._view = k.createView(null, F); F.setHeight(B), F.setWidth(80), F._canvas = h(A), new Iq(F), F.iv() } , q(L + "Button", X, { ms_v: 1, ms_fire: 1, ms_tip: 1, ms_ac: ["groupId", "label", "icon", "iconColor", "orientation", "toolTip", "labelFont", "labelColor", "labelSelectColor", "borderColor", "background", "selectBackground", "togglable", "selected", "pressed", "clickable"], _clickable: !0, _togglable: !1, _selected: !1, _pressed: !1, _orientation: "h", _labelFont: $.buttonLabelFont, _labelColor: $.buttonLabelColor, _labelSelectColor: $.buttonLabelSelectColor, _borderColor: $.buttonBorderColor, _background: $.buttonBackground, _selectBackground: $.buttonSelectBackground, onClicked: function() {}, onSelectedChanged: function() {}, onValueChanged: function() {}, onPropertyChanged: function(h) { var X = this , L = X._view.parentNode; X.iv(), "selected" === h.property && (null != X.getGroupId() && L && L.handleGroupSelectedChanged && L.handleGroupSelectedChanged(X), X.onSelectedChanged(), X.onValueChanged(h.oldValue, h.newValue)) }, getToolTip: function() { return this._toolTip || this._label }, validateImpl: function() { var o = this , K = o._canvas , l = o.getWidth() , b = o.getHeight() , c = o._pressed || o._selected , h = c ? o._selectBackground : o._background; F(K, l, b); var v = A(K); z(v, 0, 0, 1), v.clearRect(0, 0, l, b), h && t(v, 0, 0, l, b, h), m(v, o._borderColor, 0, 0, l, b); var R = o._iconColor , i = V(o._icon, R) , T = I(i) , O = U(i) , q = o._label , E = o.getLabelFont() , W = c ? o._labelSelectColor : o._labelColor , M = null == q ? oe : s(E, q) , g = M.width , u = M.height; n(o) ? (T && S(v, i, l / 2 - (T + g) / 2 + T / 2, b / 2, o, o, R), g && e(v, q, E, W, l / 2 - (T + g) / 2 + T, 0, g, b, "center")) : (T && S(v, i, l / 2, b / 2 - (O + u) / 2 + O / 2, o, o, R), g && e(v, q, E, W, l / 2 - g / 2, b / 2 - (O + u) / 2 + O, g, u, "center")), v.restore() } }); var Iq = function(X) { this.button = X, this.addListeners() }; q(Iq, X, { ms_listener: 1, getView: function() { return this.button._view }, handle_mousedown: function(w) { J(w) && this.handle_touchstart(w) }, handleWindowMouseMove: function(s) { this.handleWindowTouchMove(s) }, handleWindowMouseUp: function(d) { this.handleWindowTouchEnd(d) }, handle_touchstart: function(o) { C(o), this.button.isClickable() && (g(this, o), this.button.setPressed(!0)) }, handleWindowTouchMove: function() {}, handleWindowTouchEnd: function(E) { var p = this , Z = p.button; Z.setPressed(!1), jj(Z, E) && (Z.isTogglable() && (null != Z.getGroupId() ? Z.setSelected(!0) : Z.setSelected(!Z.isSelected())), Z.onClicked(E)) } }); var up = function() { var K = this , s = K._view = k.createView(null, K); K.setHeight(B), K.setWidth(80), K._canvas = h(s), new Oj(K), K.iv() }; q(up, X, { ms_v: 1, ms_fire: 1, ms_tip: 1, ms_ac: ["label", "labelFont", "labelColor", "toolTip", "icon", "iconColor", "selected", "pressed", "pressBackground", "padding"], _padding: 0, _selected: !1, _pressed: !1, onClicked: function() {}, onSelectedChanged: function() {}, onValueChanged: function() {}, getValue: function() { return this.isSelected() }, setValue: function(H) { this.setSelected(H) }, onPropertyChanged: function(e) { var V = this; V.iv(), "selected" === e.property && (V.onSelectedChanged(), V.onValueChanged(e.oldvalue, e.newValue)) }, getToolTip: function() { return this._toolTip || this._label }, validateImpl: function() { var x = this , K = x._canvas , Q = x.getWidth() , B = x.getHeight() , k = x.getCheckIcon; F(K, Q, B); var Z = A(K); z(Z, 0, 0, 1), Z.clearRect(0, 0, Q, B); var s = x._padding , b = x._iconColor , $ = V(k ? x.getCheckIcon() : x.getRadioIcon()) , X = I($) , v = U($); x._pressed && (Z.fillStyle = x._pressBackground, Z.beginPath(), k ? Z.rect(s, B / 2 - v / 2, X, v) : Z.arc(s + X / 2, B / 2, Math.min(X, v) / 2, 0, 2 * Math.PI, !0), Z.fill()), S(Z, $, s + X / 2, B / 2, x, x), s += X + 1, $ = V(x.getIcon(), b), X = I($), S(Z, $, s + X / 2, B / 2, x, x, b), s += X, e(Z, x._label, x._labelFont, x._labelColor, s, 0, 0, B), Z.restore() } }); var Oj = function(h) { this.c = h, this.addListeners() }; q(Oj, X, { ms_listener: 1, getView: function() { return this.c._view }, handle_mousedown: function(q) { J(q) && this.handle_touchstart(q) }, handleWindowMouseMove: function(Q) { this.handleWindowTouchMove(Q) }, handleWindowMouseUp: function(a) { this.handleWindowTouchEnd(a) }, handle_touchstart: function(M) { C(M), g(this, M), this.c.setPressed(!0) }, handleWindowTouchMove: function() {}, handleWindowTouchEnd: function(C) { var u = this , K = u.c; K.setPressed(!1), jj(K, C) && (K.handleClick(C), K.onClicked(C)) } }), i.CheckBox = function() { i.CheckBox.superClass.constructor.call(this) } , q(L + "CheckBox", up, { _labelFont: $.checkBoxLabelFont, _labelColor: $.checkBoxLabelColor, _pressBackground: $.checkBoxPressBackground, getCheckIcon: function() { return this._selected ? "check" : "uncheck" }, handleClick: function() { this.setSelected(!this.isSelected()) } }), i.RadioButton = function() { i.RadioButton.superClass.constructor.call(this) } , q(L + "RadioButton", up, { ms_ac: ["groupId"], _pressBackground: $.radioButtonPressBackground, _labelFont: $.radioButtonLabelFont, _labelColor: $.radioButtonLabelColor, getRadioIcon: function() { return this._selected ? "radioOn" : "radioOff" }, onPropertyChanged: function(s) { var H = this , V = H._view.parentNode; H.iv(), null != H.getGroupId() && "selected" === s.property && (V && V.handleGroupSelectedChanged && V.handleGroupSelectedChanged(H), H.onSelectedChanged(), H.onValueChanged(s.oldValue, s.newValue)) }, handleClick: function() { this.setSelected(!0) } }), i.Slider = function() { var g = this , c = g._view = k.createView(null, g); g.setHeight(B), g.setWidth(80), g._canvas = h(c), new Mk(g), g.iv(), g.enableToolTip() } , q(L + "Slider", X, { ms_v: 1, ms_fire: 1, ms_tip: 1, ms_ac: ["value", "min", "max", "step", "button", "toolTip", "instant", "thickness", "padding", "background", "leftBackground"], _min: 0, _max: 100, _value: 50, _step: R, _instant: !0, _button: $.sliderButton, _thickness: $.sliderThickness, _padding: $.sliderPadding, _background: $.sliderBackground, _leftBackground: $.sliderLeftBackground, onPropertyChanged: function(M) { var z = this , n = M.property; ("min" === n || "max" === n || "step" === n) && z.setValue(z._value), z.iv() }, adjustValue: function(M) { null == M && (M = 0); var X = this , J = X._min , e = X._max , V = X._step; return J > M && (M = J), M > e && (M = e), V > 0 && (M = Math.floor((M - J) / V) * V + J), M }, getToolTip: function() { return this._toolTip || H(this._value) }, getValue: function() { return this._value }, setValue: function(s) { var T = this , H = T._value; s = T.adjustValue(s), H !== s && (T._value = s, T.fp("value", H, s), T.onValueChanged(H, s)) }, onValueChanged: function() {}, onEndValueChanged: function() {}, drawBackground: function(p, C, v, U, W) { t(p, C, v, U, W, this.getBackground()) }, drawLeftBackground: function(T, h, m, n, H) { var S = this.getLeftBackground(); S && t(T, h, m, n, H, S) }, drawButton: function(N, c, E, z, I) { S(N, V(this._button), c + z / 2, E + I / 2, this, this) }, getButtonWidth: function() { var s = V(this._button); return s ? s.width : 0 }, validateImpl: function() { var X = this , P = X._canvas , d = X._min , L = X._max , K = X._value , W = X._padding , o = X._thickness , q = X.getWidth() , Z = X.getHeight() , x = X.getButtonWidth() , v = (Z - o) / 2 , h = x / 2 + (K - d) / (L - d) * (q - 2 * W - x); F(P, q, Z); var J = A(P); z(J, 0, 0, 1), J.clearRect(0, 0, q, Z), X.drawBackground(J, W, v, q - 2 * W, o), X.drawLeftBackground(J, W, v, h, o), X.drawButton(J, W + h - x / 2, 0, x, Z), J.restore() } }); var Mk = function(f) { this.slider = f, this.addListeners() }; q(Mk, X, { ms_listener: 1, getView: function() { return this.slider._view }, handle_mousedown: function(K) { J(K) && this.handle_touchstart(K) }, handleWindowMouseMove: function(B) { this.handleWindowTouchMove(B) }, handleWindowMouseUp: function(E) { this.handleWindowTouchEnd(E) }, setValue: function(c) { var C = this.slider , p = C.getPadding() + C.getButtonWidth() / 2 , A = C.getMin(); C.setValue(A + (Y(c, C._canvas).x - p) / (C.getWidth() - 2 * p) * (C.getMax() - A)) }, handle_touchstart: function(P) { var L = this; C(P), L.setValue(P), g(L, P), $.showToolTip(P, L.slider.getToolTip(P)) }, handleWindowTouchMove: function(w) { this.setValue(w), $.showToolTip(w, this.slider.getToolTip(w)) }, handleWindowTouchEnd: function(q) { this.setValue(q), this.slider.onEndValueChanged(), $.hideToolTip() } }), i.ComboBox = function() { var Y = this , _ = Y._view = k.createView(null, Y) , N = Y._listView = new i.ListView , e = Y._canvas = h(_) , t = N._view , c = N.sm(); Y.setHeight(B), Y.setWidth(80), c.setSelectionMode("single"), N.drawRow = function(L, C, c, p, i, V, n) { Y.drawRow(L, C, c, p, i, V, n) } , _.style.display = "inline-block", k.setBorder(_, $.comboBoxBorderColor), t.style.boxShadow = "0px 0px 10px " + $.comboBoxShadowColor, null != $.baseZIndex && (t.style.zIndex = parseInt($.baseZIndex) + 1 + ""), t.addEventListener("mousemove", function(C) { c.ss(N.getDataAt(C)) }, !1), t.addEventListener("keydown", function(r) { if (k.isEnter(r)) { var H = c.ld(); H && (Y.setValue(H.value), Y.close()) } k.isEsc(r) && Y.close() }, !1), _.addEventListener("keydown", function(U) { (k.isDown(U) || k.isUp(U)) && Y.open() }, !1), N.onDataClicked = function(C) { Y.setValue(C.value), Y.close() } , _.addEventListener(a, function(w) { if (J(w)) { var O = w.target; (O === e || O === _) && (C(w), Y.toggle()) } }, !1), Y._handleWindowClick = function(R) { if (J(R)) { var X = R.target; X === Y._input || t.contains(X) || X === _ || Y.close() } } , Y.iv() } , $.def(L + "ComboBox", X, { ms_v: 1, ms_fire: 1, ms_tip: 1, ms_ac: ["dropDownIcon", "dropDownWidth", "toolTip", "strict", "indent", "background", "labelFont", "labelColor", "labelSelectColor", "maxHeight", "selectBackground", "value", "values", "labels", "icons", "editable"], _strict: !0, _editable: !1, _maxHeight: $.comboBoxMaxHeight, _labelFont: $.comboBoxLabelFont, _labelColor: $.comboBoxLabelColor, _labelSelectColor: $.comboBoxLabelSelectColor, _background: $.comboBoxBackground, _dropDownWidth: R, _dropDownIcon: $.comboBoxDropDownIcon, _selectBackground: $.comboBoxSelectBackground, _indent: T, getListView: function() { return this._listView }, onPropertyChanged: function(G) { this.iv(), "value" === G.property && this.onValueChanged(G.oldValue, G.newValue) }, onValueChanged: function() {}, getToolTip: function() { return this._toolTip || this.toLabel(this._value) }, getLabelColor: function(U, i) { return i ? this._labelSelectColor : this._labelColor }, isEqual: function(V, s) { return this._strict ? V === s : V == s }, toLabel: function(v) { var t = this , U = t._values , k = t._labels; if (k && U && k.length === U.length) for (var $ = 0; $ < U.length; $++) if (t.isEqual(U[$], v)) return k[$]; return null == v ? "" : v + "" }, toIcon: function(Q) { var S = this , v = S._values , W = S._icons; if (W && v && W.length === v.length) for (var Y = 0; Y < v.length; Y++) if (S.isEqual(v[Y], Q)) return W[Y]; return null }, drawValue: function(D, p, $, T, M, K, j) { var d = this , z = d._indent , r = d.toLabel(p) , P = V(d.toIcon(p)); P && (S(D, P, T + z / 2, M + j / 2), T += z), r && e(D, r, d.getLabelFont(p, $), d.getLabelColor(p, $), T, M, 0, j) }, drawRow: function(e, J, H, v, W, V, O) { var X = this , y = J.value , Z = X._indent; H && t(e, v, W, V, O, X._selectBackground), X.drawValue(e, y, H, v, W, V - Z, O) }, validateImpl: function() { var c = this , _ = c._canvas , m = c._indent , M = c.getWidth() , o = c.getHeight() , G = M - m , d = c._background || "" , ld = c._dropDownBackground || d; c._view.style.background = d, c._listView._view.style.background = ld, F(_, M, o); var X = A(_); z(X, 0, 0, 1), X.clearRect(0, 0, M, o), S(X, V(c._dropDownIcon), G + m / 2, o / 2, c, c), X.beginPath(), X.rect(0, 0, G, o), X.clip(), c.drawValue(X, c._value, !1, 0, 0, G, o), X.restore() }, isOpened: function() { return !!this._listView._view.parentNode }, open: function() { var G = this , S = G._listView , Q = S.dm() , h = G._values || [] , r = h.length; if (!G.isOpened()) { Q.clear(); for (var A = 0; r > A; A++) { var u = new p.Data , R = h[A]; u.setName(G.toLabel(R)), u.value = R, Q.add(u), G.isEqual(R, G._value) && Q.sm().ss(u) } var o = j() , W = o.left , V = o.top , n = o.height , F = G._view.getBoundingClientRect() , J = F.left + W , g = F.top + V , m = F.height , f = G.getIndent() , K = G.getWidth() , w = G.getHeight() , E = J + 1 , s = g + m , M = G.getDropDownWidth() || K , e = r * w; if (G._maxHeight > 0 && (e = Math.min(e, G._maxHeight)), S.setRowHeight(w), s + e > V + n && (g - V > V + n - g - m ? (e = Math.min(e, g - V), s = g - e) : e = V + n - s), G._editable) { var L = G._input = $.createElement("input", G.getSelectBackground(), G.getLabelFont(), G.toLabel(G._value)); document.body.appendChild(L), x(L, J, g + 1, K - f, w), L.addEventListener("keydown", function(W) { k.isEnter(W) ? G.setInputValue(L) : k.isEsc(W) && G.close() }, !1), G.onInputCreated(L) } document.body.appendChild(S.getView()), x(S, E, s, M, e), S.setFocus(), p.Default.callLater(function() { y.addEventListener(a, G._handleWindowClick, !1) }), G.onOpened && G.onOpened(), k.closePopup(G) } }, onInputCreated: function() {}, setInputValue: function(M) { var c = this , p = c._labels , u = c._values , j = M.value; if (p) for (var P = 0; P < p.length; P++) j === p[P] && (j = u[P]); "string" == typeof j && u && u.length && "number" == typeof u[0] && (j = parseFloat(j)), c.setValue(j), c.close() }, close: function() { var w = this; w.isOpened() && (o(w._listView._view), w._input && (o(w._input), delete w._input), y.removeEventListener(a, w._handleWindowClick, !1), w.onClosed && w.onClosed(), $.popup === w && delete $.popup), w.setFocus() }, toggle: function() { var H = this; H.isOpened() ? H.close() : H.open() } }), i.BaseDropDownTemplate = function(L) { this._master = L } , $.def(L + "BaseDropDownTemplate", X, { ms_ac: ["master"], getView: function() {}, onOpened: function() {}, onClosed: function() {}, getValue: function() {}, getWidth: function() {}, getHeight: function() {} }), i.MultiComboBox = function() { var f = this , l = f._view = k.createView(null, f) , N = f._canvas = h(l); f.setHeight(B), f.setWidth(80), l.style.display = "inline-block", k.setBorder(l, $.comboBoxBorderColor), l.addEventListener("keydown", function(w) { (k.isDown(w) || k.isUp(w)) && f.open() }, !1), l.addEventListener(a, function(u) { if (J(u)) { var o = u.target; (o === N || o === l) && (C(u), f.toggle()) } }, !1), f._handleWindowClick = function(H) { if (J(H)) { var I = H.target , G = f._dropDownComponentInstanceView; I === f._input || I === l || G && G.contains(I) || f.close() } } , f.iv() } , $.def(L + "MultiComboBox", X, { ms_v: 1, ms_fire: 1, ms_tip: 1, ms_ac: ["dropDownIcon", "toolTip", "background", "labelFont", "labelColor", "value", "editable", "indent", "dropDownComponent"], _editable: !1, _background: $.comboBoxBackground, _dropDownIcon: $.comboBoxDropDownIcon, _indent: T, _labelFont: $.comboBoxLabelFont, _labelColor: $.comboBoxLabelColor, onPropertyChanged: function(E) { var p = this; p.iv(), "value" === E.property && p.onValueChanged(E.oldValue, E.newValue) }, onValueChanged: function() {}, getDropDownComponentInstance: function() { return this._dropDownComponentInstance }, getToolTip: function() { return this._toolTip }, validateImpl: function() { var u = this , c = u._canvas , t = u._indent , g = u.getWidth() , E = u.getHeight() , Q = g - t , G = u._background || ""; u._view.style.background = G, F(c, g, E); var v = A(c); z(v, 0, 0, 1), v.clearRect(0, 0, g, E), S(v, V(u._dropDownIcon), Q + t / 2, E / 2, u, u), v.beginPath(), v.rect(0, 0, Q, E), v.clip(), this.drawValue(v, 0, 0, Q, E), u._input && u._input.value !== u._value && (u._input.value = null == u._value ? "" : u._value), v.restore() }, drawValue: function(J, i, I, M, m) { e(J, this._value, this.getLabelFont(), this.getLabelColor(), i + 1, I, 0, m) }, isOpened: function() { var w = this , j = w._dropDownComponentInstanceView; return !!j }, open: function() { var _ = this; if (!_.isOpened()) { var N = $.getClass(_._dropDownComponent) , u = _._dropDownComponentInstance = new N(_) , M = _._dropDownComponentInstanceView = u.getView() , F = j() , d = F.left , n = F.top , T = F.width , G = F.height , W = _._view.getBoundingClientRect() , m = W.left + d , O = W.top + n , i = (W.width, W.height) , g = _.getIndent() , Q = _.getWidth() , o = _.getHeight() , R = m , s = O + i , D = u.getWidth() || Q , v = u.getHeight(); if (s + v > n + G && O - n > n + G - O - i && (s = O - v), R + D > d + T && (R -= R + D - d - T), _._editable) { var b = _._input = $.createElement("input", $.comboBoxSelectBackground, _.getLabelFont(), _._value); document.body.appendChild(b), x(b, m, O + 1, Q - g, o), b.addEventListener("keydown", function(E) { k.isEnter(E) ? (_.setValue(b.value), _.close(!0)) : k.isEsc(E) && _.close(!0) }, !1), _.onInputCreated(b) } M.style.boxShadow = "0px 0px 10px " + $.toolTipShadowColor, M.style.position = "absolute", null != $.baseZIndex && (M.style.zIndex = parseInt($.baseZIndex) + 1 + ""), document.body.appendChild(M), M.focus(), x(u, R, s, D, v), u.onOpened && u.onOpened(_._value), y.addEventListener(a, _._handleWindowClick, !1), _.onOpened && _.onOpened(), k.closePopup(_) } }, onInputCreated: function() {}, close: function(I) { var v = this; if (v.isOpened()) { I || v.setValue(v._dropDownComponentInstance.getValue()); var L = v._dropDownComponentInstance , e = v._dropDownComponentInstanceView; L.onClosed && L.onClosed(), o(e), delete v._dropDownComponentInstanceView, delete v._dropDownComponentInstance, v._input && (o(v._input), delete v._input), y.removeEventListener(a, v._handleWindowClick, !1), v.onClosed && v.onClosed(), $.popup === v && delete $.popup } v.setFocus() }, toggle: function() { var J = this; J.isOpened() ? J.close() : J.open() } }), i.Image = function() { var w = this , c = w._view = k.createView(null, w); c.onmousedown = C, w.setHeight(B), w.setWidth(80), w._canvas = h(c), new bp(w), w.iv() } , q(L + "Image", X, { ms_v: 1, ms_fire: 1, ms_tip: 1, ms_ac: ["icon", "iconColor", "stretch", "toolTip", "borderColor", "background"], _borderColor: $.imageBorderColor, _background: $.imageBackground, _stretch: "centerUniform", onClicked: function() {}, onPropertyChanged: function() { this.iv() }, validateImpl: function() { var a = this , I = a._canvas , X = a.getWidth() , D = a.getHeight() , R = a._iconColor , u = V(a._icon, R) , J = a._background; F(I, X, D); var W = A(I); z(W, 0, 0, 1), W.clearRect(0, 0, X, D), J && t(W, 0, 0, X, D, J), this.drawImage(W, u, 0, 0, X, D, R), m(W, a._borderColor, 0, 0, X, D), W.restore() }, drawImage: function(U, A, z, B, Z, R, m) { A && $.drawStretchImage(U, A, this._stretch, z, B, Z, R, null, this, m) } }); var bp = function(I) { this.image = I, this.addListeners() }; q(bp, X, { ms_listener: 1, getView: function() { return this.image._view }, handle_mousedown: function(l) { J(l) && this.handle_touchstart(l) }, handleWindowMouseMove: function(G) { this.handleWindowTouchMove(G) }, handleWindowMouseUp: function(s) { this.handleWindowTouchEnd(s) }, handle_touchstart: function(f) { C(f), g(this, f) }, handleWindowTouchMove: function() {}, handleWindowTouchEnd: function(p) { var N = this , Y = N.image; jj(Y, p) && Y.onClicked(p) } }); var Sn = "" , Up = "" , Pf = "" , Qp = "" , $q = ""; i.ColorPicker = function() { var v = this; i.ColorPicker.superClass.constructor.call(v), v.setEditable(!0), v.setDropDownComponent(i.ColorPickerTemp) } , q(L + "ColorPicker", i.MultiComboBox, { ms_ac: ["instant", "clearButtonVisible"], _clearButtonVisible: !0, setValue: function(M) { var m = this; if (M !== R) { var v = m._value; m._value = M, m.fp("value", v, M) } }, drawValue: function($, r, S, K, W) { this._value && ($.beginPath(), $.rect(r + 2, S + 2, 20, W - 4), $.fillStyle = this._value, $.fill()), e($, this._value, this.getLabelFont(), this.getLabelColor(), r + 23, S, 0, W) } }), i.ColorPickerTemp = function(J) { var y = this , _ = "px" , x = y._view = k.createView(null, y) , P = y.$10o = document.createElement("div") , t = y.$11o = u() , a = y.$12o = u() , z = P.style; y._h = 360, y._s = 100, y._v = 100, x.className = "colorPickerPopup", x.style.position = "absolute", x.style.background = "white", i.ColorPickerTemp.superClass.constructor.call(y, J); var g = '