FEATURE: Always show full page "New Features" to admins (#28383)
We used to show New Features in a tab on the dashboard,
but this could get pushed down the page especially on
our hosting. In 043117ca13
we made a separate What's New page, so this commit removes
the dashboard tab and changes the admin notification to
send the admin to /admin/whats-new instead of the dashboard
tab.
This commit is contained in:
parent
43abc219d1
commit
3e5976f843
|
@ -18,7 +18,7 @@ export default class DashboardNewFeatures extends Component {
|
|||
|
||||
@bind
|
||||
loadNewFeatures() {
|
||||
ajax("/admin/dashboard/whats-new.json")
|
||||
ajax("/admin/whats-new.json")
|
||||
.then((json) => {
|
||||
const items = json.new_features.reduce((acc, feature) => {
|
||||
const key = moment(feature.released_at || feature.created_at).format(
|
||||
|
|
|
@ -1,3 +0,0 @@
|
|||
import Controller from "@ember/controller";
|
||||
|
||||
export default class AdminDashboardNewFeaturesController extends Controller {}
|
|
@ -50,11 +50,6 @@ export default class AdminDashboardController extends Controller {
|
|||
return this.visibleTabs.includes("reports");
|
||||
}
|
||||
|
||||
@computed("visibleTabs")
|
||||
get isNewFeaturesTabVisible() {
|
||||
return this.visibleTabs.includes("features");
|
||||
}
|
||||
|
||||
fetchProblems() {
|
||||
if (this.isLoadingProblems) {
|
||||
return;
|
||||
|
@ -91,7 +86,6 @@ export default class AdminDashboardController extends Controller {
|
|||
if (versionChecks) {
|
||||
properties.versionCheck = VersionCheck.create(model.version_check);
|
||||
}
|
||||
properties.hasUnseenFeatures = model.hasUnseenFeatures;
|
||||
|
||||
this.setProperties(properties);
|
||||
})
|
||||
|
|
|
@ -13,7 +13,6 @@ export default class AdminDashboard extends EmberObject {
|
|||
const model = AdminDashboard.create();
|
||||
model.setProperties({
|
||||
version_check: json.version_check,
|
||||
hasUnseenFeatures: json.has_unseen_features,
|
||||
});
|
||||
|
||||
return model;
|
||||
|
|
|
@ -1,3 +0,0 @@
|
|||
import DiscourseRoute from "discourse/routes/discourse";
|
||||
|
||||
export default class AdminDashboardNewFeaturesRoute extends DiscourseRoute {}
|
|
@ -14,10 +14,6 @@ export default function () {
|
|||
path: "/dashboard/reports",
|
||||
resetNamespace: true,
|
||||
});
|
||||
this.route("admin.dashboardNewFeatures", {
|
||||
path: "/dashboard/whats-new",
|
||||
resetNamespace: true,
|
||||
});
|
||||
});
|
||||
|
||||
this.route(
|
||||
|
|
|
@ -50,17 +50,6 @@
|
|||
</li>
|
||||
{{/if}}
|
||||
|
||||
{{#if this.isNewFeaturesTabVisible}}
|
||||
<li class="navigation-item new-features">
|
||||
<LinkTo @route="admin.dashboardNewFeatures" class="navigation-link">
|
||||
{{#if this.hasUnseenFeatures}}
|
||||
{{replace-emoji ":gift:"}}
|
||||
{{/if}}
|
||||
{{i18n "admin.dashboard.new_features.title"}}
|
||||
</LinkTo>
|
||||
</li>
|
||||
{{/if}}
|
||||
|
||||
<PluginOutlet @name="admin-dashboard-tabs-after" />
|
||||
</ul>
|
||||
</nav>
|
||||
|
|
|
@ -12,7 +12,7 @@ export default class extends NotificationTypeBase {
|
|||
}
|
||||
|
||||
get linkHref() {
|
||||
return getURL("/admin/dashboard/whats-new");
|
||||
return getURL("/admin/whats-new");
|
||||
}
|
||||
|
||||
get icon() {
|
||||
|
|
|
@ -130,20 +130,6 @@ acceptance("Dashboard", function (needs) {
|
|||
"its set the value of the filter from the query params"
|
||||
);
|
||||
});
|
||||
|
||||
test("new features", async function (assert) {
|
||||
await visit("/admin");
|
||||
|
||||
await click(".dashboard .navigation-item.new-features .navigation-link");
|
||||
|
||||
assert.ok(
|
||||
exists(
|
||||
".dashboard .navigation-item.new-features .navigation-link .emoji[title='gift']"
|
||||
)
|
||||
);
|
||||
assert.ok(exists(".dashboard-new-features"));
|
||||
assert.ok(exists("img.admin-new-feature-item__screenshot"));
|
||||
});
|
||||
});
|
||||
|
||||
acceptance("Dashboard: dashboard_visible_tabs", function (needs) {
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
export default {
|
||||
"/admin/dashboard/whats-new.json": {
|
||||
"/admin/whats-new.json": {
|
||||
new_features: [
|
||||
{
|
||||
id: 1,
|
||||
|
|
|
@ -7,7 +7,6 @@ class Admin::DashboardController < Admin::StaffController
|
|||
if SiteSetting.version_checks?
|
||||
data.merge!(version_check: DiscourseUpdates.check_version.as_json)
|
||||
end
|
||||
data.merge!(has_unseen_features: DiscourseUpdates.has_unseen_features?(current_user.id))
|
||||
|
||||
render json: data
|
||||
end
|
||||
|
|
|
@ -164,7 +164,7 @@ RSpec.describe Admin::DashboardController do
|
|||
before { sign_in(admin) }
|
||||
|
||||
it "is empty by default" do
|
||||
get "/admin/dashboard/whats-new.json"
|
||||
get "/admin/whats-new.json"
|
||||
expect(response.status).to eq(200)
|
||||
json = response.parsed_body
|
||||
expect(json["new_features"]).to eq(nil)
|
||||
|
@ -172,7 +172,7 @@ RSpec.describe Admin::DashboardController do
|
|||
|
||||
it "fails gracefully for invalid JSON" do
|
||||
Discourse.redis.set("new_features", "INVALID JSON")
|
||||
get "/admin/dashboard/whats-new.json"
|
||||
get "/admin/whats-new.json"
|
||||
expect(response.status).to eq(200)
|
||||
json = response.parsed_body
|
||||
expect(json["new_features"]).to eq(nil)
|
||||
|
@ -181,7 +181,7 @@ RSpec.describe Admin::DashboardController do
|
|||
it "includes new features when available" do
|
||||
populate_new_features
|
||||
|
||||
get "/admin/dashboard/whats-new.json"
|
||||
get "/admin/whats-new.json"
|
||||
expect(response.status).to eq(200)
|
||||
json = response.parsed_body
|
||||
|
||||
|
@ -195,7 +195,7 @@ RSpec.describe Admin::DashboardController do
|
|||
populate_new_features
|
||||
DiscourseUpdates.mark_new_features_as_seen(admin.id)
|
||||
|
||||
get "/admin/dashboard/whats-new.json"
|
||||
get "/admin/whats-new.json"
|
||||
expect(response.status).to eq(200)
|
||||
json = response.parsed_body
|
||||
|
||||
|
@ -209,7 +209,7 @@ RSpec.describe Admin::DashboardController do
|
|||
|
||||
expect(DiscourseUpdates.get_last_viewed_feature_date(admin.id)).to eq(nil)
|
||||
|
||||
get "/admin/dashboard/whats-new.json"
|
||||
get "/admin/whats-new.json"
|
||||
expect(response.status).to eq(200)
|
||||
expect(DiscourseUpdates.get_last_viewed_feature_date(admin.id)).to be_within_one_second_of(
|
||||
date2,
|
||||
|
@ -218,7 +218,7 @@ RSpec.describe Admin::DashboardController do
|
|||
date2 = 10.minutes.ago
|
||||
populate_new_features(date1, date2)
|
||||
|
||||
get "/admin/dashboard/whats-new.json"
|
||||
get "/admin/whats-new.json"
|
||||
expect(response.status).to eq(200)
|
||||
expect(DiscourseUpdates.get_last_viewed_feature_date(admin.id)).to be_within_one_second_of(
|
||||
date2,
|
||||
|
@ -233,7 +233,7 @@ RSpec.describe Admin::DashboardController do
|
|||
expect(DiscourseUpdates.new_features_last_seen(admin.id)).to eq(nil)
|
||||
expect(DiscourseUpdates.has_unseen_features?(admin.id)).to eq(true)
|
||||
|
||||
get "/admin/dashboard/whats-new.json"
|
||||
get "/admin/whats-new.json"
|
||||
expect(response.status).to eq(200)
|
||||
|
||||
expect(DiscourseUpdates.new_features_last_seen(admin.id)).not_to eq(nil)
|
||||
|
@ -244,7 +244,7 @@ RSpec.describe Admin::DashboardController do
|
|||
end
|
||||
|
||||
it "doesn't error when there are no new features" do
|
||||
get "/admin/dashboard/whats-new.json"
|
||||
get "/admin/whats-new.json"
|
||||
expect(response.status).to eq(200)
|
||||
end
|
||||
end
|
||||
|
@ -255,7 +255,7 @@ RSpec.describe Admin::DashboardController do
|
|||
it "includes new features when available" do
|
||||
populate_new_features
|
||||
|
||||
get "/admin/dashboard/whats-new.json"
|
||||
get "/admin/whats-new.json"
|
||||
|
||||
json = response.parsed_body
|
||||
|
||||
|
@ -270,7 +270,7 @@ RSpec.describe Admin::DashboardController do
|
|||
|
||||
expect(DiscourseUpdates.get_last_viewed_feature_date(moderator.id)).to eq(nil)
|
||||
|
||||
get "/admin/dashboard/whats-new.json"
|
||||
get "/admin/whats-new.json"
|
||||
expect(response.status).to eq(200)
|
||||
expect(DiscourseUpdates.get_last_viewed_feature_date(moderator.id)).to eq(nil)
|
||||
end
|
||||
|
@ -280,7 +280,7 @@ RSpec.describe Admin::DashboardController do
|
|||
before { sign_in(user) }
|
||||
|
||||
it "denies access with a 404 response" do
|
||||
get "/admin/dashboard/whats-new.json"
|
||||
get "/admin/whats-new.json"
|
||||
|
||||
expect(response.status).to eq(404)
|
||||
expect(response.parsed_body["errors"]).to include(I18n.t("not_found"))
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
# frozen_string_literal: true
|
||||
|
||||
describe "Admin Dashboard New Features Page", type: :system do
|
||||
let(:new_features_page) { PageObjects::Pages::AdminDashboardNewFeatures.new }
|
||||
describe "Admin New Features Page", type: :system do
|
||||
let(:new_features_page) { PageObjects::Pages::AdminNewFeatures.new }
|
||||
fab!(:admin)
|
||||
|
||||
before { sign_in(admin) }
|
||||
|
|
|
@ -2,9 +2,9 @@
|
|||
|
||||
module PageObjects
|
||||
module Pages
|
||||
class AdminDashboardNewFeatures < PageObjects::Pages::Base
|
||||
class AdminNewFeatures < PageObjects::Pages::Base
|
||||
def visit
|
||||
page.visit("/admin/dashboard/whats-new")
|
||||
page.visit("/admin/whats-new")
|
||||
self
|
||||
end
|
||||
|
Loading…
Reference in New Issue