mirror of
https://github.com/discourse/discourse.git
synced 2025-01-16 04:42:51 +08:00
FIX: Calculate experiment_enabled on server for "What's new?" (#30599)
Experimental "What's new?" feature feed items previously calculated a boolean for experimentEnabled on the client based on the siteSettings service, and this would control the initial state of the experiment toggle. However this requires the person who creates the site setting for the experiment to remember to set it to `client: true`. This commit removes that manual step by calculating whether the experiment is enabled server-side, where we have access to all the site settings.
This commit is contained in:
parent
f015ea897e
commit
725e146dca
|
@ -2,7 +2,6 @@ import Component from "@glimmer/component";
|
||||||
import { tracked } from "@glimmer/tracking";
|
import { tracked } from "@glimmer/tracking";
|
||||||
import { on } from "@ember/modifier";
|
import { on } from "@ember/modifier";
|
||||||
import { action } from "@ember/object";
|
import { action } from "@ember/object";
|
||||||
import didInsert from "@ember/render-modifiers/modifiers/did-insert";
|
|
||||||
import { service } from "@ember/service";
|
import { service } from "@ember/service";
|
||||||
import { htmlSafe } from "@ember/template";
|
import { htmlSafe } from "@ember/template";
|
||||||
import { and, not } from "truth-helpers";
|
import { and, not } from "truth-helpers";
|
||||||
|
@ -11,22 +10,15 @@ import DToggleSwitch from "discourse/components/d-toggle-switch";
|
||||||
import { ajax } from "discourse/lib/ajax";
|
import { ajax } from "discourse/lib/ajax";
|
||||||
import { popupAjaxError } from "discourse/lib/ajax-error";
|
import { popupAjaxError } from "discourse/lib/ajax-error";
|
||||||
import dIcon from "discourse-common/helpers/d-icon";
|
import dIcon from "discourse-common/helpers/d-icon";
|
||||||
import { bind } from "discourse-common/utils/decorators";
|
|
||||||
import { i18n } from "discourse-i18n";
|
import { i18n } from "discourse-i18n";
|
||||||
import DTooltip from "float-kit/components/d-tooltip";
|
import DTooltip from "float-kit/components/d-tooltip";
|
||||||
|
|
||||||
export default class DiscourseNewFeatureItem extends Component {
|
export default class DiscourseNewFeatureItem extends Component {
|
||||||
@service siteSettings;
|
@service siteSettings;
|
||||||
@service toasts;
|
@service toasts;
|
||||||
@tracked experimentEnabled;
|
@tracked experimentEnabled = this.args.item.experiment_enabled;
|
||||||
@tracked toggleExperimentDisabled = false;
|
@tracked toggleExperimentDisabled = false;
|
||||||
|
|
||||||
@bind
|
|
||||||
initEnabled() {
|
|
||||||
this.experimentEnabled =
|
|
||||||
this.siteSettings[this.args.item.experiment_setting];
|
|
||||||
}
|
|
||||||
|
|
||||||
@action
|
@action
|
||||||
async toggleExperiment() {
|
async toggleExperiment() {
|
||||||
if (this.toggleExperimentDisabled) {
|
if (this.toggleExperimentDisabled) {
|
||||||
|
@ -68,7 +60,7 @@ export default class DiscourseNewFeatureItem extends Component {
|
||||||
}
|
}
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div class="admin-new-feature-item" {{didInsert this.initEnabled}}>
|
<div class="admin-new-feature-item">
|
||||||
<div class="admin-new-feature-item__content">
|
<div class="admin-new-feature-item__content">
|
||||||
<div class="admin-new-feature-item__header">
|
<div class="admin-new-feature-item__header">
|
||||||
{{#if (and @item.emoji (not @item.screenshot_url))}}
|
{{#if (and @item.emoji (not @item.screenshot_url))}}
|
||||||
|
|
|
@ -156,8 +156,14 @@ module DiscourseUpdates
|
||||||
entries.map! do |item|
|
entries.map! do |item|
|
||||||
next item if !item["experiment_setting"]
|
next item if !item["experiment_setting"]
|
||||||
|
|
||||||
item["experiment_setting"] = nil if !SiteSetting.respond_to?(item["experiment_setting"]) ||
|
if !SiteSetting.respond_to?(item["experiment_setting"]) ||
|
||||||
SiteSetting.type_supervisor.get_type(item["experiment_setting"].to_sym) != :bool
|
SiteSetting.type_supervisor.get_type(item["experiment_setting"].to_sym) != :bool
|
||||||
|
item["experiment_setting"] = nil
|
||||||
|
item["experiment_enabled"] = false
|
||||||
|
else
|
||||||
|
item["experiment_enabled"] = SiteSetting.send(item["experiment_setting"].to_sym) if item
|
||||||
|
end
|
||||||
|
|
||||||
item
|
item
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -277,8 +277,11 @@ RSpec.describe DiscourseUpdates do
|
||||||
|
|
||||||
expect(result.length).to eq(3)
|
expect(result.length).to eq(3)
|
||||||
expect(result[0]["experiment_setting"]).to eq("enable_mobile_theme")
|
expect(result[0]["experiment_setting"]).to eq("enable_mobile_theme")
|
||||||
|
expect(result[0]["experiment_enabled"]).to eq(true)
|
||||||
expect(result[1]["experiment_setting"]).to be_nil
|
expect(result[1]["experiment_setting"]).to be_nil
|
||||||
|
expect(result[1]["experiment_enabled"]).to eq(false)
|
||||||
expect(result[2]["experiment_setting"]).to be_nil
|
expect(result[2]["experiment_setting"]).to be_nil
|
||||||
|
expect(result[2]["experiment_enabled"]).to eq(false)
|
||||||
end
|
end
|
||||||
|
|
||||||
it "correctly shows features when related plugins are installed" do
|
it "correctly shows features when related plugins are installed" do
|
||||||
|
|
|
@ -88,7 +88,7 @@ describe "Admin New Features Page", type: :system do
|
||||||
expect(new_features_page).to have_no_screenshot
|
expect(new_features_page).to have_no_screenshot
|
||||||
end
|
end
|
||||||
|
|
||||||
it "displays experimental feature toggle" do
|
it "displays experimental feature toggle and has the correct state" do
|
||||||
DiscourseUpdates.stubs(:new_features).returns(
|
DiscourseUpdates.stubs(:new_features).returns(
|
||||||
[
|
[
|
||||||
{
|
{
|
||||||
|
@ -103,11 +103,12 @@ describe "Admin New Features Page", type: :system do
|
||||||
"created_at" => "2023-11-10T02:52:41.462Z",
|
"created_at" => "2023-11-10T02:52:41.462Z",
|
||||||
"updated_at" => "2023-11-10T04:28:47.020Z",
|
"updated_at" => "2023-11-10T04:28:47.020Z",
|
||||||
"experiment_setting" => "experimental_form_templates",
|
"experiment_setting" => "experimental_form_templates",
|
||||||
|
"experiment_enabled" => true,
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
new_features_page.visit
|
new_features_page.visit
|
||||||
expect(new_features_page).to have_toggle_experiment_button
|
expect(new_features_page).to have_toggle_experiment_button(true)
|
||||||
end
|
end
|
||||||
|
|
||||||
it "displays experimental text next to feature title when feature is experimental" do
|
it "displays experimental text next to feature title when feature is experimental" do
|
||||||
|
@ -125,6 +126,7 @@ describe "Admin New Features Page", type: :system do
|
||||||
"created_at" => "2023-11-10T02:52:41.462Z",
|
"created_at" => "2023-11-10T02:52:41.462Z",
|
||||||
"updated_at" => "2023-11-10T04:28:47.020Z",
|
"updated_at" => "2023-11-10T04:28:47.020Z",
|
||||||
"experiment_setting" => "experimental_form_templates",
|
"experiment_setting" => "experimental_form_templates",
|
||||||
|
"experiment_enabled" => true,
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
|
|
|
@ -16,8 +16,11 @@ module PageObjects
|
||||||
page.has_no_css?(".admin-new-feature-item__screenshot")
|
page.has_no_css?(".admin-new-feature-item__screenshot")
|
||||||
end
|
end
|
||||||
|
|
||||||
def has_toggle_experiment_button?
|
def has_toggle_experiment_button?(enabled)
|
||||||
page.has_css?(".admin-new-feature-item__feature-toggle")
|
page.has_css?(
|
||||||
|
".admin-new-feature-item__feature-toggle .d-toggle-switch__checkbox[aria-checked='#{enabled}']",
|
||||||
|
visible: false,
|
||||||
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
def has_learn_more_link?
|
def has_learn_more_link?
|
||||||
|
|
Loading…
Reference in New Issue
Block a user