访问商店的服务的计算属性

时间:2017-02-12 08:59:56

标签: ember.js promise ember-data

我写了一个加载通知的服务:

import Ember from 'ember';

export default Ember.Service.extend({
  sessionUser: Ember.inject.service(),
  store: Ember.inject.service(),

  read() {
    let currentUserId = this.get('sessionUser.user.id');
    return this.get('store').query('notification', {
      userId: currentUserId,
      read: true
    });
  },

  unread() {
    let currentUserId = this.get('sessionUser.user.id');
    return this.get('store').query('notification', {
      userId: currentUserId,
      read: false
    });
  }
});

我想在有未读通知时更改导航栏中图标的颜色。导航栏是一个组件:

import Ember from 'ember';

export default Ember.Component.extend({
  notifications: Ember.inject.service(),
  session: Ember.inject.service(),

  hasUnreadNotifications: Ember.computed('notifications', function() {
    return this.get('notifications').unread().then((unread) => {
      return unread.get('length') > 0;
    });
  })
});

然后模板使用hasUnreadNotifications属性来决定是否应该使用高亮类:

<span class="icon">
  <i class="fa fa-bell {{if hasUnreadNotifications 'has-notifications'}}"></i>
</span>

然而,它不起作用。虽然调用了存储并返回了通知,但hadUnreadNotifications并未解析为布尔值。我认为这是因为它返回了一个承诺而模板无法处理,但我不确定。

问题

  • 将商店包装在这样的服务中是不是特殊的余烬。我这样做是因为在应用程序路由中加载通知只是为了显示计数而感到笨拙。
  • 为什么hasUnreadNotifications没有返回布尔值?
  • 是否可以使readunread属性而不是函数,因此可以在服务中创建计算属性来计算计数?

1 个答案:

答案 0 :(得分:2)

从计算属性返回承诺将不起作用。计算属性不是Promise意识。要使它工作,您需要返回DS.PrmoiseObject或DS.PromiseArray。

您可以阅读此igniter article中提供的其他选项。

import Ember from 'ember';
import DS from 'ember-data';

export default Ember.Component.extend({
    notifications: Ember.inject.service(),
    session: Ember.inject.service(),

    hasUnreadNotifications: Ember.computed('notifications', function() {
        return DS.PromiseObject.create({
            promise: this.get('notifications').unread().then((unread) => {
                return unread.get('length') > 0;
            })
        });
    })

});