mirror of
https://github.com/flarum/framework.git
synced 2025-01-26 17:02:01 +08:00
135 lines
4.5 KiB
JavaScript
135 lines
4.5 KiB
JavaScript
import Ember from 'ember';
|
|
|
|
import ComposerReply from 'flarum/components/composer/composer-reply';
|
|
import ActionButton from 'flarum/components/ui/action-button';
|
|
import AlertMessage from 'flarum/components/ui/alert-message';
|
|
import UseComposerMixin from 'flarum/mixins/use-composer';
|
|
|
|
export default Ember.Controller.extend(Ember.Evented, UseComposerMixin, {
|
|
needs: ['application'],
|
|
composer: Ember.inject.controller('composer'),
|
|
alerts: Ember.inject.controller('alerts'),
|
|
|
|
queryParams: ['start'],
|
|
start: '1',
|
|
searchQuery: '',
|
|
|
|
loaded: false,
|
|
stream: null,
|
|
|
|
// Save a reply. This may be called by a composer-reply component that was
|
|
// set up on a different discussion, so we require a discussion model to
|
|
// be explicitly passed rather than using the controller's implicit one.
|
|
// @todo break this down into bite-sized functions so that extensions can
|
|
// easily override where they please.
|
|
saveReply: function(discussion, data) {
|
|
var post = this.store.createRecord('post', {
|
|
content: data.content,
|
|
discussion: discussion
|
|
});
|
|
|
|
var controller = this;
|
|
var stream = this.get('stream');
|
|
return this.saveAndDismissComposer(post).then(function(post) {
|
|
discussion.setProperties({
|
|
lastTime: post.get('time'),
|
|
lastUser: post.get('user'),
|
|
lastPost: post,
|
|
lastPostNumber: post.get('number'),
|
|
commentsCount: discussion.get('commentsCount') + 1,
|
|
readTime: post.get('time'),
|
|
readNumber: post.get('number')
|
|
});
|
|
|
|
// If we're currently viewing the discussion which this reply was
|
|
// made in, then we can add the post to the end of the post
|
|
// stream.
|
|
if (discussion == controller.get('model') && stream) {
|
|
stream.addPostToEnd(post);
|
|
controller.transitionToRoute({queryParams: {start: post.get('number')}});
|
|
} else {
|
|
// Otherwise, we'll create an alert message to inform the user
|
|
// that their reply has been posted, containing a button which
|
|
// will transition to their new post when clicked.
|
|
var message = AlertMessage.extend({
|
|
type: 'success',
|
|
message: 'Your reply was posted.',
|
|
buttons: [{
|
|
label: 'View',
|
|
action: function() {
|
|
controller.transitionToRoute('discussion', post.get('discussion'), {queryParams: {start: post.get('number')}});
|
|
}
|
|
}]
|
|
});
|
|
controller.get('alerts').send('alert', message);
|
|
}
|
|
});
|
|
},
|
|
|
|
// Whenever we transition to a different discussion or the logged-in user
|
|
// changes, we'll need the composer content to refresh next time the reply
|
|
// button is clicked.
|
|
clearComposerContent: Ember.observer('model', 'session.user', function() {
|
|
this.set('composerContent', undefined);
|
|
}),
|
|
|
|
actions: {
|
|
reply: function() {
|
|
var discussion = this.get('model');
|
|
var controller = this;
|
|
if (this.get('session.isAuthenticated')) {
|
|
this.showComposer(function() {
|
|
return ComposerReply.create({
|
|
user: controller.get('session.user'),
|
|
discussion: discussion,
|
|
submit: function(data) {
|
|
controller.saveReply(discussion, data);
|
|
}
|
|
});
|
|
});
|
|
} else {
|
|
this.send('signup');
|
|
}
|
|
},
|
|
|
|
// This action is called when the start position of the discussion
|
|
// currently being viewed changes (i.e. when the user scrolls up/down
|
|
// the post stream.)
|
|
positionChanged: function(startNumber, endNumber) {
|
|
this.set('start', startNumber);
|
|
|
|
var discussion = this.get('model');
|
|
if (endNumber > discussion.get('readNumber') && this.get('session.isAuthenticated')) {
|
|
discussion.set('readNumber', endNumber);
|
|
discussion.save();
|
|
}
|
|
},
|
|
|
|
postRemoved: function(post) {
|
|
this.get('stream').removePost(post);
|
|
},
|
|
|
|
rename: function(title) {
|
|
var discussion = this.get('model');
|
|
discussion.set('title', title);
|
|
|
|
// When we save the title, we should get back an 'added post' in the
|
|
// response which documents the title change. We'll add this to the post
|
|
// stream.
|
|
var controller = this;
|
|
discussion.save().then(function(discussion) {
|
|
discussion.get('addedPosts').forEach(function(post) {
|
|
controller.get('stream').addPostToEnd(post);
|
|
});
|
|
});
|
|
},
|
|
|
|
delete: function() {
|
|
var controller = this;
|
|
this.get('model').destroyRecord().then(function() {
|
|
controller.transitionToRoute('index');
|
|
});
|
|
}
|
|
}
|
|
});
|