UNPKG

@qooxdoo/framework

Version:

The JS Framework for Coders

155 lines (125 loc) 4.23 kB
/* ************************************************************************ qooxdoo - the new era of web development http://qooxdoo.org Copyright: 2009 1&1 Internet AG, Germany, http://www.1und1.de License: MIT: https://opensource.org/licenses/MIT See the LICENSE file in the project's top-level directory for details. Authors: * Fabian Jakobs (fjakobs) ************************************************************************ */ qx.Class.define("qx.test.theme.manager.Decoration", { extend : qx.dev.unit.TestCase, members : { setUp : function() { this.manager = qx.theme.manager.Decoration.getInstance(); this.__formerTheme = this.manager.getTheme(); }, tearDown : function() { qx.test.Theme.themes = null; this.manager.setTheme(this.__formerTheme); this.__formerTheme = null; }, testAlias : function() { qx.Theme.define("qx.test.Theme.themes.A", { aliases : { decoration: "test/decoration", custom : "test/custom" }, decorations : {} }); this.manager.setTheme(qx.test.Theme.themes.A); // make sure the decoration alias is set var alias = qx.util.AliasManager.getInstance(); this.assertEquals("test/decoration", alias.resolve("decoration")); this.assertEquals("test/custom", alias.resolve("custom")); }, testAliasExtend : function() { qx.Theme.define("qx.test.Theme.themes.A", { aliases : { decoration: "test/decoration", custom : "test/custom" }, decorations : {} }); qx.Theme.define("qx.test.Theme.themes.B", { extend : qx.test.Theme.themes.A, decorations : {} }); this.manager.setTheme(qx.test.Theme.themes.B); // make sure the decoration alias is set var alias = qx.util.AliasManager.getInstance(); this.assertEquals("test/decoration", alias.resolve("decoration")); this.assertEquals("test/custom", alias.resolve("custom")); }, testAliasOverride : function() { qx.Theme.define("qx.test.Theme.themes.A", { aliases : { decoration: "test/decoration", custom : "test/custom" }, decorations : {} }); qx.Theme.define("qx.test.Theme.themes.B", { extend : qx.test.Theme.themes.A, aliases : { decoration: "juhu/decoration" }, decorations : {} }); this.manager.setTheme(qx.test.Theme.themes.B); // make sure the decoration alias is set var alias = qx.util.AliasManager.getInstance(); this.assertEquals("juhu/decoration", alias.resolve("decoration")); this.assertEquals("test/custom", alias.resolve("custom")); }, testChangeThemeEventFired : function() { qx.Theme.define("qx.test.Theme.themes.A", { aliases : { decoration: "test/decoration", custom : "test/custom" }, decorations : {} }); var that = this; this.assertEventFired(this.manager, "changeTheme", function() { that.manager.setTheme(qx.test.Theme.themes.A); }, function(e) { that.assertIdentical(e.getData(), qx.test.Theme.themes.A, "Setting theme failed!"); }); }, testAddCssClass : function() { qx.Theme.define("qx.test.Theme.themes.B", { aliases : { decoration: "test/decoration", custom : "test/custom" }, decorations : { "test-add-css": { style: { backgroundColor: "red", backgroundImage: "icon/16/places/folder-open.png" } } } }); this.manager.setTheme(qx.test.Theme.themes.B); var selector = this.manager.addCssClass("test-add-css"); var sheet = qx.ui.style.Stylesheet.getInstance(); var elem = document.createElement("div"); elem.setAttribute("class", selector); document.body.appendChild(elem); var compStyle = window.getComputedStyle(elem); this.assertEquals("255,0,0", qx.util.ColorUtil.cssStringToRgb(compStyle.getPropertyValue("background-color"))); } } });