FIX: empty state message on the user bookmarks page (#14257)
After adding an empty state banner to the user bookmarks page, we have found the bug. Steps to reproduce: - Go to the user bookmarks page - Search for something that doesn’t exist in bookmarks - Click again Bookmarked on the sidebar or View All Bookmarks on the user menu again
This commit is contained in:
parent
149e869c22
commit
9f626f2735
|
@ -3,42 +3,31 @@ import { iconHTML } from "discourse-common/lib/icon-library";
|
||||||
import Bookmark from "discourse/models/bookmark";
|
import Bookmark from "discourse/models/bookmark";
|
||||||
import I18n from "I18n";
|
import I18n from "I18n";
|
||||||
import { Promise } from "rsvp";
|
import { Promise } from "rsvp";
|
||||||
import EmberObject, { action } from "@ember/object";
|
import EmberObject, { action, computed } from "@ember/object";
|
||||||
import discourseComputed from "discourse-common/utils/decorators";
|
import discourseComputed from "discourse-common/utils/decorators";
|
||||||
import { notEmpty } from "@ember/object/computed";
|
import { equal, notEmpty } from "@ember/object/computed";
|
||||||
|
import { ajax } from "discourse/lib/ajax";
|
||||||
|
|
||||||
export default Controller.extend({
|
export default Controller.extend({
|
||||||
queryParams: ["q"],
|
queryParams: ["q"],
|
||||||
|
q: null,
|
||||||
|
|
||||||
application: controller(),
|
application: controller(),
|
||||||
user: controller(),
|
user: controller(),
|
||||||
|
|
||||||
content: null,
|
|
||||||
loading: false,
|
loading: false,
|
||||||
|
loadingMore: false,
|
||||||
permissionDenied: false,
|
permissionDenied: false,
|
||||||
searchTerm: null,
|
|
||||||
q: null,
|
|
||||||
inSearchMode: notEmpty("q"),
|
inSearchMode: notEmpty("q"),
|
||||||
|
noContent: equal("model.bookmarks.length", 0),
|
||||||
|
|
||||||
loadItems() {
|
searchTerm: computed("q", {
|
||||||
this.setProperties({
|
get() {
|
||||||
content: [],
|
return this.q;
|
||||||
loading: true,
|
},
|
||||||
permissionDenied: false,
|
set(key, value) {
|
||||||
searchTerm: this.q,
|
return value;
|
||||||
});
|
},
|
||||||
|
}),
|
||||||
return this.model
|
|
||||||
.loadItems({ q: this.q })
|
|
||||||
.then((response) => this._processLoadResponse(response))
|
|
||||||
.catch(() => this._bookmarksListDenied())
|
|
||||||
.finally(() => {
|
|
||||||
this.setProperties({
|
|
||||||
loaded: true,
|
|
||||||
loading: false,
|
|
||||||
});
|
|
||||||
});
|
|
||||||
},
|
|
||||||
|
|
||||||
@discourseComputed()
|
@discourseComputed()
|
||||||
emptyStateBody() {
|
emptyStateBody() {
|
||||||
|
@ -57,20 +46,16 @@ export default Controller.extend({
|
||||||
return inSearchMode && noContent;
|
return inSearchMode && noContent;
|
||||||
},
|
},
|
||||||
|
|
||||||
@discourseComputed("loaded", "content.length")
|
|
||||||
noContent(loaded, contentLength) {
|
|
||||||
return loaded && contentLength === 0;
|
|
||||||
},
|
|
||||||
|
|
||||||
@action
|
@action
|
||||||
search() {
|
search() {
|
||||||
this.set("q", this.searchTerm);
|
this.transitionToRoute({
|
||||||
this.loadItems();
|
queryParams: { q: this.searchTerm },
|
||||||
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
@action
|
@action
|
||||||
reload() {
|
reload() {
|
||||||
this.loadItems();
|
this.send("triggerRefresh");
|
||||||
},
|
},
|
||||||
|
|
||||||
@action
|
@action
|
||||||
|
@ -81,13 +66,27 @@ export default Controller.extend({
|
||||||
|
|
||||||
this.set("loadingMore", true);
|
this.set("loadingMore", true);
|
||||||
|
|
||||||
return this.model
|
return this._loadMoreBookmarks(this.q)
|
||||||
.loadMore({ q: this.q })
|
|
||||||
.then((response) => this._processLoadResponse(response))
|
.then((response) => this._processLoadResponse(response))
|
||||||
.catch(() => this._bookmarksListDenied())
|
.catch(() => this._bookmarksListDenied())
|
||||||
.finally(() => this.set("loadingMore", false));
|
.finally(() => this.set("loadingMore", false));
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_loadMoreBookmarks(searchQuery) {
|
||||||
|
if (!this.model.loadMoreUrl) {
|
||||||
|
return Promise.resolve();
|
||||||
|
}
|
||||||
|
|
||||||
|
let moreUrl = this.model.loadMoreUrl;
|
||||||
|
if (searchQuery) {
|
||||||
|
const delimiter = moreUrl.includes("?") ? "&" : "?";
|
||||||
|
const q = encodeURIComponent(searchQuery);
|
||||||
|
moreUrl += `${delimiter}q=${q}`;
|
||||||
|
}
|
||||||
|
|
||||||
|
return ajax({ url: moreUrl });
|
||||||
|
},
|
||||||
|
|
||||||
_bookmarksListDenied() {
|
_bookmarksListDenied() {
|
||||||
this.set("permissionDenied", true);
|
this.set("permissionDenied", true);
|
||||||
},
|
},
|
||||||
|
@ -98,22 +97,24 @@ export default Controller.extend({
|
||||||
}
|
}
|
||||||
|
|
||||||
response = response.user_bookmark_list;
|
response = response.user_bookmark_list;
|
||||||
this.model.more_bookmarks_url = response.more_bookmarks_url;
|
this.model.loadMoreUrl = response.more_bookmarks_url;
|
||||||
|
|
||||||
if (response.bookmarks) {
|
if (response.bookmarks) {
|
||||||
const bookmarkModels = response.bookmarks.map((bookmark) => {
|
const bookmarkModels = response.bookmarks.map(this.transform);
|
||||||
const bookmarkModel = Bookmark.create(bookmark);
|
this.model.bookmarks.pushObjects(bookmarkModels);
|
||||||
bookmarkModel.topicStatus = EmberObject.create({
|
|
||||||
closed: bookmark.closed,
|
|
||||||
archived: bookmark.archived,
|
|
||||||
is_warning: bookmark.is_warning,
|
|
||||||
pinned: false,
|
|
||||||
unpinned: false,
|
|
||||||
invisible: bookmark.invisible,
|
|
||||||
});
|
|
||||||
return bookmarkModel;
|
|
||||||
});
|
|
||||||
this.content.pushObjects(bookmarkModels);
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
transform(bookmark) {
|
||||||
|
const bookmarkModel = Bookmark.create(bookmark);
|
||||||
|
bookmarkModel.topicStatus = EmberObject.create({
|
||||||
|
closed: bookmark.closed,
|
||||||
|
archived: bookmark.archived,
|
||||||
|
is_warning: bookmark.is_warning,
|
||||||
|
pinned: false,
|
||||||
|
unpinned: false,
|
||||||
|
invisible: bookmark.invisible,
|
||||||
|
});
|
||||||
|
return bookmarkModel;
|
||||||
|
},
|
||||||
});
|
});
|
||||||
|
|
|
@ -141,40 +141,6 @@ const Bookmark = RestModel.extend({
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
loadItems(params) {
|
|
||||||
let url = `/u/${this.user.username}/bookmarks.json`;
|
|
||||||
|
|
||||||
if (params) {
|
|
||||||
url += "?" + $.param(params);
|
|
||||||
}
|
|
||||||
|
|
||||||
return ajax(url);
|
|
||||||
},
|
|
||||||
|
|
||||||
loadMore(additionalParams) {
|
|
||||||
if (!this.more_bookmarks_url) {
|
|
||||||
return Promise.resolve();
|
|
||||||
}
|
|
||||||
|
|
||||||
let moreUrl = this.more_bookmarks_url;
|
|
||||||
if (moreUrl) {
|
|
||||||
let [url, params] = moreUrl.split("?");
|
|
||||||
moreUrl = url;
|
|
||||||
if (params) {
|
|
||||||
moreUrl += "?" + params;
|
|
||||||
}
|
|
||||||
if (additionalParams) {
|
|
||||||
if (moreUrl.includes("?")) {
|
|
||||||
moreUrl += "&" + $.param(additionalParams);
|
|
||||||
} else {
|
|
||||||
moreUrl += "?" + $.param(additionalParams);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return ajax({ url: moreUrl });
|
|
||||||
},
|
|
||||||
|
|
||||||
@discourseComputed(
|
@discourseComputed(
|
||||||
"post_user_username",
|
"post_user_username",
|
||||||
"post_user_avatar_template",
|
"post_user_avatar_template",
|
||||||
|
|
|
@ -1,27 +1,63 @@
|
||||||
import DiscourseRoute from "discourse/routes/discourse";
|
import DiscourseRoute from "discourse/routes/discourse";
|
||||||
|
import { ajax } from "discourse/lib/ajax";
|
||||||
|
import { action } from "@ember/object";
|
||||||
|
|
||||||
export default DiscourseRoute.extend({
|
export default DiscourseRoute.extend({
|
||||||
queryParams: {
|
queryParams: {
|
||||||
acting_username: { refreshModel: true },
|
acting_username: { refreshModel: true },
|
||||||
|
q: { refreshModel: true },
|
||||||
},
|
},
|
||||||
|
|
||||||
model() {
|
model(params) {
|
||||||
return this.modelFor("user").get("bookmarks");
|
const controller = this.controllerFor("user-activity-bookmarks");
|
||||||
|
|
||||||
|
return this._loadBookmarks(params)
|
||||||
|
.then((response) => {
|
||||||
|
if (!response.user_bookmark_list) {
|
||||||
|
return { bookmarks: [] };
|
||||||
|
}
|
||||||
|
|
||||||
|
const bookmarks = response.user_bookmark_list.bookmarks.map(
|
||||||
|
controller.transform
|
||||||
|
);
|
||||||
|
const loadMoreUrl = response.user_bookmark_list.more_bookmarks_url;
|
||||||
|
|
||||||
|
return { bookmarks, loadMoreUrl };
|
||||||
|
})
|
||||||
|
.catch(() => controller.set("permissionDenied", true));
|
||||||
},
|
},
|
||||||
|
|
||||||
renderTemplate() {
|
renderTemplate() {
|
||||||
this.render("user_bookmarks");
|
this.render("user_bookmarks");
|
||||||
},
|
},
|
||||||
|
|
||||||
setupController(controller, model) {
|
@action
|
||||||
controller.set("model", model);
|
didTransition() {
|
||||||
controller.loadItems();
|
this.controllerFor("user-activity")._showFooter();
|
||||||
|
return true;
|
||||||
},
|
},
|
||||||
|
|
||||||
actions: {
|
@action
|
||||||
didTransition() {
|
loading(transition) {
|
||||||
this.controllerFor("user-activity")._showFooter();
|
let controller = this.controllerFor("user-activity-bookmarks");
|
||||||
return true;
|
controller.set("loading", true);
|
||||||
},
|
transition.promise.finally(function () {
|
||||||
|
controller.set("loading", false);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
@action
|
||||||
|
triggerRefresh() {
|
||||||
|
this.refresh();
|
||||||
|
},
|
||||||
|
|
||||||
|
_loadBookmarks(params) {
|
||||||
|
let url = `/u/${this.modelFor("user").username}/bookmarks.json`;
|
||||||
|
|
||||||
|
if (params) {
|
||||||
|
url += "?" + $.param(params);
|
||||||
|
}
|
||||||
|
|
||||||
|
return ajax(url);
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
|
@ -29,7 +29,7 @@
|
||||||
loadMore=(action "loadMore")
|
loadMore=(action "loadMore")
|
||||||
reload=(action "reload")
|
reload=(action "reload")
|
||||||
loadingMore=loadingMore
|
loadingMore=loadingMore
|
||||||
content=content
|
content=model.bookmarks
|
||||||
}}
|
}}
|
||||||
{{/if}}
|
{{/if}}
|
||||||
{{/if}}
|
{{/if}}
|
||||||
|
|
Loading…
Reference in New Issue