Code Monkey home page Code Monkey logo

forem's Introduction

New maintainer required

I am currently looking for a new maintainer for this gem. I am no longer doing any more work on this myself. Please contact [email protected] if you'd like to take over this project.

Forem - using Bootstrap

Forem, using the forem-bootstrap theme

Forem Build Status

"NO U!"

Forem is an engine for Rails that aims to be the best little forum system ever. The end goal is to have an engine that can be dropped into an application that provides the basic functionality of forums, topics and posts.

Demo

A demo application can be found at http://forem.heroku.com, and the source for this application can be found on the forem.heroku.com repository

Installation

Installing Forem is easy.

Specify Gem dependencies

If you're using Rails 3:

gem 'forem', :github => "radar/forem", :branch => "rails3"

For Rails 4, use the rails4 branch:

gem 'forem', :github => "radar/forem", :branch => "rails4"

And then one of kaminari or will_paginate

gem 'kaminari', '0.15.1'
# OR
gem 'will_paginate', '3.0.5'

Run the installer

Ensure that you first of all have a User model and some sort of authentication system set up. We would recommend going with Devise, but it's up to you. All Forem needs is a model to link topics and posts to.

Run the installer and answer any questions that pop up. There's sensible defaults there if you don't want to answer them.

rails g forem:install

Set up helper methods in your user model

Forem uses a forem_name (which defaults as to_s) method being available on your User model so that it can display the user's name in posts. Define it in your model like this:

def forem_name
  name
end

Please note that if you are using Devise, User model does not have name column by default, so you either should use custom migration to add it or use another column (email for example).

It also uses an optional forem_email method for displaying avatars using Gravatar. It defaults to email. If you don't have an email attribute on the model, define a new method:

def forem_email
  email_address
end

Require basic Forem assets

Add this line to your application.js file to load required JavaScript files:

//= require forem

Add this line to your application.css to apply required styling:

*= require 'forem/base'

Specify formatter to use

If you want to provide users with an extended formatting capability, you should pick a formatter to use. If you do not use a formatter users will not be able to insert newlines in their posts and do some other fancy stuff, however quoting will work fine.

And you're done! Yaaay!

For more information on installing, please see the "Installation" wiki page

Features

Here's a comprehensive list of the features currently in Forem:

If there's a feature you think would be great to add to Forem, let us know on the Issues page

Auto Discovery Links

If you would like to add auto discovery links for the built in forum Atom feeds, then add the following method inside your <head> tag:

<%= forem_atom_auto_discovery_link_tag %>

Forem's default layout includes this tag.

View Customisation

If you want to customise Forem, you can copy over the views using the (Devise-inspired) forem:views generator:

rails g forem:views

You will then be able to edit the forem views inside the app/views/forem of your application. These views will take precedence over those in the engine.

Extending Classes

All of Forem’s business logic (models, controllers, helpers, etc) can easily be extended / overridden to meet your exact requirements using standard Ruby idioms.

Standard practice for including such changes in your application or extension is to create a directory app/decorators. place file within the relevant app/decorators/models or app/decorators/controllers directory with the original class name with _decorator appended.

Adding a custom method to the Post model:

# app/decorators/models/forem/post_decorator.rb

Forem::Post.class_eval do
  def some_method
    ...
  end
end

Adding a custom method to the PostsController:

# app/decorators/controllers/forem/posts_controller_decorator.rb

Forem::PostsController.class_eval do
  def some_action
    ...
  end
end

The exact same format can be used to redefine an existing method.

Translations

We currently have support for the following languages:

  • Arabic
  • Brazillian (pt-BR)
  • Bulgarian
  • Chinese (Simplified, zh-CN)
  • Chinese (Traditional, zh-TW)
  • Czech
  • Dutch
  • English
  • Estonian
  • Farsi (Persian)
  • German
  • Italian
  • Japanese
  • Korean
  • Lithuanian
  • Polish
  • Portuguese (pt-PT)
  • Russian
  • Slovak
  • Spanish
  • Turkish

Patches for new translations are very much welcome!

OMG BUG! / OMG FEATURE REQUEST!

File an issue and we'll get around to it when we can.

Developing on forem

Forem is implemented as a Rails engine and its specs are run in the context of a dummy Rails app. The process for getting the specs to run is similar to setting up a regular rails app:

bundle exec rake forem:dummy_app

Once this setup has been done, Forem's specs can be run by executing this command:

bundle exec rspec spec

More information can be found in this issue in the bugtracker.

If all the tests are passing (they usually are), then you're good to go! Develop a new feature for Forem and be lavished with praise!

Contributors

  • Ryan Bigg
  • Philip Arndt
  • Josh Adams
  • Adam McDonald
  • Zak Strassburg
  • And more

Places using Forem

If you want yours added here, just ask!

forem's People

Contributors

radar avatar parndt avatar gabrielbaez avatar jgadbois avatar yan-hoose avatar phiggins avatar browning avatar nashby avatar raid5 avatar phlipper avatar frankel avatar juozasg avatar mauriciopasquier avatar alexcwatt avatar johanb avatar nruth avatar idearise avatar ugisozols avatar kunalchaudhari avatar nebiros avatar glebm avatar filiptepper avatar victormartins avatar tanraya avatar fracek avatar tomg65 avatar tigercat avatar strd6 avatar dapz avatar caffo avatar

Stargazers

Roman avatar

Watchers

James Cloos avatar Park Eugene avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    πŸ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. πŸ“ŠπŸ“ˆπŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❀️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.