//.CommonJS
|
|
var CSSOM = {};
|
|
///CommonJS
|
|
|
|
|
|
/**
|
|
* @constructor
|
|
* @see http://www.w3.org/TR/DOM-Level-2-Style/css.html#CSS-CSSStyleDeclaration
|
|
*/
|
|
CSSOM.CSSStyleDeclaration = function CSSStyleDeclaration(){
|
|
this.length = 0;
|
|
this.parentRule = null;
|
|
|
|
// NON-STANDARD
|
|
this._importants = {};
|
|
};
|
|
|
|
|
|
CSSOM.CSSStyleDeclaration.prototype = {
|
|
|
|
constructor: CSSOM.CSSStyleDeclaration,
|
|
|
|
/**
|
|
*
|
|
* @param {string} name
|
|
* @see http://www.w3.org/TR/DOM-Level-2-Style/css.html#CSS-CSSStyleDeclaration-getPropertyValue
|
|
* @return {string} the value of the property if it has been explicitly set for this declaration block.
|
|
* Returns the empty string if the property has not been set.
|
|
*/
|
|
getPropertyValue: function(name) {
|
|
return this[name] || "";
|
|
},
|
|
|
|
/**
|
|
*
|
|
* @param {string} name
|
|
* @param {string} value
|
|
* @param {string} [priority=null] "important" or null
|
|
* @see http://www.w3.org/TR/DOM-Level-2-Style/css.html#CSS-CSSStyleDeclaration-setProperty
|
|
*/
|
|
setProperty: function(name, value, priority) {
|
|
if (this[name]) {
|
|
// Property already exist. Overwrite it.
|
|
var index = Array.prototype.indexOf.call(this, name);
|
|
if (index < 0) {
|
|
this[this.length] = name;
|
|
this.length++;
|
|
}
|
|
} else {
|
|
// New property.
|
|
this[this.length] = name;
|
|
this.length++;
|
|
}
|
|
this[name] = value + "";
|
|
this._importants[name] = priority;
|
|
},
|
|
|
|
/**
|
|
*
|
|
* @param {string} name
|
|
* @see http://www.w3.org/TR/DOM-Level-2-Style/css.html#CSS-CSSStyleDeclaration-removeProperty
|
|
* @return {string} the value of the property if it has been explicitly set for this declaration block.
|
|
* Returns the empty string if the property has not been set or the property name does not correspond to a known CSS property.
|
|
*/
|
|
removeProperty: function(name) {
|
|
if (!(name in this)) {
|
|
return "";
|
|
}
|
|
var index = Array.prototype.indexOf.call(this, name);
|
|
if (index < 0) {
|
|
return "";
|
|
}
|
|
var prevValue = this[name];
|
|
this[name] = "";
|
|
|
|
// That's what WebKit and Opera do
|
|
Array.prototype.splice.call(this, index, 1);
|
|
|
|
// That's what Firefox does
|
|
//this[index] = ""
|
|
|
|
return prevValue;
|
|
},
|
|
|
|
getPropertyCSSValue: function() {
|
|
//FIXME
|
|
},
|
|
|
|
/**
|
|
*
|
|
* @param {String} name
|
|
*/
|
|
getPropertyPriority: function(name) {
|
|
return this._importants[name] || "";
|
|
},
|
|
|
|
|
|
/**
|
|
* element.style.overflow = "auto"
|
|
* element.style.getPropertyShorthand("overflow-x")
|
|
* -> "overflow"
|
|
*/
|
|
getPropertyShorthand: function() {
|
|
//FIXME
|
|
},
|
|
|
|
isPropertyImplicit: function() {
|
|
//FIXME
|
|
},
|
|
|
|
// Doesn't work in IE < 9
|
|
get cssText(){
|
|
var properties = [];
|
|
for (var i=0, length=this.length; i < length; ++i) {
|
|
var name = this[i];
|
|
var value = this.getPropertyValue(name);
|
|
var priority = this.getPropertyPriority(name);
|
|
if (priority) {
|
|
priority = " !" + priority;
|
|
}
|
|
properties[i] = name + ": " + value + priority + ";";
|
|
}
|
|
return properties.join(" ");
|
|
},
|
|
|
|
set cssText(text){
|
|
var i, name;
|
|
for (i = this.length; i--;) {
|
|
name = this[i];
|
|
this[name] = "";
|
|
}
|
|
Array.prototype.splice.call(this, 0, this.length);
|
|
this._importants = {};
|
|
|
|
var dummyRule = CSSOM.parse('#bogus{' + text + '}').cssRules[0].style;
|
|
var length = dummyRule.length;
|
|
for (i = 0; i < length; ++i) {
|
|
name = dummyRule[i];
|
|
this.setProperty(dummyRule[i], dummyRule.getPropertyValue(name), dummyRule.getPropertyPriority(name));
|
|
}
|
|
}
|
|
};
|
|
|
|
|
|
//.CommonJS
|
|
exports.CSSStyleDeclaration = CSSOM.CSSStyleDeclaration;
|
|
CSSOM.parse = require('./parse').parse; // Cannot be included sooner due to the mutual dependency between parse.js and CSSStyleDeclaration.js
|
|
///CommonJS
|