# frozen_string_literal: true require "decidim/core/test/factories" require "decidim/participatory_processes/test/factories" FactoryBot.define do factory :proposal_component, parent: :component do name { Decidim::Components::Namer.new(participatory_space.organization.available_locales, :proposals).i18n_name } manifest_name { :proposals } participatory_space { create(:participatory_process, :with_steps, organization: organization) } trait :with_endorsements_enabled do step_settings do { participatory_space.active_step.id => { endorsements_enabled: true } } end end trait :with_endorsements_disabled do step_settings do { participatory_space.active_step.id => { endorsements_enabled: false } } end end trait :with_votes_enabled do step_settings do { participatory_space.active_step.id => { votes_enabled: true } } end end trait :with_votes_disabled do step_settings do { participatory_space.active_step.id => { votes_enabled: false } } end end trait :with_votes_hidden do step_settings do { participatory_space.active_step.id => { votes_hidden: true } } end end trait :with_vote_limit do transient do vote_limit { 10 } end settings do { vote_limit: vote_limit } end end trait :with_proposal_limit do transient do proposal_limit { 1 } end settings do { proposal_limit: proposal_limit } end end trait :with_proposal_length do transient do proposal_length { 500 } end settings do { proposal_length: proposal_length } end end trait :with_endorsements_blocked do step_settings do { participatory_space.active_step.id => { endorsements_enabled: true, endorsements_blocked: true } } end end trait :with_votes_blocked do step_settings do { participatory_space.active_step.id => { votes_enabled: true, votes_blocked: true } } end end trait :with_creation_enabled do step_settings do { participatory_space.active_step.id => { creation_enabled: true } } end end trait :with_geocoding_enabled do settings do { geocoding_enabled: true } end end trait :with_attachments_allowed do settings do { attachments_allowed: true } end end trait :with_threshold_per_proposal do transient do threshold_per_proposal { 1 } end settings do { threshold_per_proposal: threshold_per_proposal } end end trait :with_can_accumulate_supports_beyond_threshold do settings do { can_accumulate_supports_beyond_threshold: true } end end trait :with_collaborative_drafts_enabled do settings do { collaborative_drafts_enabled: true } end end trait :with_minimum_votes_per_user do transient do minimum_votes_per_user { 3 } end settings do { minimum_votes_per_user: minimum_votes_per_user } end end trait :with_participatory_texts_enabled do settings do { participatory_texts_enabled: true } end end end factory :proposal, class: "Decidim::Proposals::Proposal" do transient do users { nil } # user_groups correspondence to users is by sorting order user_groups { [] } end title { generate(:title) } body { Faker::Lorem.sentences(3).join("\n") } component { create(:proposal_component) } published_at { Time.current } address { "#{Faker::Address.street_name}, #{Faker::Address.city}" } after(:build) do |proposal, evaluator| if proposal.component users = evaluator.users || [create(:user, organization: proposal.component.participatory_space.organization)] users.each_with_index do |user, idx| user_group = evaluator.user_groups[idx] proposal.coauthorships.build(author: user, user_group: user_group) end end end trait :published do published_at { Time.current } end trait :unpublished do published_at { nil } end trait :official do after :build do |proposal| proposal.coauthorships.clear proposal.coauthorships.build(author: proposal.organization) end end trait :evaluating do state { "evaluating" } answered_at { Time.current } end trait :accepted do state { "accepted" } answered_at { Time.current } end trait :rejected do state { "rejected" } answered_at { Time.current } end trait :withdrawn do state { "withdrawn" } end trait :with_answer do state { "accepted" } answer { generate_localized_title } answered_at { Time.current } end trait :draft do published_at { nil } end trait :hidden do after :create do |proposal| create(:moderation, hidden_at: Time.current, reportable: proposal) end end trait :with_votes do after :create do |proposal| create_list(:proposal_vote, 5, proposal: proposal) end end trait :with_endorsements do after :create do |proposal| create_list(:proposal_endorsement, 5, proposal: proposal) end end end factory :proposal_vote, class: "Decidim::Proposals::ProposalVote" do proposal { build(:proposal) } author { build(:user, organization: proposal.organization) } end factory :proposal_endorsement, class: "Decidim::Proposals::ProposalEndorsement" do proposal { build(:proposal) } author { build(:user, organization: proposal.organization) } end factory :user_group_proposal_endorsement, class: "Decidim::Proposals::ProposalEndorsement" do proposal { build(:proposal) } author { build(:user, organization: proposal.organization) } user_group { create(:user_group, verified_at: Time.current, organization: proposal.organization, users: [author]) } end factory :proposal_note, class: "Decidim::Proposals::ProposalNote" do body { Faker::Lorem.sentences(3).join("\n") } proposal { build(:proposal) } author { build(:user, organization: proposal.organization) } end factory :collaborative_draft, class: "Decidim::Proposals::CollaborativeDraft" do transient do users { nil } # user_groups correspondence to users is by sorting order user_groups { [] } end title { generate(:title) } body { Faker::Lorem.sentences(3).join("\n") } component { create(:proposal_component) } address { "#{Faker::Address.street_name}, #{Faker::Address.city}" } state { "open" } after(:build) do |collaborative_draft, evaluator| if collaborative_draft.component users = evaluator.users || [create(:user, organization: collaborative_draft.component.participatory_space.organization)] users.each_with_index do |user, idx| user_group = evaluator.user_groups[idx] collaborative_draft.coauthorships.build(author: user, user_group: user_group) end end end trait :published do state { "published" } published_at { Time.current } end trait :open do state { "open" } end trait :withdrawn do state { "withdrawn" } end end end