mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-06 22:40:14 -05:00
fixed notification components
This commit is contained in:
parent
cf239774eb
commit
77d08c3207
8 changed files with 79 additions and 52 deletions
40
core/client/app/components/gh-alert.js
Normal file
40
core/client/app/components/gh-alert.js
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
import Ember from 'ember';
|
||||||
|
|
||||||
|
var AlertComponent = Ember.Component.extend({
|
||||||
|
tagName: 'article',
|
||||||
|
classNames: ['gh-alert', 'gh-alert-blue'],
|
||||||
|
classNameBindings: ['typeClass'],
|
||||||
|
|
||||||
|
typeClass: Ember.computed(function () {
|
||||||
|
var classes = '',
|
||||||
|
message = this.get('message'),
|
||||||
|
type,
|
||||||
|
dismissible;
|
||||||
|
|
||||||
|
// Check to see if we're working with a DS.Model or a plain JS object
|
||||||
|
if (typeof message.toJSON === 'function') {
|
||||||
|
type = message.get('type');
|
||||||
|
dismissible = message.get('dismissible');
|
||||||
|
} else {
|
||||||
|
type = message.type;
|
||||||
|
dismissible = message.dismissible;
|
||||||
|
}
|
||||||
|
|
||||||
|
classes += 'notification-' + type;
|
||||||
|
|
||||||
|
if (type === 'success' && dismissible !== false) {
|
||||||
|
classes += ' notification-passive';
|
||||||
|
}
|
||||||
|
|
||||||
|
return classes;
|
||||||
|
}),
|
||||||
|
|
||||||
|
actions: {
|
||||||
|
closeNotification: function () {
|
||||||
|
var self = this;
|
||||||
|
self.notifications.closeNotification(self.get('message'));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
export default AlertComponent;
|
18
core/client/app/components/gh-alerts.js
Normal file
18
core/client/app/components/gh-alerts.js
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
import Ember from 'ember';
|
||||||
|
var AlertsComponent = Ember.Component.extend({
|
||||||
|
tagName: 'aside',
|
||||||
|
classNames: 'gh-alerts',
|
||||||
|
|
||||||
|
messages: Ember.computed.filter('notifications', function (notification) {
|
||||||
|
var displayStatus = (typeof notification.toJSON === 'function') ?
|
||||||
|
notification.get('status') : notification.status;
|
||||||
|
|
||||||
|
return displayStatus === 'persistent';
|
||||||
|
}),
|
||||||
|
|
||||||
|
messageCountObserver: Ember.observer('messages.[]', function () {
|
||||||
|
this.sendAction('notify', this.get('messages').length);
|
||||||
|
})
|
||||||
|
});
|
||||||
|
|
||||||
|
export default AlertsComponent;
|
|
@ -1,7 +1,9 @@
|
||||||
import Ember from 'ember';
|
import Ember from 'ember';
|
||||||
|
|
||||||
var NotificationComponent = Ember.Component.extend({
|
var NotificationComponent = Ember.Component.extend({
|
||||||
classNames: ['js-bb-notification'],
|
tagName: 'article',
|
||||||
|
classNames: ['gh-notification', 'gh-notification-green'],
|
||||||
|
classNameBindings: ['typeClass'],
|
||||||
|
|
||||||
typeClass: Ember.computed(function () {
|
typeClass: Ember.computed(function () {
|
||||||
var classes = '',
|
var classes = '',
|
||||||
|
|
|
@ -1,25 +1,14 @@
|
||||||
import Ember from 'ember';
|
import Ember from 'ember';
|
||||||
var NotificationsComponent = Ember.Component.extend({
|
var NotificationsComponent = Ember.Component.extend({
|
||||||
tagName: 'aside',
|
tagName: 'aside',
|
||||||
classNames: 'notifications',
|
classNames: 'gh-notifications',
|
||||||
classNameBindings: ['location'],
|
|
||||||
|
|
||||||
messages: Ember.computed.filter('notifications', function (notification) {
|
messages: Ember.computed.filter('notifications', function (notification) {
|
||||||
// If this instance of the notifications component has no location affinity
|
var displayStatus = (typeof notification.toJSON === 'function') ?
|
||||||
// then it gets all notifications
|
notification.get('status') : notification.status;
|
||||||
if (!this.get('location')) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
var displayLocation = (typeof notification.toJSON === 'function') ?
|
return displayStatus === 'passive';
|
||||||
notification.get('location') : notification.location;
|
|
||||||
|
|
||||||
return this.get('location') === displayLocation;
|
|
||||||
}),
|
}),
|
||||||
|
|
||||||
messageCountObserver: function () {
|
|
||||||
this.sendAction('notify', this.get('messages').length);
|
|
||||||
}.observes('messages.[]')
|
|
||||||
});
|
});
|
||||||
|
|
||||||
export default NotificationsComponent;
|
export default NotificationsComponent;
|
||||||
|
|
|
@ -1,17 +1,6 @@
|
||||||
<a class="sr-only sr-only-focusable" href="#gh-main">Skip to main content</a>
|
<a class="sr-only sr-only-focusable" href="#gh-main">Skip to main content</a>
|
||||||
|
|
||||||
<!-- TODO: Rename gh-alerts, remove location attr -->
|
{{gh-alerts notify="topNotificationChange"}}
|
||||||
{{gh-notifications location="top" notify="topNotificationChange"}}
|
|
||||||
<!-- TODO: SHOULD RENDER LIKE
|
|
||||||
<aside id="ember754" class="gh-alerts">
|
|
||||||
<article class="gh-alert gh-alert-blue">
|
|
||||||
<div class="gh-alert-content">
|
|
||||||
<a href="https://ghost.org/download">Ghost 0.6.4</a> is available! Hot Damn. Please <a href="http://support.ghost.org/how-to-upgrade/" target="_blank">upgrade</a> now.
|
|
||||||
</div>
|
|
||||||
<button class="gh-alert-close icon-x" data-ember-action="779"><span class="hidden">Close</span></button>
|
|
||||||
</article>
|
|
||||||
</aside>
|
|
||||||
-->
|
|
||||||
|
|
||||||
<div class="gh-viewport">
|
<div class="gh-viewport">
|
||||||
|
|
||||||
|
@ -23,24 +12,8 @@
|
||||||
{{outlet}}
|
{{outlet}}
|
||||||
</main>
|
</main>
|
||||||
|
|
||||||
<!-- TODO: Remove location attr -->
|
{{gh-notifications}}
|
||||||
{{gh-notifications location="bottom"}}
|
|
||||||
<!-- TODO: SHOULD RENDER LIKE
|
|
||||||
<aside id="ember721" class="ember-view gh-notifications">
|
|
||||||
<article class="gh-notification gh-notification-green">
|
|
||||||
<div class="gh-notification-content">
|
|
||||||
<strong>Hannah Wolfe</strong> just updated the post <em>12 Reasons Why You're Not Selling Anything</em>.
|
|
||||||
</div>
|
|
||||||
<button class="gh-notification-close icon-x" data-ember-action="1077"><span class="hidden">Close</span></button>
|
|
||||||
</article>
|
|
||||||
<article class="gh-notification">
|
|
||||||
<div class="gh-notification-content">
|
|
||||||
<strong>Hannah Wolfe</strong> just updated the post <em>20 Reasons Why You're Not Selling Anything</em>.
|
|
||||||
</div>
|
|
||||||
<button class="gh-notification-close icon-x" data-ember-action="1077"><span class="hidden">Close</span></button>
|
|
||||||
</article>
|
|
||||||
</aside>
|
|
||||||
-->
|
|
||||||
{{outlet "modal"}}
|
{{outlet "modal"}}
|
||||||
{{outlet "settings-menu"}}
|
{{outlet "settings-menu"}}
|
||||||
|
|
||||||
|
|
4
core/client/app/templates/components/gh-alert.hbs
Normal file
4
core/client/app/templates/components/gh-alert.hbs
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
<div class="gh-alert-content">
|
||||||
|
{{message.message}}
|
||||||
|
</div>
|
||||||
|
<button class="gh-alert-close icon-x" {{action "closeNotification"}}><span class="hidden">Close</span></button>
|
3
core/client/app/templates/components/gh-alerts.hbs
Normal file
3
core/client/app/templates/components/gh-alerts.hbs
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
{{#each message in messages}}
|
||||||
|
{{gh-alert message=message}}
|
||||||
|
{{/each}}
|
|
@ -1,6 +1,4 @@
|
||||||
<article class="gh-notification js-notification {{typeClass}}">
|
<div class="gh-notification-content">
|
||||||
<div class="gh-notification-content">
|
{{message.message}}
|
||||||
{{message.message}}
|
</div>
|
||||||
</div>
|
<button class="gh-notification-close icon-x" {{action "closeNotification"}}><span class="hidden">Close</span></button>
|
||||||
<button class="gh-notification-close icon-x" {{action "closeNotification"}}><span class="hidden">Close</span></button>
|
|
||||||
</article>
|
|
Loading…
Reference in a new issue