Added LinuxChix theme
[moodle-linuxchix.git] / lib / yui / datatable / README
blobed31cca42fdada41dff7f327fd3cd14c84648af9
1 DataTable Release Notes
3 *** version 2.3.0 ***
5 * DataSource requests over XHR no longer automatically insert a "?" in the URIs
6 between the host and the query. Implementers should explicitly include the
7 question mark if it is required by your server. Please refer to the XHR
8 examples for implementation details.
10 * Applied new skinning model.
12 * The MVC model has been stabilized and many APIs have been renamed or changed
13 quite a bit from the previous version. Implementers should now only use
14 DataTable APIs and not use any Record or RecordSet APIs to add/delete/update
15 rows, Records, and DOM elements. RecordSet synchronization will be managed for
16 you under the hood. For example, myDataTable.addRow() now accepts an object
17 literal of data and will create a Record and update the DOM. Calling
18 myDataTable.deleteRow() will delete the appropriate Record and update the DOM.
19 Please refer to the API reference for full details on property and method names and
20 argument signatures. When possible, Logger messages will provide deprecation warnings,
21 so implementers upgrading from the previous version are encouraged to use the debug
22 build of DataTable.
24 * The DataTable constructor signature has changed in 2 major ways:
25 1) Do not pass in a ColumnSet instance. Instead, pass in an array of Column
26 definitions directly, and a ColumnSet instance will be created for you under the hood.
27 2) In the progressive enhancement case, first instantiate a DataSource pointing
28 to your HTML TABLE element, and then pass in that DataSource instance to your
29 DataTable constructor. Please refer to the progressive enhancement example
30 for implementation details.
32 * DataTable now extends Element, which has become a required dependency. Implementers
33 should now use the myDataTable.set("propertyName", newValue) syntax instead of direct
34 dot notation of any properties.
36 * The underlying pagination architecture and API have been revised. Specifically,
37 the property paginator has been deprecated in favor of paginated,
38 paginatorOptions has been deprecated in favor of paginator, and related events
39 and method names have been changed. Please see the pagination examples for
40 implementation details. Please refer to the API reference for full details on
41 new property and method names and argument signatures.
43 * There is a known pagination bug where changing the rows-per-page dropdown while
44 on a page number that is out of bounds of the new range, the current page value
45 fails to get reset to an appropriate default value.
47 * There is a known pagination bug where custom containers are ignored.
49 * There is a known bug where row and cell selections are not tracked correctly in
50 paginated DataTables.
52 * The underlying editing architecture and API have been revised. Specifically, the
53 ColumnEditor class is no longer used, the method editCell() has been deprecated
54 in favor of showCellEditor(), and the Custom Event "cellEditEvent" is now
55 "editorSaveEvent". Please see the inline editing example for
56 implementation details. Please refer to the API reference for full details on
57 property and method names and argument signatures.
59 * There is a known issue where the built-in date editor throws a JavaScript
60 exception when encountering a null or non-Date value. Implementers using the built-in
61 date editor should validate for type Date and avoid null values in these data
62 fields.
64 * The underlying sort architecture, including YAHOO.util.Sort, has been modified
65 to accept a single sort function rather than separate functions for ascending
66 and descending sorts.
68 * Scrolling a DataTable with an active Cell Editor will cancel the edit to
69 to prevent the Cell Editor's position from getting out of sync with its
70 associated TD element.
72 * The following static methods are executed in the scope of the DataTable
73 instance: DataTable.validateNumber(), DataTable.formatButton(),
74 DataTable.formatCheckbox(), DataTable.formatCurrency(), DataTable.formatDate(),
75 DataTable.formatDropdown(), DataTable.formatEmail(), DataTable.formatLink(),
76 DataTable.formatNumber(), DataTable.formatRadio(), DataTable.formatText(),
77 DataTable.formatTextarea(), DataTable.formatTextbox().
79 * The following DataTable APIs have changed:
80 - The following static constants have been removed: CLASS_CURRENCY, CLASS_CURRENTPAGE,
81 CLASS_DATE, CLASS_EMAIL, CLASS_FIRSTLINK, CLASS_FIRSTPAGE, CLASS_HEADCONTAINER,
82 CLASS_HEADRESIZER, CLASS_HEADTEXT, CLASS_HIGHLIGHT, CLASS_LASTLINK, CLASS_LASTPAGE,
83 CLASS_LINK, CLASS_NEXTLINK, CLASS_NEXTPAGE, CLASS_NUMBER, CLASS_PAGELINK,
84 CLASS_PAGELINKS, CLASS_PAGESELECT, CLASS_PREVLINK, CLASS_PREVPAGE, CLASS_SORTEDBYASC,
85 CLASS_SORTEDBYDESC, CLASS_STRING.
86 - The following static constants have been added: CLASS_ASC, CLASS_BUTTON,
87 CLASS_DEFAULT, CLASS_DESC, CLASS_DISABLED, CLASS_DROPDOWN, CLASS_HEADER,
88 CLASS_HIGHLIGHTED, CLASS_LABEL, CLASS_NEXT, CLASS_PAGE, CLASS_PREVIOUS,
89 CLASS_RESIZER
90 - The property contextMenu is no longer supported.
91 - The property dataSource has been deprecated in favor of the accessor method
92 getDataSource().
93 - The property fixedWidth is not fully supported.
94 - The property sortedBy now defines key instead of colKey.
95 - The property rowSingleSelect has been deprecated in favor of selectionMode.
97 * The following Record APIs have changed:
98 - Record data values are no longer accessible with oRecord[key] or oRecord.key.
99 Implementers should now use oRecord.getData(key).
100 - The property yuiRecordId has been deprecated in favor of the accessor method
101 getId().
103 * The following RecordSet APIs have changed:
104 - The method getRecordBy() is not implemented.
105 - The method insert() has been deprecated in favor of addRecord() and addRecords().
106 - The method replace() has been renamed replaceRecords().
107 - The method sort() has been deprecated in favor of sortRecords().
109 * The following Column APIs have changed:
110 - Column type has been deprecated in favor of formatter. In your Column
111 definitions, please change type:"date" to formatter:"date", type:"currency" to
112 formatter:"currency", etc.
113 - The property parser is no longer used. Implementers should use the static
114 DataSource methods DataSource.parseDate(), DataSource.parseNumber(), and
115 DataSource.parseString() for type conversion functionality.
116 - The methods getColSpan() and getRowSpan() have been renamed to getColspan()
117 and getRowspan().
118 - The return value for the method getId() has been changed.
119 - The following methods are no longer implemented: parse(), parseCheckbox(),
120 parseDate(), parseNumber(), parseSelect(). Implementers should now use a
121 DataSource with a data type of HTML TABLE element.
122 - The showEditor() method is no longer implemented. Implementers should now use
123 the DataTable method showCellEditor().
124 - All static formatter functions have been moved from the Column class to the
125 DataTable class.
127 * The DataTable method getColumn() has a known issue where instead of accepting
128 a Column's key index value, the method accepts a Column's ID value. Until this
129 issue is fixed, implementers can use the following workaround:
131     // Instead of this:
132     // var oColumn = myDataTable.getColumn(0);
134     // Use this:
135     var oColumn = myDataTable.getColumn(myDataTable.getFirstTrEl().cells[0].yuiColumnId);
146 *** version 2.2.2 ***
148 * Removed workaround for a fixed Dom.getXY() bug that was causing a positioning
149 problem for inline editors on scrolled pages.
153 **** version 2.2.1 ***
155 * Changed default pagination from enabled to disabled. Must set property
156 paginator to true to enable built-in client-side pagination.
157 * Removed deleteSelectedRows() and added deleteRows().
158 * Deprecated properties isEmpty and isLoading, and methods showLoadingMessage(),
159 showEmptyMessage(), and hideTableMessages(). Implementers should now use
160 showTableMessage() and hideTableMessage().
161 * Deprecated methods paginateRows() and onDataReturnPaginateRows(). Implementers
162 should now use popualateTable() and onDataReturnPopulateTable().
163 * Deprecated pagination properties pageCurrent, rowsPerPage, startRecordIndex,
164 pageLinksLength, rowsPerPageDropdown, pageLinksStart, and pagers.
165 * Fixed unclickable links.
166 * Fix to support data values of 0 (zero).
167 * Fixed broken validation in multiple places when the value 0 (zero) is passed
168 in as an argument.
169 * Fixed incorrect month output in formatDate().
170 * Fixed broken empty message when there are zero rows.
171 * Allow implementers to use data with field name "id".
172 * Fixed Column resizeability in -min builds.
173 * Fixed Column sorting of null, undefined, and empty values.
174 * Fixed Column sorting of nested headers.
175 * Fixed paginator dropdowns to stay in sync when paginating.
176 * Fixed rowSingleSelect for paginated DataTable.
177 * Fix for currency values with more than 2 decimal places.
178 * Fixed broken TR ID assignments in replaceRows().
179 * Fixed Opera UI artifacting problem when repaginating via dropdowns.
180 * Fixed orphaned ColumnEditor during pagination or other de facto blur
181 interaction. Data gets saved.
182 * Extracted non-foundational CSS for scrollable DataTables to make UI easier to
183 customize.
184 * Updated methods select() and unselect() to also accept an array of elements or
185 an array of strings.
186 * Improved row selection behavior to model the desktop paradigm (i.e., require
187 CONTROL and/or SHIFT keys to multi-select).
188 * Tweaked inline editing for better Mac performance.
189 * Refactored pagination code to be easier to implement, configure, and extend.
190 * Accept an error boolean from DataSource in case of data error and show error
191 message.
192 * The CustomEvent rowDeleteEvent is now only fired once per deleted row and
193 its argument signature has been modified.
194 * Added selectRow(), rowSelectEvent, unselectRow(), rowUnselectEvent, rowAddEvent,
195 and rowUpdateEvent.
196 * Added constants CLASS_TABLE, CLASS_EDITOR, CLASS_FIRST, and CLASS_LAST.
197 * Added ColumnEditor class moveContainerTo().
198 * Add IDs and class hooks to TABLE element and ColumnEditor's container DIV.
199 * Add class hooks to first and last TR elements.
200 * Added hook to doBeforeLoadData() for the not-from-markup constructor flow.
201 * Added properties paginator and paginatorOptions, as well as method getPaginator().
202 * Added methods saveEditorData() and cancelEditorData().
203 * Improved type checking with YAHOO.lang.
207 **** version 2.2.0 ***
209 * Beta release.
210 * Caption is not supported when scrolling is enabled.
211 * Resizeability is not supported for fixed-width DataTables.