Page:
							Third party software and services
						
						
					
					
							Pages
							
							
								Access dev database
							
								Access power user features
							
								Access url params in a view
							
								Accessing data through data attribute
							
								Add a Mongoose Model
							
								Add a collection schema
							
								Add a collection
							
								Add a form
							
								Add a route
							
								Add a view
							
								Add basic REST endpoints for a collection
							
								Add events to a view
							
								Add methods for special server endpoints
							
								Add space between elements
							
								Adventurer Home
							
								Aether
							
								Ambassador Home
							
								Archmage Home
							
								Artisan Home
							
								Artisan How To Index
							
								Autocomplete Tuning
							
								Building A Level
							
								Call server from view
							
								Change player level
							
								Chat Room Rules
							
								Chat Room
							
								Chief Artisan Level Audition
							
								Client models
							
								Coco Models
							
								Coding Guidelines for Artisans
							
								Coding Guidelines
							
								Component Authoring Guide
							
								Component
							
								Components And Systems Tabs
							
								Connect Backbone to new collection
							
								Cookbook
							
								Debug a template
							
								Dev Setup: General Information
							
								Dev Setup: Issues
							
								Dev Setup: Linux
							
								Dev Setup: Mac
							
								Dev Setup: Vagrant
							
								Dev Setup: Windows
							
								Developer organization
							
								Diplomat Home
							
								Edit page translations
							
								Editing Thang Components
							
								Educational Standards
							
								Events, subscriptions, shortcuts
							
								File system
							
								Git Policies
							
								Goals
							
								HOWTO: Create static teacher page
							
								Handle a server error
							
								Home
							
								Important Artisan Concepts
							
								Inspect a view
							
								JSON Schema
							
								Keyboard Shortcuts
							
								Level editor
							
								Make yourself admin
							
								Mission statement
							
								Multiplayer
							
								Organize a complicated template
							
								Permissions
							
								Programming Concepts
							
								Project Ideas List
							
								Referee Scripting
							
								Run dev client on prod db
							
								Sample Code
							
								Scribe Home
							
								Scripts Tab
							
								Scripts
							
								Settings Tab
							
								Show data in a view
							
								Simplify Collision
							
								Start a New Level
							
								Surface
							
								System
							
								Tasks Tab
							
								Technical overview
							
								Test client interface
							
								Test client
							
								Test server endpoint
							
								Testing
							
								Thang Component System
							
								Thang
							
								Thangs Tab
							
								Third party software and services
							
								Tome
							
								Translate page strings
							
								Treema
							
								Versioning
							
								Views
							
								World
							
								i18n Glossary es 419
							
								i18n Glossary nb
							
								i18n Glossary ru
							
								i18n
							
						
					No results
				
					9 
					Third party software and services
					
				
						
						themaka edited this page 2015-11-02 12:27:24 -05:00 
					
				This is not an exhaustive list, but these are the most important for you to know about. We rely heavily on open source code and high quality services to speed development and focus on building CodeCombat, and these tools are what inspire us to open source our own work as well, to give back to the community that has given us all this.
You don't need to learn how to use all of these tools, but please take some time to familiarize yourself with at least the ones you'll be using for the area(s) you'd like to work on.
Core Languages
- CoffeeScript: Used throughout the site instead of JavaScript. If you're familiar with Python or Ruby then you'll feel right at home. If you're familiar with JavaScript, you'll find CoffeeScript seeks to fix many of JavaScript's faults and, we think, does a pretty good job.
- Jade: HTML needs to be rendered on the client. Jade files get compiled into JavaScript functions that, given a context object, returns an HTML string. All our pages are written in Jade; use it rather than other HTML generation methods like jQuery.
- Sass: These are compiled in to CSS files and provide many nice features CSS does not have.
- Markdown: Used for static HTML strings, such as in database text documents or incorporated in some text-heavy Jade templates (see the legal page for an example). We use Marked as our Markdown processor.
Server-side
- Node.js: The web server.
- Express: The web framework.
- MongoDB: The database. Beyond standard collections, we also use the MongoDB search indexing and GridFS.
Libraries available on the server
- Passport: Authentication. Right now we just use it for authentication through passwords, but one project is to expand the site's login options through it.
- Mongoose: An interface for MongoDB that turns documents into active records. We mainly use their plugin system to share certain logic between multiple collections, for versioning, naming, searching and permissions.
- TV4: JSON-Schema validation. Whole other article on this subject.
- Request: Simpler request handling, used in testing to test query the test server, and on the production server to interact with HTTP APIs for services like Facebook and Google.
- Lo-Dash and Underscore.String: Great utility libraries.
- Async: Various utility methods for doing all sorts of fun asynchronous tricks. We mainly have used its waterfall method to do a serial string of checks on User documents when they are changed.
- Winston: Logging library for Node.js.
- Bayesian Battle: A library Michael wrote for ranking multiplayer skill based on one-on-one matches.
Browser-side
Site-wide Libraries
- Backbone.js: Provides a lot of the basic structure we use. The classes they provide are subclassed and extended. Each collection in the database has a parallel Backbone Model and each page on the site has one View which can contain many more Views. The Event system is also used, though perhaps underutilized for objects other than Views.
- Validated-Backbone-Mediator: A mediator so wide-spread classes and views can communicate with one another more easily, now with JSON Schema validation.
- jQuery: Used largely for manipulating DOM elements. When it comes to utilities, Lo-Dash tends to be used instead.
- jQueryUI: autocomplete and others.
- Keymaster: Keyboard bound events.
- Bootstrap: Used mainly for styling and its JavaScript components. Scaffolding isn't really used.
- Moment: Formats times and dates.
- Treema: Custom built library for editing schema-defined JSON data. Used for all editors.
- jsondiffpatch: Adds support for showing diffs and patching JS objects.
- i18next: Handling our i18n needs (CodeCombat is translated into 45+ languages).
- d3: Data vis!
- Zatanna: Manages CodeCombat-style autocomplete for the ACE editor.
- nanoScroller.js: For when you need those scrollbars to get out of the way until you use them.
- Modernizr: Helps with browser feature detection and fallbacks.
- Flying Focus: Makes it easier to see what your browser focus is doing.
- Lo-Dash, Underscore.String, and TV4 are also available in the browser.
Gameplay Libraries and Services
- CreateJS: A suite of four libraries, all of which are used extensively for animation, tweening, sound and loading resources. It has its own internal event system, so that's used in lieu of Backbone events when required.
- ACE: The code editor in game, and also used when editing code everywhere else on the site.
- Box2D: Physics engine.
- Aether: Custom built library for running and deeply analyzing code. Used in gameplay to show things like what code is running at any given frame or where the code breaks and why. Transpiles multiple programming languages to JavaScript.
- Firebase: Service that synchronizes data between multiple clients. Used for synchronizing gameplay data when multiple people are playing on the same level. We also plan to use it for other inter-player communications, like chatting with friends or inviting other players to join in a campaign.
- Firepad: Collaborative text-editor built on top of Firebase, used in CodeCombat's code editor.
Other tools
- Jasmine: Used for testing.
- BrowserStack: Used for browser compatibility testing.
- Karma: Test runner.
- Brunch: Assembles the project, and is pretty much central to everything development.
- Discourse: Actually good forum software. CodeCombat is blessed by Jeff Atwood and Discourse.
- SETT: High-engagement blogging software. Good for startup blogging.
- Home
- Archmage Home
- Artisan Home
- Adventurer Home
- Scribe Home
- Diplomat Home
- Ambassador Home
- Archmage General
- Mission statement
- Coco Models
- Coding Guidelines
- Cookbook
- File system
- JSON Schema
- Technical overview
- Testing
- Third party software and services
- Artisan General
- Building A Level
- Coding Guidelines for Artisans
- Editing Thang Components
- Important Artisan Concepts
- Keyboard Shortcuts
- Artisan How-To Index
- Adventurer General
- Scribe General
- Diplomat General
- i18n
- i18n Glossary nb
- i18n Glossary ru
- i18n Glossary es-419
- Ambassador General
- Dev Setup
- Dev Setup: Linux
- Dev Setup: Windows
- Dev Setup: Mac
- Dev Setup: Vagrant
- Dev Setup: Issues
- Game Engine
- Component
- Multiplayer
- Surface
- System
- Thang
- Thang Component System
- Tome
- World
- Artisan Tabs
- Components And Systems
- Scripts
- Settings
- Thangs
- Other
- Aether
- Client models
- Developer organization
- Educational Standards
- Events, subscriptions, shortcuts
- Chat Room
- Chat Room Rules
- Permissions
- Project Ideas List
- Treema
- Versioning
- Views
CodeCombat | Home | Blog | Forum | Teachers | Legal | Contribute