Skip to content

jackrobertscott/forge-181201

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 
ย 

Repository files navigation

Forge

๐Ÿน Free, unobtrusive, and modern tool for developers.

Links to download a version can be found on our website.

Forge

Search by Name Use ${1:Variables} Edit in Seconds
Forge Screenshot Forge Screenshot Forge Screenshot

Overview

Forge is a tool designed to aid ๐Ÿฅ developers with basic development tasks such as creating and finding code snippets.

Problems with current tools

While designing Forge, we wanted to address the following difficulties faced when you only use a code editor while developing.

  1. ๐Ÿค” Snippet shortcuts are hard to remember e.g. rccp or conc.
  2. ๐Ÿ˜ง Creating custom snippets is really hard (usually you need to create an entire JSON page).
  3. ๐Ÿ˜  Settings don't save across your computers.
  4. ๐Ÿ˜ฉ You can't preview a snippet before you start using it.
  5. ๐Ÿ˜ณ You can't search snippets by keywords.

Features of Forge

Forge was designed to overcome these issues by providing a developer tool which complements your code editor.

  1. ๐Ÿ”ฅ Doesn't interrupt workflow; the app pops up above your editor and hides when you're done.
  2. ๐Ÿ˜ป Easier to use; search snippets by full name or shortcut.
  3. ๐Ÿ’ƒ Preview your snippets before using them.
  4. ๐Ÿ† Use ${1:variables} inside your snippets in the same way you use VS Code snippets.
  5. ๐ŸŽ Develop in-style with Forge's sleek and modern user interface.

Shortcut: press CmdOrCtrl+Shift+D to toggle the Forge app's visibility.

Technologies

The Forge repository is a testing ground for a new sort of application design architecture. We have made Forge open source so that you can preview how we use and built this application using the lastest in app development technologies.

Desktop

The desktop application is built with TypeScript and is using:

Server

The server is also built with TypeScript and is using:

  • Node.js: enables JavaScript to be run as a server.
  • Apollo GraphQL: creates a GraphQL interface for server data.
  • MongoDB: a NoSQL database which works well with Node.js.
  • mongoose: a schema validator used when working with MongoDB.

Architecture

There are very few good examples of good React application design and so we designed one. The front-end design system was the most challenging part. As such, we broke down the roles of the application into a specific modules.

  • Requests: concerned with saving and retrieving data from persistent data sources.
  • Logics: maps data from our requests to our graphical layouts.
  • Layouts: concerned with the structure and composition of the data and visual components.
  • Visuals: manages all the visuals on the page such as color, size, and spacing.

Authors

  • Jack Scott @jacrobsco - I tweet about coding and startups.