12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796 |
- !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 = '<div style="border: 1px solid rgba(0, 0, 0, 0); position: absolute; width: 40px; height: 20px; top: 5px; left: 5px; bottom: 5px; background: url(' + Qp + ') repeat;"></div> <div class= "preview" style="border: 1px solid black; position: absolute; width: 40px; height: 20px; top: 5px; left: 5px; bottom: 5px;"></div> <div style="margin-left: 50px; font: ' + $.labelFont + '; line-height: 30px;" > R:<input class="color_R" style="width: 28px;" type="' + (b ? "number" : "text") + '"> G:<input class="color_G" style="width: 28px" type="' + (b ? "number" : "text") + '"> B:<input class="color_B" style="width: 28px" type="' + (b ? "number" : "text") + '"> A:<input class="color_A" style="width: 28px" value="1" type="' + (b ? "number" : "text") + '"> </div>'
- , s = '<div> <div class="satval" style="position: absolute;cursor:crosshair;margin-left:5px;top: 6px;border:1px solid black;width:128px;height:128px;background-image: url(' + Sn + ');background-color: red;background-size:contain;"> <div class="satval_pointer" style="position:absolute;left: 124px; top: -3px;width: 7px; height: 7px;background-image: url(' + $q + ')"></div> </div> <div class="hue_picker" style="position:absolute;width: 46px; height: 140px;left: 152px;top:0;"> <div class="hue_image" style="border: 1px solid black;position:absolute;left:7px;top:6px;width:30px; height:128px; background: url(' + Up + ');background-size:contain;"></div> <div class="hue_pointer" style="position:absolute;top:1px;left:0;width:46px; height:12px; background: url(' + Pf + ')"></div> </div> <div style="position: absolute; left: 210px;top:6px;"> <input type="button" value="✓" class="color_ok"><br><br> <input type="button" value="✕" class="color_clear"> </div> </div>';
- z.font = $.labelFont,
- z.height = 30 + _,
- z.lineHeight = 30 + _,
- z.position = "relative",
- z.whiteSpace = "nowrap",
- P.innerHTML = g,
- a.innerHTML = s,
- x.appendChild(P),
- x.appendChild(a),
- x.addEventListener("click", function(Z) {
- var x = Z.target
- , z = x.className;
- "color_ok" === z ? (y.$13o = y.$9o(),
- J.close()) : "color_clear" === z ? (y.$13o = null,
- J.close()) : ["color_R", "color_G", "color_B", "color_A"].indexOf(z) >= 0 && x.select()
- });
- var v = function(p) {
- var X, c = p.target, z = c.className, b = !1;
- ["color_R", "color_G", "color_B"].indexOf(z) >= 0 ? (X = parseInt(c.value),
- c.value = X >= 0 && 255 >= X ? parseInt(c.value) : 0,
- b = !0) : "color_A" === z && (X = parseFloat(c.value),
- c.value = X >= 0 && 1 >= X ? parseFloat(c.value) : 0,
- b = !0),
- b && (t.style.backgroundColor = y.$9o())
- };
- x.addEventListener("keydown", function(F) {
- var O = F.target
- , n = O.className;
- ["color_R", "color_G", "color_B", "color_A", "color_ok", "color_clear"].indexOf(n) >= 0 && 13 == F.keyCode && (v(F),
- y.$13o = y.$9o(),
- J.close())
- }),
- new ml(y),
- x.addEventListener("change", v);
- var q = ap(x, ".color_clear");
- J._clearButtonVisible || (q.style.display = "none"),
- p.Default.onElementCreated && (p.Default.onElementCreated(x.querySelector("input.color_R")),
- p.Default.onElementCreated(x.querySelector("input.color_G")),
- p.Default.onElementCreated(x.querySelector("input.color_B")),
- p.Default.onElementCreated(x.querySelector("input.color_A")),
- p.Default.onElementCreated(x.querySelector(".color_ok")),
- p.Default.onElementCreated(x.querySelector(".color_clear")))
- }
- ,
- q(i.ColorPickerTemp, i.BaseDropDownTemplate, {
- $6o: function() {
- var R = this
- , D = R._view
- , t = R._master
- , M = R._h
- , N = R._s
- , n = R._v
- , p = R.$2o(M / 360, N / 100, n / 100)
- , T = p.r
- , g = p.g
- , W = p.b;
- D.querySelector("input.color_R").value = K(255 * T),
- D.querySelector("input.color_G").value = K(255 * g),
- D.querySelector("input.color_B").value = K(255 * W);
- var z = R.$9o();
- D.querySelector(".preview").style.backgroundColor = z;
- var J = R.$2o(M / 360, 1, 1);
- D.querySelector(".satval").style.backgroundColor = R.$4o(J.r, J.g, J.b, !0),
- t._instant && t.setValue(z)
- },
- $5o: function(I, c, b) {
- var r, t, Q = Math.max(Math.max(I, c), b), B = Math.min(Math.min(I, c), b), m = Q;
- if (B == Q)
- r = 0,
- t = 0;
- else {
- var X = Q - B;
- t = X / Q,
- r = I == Q ? (c - b) / X : c == Q ? 2 + (b - I) / X : 4 + (I - c) / X,
- r /= 6,
- 0 > r && (r += 1),
- r > 1 && (r -= 1)
- }
- return {
- h: r,
- s: t,
- v: m
- }
- },
- $4o: function(q, M, E, Q) {
- return q = K(255 * q),
- M = K(255 * M),
- E = K(255 * E),
- Q == R && (Q = !0),
- q = q.toString(16),
- 1 == q.length && (q = "0" + q),
- M = M.toString(16),
- 1 == M.length && (M = "0" + M),
- E = E.toString(16),
- 1 == E.length && (E = "0" + E),
- ((Q ? "#" : "") + q + M + E).toUpperCase()
- },
- $3o: function(v, n, e) {
- e == R && (e = null),
- "#" == v.substr(0, 1) && (v = v.substr(1));
- var Y, M, O;
- if (3 == v.length)
- Y = v.substr(0, 1),
- Y += Y,
- M = v.substr(1, 1),
- M += M,
- O = v.substr(2, 1),
- O += O;
- else {
- if (6 != v.length)
- return e;
- Y = v.substr(0, 2),
- M = v.substr(2, 2),
- O = v.substr(4, 2)
- }
- return Y = parseInt(Y, 16),
- M = parseInt(M, 16),
- O = parseInt(O, 16),
- isNaN(Y) || isNaN(M) || isNaN(O) ? e : n ? {
- r: Y,
- g: M,
- b: O
- } : {
- r: Y / 255,
- g: M / 255,
- b: O / 255
- }
- },
- $2o: function(S, c, i) {
- var o, a, f;
- if (0 == i)
- o = 0,
- a = 0,
- f = 0;
- else {
- var V = Math.floor(6 * S)
- , s = 6 * S - V
- , R = i * (1 - c)
- , $ = i * (1 - c * s)
- , u = i * (1 - c * (1 - s));
- switch (V) {
- case 1:
- o = $,
- a = i,
- f = R;
- break;
- case 2:
- o = R,
- a = i,
- f = u;
- break;
- case 3:
- o = R,
- a = $,
- f = i;
- break;
- case 4:
- o = u,
- a = R,
- f = i;
- break;
- case 5:
- o = i,
- a = R,
- f = $;
- break;
- case 6:
- case 0:
- o = i,
- a = u,
- f = R
- }
- }
- return {
- r: o,
- g: a,
- b: f
- }
- },
- $9o: function() {
- var C = this._view
- , m = ap(C, "input.color_R").value
- , e = ap(C, "input.color_G").value
- , _ = ap(C, "input.color_B").value
- , w = ap(C, "input.color_A").value || 1;
- return "" === m || "" === e || "" === _ || "" === w ? R : 1 == w ? "rgb(" + m + "," + e + "," + _ + ")" : "rgba(" + m + "," + e + "," + _ + "," + w + ")"
- },
- getView: function() {
- return this._view
- },
- onOpened: function(Y) {
- if (Y) {
- var i, $ = this, G = $._view;
- if ($.$11o.style.backgroundColor = Y,
- 0 === Y.indexOf("#") ? (Y = Y.substr(1, 6),
- i = $.$3o(Y, !0),
- i = [i.r, i.g, i.b]) : 0 === Y.indexOf("rgb") && (Y = Y.substring(Y.indexOf("(") + 1, Y.indexOf(")")),
- i = Y.split(",")),
- i) {
- var z = 4 === i.length ? i[3] : 1
- , r = $.$5o(i[0] / 255, i[1] / 255, i[2] / 255)
- , I = ap(G, ".satval_pointer");
- ap(G, "input.color_R").value = i[0],
- ap(G, "input.color_G").value = i[1],
- ap(G, "input.color_B").value = i[2],
- ap(G, "input.color_A").value = z,
- $._h = K(360 * r.h),
- $._s = K(100 * r.s),
- $._v = K(100 * r.v),
- I.style.left = 127 * r.s - 3 + "px",
- I.style.top = 127 - 127 * r.v - 3 + "px",
- ap(G, ".hue_pointer").style.top = 128 - 127 * r.h + "px",
- $.$6o()
- }
- }
- },
- onClosed: function() {},
- getValue: function() {
- return this.$13o
- },
- getHeight: function() {
- return 170
- },
- getWidth: function() {
- return 252
- }
- });
- var ml = function(f) {
- this.$8o = f,
- this.setUp()
- };
- q(ml, X, {
- ms_listener: 1,
- getView: function() {
- return this.$8o._view
- },
- setUp: function() {
- this.addListeners()
- },
- tearDown: function() {
- this.removeListeners(),
- this.clear()
- },
- clear: function() {
- delete this.$7o
- },
- handle_touchstart: function(t) {
- var H = this
- , E = t.target
- , R = H.$8o
- , B = H.getView()
- , P = ap(B, ".hue_picker")
- , A = ap(B, ".satval");
- P.contains(E) ? (H.$7o = 1,
- H.$1o(t, 1)) : A.contains(E) && (H.$7o = 2,
- H.$1o(t, 2)),
- H.$7o && $.isDoubleClick(t) && (R.$13o = R.$9o(),
- R._master.close())
- },
- $1o: function(u, p) {
- $.preventDefault(u);
- var V, y, Y, M = this, L = M.$8o, l = M.getView(), R = ap(l, ".hue_picker"), J = ap(l, ".satval");
- if (u = b ? vg(u) : u,
- 1 === p) {
- V = R.getBoundingClientRect(),
- Y = u.clientY - V.top,
- Y -= 7,
- 0 > Y && (Y = 0),
- Y > 127 && (Y = 127),
- ap(l, ".hue_pointer").style.top = Y + 1 + "px";
- var T = Y;
- T = K(360 - T * (360 / 127)),
- L._h = T,
- L.$6o()
- } else if (2 === p) {
- V = J.getBoundingClientRect(),
- y = u.clientX - V.left - 1,
- Y = u.clientY - V.top - 1,
- 0 > y && (y = 0),
- y > 127 && (y = 127),
- 0 > Y && (Y = 0),
- Y > 127 && (Y = 127),
- L._s = K(100 * y / 127),
- L._v = K(100 - 100 * Y / 127);
- var H = ap(l, ".satval_pointer");
- H.style.left = y - 3 + "px",
- H.style.top = Y - 3 + "px",
- L.$6o()
- }
- },
- handle_mousedown: function(n) {
- this.handle_touchstart(n)
- },
- handle_mouseup: function(h) {
- this.handle_touchend(h)
- },
- handle_touchend: function(P) {
- var f = this;
- f.clear(P)
- },
- handle_mousemove: function(q) {
- this.handle_touchmove(q)
- },
- handle_touchmove: function() {
- var W = this;
- W.$7o && $.startDragging(W)
- },
- handleWindowMouseUp: function(p) {
- this.handleWindowTouchEnd(p)
- },
- handleWindowTouchEnd: function(H) {
- var m = this;
- m.clear(H)
- },
- handleWindowMouseMove: function(p) {
- this.handleWindowTouchMove(p)
- },
- handleWindowTouchMove: function(L) {
- var X = this
- , f = X.$7o;
- f && X.$1o(L, f)
- }
- }),
- i.FormPane = function(m) {
- var g = this
- , A = g._view = k.createView(1, g);
- m || (g._canvas = h(A)),
- A.appendChild(g._79O = u()),
- g._rows = [],
- g._itemMap = {},
- g.iv(),
- A.handleGroupSelectedChanged = function(w) {
- if (w.isSelected()) {
- var k = w.getGroupId();
- null != k && g._rows.forEach(function(L) {
- var P = L.items;
- P && P.forEach(function(H) {
- if (H) {
- var G = H.element;
- G && G !== w && G.setSelected && G.getGroupId && G.getGroupId() === k && G.setSelected(!1)
- }
- })
- })
- }
- }
- ,
- new yg(g)
- }
- ,
- q(L + "FormPane", X, {
- ms_v: 1,
- ms_fire: 1,
- ms_txy: 1,
- ms_lp: 1,
- ms_vs: 1,
- ms_hs: 1,
- ms_value: 1,
- ms_ac: ["labelColor", "labelFont", "labelAlign", "labelVAlign", "vPadding", "hPadding", "labelHPadding", "labelVPadding", "hGap", "vGap", "rows", "rowHeight", "scrollBarColor", "scrollBarSize", "autoHideScrollBar"],
- _29I: oe,
- _91I: 0,
- _59I: 0,
- _labelColor: $.formPaneLabelColor,
- _labelFont: $.formPaneLabelFont,
- _labelAlign: $.formPaneLabelAlign,
- _labelVAlign: $.formPaneLabelVAlign,
- _hPadding: $.formPaneHPadding,
- _vPadding: $.formPaneVPadding,
- _labelHPadding: $.formPaneLabelHPadding,
- _labelVPadding: $.formPaneLabelVPadding,
- _hGap: $.formPaneHGap,
- _vGap: $.formPaneVGap,
- _rowHeight: $.widgetRowHeight,
- _scrollBarColor: $.scrollBarColor,
- _scrollBarSize: $.scrollBarSize,
- _autoHideScrollBar: $.autoHideScrollBar,
- onPropertyChanged: function(e) {
- var P = this
- , f = e.property;
- P.iv(),
- "translateX" === f ? P._42o() : "translateY" === f && P._43o()
- },
- adjustTranslateX: function(t) {
- var h = this.getWidth() - this._91I;
- return h > t && (t = h),
- t > 0 ? 0 : Math.round(t)
- },
- adjustTranslateY: function(L) {
- var B = this.getHeight() - this._59I;
- return B > L && (L = B),
- L > 0 ? 0 : Math.round(L)
- },
- setPadding: function(a) {
- this.setVPadding(a),
- this.setHPadding(a)
- },
- getLabelFont: function(k) {
- return k && k.font ? k.font : this._labelFont
- },
- getLabelColor: function(J) {
- return J && J.color ? J.color : this._labelColor
- },
- getLabelAlign: function(V) {
- return V && V.align ? V.align : this._labelAlign
- },
- getLabelVAlign: function(g) {
- return g && g.vAlign ? g.vAlign : this._labelVAlign
- },
- getRowBorderColor: function(Q) {
- return Q ? Q.borderColor : null
- },
- getRowBackground: function(J) {
- return J ? J.background : null
- },
- getItemBorderColor: function(j) {
- return j ? j.borderColor : null
- },
- getItemBackground: function(R) {
- return R ? R.background : null
- },
- getItemById: function(O) {
- return this._itemMap[O]
- },
- getViewById: function(k) {
- var D = this.getItemById(k);
- return D ? D.element : null
- },
- getItemView: function(b) {
- if (b) {
- var T = b.element;
- if (T) {
- if (T.tagName)
- return T;
- if (T.getView)
- return T.getView()
- }
- }
- return null
- },
- updateItemElement: function(D, y) {
- var s = this
- , Y = s.getItemById(D);
- if (Y) {
- var l = s.getItemView(Y);
- l && s._view.removeChild(l),
- Y.element = y,
- l = s.getItemView(Y),
- l && (l.style.position = "absolute",
- s._view.insertBefore(l, s._79O)),
- s.iv()
- }
- },
- addRow: function(Q, I, u, D) {
- var y = this
- , g = y._view;
- if (Q) {
- for (var E = 0; E < Q.length; E++) {
- var M = Q[E];
- M && ((M.tagName || M.getView) && (Q[E] = {
- element: M
- }),
- k.initItemElement(M),
- null != M.id && (y._itemMap[M.id] = M))
- }
- Q.forEach(function(R) {
- var I = y.getItemView(R);
- I && (I.style.position = "absolute",
- g.insertBefore(I, y._79O))
- })
- }
- var q = D || {};
- return q.items = Q,
- q.widths = I,
- q.height = u,
- null == q.index ? y._rows.push(q) : y._rows.splice(q.index, 0, q),
- y.iv(),
- q
- },
- removeRows: function(f) {
- if (f) {
- var E = this
- , W = [];
- f.forEach(function(P) {
- P.items && P.items.forEach(function(B) {
- var Q = E.getItemView(B);
- Q && E._view.removeChild(Q),
- B && null != B.id && delete E._itemMap[B.id]
- })
- }),
- E._rows.forEach(function(y) {
- f.indexOf(y) < 0 && W.push(y)
- }),
- E._rows = W,
- E.iv()
- }
- },
- removeRow: function(K) {
- var D = this
- , B = D._rows.splice(K, 1)[0].items;
- B && B.forEach(function(e) {
- var C = D.getItemView(e);
- C && D._view.removeChild(C),
- e && null != e.id && delete D._itemMap[e.id]
- }),
- D.iv()
- },
- clear: function() {
- for (var c = this, k = c._view; k.firstChild; )
- k.removeChild(k.firstChild);
- c._canvas && k.appendChild(c._canvas),
- k.appendChild(c._79O),
- c._rows = [],
- c._itemMap = {},
- c.iv()
- },
- validateImpl: function() {
- var M, f, $, p, W, a, r = this, v = r._canvas, J = r._rowHeight, _ = r.getWidth(), G = r.getHeight(), P = r._hPadding, h = r._vPadding, e = r._vGap, V = r.ty(), T = r.tx(), E = _ - 2 * P, C = G - 2 * h, n = r._rows, k = n.length, L = 0, N = C - (k - 1) * e;
- for (r._29I = {
- x: -T,
- y: -V,
- width: _,
- height: G
- },
- v && (F(v, _, G),
- a = A(v),
- z(a, 0, 0, 1),
- a.clearRect(0, 0, _, G)),
- $ = 0; k > $; $++)
- p = n[$],
- W = p.height,
- null == W ? N -= J : O(W) ? (M = W.split("+"),
- f = parseFloat(M[0]),
- f > 1 ? N -= f : L += f,
- f = parseFloat(M[1]),
- f > 1 ? N -= f : L += f) : W > 1 ? N -= W : L += W;
- 0 > N ? (r._59I = G - N,
- N = 0) : r._59I = G;
- var w = h + V
- , U = _;
- for ($ = 0; k > $; $++) {
- p = n[$],
- W = p.height,
- null == W ? W = J : O(W) ? (M = W.split("+"),
- f = parseFloat(M[0]),
- W = f > 1 ? f : f / L * N,
- f = parseFloat(M[1]),
- W += f > 1 ? f : f / L * N) : 1 >= W && (W = W / L * N);
- var u = P + T;
- if (a) {
- var j = r.getRowBorderColor(p)
- , c = r.getRowBackground(p);
- c && t(a, u, w, E, W, c),
- j && m(a, j, u, w, E, W)
- }
- var D = r.validateRow(a, _, p.items, p.widths, u, w, E, W);
- D > U && (U = D),
- w += W + e
- }
- a && a.restore(),
- r._91I = U,
- r._92I(),
- r._93I(),
- r.tx(r.tx()),
- r.ty(r.ty())
- },
- validateRow: function(x, v, N, J, r, o, z, u) {
- if (!N)
- return 0;
- var E, j, c, C, Q, q = this, _ = v, i = q._hGap, $ = N.length, b = 0, F = z - ($ - 1) * i;
- for (c = 0; $ > c; c++)
- C = J[c],
- O(C) ? (E = C.split("+"),
- j = parseFloat(E[0]),
- j > 1 ? F -= j : b += j,
- j = parseFloat(E[1]),
- j > 1 ? F -= j : b += j) : C > 1 ? F -= C : b += C;
- for (0 > F && (_ -= F,
- F = 0),
- c = 0; $ > c; c++) {
- if (Q = N[c],
- C = J[c],
- O(C) ? (E = C.split("+"),
- j = parseFloat(E[0]),
- C = j > 1 ? j : j / b * F,
- j = parseFloat(E[1]),
- C += j > 1 ? j : j / b * F) : 1 >= C && (C = C / b * F),
- Q) {
- if (x) {
- var X = q.getItemBorderColor(Q)
- , e = q.getItemBackground(Q);
- e && t(x, r, o, C, u, e),
- X && m(x, X, r, o, C, u)
- }
- q.validateItem(x, Q, r, o, C, u)
- }
- r += C + i
- }
- return _
- },
- validateItem: function(n, D, p, r, S, T) {
- var l, I = this, h = D.element;
- h && !O(h) ? x(h, p, r, S, T) : n && (O(D) ? l = D : O(D.element) && (l = D.element),
- l && (n.save(),
- n.beginPath(),
- n.rect(p, r, S, T),
- n.clip(),
- e(n, l, I.getLabelFont(D), I.getLabelColor(D), p + I._labelHPadding, r - I._labelVPadding, S - 2 * I._labelHPadding, T - 2 * I._labelVPadding, I.getLabelAlign(D), I.getLabelVAlign(D)),
- n.restore()))
- }
- });
- var yg = function(S) {
- this.f = S,
- this.addListeners()
- };
- q(yg, X, {
- ms_listener: 1,
- getView: function() {
- return this.f._view
- },
- handle_mousedown: function(q) {
- J(q) && this.handle_touchstart(q)
- },
- handleWindowMouseMove: function(h) {
- this.handleWindowTouchMove(h)
- },
- handleWindowMouseUp: function(G) {
- this.handleWindowTouchEnd(G)
- },
- handle_touchstart: function(w) {
- var M, e = this, o = e.f, p = w.target;
- e.isV(w) ? M = "v" : e.isH(w) ? M = "h" : (p === e.getView() || o._79O.contains(p)) && (M = "p"),
- (e.s = M) && (e.cp = v(w),
- e.tx = o.tx(),
- e.ty = o.ty(),
- C(w),
- g(e, w))
- },
- handle_mousemove: function(t) {
- var m = this
- , e = m.f;
- m.isV(t) && e._43o(),
- m.isH(t) && e._42o()
- },
- handleWindowTouchMove: function($) {
- var H = this
- , F = H.f
- , y = H.s
- , q = H.tx
- , K = H.ty
- , c = H.cp
- , D = v($)
- , t = F._29I;
- "p" === y ? F.setTranslate(q + D.x - c.x, K + D.y - c.y) : "v" === y ? F.ty(K + (c.y - D.y) * F._59I / t.height) : "h" === y && F.tx(q + (c.x - D.x) * F._91I / t.width)
- },
- handleWindowTouchEnd: function() {},
- handle_mousewheel: function(I) {
- this.h(I, I.wheelDelta / 40, I.wheelDelta !== I.wheelDeltaX)
- },
- handle_DOMMouseScroll: function(n) {
- this.h(n, -n.detail, 1)
- },
- h: function(S, H, O) {
- var v = this.f;
- C(S),
- k.closePopup(),
- O && v._41o() ? v.translate(0, 10 * H) : v._40o() && v.translate(10 * H, 0)
- },
- isV: function(k) {
- var M = this.f
- , d = M._29I;
- return M._41o() && d.x + d.width - M.lp(k).x < N
- },
- isH: function(n) {
- var q = this.f
- , O = q._29I;
- return q._40o() && O.y + O.height - q.lp(n).y < N
- }
- })
- }("undefined" != typeof global ? global : "undefined" != typeof self ? self : "undefined" != typeof window ? window : this, Object);
|