Code coverage report for app/views/common/buttons/button_progress_view.js

Statements: 13.04% (3 / 23)      Branches: 0% (0 / 20)      Functions: 33.33% (1 / 3)      Lines: 13.04% (3 / 23)      Ignored: none     

All files » app/views/common/buttons/ » button_progress_view.js
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81    1                                     1   1                                                                                                                  
'use strict';
 
;require.register("views/common/buttons/button_progress_view", function (exports, require, module) {
  /**
   * Licensed to the Apache Software Foundation (ASF) under one
   * or more contributor license agreements.  See the NOTICE file
   * distributed with this work for additional information
   * regarding copyright ownership.  The ASF licenses this file
   * to you under the Apache License, Version 2.0 (the
   * "License"); you may not use this file except in compliance
   * with the License.  You may obtain a copy of the License at
   *
   *     http://www.apache.org/licenses/LICENSE-2.0
   *
   * Unless required by applicable law or agreed to in writing, software
   * distributed under the License is distributed on an "AS IS" BASIS,
   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
   * See the License for the specific language governing permissions and
   * limitations under the License.
   */
 
  var App = require('app');
 
  App.ButtonProgressView = Em.View.extend(Em.TargetActionSupport, {
    layoutName: require('templates/common/button_progress'),
    isDisabled: Em.computed.or('disabled', 'isInProgress'),
    /**
     * Target to perform `onClick` function default to App.router
     * @type {Em.Object|Em.View|Em.Controller}
     */
    target: null,
    /**
     * Property determines progress state
     * @type {Boolean}
     */
    isInProgress: null,
    /**
     * on click handler
     * @type {Function}
     */
    action: null,
    /**
     * When true spinner appears to right side, when false - to left
     * @type {Boolean}
     */
    doSpinRight: true,
 
    targetObject: function () {
      var target = this.get('target'),
          splitted;
      if (!target) {
        return this.get('controller.target');
      } else if (typeof target === 'string') {
        splitted = target.split('.');
        if (splitted[0] === 'view') {
          splitted = ['parentView'].concat(splitted.slice(1));
        }
        return Em.get(this, splitted.join('.'));
      } else {
        return target;
      }
    }.property('target'),
 
    handleClick: function handleClick() {
      if (this.get('isDisabled')) {
        return;
      }
      var target = this.get('targetObject');
      var targetMethod = this.get('action');
      if (target.isState && typeof target.send === 'function') {
        target.send(targetMethod);
      } else if (targetMethod && typeof targetMethod === 'function') {
        targetMethod.apply(target);
      } else if (typeof targetMethod === 'string' && typeof Em.get(target, targetMethod) === 'function') {
        Em.get(target, targetMethod).call(target);
      } else {
        Ember.Logger.error('Cannot invoke action %s on target %s', targetMethod, target);
      }
    }
  });
});