mirror of
				https://github.com/flarum/core.git
				synced 2025-10-26 05:06:06 +01:00 
			
		
		
		
	Webpack (#1367)
* Replace gulp with webpack and npm scripts for JS compilation * Set up Travis CI to commit compiled JS * Restructure `js` directory; only one instance of npm, forum/admin are "submodules" * Refactor JS initializers into Application subclasses * Maintain partial compatibility API (importing from absolute paths) for extensions * Remove minification responsibility from PHP asset compiler * Restructure `less` directory
This commit is contained in:
		
							
								
								
									
										92
									
								
								js/src/forum/components/HeaderSecondary.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										92
									
								
								js/src/forum/components/HeaderSecondary.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,92 @@ | ||||
| import Component from '../../common/Component'; | ||||
| import Button from '../../common/components/Button'; | ||||
| import LogInModal from './LogInModal'; | ||||
| import SignUpModal from './SignUpModal'; | ||||
| import SessionDropdown from './SessionDropdown'; | ||||
| import SelectDropdown from '../../common/components/SelectDropdown'; | ||||
| import NotificationsDropdown from './NotificationsDropdown'; | ||||
| import ItemList from '../../common/utils/ItemList'; | ||||
| import listItems from '../../common/helpers/listItems'; | ||||
|  | ||||
| /** | ||||
|  * The `HeaderSecondary` component displays secondary header controls, such as | ||||
|  * the search box and the user menu. On the default skin, these are shown on the | ||||
|  * right side of the header. | ||||
|  */ | ||||
| export default class HeaderSecondary extends Component { | ||||
|   view() { | ||||
|     return ( | ||||
|       <ul className="Header-controls"> | ||||
|         {listItems(this.items().toArray())} | ||||
|       </ul> | ||||
|     ); | ||||
|   } | ||||
|  | ||||
|   config(isInitialized, context) { | ||||
|     // Since this component is 'above' the content of the page (that is, it is a | ||||
|     // part of the global UI that persists between routes), we will flag the DOM | ||||
|     // to be retained across route changes. | ||||
|     context.retain = true; | ||||
|   } | ||||
|  | ||||
|   /** | ||||
|    * Build an item list for the controls. | ||||
|    * | ||||
|    * @return {ItemList} | ||||
|    */ | ||||
|   items() { | ||||
|     const items = new ItemList(); | ||||
|  | ||||
|     items.add('search', app.search.render(), 30); | ||||
|  | ||||
|     if (app.forum.attribute("showLanguageSelector") && Object.keys(app.data.locales).length > 1) { | ||||
|       const locales = []; | ||||
|  | ||||
|       for (const locale in app.data.locales) { | ||||
|         locales.push(Button.component({ | ||||
|           active: app.data.locale === locale, | ||||
|           children: app.data.locales[locale], | ||||
|           icon: app.data.locale === locale ? 'fas fa-check' : true, | ||||
|           onclick: () => { | ||||
|             if (app.session.user) { | ||||
|               app.session.user.savePreferences({locale}).then(() => window.location.reload()); | ||||
|             } else { | ||||
|               document.cookie = `locale=${locale}; path=/; expires=Tue, 19 Jan 2038 03:14:07 GMT`; | ||||
|               window.location.reload(); | ||||
|             } | ||||
|           } | ||||
|         })); | ||||
|       } | ||||
|  | ||||
|       items.add('locale', SelectDropdown.component({ | ||||
|         children: locales, | ||||
|         buttonClassName: 'Button Button--link' | ||||
|       }), 20); | ||||
|     } | ||||
|  | ||||
|     if (app.session.user) { | ||||
|       items.add('notifications', NotificationsDropdown.component(), 10); | ||||
|       items.add('session', SessionDropdown.component(), 0); | ||||
|     } else { | ||||
|       if (app.forum.attribute('allowSignUp')) { | ||||
|         items.add('signUp', | ||||
|           Button.component({ | ||||
|             children: app.translator.trans('core.forum.header.sign_up_link'), | ||||
|             className: 'Button Button--link', | ||||
|             onclick: () => app.modal.show(new SignUpModal()) | ||||
|           }), 10 | ||||
|         ); | ||||
|       } | ||||
|  | ||||
|       items.add('logIn', | ||||
|         Button.component({ | ||||
|           children: app.translator.trans('core.forum.header.log_in_link'), | ||||
|           className: 'Button Button--link', | ||||
|           onclick: () => app.modal.show(new LogInModal()) | ||||
|         }), 0 | ||||
|       ); | ||||
|     } | ||||
|  | ||||
|     return items; | ||||
|   } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user