Donation dialog changes (#5552)

* Remove disable_donation_dialog option

* Option to hide donation dialog permanently

* fix
This commit is contained in:
Nutomic 2025-03-28 13:10:54 +00:00 committed by GitHub
parent 636811eb8e
commit 192344231c
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
9 changed files with 18 additions and 24 deletions

View file

@ -1,6 +1,6 @@
use actix_web::web::{Data, Json};
use chrono::Utc;
use lemmy_api_common::{context::LemmyContext, SuccessResponse};
use chrono::{DateTime, Utc};
use lemmy_api_common::{context::LemmyContext, person::DonationDialogShown, SuccessResponse};
use lemmy_db_schema::source::local_user::{LocalUser, LocalUserUpdateForm};
use lemmy_db_views::structs::LocalUserView;
use lemmy_utils::error::LemmyResult;
@ -8,9 +8,15 @@ use lemmy_utils::error::LemmyResult;
pub async fn donation_dialog_shown(
context: Data<LemmyContext>,
local_user_view: LocalUserView,
data: Json<DonationDialogShown>,
) -> LemmyResult<Json<SuccessResponse>> {
let last = if data.hide_permanently.unwrap_or_default() {
DateTime::<Utc>::MAX_UTC
} else {
Utc::now()
};
let form = LocalUserUpdateForm {
last_donation_notification: Some(Utc::now()),
last_donation_notification: Some(last),
..Default::default()
};
LocalUser::update(&mut context.pool(), local_user_view.local_user.id, &form).await?;

View file

@ -567,3 +567,12 @@ pub struct ListLoginsResponse {
pub struct ResendVerificationEmail {
pub email: SensitiveString,
}
#[derive(Debug, Serialize, Deserialize, Clone, Default, PartialEq, Eq, Hash)]
#[cfg_attr(feature = "full", derive(TS))]
#[cfg_attr(feature = "full", ts(export))]
/// Make a request to resend your verification email.
pub struct DonationDialogShown {
#[cfg_attr(feature = "full", ts(optional))]
pub hide_permanently: Option<bool>,
}

View file

@ -259,8 +259,6 @@ pub struct CreateSite {
#[cfg_attr(feature = "full", ts(optional))]
pub comment_downvotes: Option<FederationMode>,
#[cfg_attr(feature = "full", ts(optional))]
pub disable_donation_dialog: Option<bool>,
#[cfg_attr(feature = "full", ts(optional))]
pub disallow_nsfw_content: Option<bool>,
}
@ -392,10 +390,6 @@ pub struct EditSite {
/// What kind of comment downvotes your site allows.
#[cfg_attr(feature = "full", ts(optional))]
pub comment_downvotes: Option<FederationMode>,
/// If this is true, users will never see the dialog asking to support Lemmy development with
/// donations.
#[cfg_attr(feature = "full", ts(optional))]
pub disable_donation_dialog: Option<bool>,
/// Block NSFW content being created
#[cfg_attr(feature = "full", ts(optional))]
pub disallow_nsfw_content: Option<bool>,

View file

@ -103,7 +103,6 @@ pub async fn create_site(
post_downvotes: data.post_downvotes,
comment_upvotes: data.comment_upvotes,
comment_downvotes: data.comment_downvotes,
disable_donation_dialog: data.disable_donation_dialog,
disallow_nsfw_content: data.disallow_nsfw_content,
..Default::default()
};

View file

@ -112,7 +112,6 @@ pub async fn update_site(
post_downvotes: data.post_downvotes,
comment_upvotes: data.comment_upvotes,
comment_downvotes: data.comment_downvotes,
disable_donation_dialog: data.disable_donation_dialog,
disallow_nsfw_content: data.disallow_nsfw_content,
..Default::default()
};

View file

@ -436,7 +436,6 @@ diesel::table! {
post_downvotes -> FederationModeEnum,
comment_upvotes -> FederationModeEnum,
comment_downvotes -> FederationModeEnum,
disable_donation_dialog -> Bool,
default_post_time_range_seconds -> Nullable<Int4>,
disallow_nsfw_content -> Bool,
users -> Int8,

View file

@ -83,9 +83,6 @@ pub struct LocalSite {
pub comment_upvotes: FederationMode,
/// What kind of comment downvotes your site allows.
pub comment_downvotes: FederationMode,
/// If this is true, users will never see the dialog asking to support Lemmy development with
/// donations.
pub disable_donation_dialog: bool,
#[cfg_attr(feature = "full", ts(optional))]
/// A default time range limit to apply to post sorts, in seconds.
pub default_post_time_range_seconds: Option<i32>,
@ -163,8 +160,6 @@ pub struct LocalSiteInsertForm {
#[new(default)]
pub comment_downvotes: Option<FederationMode>,
#[new(default)]
pub disable_donation_dialog: Option<bool>,
#[new(default)]
pub default_post_time_range_seconds: Option<Option<i32>>,
#[new(default)]
pub disallow_nsfw_content: bool,
@ -201,7 +196,6 @@ pub struct LocalSiteUpdateForm {
pub post_downvotes: Option<FederationMode>,
pub comment_upvotes: Option<FederationMode>,
pub comment_downvotes: Option<FederationMode>,
pub disable_donation_dialog: Option<bool>,
pub default_post_time_range_seconds: Option<Option<i32>>,
pub disallow_nsfw_content: Option<bool>,
}

View file

@ -1,6 +1,3 @@
ALTER TABLE local_user
DROP COLUMN last_donation_notification;
ALTER TABLE local_site
DROP COLUMN disable_donation_dialog;

View file

@ -3,6 +3,3 @@
ALTER TABLE local_user
ADD COLUMN last_donation_notification timestamptz NOT NULL DEFAULT (now() - (random() * (interval '12 months')));
ALTER TABLE local_site
ADD COLUMN disable_donation_dialog boolean NOT NULL DEFAULT FALSE;