/* * Based on: * Ext JS Library 1.1.1 * Copyright(c) 2006-2007, Ext JS, LLC. * * Originally Released Under LGPL - original licence link has changed is not relivant. * * Fork - LGPL * <script type="text/javascript"> */ /** * @class Roo.data.Record * Instances of this class encapsulate both record <em>definition</em> information, and record * <em>value</em> information for use in {@link Roo.data.Store} objects, or any code which needs * to access Records cached in an {@link Roo.data.Store} object.<br> * <p> * Constructors for this class are generated by passing an Array of field definition objects to {@link #create}. * Instances are usually only created by {@link Roo.data.Reader} implementations when processing unformatted data * objects.<br> * <p> * Record objects generated by this constructor inherit all the methods of Roo.data.Record listed below. * @constructor * This constructor should not be used to create Record objects. Instead, use the constructor generated by * {@link #create}. The parameters are the same. * @param {Array} data An associative Array of data values keyed by the field name. * @param {Object} id (Optional) The id of the record. This id should be unique, and is used by the * {@link Roo.data.Store} object which owns the Record to index its collection of Records. If * not specified an integer id is generated. */ Roo.data.Record = function(data, id){ this.id = (id || id === 0) ? id : ++Roo.data.Record.AUTO_ID; this.data = data; }; /** * Generate a constructor for a specific record layout. * @param {Array} o An Array of field definition objects which specify field names, and optionally, * data types, and a mapping for an {@link Roo.data.Reader} to extract the field's value from a data object. * Each field definition object may contain the following properties: <ul> * <li><b>name</b> : String<p style="margin-left:1em">The name by which the field is referenced within the Record. This is referenced by, * for example the <em>dataIndex</em> property in column definition objects passed to {@link Roo.grid.ColumnModel}</p></li> * <li><b>mapping</b> : String<p style="margin-left:1em">(Optional) A path specification for use by the {@link Roo.data.Reader} implementation * that is creating the Record to access the data value from the data object. If an {@link Roo.data.JsonReader} * is being used, then this is a string containing the javascript expression to reference the data relative to * the record item's root. If an {@link Roo.data.XmlReader} is being used, this is an {@link Roo.DomQuery} path * to the data item relative to the record element. If the mapping expression is the same as the field name, * this may be omitted.</p></li> * <li><b>type</b> : String<p style="margin-left:1em">(Optional) The data type for conversion to displayable value. Possible values are * <ul><li>auto (Default, implies no conversion)</li> * <li>string</li> * <li>int</li> * <li>float</li> * <li>boolean</li> * <li>date</li></ul></p></li> * <li><b>sortType</b> : Mixed<p style="margin-left:1em">(Optional) A member of {@link Roo.data.SortTypes}.</p></li> * <li><b>sortDir</b> : String<p style="margin-left:1em">(Optional) Initial direction to sort. "ASC" or "DESC"</p></li> * <li><b>convert</b> : Function<p style="margin-left:1em">(Optional) A function which converts the value provided * by the Reader into an object that will be stored in the Record. It is passed the * following parameters:<ul> * <li><b>v</b> : Mixed<p style="margin-left:1em">The data value as read by the Reader.</p></li> * </ul></p></li> * <li><b>dateFormat</b> : String<p style="margin-left:1em">(Optional) A format String for the Date.parseDate function.</p></li> * </ul> * <br>usage:<br><pre><code> var TopicRecord = Roo.data.Record.create( {name: 'title', mapping: 'topic_title'}, {name: 'author', mapping: 'username'}, {name: 'totalPosts', mapping: 'topic_replies', type: 'int'}, {name: 'lastPost', mapping: 'post_time', type: 'date'}, {name: 'lastPoster', mapping: 'user2'}, {name: 'excerpt', mapping: 'post_text'} ); var myNewRecord = new TopicRecord({ title: 'Do my job please', author: 'noobie', totalPosts: 1, lastPost: new Date(), lastPoster: 'Animal', excerpt: 'No way dude!' }); myStore.add(myNewRecord); </code></pre> * @method create * @static */ Roo.data.Record.create = function(o){ var f = function(){ f.superclass.constructor.apply(this, arguments); }; Roo.extend(f, Roo.data.Record); var p = f.prototype; p.fields = new Roo.util.MixedCollection(false, function(field){ return field.name; }); for(var i = 0, len = o.length; i < len; i++){ p.fields.add(new Roo.data.Field(o[i])); } f.getField = function(name){ return p.fields.get(name); }; return f; }; Roo.data.Record.AUTO_ID = 1000; Roo.data.Record.EDIT = 'edit'; Roo.data.Record.REJECT = 'reject'; Roo.data.Record.COMMIT = 'commit'; Roo.data.Record.prototype = { /** * Readonly flag - true if this record has been modified. * @type Boolean */ dirty : false, editing : false, error: null, modified: null, // private join : function(store){ this.store = store; }, /** * Set the named field to the specified value. * @param {String} name The name of the field to set. * @param {Object} value The value to set the field to. */ set : function(name, value){ if(this.data[name] == value){ return; } this.dirty = true; if(!this.modified){ this.modified = {}; } if(typeof this.modified[name] == 'undefined'){ this.modified[name] = this.data[name]; } this.data[name] = value; if(!this.editing && this.store){ this.store.afterEdit(this); } }, /** * Get the value of the named field. * @param {String} name The name of the field to get the value of. * @return {Object} The value of the field. */ get : function(name){ return this.data[name]; }, // private beginEdit : function(){ this.editing = true; this.modified = {}; }, // private cancelEdit : function(){ this.editing = false; delete this.modified; }, // private endEdit : function(){ this.editing = false; if(this.dirty && this.store){ this.store.afterEdit(this); } }, /** * Usually called by the {@link Roo.data.Store} which owns the Record. * Rejects all changes made to the Record since either creation, or the last commit operation. * Modified fields are reverted to their original values. * <p> * Developers should subscribe to the {@link Roo.data.Store#update} event to have their code notified * of reject operations. */ reject : function(){ var m = this.modified; for(var n in m){ if(typeof m[n] != "function"){ this.data[n] = m[n]; } } this.dirty = false; delete this.modified; this.editing = false; if(this.store){ this.store.afterReject(this); } }, /** * Usually called by the {@link Roo.data.Store} which owns the Record. * Commits all changes made to the Record since either creation, or the last commit operation. * <p> * Developers should subscribe to the {@link Roo.data.Store#update} event to have their code notified * of commit operations. */ commit : function(){ this.dirty = false; delete this.modified; this.editing = false; if(this.store){ this.store.afterCommit(this); } }, // private hasError : function(){ return this.error != null; }, // private clearError : function(){ this.error = null; }, /** * Creates a copy of this record. * @param {String} id (optional) A new record id if you don't want to use this record's id * @return {Record} */ copy : function(newId) { return new this.constructor(Roo.apply({}, this.data), newId || this.id); } };