使用角度流星管理ui路由中的订阅

时间:2015-11-27 09:05:05

标签: javascript angularjs meteor

我目前正在使用角度流星建立一个使用meteor和angularJS的应用程序。我目前正在问自己,如何正确处理订阅。我目前的做法是:

  • 解决每个相关订阅准备就绪时的路由
  • 确保停止该出版物的先前订阅

有更高效的方法吗?

profileRoutes.js:

function profileRoutes($stateProvider, ResolverProvider) {
  $stateProvider
    .state('user.profile', {
      url: '/:username/profile',
      resolve: _.extend(
        {
          $title: ['$stateParams', function($sp) {
            return $sp.username + "'s Profil";
          }]
        },
        ResolverProvider.waitForMedia(),
        ResolverProvider.waitForUsers()
      ),
      abstract: true,
      views: {
        'main': {
          controller: 'UserProfileController',
          templateUrl: 'client/components/users/profile.html'
        }
      }
    });
  }

  angular
    .module('myApp')
    .config(profileRoutes);

resolver.js

function ResolverProvider() {

  /**
   * _stopIfSubscribed
   *
   * Checks if a subscription for that publication is already present and stops it.
   * @param publicationName
   * @private
   */
   function _stopIfSubscribed(publicationName) {
     _.forEach(_.get(Meteor, 'default_connection._subscriptions'), (handle) => {
     if(_.get(handle, 'name') === publicationName && handle.stop) {
       handle.stop();
     }
   });
 }

 /**
  * waitForUsers
  *
  * Returns resolvers for waiting on my own and all other users
  * Does not require a user
  * @returns {{meSubscription: *[], usersSubscription: *[]}}
  */
 this.waitForUsers = () => {
   return {
     "meSubscription": ['$meteor', function ($meteor) {
       return $meteor.waitForUser();
     }],
      "usersSubscription": ['$meteor', function ($meteor) {
       _stopIfSubscribed('allUsers');
       return $meteor.subscribe('allUsers');
     }]
   };
 };

 /**
  * waitForMedia
  *
  * Returns resolvers for waiting on galleries and media
  * @returns {{mediaSubscription: *[], gallerySubscription: *[]}}
  */
 this.waitForMedia = () => {
   return {
     "mediaSubscription": ['$meteor', function ($meteor) {
       _stopIfSubscribed('media');
       return $meteor.subscribe('media');
     }],
     "gallerySubscription": ['$meteor', function ($meteor) {
       _stopIfSubscribed('galleries');
       return $meteor.subscribe('galleries');
     }]
   };
 };
}

0 个答案:

没有答案