FIX: redirect to top was always redirecting to 'All'

This commit is contained in:
Régis Hanol 2019-06-03 20:17:25 +02:00
parent 8511bfe583
commit b792db9d92
3 changed files with 49 additions and 31 deletions

View File

@ -11,16 +11,16 @@ export default Discourse.Route.extend(OpenComposer, {
}, },
beforeModel(transition) { beforeModel(transition) {
const user = Discourse.User;
const url = transition.intent.url;
if ( if (
(transition.intent.url === "/" || (url === "/" || url === "/latest" || url === "/categories") &&
transition.intent.url === "/latest" ||
transition.intent.url === "/categories") &&
transition.targetName.indexOf("discovery.top") === -1 && transition.targetName.indexOf("discovery.top") === -1 &&
Discourse.User.currentProp("should_be_redirected_to_top") user.currentProp("should_be_redirected_to_top")
) { ) {
Discourse.User.currentProp("should_be_redirected_to_top", false); user.currentProp("should_be_redirected_to_top", false);
const period = const period = user.currentProp("redirected_to_top.period") || "all";
Discourse.User.currentProp("redirect_to_top.period") || "all";
this.replaceWith(`discovery.top${period.capitalize()}`); this.replaceWith(`discovery.top${period.capitalize()}`);
} }
}, },

View File

@ -77,12 +77,12 @@ class SiteSetting < ActiveRecord::Base
def self.should_download_images?(src) def self.should_download_images?(src)
setting = disabled_image_download_domains setting = disabled_image_download_domains
return true unless setting.present? return true if setting.blank?
host = URI.parse(src).host host = URI.parse(src).host
return !(setting.split('|').include?(host)) !setting.split("|").include?(host)
rescue URI::Error rescue URI::Error
return true true
end end
def self.scheme def self.scheme
@ -99,11 +99,7 @@ class SiteSetting < ActiveRecord::Base
end end
def self.min_redirected_to_top_period(duration) def self.min_redirected_to_top_period(duration)
period = ListController.best_period_with_topics_for(duration) ListController.best_period_with_topics_for(duration)
return period if period
# not enough topics
nil
end end
def self.queue_jobs=(val) def self.queue_jobs=(val)

View File

@ -3,14 +3,51 @@ import DiscoveryFixtures from "fixtures/discovery_fixtures";
acceptance("Redirect to Top", { acceptance("Redirect to Top", {
pretend(server, helper) { pretend(server, helper) {
server.get("/top/weekly.json", () => {
return helper.response(DiscoveryFixtures["/latest.json"]);
});
server.get("/top/monthly.json", () => {
return helper.response(DiscoveryFixtures["/latest.json"]);
});
server.get("/top/all.json", () => { server.get("/top/all.json", () => {
return helper.response(DiscoveryFixtures["/latest.json"]); return helper.response(DiscoveryFixtures["/latest.json"]);
}); });
} }
}); });
function setupUser() { QUnit.test("redirects categories to weekly top", async assert => {
logIn(); logIn();
replaceCurrentUser({
should_be_redirected_to_top: true,
redirected_to_top: {
period: "weekly",
reason: "Welcome back!"
}
});
await visit("/categories");
assert.equal(currentPath(), "discovery.topWeekly", "it works for categories");
});
QUnit.test("redirects latest to monthly top", async assert => {
logIn();
replaceCurrentUser({
should_be_redirected_to_top: true,
redirected_to_top: {
period: "monthly",
reason: "Welcome back!"
}
});
await visit("/latest");
assert.equal(currentPath(), "discovery.topMonthly", "it works for latest");
});
QUnit.test("redirects root to All top", async assert => {
logIn();
replaceCurrentUser({ replaceCurrentUser({
should_be_redirected_to_top: true, should_be_redirected_to_top: true,
redirected_to_top: { redirected_to_top: {
@ -18,22 +55,7 @@ function setupUser() {
reason: "Welcome back!" reason: "Welcome back!"
} }
}); });
}
QUnit.test("redirects categories to top", async assert => {
setupUser();
await visit("/categories");
assert.equal(currentPath(), "discovery.topAll", "it works for categories");
});
QUnit.test("redirects latest to top", async assert => {
setupUser();
await visit("/latest");
assert.equal(currentPath(), "discovery.topAll", "it works for latest");
});
QUnit.test("redirects root to top", async assert => {
setupUser();
await visit("/"); await visit("/");
assert.equal(currentPath(), "discovery.topAll", "it works for root"); assert.equal(currentPath(), "discovery.topAll", "it works for root");
}); });