mirror of
				https://github.com/flarum/core.git
				synced 2025-10-25 05:36:07 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			77 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			77 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import Modal from '../../common/components/Modal';
 | |
| import Button from '../../common/components/Button';
 | |
| import Stream from '../../common/utils/Stream';
 | |
| 
 | |
| /**
 | |
|  * The 'RenameDiscussionModal' displays a modal dialog with an input to rename a discussion
 | |
|  */
 | |
| export default class RenameDiscussionModal extends Modal {
 | |
|   oninit(vnode) {
 | |
|     super.oninit(vnode);
 | |
| 
 | |
|     this.discussion = this.attrs.discussion;
 | |
|     this.currentTitle = this.attrs.currentTitle;
 | |
|     this.newTitle = Stream(this.currentTitle);
 | |
|   }
 | |
| 
 | |
|   className() {
 | |
|     return 'RenameDiscussionModal Modal--small';
 | |
|   }
 | |
| 
 | |
|   title() {
 | |
|     return app.translator.trans('core.forum.rename_discussion.title');
 | |
|   }
 | |
| 
 | |
|   content() {
 | |
|     return (
 | |
|       <div className="Modal-body">
 | |
|         <div className="Form Form--centered">
 | |
|           <div className="Form-group">
 | |
|             <input className="FormControl" bidi={this.newTitle} type="text" />
 | |
|           </div>
 | |
|           <div className="Form-group">
 | |
|             {Button.component(
 | |
|               {
 | |
|                 className: 'Button Button--primary Button--block',
 | |
|                 type: 'submit',
 | |
|                 loading: this.loading,
 | |
|               },
 | |
|               app.translator.trans('core.forum.rename_discussion.submit_button')
 | |
|             )}
 | |
|           </div>
 | |
|         </div>
 | |
|       </div>
 | |
|     );
 | |
|   }
 | |
| 
 | |
|   onsubmit(e) {
 | |
|     e.preventDefault();
 | |
| 
 | |
|     this.loading = true;
 | |
| 
 | |
|     const title = this.newTitle;
 | |
|     const currentTitle = this.currentTitle;
 | |
| 
 | |
|     // If the title is different to what it was before, then save it. After the
 | |
|     // save has completed, update the post stream as there will be a new post
 | |
|     // indicating that the discussion was renamed.
 | |
|     if (title && title !== currentTitle) {
 | |
|       return this.discussion
 | |
|         .save({ title })
 | |
|         .then(() => {
 | |
|           if (app.viewingDiscussion(this.discussion)) {
 | |
|             app.current.get('stream').update();
 | |
|           }
 | |
|           m.redraw();
 | |
|           this.hide();
 | |
|         })
 | |
|         .catch(() => {
 | |
|           this.loading = false;
 | |
|           m.redraw();
 | |
|         });
 | |
|     } else {
 | |
|       this.hide();
 | |
|     }
 | |
|   }
 | |
| }
 |