The United States government is a wide-reaching entity with many facets and departments that focus on a wide range of problems to solve and things to keep track of. Since SpreadJS can be used in many different scenarios, we can use it to create a simple government application that can be expanded upon. In the case of this application, we will create a tracker for government bids, a compliance checklist, and a contract management dashboard.
Download the sample for this blog and follow along.
Ready to check out more from SpreadJS? Download Our 30-Day Free Trial Today!
Creating the Template
To get started, we can put together a template workbook in the Desktop SpreadJS Designer. This workbook will have three sheets:
We can create these three sheets and then add the content to them. For the bid tracker sheet, all we need is a title and a simple table, which we can name “BidTable”:
The Bid Tracker sheet in the SpreadJS Designer
Our table can have any number of rows, as we will add the data in the code.
The next sheet is the Compliance Checklist, a simple form to which users can add data. As such, we will need to make sure we lock down specific cells to prevent users from changing them. We can do this by simply selecting the cells we want users to be able to add data to and navigating to HOME>Cells>Format>Unlock Cells:
Unlocking cells in the SpreadJS Designer
When you’ve done that for all of the cells you want to edit, navigate to HOME>Cells>Format>Protect Sheet… and select only the “Select unlocked cells” option. In addition, we can set a password to unprotect the sheet in this same dialog:
Protecting the sheet in the SpreadJS Designer
The last sheet we are putting together is the Contract Management sheet, which has a simple table on it. We will add the rest in the code:
The Contract Management sheet in the SpreadJS Designer
Bid Tracker
The bid tracker sheet is just a simple table with some conditional formatting, so we can go ahead and load the data from “data.js” into the table:
We can also add currency formatting to the Amount column:
Finally, we can add conditional formatting to the Amount column, in this case, a data bar:
The final Bid Tracker sheet
Compliance Checklist
Regarding the Compliance Checklist, the work was finished in the SpreadJS Designer. We were able to add the text, format the cells, unlock specific cells, and protect the sheet, so no further work is needed:
The finished Compliance Checklist sheet
You’ll notice that due to the options we changed in the SpreadJS Designer, we can only select and change specific cells, particularly the cells where data needs to be entered.
Contract Management
Contracts are a big part of the US government, especially with the amount of products and services that the government buys. Keeping track of all the contracts can be immensely useful so that we can create a sheet in our application showing the contracts and their amounts.
As with the other sheets, we have data in a separate “data.js” file so that we can load that data into the table we created:
We also need to add formatting for the Original, Forecasted, and Invoiced Amount columns to format them as currency, so we can just set a formatter:
The last things we need to add to the Contract Management sheet are the charts, such as a doughnut chart for the Invoice Amount column and a column chart for all the contract amounts. We can start with the doughnut chart. We need to create the chart based on the Invoice Amount column and set the Contract column as the labels for the chart:
For the column chart, we want to have three different series, one for each amount. So we can create the column chart based on the whole table and then just set the xValues and yValues for each series in the chart:
The final Contract Management sheet with charts
With that, we have created a simple government application. This can be expanded upon with even more features and security, and this can serve as a simple starting point.
If you want to try these features and more out for yourself, be sure to download a trial of SpreadJS today: Download JavaScript Spreadsheet | SpreadJS