Skip to content

Commit

Permalink
Add feed.
Browse files Browse the repository at this point in the history
  • Loading branch information
paulmillr committed Jun 12, 2012
1 parent 3a3088d commit bb8529c
Show file tree
Hide file tree
Showing 18 changed files with 73 additions and 5 deletions.
8 changes: 8 additions & 0 deletions app/controllers/feed_controller.coffee
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
Controller = require 'controllers/controller'
FeedPageView = require 'views/feed_page_view'

module.exports = class FeedController extends Controller
historyURL: 'feed'

show: (params) ->
@view = new FeedPageView()
3 changes: 3 additions & 0 deletions app/models/feed.coffee
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
Model = require 'models/model'

module.exports = class Feed extends Model
6 changes: 6 additions & 0 deletions app/models/post.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -15,3 +15,9 @@ module.exports = class Post extends Model
repo = new Repo _.extend response.topic.repo, {user}
topic = new Topic _.extend response.topic, {repo}
_.extend response, {topic}

setUrl: ->
url = "/#{@get('topic').get('repo').get('user').get('login')}
/#{@get('topic').get('repo').get('name')}
/topics/#{@get('topic').get('number')}"
@set({url})
1 change: 1 addition & 0 deletions app/routes.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ module.exports = (match) ->
match '', 'home#show'
match 'logout/', 'auth#logout'
match 'auth-callback/?login=:login&accessToken=:accessToken', 'auth#callback'
match 'feed/', 'feed#show'
match ':login', 'users#show'
match ':login/:repoName', 'repos#show'
match ':login/:repoName/', 'topics#redirect_to_repo'
Expand Down
27 changes: 27 additions & 0 deletions app/views/feed_page_view.coffee
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
PageView = require 'views/page_view'
template = require 'views/templates/feed_page'
config = require 'config'
Collection = require 'models/collection'
Post = require 'models/post'
FeedPostsView = require 'views/feed_posts_view'
User = require 'models/user'
UsersView = require 'views/users_view'

module.exports = class FeedPageView extends PageView
template: template
autoRender: yes

renderSubviews: ->
users = new Collection null, model: User
users.url = "#{config.api.versionRoot}/users/"
@subview 'users', new UsersView
collection: users,
container: @$('.user-list-container')
users.fetch()

posts = new Collection null, model: Post
posts.url = "#{config.api.versionRoot}/posts/"
@subview 'posts', new FeedPostsView
collection: posts,
container: @$('.post-list-container')
posts.fetch()
9 changes: 9 additions & 0 deletions app/views/feed_post_view.coffee
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
PostView = require 'views/view'

module.exports = class FeedPostView extends PostView
template: require 'views/templates/post'

initialize: ->
super
@model.setUrl()
console.log @$el
6 changes: 6 additions & 0 deletions app/views/feed_posts_view.coffee
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
PostsView = require 'views/posts_view'
FeedPostView = require 'views/feed_post_view'

module.exports = class FeedPostsView extends PostsView
getView: (item) ->
new FeedPostView model: item
1 change: 1 addition & 0 deletions app/views/organization_owners_view.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -3,3 +3,4 @@ template = require 'views/templates/organization_owners'

module.exports = class OrganizationOwnersView extends UsersView
template: template
listSelector: '.users-list'
7 changes: 7 additions & 0 deletions app/views/templates/feed_page.hbs
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
<div class="user-list-container">
<h4>Latest users</h4>
</div>

<div class="post-list-container">
<h4>Latest posts</h4>
</div>
4 changes: 3 additions & 1 deletion app/views/templates/header.hbs
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
<h1 class="header-logo"><a href="/">Ost.io</a></h1>
<h1 class="header-logo">
<a href="/{{#if_logged_in}}feed/{{/if_logged_in}}">Ost.io</a>
</h1>
<div class="header-auth">
{{#if_logged_in}}
{{#with_user}}
Expand Down
1 change: 1 addition & 0 deletions app/views/templates/post.hbs
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
<div class="topic-post-content">
<div class="topic-post-header">
<a class="topic-post-author" href="/{{user.login}}">{{user.login}}</a>
{{#if url}}in <a class="topic-post-url" href="{{url}}">{{url}}</a>{{/if}}
<time class="topic-post-metadata topic-post-date">{{#date}}{{created_at}}{{/date}}</time>
</div>
<div class="topic-post-text">
Expand Down
1 change: 1 addition & 0 deletions app/views/user_organizations_view.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -3,3 +3,4 @@ template = require 'views/templates/user_organizations'

module.exports = class UserOrganizationsView extends UsersView
template: template
listSelector: '.users-list'
4 changes: 0 additions & 4 deletions app/views/users_view.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,6 @@ User = require 'views/user_view'

module.exports = class UsersView extends CollectionView
className: 'users'
listSelector: '.users-list'

getTemplateFunction: ->
@template

getView: (item) ->
new User model: item
Empty file.
Empty file added test/models/feed_test.coffee
Empty file.
Empty file.
Empty file.
Empty file.

0 comments on commit bb8529c

Please sign in to comment.