113 lines
3.2 KiB
JavaScript
113 lines
3.2 KiB
JavaScript
import LoadMore from "discourse/mixins/load-more";
|
|
import ClickTrack from "discourse/lib/click-track";
|
|
import { selectedText } from "discourse/lib/utilities";
|
|
import Post from "discourse/models/post";
|
|
import DiscourseURL from "discourse/lib/url";
|
|
import Draft from "discourse/models/draft";
|
|
import { popupAjaxError } from "discourse/lib/ajax-error";
|
|
import { getOwner } from "discourse-common/lib/get-owner";
|
|
|
|
export default Ember.Component.extend(LoadMore, {
|
|
loading: false,
|
|
eyelineSelector: ".user-stream .item",
|
|
classNames: ["user-stream"],
|
|
|
|
_scrollTopOnModelChange: function() {
|
|
Ember.run.schedule("afterRender", () => $(document).scrollTop(0));
|
|
}.observes("stream.user.id"),
|
|
|
|
_inserted: function() {
|
|
this.bindScrolling({ name: "user-stream-view" });
|
|
|
|
$(window).on("resize.discourse-on-scroll", () => this.scrolled());
|
|
|
|
this.$().on("click.details-disabled", "details.disabled", () => false);
|
|
this.$().on("mouseup.discourse-redirect", ".excerpt a", function(e) {
|
|
// bypass if we are selecting stuff
|
|
const selection = window.getSelection && window.getSelection();
|
|
if (selection.type === "Range" || selection.rangeCount > 0) {
|
|
if (selectedText() !== "") {
|
|
return true;
|
|
}
|
|
}
|
|
|
|
const $target = $(e.target);
|
|
if (
|
|
$target.hasClass("mention") ||
|
|
$target.parents(".expanded-embed").length
|
|
) {
|
|
return false;
|
|
}
|
|
|
|
return ClickTrack.trackClick(e);
|
|
});
|
|
}.on("didInsertElement"),
|
|
|
|
// This view is being removed. Shut down operations
|
|
_destroyed: function() {
|
|
this.unbindScrolling("user-stream-view");
|
|
$(window).unbind("resize.discourse-on-scroll");
|
|
this.$().off("click.details-disabled", "details.disabled");
|
|
|
|
// Unbind link tracking
|
|
this.$().off("mouseup.discourse-redirect", ".excerpt a");
|
|
}.on("willDestroyElement"),
|
|
|
|
actions: {
|
|
removeBookmark(userAction) {
|
|
const stream = this.get("stream");
|
|
Post.updateBookmark(userAction.get("post_id"), false).then(() => {
|
|
stream.remove(userAction);
|
|
});
|
|
},
|
|
|
|
resumeDraft(item) {
|
|
const composer = getOwner(this).lookup("controller:composer");
|
|
if (composer.get("model.viewOpen")) {
|
|
composer.close();
|
|
}
|
|
if (item.get("postUrl")) {
|
|
DiscourseURL.routeTo(item.get("postUrl"));
|
|
} else {
|
|
Draft.get(item.draft_key)
|
|
.then(d => {
|
|
if (d.draft) {
|
|
composer.open({
|
|
draft: d.draft,
|
|
draftKey: item.draft_key,
|
|
draftSequence: d.draft_sequence
|
|
});
|
|
}
|
|
})
|
|
.catch(error => {
|
|
popupAjaxError(error);
|
|
});
|
|
}
|
|
},
|
|
|
|
removeDraft(draft) {
|
|
const stream = this.get("stream");
|
|
Draft.clear(draft.draft_key, draft.sequence)
|
|
.then(() => {
|
|
stream.remove(draft);
|
|
})
|
|
.catch(error => {
|
|
popupAjaxError(error);
|
|
});
|
|
},
|
|
|
|
loadMore() {
|
|
if (this.get("loading")) {
|
|
return;
|
|
}
|
|
|
|
this.set("loading", true);
|
|
const stream = this.get("stream");
|
|
stream.findItems().then(() => {
|
|
this.set("loading", false);
|
|
this.get("eyeline").flushRest();
|
|
});
|
|
}
|
|
}
|
|
});
|