Starting in a joint Head of Product and Lead Front-end Engineer at Q-CTRL I was involved in the conception and build of BLACK OPAL for Alpha, Beta and public release. It was my responsibility to take the ideas from the CEO and team and bring them together into an application called BLACK OPAL. By the time I left I was managing two other developers and helping direct the overall development of the platform with Lead Back-end Engineer Kevin Nguyen.
BLACK OPAL is a React application which allows users to analyse the performance of single and multi-qubit gates, download quantum controls, download and run experiments to analyse noise sources disrupting their quantum hardware and generate optimised controls.
The Front-end application was bootstrapped with Create React App, packages were managed with yarn, made use of Redux for state management, React Router for routing, Reselect to compute derived data allowing Redux to store the minimal possible state, React Redux Form to create forms, react-intl for internationalisation, Enzyme and Jest for unit and integration tests, Styled Components for css-in-js components, grid-styled for a flex box grid system and styled-system to provide design system utilities for styled-components. Code was formatted with Prettier and Storybook was used for UI development.
The product leveraged the Google stack for a server-less architecture, using Firebase for hosting, data and authentication and event-driven processing with Cloud Functions. We integrated with Stripe for Payments and Segment for analytics.
The Front-end application would listen for updates in the Firebase realtime database and use this data to populate the state via Redux. When a user would make a change it would be updated in the realtime database where Cloud Functions would then make the appropriate API calls and return the data to the realtime database which would automatically update in the front-end.
Circle CI was setup and used for Continuous Integration, deploying the application to Firebase and hosting the Storybook on Netlify.