EdExplorer
The App for Connecticut Education Data
The School and State Finance Project (SSFP) is a nonpartisan policy organization focused on ensuring equitable education funding for all Connecticut students. SSFP needed a web application to visualize and compare data between districts and schools.
The result: a clean, beautifully designed progressive web application with a HubSpot integration.
Phases
The Project Goals
Ingest demographic, financial, and performance data for Connecticut schools and districts and visualize it using graphs, allowing the user to compare data with ease.
"},{"color":"blue","heading":"Progressive Web Application","icon":"computer-desktop","span":"lg:row-span-1","sub_heading":"Goals","text":"Create a progressive web application allowing visitors to add the app to their home screen.*
\n* This was not an original project goal, but it was a key request from the beta testers. Read more on this in the Highlights section.
"},{"color":"blue","heading":"Print to PDF","icon":"printer","span":"lg:row-span-1","sub_heading":"Goals","text":"Allow visitors to print the data to a PDF file.
"}]}Goals
Data Import
Ingest demographic, financial, and performance data for Connecticut schools and districts and visualize it using graphs, allowing the user to compare data with ease.
Goals
Progressive Web Application
Create a progressive web application allowing visitors to add the app to their home screen.*
* This was not an original project goal, but it was a key request from the beta testers. Read more on this in the Highlights section.
Goals
Print to PDF
Allow visitors to print the data to a PDF file.
The Project Challenges
Data Availability: There were two key challenges with the availability of data.
\n- \n
- Not all data was released at the same time, with financial data often unavailable until a full year after the end of the school year. This meant we could be showing 2022/2023 data for performance metrics, but 2021/2022 data for financial metrics, on the same page. \n
- Not all Districts or Schools had the same amount of data, nor did we always have complete data sets for a full year. This meant when comparing districts or schools, there could be instances where one entity would have data for performance, and the other would not. \n
The second major challenge was importing the provided data from the SSFP Data Team.
"},{"color":"orange","heading":"Download Data","icon":"arrow-down-on-square-stack","span":"lg:row-span-1","sub_heading":"Challenge","text":"The third and final major challenge was giving the ability to allow users to download district/school data in a presentable format i.e., PDF.
"},{"color":"orange","heading":"Translation","icon":"language","span":"lg:row-span-1","sub_heading":"Challenge","text":"The application needs to be translated into 4 different languages.
"}]}Challenge
Data Availability
Data Availability: There were two key challenges with the availability of data.
- Not all data was released at the same time, with financial data often unavailable until a full year after the end of the school year. This meant we could be showing 2022/2023 data for performance metrics, but 2021/2022 data for financial metrics, on the same page.
- Not all Districts or Schools had the same amount of data, nor did we always have complete data sets for a full year. This meant when comparing districts or schools, there could be instances where one entity would have data for performance, and the other would not.
Challenge
Data Import
The second major challenge was importing the provided data from the SSFP Data Team.
Challenge
Download Data
The third and final major challenge was giving the ability to allow users to download district/school data in a presentable format i.e., PDF.
Challenge
Translation
The application needs to be translated into 4 different languages.
Project Solutions
We created a versioning system to help tackle the primary goal and numerous challenges.
\nThe client wanted to display the most recent year of data. To accomplish this, we needed to review all imported data, extract the latest information, and then present that on the front-end charts and graphs. However, this was a resource-heavy process and wasn't prudent for every request. To alleviate the load on the server, we developed a database structure to store both raw imported data and presentable frontend data.
\nThis allowed us to streamline data retrieval and optimize performance, automatically updating frontend data whenever new information was imported, ensuring that users always had access to the latest insights.
"},{"color":"orange","heading":"Data Import","icon":"arrow-up-on-square-stack","span":"lg:row-span-1","sub_heading":"Challenge","text":"The client provided raw CSV files, prompting collaboration with the data team to establish a mutually compatible format. After importing the data, we combined crucial information to generate unique keys for each data row. This facilitated the uploading of slightly modified data, ensuring that any changes would overwrite existing entries without duplication.
"},{"color":"green","heading":"Bonus","icon":"eye","span":"lg:row-span-1","sub_heading":"Challenge","text":"Creation of the database structure for raw and presentable frontend data enabled the implementation of a previewable URL without impacting production data during imports. This approach ensured seamless data deployment with zero downtime.
"}],"media":{"enabled":true,"heading":"Version System","image":{"alt":"header (1)","height":401,"max_height":401,"max_width":1141,"size_type":"auto_custom_max","src":"https://19620338.fs1.hubspotusercontent-na1.net/hubfs/19620338/header%20(1).jpg","width":1141}}}In our UX design, we prioritized the visibility and clarity of the latest dataset. It was crucial for users to easily identify the specific year associated with each metric. We also implemented this feature in a subtle and non-intrusive manner, enhancing the user experience while delivering key insights.
"},{"color":"orange","heading":"Download Data","icon":"arrow-down-on-square-stack","span":"lg:row-span-1","sub_heading":"Challenge","text":"We collaborated with the client to identify the key data points for inclusion in the PDF downloads. We then crafted a meticulously formatted document that aligns seamlessly with their brand aesthetics.
"}],"media":{"enabled":true,"heading":"UI, UX & design","image":{"alt":"header (3) (1)","height":400,"max_height":400,"max_width":1140,"src":"https://19620338.fs1.hubspotusercontent-na1.net/hubfs/19620338/header%20(3)%20(1).jpg","width":1140}}}Enabling data downloads posed challenges, especially considering the inclusion of data charts. To address this, we developed an HTML template to dynamically generate printable PDFs, incorporating data retrieved from the database. Leveraging the extensibility of Chart.js, we produced images of specific charts for integration into the PDFs.
\nRecognizing the resource-intensive nature of this process, we implemented the following steps:
\n- \n
- Upon initial request for a specific district or school, we generate the PDF. \n
- We dynamically generate graph images and gather data. \n
- The resulting PDF is saved on the server. \n
- Users are then redirected to access the PDF. \n
By following this approach, subsequent requests are instantaneous, ensuring optimal server performance without overload.
"},{"color":"orange","heading":"Translation","icon":"language","span":"lg:row-span-1","sub_heading":"Challenge","text":"To accommodate the application's translation into four languages, the downloadable PDFs also required translation. To handle this, we implemented a system to detect the user's language and generate PDFs accordingly. However, this solution introduced an additional challenge, unrelated to our initial design
"},{"color":"green","heading":"Bonus","icon":"eye","span":"lg:row-span-1","sub_heading":"Challenge","text":"As we were creating static PDF files, representing a \"snapshot\" of data at a specific time, this meant that once the data was updated, previously generated PDFs became obsolete.
\nTo address this, we utilized the Versioning System:
\n- \n
- Each new version received a unique identifier. \n
- We prefixed the PDF file with the unique identifier \n
- When a PDF for a district/school was requested, we checked if the current version of the PDF existed, and if it did, we provided it; otherwise, we generated a new one. \n
This approach ensured that all download requests provided users with the most up-to-date data available.
"}],"media":{"enabled":true,"heading":"Print to PDF","image":{"alt":"header (4)","height":800,"max_height":701.7543859649122,"max_width":2000,"size_type":"auto_custom_max","src":"https://19620338.fs1.hubspotusercontent-na1.net/hubfs/19620338/header%20(4).jpg","width":2280}}}Version System
Challenge
Data Availability
We created a versioning system to help tackle the primary goal and numerous challenges.
The client wanted to display the most recent year of data. To accomplish this, we needed to review all imported data, extract the latest information, and then present that on the front-end charts and graphs. However, this was a resource-heavy process and wasn't prudent for every request. To alleviate the load on the server, we developed a database structure to store both raw imported data and presentable frontend data.
This allowed us to streamline data retrieval and optimize performance, automatically updating frontend data whenever new information was imported, ensuring that users always had access to the latest insights.
Challenge
Data Import
The client provided raw CSV files, prompting collaboration with the data team to establish a mutually compatible format. After importing the data, we combined crucial information to generate unique keys for each data row. This facilitated the uploading of slightly modified data, ensuring that any changes would overwrite existing entries without duplication.
Challenge
Bonus
Creation of the database structure for raw and presentable frontend data enabled the implementation of a previewable URL without impacting production data during imports. This approach ensured seamless data deployment with zero downtime.
UI, UX & design
Challenge
Data Availability
In our UX design, we prioritized the visibility and clarity of the latest dataset. It was crucial for users to easily identify the specific year associated with each metric. We also implemented this feature in a subtle and non-intrusive manner, enhancing the user experience while delivering key insights.
Challenge
Download Data
We collaborated with the client to identify the key data points for inclusion in the PDF downloads. We then crafted a meticulously formatted document that aligns seamlessly with their brand aesthetics.
Print to PDF
Challenge
Download Data
Enabling data downloads posed challenges, especially considering the inclusion of data charts. To address this, we developed an HTML template to dynamically generate printable PDFs, incorporating data retrieved from the database. Leveraging the extensibility of Chart.js, we produced images of specific charts for integration into the PDFs.
Recognizing the resource-intensive nature of this process, we implemented the following steps:
- Upon initial request for a specific district or school, we generate the PDF.
- We dynamically generate graph images and gather data.
- The resulting PDF is saved on the server.
- Users are then redirected to access the PDF.
By following this approach, subsequent requests are instantaneous, ensuring optimal server performance without overload.
Challenge
Translation
To accommodate the application's translation into four languages, the downloadable PDFs also required translation. To handle this, we implemented a system to detect the user's language and generate PDFs accordingly. However, this solution introduced an additional challenge, unrelated to our initial design
Challenge
Bonus
As we were creating static PDF files, representing a "snapshot" of data at a specific time, this meant that once the data was updated, previously generated PDFs became obsolete.
To address this, we utilized the Versioning System:
- Each new version received a unique identifier.
- We prefixed the PDF file with the unique identifier
- When a PDF for a district/school was requested, we checked if the current version of the PDF existed, and if it did, we provided it; otherwise, we generated a new one.
This approach ensured that all download requests provided users with the most up-to-date data available.
Process
Scope
Before starting the project, detailed scoping is conducted to define deliverables, anticipate potential issues, and provide accurate pricing estimates
Project Planning
Key stages (milestones), important tasks, and client meetings are mapped out, resulting in a Gantt Chart of the project timeline.
Client Kick-off
A meeting is held with the client to introduce key team members and present the project timeline.
UX (User Experience)
Significant time is dedicated to mapping out application structure, user experience, and user navigation. Feedback from the client is sought continuously to ensure rapid iteration.
Design
Once the UX is finalized, branding is layered over the UX. The thorough UX phase facilitates a smoother design implementation.
Development
Backend work begins early, allowing for concurrent progress with design. Frontend visuals are coded once designs are approved.
Beta Testing
Community users participate in beta testing, providing valuable usability feedback.
Highlights
Design System
Using Figma, we created a fresh new design system by revitalizing existing core brand elements and bringing them up to date. We utilized Tailwind CSS for an API-driven design system and configured Figma to work well with it. This kept all designs and UI elements consistent and on-brand at all times, enforcing type, color, and spacing constraints.
Chart.js
As this was a data-heavy project, we made use of the Chart.js plugin. It's extremely powerful and extensible, and we were delighted with our choice. It enabled us to accomplish all our goals, integrate into the application, allow for custom work, provide a great user experience, and reduce development time by utilizing such a robust framework.
Reactive Frontend
The core requirement was to allow users to be able to compare data between two Districts or two Schools. To make this happen, we created an intuitive user interface (UI) that allows multiple datasets to be requested, updates frontend UI elements on the fly, and ensures good SEO practices.
Progressive Web Application (PWA)
One key piece of user feedback was the desire to "install" the application onto their phones. As it wasn't in scope or budget to create a fully native iOS or Android application, we landed on a Progressive Web Application, which allows users to "save" the application to their phone start screen for easy access.
Summary
The School and State Finance Project required a sophisticated web application to facilitate the visualization and comparative analysis of data across various districts and schools.
Despite multiple technical and data-related challenges, our development and design team crafted an innovative, robust, and elegant solution, distinguished by its intuitive interface and seamless functionality.
Moreover, the integration with HubSpot added a layer of versatility, enabling efficient management and utilization of data within the platform.
At EverWonder, we thrive on embracing development and design challenges. Contact us today to explore how our expertise can empower your project.
Next case study
OneClick Data
The roofing technology experts.