Have the topic progress and timeline use the same appEvent

This commit is contained in:
Robin Ward 2016-06-01 15:52:42 -04:00
parent a8fba38486
commit e24fe0246a
No known key found for this signature in database
GPG Key ID: 0E091E2B4ED1B83D
3 changed files with 16 additions and 18 deletions

View File

@ -9,6 +9,7 @@ export default Ember.Component.extend({
progressPosition: null, progressPosition: null,
postStream: Ember.computed.alias('topic.postStream'), postStream: Ember.computed.alias('topic.postStream'),
userWantsToJump: null, userWantsToJump: null,
_streamPercentage: null,
init() { init() {
this._super(); this._super();
@ -35,14 +36,6 @@ export default Ember.Component.extend({
} }
}, },
@computed('postStream.loaded', 'progressPosition', 'postStream.filteredPostsCount', 'postStream.highest_post_number')
streamPercentage(loaded, progressPosition, filteredPostsCount, highestPostNumber) {
if (!loaded) { return 0; }
if (highestPostNumber === 0) { return 0; }
const perc = progressPosition / filteredPostsCount;
return (perc > 1.0) ? 1.0 : perc;
},
@computed('progressPosition') @computed('progressPosition')
jumpTopDisabled(progressPosition) { jumpTopDisabled(progressPosition) {
return progressPosition <= 3; return progressPosition <= 3;
@ -72,11 +65,17 @@ export default Ember.Component.extend({
} }
}, },
@observes('streamPercentage', 'postStream.stream.[]') @observes('postStream.stream.[]')
_updateBar() { _updateBar() {
Ember.run.scheduleOnce('afterRender', this, this._updateProgressBar); Ember.run.scheduleOnce('afterRender', this, this._updateProgressBar);
}, },
_topicScrolled(event) {
this.set('progressPosition', event.postIndex);
this._streamPercentage = event.percent;
this._updateBar();
},
didInsertElement() { didInsertElement() {
this._super(); this._super();
@ -84,7 +83,7 @@ export default Ember.Component.extend({
.on("composer:resized", this, this._dock) .on("composer:resized", this, this._dock)
.on('composer:closed', this, this._dock) .on('composer:closed', this, this._dock)
.on("topic:scrolled", this, this._dock) .on("topic:scrolled", this, this._dock)
.on('topic:current-post-changed', postNumber => this.set('progressPosition', postNumber)) .on('topic:current-post-scrolled', this, this._topicScrolled)
.on('topic-progress:keyboard-trigger', this, this.keyboardTrigger); .on('topic-progress:keyboard-trigger', this, this.keyboardTrigger);
Ember.run.scheduleOnce('afterRender', this, this._updateProgressBar); Ember.run.scheduleOnce('afterRender', this, this._updateProgressBar);
@ -96,13 +95,12 @@ export default Ember.Component.extend({
.off("composer:resized", this, this._dock) .off("composer:resized", this, this._dock)
.off('composer:closed', this, this._dock) .off('composer:closed', this, this._dock)
.off('topic:scrolled', this, this._dock) .off('topic:scrolled', this, this._dock)
.off('topic:current-post-changed') .off('topic:current-post-scrolled')
.off('topic-progress:keyboard-trigger'); .off('topic-progress:keyboard-trigger');
}, },
_updateProgressBar() { _updateProgressBar() {
if (this.isDestroyed || this.isDestroying) { return; } if (this.isDestroyed || this.isDestroying || this.get('hidden')) { return; }
if (this.get('hidden')) { return; }
const $topicProgress = this.$('#topic-progress'); const $topicProgress = this.$('#topic-progress');
// speeds up stuff, bypass jquery slowness and extra checks // speeds up stuff, bypass jquery slowness and extra checks
@ -110,7 +108,7 @@ export default Ember.Component.extend({
this._totalWidth = $topicProgress[0].offsetWidth; this._totalWidth = $topicProgress[0].offsetWidth;
} }
const totalWidth = this._totalWidth; const totalWidth = this._totalWidth;
const progressWidth = this.get('streamPercentage') * totalWidth; const progressWidth = (this._streamPercentage || 0) * totalWidth;
const borderSize = (progressWidth === totalWidth) ? "0px" : "1px"; const borderSize = (progressWidth === totalWidth) ? "0px" : "1px";
const $bg = $topicProgress.find('.bg'); const $bg = $topicProgress.find('.bg');

View File

@ -206,13 +206,14 @@ export default Ember.Controller.extend(SelectedPostsCount, BufferedContent, {
const postStream = model.get('postStream'); const postStream = model.get('postStream');
this._progressIndex = postStream.progressIndexOfPost(post); this._progressIndex = postStream.progressIndexOfPost(post);
this.appEvents.trigger('topic:current-post-changed', this._progressIndex);
}, },
currentPostScrolled(event) { currentPostScrolled(event) {
const total = this.get('model.postStream.filteredPostsCount');
const percent = (parseFloat(this._progressIndex + event.percent - 1) / total);
this.appEvents.trigger('topic:current-post-scrolled', { this.appEvents.trigger('topic:current-post-scrolled', {
postIndex: this._progressIndex, postIndex: this._progressIndex,
percent: event.percent percent: Math.max(Math.min(percent, 1.0), 0.0)
}); });
}, },

View File

@ -170,8 +170,7 @@ createWidget('timeline-scrollarea', {
}, },
topicCurrentPostScrolled(event) { topicCurrentPostScrolled(event) {
const { postIndex, percent } = event; this.state.percentage = event.percent;
this.state.percentage = this._percentFor(this.attrs.topic, parseFloat(postIndex) + percent);
}, },
_percentFor(topic, postIndex) { _percentFor(topic, postIndex) {