Integrate D3 chart into UI5 Application

You don’t need to create custom control for charts

In my last project, I encoutered a situation that I need to incorporate d3 chart into ui5 appliation. I googled around and found some posts about this topic:

  1. Custom SAPUI5 Visualization Controls with D3.js
  2. How to Use D3 elements inside SAP UI5 , when using JS views?
  3. I even asked a question on SCN myself, What’s the best way to incorporate a d3 chart into UI5 application?

In above posts, the solution is to create a custom control for the chart, but IMO, creating a custom control in UI5 is a complicated and unpleasant task.
After some research, I found a much easier solution, you do NOT need to create custom control at all! Let me show you how.

How

For the example, I’ll embed a simple pie chart into a UI5 application. Here’s a snapshot of the final result
Final Result

Implement Reusable Chart Module

Implement a reusable chart module. I highly recommend you to read the article Towards Reusable Charts in which the author of d3 library Mike Bostoc proposed a convention for building reusable chart. Below is the code of an example chart module compliant with the reusable convention, you don’t need to go through the code, you only need to know it will generate a pie chart.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
sap.ui.define([], function () {
return function () {
// avabled configuration options
var _innerRadius = 5
var _outerRadius = 30
var _width = 60
var _height = 60

// Chart
var my = function (selection) {
selection.each(function (d, i) {
var arc = d3.svg.arc().outerRadius(_outerRadius).innerRadius(_innerRadius)
var pie = d3.layout.pie().value(function (d) {
return d.score
})

var g = d3.select(this).append('g')
.attr('transform', 'translate(' + _width / 2 + ',' + _height / 2 + ')')

g.selectAll('path')
.data(pie(d))
.enter()
.append('path')
.attr('d', arc)
.attr('fill', function (d) {
return d.data.color
})
})
}

// getter/setter for outerRadius
my.outerRadius = function (outerRadius) {
if (!arguments.length) return _outerRadius
_outerRadius = outerRadius
return my
}

// getter/setter for innerRadius
my.innerRadius = function (innerRadius) {
if (!arguments.length) return _innerRadius
_innerRadius = innerRadius
return my
}

// getter/setter for width
my.width = function (width) {
if (!arguments.length) return _width
_width = width
return my
}

// getter/setter for height
my.height = function (height) {
if (!arguments.length) return _height
_height = height
return my
}
return my
}
})

A side note about “resubale”, for a chart to be reusable, it meets the following requirements:

  1. configurable
  2. environment-agnostic

environment-agnostic means the chart should be implemented in the way that it should be told in which container and what data it should draw. In a simpler word, the container element and data should be passed in as parameters.

Put HTML Placeholder in the Page

In the xml view, insert a sap.ui.core.HTML element as the root container for our chart.

1
2
3
4
5
6
7
8
9
10
11
<mvc:View controllerName="d3inui5.view.Main"
xmlns:mvc="sap.ui.core.mvc"
xmlns:core="sap.ui.core"
displayBlock="true"
xmlns="sap.m">

<Page>
<content>
<core:HTML content="<svg id='pieChart' width='100%' height='200px'></svg>" afterRendering='draw'></core:HTML>
</content>
</Page>
</mvc:View>

Use the Chart in Controller

In the controller, use the chart like below:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
sap.ui.define([
'd3inui5/view/BaseController',
'd3inui5/chart/pieChart'
], function (Controller, pieChart) {
'use strict'

return Controller.extend('d3inui5.view.Main', {
onInit: function () {
// initialize a pie chart instance
this.chart = pieChart()
// configure the inner and outer radius for the chart
this.chart.innerRadius(40)
this.chart.outerRadius(80)
},
draw: function () {
// sample data
var data = [
{
'name': 'jun shen',
'score': 30,
'color': 'red'
},
{
'name': 'aaron',
'score': 60,
'color': 'yellow'
},
{
'name': 'atige',
'score': 137,
'color': 'purple'
},
{
'name': 'linus',
'score': 46,
'color': 'black'
},
{
'name': 'grass',
'score': 8,
'color': 'green'
}
]

// configure the width and height for the chart
this.chart.width($('#pieChart').width())
this.chart.height($('#pieChart').height())

// draw the chart
d3.select('#pieChart').data([data])
.call(this.chart)
}
})
})

That’s it, our chart has been integrated into our UI5 application. It’s super simple, there’s no overhead for creating a UI5 custom control. And out chart is highly reusable and customiziable, you can use it in other UI5 applications. you can even reuse it in non-UI5 projects. Isn’t that great?

The End

Happy coding !!!
Thanks for reading !!!
Leave comment if you have any question or comments.

Set Up Your Own Blogging Site Using Hexo

Recently, I came across github pages, github pages is a service which github helps you host your static site in github repository, it’s completely free to everyone. So I’m thinking to have my own blog site to start blogging. The first tool I started using is jekyll because it’s recommended at the bottom of github pages website.
jekyll
I played around with jekyll and octopress( a blogging framework built on top of jekyll ) for a few days. I finally give up. The reason is jekyll is written in ruby, all the thing around ruby including the language , tools and commands are just foreign to me as a javascripter. And another reason is that I feel it’s getting a little complex when octopress is involved ( maybe it’s due to the first reason, ruby is not my thing… ).

I googled around static site generator built on nodejs ( if you’re javascripter, you know the feeling we have for node ). Finally, I found Hexo, which is extremly simple, easy to use blog generator, it only took me a few minutes to get my site running on my local pc, and a few more minutes to deploy it on github pages. If you know javascript and nodejs, I highly recommend try hexo and start blogging and share your good ideas to the world! Now let’s get started! BTW, the blog you’re looking at now is the very first blog written on Hexo.

Prerequisites

Knowledge

  1. You should have some basic knowledge about git and github
  2. You’ll need to use some command line tools
  3. You’ll need to know markdown to blog

Things you need to have

  1. terminal ( I’m using iTerm2)
  2. git
  3. nodejs
  4. of course, your favorite text editor (mine is vim)
  5. github user account (prefer ssh key configured, otherwise ssh git repo url won’t work, if you use https repo url, then you’ll have to enter username and password when deploying)

Get Started

Install Hexo

Go to your terminal and enter the following command:

1
npm install -g hexo-cli

It’ll take a while to have hexo installed, have some patience and treat yourself a cup of coffee.

Init Hexo Blog Site

Create your blog site using following command:

1
hexo init [sitename]

Hexo will start initiating your initial blog site in the sitename directory. sitename is just a placeholder, choose whatever sitename you want. After done, you’ll have the directory looks like below:
initial hexo blog site structure

Running Your Blog Site Locally

In the directory of your blog site, run command:

1
hexo server

This will start a local http server serving your site on port 4000 by default, so now you should be able to open your site locally at http://localhost:4000. If everything is working fine, you should now see your blog site like below:
Local Blog Site
Your blog site is already looking great, isn’t it? And hexo has included a default “hello world” post to show you how your blog looks like.

Create Your First Post

I won’t cover all the details about how to use hexo to blog, you can find all the information on hexo’s official website. But in here, I’ll show you how easy it is to create a post and start blogging. In the blog site directory, run following command to create your first post:

1
hexo new "My First Blog on Hexo"

This will create a markdown file My-First-Blog-on-Hexo.md under source/_posts/ directory, and now if you open your local blog site again, you can see your first blog is shown on your blog site ( if you’re doing along with me, you need to use ctrl+c to terminate the previous server and run hexo server again to see the changes )
My First Blog on Hexo
Next, let’s deploy our blog site to github pages and show the world WHO I AM! (don’t carry away too far)

Create a Github Site Repository for Your User

Follow the guide on github pages to create a repository for a website fo your user. In the end, you’ll create a repository like this: youruser/youruser.github.io.

Install hexo-deployer-git npm module

In your blog site directory, run following command:

1
npm install hexo-deployer-git --save

This will install the hexo-deployer-git npm module locally as a dependency for your site, the module is a plugin to Hexo to help you deploy your site to github repository with zero effort.

Config Deploy to Git in _config.yml

There’s a _config.yml file located in root directory of your blog site. The config file is a central place where you do configuration to your whole website. Some default configuration is already in the file when Hexo initialze your blog site. You can find a tonne of available configuration option at Hexo’s website. For now, we’ll just add configuration of deploy to git at the bottom of the config file:
Deploy to Git Configuration

Deploy to Github Pages

Finally, we reach here! Now Let’s deploy to our github page repository. It’s rather simple, just run the following command in your blog site directory:

1
hexo deploy

You should see some log generated by hexo and in the end, it tells you deploy done. Congrats!!! Now you have your own blog site up and running. Quickly open url in browser to see your website: http://youruser.github.io/.

Work on Same Blog Any Time Any Where

Now you have your blog site up and running, you can start writing your wonderful blog in markdown and deploy to github pages without any issue. It’s fine for simple cases: you always blog on the same machine and you’ll bring it with you wherever you go. For a more practical scenario, the way we did lacks flexibility, for instance, you start a blog at home on your home PC, you can’t finish it immediately and you go to work and you want to continue to work on that blog on your company PC.

To be able to work on the same blog on different machines at any time, we need to use git repository. It’s really simple, probably you already know how to do that. But I’ll still elaborate the details for readers who are git and github beginners.

The theory here is: github pages will only serve static content on the master branch (it’ll be gh-pages branch for project site) of your repository. So you only need to create another branch to store your work in process blogs, and these blogs won’t be served until you deploy them to the master branch. Let’s see how to do that:

1
2
3
4
5
6
git init                        
git checkout -b source
git add .
git commit -m "initial commit"
git remote add origin git@github.com:youruser/youruser.github.io.git
git push --set-upstream origin source

What above command does:

  1. initialize your blog site directory as a git repository
  2. create a new branch: source and checkout to that branch
  3. staging all the untracked content and changed content
  4. create a commit with message “initial commit”
  5. add a remote source: origin whose url is git@github.com:youruser/youruser.github.io.git
  6. push your work in process content to the source branch of origin upstream

Now you wip content is pushed and stored on the source branch of github. Next time you want to work on that blog, you only need to pull the source branch to your local machine and keep working on that. Now You can close your laptop and go to work with confidence that you can keep working on that blog when you reach office.

Add Google Analytics to Your Site

Most sites on the internet use Google Analytics to analyze vistors. You can see how many visitors visited your site on a certain day, how wany of them are new visitors, how many of them are returning vistors, what operating systems they are using, what browsers they use, which contry which city do they come from …… a whole lot more. Google Analytics provide you all kinds of reports to help you understand your audience.
Google Aanlytics Screenshot
If you haven’t got a google account, go quickly register one, afterwards, you should be able to log into google analytics using the same account. I won’t cover how to setup your site in google analytics and start monitoring. There’re plenty of tutorials on the internet, I just did a quick google search and list two here:

  1. The Absolute Beginner’s Guide to Google Analytics
  2. 50 Resources for Getting the Most Out of Google Analytics

I’ll assume you’ve got your site configured in google analytics, and let see how to let google start analyzing your visitors. Find your site Tracking ID like shown below:
Find the Tracking ID

Make google analytics work is really simple, if you’re using some theme in your hexo blog, mine is the default theme: landscape, google analytics is already built in, you only need to configure your Tracking ID in the theme configuration. I’ll take the landscape theme as an example, open and edit the theme configuration file: themes/_config.yml, in the file, you’ll find a configuration option google_analytics:, just copy paste your Tracking ID here, save and publish your site, that’s it, really simple. I visited my site dozens of times after integrated google analytics, it’s so exciting to see the figures updated in google analytics report. There’s even some real time report, which can show you analytical information about the visitors on your site right now, isn’t that Awesome !!!

The End

Happy blogging!!!
Thanks for reading!!!
Leave comment if you have any question or comments.