Class: Users::InProductMarketingEmail
Constant Summary
collapse
- BUILD_IOS_APP_GUIDE =
'build_ios_app_guide'
- CAMPAIGNS =
[BUILD_IOS_APP_GUIDE].freeze
- INACTIVE_TRACK_NAMES =
Tracks we don’t send emails for (e.g. unsuccessful experiment). These are kept since we already have DB records that use the enum value.
%w[invite_team experience].freeze
- ACTIVE_TRACKS =
tracks.except(*INACTIVE_TRACK_NAMES)
BulkInsertSafe::ALLOWED_CALLBACKS, BulkInsertSafe::DEFAULT_BATCH_SIZE, BulkInsertSafe::MethodNotAllowedError, BulkInsertSafe::PrimaryKeySetError
ApplicationRecord::MAX_PLUCK
ResetOnUnionError::MAX_RESET_PERIOD
Class Method Summary
collapse
cached_column_list, #create_or_load_association, declarative_enum, default_select_columns, id_in, id_not_in, iid_in, pluck_primary_key, primary_key_in, #readable_by?, safe_ensure_unique, safe_find_or_create_by, safe_find_or_create_by!, #to_ability_name, underscore, where_exists, where_not_exists, with_fast_read_statement_timeout, without_order
#serializable_hash
Class Method Details
.distinct_users_sql ⇒ Object
65
66
67
68
|
# File 'app/models/users/in_product_marketing_email.rb', line 65
def self.distinct_users_sql
name = users_table.table_name
Arel.sql("DISTINCT ON(#{name}.id) #{name}.*")
end
|
.for_campaign(campaign) ⇒ Object
81
82
83
|
# File 'app/models/users/in_product_marketing_email.rb', line 81
def self.for_campaign(campaign)
arel_table[:campaign].eq(campaign)
end
|
.for_track_and_series(track, series) ⇒ Object
85
86
87
88
|
# File 'app/models/users/in_product_marketing_email.rb', line 85
def self.for_track_and_series(track, series)
arel_table[:track].eq(ACTIVE_TRACKS[track])
.and(arel_table[:series]).eq(series)
end
|
.for_user ⇒ Object
77
78
79
|
# File 'app/models/users/in_product_marketing_email.rb', line 77
def self.for_user
arel_table[:user_id].eq(users_table[:id])
end
|
.save_cta_click(user, track, series) ⇒ Object
90
91
92
93
94
|
# File 'app/models/users/in_product_marketing_email.rb', line 90
def self.save_cta_click(user, track, series)
email = for_user_with_track_and_series(user, track, series).take
email.update(cta_clicked_at: Time.zone.now) if email && email.cta_clicked_at.blank?
end
|
.users_table ⇒ Object
61
62
63
|
# File 'app/models/users/in_product_marketing_email.rb', line 61
def self.users_table
User.arel_table
end
|
.users_without_records(condition) ⇒ Object
70
71
72
73
74
75
|
# File 'app/models/users/in_product_marketing_email.rb', line 70
def self.users_without_records(condition)
arel_join = users_table.join(arel_table, Arel::Nodes::OuterJoin).on(condition)
joins(arel_join.join_sources)
.where(in_product_marketing_emails: { id: nil })
.select(distinct_users_sql)
end
|