mirror of
				https://github.com/flarum/core.git
				synced 2025-10-24 21:26:11 +02:00 
			
		
		
		
	Working on interface components.
This commit is contained in:
		| @@ -10,7 +10,7 @@ export default Ember.View.extend({ | |||||||
| 	classNames: ['btn'], | 	classNames: ['btn'], | ||||||
| 	classNameBindings: ['class', 'disabled'], | 	classNameBindings: ['class', 'disabled'], | ||||||
|  |  | ||||||
| 	layout: Ember.Handlebars.compile('{{#if view.icon}}{{fa-icon view.icon class="fa-fw"}} {{/if}}<span>{{view.title}}</span>'), | 	layout: Ember.Handlebars.compile('{{#if view.icon}}{{fa-icon view.icon class="fa-fw"}} {{/if}}<span class="label">{{view.title}}</span>'), | ||||||
|  |  | ||||||
| 	click: function() { | 	click: function() { | ||||||
| 		this.action(); | 		this.action(); | ||||||
|   | |||||||
| @@ -131,18 +131,18 @@ export default Ember.View.extend({ | |||||||
|  |  | ||||||
| 		var discussion = this.get('discussion'); | 		var discussion = this.get('discussion'); | ||||||
|  |  | ||||||
| 		var controls = this.get('controls'); | 		// var controls = this.get('controls'); | ||||||
|  |  | ||||||
| 		controls.addItem('sticky', MenuItem.extend({title: 'Sticky', icon: 'thumb-tack', action: 'sticky'})); | 		// controls.addItem('sticky', MenuItem.extend({title: 'Sticky', icon: 'thumb-tack', action: 'sticky'})); | ||||||
| 		controls.addItem('lock', MenuItem.extend({title: 'Lock', icon: 'lock', action: 'lock'})); | 		// controls.addItem('lock', MenuItem.extend({title: 'Lock', icon: 'lock', action: 'lock'})); | ||||||
|  |  | ||||||
| 		controls.addSeparator(); | 		// controls.addSeparator(); | ||||||
|  |  | ||||||
| 		controls.addItem('delete', MenuItem.extend({title: 'Delete', icon: 'times', className: 'delete', action: function() { | 		// controls.addItem('delete', MenuItem.extend({title: 'Delete', icon: 'times', className: 'delete', action: function() { | ||||||
| 			// this.get('controller').send('delete', discussion); | 		// 	// this.get('controller').send('delete', discussion); | ||||||
| 			var discussion = view.$().slideUp().find('.discussion'); | 		// 	var discussion = view.$().slideUp().find('.discussion'); | ||||||
| 			discussion.css('position', 'relative').animate({left: -discussion.width()}); | 		// 	discussion.css('position', 'relative').animate({left: -discussion.width()}); | ||||||
| 		}})); | 		// }})); | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
| 	actions: { | 	actions: { | ||||||
|   | |||||||
| @@ -1,5 +1,7 @@ | |||||||
| import Ember from 'ember'; | import Ember from 'ember'; | ||||||
|  |  | ||||||
|  | import MenuItemContainer from '../components/menu-item-container'; | ||||||
|  |  | ||||||
| export default Ember.Component.extend({ | export default Ember.Component.extend({ | ||||||
|     items: null, // NamedContainerView/Menu |     items: null, // NamedContainerView/Menu | ||||||
|     layoutName: 'components/dropdown-button', |     layoutName: 'components/dropdown-button', | ||||||
| @@ -17,5 +19,19 @@ export default Ember.Component.extend({ | |||||||
|  |  | ||||||
|     itemCountClass: function() { |     itemCountClass: function() { | ||||||
|         return 'item-count-'+this.get('items.length'); |         return 'item-count-'+this.get('items.length'); | ||||||
|     }.property('items') |     }.property('items'), | ||||||
|  |  | ||||||
|  |     containedItems: function() { | ||||||
|  |         var contained = []; | ||||||
|  |         this.get('items').forEach(function(item) { | ||||||
|  |             if (item.tagName != 'li') { | ||||||
|  |                 contained.push(MenuItemContainer.extend({ | ||||||
|  |                     item: item | ||||||
|  |                 })); | ||||||
|  |             } else { | ||||||
|  |                 contained.push(item); | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  |         return contained; | ||||||
|  |     }.property('items.[]') | ||||||
| }); | }); | ||||||
|   | |||||||
							
								
								
									
										30
									
								
								ember/app/components/dropdown-select.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								ember/app/components/dropdown-select.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,30 @@ | |||||||
|  | import Ember from 'ember'; | ||||||
|  |  | ||||||
|  | import Menu from '../utils/menu'; | ||||||
|  |  | ||||||
|  | export default Ember.Component.extend({ | ||||||
|  |     items: [], | ||||||
|  |     layoutName: 'components/dropdown-select', | ||||||
|  |     classNames: ['dropdown', 'dropdown-select', 'btn-group'], | ||||||
|  |     classNameBindings: ['itemCountClass'], | ||||||
|  |  | ||||||
|  |     buttonClass: 'btn-default', | ||||||
|  |     menuClass: 'pull-right', | ||||||
|  |     icon: 'ellipsis-v', | ||||||
|  |  | ||||||
|  |     mainButtonClass: function() { | ||||||
|  |     	return 'btn '+this.get('buttonClass'); | ||||||
|  |     }.property('buttonClass'), | ||||||
|  |  | ||||||
|  |     dropdownMenuClass: function() { | ||||||
|  |     	return 'dropdown-menu '+this.get('menuClass'); | ||||||
|  |     }.property('menuClass'), | ||||||
|  |  | ||||||
|  |     itemCountClass: function() { | ||||||
|  |         return 'item-count-'+this.get('items.length'); | ||||||
|  |     }.property('items.length'), | ||||||
|  |  | ||||||
|  |     currentItem: function() { | ||||||
|  |         return this.get('menu.childViews').findBy('active'); | ||||||
|  |     }.property('menu.childViews.@each.active') | ||||||
|  | }); | ||||||
| @@ -1,5 +1,7 @@ | |||||||
| import Ember from 'ember'; | import Ember from 'ember'; | ||||||
|  |  | ||||||
|  | import MenuItemContainer from '../components/menu-item-container'; | ||||||
|  |  | ||||||
| export default Ember.Component.extend({ | export default Ember.Component.extend({ | ||||||
|     items: null, // NamedContainerView/Menu |     items: null, // NamedContainerView/Menu | ||||||
|     layoutName: 'components/dropdown-split', |     layoutName: 'components/dropdown-split', | ||||||
| @@ -20,5 +22,19 @@ export default Ember.Component.extend({ | |||||||
|  |  | ||||||
|     itemCountClass: function() { |     itemCountClass: function() { | ||||||
|         return 'item-count-'+this.get('items.length'); |         return 'item-count-'+this.get('items.length'); | ||||||
|     }.property('items') |     }.property('items'), | ||||||
|  |  | ||||||
|  |     containedItems: function() { | ||||||
|  |         var contained = []; | ||||||
|  |         this.get('items').forEach(function(item) { | ||||||
|  |             if (item.tagName != 'li') { | ||||||
|  |                 contained.push(MenuItemContainer.extend({ | ||||||
|  |                     item: item | ||||||
|  |                 })); | ||||||
|  |             } else { | ||||||
|  |                 contained.push(item); | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  |         return contained; | ||||||
|  |     }.property('items.[]') | ||||||
| }); | }); | ||||||
|   | |||||||
							
								
								
									
										6
									
								
								ember/app/components/menu-item-container.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								ember/app/components/menu-item-container.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | import Ember from 'ember'; | ||||||
|  |  | ||||||
|  | export default Ember.Component.extend({ | ||||||
|  |     tagName: 'li', | ||||||
|  |     layoutName: 'components/menu-item-container' | ||||||
|  | }); | ||||||
| @@ -1,5 +1,6 @@ | |||||||
| import Ember from 'ember'; | import Ember from 'ember'; | ||||||
|  |  | ||||||
| export default Ember.Component.extend({ | export default Ember.Component.extend({ | ||||||
|     liClass: 'divider' |     liClass: 'divider', | ||||||
|  |     active: false | ||||||
| }); | }); | ||||||
|   | |||||||
| @@ -6,6 +6,7 @@ var MenuItem = Ember.Component.extend({ | |||||||
|     className: '', |     className: '', | ||||||
|     action: null, |     action: null, | ||||||
|     divider: false, |     divider: false, | ||||||
|  |     active: false, | ||||||
|  |  | ||||||
|     tagName: 'a', |     tagName: 'a', | ||||||
|     attributeBindings: ['href'], |     attributeBindings: ['href'], | ||||||
|   | |||||||
| @@ -2,5 +2,5 @@ import Ember from 'ember'; | |||||||
|  |  | ||||||
| export default Ember.Component.extend({ | export default Ember.Component.extend({ | ||||||
|     tagName: 'ul', |     tagName: 'ul', | ||||||
|     layoutName: 'components/menu-list', |     layoutName: 'components/menu-list' | ||||||
| }); | }); | ||||||
|   | |||||||
| @@ -5,18 +5,24 @@ export default Ember.Component.extend({ | |||||||
| 	title: '', | 	title: '', | ||||||
| 	action: null, | 	action: null, | ||||||
| 	badge: '', | 	badge: '', | ||||||
| 	badgeAction: null, |  | ||||||
| 	// active: false, |  | ||||||
|  |  | ||||||
| 	tagName: 'li', | 	tagName: 'li', | ||||||
| 	classNameBindings: ['active'], | 	classNameBindings: ['active'], | ||||||
|     active: function() { |     active: function() { | ||||||
|         return this.get('childViews').anyBy('active'); |         return !! this.get('childViews').anyBy('active'); | ||||||
|     }.property('childViews.@each.active'), |     }.property('childViews.@each.active'), | ||||||
|  |  | ||||||
|  |     // init: function() { | ||||||
|  |     //     var params = this.params; | ||||||
|  |     //     if (params[params.length - 1].queryParams) { | ||||||
|  |     //         this.queryParamsObject = {values: params.pop().queryParams}; | ||||||
|  |     //     } | ||||||
|  |  | ||||||
|  |     //     this._super(); | ||||||
|  |     // }, | ||||||
|  |  | ||||||
| 	layout: function() { | 	layout: function() { | ||||||
|         return Ember.Handlebars.compile('<a href="#" class="count" {{action "badge"}}>{{badge}}</a>\ |         return Ember.Handlebars.compile('{{#link-to '+this.get('linkTo')+'}}'+this.get('iconTemplate')+' {{title}} <span class="count">{{badge}}</span>{{/link-to}}'); | ||||||
|             {{#link-to '+this.get('linkTo')+'}}'+this.get('iconTemplate')+'{{title}}{{/link-to}}'); |  | ||||||
|     }.property('linkTo', 'iconTemplate'), |     }.property('linkTo', 'iconTemplate'), | ||||||
|  |  | ||||||
|     iconTemplate: function() { |     iconTemplate: function() { | ||||||
| @@ -26,9 +32,6 @@ export default Ember.Component.extend({ | |||||||
|     actions: { |     actions: { | ||||||
|         main: function() { |         main: function() { | ||||||
|             this.get('action')(); |             this.get('action')(); | ||||||
|         }, |  | ||||||
|         badge: function() { |  | ||||||
|             this.get('badgeAction')(); |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| }); | }); | ||||||
|   | |||||||
| @@ -4,6 +4,6 @@ export default Ember.View.extend({ | |||||||
|  |  | ||||||
| 	tagName: 'span', | 	tagName: 'span', | ||||||
| 	classNames: ['select'], | 	classNames: ['select'], | ||||||
| 	layout: Ember.Handlebars.compile('{{view Ember.Select content=view.content optionValuePath=view.optionValuePath optionLabelPath=view.optionLabelPath value=view.value}} {{fa-icon "sort"}}') | 	layout: Ember.Handlebars.compile('{{view "select" content=view.content optionValuePath=view.optionValuePath optionLabelPath=view.optionLabelPath value=view.value}} {{fa-icon "sort"}}') | ||||||
|  |  | ||||||
| }); | }); | ||||||
|   | |||||||
| @@ -1,8 +1,8 @@ | |||||||
| {{#if items}} | {{#if items}} | ||||||
|     <button {{bind-attr class=":dropdown-toggle :btn buttonClass"}}> |     <button {{bind-attr class=":dropdown-toggle :btn buttonClass"}} data-toggle="dropdown"> | ||||||
|         {{fa-icon icon class="icon-glyph"}} |         {{fa-icon icon class="icon-glyph"}} | ||||||
|     	<span class="label">{{title}}</span> |     	<span class="label">{{title}}</span> | ||||||
|         {{fa-icon "caret-down" class="icon-caret"}} |         {{fa-icon "caret-down" class="icon-caret"}} | ||||||
|     </button> |     </button> | ||||||
|     {{menu-list items=items class=dropdownMenuClass}} |     {{menu-list items=containedItems class=dropdownMenuClass}} | ||||||
| {{/if}} | {{/if}} | ||||||
							
								
								
									
										7
									
								
								ember/app/templates/components/dropdown-select.hbs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								ember/app/templates/components/dropdown-select.hbs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | {{#if items}} | ||||||
|  |     <button {{bind-attr class=":dropdown-toggle :btn buttonClass"}} data-toggle="dropdown"> | ||||||
|  |     	<span class="label">{{currentItem.title}}</span> | ||||||
|  |         {{fa-icon "sort" class="icon-caret"}} | ||||||
|  |     </button> | ||||||
|  |     {{menu-list items=items class=dropdownMenuClass viewName="menu"}} | ||||||
|  | {{/if}} | ||||||
| @@ -1,8 +1,8 @@ | |||||||
| {{#if items}} | {{#if items}} | ||||||
|     {{view items.firstItem class=mainButtonClass}} |     {{view items.firstItem class=mainButtonClass}} | ||||||
|     <button {{bind-attr class=":dropdown-toggle :btn buttonClass"}}> |     <button {{bind-attr class=":dropdown-toggle :btn buttonClass"}} data-toggle="dropdown"> | ||||||
|         {{fa-icon "caret-down" class="icon-caret"}} |         {{fa-icon "caret-down" class="icon-caret"}} | ||||||
|         {{fa-icon icon class="icon-glyph"}} |         {{fa-icon icon class="icon-glyph"}} | ||||||
|     </button> |     </button> | ||||||
|     {{menu-list items=items class=dropdownMenuClass}} |     {{menu-list items=containedItems class=dropdownMenuClass}} | ||||||
| {{/if}} | {{/if}} | ||||||
							
								
								
									
										1
									
								
								ember/app/templates/components/menu-item-container.hbs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								ember/app/templates/components/menu-item-container.hbs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | {{view item}} | ||||||
| @@ -1,3 +1,3 @@ | |||||||
| {{#each item in items}} | {{#each item in items}} | ||||||
|     <li {{bind-attr class="item.liClass"}}>{{view item}}</li> |     {{view item}} | ||||||
| {{/each}} | {{/each}} | ||||||
|   | |||||||
| @@ -1,11 +1,7 @@ | |||||||
| <div class="discussions-area"> | <div class="discussions-area"> | ||||||
|  |  | ||||||
| 	<nav class="discussions-nav"> | 	<nav class="discussions-nav"> | ||||||
| 		<button class="btn btn-primary"> | 		{{view view.sidebarView viewName="sidebar"}} | ||||||
| 			{{fa-icon "edit"}} |  | ||||||
| 			<span class="label">Start a Discussion</span> |  | ||||||
| 		</button> |  | ||||||
| 		{{menu-list items=discussionsNavItems class="nav"}} |  | ||||||
| 	</nav> | 	</nav> | ||||||
|  |  | ||||||
| 	<div class="discussions-results"> | 	<div class="discussions-results"> | ||||||
|   | |||||||
| @@ -5,29 +5,10 @@ import MenuItemSeparator from '../components/menu-item-separator'; | |||||||
|  |  | ||||||
| export default NamedContainerView.extend({ | export default NamedContainerView.extend({ | ||||||
|  |  | ||||||
|     tagName: 'ul', |  | ||||||
|  |  | ||||||
|     active: null, |  | ||||||
|  |  | ||||||
|     i: 1, |     i: 1, | ||||||
|     addSeparator: function(index) { |     addSeparator: function(index) { | ||||||
|         var item = MenuItemSeparator; |         var item = MenuItemSeparator; | ||||||
|         this.addItem('separator'+(this.i++), item, index); |         this.addItem('separator'+(this.i++), item, index); | ||||||
|     }, |  | ||||||
|  |  | ||||||
|     activeChanged: function() { |  | ||||||
|         var active = this.get('active'); |  | ||||||
|         if (typeof active != 'array') { |  | ||||||
|             active = [active]; |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|         var namedViews = this.get('namedViews'); |  | ||||||
|         var view; |  | ||||||
|         for (var name in namedViews) { |  | ||||||
|             if (namedViews.hasOwnProperty(name) && (view = namedViews.get(name))) { |  | ||||||
|                 view.set('active', active.indexOf(name) !== -1); |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     }.observes('active') |  | ||||||
|  |  | ||||||
| }); | }); | ||||||
|   | |||||||
| @@ -3,11 +3,10 @@ import Ember from 'ember'; | |||||||
| export default Ember.ArrayProxy.extend({ | export default Ember.ArrayProxy.extend({ | ||||||
|  |  | ||||||
|     content: null, |     content: null, | ||||||
|  |  | ||||||
| 	namedViews: null, | 	namedViews: null, | ||||||
|  |  | ||||||
|     init: function() { |     init: function() { | ||||||
|         this.set('content', Ember.A()); |         this.set('content', Ember.A()); // this is an important line. | ||||||
|         this.set('namedViews', Ember.Object.create()); |         this.set('namedViews', Ember.Object.create()); | ||||||
|         this._super(); |         this._super(); | ||||||
|     }, |     }, | ||||||
|   | |||||||
| @@ -1,7 +1,14 @@ | |||||||
| import Ember from 'ember'; | import Ember from 'ember'; | ||||||
|  |  | ||||||
|  | import DropdownSelect from '../components/dropdown-select'; | ||||||
|  | import ButtonItem from '../components/button-item'; | ||||||
|  | import NavItem from '../components/nav-item'; | ||||||
|  | import Menu from '../utils/menu'; | ||||||
|  |  | ||||||
| export default Ember.View.extend({ | export default Ember.View.extend({ | ||||||
|  |  | ||||||
|  | 	sidebarView: Ember.ContainerView.extend(), | ||||||
|  |  | ||||||
| 	classNameBindings: ['pinned'], | 	classNameBindings: ['pinned'], | ||||||
|  |  | ||||||
|     pinned: function() { |     pinned: function() { | ||||||
| @@ -10,6 +17,8 @@ export default Ember.View.extend({ | |||||||
|  |  | ||||||
| 	didInsertElement: function() { | 	didInsertElement: function() { | ||||||
|  |  | ||||||
|  | 		this.trigger('populateSidebar', this.get('sidebar')); | ||||||
|  |  | ||||||
| 		var view = this; | 		var view = this; | ||||||
|  |  | ||||||
| 		this.$().find('.discussions-pane').on('mouseenter', function() { | 		this.$().find('.discussions-pane').on('mouseenter', function() { | ||||||
| @@ -49,6 +58,46 @@ export default Ember.View.extend({ | |||||||
| 		}); | 		}); | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
|  | 	setupSidebar: function(sidebar) { | ||||||
|  |         sidebar.pushObject(ButtonItem.create({ | ||||||
|  |         	title: 'Start a Discussion', | ||||||
|  |         	icon: 'edit', | ||||||
|  |         	class: 'btn-primary' | ||||||
|  |         })); | ||||||
|  |  | ||||||
|  |         var nav = Menu.create(); | ||||||
|  |         this.trigger('populateNav', nav); | ||||||
|  |         sidebar.pushObject(DropdownSelect.create({ | ||||||
|  |             items: nav | ||||||
|  |         })); | ||||||
|  |     }.on('populateSidebar'), | ||||||
|  |  | ||||||
|  |     setupNav: function(nav) { | ||||||
|  |         nav.addItem('all', NavItem.create({ | ||||||
|  | 			title: 'All Discussions', | ||||||
|  | 			icon: 'comments-o', | ||||||
|  | 			linkTo: '"discussions" (query-params filter="")' | ||||||
|  | 		})); | ||||||
|  |  | ||||||
|  | 		nav.addItem('private', NavItem.create({ | ||||||
|  | 			title: 'Private', | ||||||
|  | 			icon: 'envelope-o', | ||||||
|  | 			linkTo: '"discussions" (query-params filter="private")' | ||||||
|  | 		})); | ||||||
|  |  | ||||||
|  | 		nav.addItem('following', NavItem.create({ | ||||||
|  | 			title: 'Following', | ||||||
|  | 			icon: 'star', | ||||||
|  | 			linkTo: '"discussions" (query-params filter="following")' | ||||||
|  | 		})); | ||||||
|  |  | ||||||
|  | 		nav.addItem('categories', NavItem.create({ | ||||||
|  | 			title: 'Categories', | ||||||
|  | 			icon: 'reorder', | ||||||
|  | 			linkTo: '"categories"' | ||||||
|  | 		})); | ||||||
|  |     }.on('populateNav'), | ||||||
|  |  | ||||||
| 	willDestroyElement: function() { | 	willDestroyElement: function() { | ||||||
| 		this.set('controller.test', $(window).scrollTop()); | 		this.set('controller.test', $(window).scrollTop()); | ||||||
| 		$(window).off('scroll.loadMore'); | 		$(window).off('scroll.loadMore'); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user