decidim-decidim_awesome 0.10.3 → 0.11.1
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of decidim-decidim_awesome might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/CHANGELOG.md +14 -5
- data/README.md +65 -67
- data/app/cells/concerns/decidim/decidim_awesome/global_menu_cell_override.rb +20 -0
- data/app/cells/concerns/decidim/decidim_awesome/proposal_l_cell_override.rb +44 -0
- data/app/cells/decidim/decidim_awesome/content_blocks/map/show.erb +5 -12
- data/app/cells/decidim/decidim_awesome/voting/proposal_metadata_cell.rb +54 -0
- data/app/cells/decidim/decidim_awesome/voting/voting_cards_proposal/modal.erb +18 -0
- data/app/cells/decidim/decidim_awesome/voting/voting_cards_proposal/show.erb +37 -32
- data/app/cells/decidim/decidim_awesome/voting/voting_cards_proposal_cell.rb +9 -4
- data/app/commands/concerns/decidim/decidim_awesome/admin/needs_constraint_helpers.rb +1 -1
- data/app/commands/concerns/decidim/decidim_awesome/proposals/create_proposal_override.rb +2 -2
- data/app/commands/concerns/decidim/decidim_awesome/proposals/update_proposal_override.rb +2 -2
- data/app/commands/decidim/decidim_awesome/admin/create_constraint.rb +1 -1
- data/app/commands/decidim/decidim_awesome/admin/destroy_custom_redirect.rb +1 -1
- data/app/commands/decidim/decidim_awesome/admin/destroy_menu_hack.rb +1 -1
- data/app/commands/decidim/decidim_awesome/admin/rename_scope_label.rb +1 -1
- data/app/commands/decidim/decidim_awesome/admin/update_constraint.rb +1 -1
- data/app/commands/decidim/decidim_awesome/admin/update_custom_redirect.rb +2 -2
- data/app/commands/decidim/decidim_awesome/command.rb +1 -7
- data/app/controllers/concerns/decidim/decidim_awesome/admin/maintenance_context.rb +1 -1
- data/app/controllers/concerns/decidim/decidim_awesome/admin_accountability/admin/filterable_helper.rb +3 -4
- data/app/controllers/concerns/decidim/decidim_awesome/content_security_policy.rb +34 -0
- data/app/controllers/concerns/decidim/decidim_awesome/not_found_redirect.rb +1 -1
- data/app/controllers/concerns/decidim/decidim_awesome/proposals/orderable_override.rb +22 -9
- data/app/controllers/concerns/decidim/decidim_awesome/proposals/proposal_votes_controller_override.rb +3 -3
- data/app/controllers/decidim/decidim_awesome/admin/admin_accountability_controller.rb +7 -7
- data/app/controllers/decidim/decidim_awesome/admin/checks_controller.rb +7 -7
- data/app/controllers/decidim/decidim_awesome/admin/config_controller.rb +8 -10
- data/app/controllers/decidim/decidim_awesome/admin/constraints_controller.rb +20 -19
- data/app/controllers/decidim/decidim_awesome/admin/custom_redirects_controller.rb +6 -8
- data/app/controllers/decidim/decidim_awesome/admin/maintenance_controller.rb +2 -2
- data/app/controllers/decidim/decidim_awesome/admin/menu_hacks_controller.rb +6 -8
- data/app/controllers/decidim/decidim_awesome/admin/proposal_custom_fields_controller.rb +2 -2
- data/app/controllers/decidim/decidim_awesome/admin/scoped_admins_controller.rb +2 -2
- data/app/controllers/decidim/decidim_awesome/admin/scoped_styles_controller.rb +2 -2
- data/app/controllers/decidim/decidim_awesome/blank_component_controller.rb +8 -3
- data/app/controllers/decidim/decidim_awesome/editor_images_controller.rb +3 -3
- data/app/controllers/decidim/decidim_awesome/iframe_component/iframe_controller.rb +11 -5
- data/app/forms/concerns/decidim/decidim_awesome/proposals/proposal_wizard_create_step_form_override.rb +1 -1
- data/app/forms/decidim/decidim_awesome/admin/config_form.rb +13 -25
- data/app/forms/decidim/decidim_awesome/admin/custom_redirect_form.rb +2 -2
- data/app/forms/decidim/decidim_awesome/admin/intergram_form.rb +4 -0
- data/app/forms/decidim/decidim_awesome/admin/menu_form.rb +4 -4
- data/app/helpers/concerns/decidim/decidim_awesome/amendments_helper_override.rb +8 -1
- data/app/helpers/concerns/decidim/decidim_awesome/breadcrumb_helper_override.rb +23 -0
- data/app/helpers/concerns/decidim/decidim_awesome/proposals/application_helper_override.rb +23 -39
- data/app/helpers/decidim/decidim_awesome/admin/config_constraints_helpers.rb +2 -2
- data/app/helpers/decidim/decidim_awesome/map_helper.rb +8 -27
- data/app/jobs/decidim/decidim_awesome/migrate_legacy_images_job.rb +5 -4
- data/app/middleware/decidim/decidim_awesome/current_config.rb +3 -5
- data/app/models/concerns/decidim/decidim_awesome/has_proposal_extra_fields.rb +1 -1
- data/app/models/decidim/decidim_awesome/awesome_config.rb +1 -1
- data/app/models/decidim/decidim_awesome/paper_trail_version.rb +4 -8
- data/app/models/decidim/decidim_awesome/proposal_extra_field.rb +1 -1
- data/app/models/decidim/decidim_awesome/vote_weight.rb +2 -2
- data/app/overrides/decidim/proposals/proposals/{show → _proposal_aside}/limit_amendments_modal.html.erb.deface +1 -1
- data/app/overrides/decidim/proposals/proposals/_vote_button/replace_vote_button.html.erb.deface +1 -1
- data/app/overrides/layouts/decidim/_decidim_javascript/add_awesome_tags.html.erb.deface +6 -0
- data/app/overrides/layouts/decidim/_head/add_awesome_tags.html.erb.deface +4 -11
- data/app/overrides/layouts/decidim/admin/_header/{replace_scripts.html.erb.deface → add_awesome_tags.html.erb.deface} +4 -4
- data/app/packs/entrypoints/decidim_admin_decidim_awesome.js +1 -2
- data/app/packs/entrypoints/decidim_admin_decidim_awesome_global.js +4 -0
- data/app/packs/entrypoints/decidim_admin_decidim_awesome_global.scss +1 -0
- data/app/packs/entrypoints/decidim_decidim_awesome.js +2 -2
- data/app/packs/entrypoints/decidim_editor.js +14 -0
- data/app/packs/src/decidim/decidim_awesome/admin/auto_edit.js +95 -70
- data/app/packs/src/decidim/decidim_awesome/admin/check_redirections.js +46 -41
- data/app/packs/src/decidim/decidim_awesome/admin/codemirror.js +3 -3
- data/app/packs/src/decidim/decidim_awesome/admin/constraint_form_events.js +115 -0
- data/app/packs/src/decidim/decidim_awesome/admin/custom_fields_builder.js +4 -1
- data/app/packs/src/decidim/decidim_awesome/admin/form_exit_warn.js +22 -11
- data/app/packs/src/decidim/decidim_awesome/admin/proposal_sortings.js +26 -8
- data/app/packs/src/decidim/decidim_awesome/admin/user_picker.js +34 -21
- data/app/packs/src/decidim/decidim_awesome/amendments/show_modal_on_limits.js +20 -22
- data/app/packs/src/decidim/decidim_awesome/awesome_admin.js +5 -16
- data/app/packs/src/decidim/decidim_awesome/awesome_admin_global.js +1 -0
- data/app/packs/src/decidim/decidim_awesome/awesome_application.js +0 -15
- data/app/packs/src/decidim/decidim_awesome/awesome_map/api/fetcher.js +33 -11
- data/app/packs/src/decidim/decidim_awesome/awesome_map/api/meetings_fetcher.js +9 -12
- data/app/packs/src/decidim/decidim_awesome/awesome_map/api/proposals_fetcher.js +28 -0
- data/app/packs/src/decidim/decidim_awesome/awesome_map/awesome_map.js +3 -4
- data/app/packs/src/decidim/decidim_awesome/awesome_map/controllers/controller.js +12 -12
- data/app/packs/src/decidim/decidim_awesome/awesome_map/controllers/meetings_controller.js +11 -7
- data/app/packs/src/decidim/decidim_awesome/awesome_map/controllers/proposals_controller.js +6 -13
- data/app/packs/src/decidim/decidim_awesome/awesome_map/controls_ui.js +51 -20
- data/app/packs/src/decidim/decidim_awesome/awesome_map/load_map.js +27 -18
- data/app/packs/src/decidim/decidim_awesome/editor/index.js +94 -0
- data/app/packs/src/decidim/decidim_awesome/forms/autosave.js +28 -23
- data/app/packs/src/decidim/decidim_awesome/forms/custom_fields_renderer.js +9 -14
- data/app/packs/src/decidim/decidim_awesome/forms/rich_text_plugin.js +27 -32
- data/app/packs/src/decidim/decidim_awesome/proposals/images.js +16 -10
- data/app/packs/src/decidim/decidim_awesome/voting/voting_cards.js +47 -38
- data/app/packs/stylesheets/decidim/decidim_awesome/admin/auto_edits.scss +11 -12
- data/app/packs/stylesheets/decidim/decidim_awesome/admin/check_redirections.scss +15 -0
- data/app/packs/stylesheets/decidim/decidim_awesome/admin/codemirror.scss +19 -12
- data/app/packs/stylesheets/decidim/decidim_awesome/admin/constraints.scss +8 -32
- data/app/packs/stylesheets/decidim/decidim_awesome/admin/custom_fields.scss +28 -78
- data/app/packs/stylesheets/decidim/decidim_awesome/admin/custom_styles.scss +48 -0
- data/app/packs/stylesheets/decidim/decidim_awesome/admin/intergram_fixes.scss +11 -0
- data/app/packs/stylesheets/decidim/decidim_awesome/admin/user_picker.scss +15 -24
- data/app/packs/stylesheets/decidim/decidim_awesome/amendments/modal.scss +5 -0
- data/app/packs/stylesheets/decidim/decidim_awesome/awesome_admin.scss +9 -47
- data/app/packs/stylesheets/decidim/decidim_awesome/awesome_admin_global.scss +3 -12
- data/app/packs/stylesheets/decidim/decidim_awesome/awesome_application.scss +3 -19
- data/app/packs/stylesheets/decidim/decidim_awesome/awesome_iframe/iframe.scss +1 -1
- data/app/packs/stylesheets/decidim/decidim_awesome/awesome_map/map.scss +27 -21
- data/app/packs/stylesheets/decidim/decidim_awesome/forms/autosave.scss +6 -6
- data/app/packs/stylesheets/decidim/decidim_awesome/forms/custom_fields.scss +32 -101
- data/app/packs/stylesheets/decidim/decidim_awesome/shared/spinner.scss +5 -26
- data/app/packs/stylesheets/decidim/decidim_awesome/voting/voting_cards.scss +34 -52
- data/app/permissions/decidim/decidim_awesome/permissions.rb +3 -4
- data/app/presenters/concerns/decidim/decidim_awesome/breadcrumb_root_menu_item_presenter_override.rb +23 -0
- data/app/presenters/concerns/decidim/decidim_awesome/menu_item_presenter_override.rb +10 -2
- data/app/presenters/concerns/decidim/decidim_awesome/menu_presenter_override.rb +8 -0
- data/app/presenters/decidim/decidim_awesome/participatory_space_role_presenter.rb +1 -1
- data/app/presenters/decidim/decidim_awesome/private_data_presenter.rb +11 -11
- data/app/presenters/decidim/decidim_awesome/user_entity_presenter.rb +1 -1
- data/app/queries/decidim/decidim_awesome/private_data_finder.rb +1 -1
- data/app/serializers/decidim/decidim_awesome/proposals/private_proposal_serializer.rb +0 -8
- data/app/views/decidim/decidim_awesome/admin/admin_accountability/index.html.erb +23 -17
- data/app/views/decidim/decidim_awesome/admin/checks/index.html.erb +1 -3
- data/app/views/decidim/decidim_awesome/admin/config/_autoedit_box_label.html.erb +3 -3
- data/app/views/decidim/decidim_awesome/admin/config/_constraints.html.erb +20 -21
- data/app/views/decidim/decidim_awesome/admin/config/_form_admins.html.erb +6 -5
- data/app/views/decidim/decidim_awesome/admin/config/_form_editors.html.erb +2 -2
- data/app/views/decidim/decidim_awesome/admin/config/_form_livechat.html.erb +39 -23
- data/app/views/decidim/decidim_awesome/admin/config/_form_proposal_custom_fields.html.erb +4 -6
- data/app/views/decidim/decidim_awesome/admin/config/_form_proposals.html.erb +64 -76
- data/app/views/decidim/decidim_awesome/admin/config/_form_styles.html.erb +15 -11
- data/app/views/decidim/decidim_awesome/admin/config/_form_surveys.html.erb +8 -6
- data/app/views/decidim/decidim_awesome/admin/config/show.html.erb +22 -12
- data/app/views/decidim/decidim_awesome/admin/constraints/_form.html.erb +1 -49
- data/app/views/decidim/decidim_awesome/admin/constraints/new.html.erb +14 -9
- data/app/views/decidim/decidim_awesome/admin/constraints/show.html.erb +14 -9
- data/app/views/decidim/decidim_awesome/admin/custom_redirects/_form.html.erb +20 -5
- data/app/views/decidim/decidim_awesome/admin/custom_redirects/edit.html.erb +5 -5
- data/app/views/decidim/decidim_awesome/admin/custom_redirects/index.html.erb +15 -15
- data/app/views/decidim/decidim_awesome/admin/custom_redirects/new.html.erb +5 -5
- data/app/views/decidim/decidim_awesome/admin/maintenance/_private_data.html.erb +4 -4
- data/app/views/decidim/decidim_awesome/admin/menu_hacks/_form.html.erb +6 -6
- data/app/views/decidim/decidim_awesome/admin/menu_hacks/edit.html.erb +21 -12
- data/app/views/decidim/decidim_awesome/admin/menu_hacks/index.html.erb +16 -18
- data/app/views/decidim/decidim_awesome/admin/menu_hacks/new.html.erb +21 -12
- data/app/views/decidim/decidim_awesome/admin/shared/_filters_with_date.html.erb +14 -18
- data/app/views/decidim/decidim_awesome/amendments/_modal.html.erb +18 -11
- data/app/views/decidim/decidim_awesome/custom_fields/_form_render.html.erb +3 -5
- data/app/views/decidim/decidim_awesome/iframe_component/iframe/show.html.erb +7 -12
- data/app/views/decidim/decidim_awesome/map_component/map/_map_template.html.erb +53 -37
- data/app/views/decidim/decidim_awesome/map_component/map/show.html.erb +14 -5
- data/app/views/decidim/decidim_awesome/voting/voting_cards/_show_vote_button.html.erb +0 -3
- data/app/views/layouts/decidim/decidim_awesome/_awesome_config.html.erb +9 -7
- data/app/views/layouts/decidim/decidim_awesome/_intergram_widget.html.erb +9 -6
- data/app/views/layouts/decidim/decidim_awesome/admin/_base.html.erb +3 -12
- data/config/assets.rb +3 -33
- data/config/i18n-tasks.yml +1 -0
- data/config/locales/ca.yml +17 -94
- data/config/locales/cs.yml +15 -93
- data/config/locales/de.yml +15 -91
- data/config/locales/en.yml +24 -28
- data/config/locales/es.yml +18 -96
- data/config/locales/eu.yml +8 -18
- data/config/locales/fr.yml +15 -94
- data/config/locales/hu.yml +4 -18
- data/config/locales/it.yml +9 -26
- data/config/locales/ja.yml +16 -93
- data/config/locales/lt.yml +2 -4
- data/config/locales/nl.yml +8 -18
- data/config/locales/pt-BR.yml +11 -25
- data/config/locales/ro-RO.yml +2 -14
- data/config/locales/sv.yml +10 -21
- data/config/rubocop/disabled.yml +11 -0
- data/config/rubocop/faker.yml +480 -0
- data/config/rubocop/rails.yml +88 -0
- data/config/rubocop/rspec.yml +65 -0
- data/config/rubocop/ruby.yml +1210 -0
- data/db/migrate/20240306175331_rename_editor_images_awesome_config.rb +18 -0
- data/db/migrate/20240729164227_add_decidim_awesome_proposal_private_fields_date.rb +1 -1
- data/db/seeds.rb +3 -3
- data/lib/decidim/decidim_awesome/admin_engine.rb +4 -1
- data/lib/decidim/decidim_awesome/api/types/translated_custom_fields_type.rb +2 -3
- data/lib/decidim/decidim_awesome/awesome.rb +42 -28
- data/lib/decidim/decidim_awesome/awesome_helpers.rb +1 -1
- data/lib/decidim/decidim_awesome/checksums.yml +39 -60
- data/lib/decidim/decidim_awesome/config.rb +1 -1
- data/lib/decidim/decidim_awesome/custom_fields.rb +5 -5
- data/lib/decidim/decidim_awesome/engine.rb +24 -6
- data/lib/decidim/decidim_awesome/iframe_component/component.rb +1 -2
- data/lib/decidim/decidim_awesome/lock.rb +2 -2
- data/lib/decidim/decidim_awesome/map_component/component.rb +1 -1
- data/lib/decidim/decidim_awesome/menu.rb +33 -14
- data/lib/decidim/decidim_awesome/menu_hacker.rb +4 -8
- data/lib/decidim/decidim_awesome/system_checker.rb +2 -4
- data/lib/decidim/decidim_awesome/test/factories.rb +10 -10
- data/lib/decidim/decidim_awesome/test/initializer.rb +3 -11
- data/lib/decidim/decidim_awesome/test/layouts/decidim/_head.html.erb +2 -2
- data/lib/decidim/decidim_awesome/test/layouts/decidim/admin/_header.html.erb +2 -2
- data/lib/decidim/decidim_awesome/test/shared_examples/box_label_editor_examples.rb +18 -18
- data/lib/decidim/decidim_awesome/test/shared_examples/config_examples.rb +3 -3
- data/lib/decidim/decidim_awesome/test/shared_examples/custom_fields_examples.rb +11 -11
- data/lib/decidim/decidim_awesome/test/shared_examples/custom_redirects_contexts.rb +7 -7
- data/lib/decidim/decidim_awesome/test/shared_examples/editor_examples.rb +26 -66
- data/lib/decidim/decidim_awesome/test/shared_examples/menu_hack_contexts.rb +10 -9
- data/lib/decidim/decidim_awesome/test/shared_examples/scoped_admins_examples.rb +30 -20
- data/lib/decidim/decidim_awesome/test/shared_examples/summary_examples.rb +19 -10
- data/lib/decidim/decidim_awesome/version.rb +2 -2
- data/lib/decidim/decidim_awesome/voting_manifest.rb +5 -10
- data/lib/decidim/decidim_awesome.rb +1 -2
- data/lib/tasks/decidim_awesome_active_storage_migrations_tasks.rake +1 -1
- data/lib/tasks/decidim_awesome_upgrade_tasks.rake +4 -0
- data/package.json +19 -28
- metadata +40 -56
- data/app/cells/concerns/decidim/decidim_awesome/proposal_m_cell_override.rb +0 -18
- data/app/cells/decidim/decidim_awesome/voting/voting_cards_counter/show.erb +0 -15
- data/app/cells/decidim/decidim_awesome/voting/voting_cards_counter/vote_button.erb +0 -15
- data/app/cells/decidim/decidim_awesome/voting/voting_cards_counter_cell.rb +0 -21
- data/app/cells/decidim/decidim_awesome/voting/voting_cards_proposal_modal/show.erb +0 -16
- data/app/cells/decidim/decidim_awesome/voting/voting_cards_proposal_modal_cell.rb +0 -20
- data/app/cells/decidim/proposals/proposal_m/footer.erb +0 -13
- data/app/overrides/layouts/decidim/_head/add_awesome_legacy_scripts.rb +0 -14
- data/app/overrides/layouts/decidim/admin/_header/replace_styles.html.erb.deface +0 -3
- data/app/packs/entrypoints/decidim_admin_decidim_awesome_custom_fields.js +0 -2
- data/app/packs/entrypoints/decidim_decidim_awesome_admin_form_exit_warn.js +0 -1
- data/app/packs/src/decidim/decidim_awesome/admin/constraints.js +0 -55
- data/app/packs/src/decidim/decidim_awesome/editors/editor.js +0 -213
- data/app/packs/stylesheets/decidim/decidim_awesome/editors/markdown_editor.scss +0 -19
- data/app/packs/stylesheets/decidim/decidim_awesome/editors/quill_editor.scss +0 -58
- data/app/packs/stylesheets/vendor/select2-foundation-theme.scss +0 -348
- data/app/serializers/concerns/decidim/decidim_awesome/proposal_serializer_override.rb +0 -65
- data/app/views/decidim/decidim_awesome/admin/config/_modal.html.erb +0 -11
- data/app/views/decidim/decidim_awesome/voting/voting_cards/_proposal_m_cell_footer.erb +0 -15
- /data/app/packs/src/decidim/decidim_awesome/{editors/tabs_focus.js → admin/tabs_change.js} +0 -0
@@ -21,6 +21,7 @@ module Decidim
|
|
21
21
|
default = default_items.find { |i| i.url.gsub(/\?.*/, "") == item.url }
|
22
22
|
if default
|
23
23
|
item.send("overrided?=", true)
|
24
|
+
item[:original_active] = default.active
|
24
25
|
@items.reject! { |i| i.url.gsub(/\?.*/, "") == item.url }
|
25
26
|
end
|
26
27
|
@items << item
|
@@ -36,10 +37,7 @@ module Decidim
|
|
36
37
|
attr_reader :name, :view
|
37
38
|
|
38
39
|
def default_items
|
39
|
-
@default_items ||= build_menu.items
|
40
|
-
item.instance_variable_set(:@active, method(:activate?)) unless item.active == :exact
|
41
|
-
item
|
42
|
-
end
|
40
|
+
@default_items ||= build_menu.items
|
43
41
|
end
|
44
42
|
|
45
43
|
def build_menu
|
@@ -48,7 +46,6 @@ module Decidim
|
|
48
46
|
menu
|
49
47
|
end
|
50
48
|
|
51
|
-
# rubocop:disable Style/OpenStructUse
|
52
49
|
def menu_overrides
|
53
50
|
@menu_overrides ||= current_config.map do |item|
|
54
51
|
OpenStruct.new(
|
@@ -65,7 +62,6 @@ module Decidim
|
|
65
62
|
)
|
66
63
|
end
|
67
64
|
end
|
68
|
-
# rubocop:enable Style/OpenStructUse
|
69
65
|
|
70
66
|
def activate?(url, view)
|
71
67
|
urls = @items.map(&:url).sort_by(&:length).reverse
|
@@ -83,14 +79,14 @@ module Decidim
|
|
83
79
|
when "verified_user"
|
84
80
|
# the cleaner version should be user.authorizations.any?
|
85
81
|
# but there is not relationship between users and authorizations
|
86
|
-
Decidim::Authorization.where(user:
|
82
|
+
Decidim::Authorization.where(user:).any? { |auth| auth.granted? && !auth.expired? }
|
87
83
|
else
|
88
84
|
true
|
89
85
|
end
|
90
86
|
end
|
91
87
|
|
92
88
|
def current_config
|
93
|
-
@current_config ||= (AwesomeConfig.find_by(var: name, organization:
|
89
|
+
@current_config ||= (AwesomeConfig.find_by(var: name, organization:)&.value || []).filter { |i| i.is_a? Hash }
|
94
90
|
end
|
95
91
|
end
|
96
92
|
end
|
@@ -24,8 +24,8 @@ module Decidim
|
|
24
24
|
|
25
25
|
delegate :to_h, to: :overrides
|
26
26
|
|
27
|
-
def each(&
|
28
|
-
to_h.each(&
|
27
|
+
def each(&)
|
28
|
+
to_h.each(&)
|
29
29
|
end
|
30
30
|
|
31
31
|
def each_file
|
@@ -58,11 +58,9 @@ module Decidim
|
|
58
58
|
Digest::MD5.hexdigest(File.read(file))
|
59
59
|
end
|
60
60
|
|
61
|
-
# rubocop:disable Style/OpenStructUse
|
62
61
|
def to_struct(obj)
|
63
62
|
OpenStruct.new obj
|
64
63
|
end
|
65
|
-
# rubocop:enable Style/OpenStructUse
|
66
64
|
end
|
67
65
|
end
|
68
66
|
end
|
@@ -8,22 +8,22 @@ FactoryBot.define do
|
|
8
8
|
factory :awesome_config, class: "Decidim::DecidimAwesome::AwesomeConfig" do
|
9
9
|
var { Faker::Hacker.noun }
|
10
10
|
value { Decidim::DecidimAwesome.config.to_a.sample(1).to_h }
|
11
|
-
organization
|
11
|
+
organization
|
12
12
|
end
|
13
13
|
|
14
14
|
factory :config_constraint, class: "Decidim::DecidimAwesome::ConfigConstraint" do
|
15
15
|
settings { { Faker::Hacker.noun => Faker::Hacker.noun } }
|
16
|
-
awesome_config
|
16
|
+
awesome_config
|
17
17
|
end
|
18
18
|
|
19
19
|
factory :awesome_editor_image, class: "Decidim::DecidimAwesome::EditorImage" do
|
20
20
|
file { Decidim::Dev.test_file("city.jpeg", "image/jpeg") }
|
21
21
|
path { Faker::Internet.url(host: "", scheme: "") }
|
22
|
-
author {
|
23
|
-
organization
|
22
|
+
author { association :user }
|
23
|
+
organization
|
24
24
|
end
|
25
25
|
|
26
|
-
factory :paper_trail_version, class: Decidim::DecidimAwesome::PaperTrailVersion do
|
26
|
+
factory :paper_trail_version, class: "Decidim::DecidimAwesome::PaperTrailVersion" do
|
27
27
|
item_id { user.id }
|
28
28
|
item_type { "Decidim::ParticipatoryProcessUserRole" }
|
29
29
|
event { "create" }
|
@@ -33,28 +33,28 @@ FactoryBot.define do
|
|
33
33
|
factory :map_component, parent: :component do
|
34
34
|
name { Decidim::Components::Namer.new(participatory_space.organization.available_locales, :proposals).i18n_name }
|
35
35
|
manifest_name { :awesome_map }
|
36
|
-
participatory_space {
|
36
|
+
participatory_space { association(:participatory_process, :with_steps, organization:) }
|
37
37
|
end
|
38
38
|
|
39
39
|
factory :iframe_component, parent: :component do
|
40
40
|
name { Decidim::Components::Namer.new(participatory_space.organization.available_locales, :proposals).i18n_name }
|
41
41
|
manifest_name { :awesome_iframe }
|
42
|
-
participatory_space {
|
42
|
+
participatory_space { association(:participatory_process, :with_steps, organization:) }
|
43
43
|
end
|
44
44
|
|
45
45
|
factory :awesome_vote_weight, class: "Decidim::DecidimAwesome::VoteWeight" do
|
46
|
-
vote {
|
46
|
+
vote { association(:proposal_vote) }
|
47
47
|
sequence(:weight) { |n| n }
|
48
48
|
end
|
49
49
|
|
50
50
|
factory :awesome_proposal_extra_fields, class: "Decidim::DecidimAwesome::ProposalExtraField" do
|
51
|
-
proposal
|
51
|
+
proposal
|
52
52
|
|
53
53
|
trait :with_votes do
|
54
54
|
after :create do |weight|
|
55
55
|
5.times.collect do |n|
|
56
56
|
vote = create(:proposal_vote, proposal: weight.proposal, author: create(:user, organization: weight.proposal.organization))
|
57
|
-
create(:awesome_vote_weight, vote
|
57
|
+
create(:awesome_vote_weight, vote:, weight: n + 1)
|
58
58
|
end
|
59
59
|
end
|
60
60
|
end
|
@@ -3,11 +3,9 @@
|
|
3
3
|
Decidim::DecidimAwesome.configure do |config|
|
4
4
|
if ENV.fetch("FEATURES", nil) == "disabled"
|
5
5
|
[
|
6
|
-
:
|
7
|
-
:
|
6
|
+
:allow_images_in_editors,
|
7
|
+
:allow_videos_in_editors,
|
8
8
|
:allow_images_in_proposals,
|
9
|
-
:use_markdown_editor,
|
10
|
-
:allow_images_in_markdown_editor,
|
11
9
|
:auto_save_forms,
|
12
10
|
:intergram_for_admins,
|
13
11
|
:intergram_for_public,
|
@@ -15,6 +13,7 @@ Decidim::DecidimAwesome.configure do |config|
|
|
15
13
|
:proposal_custom_fields,
|
16
14
|
:proposal_private_custom_fields,
|
17
15
|
:menu,
|
16
|
+
:home_content_block_menu,
|
18
17
|
:scoped_admins,
|
19
18
|
:custom_redirects,
|
20
19
|
:validate_title_min_length,
|
@@ -36,10 +35,3 @@ Decidim::DecidimAwesome.configure do |config|
|
|
36
35
|
config.disabled_components = [:awesome_map, :awesome_iframe]
|
37
36
|
end
|
38
37
|
end
|
39
|
-
|
40
|
-
if Decidim::DecidimAwesome.legacy_version?
|
41
|
-
Rails.application.config.to_prepare do
|
42
|
-
Decidim::Api::Schema.max_complexity = 5000
|
43
|
-
Decidim::Api::Schema.max_depth = 50
|
44
|
-
end
|
45
|
-
end
|
@@ -18,11 +18,11 @@
|
|
18
18
|
<meta property="og:image" content="<%= decidim_meta_image_url %>">
|
19
19
|
|
20
20
|
<%= favicon %>
|
21
|
-
<%=
|
21
|
+
<%= append_stylesheet_pack_tag "decidim_core", media: "all" %>
|
22
22
|
<%= invisible_captcha_styles %>
|
23
23
|
|
24
24
|
<%= organization_colors %>
|
25
|
-
<%=
|
25
|
+
<%= append_javascript_pack_tag "decidim_core", defer: false %>
|
26
26
|
|
27
27
|
<%= render partial: "layouts/decidim/head_extra" %>
|
28
28
|
<%== current_organization.header_snippets if Decidim.enable_html_header_snippets %>
|
@@ -2,7 +2,7 @@
|
|
2
2
|
<%= csrf_meta_tags %>
|
3
3
|
<%= organization_colors %>
|
4
4
|
|
5
|
-
<%=
|
6
|
-
<%=
|
5
|
+
<%= append_stylesheet_pack_tag "decidim_admin", media: "all" %>
|
6
|
+
<%= append_javascript_pack_tag "decidim_admin", defer: false %>
|
7
7
|
|
8
8
|
<%= snippets.display(:head) %>
|
@@ -5,19 +5,19 @@ shared_examples "edits box label inline" do |test_case, key|
|
|
5
5
|
|
6
6
|
it "updates the label when no changes" do
|
7
7
|
link = find("[data-key=#{key}] a.awesome-auto-edit", match: :first)
|
8
|
-
expect(page).not_to
|
8
|
+
expect(page).not_to have_field(class: "awesome-auto-edit")
|
9
9
|
link.click
|
10
|
-
expect(page).to
|
10
|
+
expect(page).to have_field(class: "awesome-auto-edit")
|
11
11
|
find("body").click
|
12
|
-
expect(page).not_to
|
12
|
+
expect(page).not_to have_field(class: "awesome-auto-edit")
|
13
13
|
link.click
|
14
14
|
input = find("[data-key=#{key}] input.awesome-auto-edit")
|
15
15
|
input.fill_in with: "A new làbel\n"
|
16
16
|
sleep 1
|
17
|
-
expect(page).not_to
|
17
|
+
expect(page).not_to have_field(class: "awesome-auto-edit")
|
18
18
|
expect(page).to have_css("span.awesome-auto-edit[data-key=a_new_label]")
|
19
19
|
|
20
|
-
|
20
|
+
click_link_or_button "Update configuration"
|
21
21
|
case test_case
|
22
22
|
when :css
|
23
23
|
expect(page).to have_content("body {background: red;}")
|
@@ -48,19 +48,19 @@ shared_examples "edits box label inline" do |test_case, key|
|
|
48
48
|
end
|
49
49
|
|
50
50
|
link = find("[data-key=#{key}] a.awesome-auto-edit", match: :first)
|
51
|
-
expect(page).not_to
|
51
|
+
expect(page).not_to have_field(class: "awesome-auto-edit")
|
52
52
|
link.click
|
53
|
-
expect(page).to
|
53
|
+
expect(page).to have_field(class: "awesome-auto-edit")
|
54
54
|
find("body").click
|
55
|
-
expect(page).not_to
|
55
|
+
expect(page).not_to have_field(class: "awesome-auto-edit")
|
56
56
|
link.click
|
57
57
|
input = find("[data-key=#{key}] input.awesome-auto-edit")
|
58
58
|
input.fill_in with: "A new làbel\n"
|
59
59
|
sleep 1
|
60
|
-
expect(page).not_to
|
60
|
+
expect(page).not_to have_field(class: "awesome-auto-edit")
|
61
61
|
expect(page).to have_css("span.awesome-auto-edit[data-key=a_new_label]")
|
62
62
|
|
63
|
-
|
63
|
+
click_link_or_button "Update configuration"
|
64
64
|
case test_case
|
65
65
|
when :css
|
66
66
|
expect(page).to have_admin_callout("updated successfully")
|
@@ -78,34 +78,34 @@ shared_examples "edits box label inline" do |test_case, key|
|
|
78
78
|
|
79
79
|
it "updates the label with post changes" do
|
80
80
|
link = find("[data-key=#{key}] a.awesome-auto-edit", match: :first)
|
81
|
-
expect(page).not_to
|
81
|
+
expect(page).not_to have_field(class: "awesome-auto-edit")
|
82
82
|
link.click
|
83
|
-
expect(page).to
|
83
|
+
expect(page).to have_field(class: "awesome-auto-edit")
|
84
84
|
find("body").click
|
85
|
-
expect(page).not_to
|
85
|
+
expect(page).not_to have_field(class: "awesome-auto-edit")
|
86
86
|
link.click
|
87
87
|
input = find("[data-key=#{key}] input.awesome-auto-edit")
|
88
88
|
input.fill_in with: "A new làbel\n"
|
89
89
|
sleep 1
|
90
|
-
expect(page).not_to
|
90
|
+
expect(page).not_to have_field(class: "awesome-auto-edit")
|
91
91
|
expect(page).to have_css("span.awesome-auto-edit[data-key=a_new_label]")
|
92
92
|
|
93
93
|
case test_case
|
94
94
|
when :css
|
95
|
-
sleep
|
95
|
+
sleep 1
|
96
96
|
page.execute_script('document.querySelector("[data-key=a_new_label] .CodeMirror").CodeMirror.setValue("body {background: lilac;}");')
|
97
|
-
|
97
|
+
click_link_or_button "Update configuration"
|
98
98
|
expect(page).to have_admin_callout("updated successfully")
|
99
99
|
expect(page).to have_content("body {background: lilac;}")
|
100
100
|
when :fields
|
101
101
|
expect(page).to have_content("Full Name")
|
102
102
|
sleep 2
|
103
103
|
page.execute_script("$('.proposal_custom_fields_container[data-key=a_new_label] .proposal_custom_fields_editor')[0].FormBuilder.actions.setData(#{data})")
|
104
|
-
|
104
|
+
click_link_or_button "Update configuration"
|
105
105
|
expect(page).to have_content("Short Name")
|
106
106
|
when :admins
|
107
107
|
page.execute_script("$('.multiusers-select:first').append(new Option('#{user.name}', #{user.id}, true, true)).trigger('change');")
|
108
|
-
|
108
|
+
click_link_or_button "Update configuration"
|
109
109
|
expect(page).to have_content(user.name.to_s)
|
110
110
|
expect(page).to have_content(user2.name.to_s)
|
111
111
|
expect(page).to have_content(user3.name.to_s)
|
@@ -4,7 +4,7 @@ shared_examples "javascript config vars" do
|
|
4
4
|
it "has DecidimAwesome object" do
|
5
5
|
expect(page.body).to have_content("window.DecidimAwesome")
|
6
6
|
expect(page.body).to have_content("window.DecidimAwesome.version")
|
7
|
-
expect(page.body).to have_content("window.DecidimAwesome.
|
7
|
+
expect(page.body).to have_content("window.DecidimAwesome.editorUploaderPath")
|
8
8
|
expect(page.body).to have_content("window.DecidimAwesome.texts")
|
9
9
|
end
|
10
10
|
end
|
@@ -12,7 +12,7 @@ end
|
|
12
12
|
shared_examples "has menu link" do |item|
|
13
13
|
let(:prefix) { "config/" }
|
14
14
|
it "shows the feature link" do
|
15
|
-
within ".
|
15
|
+
within ".sidebar-menu" do
|
16
16
|
expect(page).to have_link(href: "/admin/decidim_awesome/#{prefix}#{item}")
|
17
17
|
end
|
18
18
|
end
|
@@ -21,7 +21,7 @@ end
|
|
21
21
|
shared_examples "do not have menu link" do |item|
|
22
22
|
let(:prefix) { "config/" }
|
23
23
|
it "do not show the feature link" do
|
24
|
-
within ".
|
24
|
+
within ".sidebar-menu" do
|
25
25
|
expect(page).not_to have_link(href: "/admin/decidim_awesome/#{prefix}#{item}")
|
26
26
|
end
|
27
27
|
end
|
@@ -66,8 +66,8 @@ shared_examples "removes a box" do |name|
|
|
66
66
|
expect(page).to have_content("Street Sweeper")
|
67
67
|
expect(page).not_to have_content("Short Bio")
|
68
68
|
|
69
|
-
expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization
|
70
|
-
expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization
|
69
|
+
expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization:, var: "#{var_name}_foo")).not_to be_present
|
70
|
+
expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization:, var: "#{var_name}_bar")).to be_present
|
71
71
|
end
|
72
72
|
end
|
73
73
|
|
@@ -81,11 +81,11 @@ shared_examples "adds a constraint" do
|
|
81
81
|
|
82
82
|
it "adds a new config helper var" do
|
83
83
|
within ".proposal_custom_fields_container[data-key=\"foo\"]" do
|
84
|
-
|
84
|
+
click_on "Add case"
|
85
85
|
end
|
86
86
|
|
87
87
|
select "Processes", from: "constraint_participatory_space_manifest"
|
88
|
-
within "
|
88
|
+
within "#new-modal-#{var_name}_foo" do
|
89
89
|
click_on "Save"
|
90
90
|
end
|
91
91
|
|
@@ -95,8 +95,8 @@ shared_examples "adds a constraint" do
|
|
95
95
|
expect(page).to have_content("Processes")
|
96
96
|
end
|
97
97
|
|
98
|
-
expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization
|
99
|
-
expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization
|
98
|
+
expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization:, var: "#{var_name}_bar")).to be_present
|
99
|
+
expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization:, var: "#{var_name}_bar").constraints.first.settings).to eq(constraint.settings)
|
100
100
|
end
|
101
101
|
end
|
102
102
|
|
@@ -130,9 +130,9 @@ shared_examples "removes a constraint" do
|
|
130
130
|
expect(page).not_to have_content("Proposals")
|
131
131
|
end
|
132
132
|
|
133
|
-
expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization
|
134
|
-
expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization
|
135
|
-
expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization
|
133
|
+
expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization:, var: "#{var_name}_bar")).to be_present
|
134
|
+
expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization:, var: "#{var_name}_bar").constraints.count).to eq(1)
|
135
|
+
expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization:, var: "#{var_name}_bar").constraints.first).to eq(another_constraint)
|
136
136
|
end
|
137
137
|
|
138
138
|
context "and there is only one constraint" do
|
@@ -148,8 +148,8 @@ shared_examples "removes a constraint" do
|
|
148
148
|
end
|
149
149
|
|
150
150
|
expect(page).to have_content("Sorry, this cannot be deleted")
|
151
|
-
expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization
|
152
|
-
expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization
|
151
|
+
expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization:, var: "#{var_name}_bar").constraints.count).to eq(1)
|
152
|
+
expect(Decidim::DecidimAwesome::AwesomeConfig.find_by(organization:, var: "#{var_name}_bar").constraints.first).to eq(constraint)
|
153
153
|
end
|
154
154
|
end
|
155
155
|
end
|
@@ -4,16 +4,16 @@ shared_context "with custom redirects params" do
|
|
4
4
|
let(:organization) { create(:organization) }
|
5
5
|
let(:context) do
|
6
6
|
{
|
7
|
-
current_user: create(:user, organization:
|
7
|
+
current_user: create(:user, organization:),
|
8
8
|
current_organization: organization
|
9
9
|
}
|
10
10
|
end
|
11
11
|
let(:params) do
|
12
12
|
{
|
13
|
-
origin
|
14
|
-
destination
|
15
|
-
active
|
16
|
-
pass_query:
|
13
|
+
origin:,
|
14
|
+
destination:,
|
15
|
+
active:,
|
16
|
+
pass_query:
|
17
17
|
}
|
18
18
|
end
|
19
19
|
let(:attributes) do
|
@@ -33,8 +33,8 @@ shared_context "with custom redirects params" do
|
|
33
33
|
|
34
34
|
let(:another_params) do
|
35
35
|
{
|
36
|
-
|
37
|
-
|
36
|
+
allow_images_in_editors: true,
|
37
|
+
allow_videos_in_editors: true
|
38
38
|
}
|
39
39
|
end
|
40
40
|
let(:form) do
|
@@ -24,76 +24,36 @@ shared_examples "has video support" do
|
|
24
24
|
end
|
25
25
|
end
|
26
26
|
|
27
|
-
shared_examples "has no drag and drop" do
|
28
|
-
it "
|
27
|
+
shared_examples "has no drag and drop" do
|
28
|
+
it "cannot drop a file" do
|
29
29
|
expect(page).not_to have_content("Add images by dragging & dropping or pasting them.")
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
end
|
36
|
-
else
|
37
|
-
it "has no paste event" do
|
38
|
-
sleep 1
|
39
|
-
expect(page.execute_script("return typeof $._data($('#{editor_selector}')[0], 'events').paste")).to eq("undefined")
|
40
|
-
end
|
41
|
-
|
42
|
-
it "has no drop event" do
|
43
|
-
sleep 1
|
44
|
-
expect(page.execute_script("return typeof $._data($('#{editor_selector}')[0], 'events').drop")).to eq("undefined")
|
45
|
-
end
|
46
|
-
end
|
47
|
-
end
|
48
|
-
|
49
|
-
shared_examples "has drag and drop" do |rte|
|
50
|
-
it "has help text" do
|
51
|
-
expect(page).to have_content("Add images by dragging & dropping or pasting them.")
|
52
|
-
end
|
53
|
-
|
54
|
-
if rte
|
55
|
-
it "has image button" do
|
56
|
-
expect(page).to have_xpath("//button[@class='ql-image']")
|
57
|
-
end
|
58
|
-
else
|
59
|
-
it "has paste event" do
|
60
|
-
sleep 1
|
61
|
-
expect(page.execute_script("return typeof $._data($('#{editor_selector}')[0], 'events').paste")).to eq("object")
|
62
|
-
end
|
63
|
-
|
64
|
-
it "has drop event" do
|
65
|
-
sleep 1
|
66
|
-
expect(page.execute_script("return typeof $._data($('#{editor_selector}')[0], 'events').drop")).to eq("object")
|
67
|
-
end
|
30
|
+
find(editor_selector).drop(image)
|
31
|
+
expect(page.execute_script("return document.querySelector('#{editor_selector}').value")).not_to eq("[Uploading file...]")
|
32
|
+
sleep 1
|
33
|
+
last_image = Decidim::DecidimAwesome::EditorImage.last
|
34
|
+
expect(last_image).to be_nil
|
68
35
|
end
|
69
36
|
end
|
70
37
|
|
71
|
-
shared_examples "has
|
72
|
-
it "
|
73
|
-
|
74
|
-
end
|
75
|
-
|
76
|
-
it "has toolbar" do
|
77
|
-
expect(page).to have_xpath("//div[@class='editor-toolbar']")
|
78
|
-
end
|
79
|
-
|
80
|
-
if images
|
81
|
-
it "has help text" do
|
38
|
+
shared_examples "has drag and drop" do
|
39
|
+
it "can drop a file" do
|
40
|
+
within "form.edit_proposal" do
|
82
41
|
expect(page).to have_content("Add images by dragging & dropping or pasting them.")
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
42
|
+
fill_in :proposal_body, with: ""
|
43
|
+
end
|
44
|
+
find(editor_selector).drop(image)
|
45
|
+
expect(page.execute_script("return document.querySelector('#{editor_selector}').value")).to include("[Uploading file...]")
|
46
|
+
sleep 1
|
47
|
+
last_image = Decidim::DecidimAwesome::EditorImage.last
|
48
|
+
expect(last_image).to be_present
|
49
|
+
content = page.execute_script("return document.querySelector('#{editor_selector}').value")
|
50
|
+
expect(content).to include(last_image.attached_uploader(:file).path)
|
51
|
+
within "form.edit_proposal" do
|
52
|
+
# ensures valid body validations
|
53
|
+
fill_in :proposal_body, with: "This is a super test with lots of downcases characters to be sure that the image name does not mess with percentage of caps.\n#{content}"
|
54
|
+
fill_in :proposal_title, with: "This is a test proposal"
|
55
|
+
click_on "Send"
|
56
|
+
end
|
57
|
+
expect(proposal.reload.body["en"]).to include(last_image.attached_uploader(:file).path)
|
98
58
|
end
|
99
59
|
end
|
@@ -4,20 +4,21 @@ shared_context "with menu hacks params" do
|
|
4
4
|
let(:organization) { create(:organization) }
|
5
5
|
let(:context) do
|
6
6
|
{
|
7
|
-
current_user: create(:user, organization:
|
7
|
+
current_user: create(:user, organization:),
|
8
8
|
current_organization: organization
|
9
9
|
}
|
10
10
|
end
|
11
11
|
let(:params) do
|
12
12
|
{
|
13
|
-
menu_id
|
13
|
+
menu_id:,
|
14
14
|
raw_label: label,
|
15
|
-
url
|
16
|
-
position
|
17
|
-
target
|
18
|
-
visibility:
|
15
|
+
url:,
|
16
|
+
position:,
|
17
|
+
target:,
|
18
|
+
visibility:
|
19
19
|
}
|
20
20
|
end
|
21
|
+
let(:menu_id) { menu_name.to_sym }
|
21
22
|
let(:attributes) do
|
22
23
|
{
|
23
24
|
"label" => label,
|
@@ -37,11 +38,11 @@ shared_context "with menu hacks params" do
|
|
37
38
|
let(:position) { 2 }
|
38
39
|
let(:target) { "_blank" }
|
39
40
|
let(:visibility) { "hidden" }
|
40
|
-
|
41
|
+
|
41
42
|
let(:another_params) do
|
42
43
|
{
|
43
|
-
|
44
|
-
|
44
|
+
allow_images_in_editors: true,
|
45
|
+
allow_videos_in_editors: true
|
45
46
|
}
|
46
47
|
end
|
47
48
|
let(:form) do
|