jvm.MapObject = function(config){};
jvm.MapObject.prototype.getLabelText = function(key){
var text;
if (this.config.label) {
if (typeof this.config.label.render === 'function') {
text = this.config.label.render(key);
} else {
text = key;
}
} else {
text = null;
}
return text;
}
jvm.MapObject.prototype.getLabelOffsets = function(key){
var offsets;
if (this.config.label) {
if (typeof this.config.label.offsets === 'function') {
offsets = this.config.label.offsets(key);
} else if (typeof this.config.label.offsets === 'object') {
offsets = this.config.label.offsets[key];
}
}
return offsets || [0, 0];
}
/**
* Set hovered state to the element. Hovered state means mouse cursor is over element. Styles will be updates respectively.
* @param {Boolean} isHovered true
to make element hovered, false
otherwise.
*/
jvm.MapObject.prototype.setHovered = function(isHovered){
if (this.isHovered !== isHovered) {
this.isHovered = isHovered;
this.shape.isHovered = isHovered;
this.shape.updateStyle();
if (this.label) {
this.label.isHovered = isHovered;
this.label.updateStyle();
}
}
};
/**
* Set selected state to the element. Styles will be updates respectively.
* @param {Boolean} isSelected true
to make element selected, false
otherwise.
*/
jvm.MapObject.prototype.setSelected = function(isSelected){
if (this.isSelected !== isSelected) {
this.isSelected = isSelected;
this.shape.isSelected = isSelected;
this.shape.updateStyle();
if (this.label) {
this.label.isSelected = isSelected;
this.label.updateStyle();
}
jvm.$(this.shape).trigger('selected', [isSelected]);
}
};
jvm.MapObject.prototype.setStyle = function(){
this.shape.setStyle.apply(this.shape, arguments);
};
jvm.MapObject.prototype.remove = function(){
this.shape.remove();
if (this.label) {
this.label.remove();
}
};