-
Notifications
You must be signed in to change notification settings - Fork 87
Upgrade Guide
We wrote this guide to help you to upgrade from Chico UI 0.13.x to Chico UI 1.0.0.
Our APIs have been redesigned, following these goals:
- Reuse our code: Mobile + Desktop!
- Extend our widgets (using prototypal inheritance).
- Add performance improvements.
- Be Modular.
- Core (ch)
- ch.Positioner
- ch.Content
- ch.Viewport
- ch.Calendar
- ch.Countdown
- ch.DatePicker
- ch.Expandable
- ch.Popover
- ch.Carousel
- ch.Tabs
- ch.Menu
- ch.Form
- ch.Validation
- CSS
- Removed
ch.cache
object. - Removed
ch.debug()
method. - Removed
ch.version
property. - Removed
ch.instances
collection. - Removed
ch.blink
method. - Removed
ch.keyboard
; usech.shortcuts
. - Removed
ch.Controls
class. - Removed
ch.Floats
class; usech.Popover
. - Removed
ch.events
; use the followings properties:ch.onchangelayout
,ch.onkeybackspace
,ch.onkeydownarrow
,ch.onkeyenter
,ch.onkeyesc
,ch.onkeyinput
,ch.onkeyleftarrow
,ch.onkeyrightarrow
,ch.onkeytab
,ch.onkeyuparrow
,ch.onpointerdown
,ch.onpointerenter
,ch.onpointerleave
,ch.onpointermove
,ch.onpointertap
,ch.onpointerup
,ch.onresize
,ch.onscroll
- Removed
ch.support.fixed
. - Added
ch.support.fx
. - Added
ch.support.touch
.
- Removed
ch.util.hasOwn()
method. - Removed
ch.util.inDom()
method. - Removed
ch.util.index
property. - Removed
ch.util.isSelector()
method. - Removed
ch.util.isTag()
method. - Removed
ch.util.use()
method. - Added
ch.util.getOffset(el)
method. - Added
ch.util.getOuterDimensions(el)
method. - Added
ch.util.getScroll(el)
method.
### Options
- Removed
reposition
option. - Removed
element
option; usetarget
. - Removed
context
option; usereference
. - Removed
points
option; useside
andalign
. - Removed
offset
option; useoffsetX
andoffsetY
. - Added
positioned
option.
- Added
refresh()
method (standalone version). - Removed
position('refresh')
from Popovers; userefreshPosition()
.
new ch.Positioner({
'element': '#element',
'context': '#context',
'points': 'lt rt',
'offset': '10 0'
});
new ch.Positioner({
'target': $('#element'),
'reference': $('#reference'),
'offsetX': 10,
'offsetY': 0,
'side': 'center',
'align': 'center',
'positioned': 'fixed'
});
We updated the content(options)
ability to content(content, [options])
.
- Added
content
parameter.-
AJAX.
widget.content('http://www.some-url.com');
-
Plain text.
widget.content('Some plain text.');
-
Query Selectors.
widget.content('#element');
widget.content($('#element'));
-
- Added
options
(optional) parameter.// Use only with AJAX content widget.content('http://www.some-url.com', { 'method': 'POST', 'params': 'x-request=true', 'cache': false, 'async': true, 'waiting': '<div class="ch-loading-big"></div>' });
- Removed
contentLoad
event; usecontentdone
. - Removed
contentError
event; usecontenterror
. - Added
contentwaiting
event.
The viewport has been redesigned to ease viewport management.
### Properties
- Removed
element
property; use$el
. - Added
orientation
property.
- Removed
getOffset()
method; usecalculateOffset()
. - Removed
getSize()
method; usecalculateDimensions()
. - Removed
getPosition()
method; useoffsetTop
,offsetBottom
,offsetRight
oroffsetLeft
options. - Added
calculateOrientation()
method. - Added
inViewport()
method. - Added
isVisible()
method. - Added
refresh()
method. - Added
ch.EventEmitter
methods:on()
,once()
,off()
,emit()
,listener()
.
- Added
ch.onresize
event. - Added
ch.onscroll
event.
- Removed
onSelect
option; suscribe to theselect
event.calendar.on('select', function () {...});
- Removed
onNextMonth
option; suscribe to thenextmonth
event.calendar.on('nextmonth', function () {...});
- Removed
onPrevMonth
option; suscribe to theprevmonth
event.calendar.on('prevmonth', function () {...});
- Removed
onNextYear
option; suscribe to thenextyear
event.calendar.on('nextyear', function () {...});
- Removed
onPrevYear
option; suscribe to theprevyear
event.calendar.on('prevyear', function () {...});
- Removed
type
property; usename
. - Removed
element
property; use$container
.
- Removed
reset()
method. - Removed
today()
method; usegetToday()
. - Removed
to()
method; usesetTo()
. - Removed
from()
method; usesetFrom()
. - Removed
next()
method; usenextMonth()
ornextYear()
methods. - Removed
prev()
method; useprevMonth()
orprevYear()
methods. - Removed
trigger()
method; useemit()
. - Added
getListeners()
method. - Added
require()
method. - Added
destroy()
method. - Added
enable()
method. - Added
disable()
method.
- Added
nextmonth
event. - Added
nextyear
event. - Added
prevmonth
event. - Added
prevyear
event.
- Removed
type
property; usename
. - Removed
element
property; use$trigger
. - Added
$container
property.
- Removed
trigger()
method; useemit()
. - Added
getListeners()
method. - Added
require()
method. - Added
destroy()
method. - Added
enable()
method. - Added
disable()
method.
- Added
exceeded
event.
### Options
-
Removed
onSelect
option; suscribe to theselect
event.datePicker.on('select', function () {...});
-
Removed
points
option; useside
andalign
. -
Removed
closable
option; usehiddenby
. -
Added
positioned
option. -
Added
offsetX
option. -
Added
offsetY
option.$('#element').datePicker({ 'closable': 'click', 'points': 'lt lt' });
$('#element').datePicker({ 'hiddenby': 'pointers-only', 'side': 'bottom', 'align': 'center' });
- Removed
type
property; usename
. - Removed
element
property; use$field
. - Added
$trigger
property.
- Removed
trigger()
method; useemit()
. - Removed
prev()
method; useprevMonth()
orprevYear()
. - Removed
next()
method; usenextMonth()
ornextYear()
. - Added
getListeners()
method. - Added
require()
method. - Added
destroy()
method. - Added
enable()
method. - Added
disable()
method.
- Added
show
event. - Added
hide
event. - Added
reset
event. - Added
nextmonth
event. - Added
nextyear
event. - Added
prevmonth
event. - Added
prevyear
event.
### Options
- Removed
open
option. - Removed
onShow
option; suscribe to theshow
event.expandable.on('show', function () {...});
- Removed
onHide
option; suscribe to thehide
event. - Added
toggle
option. - Added
content
option. - Added
container
option.
$('#element').expandable({
'open': true
});
$('#element').expandable().show();
$('#element').expandable({
'toggle': true,
'content': 'Some content!',
'container': $('#container')
});
- Removed
element
property; use$trigger
. - Removed
type
property; usename
. - Added
$container
property.
- Removed
isActive()
method; useisShown()
. - Removed
trigger()
method; useemit()
. - Added
getListeners()
method. - Added
require()
method. - Added
destroy()
method. - Added
enable()
method. - Added
disable()
method. - Added
content()
method.
- Removed
contentLoad
event; usecontentdone
. - Removed
contentError
event; usecontenterror
. - Added
contentloading
event.
Previously known as ch.Floats. It includes ch.Layer, ch.Modal, ch.Tooltip, ch.Transition, ch.Zoom and add the new widget ch.Bubble (used for validation errors).
The Floats were redesigned as Popover to be the basic unit of a dialog window. It can be instantiated as a generic widget too. Widgets that inherits from Popover, just adds specific functionality. For example, a Modal window shows and hides an underlay.
Popover also has the ability to be instantiated without the need of an existent element. It means you no longer need to create an element in memory (usually implemented with an <a>
tag) to create a widget:
$('<a>').modal();
$.modal();
- Removed
reposition
option. - Removed
onShow
option; suscribe to theshow
event.$('#element').layer().on('show', function () {});
- Removed
onHide
option; suscribe to thehide
event.$('#element').layer().on('hide', function () {});
- Removed
onContentLoad
option; suscribe to thecontentdone
event.$('#element').layer().on('contentdone', function () {});
- Removed
onContentError
option; suscribe to thecontenterror
event.$('#element').layer().on('contenterror', function () {});
- Removed
classes
option; useaddClass
. - Removed
points
option; useside
andalign
. - Removed
offset
option; useoffsetX
andoffsetY
. - Removed
event
option; useshownby
. The possible values are:shownby: 'pointertap'
instead ofevent: 'click'
(default),shownby: 'pointerenter'
instead ofevent: 'hover'
orshownby: 'none'
- Removed
closable
option; usehiddenby
. - Removed
closeButton
option; the Close button appears with'hiddenby': 'button-only'
or'hiddenby': 'all'
options. - Updated
fx:Boolean
option; usefx:Boolean || String
. - Updated
width:Number || String
option; usewidth:String
. - Updated
height:Number || String
option; useheight:String
. - Added
positioned
option. - Added
waiting
option.
$('#element').layer({
'classes': 'test',
'points': 'lt lb',
'offset': '0 10',
'event': 'click',
'closable': 'button',
'closeButton': true,
'fx': true,
'width': 100,
'height': 50
});
$('#element').layer({
'addClass': 'test',
'side': 'bottom',
'align': 'left',
'offsetX': 0,
'offsetY': 10,
'shownby': 'pointerenter',
'hiddenby': 'button',
'fx': 'fadeIn',
'width': '100px',
'height': '50px',
'positioned': 'absolute',
'waiting': '<div class="ch-loading ch-loading-centered"></div>'
});
- Removed
element
property; use$trigger
. - Removed
type
property; usename
. - Added
$container
property.
- Removed
closable()
method. - Removed
trigger()
method; useemit()
. - Removed
isActive()
method; useisShown()
. - Removed
position()
method; userefreshPosition()
. - Updated
width(Number || String)
parameters; usewidth(String)
. - Updated
height(Number || String)
parameters; useheight(String)
. - Added
init()
method. - Added
enable()
method. - Added
destroy()
method. - Added
disable()
method. - Added
getListeners()
method. - Added
require()
method. - Added
constructor()
method.
- Removed
contentLoad
event; usecontentdone
. - Removed
contentError
event; usecontenterror
. - Added
contentwaiting
event.
The Dropdown was redesigned to share most of its code (and its public API) with widgets with similar behavior. That's why now it's part of ch.Popover.
- Removed
open
option. - Removed
icon
option. - Removed
reposition
option; reposition manually using the methodinViewport()
in ch.Viewport and use this CSS for upwards Dropdown:.ch-dropdown[data-side="top"] { border-radius: 5px 5px 5px 0px; } .ch-dropdown-trigger-on[data-side="top"], .ch-dropdown-trigger-on[data-side="top"]:hover { border-radius: 0 0 3px 3px; }
- Removed
onShow
option; suscribe to theshow
event.$('#element').dropdown().on('show', function () {});
- Removed
onHide
option; suscribe to thehide
event.$('#element').dropdown().on('hide', function () {});
- Removed
points
option; useside
andalign
. - Updated
fx:Boolean
option; usefx:Boolean || String
. - Added
addClass
option. - Added
offsetX
andoffsetY
. - Added
shownby
option. The possible values are:shownby: 'pointertap'
(default),shownby: 'pointerenter'
orshownby: 'none'
- Added
hiddenby
option. - Added
skin
option. This replaces the old way of instantiate a Dropdown skin, where you added the CSS classch-dropdown-skin
to the main HTML element. - Added
shortcuts
option. - Added
width
option. - Added
height
option. - Added
positioned
option. - Added
waiting
option.
$('#element').dropdown({
'open': false,
'icon': true,
'reposition': true,
'points': 'lt lb',
'fx': false
});
$('#element').dropdown({
'side': 'bottom',
'align': 'left',
'fx': 'fadeIn',
'offsetX': 0,
'offsetY': 10,
'shownby': 'pointerenter',
'hiddenby': 'pointerleave',
'skin': true,
'shortcuts': true,
'width': '100px',
'height': '50px',
'positioned': 'absolute',
'waiting': '<div class="ch-loading ch-loading-centered"></div>'
});
- Removed
element
property; use$trigger
. - Removed
type
property; usename
. - Added
$container
property.
- Removed
trigger()
method; useemit()
. - Removed
isActive()
method; useisShown()
. - Removed
position()
method; userefreshPosition()
. - Added
init()
method. - Added
enable()
method. - Added
destroy()
method. - Added
disable()
method. - Added
getListeners()
method. - Added
require()
method. - Added
constructor()
method. - Added
width
method. - Added
height
method. - Added
content
method.
- Added
contentdone
event. - Added
contenterror
event. - Added
contentwaiting
event.
- Removed
page
option. - Removed
width
option; it's an adaptive widget, so set a width in CSS for the element that wraps the Carousel in your layout. - Removed
onNext
option; suscribe to thenext
event.$('#element').carousel().on('next', function () {});
- Removed
onPrev
option; suscribe to theprev
event.$('#element').carousel().on('prev', function () {});
- Removed
onRedraw
option; suscribe to theredraw
event.$('#element').carousel().on('redraw', function () {});
- Removed
onSelect
option; suscribe to theselect
event.$('#element').carousel().on('select', function () {});
- Removed
onItemsAdded
option; suscribe to theaddeditems
event.$('#element').carousel().on('addeditems', function () {});
- Removed
asyncData
andasyncRender
options; useasync
option andaddeditems
event:$('#element').carousel({ 'async': 10 }).on('addeditems', function ($items) { // Inject content into the added <li> elements $.each($items, function (i, e) { $(e).html('Content into one of newly inserted <li> elements.'); }); });
- Removed
maxItems
option; uselimitPerPage
. - Updated
arrows:String
option; usearrows:Boolean
. Now, when there is no arrows, you should handle the mask margin with CSS:.my-own-carousel .ch-carousel-mask { margin: 0; }
$('#element').carousel({
'width': 300,
'page': 2,
'asyncData': ['First', 'Second', 'Third'],
'asyncRender': function (a) { return a + 'element'; },
'maxItems': 2,
'arrows': 'over'
});
$('#element').carousel({
'async': 3, // Use 'addeditems' events to inject content into the new <li> elements
'limitPerPage': 2,
'arrows': false
});
- Removed
type
property; usename
. - Removed
element
property.
- Removed
arrows()
method. - Removed
page()
method. - Removed
itemsPerPage()
method. - Removed
play()
andpause()
methods; use the extension ch.carousel.autoSliding.js from the /extension folder in repository. - Removed
redraw()
method; userefresh()
. - Removed
trigger()
method; useemit()
. - Added
init()
method. - Added
enable()
method. - Added
destroy()
method. - Added
disable()
method. - Added
getListeners()
method. - Added
require()
method. - Added
constructor()
method.
- Removed
redraw
event; userefresh
. - Removed
itemsAdded
event; useaddeditems
.
### Options
- Removed
onSelect
option; suscribe to theselect
event.tabs.on('select', function () {...});
- Removed
onContentLoad
option; suscribe to thecontentdone
event.tabs.on('contentdone', function () {...});
- Removed
onContentError
option; suscribe to thecontenterror
event.tabs.on('contenterror', function () {...});
- Removed
selected
option.
- Removed
element
property; use$container
. - Removed
children
collection; usetabpanels
. - Removed
type
property; usename
. - Added
$panel
property. - Added
$triggers
property.
- Removed
isActive()
method; useisShown()
. - Removed
trigger()
method; useemit()
. - Removed
select()
method; useshow()
. - Added
getListeners()
method. - Added
require()
method. - Added
destroy()
method. - Added
enable()
method. - Added
disable()
method. - Added
content()
method. - Added
getShown()
method.
- Removed
contentLoad
event; usecontentdone
. - Removed
contentError
event; usecontenterror
. - Added
contentloading
event. - Added
select
event.
### Options
- Removed
onSelect
option; suscribe to theselect
event.menu.on('select', function () {...});
- Removed
selected
option.
- Removed
element
property; use$container
. - Removed
type
property; usename
. - Added
fold
collection.
- Removed
trigger()
method; useemit()
. - Removed
select()
method; useshow()
. - Added
getListeners()
method. - Added
require()
method. - Added
destroy()
method. - Added
enable()
method. - Added
disable()
method. - Added
content()
method. - Added
hide()
method.
The ch.Form
API has been redesigned to easy manipulation. Now, you have more control on the submit event and you decide what you want to do.
- Removed
beforeSubmit
option. - Removed
afterSubmit
option. - Removed
afterValidate
option. - Removed
beforeValidate
option; suscribe to thebeforevalidate
event.form.on('beforevalidate', function () {...});
- Removed
onValidate
option; suscribe to thesuccess
event.validation.on('success', function () {...});
- Removed
onError
option; suscribe to theerror
event.validation.on('error', function () {...});
- Removed
onClear
option; suscribe to theclear
event.validation.on('clear', function () {...});
- Removed
onReset
option; suscribe to thereset
event.validation.on('reset', function () {...});
- Removed
messages
property. - Removed
element
property; use$container
. - Removed
type
property; usename
. - Removed
children
collection; usevalidations
. - Added
errors
collection.
- Removed
submit()
method. - Removed
trigger()
method; useemit()
. - Removed
isValidated()
method; usehasError()
. - Added
getListeners()
method. - Added
require()
method. - Added
destroy()
method. - Added
enable()
method. - Added
disable()
method.
-
Removed
beforeSubmit
,afterSubmit
andsubmit
events. Use native event:form.on('beforeSubmit', function () {...}); form.on('submit', function () {...}); form.on('afterSubmit', function () {...});
$('.myForm').on('submit', function (event) { // Some code here! if (!form.hasError()) { event.preventDefault(); // Some code here! } });
-
Removed
afterValidate
event. -
Removed
validate
event; usesuccess
.form.on('success', function (event) { event.preventDefault(); // Some code here! });
-
Removed
beforeValidate
event; usebeforevalidate
. -
Updated
error
event; it now receives a collection with errors:form.on('error', function (errors) {...});
The ch.Validation
API has been redesigned to easy manipulation. You can use validations interfaces: ch.Custom
, ch.Required
, ch.String
, ch.Email
, ch.Url
, ch.MaxLength
, ch.MinLength
, ch.Number
, ch.Max
and ch.Min
.
- Removed
ch.Price
- Removed
classes
option. - Removed
beforeValidate
option. - Removed
afterValidate
option. - Removed
beforeValidate
option; suscribe to thebeforevalidate
event.validation.on('beforevalidate', function () {...});
- Removed
onValidate
option; suscribe to thesuccess
event.validation.on('success', function () {...});
- Removed
onError
option; suscribe to theerror
event.validation.on('error', function () {...});
- Removed
onClear
option; suscribe to theclear
event.validation.on('clear', function () {...});
- Removed
content
option; usemessage
.$('#element').required({ 'message': 'Some message!' })
- Removed
condition
option; useconditions
. - Removed
context
option; usereference
. - Removed
points
option; useside
andalign
. - Removed
offset
option; useoffsetX
andoffsetY
.
$('#element').validation({
'condition': {
'name': 'required'
},
'context': '#context',
'points': 'lt rt',
'offset': '10 0'
});
$('#element').validation({
'conditions': [
{
'name': 'required'
},
{
'name': 'custom-name',
'fn': function (value) { return value === "custom";},
'message': 'This is a custom validation.'
}
],
'reference': $('#reference'),
'offsetX': 10,
'offsetY': 0,
'side': 'left',
'align': 'top'
});
- Removed
validator
property. - Removed
element
property; use$trigger
. - Removed
helper
property; usebubble
. - Removed
float
property; usebubble
. - Removed
type
property; usename
. - Added
error
property. - Added
conditions
property.
- Removed
toggleEnable()
method. - Removed
isActive()
method; useisShown()
. - Removed
float.position()
method; usebubble.refreshPosition()
. - Removed
trigger()
method; useemit()
. - Added
getListeners()
method. - Added
require()
method. - Added
destroy()
method.
- Removed
beforeValidate
event. - Removed
validated
event; usesuccess
.validation.on('success', function () {...});
- Removed
afterValidate
event.
The ch.Custom
API has been redesigned to create and manipulate multiple custom
validations instance with the same trigger.
Now, you should give a name to your custom
validations.
$('#element').custom(function (value) {
return value === 'Something';
}, 'This is a custom Validation!');
$('#element').custom('some-name', function (value) {
return value === 'Something';
}, 'This is a custom Validation!');
- Removed
url
. - Removed
content
. - Removed
suggestions
. - Removed
jsonpCallback
. - Removed
points
option; useside
andalign
.
var ac = $('.example').autoComplete({
'url': 'http://www.chico-ui.com.ar/suggest?q=',
'jsonpCallback': 'autoComplete'
});
function autoComplete(data) {
ac.suggest(data);
}
var ac = $('.example').autoComplete();
ac.on('typing', function (userInput) {
$.ajax({
'url': 'http://www.chico-ui.com.ar/suggest?q=' + userInput + '&callback=ac.suggest',
'dataType': 'jsonp',
'cache': false,
'global': true,
'context': window,
'jsonp': 'ac.suggest',
'crossDomain': true
});
});
Example with the MercadoLibre API
var mercadolibre = $('.autoComplete3').autoComplete();
var parseMLAPIResults = function (results) {
var data = [];
results[2].suggested_queries.forEach(function (e, i) {
data.push(e.q);
});
mercadolibre.suggest(data);
}
mercadolibre.on('typing', function (userInput) {
$.ajax({
'url': 'http://suggestgz.mlapps.com/sites/MLA/autosuggest?q='+ userInput +'&v=1&callback=parseMLAPIResults',
'dataType': 'jsonp',
'cache': false,
'global': true,
'context': window,
'jsonp': 'parseMLAPIResults',
'crossDomain': true
});
});
- Added
typing
To expand the messages boxes variety, now you have to include the icon by yourself and the CSS class name ch-box-icon
to the container:
<div class="ch-box-error">Oops, something wrong happened</div>
<div class="ch-box-icon ch-box-error"><i class="ch-icon-remove-sign"></i>Oops, something wrong happened</div>