mirror of
				https://github.com/flarum/core.git
				synced 2025-10-25 13:46:29 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			136 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			136 lines
		
	
	
		
			4.6 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', 'index'],
 | |
|   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;
 | |
|       var discussion = this.get('model');
 | |
|       discussion.destroyRecord().then(function() {
 | |
|         controller.get('controllers.index').send('discussionRemoved', discussion);
 | |
|       });
 | |
|     }
 | |
|   }
 | |
| });
 |