
Complish
JavaScript, Vue, Pusher, TipTap/ProseMirror, Gitlab
Joining the skilled & agile fully remote team at Complish I was excited to leap back into the startup world. My primary task: to build a collaborative asynchronous Discussions feature (think of a mash up between Google Docs & Notion). Easy, right? Well, not exactly.
Our first attempt was to use Quill along with Pusher and Vuex ORM to achieve our goal. This went pretty well, the Pusher & ORM side of things went off without a hitch. However, we found that Quill wasn't flexible enough for our needs so we started to look elsewhere and that's when we found TipTap (powered by ProseMirror).
Fortunately we also had the foresight of building out a seperate integration layer between the editor and our state so swapping editors would be a relatively painless task. TipTap provided a nice layer for interacting with Vue components in the editor, while ProseMirror allowed us to really harness the power of the editor and customize it however we see fit. It was exactly what we needed as we were able to achieve our goal of a performant, collaborative, feature rich, and asynchronous editor.