mirror of
https://github.com/flarum/core.git
synced 2025-10-24 13:16:08 +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