UX: Show the progress widget when the composer is expanded
This commit is contained in:
parent
27b499f4dd
commit
70df75c381
|
@ -341,6 +341,7 @@ export default Ember.Component.extend({
|
||||||
|
|
||||||
@on('willDestroyElement')
|
@on('willDestroyElement')
|
||||||
_composerClosed() {
|
_composerClosed() {
|
||||||
|
this.appEvents.trigger('composer:will-close');
|
||||||
Ember.run.next(() => {
|
Ember.run.next(() => {
|
||||||
$('#main-outlet').css('padding-bottom', 0);
|
$('#main-outlet').css('padding-bottom', 0);
|
||||||
// need to wait a bit for the "slide down" transition of the composer
|
// need to wait a bit for the "slide down" transition of the composer
|
||||||
|
|
|
@ -9,15 +9,16 @@ 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,
|
||||||
|
composerVisible: null,
|
||||||
|
|
||||||
init() {
|
init() {
|
||||||
this._super();
|
this._super();
|
||||||
(this.get('delegated') || []).forEach(m => this.set(m, m));
|
(this.get('delegated') || []).forEach(m => this.set(m, m));
|
||||||
},
|
},
|
||||||
|
|
||||||
@computed('userWantsToJump', 'showTimeline')
|
@computed('userWantsToJump', 'showTimeline', 'composerVisible')
|
||||||
hidden(userWantsToJump, showTimeline) {
|
hidden(userWantsToJump, showTimeline, composerVisible) {
|
||||||
return !userWantsToJump && showTimeline;
|
return !userWantsToJump && !composerVisible && showTimeline;
|
||||||
},
|
},
|
||||||
|
|
||||||
@observes('hidden')
|
@observes('hidden')
|
||||||
|
@ -77,11 +78,23 @@ export default Ember.Component.extend({
|
||||||
Ember.run.scheduleOnce('afterRender', this, this._updateProgressBar);
|
Ember.run.scheduleOnce('afterRender', this, this._updateProgressBar);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
_composerOpened() {
|
||||||
|
this.set('composerVisible', true);
|
||||||
|
this._dock();
|
||||||
|
},
|
||||||
|
|
||||||
|
_composerWillClose() {
|
||||||
|
this.set('composerVisible', false);
|
||||||
|
},
|
||||||
|
|
||||||
didInsertElement() {
|
didInsertElement() {
|
||||||
this._super();
|
this._super();
|
||||||
this.appEvents.on("composer:opened", this, this._dock)
|
|
||||||
.on("composer:resized", this, this._dock)
|
this.appEvents.on('composer:opened', this, this._composerOpened);
|
||||||
.on("composer:closed", this, this._dock)
|
this.appEvents.on('composer:will-close', this, this._composerWillClose);
|
||||||
|
|
||||||
|
this.appEvents.on("composer:resized", 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-changed', postNumber => this.set('progressPosition', postNumber))
|
||||||
.on('topic-progress:keyboard-trigger', this, this.keyboardTrigger);
|
.on('topic-progress:keyboard-trigger', this, this.keyboardTrigger);
|
||||||
|
@ -91,9 +104,10 @@ export default Ember.Component.extend({
|
||||||
|
|
||||||
willDestroyElement() {
|
willDestroyElement() {
|
||||||
this._super();
|
this._super();
|
||||||
this.appEvents.off("composer:opened", this, this._dock)
|
this.appEvents.off('composer:opened', this, this._composerOpened);
|
||||||
.off("composer:resized", this, this._dock)
|
this.appEvents.off('composer:will-close', this, this._composerWillClose);
|
||||||
.off("composer:closed", this, this._dock)
|
this.appEvents.off("composer:resized", 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-changed')
|
||||||
.off('topic-progress:keyboard-trigger');
|
.off('topic-progress:keyboard-trigger');
|
||||||
|
@ -111,9 +125,14 @@ export default Ember.Component.extend({
|
||||||
const totalWidth = this._totalWidth;
|
const totalWidth = this._totalWidth;
|
||||||
const progressWidth = this.get('streamPercentage') * totalWidth;
|
const progressWidth = this.get('streamPercentage') * totalWidth;
|
||||||
|
|
||||||
$topicProgress.find('.bg')
|
const borderSize = (progressWidth === totalWidth) ? "0px" : "1px";
|
||||||
.css("border-right-width", (progressWidth === totalWidth) ? "0px" : "1px")
|
const $bg = $topicProgress.find('.bg');
|
||||||
.width(progressWidth);
|
if ($bg.length === 0) {
|
||||||
|
const style = `border-right-width: ${borderSize}; width: ${progressWidth}px`;
|
||||||
|
$topicProgress.append(`<div class='bg' style="${style}"> </div>`);
|
||||||
|
} else {
|
||||||
|
$bg.css("border-right-width", borderSize).width(progressWidth);
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
_dock() {
|
_dock() {
|
||||||
|
|
|
@ -24,6 +24,5 @@
|
||||||
<h4>{{postStream.filteredPostsCount}}</h4></span>
|
<h4>{{postStream.filteredPostsCount}}</h4></span>
|
||||||
</div>
|
</div>
|
||||||
<i class="fa {{unless expanded 'fa-sort'}}"></i>
|
<i class="fa {{unless expanded 'fa-sort'}}"></i>
|
||||||
<div class='bg'> </div>
|
|
||||||
</nav>
|
</nav>
|
||||||
{{/unless}}
|
{{/unless}}
|
||||||
|
|
|
@ -183,7 +183,6 @@
|
||||||
border-right: 1px solid dark-light-diff($tertiary, $secondary, 85%, -65%);
|
border-right: 1px solid dark-light-diff($tertiary, $secondary, 85%, -65%);
|
||||||
background-color: dark-light-diff($tertiary, $secondary, 85%, -65%);
|
background-color: dark-light-diff($tertiary, $secondary, 85%, -65%);
|
||||||
transition: width .75s;
|
transition: width .75s;
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue