Traffic management
Skills used:
- Angular
- RxJS
- AG Grid
- nx
- monorepos
- Storybook
- Jest
- Agile
Overview
Yunex Traffic is one of the biggest names in traffic management and in partnership with TfL they embarked on the process build a new application for intelligent, adaptive network control.
As part of this process I was contracted to work on their utc-config application and Angular component library to help integrate new features required by TfL. Working in a large agile team I would colabarate with the other UI developers, as well as C++ backend developers, testers, and product owners.
Improving code quality
Yunex's array of software is vast and complex and much of their web based UIs relied on a library of common Angular components. These components had served the team well, however when these components required modification to accommodate new features the number of bugs and regression issues began to increase.
To combat this I began work to introduce Jest unit tests to the component library. This helped with the team's confidence that existing functionality would still work as expected as new features were added. Once unit tests were in place, I began to replace any hand coded functionality that could be provided by Angular's cdk library. This helped to reduce the number of bugs and regressions further, as well as reducing the amount of code required to maintain the library.
It was also imperative that we kept dependencies up to date to ensure the application was secure. Utilising nx and Angular's upgrade tools as well as npm-check made regular updates go smoothly with minimal disruption and refactoring.
Designing new features
As part of the project many new features needed to be added to the utc-config application. This was a collabartive effort where once the requirements were outlined by a product owner, a UI developer would create wireframe mockups of the user interface and the flow of the processes involved.
Once these mockups were approved, UI developers would work closely with the backend team to agree upon the best way to handle the data required by the feature, including the design of new API endpoints, or upgrading existing APIs to handle extra information.
Conclusion
Working on such a large project and complex project was a great experience. The team communicated and collaberated effectively meaning that all new features were delivered on time.