keikai (5 Part Series)
1 How I Created an Online Budget Report from Excel Files
2 Enable User Input in My Spreadsheet-based App
3 Automate Excel Sheet Processing with Java
4 Protect Formulas in a Web Spreadsheet Application
5 Give your classic spreadsheet a modern touch
Spreadsheets are no doubt the most popular business application – they are heavily used in all fields, favored by users from finance experts in Wall Street to top scientists in NASA. Spreadsheets allow users to calculate, organize and store data, and most important of all, analyze data without having to program.
Nowadays spreadsheets extend their reach more – they no longer sit inside a user’s Excel desktop application, they are now widely used online, either being embedded inside applications or run on an online platform like google sheets.
But when a spreadsheet goes online, can we do more than just duplicating Excel’s functionality into the browser?
More Than a Spreadsheet
While spreadsheets are great for displaying tabular data, presenting forms or charts, it is not always great to display a large block of text or display images and other elements that have varied dimensions.
This is where we can leverage today’s fancy and easy-to-use web UI components to work with an online spreadsheet and upgrade spreadsheet users’ experience.
Here I am taking Keikai spreadsheet and a ZK drawer component as an example demonstrating how this can be done. In this example, we will add a slide-in/out Help panel to our spreadsheet where we can display large blocks of Help text in a much more easy-to-read format.
Let me show you how to build this page.
Load the Form
I can load my helpTemplate.xlsx
in a zul by specifying src
at <spreadsheet/>
.
formHelp.zul
<spreadsheet id="ss"
height="100%" width="60%"
style="margin: 0 auto;"
src="/WEB-INF/books/helpTemplate.xlsx"
maxVisibleRows="40" maxVisibleColumns="5"/>
Enter fullscreen mode Exit fullscreen mode
Other attributes of the tag determine spreadsheet looking; please refer to Keikai Developer Reference.
Put a help page along with Keikai
There are 5 blocks of numbers in the form above. Hence, I create an HTML page and put help descriptions into 5 different color boxes. Each box has a corresponding help box with the same background and title. So people who read the help page can easily identify which help text matches their needs for the current block.
Then I use <include>
component to include that help HTML into <drawer>
.
<spreadsheet .../>
<drawer id="helpDrawer" visible="false"
position="right" width="40%">
<include src="help.html"/>
</drawer>
Enter fullscreen mode Exit fullscreen mode
-
visible="false"
means it’s hidden by default, so you won’t see the drawer at first. But users can click the “Help” cell to show the help.
Note, this is just a simple example; you can definitely put any other HTML content (images, videos…) to the help page based on your own context.
Allow Users to Show Help Page
To show the help panel when a user clicks the Help button (cell), I need to add an event listener for the cell click event in a controller.
Keikai supports the MVC pattern, so it’s better to implement my application logic in a controller better OO design. The controller looks like this:
public class HelpTextComposer extends SelectorComposer {
@Wire
private Drawer helpDrawer;
@Listen(Events.ON_CELL_CLICK + " = spreadsheet")
public void showHelpText(CellMouseEvent e){
Range cell = RangeHelper.getTargetRange(e);
if (cell.getCellValue() != null
&& cell.getCellValue().toString().equals("Help")) {
helpDrawer.open();
}
}
}
Enter fullscreen mode Exit fullscreen mode
-
SelectorComposer
helps me to get a reference ofhelpDrawer
which is instantiated by ZK framework. That’s why I declare a variable ofDrawer
without instantiating its object. -
@Listen
can register the method as an event listener forEvents.ON_CELL_CLICK
of the spreadsheet. So when a user clicks a cell, ZK will invoke this method. -
RangeHelper.getTargetRange(e)
returns aRange
that represents the clicked cell. Then I can check the cell’s value bycell.getCellValue().toString()
to know whether a user clicks the “Help” cell or not. -
helpDrawer.open()
makes the drawer slide in.
Summary
Spreadsheets are brought online for easier sharing and collaboration. But we can do more! This example uses Keikai Spreadsheet and ZK components to demonstrate how you can leverage rich UI components to upgrade user’s spreadsheet experience while preserving its benefits.
Source Code
You can see the complete source code in Keikai developer reference repository.
keikai (5 Part Series)
1 How I Created an Online Budget Report from Excel Files
2 Enable User Input in My Spreadsheet-based App
3 Automate Excel Sheet Processing with Java
4 Protect Formulas in a Web Spreadsheet Application
5 Give your classic spreadsheet a modern touch
暂无评论内容