This pull request fixes the model annotation tooling due to previous incomplete migration from `annotate` to `annotaterb` gem (#12600). It also improves the handling of serialized values in the `InstallationConfig` model by ensuring a default value is set, simplifying the code, and removing a workaround for YAML deserialization. **Annotation tooling updates:** * Added `.annotaterb.yml` to configure the `annotate_rb` gem with project-specific options, centralizing annotation settings. * Replaced the custom `auto_annotate_models.rake` task with the standard rake task from `annotate_rb`, and added `lib/tasks/annotate_rb.rake` to load annotation tasks in development environments. [[1]](diffhunk://#diff-9450d2359e45f1db407b3871dde787a25d60bb721aed179a65ffd2692e95fb4bL1-L61) [[2]](diffhunk://#diff-578cdfc7ad56637e42472ea891ea286dff8803d9a1750afdbfeafec164d9b8b2R1-R8) **Model serialization improvements:** * Updated the `InstallationConfig` model to set a default value for the `serialized_value` attribute, ensuring it always has a hash with indifferent access and removing the need for a deserialization workaround in the `value` method. [[1]](diffhunk://#diff-b4bdde42c1ad0f584073818bd43dbd865b1b3b50d4701b131979f900d7c68297L22-R22) [[2]](diffhunk://#diff-b4bdde42c1ad0f584073818bd43dbd865b1b3b50d4701b131979f900d7c68297L36-L39) --------- Co-authored-by: Sojan Jose <sojan@pepalo.com>
48 lines
2.3 KiB
Ruby
48 lines
2.3 KiB
Ruby
# == Schema Information
|
|
#
|
|
# Table name: csat_survey_responses
|
|
#
|
|
# id :bigint not null, primary key
|
|
# csat_review_notes :text
|
|
# feedback_message :text
|
|
# rating :integer not null
|
|
# review_notes_updated_at :datetime
|
|
# created_at :datetime not null
|
|
# updated_at :datetime not null
|
|
# account_id :bigint not null
|
|
# assigned_agent_id :bigint
|
|
# contact_id :bigint not null
|
|
# conversation_id :bigint not null
|
|
# message_id :bigint not null
|
|
# review_notes_updated_by_id :bigint
|
|
#
|
|
# Indexes
|
|
#
|
|
# index_csat_survey_responses_on_account_id (account_id)
|
|
# index_csat_survey_responses_on_assigned_agent_id (assigned_agent_id)
|
|
# index_csat_survey_responses_on_contact_id (contact_id)
|
|
# index_csat_survey_responses_on_conversation_id (conversation_id)
|
|
# index_csat_survey_responses_on_message_id (message_id) UNIQUE
|
|
# index_csat_survey_responses_on_review_notes_updated_by_id (review_notes_updated_by_id)
|
|
#
|
|
class CsatSurveyResponse < ApplicationRecord
|
|
belongs_to :account
|
|
belongs_to :conversation
|
|
belongs_to :contact
|
|
belongs_to :message
|
|
belongs_to :assigned_agent, class_name: 'User', optional: true, inverse_of: :csat_survey_responses
|
|
belongs_to :review_notes_updated_by, class_name: 'User', optional: true
|
|
|
|
validates :rating, presence: true, inclusion: { in: [1, 2, 3, 4, 5] }
|
|
validates :account_id, presence: true
|
|
validates :contact_id, presence: true
|
|
validates :conversation_id, presence: true
|
|
|
|
scope :filter_by_created_at, ->(range) { where(created_at: range) if range.present? }
|
|
scope :filter_by_assigned_agent_id, ->(user_ids) { where(assigned_agent_id: user_ids) if user_ids.present? }
|
|
scope :filter_by_inbox_id, ->(inbox_id) { joins(:conversation).where(conversations: { inbox_id: inbox_id }) if inbox_id.present? }
|
|
scope :filter_by_team_id, ->(team_id) { joins(:conversation).where(conversations: { team_id: team_id }) if team_id.present? }
|
|
# filter by rating value
|
|
scope :filter_by_rating, ->(rating) { where(rating: rating) if rating.present? }
|
|
end
|