Dive into DataView with Sencha Touch 2 Beta 2
Today we’re releasing Sencha Touch 2 beta 2, which contains around 100 enhancements, examples, and bug fixes based on your feedback from last week’s beta 1. We’ve been really energized by all your positive feedback on beta 1 and would like to reiterate our appreciation for the time and energy you put in to creating apps, reporting bugs and sharing your experiences with others.
Beta 2 should be a drop-in replacement for beta 1, and as before, we have prepared a full set of release notes. We hope you’ll continue to let us know what you think of the release in the comments, twitter and your own blogs.
Download Sencha Touch 2 Beta View Release Notes
*UPDATE*: Sencha Touch 2 RC is now available. Go download that instead!
h3. Great Progress on ICS Issues
Last week we asked for your help in raising awareness of a critical performance issue with Android 4/Ice Cream Sandwich. Thanks to your participation the bug report has been starred over 250 times and last week yielded a patch from the Android team that addresses the flashing that can happen before animations.
While that’s great news, it’s only half the story so we’d like to ask for your help one more time. While the flashing is gone, we feel that Android 4 is still not performing as well as it should when it comes to animations so if you’re in favor of better animation performance on Android 4, we’d like to ask you to take a moment to click the star on this bug report to let the Android team know how much this matters to everyone building HTML5 applications.
h3. DataView Improvements
DataView is a powerful Component that enables you to render an HTML template for each record in a Store. While that’s very useful, Sencha Touch 2 raises the bar by allowing you to render entire Components for each record. This enables a wealth of new UI options and we’d like to take the rest of this post to walk you through what’s improved.
h3. Component DataView
The Sencha Touch 2 DataView offers two ways to render items from a Store: element based and component based. In 1.x only the element-based approach was available, which made it difficult to do things like add a Button to each item in a List.
Turning your element-based DataView into a component-based one is straightforward. With a template based DataView, you normally specify a store and itemTpl configuration, but with a component based DataView, you do not need to specify an itemTpl. Instead, you set the useComponents configuration to true. This tells DataView that it will be rendering components.
Next we have to tell it which types of components it will be rendering. To do this, we set a defaultType for our DataView. This tells the DataView which type of Component to create for each record.
In the example below, we’re creating a fullscreen component-based DataView that uses the kittenslistitem type to create each item (we’ll create this kittenslistitem Component in a moment). We’re also passing in a Store full of kittens. DataView will render one kittenslistitem for each kitten:
h3. Custom DataView Item
Now we have a component DataView and we’ve told it to use a component with an xtype of kittenslistitem. That hasn’t been defined yet; so let’s do that now.
It is important to note that this DataView item must extend Ext.dataview.component.DataItem. This is because this object includes important functionality to bind a specified record to the component.
Our custom DataView item will include three items:
* Ext.Img — displays an image of the kitten
* Ext.Component — displays the name of the kitten.
* Ext.slider.Slider — shows a slider component will the cuteness of the kitten.
Each of these components will be defined as a configuration in our KittenListItem class. Once the class is instantiated for each record, the configurations will be added into the item. This looks like the following:
config: {
image: true,
name: {
cls: ‘x-name’,
flex: 1
},
slider: {
flex: 2
},
layout: {
type: ‘hbox’,
align: ‘center’
}
}
});
Let’s start from the top:
* Define the KittensListItem which we will use in our component DataView
* Extend Ext.dataview.component.DataItem
* Inside the config object, add a new config called image and set it to true (this will be transformed into a Ext.Img component)
* Create another config called name. This is an object containing a cls and a flex property of 1 (this will be transformed into an Ext.Component component)
* Create another config called slider which has a default flex of 2 (this will be transformed into a Ext.slider.Slider)
* And finally give it a HBox layout and vertically align the items in the center.
For each new configuration we create, we need to create the appropriate apply and update methods so they get transformed into the correct component, and inserted into this item. Lets do this for the image configuration:
updateImage: function(newImage, oldImage) {
if (newImage) {
this.add(newImage);
}
if (oldImage) {
this.remove(oldImage);
}
}
First, we define the applyImage which is called when this component is initialized and each time the image configuration is changed. In the method, we use Ext.factory to transform the configuration into a Ext.Img component. We then define the updateImage method which is called after applyImage. This method gets called with two arguments: the new image, and the old image (if one existed before). In this method we simply check if newImage exists and add it to this component Data Item, and the same for the oldImage, except in this case we’re removing it.
We then repeat this process for the other two configurations: name and slider.
If you want to learn more about how the Class System works, there is a great guide written by Jacky Nguyen in the Sencha Touch 2 Documentation.
h3. Mapping the Record to the DataItem
Now we have the component data item created which will be used in our DataView. The three new configurations we created are automatically transformed into components and added into the item. The next step is configuring the map between the record and the item displayed in the list. Remember we have three fields we need to map:
* name -> html config of the name component
* image -> src config of the image component
* cuteness -> value config of the slider component
To do this, we use the dataMap configuration in our DataItem. This configuration allows us to map a setter of a configuration in our DataItem to a field in the record bound to our DataItem. Lets look at an example:
dataMap: {
getImage: {
setSrc: ‘image’
}
}
}
Once this DataItem is added into DataView and the record is updated, this will essentially do this:
As you can see, it is using the getter for our new image config, then calling the src setter on the Ext.Img component with the image field of our record.
We now repeat this process for the name and cuteness fields, so the appropriate components are updated. And the final dataMap is:
dataMap: {
getImage: {
setSrc: ‘image’
},
getName: {
setHtml: ‘name’
},
getSlider: {
setValue: ‘cuteness’
}
}
}
Now that the DataItem is mapped to the record, we can load up our example in a browser. And when we add some CSS sparkle, the demo will look a little like this:
h3. Conclusion
You can view a live demo of this example on Sencha Labs and the full source code (with lots of comments!) over on GitHub.
The enhanced DataView in Sencha Touch 2 Beta 2 makes it easy to build complex data bound lists. If you have issues or find bugs with the beta, feel free to drop by our forums and let us know. We’re actively hunting down and fixing bugs, so let us know if there are things you’re expecting to work that just aren’t.
We’re excited to announce the official release of Rapid Ext JS 1.0, a revolutionary low-code…
The Sencha team is pleased to announce the availability of Sencha Architect version 4.3.6. Building…
Sencha, a leader in JavaScript developer tools for building cross-platform and enterprise web applications, is…