decidim-conferences 0.20.1 → 0.23.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (120) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +2 -0
  3. data/app/assets/images/decidim/conferences/conference.svg +1 -3
  4. data/app/cells/decidim/conferences/conference_m/footer.erb +1 -1
  5. data/app/cells/decidim/conferences/conference_m_cell.rb +4 -0
  6. data/app/cells/decidim/conferences/conference_speaker/show.erb +2 -2
  7. data/app/cells/decidim/conferences/content_blocks/highlighted_conferences/show.erb +9 -10
  8. data/app/cells/decidim/conferences/media_link/show.erb +2 -2
  9. data/app/cells/decidim/conferences/partner_cell.rb +1 -1
  10. data/app/cells/decidim/conferences/photo/show.erb +3 -5
  11. data/app/cells/decidim/conferences/photo_cell.rb +2 -2
  12. data/app/cells/decidim/conferences/photos_list/show.erb +1 -1
  13. data/app/cells/decidim/conferences/registration_type/join_conference.erb +1 -1
  14. data/app/cells/decidim/conferences/registration_type_cell.rb +2 -2
  15. data/app/commands/decidim/conferences/admin/create_conference.rb +3 -3
  16. data/app/commands/decidim/conferences/admin/create_conference_admin.rb +2 -1
  17. data/app/commands/decidim/conferences/admin/create_partner.rb +9 -9
  18. data/app/commands/decidim/conferences/admin/notify_role_assigned_to_conference.rb +22 -0
  19. data/app/commands/decidim/conferences/admin/update_conference.rb +13 -6
  20. data/app/commands/decidim/conferences/admin/update_conference_admin.rb +2 -1
  21. data/app/controllers/concerns/decidim/conferences/admin/filterable.rb +27 -0
  22. data/app/controllers/decidim/conferences/admin/conferences_controller.rb +4 -5
  23. data/app/events/decidim/conferences/conference_role_assigned_event.rb +30 -0
  24. data/app/forms/decidim/conferences/admin/conference_form.rb +5 -2
  25. data/app/forms/decidim/conferences/admin/conference_speaker_form.rb +12 -1
  26. data/app/forms/decidim/conferences/admin/diploma_form.rb +6 -2
  27. data/app/forms/decidim/conferences/admin/partner_form.rb +16 -1
  28. data/app/jobs/decidim/conferences/admin/send_conference_diploma_job.rb +1 -1
  29. data/app/models/decidim/conference.rb +28 -1
  30. data/app/models/decidim/conference_speaker.rb +5 -2
  31. data/app/models/decidim/conference_user_role.rb +1 -1
  32. data/app/models/decidim/conferences/media_link.rb +3 -0
  33. data/app/models/decidim/conferences/partner.rb +5 -1
  34. data/app/models/decidim/conferences/registration_type.rb +3 -0
  35. data/app/permissions/decidim/conferences/permissions.rb +9 -0
  36. data/app/presenters/decidim/conferences/conference_stats_presenter.rb +1 -1
  37. data/app/types/decidim/conferences/conference_media_link_type.rb +19 -0
  38. data/app/types/decidim/conferences/conference_partner_type.rb +20 -0
  39. data/app/types/decidim/conferences/conference_speaker_type.rb +24 -0
  40. data/app/types/decidim/conferences/conference_type.rb +45 -0
  41. data/app/views/decidim/conferences/_order_by_conferences.html.erb +1 -1
  42. data/app/views/decidim/conferences/admin/conference_invites/index.html.erb +2 -2
  43. data/app/views/decidim/conferences/admin/conference_speakers/index.html.erb +2 -2
  44. data/app/views/decidim/conferences/admin/conferences/index.html.erb +6 -3
  45. data/app/views/decidim/conferences/conference_program/_program_item.html.erb +6 -4
  46. data/app/views/decidim/conferences/conference_program/show.html.erb +6 -6
  47. data/app/views/decidim/conferences/conference_speakers/index.html.erb +1 -1
  48. data/app/views/decidim/conferences/conferences/_partners.html.erb +1 -1
  49. data/app/views/decidim/conferences/conferences/_promoted_conference.html.erb +3 -3
  50. data/app/views/decidim/conferences/conferences/show.html.erb +7 -13
  51. data/app/views/decidim/conferences/media/index.html.erb +3 -3
  52. data/app/views/decidim/conferences/registration_types/index.html.erb +1 -1
  53. data/app/views/layouts/decidim/_conference_hero.html.erb +4 -8
  54. data/app/views/layouts/decidim/_conferences_nav.html.erb +2 -2
  55. data/app/views/layouts/decidim/admin/conference.html.erb +2 -2
  56. data/app/views/layouts/decidim/conference.html.erb +4 -5
  57. data/config/locales/am-ET.yml +1 -0
  58. data/config/locales/bg-BG.yml +7 -0
  59. data/config/locales/bg.yml +7 -0
  60. data/config/locales/ca.yml +10 -0
  61. data/config/locales/cs.yml +20 -10
  62. data/config/locales/da-DK.yml +1 -0
  63. data/config/locales/da.yml +1 -0
  64. data/config/locales/de.yml +9 -0
  65. data/config/locales/el.yml +580 -0
  66. data/config/locales/en.yml +10 -0
  67. data/config/locales/eo.yml +1 -0
  68. data/config/locales/es-MX.yml +10 -0
  69. data/config/locales/es-PY.yml +10 -0
  70. data/config/locales/es.yml +10 -0
  71. data/config/locales/et-EE.yml +1 -0
  72. data/config/locales/et.yml +1 -0
  73. data/config/locales/fi-plain.yml +10 -0
  74. data/config/locales/fi.yml +14 -4
  75. data/config/locales/fr-CA.yml +581 -0
  76. data/config/locales/fr.yml +10 -0
  77. data/config/locales/ga-IE.yml +1 -0
  78. data/config/locales/hr-HR.yml +1 -0
  79. data/config/locales/hr.yml +1 -0
  80. data/config/locales/hu.yml +4 -0
  81. data/config/locales/is.yml +1 -0
  82. data/config/locales/it.yml +169 -159
  83. data/config/locales/ja-JP.yml +575 -0
  84. data/config/locales/ja.yml +576 -0
  85. data/config/locales/ko-KR.yml +1 -0
  86. data/config/locales/ko.yml +1 -0
  87. data/config/locales/lt-LT.yml +1 -0
  88. data/config/locales/lt.yml +1 -0
  89. data/config/locales/lv.yml +584 -0
  90. data/config/locales/mt-MT.yml +1 -0
  91. data/config/locales/mt.yml +1 -0
  92. data/config/locales/nl.yml +10 -0
  93. data/config/locales/no.yml +12 -3
  94. data/config/locales/om-ET.yml +1 -0
  95. data/config/locales/pl.yml +203 -193
  96. data/config/locales/pt-BR.yml +1 -1
  97. data/config/locales/pt.yml +238 -229
  98. data/config/locales/ro-RO.yml +536 -0
  99. data/config/locales/sk-SK.yml +585 -0
  100. data/config/locales/sk.yml +585 -0
  101. data/config/locales/sl.yml +42 -0
  102. data/config/locales/so-SO.yml +1 -0
  103. data/config/locales/sr-CS.yml +19 -0
  104. data/config/locales/sv.yml +25 -15
  105. data/config/locales/ti-ER.yml +1 -0
  106. data/config/locales/vi-VN.yml +1 -0
  107. data/config/locales/vi.yml +1 -0
  108. data/config/locales/zh-CN.yml +576 -0
  109. data/config/locales/zh-TW.yml +1 -0
  110. data/db/migrate/20200320105913_index_foreign_keys_in_decidim_conferences.rb +7 -0
  111. data/db/migrate/20200320105914_index_foreign_keys_in_decidim_conferences_conference_invites.rb +7 -0
  112. data/db/migrate/20200320105915_index_foreign_keys_in_decidim_conferences_conference_registrations.rb +7 -0
  113. data/db/seeds/city.jpeg +0 -0
  114. data/db/seeds/city2.jpeg +0 -0
  115. data/lib/decidim/conferences/admin_engine.rb +1 -0
  116. data/lib/decidim/conferences/participatory_space.rb +19 -12
  117. data/lib/decidim/conferences/test/factories.rb +19 -3
  118. data/lib/decidim/conferences/version.rb +1 -1
  119. metadata +57 -13
  120. data/app/views/decidim/conferences/conference_widgets/show.html.erb +0 -11
@@ -26,7 +26,18 @@ module Decidim
26
26
  validates :full_name, presence: true, unless: proc { |object| object.existing_user }
27
27
  validates :user, presence: true, if: proc { |object| object.existing_user }
28
28
  validates :position, :affiliation, presence: true
29
- validates :avatar, file_size: { less_than_or_equal_to: ->(_record) { Decidim.maximum_avatar_size } }
29
+ validates :avatar, passthru: {
30
+ to: Decidim::ConferenceSpeaker,
31
+ with: {
32
+ # The speaker gets its organization context through the conference
33
+ # object which is why we need to create a dummy conference in order
34
+ # to pass the correct organization context to the file upload
35
+ # validators.
36
+ conference: lambda do |form|
37
+ Decidim::Conference.new(organization: form.current_organization)
38
+ end
39
+ }
40
+ }
30
41
  validate :personal_url_format
31
42
 
32
43
  def personal_url
@@ -7,6 +7,8 @@ module Decidim
7
7
  # from the admin dashboard
8
8
  #
9
9
  class DiplomaForm < Form
10
+ include Decidim::HasUploadValidations
11
+
10
12
  mimic :conference
11
13
 
12
14
  attribute :main_logo
@@ -16,8 +18,10 @@ module Decidim
16
18
 
17
19
  validates :signature_name, :sign_date, :main_logo, :signature, presence: true
18
20
 
19
- validates :main_logo, file_size: { less_than_or_equal_to: ->(_record) { Decidim.maximum_attachment_size } }, file_content_type: { allow: ["image/jpeg", "image/png"] }
20
- validates :signature, file_size: { less_than_or_equal_to: ->(_record) { Decidim.maximum_attachment_size } }, file_content_type: { allow: ["image/jpeg", "image/png"] }
21
+ validates :main_logo, passthru: { to: Decidim::Conference }
22
+ validates :signature, passthru: { to: Decidim::Conference }
23
+
24
+ alias organization current_organization
21
25
  end
22
26
  end
23
27
  end
@@ -5,6 +5,8 @@ module Decidim
5
5
  module Admin
6
6
  # A form object used to create conference members from the admin dashboard.
7
7
  class PartnerForm < Form
8
+ include Decidim::HasUploadValidations
9
+
8
10
  mimic :conference_partner
9
11
 
10
12
  attribute :name, String
@@ -15,11 +17,24 @@ module Decidim
15
17
  attribute :remove_logo
16
18
 
17
19
  validates :name, :partner_type, presence: true, if: ->(form) { form.logo.present? }
18
- validates :logo, file_size: { less_than_or_equal_to: ->(_record) { Decidim.maximum_avatar_size } }
20
+ validates :logo, passthru: {
21
+ to: Decidim::Conferences::Partner,
22
+ with: {
23
+ # The partner gets its organization context through the conference
24
+ # object which is why we need to create a dummy conference in order
25
+ # to pass the correct organization context to the file upload
26
+ # validators.
27
+ conference: lambda do |form|
28
+ Decidim::Conference.new(organization: form.current_organization)
29
+ end
30
+ }
31
+ }
19
32
  validate :link_format
20
33
  validates :weight, numericality: { greater_than_or_equal_to: 0 }
21
34
  validates :partner_type, inclusion: { in: Decidim::Conferences::Partner::TYPES }
22
35
 
36
+ alias organization current_organization
37
+
23
38
  def link
24
39
  return if super.blank?
25
40
 
@@ -11,7 +11,7 @@ module Decidim
11
11
  return unless confirmed_registrations.any?
12
12
 
13
13
  confirmed_registrations.each do |registration_confirmed|
14
- SendConferenceDiplomaMailer.diploma(conference, registration_confirmed.user).deliver_now
14
+ SendConferenceDiplomaMailer.diploma(conference, registration_confirmed.user).deliver_later
15
15
  end
16
16
  end
17
17
  end
@@ -10,13 +10,17 @@ module Decidim
10
10
  include Decidim::HasAttachmentCollections
11
11
  include Decidim::Participable
12
12
  include Decidim::Publicable
13
- include Decidim::Scopable
13
+ include Decidim::ScopableParticipatorySpace
14
14
  include Decidim::Followable
15
15
  include Decidim::HasReference
16
16
  include Decidim::Traceable
17
17
  include Decidim::Loggable
18
18
  include Decidim::ParticipatorySpaceResourceable
19
19
  include Decidim::Searchable
20
+ include Decidim::HasUploadValidations
21
+ include Decidim::TranslatableResource
22
+
23
+ translatable_fields :title, :slogan, :short_description, :description, :objectives, :registration_terms
20
24
 
21
25
  belongs_to :organization,
22
26
  foreign_key: "decidim_organization_id",
@@ -51,9 +55,16 @@ module Decidim
51
55
  validates :slug, uniqueness: { scope: :organization }
52
56
  validates :slug, presence: true, format: { with: Decidim::Conference.slug_format }
53
57
 
58
+ validates_upload :hero_image
54
59
  mount_uploader :hero_image, Decidim::HeroImageUploader
60
+
61
+ validates_upload :banner_image
55
62
  mount_uploader :banner_image, Decidim::HomepageImageUploader
63
+
64
+ validates_upload :main_logo
56
65
  mount_uploader :main_logo, Decidim::Conferences::DiplomaUploader
66
+
67
+ validates_upload :signature
57
68
  mount_uploader :signature, Decidim::Conferences::DiplomaUploader
58
69
 
59
70
  searchable_fields({
@@ -116,5 +127,21 @@ module Decidim
116
127
 
117
128
  end_date < Date.current
118
129
  end
130
+
131
+ def user_roles(role_name = nil)
132
+ roles = Decidim::ConferenceUserRole.where(conference: self)
133
+ return roles if role_name.blank?
134
+
135
+ roles.where(role: role_name)
136
+ end
137
+
138
+ def attachment_context
139
+ :admin
140
+ end
141
+
142
+ # Allow ransacker to search for a key in a hstore column (`title`.`en`)
143
+ ransacker :title do |parent|
144
+ Arel::Nodes::InfixOperation.new("->>", parent.table[:title], Arel::Nodes.build_quoted(I18n.locale.to_s))
145
+ end
119
146
  end
120
147
  end
@@ -6,16 +6,19 @@ module Decidim
6
6
  class ConferenceSpeaker < ApplicationRecord
7
7
  include Decidim::Traceable
8
8
  include Decidim::Loggable
9
+ include Decidim::HasUploadValidations
10
+ include Decidim::TranslatableResource
11
+
12
+ translatable_fields :position, :affiliation, :short_bio
9
13
 
10
14
  belongs_to :user, foreign_key: "decidim_user_id", class_name: "Decidim::User", optional: true
11
15
  belongs_to :conference, foreign_key: "decidim_conference_id", class_name: "Decidim::Conference"
12
16
  has_many :conference_speaker_conference_meetings, dependent: :destroy
13
17
  has_many :conference_meetings, through: :conference_speaker_conference_meetings, foreign_key: "conference_speaker_id", class_name: "Decidim::ConferenceMeeting"
14
18
 
15
- validates :avatar, file_size: { less_than_or_equal_to: ->(_record) { Decidim.maximum_avatar_size } }
16
-
17
19
  default_scope { order(full_name: :asc, created_at: :asc) }
18
20
 
21
+ validates_avatar
19
22
  mount_uploader :avatar, Decidim::AvatarUploader
20
23
 
21
24
  delegate :organization, to: :conference
@@ -11,7 +11,7 @@ module Decidim
11
11
  belongs_to :conference, foreign_key: "decidim_conference_id", class_name: "Decidim::Conference", optional: true
12
12
  alias participatory_space conference
13
13
 
14
- ROLES = %w(admin collaborator moderator).freeze
14
+ ROLES = %w(admin collaborator moderator valuator).freeze
15
15
  validates :role, inclusion: { in: ROLES }, uniqueness: { scope: [:user, :conference] }
16
16
  validate :user_and_conference_same_organization
17
17
 
@@ -6,6 +6,9 @@ module Decidim
6
6
  class MediaLink < ApplicationRecord
7
7
  include Decidim::Traceable
8
8
  include Decidim::Loggable
9
+ include Decidim::TranslatableResource
10
+
11
+ translatable_fields :title
9
12
 
10
13
  belongs_to :conference, foreign_key: "decidim_conference_id", class_name: "Decidim::Conference"
11
14
 
@@ -6,15 +6,19 @@ module Decidim
6
6
  class Partner < ApplicationRecord
7
7
  include Decidim::Traceable
8
8
  include Decidim::Loggable
9
+ include Decidim::HasUploadValidations
9
10
 
10
11
  TYPES = %w(main_promotor collaborator).freeze
11
12
 
12
13
  belongs_to :conference, foreign_key: "decidim_conference_id", class_name: "Decidim::Conference"
13
- validates :logo, file_size: { less_than_or_equal_to: ->(_record) { Decidim.maximum_avatar_size } }
14
14
 
15
15
  default_scope { order(partner_type: :desc, weight: :asc) }
16
+
17
+ validates_avatar :logo
16
18
  mount_uploader :logo, Decidim::Conferences::PartnerLogoUploader
17
19
 
20
+ delegate :organization, to: :conference
21
+
18
22
  alias participatory_space conference
19
23
 
20
24
  def self.log_presenter_class_for(_log)
@@ -7,6 +7,9 @@ module Decidim
7
7
  include Decidim::Publicable
8
8
  include Decidim::Traceable
9
9
  include Decidim::Loggable
10
+ include Decidim::TranslatableResource
11
+
12
+ translatable_fields :title, :description
10
13
 
11
14
  belongs_to :conference, foreign_key: "decidim_conference_id", class_name: "Decidim::Conference"
12
15
  has_many :conference_meeting_registration_types, dependent: :destroy
@@ -51,6 +51,7 @@ module Decidim
51
51
 
52
52
  moderator_action?
53
53
  collaborator_action?
54
+ valuator_action?
54
55
  conference_admin_action?
55
56
 
56
57
  permission_action
@@ -252,6 +253,14 @@ module Decidim
252
253
  allow! if permission_action.action == :read || permission_action.action == :preview
253
254
  end
254
255
 
256
+ # Valuators can only read components
257
+ def valuator_action?
258
+ return unless can_manage_conference?(role: :valuator)
259
+
260
+ allow! if permission_action.action == :read && permission_action.subject == :component
261
+ allow! if permission_action.action == :export && permission_action.subject == :component_data
262
+ end
263
+
255
264
  # Process admins can eprform everything *inside* that conference. They cannot
256
265
  # create a conference or perform actions on conference groups or other
257
266
  # conferences.
@@ -38,7 +38,7 @@ module Decidim
38
38
 
39
39
  def render_stats_data(component_manifest, name, data, index)
40
40
  safe_join([
41
- index.zero? ? manifest_icon(component_manifest) : " /&nbsp".html_safe,
41
+ index.zero? ? manifest_icon(component_manifest, role: "img", "aria-hidden": true) : " /&nbsp".html_safe,
42
42
  content_tag(:span, "#{number_with_delimiter(data)} " + I18n.t(name, scope: "decidim.conferences.statistics"),
43
43
  class: "#{name} process_stats-text")
44
44
  ])
@@ -0,0 +1,19 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Decidim
4
+ module Conferences
5
+ # This type represents a conference.
6
+ ConferenceMediaLinkType = GraphQL::ObjectType.define do
7
+ name "ConferenceMediaLink"
8
+ description "A conference media link"
9
+
10
+ field :id, !types.ID, "Internal ID for this media link"
11
+ field :title, Decidim::Core::TranslatedFieldType, "Title for this media link"
12
+ field :link, types.String, "URL for this media link"
13
+ field :date, Decidim::Core::DateType, "Relevant date for the media link"
14
+ field :weight, types.Int, "Order of appearance in which it should be presented"
15
+ field :createdAt, Decidim::Core::DateTimeType, "The time this entry was created", property: :created_at
16
+ field :updatedAt, Decidim::Core::DateTimeType, "The time this entry was updated", property: :updated_at
17
+ end
18
+ end
19
+ end
@@ -0,0 +1,20 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Decidim
4
+ module Conferences
5
+ # This type represents a conference.
6
+ ConferencePartnerType = GraphQL::ObjectType.define do
7
+ name "ConferencePartner"
8
+ description "A conference partner"
9
+
10
+ field :id, !types.ID, "ID of the resource"
11
+ field :name, types.String, "Partner name"
12
+ field :partnerType, types.String, "Partner type", property: :partner_type
13
+ field :weight, types.Int, "Order of appearance in which it should be presented"
14
+ field :link, types.String, "Relevant URL for this partner"
15
+ field :logo, types.String, "Link to the partner's logo"
16
+ field :createdAt, Decidim::Core::DateTimeType, "The time this partner was created", property: :created_at
17
+ field :updatedAt, Decidim::Core::DateTimeType, "The time this partner was updated", property: :updated_at
18
+ end
19
+ end
20
+ end
@@ -0,0 +1,24 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Decidim
4
+ module Conferences
5
+ # This type represents a conference.
6
+ ConferenceSpeakerType = GraphQL::ObjectType.define do
7
+ name "ConferenceSpeaker"
8
+ description "A conference speaker"
9
+
10
+ field :id, !types.ID, "Internal ID of the speaker"
11
+ field :fullName, types.String, "Full name of the speaker", property: :full_name
12
+ field :position, Decidim::Core::TranslatedFieldType, "Position of the speaker in the conference"
13
+ field :affiliation, Decidim::Core::TranslatedFieldType, "Affiliation of the speaker"
14
+ field :twitterHandle, types.String, "Twitter handle", property: :twitter_handle
15
+ field :shortBio, Decidim::Core::TranslatedFieldType, "Short biography of the speaker", property: :short_bio
16
+ field :personalUrl, types.String, "Personal URL of the speaker", property: :personal_url
17
+ field :avatar, types.String, "Avatar of the speaker"
18
+ field :user, Decidim::Core::UserType, "Decidim user corresponding to this speaker", property: :user
19
+
20
+ field :createdAt, Decidim::Core::DateTimeType, "The time this member was created ", property: :created_at
21
+ field :updatedAt, Decidim::Core::DateTimeType, "The time this member was updated", property: :updated_at
22
+ end
23
+ end
24
+ end
@@ -0,0 +1,45 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Decidim
4
+ module Conferences
5
+ # This type represents a conference.
6
+ ConferenceType = GraphQL::ObjectType.define do
7
+ interfaces [
8
+ -> { Decidim::Core::ParticipatorySpaceInterface },
9
+ -> { Decidim::Core::ScopableInterface },
10
+ -> { Decidim::Core::AttachableInterface }
11
+ ]
12
+
13
+ name "Conference"
14
+ description "A conference"
15
+
16
+ field :id, !types.ID, "Internal ID for this conference"
17
+ field :shortDescription, Decidim::Core::TranslatedFieldType, "The short description of this conference", property: :short_description
18
+ field :description, Decidim::Core::TranslatedFieldType, "The description of this conference"
19
+ field :slug, types.String, "The slug of this conference"
20
+ field :hashtag, types.String, "The hashtag for this conference"
21
+ field :slogan, Decidim::Core::TranslatedFieldType, "The slogan of the conference"
22
+ field :location, types.String, "The location of this conference"
23
+ field :createdAt, Decidim::Core::DateTimeType, "The time this conference was created", property: :created_at
24
+ field :updatedAt, Decidim::Core::DateTimeType, "The time this conference was updated", property: :updated_at
25
+ field :publishedAt, Decidim::Core::DateTimeType, "The time this conference was published", property: :published_at
26
+ field :reference, types.String, "Reference prefix for this conference"
27
+
28
+ field :heroImage, types.String, "The hero image for this conference", property: :hero_image
29
+ field :bannerImage, types.String, "The banner image for this conference", property: :banner_image
30
+ field :promoted, types.Boolean, "If this conference is promoted (therefore in the homepage)"
31
+ field :objectives, Decidim::Core::TranslatedFieldType, "The objectives of the conference"
32
+ field :showStatistics, types.Boolean, "If this conference shows the statistics", property: :show_statistics
33
+ field :startDate, Decidim::Core::DateType, "The date this conference starts", property: :start_date
34
+ field :endDate, Decidim::Core::DateType, "The date this conference ends", property: :end_date
35
+ field :registrationsEnabled, types.Boolean, "If the registrations are enabled in this conference", property: :registrations_enabled
36
+ field :availableSlots, types.Int, "The number of available slots in this conference", property: :available_slots
37
+ field :registrationTerms, Decidim::Core::TranslatedFieldType, "The registration terms of this conference", property: :registration_terms
38
+
39
+ field :speakers, types[Decidim::Conferences::ConferenceSpeakerType], "List of speakers in this conference"
40
+ field :partners, types[Decidim::Conferences::ConferencePartnerType], "List of partners in this conference"
41
+ field :categories, types[Decidim::Core::CategoryType], "List of categories in this conference"
42
+ field :mediaLinks, types[Decidim::Conferences::ConferenceMediaLinkType], "List of media links in this conference", property: :media_links
43
+ end
44
+ end
45
+ end
@@ -1,3 +1,3 @@
1
1
  <div class="row collapse order-by">
2
- <h2 class="order-by__text section-heading"><%= t("conferences.order_by_conferences.conferences", scope: "layouts.decidim", count: collection.count) %></h2>
2
+ <h3 class="order-by__text section-heading"><%= t("conferences.order_by_conferences.conferences", scope: "layouts.decidim", count: collection.count) %></h3>
3
3
  </div>
@@ -26,8 +26,8 @@
26
26
  <%= search_field_tag :q, @query,label: false, class: "input-group-field", placeholder: t(".search") %>
27
27
  <%= hidden_field_tag :state, @state %>
28
28
  <div class="input-group-button">
29
- <button type="submit" class="button button--muted">
30
- <%= icon "magnifying-glass", aria_label: t(".search") %>
29
+ <button type="submit" class="button">
30
+ <%= icon "magnifying-glass", aria_label: t(".search"), role: "img" %>
31
31
  </button>
32
32
  </div>
33
33
  </div>
@@ -5,8 +5,8 @@
5
5
  <div class="input-group">
6
6
  <%= search_field_tag :q, @query,label: false, class: "input-group-field", placeholder: t(".search") %>
7
7
  <div class="input-group-button">
8
- <button type="submit" class="button button--muted">
9
- <%= icon "magnifying-glass", aria_label: t(".search") %>
8
+ <button type="submit" class="button">
9
+ <%= icon "magnifying-glass", aria_label: t(".search"), role: "img" %>
10
10
  </button>
11
11
  </div>
12
12
  </div>
@@ -1,17 +1,18 @@
1
- <div class="card" id="conferences">
1
+ <div class="card with-overflow" id="conferences">
2
2
  <div class="card-divider">
3
3
  <h2 class="card-title">
4
4
  <%= t "decidim.admin.titles.conferences" %>
5
5
  <%= link_to t("actions.new_conference", scope: "decidim.admin"), new_conference_path, class: "button tiny button--title" if allowed_to? :create, :conference %>
6
6
  </h2>
7
7
  </div>
8
+ <%= admin_filter_selector %>
8
9
  <div class="card-section">
9
10
  <div class="table-scroll">
10
11
  <table class="table-list">
11
12
  <thead>
12
13
  <tr>
13
14
  <th><%= t("models.conference.fields.title", scope: "decidim.admin") %></th>
14
- <th><%= t("models.conference.fields.created_at", scope: "decidim.admin") %></th>
15
+ <th><%= sort_link(query, :created_at, t("models.conference.fields.created_at", scope: "decidim.admin"), default_order: :desc) %></th>
15
16
  <th class="table-list__actions"><%= t("models.conference.fields.published", scope: "decidim.admin") %></th>
16
17
  <th></th>
17
18
  </tr>
@@ -22,11 +23,13 @@
22
23
  <td>
23
24
  <% if conference.promoted? %>
24
25
  <span data-tooltip class="icon-state icon-highlight" aria-haspopup="true" data-disable-hover="false" title="<%= t("models.conference.fields.promoted", scope: "decidim.admin") %>">
25
- <%= icon "star" %>
26
+ <%= icon "star", aria_label: t("models.conference.fields.promoted", scope: "decidim.admin"), role: "img" %>
26
27
  </span>
27
28
  <% end %>
28
29
  <% if allowed_to? :update, :conference, conference: conference %>
29
30
  <%= link_to translated_attribute(conference.title), edit_conference_path(conference) %><br>
31
+ <% elsif allowed_to? :read, :component, conference: conference %>
32
+ <%= link_to translated_attribute(conference.title), components_path(conference) %><br>
30
33
  <% elsif allowed_to? :preview, :conference, conference: conference %>
31
34
  <%= link_to translated_attribute(conference.title), decidim_conferences.conference_path(conference) %><br>
32
35
  <% elsif allowed_to? :read, :moderation, conference: conference %>
@@ -8,10 +8,12 @@
8
8
  <ul class="tabs buttons__row" id="conference-row-<%= seed %>-tabs" data-tabs>
9
9
  <% categories.each_with_index do |category, i| %>
10
10
  <li class="tabs-title<%= " is-active" if i == 0 %>">
11
- <!-- Wrap button in an anchor to make foundation tabs work -->
12
- <a href="#conference-row-<%= seed %>-tab<%= i %>">
13
- <button class="button button--shadow secondary tiny light"><%= category.present? ? translated_attribute(category.name) : "other" %></button>
14
- </a>
11
+ <!-- Wrap the anchor inside a div to keep correct button styling -->
12
+ <div>
13
+ <a href="#conference-row-<%= seed %>-tab<%= i %>" class="button button--shadow tiny hollow">
14
+ <%= category.present? ? translated_attribute(category.name) : "other" %>
15
+ </a>
16
+ </div>
15
17
  </li>
16
18
  <% end %>
17
19
  </ul>