inputEx-library

inputEx  0.7.1

inputEx-library > inputEx > SerializeField-beta.js (source view)
Search:
 
Filters
(function() {

   var Event = YAHOO.util.Event, Dom = YAHOO.util.Dom, lang = YAHOO.lang;

/**
 * SerializeField allows to serialize/deserialize a complex sub-group to a string
 * @class inputEx.SerializeField
 * @extends inputEx.Field
 * @constructor
 * @param {Object} options  Standard inputEx options definition
 */
inputEx.SerializeField = function(options) {
   inputEx.SerializeField.superclass.constructor.call(this, options);
   
};

lang.extend(inputEx.SerializeField, inputEx.Field, {
	
	/**
    * Adds some options: subfield & serializer
    * @param {Object} options Options object as passed to the constructor
    */
   setOptions: function(options) {
      inputEx.SerializeField.superclass.setOptions.call(this, options);
   	this.options.className = options.className || 'inputEx-SerializedField';

		this.options.subfield = options.subfield || {type: 'string'};
		this.options.serializer = options.serializer || "json";
	},
	
   /**
    * Render the subfield
    */
   renderComponent: function() {
	
      this.subfieldWrapper = inputEx.cn('div', {className: "inputEx-SerializedField-SubFieldWrapper"});
      this.fieldContainer.appendChild( this.subfieldWrapper );
      
		var config = {parentEl: this.subfieldWrapper};
		lang.augmentObject(config, this.options.subfield);
      this.subField = inputEx( config, this);
   },

	/**
	 * Subscribe the subField
	 */
	initEvents: function() {
      inputEx.SerializeField.superclass.initEvents.call(this); 
      this.subField.updatedEvt.subscribe(this.fireUpdatedEvt, this, true);
   },

	/**
	 * Use the subField getValue and serialize it with the selected serializing method
	 */
	getValue: function() {
		var val = this.subField.getValue();
		return this.serialize(val);
	},
	
	/**
	 * Use the deserialize method and set the value of the subField
	 */
	setValue: function(sValue, sendUpdatedEvt) {
		var obj = this.deserialize(sValue);
		this.subField.setValue(obj, sendUpdatedEvt);
	},
	
	/**
	 * Use the configured serializer
	 */
	serialize: function(o) {
		return inputEx.SerializeField.serializers[this.options.serializer].serialize(o);
	},
	
	/**
	 * Use the configured deserializer
	 */
	deserialize: function(sValue) {
		return inputEx.SerializeField.serializers[this.options.serializer].deserialize(sValue);
	},
	
	/**
	 * Sets the focus on this field
	 */
	focus: function() {
		this.subField.focus();
	}
	
});

/**
 * Default serializers for the SerializeField
 * @class inputEx.SerializeField.serializers
 * @static
 */
inputEx.SerializeField.serializers = {

	/**
	 * JSON Serializer
	 * @static
	 */
	json: {
		
		/**
		 * serialize to JSON
		 * @static
		 */
		serialize: function(o) {
			return YAHOO.lang.JSON.stringify(o);
		},

		/**
		 * deserialize from JSON
		 * @static
		 */
		deserialize: function(sValue) {
			return YAHOO.lang.JSON.parse(sValue);
		}
	},
	
	/**
	 * XML Serializer (uses the ObjTree library)
	 * @static
	 */
	xml: {
		
		/**
		 * serialize to XML
		 * @static
		 */
		serialize: function(o) {
			if(!XML || !YAHOO.lang.isFunction(XML.ObjTree) ) {
				alert("ObjTree.js not loaded.");
				return null;
			}
			var xotree = new XML.ObjTree();
			return xotree.writeXML(o);
		},

		/**
		 * deserialize from XML 
		 * @static
		 */
		deserialize: function(sValue) {
			if(!XML || !YAHOO.lang.isFunction(XML.ObjTree) ) {
				alert("ObjTree.js not loaded.");
				return null;
			}
			var xotree = new XML.ObjTree();
		  	var tree = xotree.parseXML( sValue );
			return tree;
		}
	}/*,
	
	flatten: {
		serialize: function(o) {
			// TODO: 
		},

		deserialize: function(sValue) {
			// TODO: 
		}
	}*/
	
};


// Register this class as "serialize" type
inputEx.registerType("serialize", inputEx.SerializeField, [
	{ type:'type', label: 'SubField', name: 'subfield'},
	{ type:'select', name: 'serializer', label: 'Serializer', choices: [{ value: 'json' }, { value: 'xml' }/*, { value: 'flatten' }*/], value: 'json'}
]);

})();

Copyright © 2011 Eric Abouaf All rights reserved.