Commit 59ae1c56925b0d6f62603d1d4e63e344895af2d5
Exists in
master
and in
79 other branches
Merge branch 'blocks'
Conflicts: lib/ext/search_controller.rb
Showing
13 changed files
with
224 additions
and
29 deletions
Show diff stats
... | ... | @@ -0,0 +1,29 @@ |
1 | +class CategoriesAndTagsBlock < Block | |
2 | + | |
3 | + attr_accessible :show_name | |
4 | + | |
5 | + settings_items :show_name, :type => :boolean, :default => false | |
6 | + | |
7 | + def self.description | |
8 | + _('Categories and Tags') | |
9 | + end | |
10 | + | |
11 | + def help | |
12 | + _('This block displays the categories and tags of a software.') | |
13 | + end | |
14 | + | |
15 | + def content(args={}) | |
16 | + block = self | |
17 | + s = show_name | |
18 | + lambda do |object| | |
19 | + render( | |
20 | + :file => 'blocks/categories_and_tags', | |
21 | + :locals => { :block => block, :show_name => s } | |
22 | + ) | |
23 | + end | |
24 | + end | |
25 | + | |
26 | + def cacheable? | |
27 | + false | |
28 | + end | |
29 | +end | ... | ... |
... | ... | @@ -0,0 +1,33 @@ |
1 | +class DownloadBlock < Block | |
2 | + | |
3 | + attr_accessible :name, :link, :software_description, :show_name, :version_news | |
4 | + | |
5 | + settings_items :name, :type => :string, :default => '' | |
6 | + settings_items :link, :type => :string, :default => '' | |
7 | + settings_items :software_description, :type => :string, :default => '' | |
8 | + settings_items :show_name, :type => :boolean, :default => false | |
9 | + settings_items :version_news, :type => :string, :default => '' | |
10 | + | |
11 | + def self.description | |
12 | + _('Download Stable Version') | |
13 | + end | |
14 | + | |
15 | + def help | |
16 | + _('This block displays the stable version of a software.') | |
17 | + end | |
18 | + | |
19 | + def content(args={}) | |
20 | + block = self | |
21 | + s = show_name | |
22 | + lambda do |object| | |
23 | + render( | |
24 | + :file => 'blocks/download', | |
25 | + :locals => { :block => block, :show_name => s } | |
26 | + ) | |
27 | + end | |
28 | + end | |
29 | + | |
30 | + def cacheable? | |
31 | + false | |
32 | + end | |
33 | +end | ... | ... |
lib/mpog_software_plugin.rb
... | ... | @@ -128,7 +128,10 @@ class MpogSoftwarePlugin < Noosfero::Plugin |
128 | 128 | { |
129 | 129 | SoftwaresBlock => {:type => [Environment, Person] }, |
130 | 130 | SoftwareInformationBlock => {:type => [Community] }, |
131 | - InstitutionsBlock => {:type => [Environment, Person]} | |
131 | + InstitutionsBlock => {:type => [Environment, Person]}, | |
132 | + DownloadBlock => {:type => [Community]}, | |
133 | + RepositoryBlock => {:type => [Community]}, | |
134 | + CategoriesAndTagsBlock => {:type => [Community]} | |
132 | 135 | } |
133 | 136 | end |
134 | 137 | |
... | ... | @@ -220,7 +223,7 @@ class MpogSoftwarePlugin < Noosfero::Plugin |
220 | 223 | |
221 | 224 | required_list[:person_fields].each do |field| |
222 | 225 | if person.send(field).blank? |
223 | - empty_fields << field.sub("_"," ") | |
226 | + empty_fields << field.sub("_"," ") | |
224 | 227 | end |
225 | 228 | end |
226 | 229 | required_list[:user_fields].each do |field| | ... | ... |
... | ... | @@ -0,0 +1,29 @@ |
1 | +class RepositoryBlock < Block | |
2 | + | |
3 | + attr_accessible :show_name | |
4 | + | |
5 | + settings_items :show_name, :type => :boolean, :default => false | |
6 | + | |
7 | + def self.description | |
8 | + _('Repository Link') | |
9 | + end | |
10 | + | |
11 | + def help | |
12 | + _('This block displays the repository link of a software.') | |
13 | + end | |
14 | + | |
15 | + def content(args={}) | |
16 | + block = self | |
17 | + s = show_name | |
18 | + lambda do |object| | |
19 | + render( | |
20 | + :file => 'blocks/repository', | |
21 | + :locals => { :block => block, :show_name => s } | |
22 | + ) | |
23 | + end | |
24 | + end | |
25 | + | |
26 | + def cacheable? | |
27 | + false | |
28 | + end | |
29 | +end | ... | ... |
public/mpog-user-validations.js
... | ... | @@ -220,7 +220,7 @@ |
220 | 220 | return false; |
221 | 221 | } |
222 | 222 | |
223 | - var correct_format_regex = new RegExp(/\A([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})\Z/i); | |
223 | + var correct_format_regex = new RegExp(/^([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})$/); | |
224 | 224 | |
225 | 225 | return !correct_format_regex.test(value); |
226 | 226 | } | ... | ... |
... | ... | @@ -0,0 +1,19 @@ |
1 | +require File.dirname(__FILE__) + '/../../../../test/test_helper' | |
2 | +require File.dirname(__FILE__) + '/../helpers/plugin_test_helper' | |
3 | + | |
4 | +class CategoriesAndTagsBlockTest < ActiveSupport::TestCase | |
5 | + include PluginTestHelper | |
6 | + should 'inherit from Block' do | |
7 | + assert_kind_of Block, CategoriesAndTagsBlock.new | |
8 | + end | |
9 | + | |
10 | + should 'declare its default title' do | |
11 | + CategoriesAndTagsBlock.any_instance.stubs(:profile_count).returns(0) | |
12 | + assert_equal Block.new.default_title, CategoriesAndTagsBlock.new.default_title | |
13 | + end | |
14 | + | |
15 | + should 'describe itself' do | |
16 | + assert_not_equal Block.description, CategoriesAndTagsBlock.description | |
17 | + end | |
18 | + | |
19 | +end | ... | ... |
... | ... | @@ -0,0 +1,29 @@ |
1 | +require File.dirname(__FILE__) + '/../../../../test/test_helper' | |
2 | +require File.dirname(__FILE__) + '/../helpers/plugin_test_helper' | |
3 | + | |
4 | +class DownloadBlockTest < ActiveSupport::TestCase | |
5 | + include PluginTestHelper | |
6 | + should 'inherit from Block' do | |
7 | + assert_kind_of Block, DownloadBlock.new | |
8 | + end | |
9 | + | |
10 | + should 'declare its default title' do | |
11 | + DownloadBlock.any_instance.stubs(:profile_count).returns(0) | |
12 | + assert_equal Block.new.default_title, DownloadBlock.new.default_title | |
13 | + end | |
14 | + | |
15 | + should 'describe itself' do | |
16 | + assert_not_equal Block.description, DownloadBlock.description | |
17 | + end | |
18 | + | |
19 | + should 'have software info to download it' do | |
20 | + | |
21 | + link = "gitlab.com/teste" | |
22 | + name = "Test Software" | |
23 | + | |
24 | + block = DownloadBlock.create(:name => name, :link => link) | |
25 | + | |
26 | + assert_equal block.link, link, "Link should not be empty" | |
27 | + assert_equal block.name, name, "Name should not be empty" | |
28 | + end | |
29 | +end | ... | ... |
... | ... | @@ -0,0 +1,19 @@ |
1 | +require File.dirname(__FILE__) + '/../../../../test/test_helper' | |
2 | +require File.dirname(__FILE__) + '/../helpers/plugin_test_helper' | |
3 | + | |
4 | +class RepositoryBlockTest < ActiveSupport::TestCase | |
5 | + include PluginTestHelper | |
6 | + | |
7 | + should 'inherit from Block' do | |
8 | + assert_kind_of Block, RepositoryBlock.new | |
9 | + end | |
10 | + | |
11 | + should 'declare its default title' do | |
12 | + RepositoryBlock.any_instance.stubs(:profile_count).returns(0) | |
13 | + assert_equal Block.new.default_title, RepositoryBlock.new.default_title | |
14 | + end | |
15 | + | |
16 | + should 'describe itself' do | |
17 | + assert_not_equal Block.description, RepositoryBlock.description | |
18 | + end | |
19 | +end | ... | ... |
... | ... | @@ -0,0 +1,14 @@ |
1 | +<h3 class="block-title"><span><%= _("Categories") %></span></h3> | |
2 | + | |
3 | +<div class="category_cloud"> | |
4 | +<% block.owner.categories.each do |category| %> | |
5 | + <%= link_to category.name , category.path, :id => "select-category-1-link", :class => "select-subcategory-link", :target => "_blank" %> | |
6 | +<% end %> | |
7 | +</div><!-- end class='category_cloud' --> | |
8 | + | |
9 | +<h3 class="block-title"><span><%= _("Tags") %></span></h3> | |
10 | +<div class="tag_cloud"> | |
11 | +<% block.owner.tag_list.each do |tag| %> | |
12 | + <%= link_to tag , "#", :id => "select-category-1-link", :class => "select-subcategory-link"%> | |
13 | +<% end %> | |
14 | +</div> | |
0 | 15 | \ No newline at end of file | ... | ... |
... | ... | @@ -0,0 +1,32 @@ |
1 | +<% if block.owner.software_info.nil? %> | |
2 | + <%= _("This community needs a software to use this block") %> | |
3 | +<% else %> | |
4 | + <div id="download-block"> | |
5 | + <div id="download_spb"> | |
6 | + <h2> <%= _("Download") %> </h2> | |
7 | + | |
8 | + <span class="download-name"> | |
9 | + <%= link_to block.name, "#" %> | |
10 | + </span> | |
11 | + | |
12 | + <span class="download-system"> | |
13 | + <%= _(block.software_description) %> | |
14 | + </span> | |
15 | + </div> | |
16 | + | |
17 | + <p id="download_info"> | |
18 | + <span class="req_spb"> | |
19 | + <%= link_to _("Minimal Requirements") , block.owner.public_profile_url, :class => "anchor-link", :target => "_self" %> | |
20 | + </span> | |
21 | + | |
22 | + <span class="nov_spb"> | |
23 | + <%= link_to(_("Version News"), block.version_news, :class => "anchor-link", :target => "_self") if !block.version_news.blank? %> | |
24 | + </span> | |
25 | + | |
26 | + <span class="licensed"> | |
27 | + <%= _("Licensed by") %> | |
28 | + <%= link_to block.owner.software_info.license_info.version , block.owner.software_info.license_info.link, :target => "_blank" %> | |
29 | + </span> | |
30 | + </p> | |
31 | + </div> | |
32 | +<% end %> | |
0 | 33 | \ No newline at end of file | ... | ... |
... | ... | @@ -0,0 +1,5 @@ |
1 | +<% if block.owner.software_info.nil? %> | |
2 | + <%= _("This community needs a software to use this block") %> | |
3 | +<% else %> | |
4 | + <%= link_to _("Repository") , block.owner.software_info.repository_link, :id => "bt_repositorio", :target => "_blank" %> | |
5 | +<% end %> | |
0 | 6 | \ No newline at end of file | ... | ... |
views/blocks/software_information.html.erb
... | ... | @@ -2,7 +2,6 @@ |
2 | 2 | |
3 | 3 | <% if block.owner.software_info.nil? %> |
4 | 4 | <%= _("This community needs a software to use this block") %> |
5 | - | |
6 | 5 | <% else %> |
7 | 6 | <table id="software-information-block-table"> |
8 | 7 | <tr> |
... | ... | @@ -13,7 +12,9 @@ |
13 | 12 | <%= link_to profile_image(block.owner, :big) +"\n", profile.url %> |
14 | 13 | </span> |
15 | 14 | <div class='admin-link'> |
16 | - <%= link_to _('Control panel'), block.owner.admin_url %> | |
15 | + <% if block.owner.admins.include?(current_user.person) %> | |
16 | + <%= link_to _('Control panel'), block.owner.admin_url %> | |
17 | + <% end %> | |
17 | 18 | </div> |
18 | 19 | </div> |
19 | 20 | </div> |
... | ... | @@ -23,33 +24,9 @@ |
23 | 24 | <%= _("#{block.owner.software_info.acronym} - ") unless block.owner.software_info.acronym.blank? %> |
24 | 25 | <%= _("#{block.owner.name}") %> |
25 | 26 | </h1> |
26 | - | |
27 | 27 | <b> |
28 | 28 | <%= block.owner.software_info.finality %> |
29 | 29 | </b> |
30 | - </td> | |
31 | - </tr> | |
32 | - <tr> | |
33 | - <td colspan="2"> | |
34 | - <% identifier_name = block.owner.software_info.acronym.blank? ? block.owner.name : block.owner.software_info.acronym %> | |
35 | - <%= _("For more detailed information see ") %> | |
36 | - <%= link_to(_("#{block.owner.name} profile"), {:controller => 'profile', :action => "index", :profile => block.owner.identifier}) %> | |
37 | - </td> | |
38 | - </tr> | |
39 | - <% unless block.owner.software_info.repository_link.blank? %> | |
40 | - <tr> | |
41 | - <td colspan="2"> | |
42 | - <%= _("Main repository: ") %> | |
43 | - <%= link_to block.owner.software_info.repository_link, block.owner.software_info.repository_link %> | |
44 | - </td> | |
45 | - </tr> | |
46 | - <% end %> | |
47 | - <tr> | |
48 | - <td> | |
49 | - <i> | |
50 | - <%= _("Licensed by ") %> | |
51 | - <%= link_to block.owner.software_info.license_info.version, block.owner.software_info.license_info.link %> | |
52 | - </i> | |
53 | 30 | </td> |
54 | 31 | </tr> |
55 | 32 | </table> | ... | ... |
... | ... | @@ -0,0 +1,6 @@ |
1 | +<div id='edit-download-block'> | |
2 | + <%= labelled_form_field _('Name:'), text_field_tag('block[name]', @block.name) %> | |
3 | + <%= labelled_form_field _('Link:'), text_field_tag('block[link]', @block.link) %> | |
4 | + <%= labelled_form_field _('Software Description:'), text_field_tag('block[software_description]', @block.software_description) %> | |
5 | + <%= labelled_form_field _('Link to Version News:'), text_field_tag('block[version_news]', @block.version_news) %> | |
6 | +</div> | ... | ... |