UX: Be more optimistic about showing topic titles while entering topics
This commit is contained in:
parent
6f230945c2
commit
d161422002
|
@ -1,3 +1,4 @@
|
||||||
|
import DiscourseURL from 'discourse/lib/url';
|
||||||
import AddArchetypeClass from 'discourse/mixins/add-archetype-class';
|
import AddArchetypeClass from 'discourse/mixins/add-archetype-class';
|
||||||
import ClickTrack from 'discourse/lib/click-track';
|
import ClickTrack from 'discourse/lib/click-track';
|
||||||
import Scrolling from 'discourse/mixins/scrolling';
|
import Scrolling from 'discourse/mixins/scrolling';
|
||||||
|
@ -143,9 +144,11 @@ export default Ember.Component.extend(AddArchetypeClass, Scrolling, {
|
||||||
if (showTopic) {
|
if (showTopic) {
|
||||||
this.appEvents.trigger('header:show-topic', topic);
|
this.appEvents.trigger('header:show-topic', topic);
|
||||||
} else {
|
} else {
|
||||||
|
if (!DiscourseURL.isJumpScheduled()) {
|
||||||
this.appEvents.trigger('header:hide-topic');
|
this.appEvents.trigger('header:hide-topic');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Trigger a scrolled event
|
// Trigger a scrolled event
|
||||||
this.appEvents.trigger('topic:scrolled', offset);
|
this.appEvents.trigger('topic:scrolled', offset);
|
||||||
|
|
|
@ -109,11 +109,11 @@ export default Ember.Component.extend(bufferedRender({
|
||||||
const result = showEntrance.call(this, e);
|
const result = showEntrance.call(this, e);
|
||||||
if (result === false) { return result; }
|
if (result === false) { return result; }
|
||||||
|
|
||||||
|
const topic = this.get('topic');
|
||||||
const target = $(e.target);
|
const target = $(e.target);
|
||||||
if (target.hasClass('bulk-select')) {
|
if (target.hasClass('bulk-select')) {
|
||||||
const selected = this.get('selected');
|
const selected = this.get('selected');
|
||||||
|
|
||||||
const topic = this.get('topic');
|
|
||||||
if (target.is(':checked')) {
|
if (target.is(':checked')) {
|
||||||
selected.addObject(topic);
|
selected.addObject(topic);
|
||||||
} else {
|
} else {
|
||||||
|
@ -122,7 +122,7 @@ export default Ember.Component.extend(bufferedRender({
|
||||||
}
|
}
|
||||||
|
|
||||||
if (target.hasClass('raw-topic-link')) {
|
if (target.hasClass('raw-topic-link')) {
|
||||||
this.appEvents.trigger('header:hide-topic');
|
this.appEvents.trigger('header:update-topic', topic);
|
||||||
DiscourseURL.routeTo(target.attr('href'));
|
DiscourseURL.routeTo(target.attr('href'));
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,10 +34,12 @@ export function jumpToElement(elementId) {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let _transitioning = false;
|
||||||
|
|
||||||
const DiscourseURL = Ember.Object.extend({
|
const DiscourseURL = Ember.Object.extend({
|
||||||
|
|
||||||
isJumpScheduled() {
|
isJumpScheduled() {
|
||||||
return _jumpScheduled;
|
return _transitioning || _jumpScheduled;
|
||||||
},
|
},
|
||||||
|
|
||||||
// Jumps to a particular post in the stream
|
// Jumps to a particular post in the stream
|
||||||
|
@ -45,12 +47,14 @@ const DiscourseURL = Ember.Object.extend({
|
||||||
opts = opts || {};
|
opts = opts || {};
|
||||||
const holderId = `#post_${postNumber}`;
|
const holderId = `#post_${postNumber}`;
|
||||||
|
|
||||||
|
_transitioning = true;
|
||||||
Em.run.schedule('afterRender', () => {
|
Em.run.schedule('afterRender', () => {
|
||||||
let elementId;
|
let elementId;
|
||||||
let holder;
|
let holder;
|
||||||
|
|
||||||
if (postNumber === 1 && !opts.anchor) {
|
if (postNumber === 1 && !opts.anchor) {
|
||||||
$(window).scrollTop(0);
|
$(window).scrollTop(0);
|
||||||
|
_transitioning = false;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -64,7 +68,11 @@ const DiscourseURL = Ember.Object.extend({
|
||||||
holder = $(elementId);
|
holder = $(elementId);
|
||||||
}
|
}
|
||||||
|
|
||||||
const lockon = new LockOn(elementId);
|
const lockon = new LockOn(elementId, {
|
||||||
|
finished() {
|
||||||
|
_transitioning = false;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
if (holder.length > 0 && opts && opts.skipIfOnScreen){
|
if (holder.length > 0 && opts && opts.skipIfOnScreen){
|
||||||
const elementTop = lockon.elementTop();
|
const elementTop = lockon.elementTop();
|
||||||
|
@ -73,6 +81,7 @@ const DiscourseURL = Ember.Object.extend({
|
||||||
const height = holder.height();
|
const height = holder.height();
|
||||||
|
|
||||||
if (elementTop > scrollTop && (elementTop + height) < (scrollTop + windowHeight)) {
|
if (elementTop > scrollTop && (elementTop + height) < (scrollTop + windowHeight)) {
|
||||||
|
_transitioning = false;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,20 +23,22 @@ export default createWidget('header-topic-info', {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
const loaded = topic.get('details.loaded');
|
const loaded = topic.get('details.loaded');
|
||||||
|
const fancyTitle = topic.get('fancyTitle');
|
||||||
|
const href = topic.get('url');
|
||||||
|
|
||||||
if (loaded) {
|
if (fancyTitle && href) {
|
||||||
heading.push(this.attach('topic-status', attrs));
|
heading.push(this.attach('topic-status', attrs));
|
||||||
|
|
||||||
const titleHTML = new RawHtml({ html: `<span>${topic.get('fancyTitle')}</span>` });
|
const titleHTML = new RawHtml({ html: `<span>${fancyTitle}</span>` });
|
||||||
heading.push(this.attach('link', { className: 'topic-link',
|
heading.push(this.attach('link', { className: 'topic-link',
|
||||||
action: 'jumpToTopPost',
|
action: 'jumpToTopPost',
|
||||||
href: topic.get('url'),
|
href,
|
||||||
contents: () => titleHTML }));
|
contents: () => titleHTML }));
|
||||||
}
|
}
|
||||||
|
|
||||||
const title = [h('h1', heading)];
|
const title = [h('h1', heading)];
|
||||||
if (loaded) {
|
|
||||||
const category = topic.get('category');
|
const category = topic.get('category');
|
||||||
|
if (loaded || category) {
|
||||||
if (category && (!category.get('isUncategorizedCategory') || !this.siteSettings.suppress_uncategorized_badge)) {
|
if (category && (!category.get('isUncategorizedCategory') || !this.siteSettings.suppress_uncategorized_badge)) {
|
||||||
const parentCategory = category.get('parentCategory');
|
const parentCategory = category.get('parentCategory');
|
||||||
if (parentCategory) {
|
if (parentCategory) {
|
||||||
|
|
Loading…
Reference in New Issue