Update `Topic#closed` client side when closing/opening a topic temporarily.
This commit is contained in:
parent
ed577fbff8
commit
b6e9871b4b
|
@ -71,6 +71,7 @@ export default Ember.Controller.extend(ModalFunctionality, {
|
||||||
this.send('closeModal');
|
this.send('closeModal');
|
||||||
this.set('topicStatusUpdate.execute_at', result.execute_at);
|
this.set('topicStatusUpdate.execute_at', result.execute_at);
|
||||||
this.set('topicStatusUpdate.duration', result.duration);
|
this.set('topicStatusUpdate.duration', result.duration);
|
||||||
|
this.set('model.closed', result.closed);
|
||||||
} else {
|
} else {
|
||||||
this.set('topicStatusUpdate', Ember.Object.create({}));
|
this.set('topicStatusUpdate', Ember.Object.create({}));
|
||||||
this.set('selection', null);
|
this.set('selection', null);
|
||||||
|
|
|
@ -347,7 +347,6 @@ export default createWidget('topic-timeline', {
|
||||||
result.push(h('div.title', elems));
|
result.push(h('div.title', elems));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (!attrs.fullScreen && currentUser && currentUser.get('canManageTopic')) {
|
if (!attrs.fullScreen && currentUser && currentUser.get('canManageTopic')) {
|
||||||
result.push(h('div.timeline-controls', this.attach('topic-admin-menu-button', { topic })));
|
result.push(h('div.timeline-controls', this.attach('topic-admin-menu-button', { topic })));
|
||||||
}
|
}
|
||||||
|
|
|
@ -310,7 +310,8 @@ class TopicsController < ApplicationController
|
||||||
render json: success_json.merge!({
|
render json: success_json.merge!({
|
||||||
execute_at: topic_status_update&.execute_at,
|
execute_at: topic_status_update&.execute_at,
|
||||||
duration: topic_status_update&.duration,
|
duration: topic_status_update&.duration,
|
||||||
based_on_last_post: topic_status_update&.based_on_last_post
|
based_on_last_post: topic_status_update&.based_on_last_post,
|
||||||
|
closed: topic.closed
|
||||||
})
|
})
|
||||||
else
|
else
|
||||||
render_json_error(topic)
|
render_json_error(topic)
|
||||||
|
|
|
@ -56,6 +56,7 @@ RSpec.describe "Managing a topic's status update", type: :request do
|
||||||
.to be_within(1.seconds).of(DateTime.parse(topic_status_update.execute_at.to_s))
|
.to be_within(1.seconds).of(DateTime.parse(topic_status_update.execute_at.to_s))
|
||||||
|
|
||||||
expect(json['duration']).to eq(topic_status_update.duration)
|
expect(json['duration']).to eq(topic_status_update.duration)
|
||||||
|
expect(json['closed']).to eq(topic.reload.closed)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should be able to delete a topic status update' do
|
it 'should be able to delete a topic status update' do
|
||||||
|
@ -72,6 +73,7 @@ RSpec.describe "Managing a topic's status update", type: :request do
|
||||||
|
|
||||||
expect(json['execute_at']).to eq(nil)
|
expect(json['execute_at']).to eq(nil)
|
||||||
expect(json['duration']).to eq(nil)
|
expect(json['duration']).to eq(nil)
|
||||||
|
expect(json['closed']).to eq(topic.closed)
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'invalid status type' do
|
describe 'invalid status type' do
|
||||||
|
|
Loading…
Reference in New Issue