ville.Embed is a Qooxdoo control designed to make images, icons and graphics more dynamic.
- Use pure CSS icons in your project using the amazing iConicss icon set.
- Embed SVG icons in your project using code, and make them themable.
- Use ville.embed.MImage Mixin to make any qx.ui.basic.Image object accept SVG/HTML content. Use themes to define the SVG/HTML/Clip-path values.
To use the control in your application, go into the application root directory and install the library into your project:
qx package update
qx package list
qx package install sqville/ville.Embed
To illustrate - To create an icon using iConicss's CSS based icon set just create the icon's named object giving it a size (required) and color (optional). To use it in a button just include the ville.embed.MEmbed Mixin and set the Button's new embed property (example below):
var cubeoicon = new ville.embed.iconicss.CubeO(3, "green");
// Placed one-time at the top of your applicaition code
qx.Class.include(qx.ui.basic.Atom, ville.embed.MEmbed);
var btnFormButton = new qx.ui.form.Button('Embeded Cube').set({ embed : cubeoicon });
To create an icon using an SVG based icon set just create the icon's named object giving it a size (in px) and color (optional):
var airplanetakeofficon = new ville.embed.fluent.AirplaneTakeOff(40);
// Placed one-time at the top of your applicaition code
qx.Class.include(qx.ui.basic.Atom, ville.embed.MEmbed);
var btnFormButton = new qx.ui.form.Button('Embeded SVG').set({ embed : airplanetakeofficon });
Approach 2 - Enable qx.ui.basic.Image, Qooxdoo object to accept HTML/SVG markup and Clip-path values as a string
// Placed one-time at the top of your applicaition code
qx.Class.include(qx.ui.basic.Image, ville.embed.MImage);
// Appearance entry changes. Example: ComboBox
"combobox/button": {
...
return {
icon: "",
...
}
},
"combobox/button/icon" :
{
include : "image",
style : function(states)
{
// To use static SVG values, comment-out "clipPath" and uncomment "html"
return {
clipPath : ville.embed.fluent.ChevronDown.REGULAR,
// html : wax.demo.theme.Image.ChevronDownRegular,
width : 16,
height : 16,
backgroundColor : "transparent"
};
}
},
Distributed under the MIT License. See LICENSE
for more information.
Chris Eskew (SQville) - email: [email protected]