add attachemnts support for wall

This commit is contained in:
Dmitriy Zaporozhets 2013-03-19 13:28:29 +02:00
parent 4d378f3c9a
commit 124a5e270e
6 changed files with 56 additions and 6 deletions

View file

@ -4,7 +4,6 @@ var NoteList = {
target_params: null, target_params: null,
target_id: 0, target_id: 0,
target_type: null, target_type: null,
loading_more_disabled: false,
init: function(tid, tt, path) { init: function(tid, tt, path) {
NoteList.notes_path = path + ".js"; NoteList.notes_path = path + ".js";

View file

@ -9,6 +9,7 @@
Wall.notes_path = "/api/" + gon.api_version + "/projects/" + project_id + "/notes.json" Wall.notes_path = "/api/" + gon.api_version + "/projects/" + project_id + "/notes.json"
Wall.getContent() Wall.getContent()
Wall.initRefresh() Wall.initRefresh()
Wall.initForm()
# #
# Gets an initial set of notes. # Gets an initial set of notes.
@ -28,6 +29,7 @@
if $.inArray(note.id, Wall.note_ids) == -1 if $.inArray(note.id, Wall.note_ids) == -1
Wall.note_ids.push(note.id) Wall.note_ids.push(note.id)
Wall.renderNote(note) Wall.renderNote(note)
Wall.scrollDown()
complete: -> complete: ->
$('.js-notes-busy').removeClass("loading") $('.js-notes-busy').removeClass("loading")
@ -35,8 +37,15 @@
$('.js-notes-busy').addClass("loading") $('.js-notes-busy').addClass("loading")
renderNote: (note) -> renderNote: (note) ->
author = '<strong>' + note.author.name + ': &nbsp;</strong>' author = '<strong class="wall-author">' + note.author.name + '</strong>'
html = '<li>' + author + note.body + '</li>' body = '<span class="wall-text">' + note.body + '</span>'
file = ''
if note.attachment
file = '<span class="wall-file"><a href="/files/note/' + note.id + '/' + note.attachment + '">' + note.attachment + '</a></span>'
html = '<li>' + author + body + file + '</li>'
$('ul.notes').append(html) $('ul.notes').append(html)
initRefresh: -> initRefresh: ->
@ -44,3 +53,33 @@
refresh: -> refresh: ->
Wall.getContent() Wall.getContent()
scrollDown: ->
notes = $('ul.notes')
$('body').scrollTop(notes.height())
initForm: ->
form = $('.new_note')
form.find("#target_type").val('wall')
# remove unnecessary fields and buttons
form.find("#note_line_code").remove()
form.find(".js-close-discussion-note-form").remove()
form.find('.js-notify-commit-author').remove()
form.on 'ajax:success', ->
Wall.refresh()
form.find(".js-note-text").val("").trigger("input")
form.on 'ajax:complete', ->
form.find(".js-comment-button").removeAttr('disabled')
form.find(".js-comment-button").removeClass('disabled')
form.on "click", ".js-choose-note-attachment-button", ->
form.find(".js-note-attachment-input").click()
form.on "change", ".js-note-attachment-input", ->
filename = $(this).val().replace(/^.*[\\\/]/, '')
form.find(".js-attachment-filename").text(filename)
form.show()

View file

@ -10,10 +10,20 @@
padding: 3px; padding: 3px;
padding-bottom: 25px; padding-bottom: 25px;
border: 1px solid #DDD; border: 1px solid #DDD;
display: block;
} }
.notes { .notes {
margin-bottom: 160px; margin-bottom: 160px;
.wall-author {
color: #666;
margin-right: 10px;
border-right: 1px solid #CCC;
padding-right: 5px
}
.wall-file {
float: right;
}
} }
} }

View file

@ -40,7 +40,7 @@
= link_to 'Wiki', project_wiki_path(@project, :home) = link_to 'Wiki', project_wiki_path(@project, :home)
- if @project.wall_enabled - if @project.wall_enabled
= nav_link(path: 'projects#wall') do = nav_link(controller: :walls) do
= link_to 'Wall', project_wall_path(@project) = link_to 'Wall', project_wall_path(@project)
- if @project.snippets_enabled - if @project.snippets_enabled

View file

@ -3,6 +3,7 @@
.notes-busy.js-notes-busy .notes-busy.js-notes-busy
.js-main-target-form .js-main-target-form
- if can? current_user, :write_note, @project
= render "notes/form" = render "notes/form"
:javascript :javascript

View file

@ -95,6 +95,7 @@ module Gitlab
class Note < Grape::Entity class Note < Grape::Entity
expose :id expose :id
expose :note, as: :body expose :note, as: :body
expose :attachment_identifier, as: :attachment
expose :author, using: Entities::UserBasic expose :author, using: Entities::UserBasic
expose :created_at expose :created_at
end end