diff options
author | Steven Thonus <steven@ln2.nl> | 2014-01-28 01:34:05 +0400 |
---|---|---|
committer | Steven Thonus <steven@ln2.nl> | 2014-01-28 11:38:00 +0400 |
commit | 251df827a5308d483a95242970569075ab655703 (patch) | |
tree | 00872b5ebaf24ca6c4e964172f59a8380c55d096 /app | |
parent | 5221dbfee74e48f379bc06b2848a64243a76270c (diff) |
added group avatars
Diffstat (limited to 'app')
-rw-r--r-- | app/assets/images/no_group_avatar.png | bin | 0 -> 704 bytes | |||
-rw-r--r-- | app/assets/javascripts/groups.js.coffee | 11 | ||||
-rw-r--r-- | app/controllers/groups/avatars_controller.rb | 12 | ||||
-rw-r--r-- | app/helpers/application_helper.rb | 9 | ||||
-rw-r--r-- | app/models/group.rb | 16 | ||||
-rw-r--r-- | app/models/namespace.rb | 1 | ||||
-rw-r--r-- | app/views/dashboard/_groups.html.haml | 1 | ||||
-rw-r--r-- | app/views/groups/edit.html.haml | 22 |
8 files changed, 71 insertions, 1 deletions
diff --git a/app/assets/images/no_group_avatar.png b/app/assets/images/no_group_avatar.png Binary files differnew file mode 100644 index 00000000000..dac3ab1bb89 --- /dev/null +++ b/app/assets/images/no_group_avatar.png diff --git a/app/assets/javascripts/groups.js.coffee b/app/assets/javascripts/groups.js.coffee index c0ffccd8f70..7850eb14e74 100644 --- a/app/assets/javascripts/groups.js.coffee +++ b/app/assets/javascripts/groups.js.coffee @@ -4,3 +4,14 @@ class GroupMembers $(this).fadeOut() @GroupMembers = GroupMembers + +$ -> + # avatar + $('.js-choose-group-avatar-button').bind "click", -> + form = $(this).closest("form") + form.find(".js-group-avatar-input").click() + + $('.js-group-avatar-input').bind "change", -> + form = $(this).closest("form") + filename = $(this).val().replace(/^.*[\\\/]/, '') + form.find(".js-avatar-filename").text(filename)
\ No newline at end of file diff --git a/app/controllers/groups/avatars_controller.rb b/app/controllers/groups/avatars_controller.rb new file mode 100644 index 00000000000..38071410f40 --- /dev/null +++ b/app/controllers/groups/avatars_controller.rb @@ -0,0 +1,12 @@ +class Groups::AvatarsController < ApplicationController + layout "profile" + + def destroy + @group = Group.find_by(path: params[:group_id]) + @group.remove_avatar! + + @group.save + + redirect_to edit_group_path(@group) + end +end diff --git a/app/helpers/application_helper.rb b/app/helpers/application_helper.rb index e60cba2bb2b..be57b60382e 100644 --- a/app/helpers/application_helper.rb +++ b/app/helpers/application_helper.rb @@ -49,6 +49,15 @@ module ApplicationHelper args.any? { |v| v.to_s.downcase == action_name } end + def group_icon(group_path) + group = Group.find_by(path: group_path) + if group && group.avatar.present? + group.avatar.url + else + '/assets/no_group_avatar.png' + end + end + def avatar_icon(user_email = '', size = nil) user = User.find_by(email: user_email) if user && user.avatar.present? diff --git a/app/models/group.rb b/app/models/group.rb index 0b64d5b4f7f..8de0c78c158 100644 --- a/app/models/group.rb +++ b/app/models/group.rb @@ -12,10 +12,20 @@ # description :string(255) default(""), not null # +require 'carrierwave/orm/activerecord' +require 'file_size_validator' + class Group < Namespace has_many :users_groups, dependent: :destroy has_many :users, through: :users_groups + attr_accessible :avatar + + validate :avatar_type, if: ->(user) { user.avatar_changed? } + validates :avatar, file_size: { maximum: 100.kilobytes.to_i } + + mount_uploader :avatar, AttachmentUploader + def human_name name end @@ -50,4 +60,10 @@ class Group < Namespace def members users_groups end + + def avatar_type + unless self.avatar.image? + self.errors.add :avatar, "only images allowed" + end + end end diff --git a/app/models/namespace.rb b/app/models/namespace.rb index 8f837c72ff5..d5b98f588e8 100644 --- a/app/models/namespace.rb +++ b/app/models/namespace.rb @@ -10,6 +10,7 @@ # updated_at :datetime not null # type :string(255) # description :string(255) default(""), not null +# avatar :string(255) # class Namespace < ActiveRecord::Base diff --git a/app/views/dashboard/_groups.html.haml b/app/views/dashboard/_groups.html.haml index d6937ca4813..dd8d85971b3 100644 --- a/app/views/dashboard/_groups.html.haml +++ b/app/views/dashboard/_groups.html.haml @@ -10,6 +10,7 @@ - groups.each do |group| %li.group-row = link_to group_path(id: group.path), class: dom_class(group) do + = image_tag group_icon(group.path), class: "avatar s32" %span.group-name.filter-title = truncate(group.name, length: 35) %span.arrow diff --git a/app/views/groups/edit.html.haml b/app/views/groups/edit.html.haml index 77734815b8a..e274a799674 100644 --- a/app/views/groups/edit.html.haml +++ b/app/views/groups/edit.html.haml @@ -20,7 +20,7 @@ %strong= @group.name group settings: %div.form-holder - = form_for @group, html: { class: "form-horizontal" } do |f| + = form_for @group, html: { multipart: true, class: "form-horizontal" }, authenticity_token: true do |f| - if @group.errors.any? .alert.alert-danger %span= @group.errors.full_messages.first @@ -35,6 +35,26 @@ .col-sm-10 = f.text_area :description, maxlength: 250, class: "form-control js-gfm-input", rows: 4 + .form-group + .col-sm-2 + .col-sm-10 + = image_tag group_icon(@group.to_param), alt: '', class: 'avatar s160' + %p.light + - if @group.avatar? + You can change your group avatar here + - else + You can upload an group avatar here + %a.choose-btn.btn.btn-small.js-choose-group-avatar-button + %i.icon-paper-clip + %span Choose File ... + + %span.file_name.js-avatar-filename File name... + = f.file_field :avatar, class: "js-group-avatar-input hidden" + .light The maximum file size allowed is 100KB. + - if @group.avatar? + %hr + = link_to 'Remove avatar', group_avatar_path(@group.to_param), data: { confirm: "Group avatar will be removed. Are you sure?"}, method: :delete, class: "btn btn-remove btn-small remove-avatar" + .form-actions = f.submit 'Save group', class: "btn btn-save" |