To build an elegant and intuitive way to create captions for local mp4 videos, YouTube videos, or Vimeo videos, and be able to export these captions to SRT files.
Captioner loops through segments of videos until you have captioned it. The interface makes it intuitive to switch between captions, alter their start and end time, and create new ones. The timeline offers an interactive visualization of the entire project, providing a visual indication as to the word per minute ratio of each caption, warning authors when this ratio is too high.
I use my design system, Sancho-UI, to achieve an accessible and interactive design. React and Typescript are used on the front-end code, while I make use of Firebase for its authorization and database features.
To create a course delivery platform that embodies the best of Visual Thinking Strategies, which emphasizes learning through collaboration and observation.
Our course delivery system operates as a collaborative canvas in which the user is encouraged to actively engage with course materials and their peers. As you engage with video, documents and images, you are asked questions and encouraged to create annotations. We use timeline visualizations that mark course progress and highlight interactions with your collaborators. The result is a highly dynamic, interactive course taking experience that visually reflects your contributions to the course.
Watershed uses React on the front-end and consumes an Express delivered GraphQL API on the backend. We utilize websockets to provide real-time chat functionality, Postgres and Redis for databases, and we use styled-components to develop our own design system.
To build an elegant way to maintain a shared recipe collection with family and friends.
Each user of Julienne can maintain their own recipe collection, but they can also follow other users. You can then view the recipe collection of each user, or you can search the entire collection of recipes for all of the users you are following. The user interface is responsive, and works well on both mobile and desktop devices.
Julienne uses my design system, Sancho-UI to create a responsive and accessible design. Firebase is used to manage authorization and data persistence. React and Typescript are used to build all of the front-end code.
The Living Archives on Eugenics project wanted to create a database of eugenics related information pertaining to its history in Canada and around the world and its continued significance today.
Our highly extensible and interactive database encourages users to explore the topic of eugenics in their own way. Content in the database can partake in different modules, like a Timeline, MindMap or Globe, which reveals different connections between database entries. It’s easy to switch between these modules to explore different contexts. We also developed a more traditional database interface to allow team members to input and edit content and include content in different modules.
To create an accessible, responsive and beautiful design system to quickly prototype React-based applications.
Sancho aims to treat the mobile experience as a first-class citizen, and therefore offers a set of components that work equally well on all devices. Accessibility is also a priority. All components are fully keyboard accessible and follow wai-aria guidelines. The visual appearance of Sancho is based upon my individual preferences, and incorporates my favourite aspects of Material UI, Bootstrap, and Evergreen.
Sancho is built using Typescript, React, and Emotion. Emotion (a popular CSS-in-JS library) provides predictable composition, allowing users to easily customize components. We also make heavy use of react-spring for building fluid, performant animations.
A responder system for your react application which allows you to build complex gesture based interfaces.
Beautiful, simple, & configurable toast notifications with an imperative API.
Drag and drop, grid edition. Supports multiple drop zones and touch devices.
An image gallery that supports touch gestures and lazy loading.