2016-12-20 7 views
0

btorfs multiselectでプレースホルダを追加する方法を教えてくださいAngular js?btorfsを追加する方法multiselectプレースホルダデフォルトのテキストを変更する国を選択するために選択しますか?

マイコーディング。

<multiselectdrop ng-model="blogadd.country" options="countryList" display-prop="country_name" search-limit="countryListCount" id-prop="country_name" show-select-all="true" show-unselect-all="true" name="country" header-text="Select Stuff1" required ng-change="check_blogcountry(blogadd.country)"> 
          </multiselectdrop> 

、以下のようなエラーが発生しましたアムは、ヘッダーテキストをチェックし、私は、ヘッダの手段を追加すると、それは、動作しないのヘッダ

multiselect] asking for template on: <header got error like these 

(function() { 
'use strict'; 

    var multiselect = angular.module('btorfs.multiselect',  ['btorfs.multiselect.templates']); 

multiselect.getRecursiveProperty = function (object, path) { 
    return path.split('.').reduce(function (object, x) { 
     if (object) { 
      return object[x]; 
     } else { 
      return null; 
     } 
    }, object) 
}; 

    multiselect.directive('multiselectdrop', ['$filter', '$document', '$log', '$interval', function ($filter, $document, $log, $interval) { 
    return { 
     restrict: 'AE', 
     scope: { 
      options: '=', 
      displayProp: '@', 
      idProp: '@', 
      searchLimit: '=?', 
      selectionLimit: '=?', 
      showSelectAll: '=?', 
      showUnselectAll: '=?', 
      showSearch: '=?', 
      searchFilter: '=?', 
      disabled: '=?ngDisabled' 
     }, 
      require: 'ngModel', 
     templateUrl: 'multiselect.html', 
     link: function ($scope, $element, $attrs, $ngModelCtrl) { 
      $scope.selectionLimit = $scope.selectionLimit || 0; 
      $scope.searchLimit = $scope.searchLimit ; 

      $scope.searchFilter = ''; 

      if (typeof $attrs.disabled != 'undefined') { 
       $scope.disabled = true; 
      } 

      $scope.toggleDropdown = function() { 
       $scope.open = !$scope.open; 
      }; 

      var closeHandler = function (event) { 
       if (!$element[0].contains(event.target)) { 
        $scope.$apply(function() { 
         $scope.open = false; 
        }); 
       } 
      }; 

      $document.on('click', closeHandler); 

      var updateSelectionLists = function() { 
       if (!$ngModelCtrl.$viewValue) { 
        if ($scope.selectedOptions) { 
         $scope.selectedOptions = []; 
        } 
        $scope.unselectedOptions = angular.copy($scope.resolvedOptions); 
       } else { 
        $scope.selectedOptions = $scope.resolvedOptions.filter(function (el) { 
         var id = $scope.getId(el); 
         for (var i = 0; i < $ngModelCtrl.$viewValue.length; i++) { 
          var selectedId = $scope.getId($ngModelCtrl.$viewValue[i]); 
          if (id === selectedId) { 
           return true; 
          } 
         } 
         return false; 
        }); 
        $scope.unselectedOptions = $scope.resolvedOptions.filter(function (el) { 
         return $scope.selectedOptions.indexOf(el) < 0; 
        }); 
       } 
      }; 

      $ngModelCtrl.$render = function() { 
       updateSelectionLists(); 
      }; 

      $ngModelCtrl.$viewChangeListeners.push(function() { 
       updateSelectionLists(); 
      }); 

      $ngModelCtrl.$isEmpty = function (value) { 
       if (value) { 
        return (value.length === 0); 
       } else { 
        return true; 
       } 
      }; 

      var watcher = $scope.$watch('selectedOptions', function() { 
       $ngModelCtrl.$setViewValue(angular.copy($scope.selectedOptions)); 
      }, true); 

      $scope.$on('$destroy', function() { 
       $document.off('click', closeHandler); 
       if (watcher) { 
        watcher(); // Clean watcher 
       } 
      }); 

      $scope.getButtonText = function() { 
       if ($scope.selectedOptions && $scope.selectedOptions.length === 1) { 
        return $scope.getDisplay($scope.selectedOptions[0]); 
       } 
       if ($scope.selectedOptions && $scope.selectedOptions.length > 1) { 
        var totalSelected; 
        totalSelected = angular.isDefined($scope.selectedOptions) ? $scope.selectedOptions.length : 0; 
        if (totalSelected === 0) { 
         return 'Select'; 
        } else { 
         return totalSelected + ' ' + 'selected'; 
        } 
       } else { 
        return 'Select'; 
       } 
      }; 

      $scope.selectAll = function() { 
       $scope.selectedOptions = $scope.resolvedOptions; 
       $scope.unselectedOptions = []; 
      }; 

      $scope.unselectAll = function() { 
       $scope.selectedOptions = []; 
       $scope.unselectedOptions = $scope.resolvedOptions; 
      }; 

      $scope.toggleItem = function (item) { 
       if (typeof $scope.selectedOptions === 'undefined') { 
        $scope.selectedOptions = []; 
       } 
       var selectedIndex = $scope.selectedOptions.indexOf(item); 
       var currentlySelected = (selectedIndex !== -1); 
       if (currentlySelected) { 
        $scope.unselectedOptions.push($scope.selectedOptions[selectedIndex]); 
        $scope.selectedOptions.splice(selectedIndex, 1); 
       } else if (!currentlySelected && ($scope.selectionLimit === 0 || $scope.selectedOptions.length < $scope.selectionLimit)) { 
        var unselectedIndex = $scope.unselectedOptions.indexOf(item); 
        $scope.unselectedOptions.splice(unselectedIndex, 1); 
        $scope.selectedOptions.push(item); 
       } 
      }; 

      $scope.getId = function (item) { 
       if (angular.isString(item)) { 
        return item; 
       } else if (angular.isObject(item)) { 
        if ($scope.idProp) { 
         return multiselect.getRecursiveProperty(item, $scope.idProp); 
        } else { 
         $log.error('Multiselect: when using objects as model, a idProp value is mandatory.'); 
         return ''; 
        } 
       } else { 
        return item; 
       } 
      }; 

      $scope.getDisplay = function (item) { 
       if (angular.isString(item)) { 
        return item; 
       } else if (angular.isObject(item)) { 
        if ($scope.displayProp) { 
         return multiselect.getRecursiveProperty(item, $scope.displayProp); 
        } else { 
         $log.error('Multiselect: when using objects as model, a displayProp value is mandatory.'); 
         return ''; 
        } 
       } else { 
        return item; 
       } 
      }; 

      $scope.isSelected = function (item) { 
       if (!$scope.selectedOptions) { 
        return false; 
       } 
       var itemId = $scope.getId(item); 
       for (var i = 0; i < $scope.selectedOptions.length; i++) { 
        var selectedElement = $scope.selectedOptions[i]; 
        if ($scope.getId(selectedElement) === itemId) { 
         return true; 
        } 
       } 
       return false; 
      }; 

      $scope.updateOptions = function() { 
       if (typeof $scope.options === 'function') { 
        $scope.options().then(function (resolvedOptions) { 
         $scope.resolvedOptions = resolvedOptions; 
         updateSelectionLists(); 
        }); 
       } 
      }; 

      // This search function is optimized to take into account the search limit. 
      // Using angular limitTo filter is not efficient for big lists, because it still runs the search for 
      // all elements, even if the limit is reached 
      $scope.search = function() { 
       var counter = 0; 
       return function (item) { 
        if (counter > $scope.searchLimit) { 
         return false; 
        } 
        var displayName = $scope.getDisplay(item); 
        if (displayName) { 
         var result = displayName.toLowerCase().indexOf($scope.searchFilter.toLowerCase()) > -1; 
         if (result) { 
          counter++; 
         } 
         return result; 
        } 
       } 
      }; 


      $interval(function(){ 
       $scope.resolvedOptions = $scope.options; 
       updateSelectionLists(); 
      },2000); 

      $scope.resolvedOptions = []; 
      if (typeof $scope.options !== 'function') { 
       $scope.resolvedOptions = $scope.options; 
      } else { 
       $scope.updateOptions(); 
      } 

     } 
    }; 
}]); 

}());

angular.module('btorfs.multiselect.templates', ['multiselect.html']); 

angular.module("multiselect.html", []).run(["$templateCache",  function($templateCache) { 
$templateCache.put("multiselect.html", 
"<div class=\"btn-group\" style=\"width: 100%\">\n" + 
" <button type=\"button\" class=\"form-control btn btn-default btn-block dropdown-toggle\" ng-click=\"toggleDropdown()\" ng-disabled=\"disabled\">\n" + 
"  {{getButtonText()}}&nbsp;<span class=\"caret\"></span>\n" + 
" </button>\n" + 
" <ul class=\"dropdown-menu dropdown-menu-form\"\n" + 
"  ng-style=\"{display: open ? 'block' : 'none'}\" style=\"width: 100%; overflow-x: auto\">\n" + 
"\n" + 
"  <li ng-show=\"showSelectAll\">\n" + 
"   <a ng-click=\"selectAll()\" href=\"\">\n" + 
"    <span class=\"glyphicon glyphicon-ok\"></span> Select All\n" + 
"   </a>\n" + 
"  </li>\n" + 
"  <li ng-show=\"showUnselectAll\">\n" + 
"   <a ng-click=\"unselectAll()\" href=\"\">\n" + 
"    <span class=\"glyphicon glyphicon-remove\"></span> Unselect All\n" + 
"   </a>\n" + 
"  </li>\n" + 
"  <li ng-show=\"(showSelectAll || showUnselectAll)\"\n" + 
"   class=\"divider\">\n" + 
"  </li>\n" + 
"\n" + 
"  <li role=\"presentation\" ng-repeat=\"option in selectedOptions\" class=\"active\">\n" + 
"   <a class=\"item-selected\" href=\"\" ng-click=\"toggleItem(option); $event.stopPropagation()\">\n" + 
"    <span class=\"glyphicon glyphicon-remove\"></span>\n" + 
"    {{getDisplay(option)}}\n" + 
"   </a>\n" + 
"  </li>\n" + 
"  <li ng-show=\"selectedOptions.length > 0\" class=\"divider\"></li>\n" + 
"\n" + 
"  <li ng-show=\"showSearch\">\n" + 
"   <div class=\"dropdown-header\">\n" + 
"    <input type=\"text\" class=\"form-control input-sm\" style=\"width: 100%;\"\n" + 
"      ng-model=\"searchFilter\" placeholder=\"Search...\" ng-change=\"updateOptions()\"/>\n" + 
"   </div>\n" + 
"  </li>\n" + 
"\n" + 
"  <li ng-show=\"showSearch\" class=\"divider\"></li>\n" + 
"  <li role=\"presentation\" ng-repeat=\"option in unselectedOptions | filter:search() | limitTo: searchLimit\"\n" + 
"   ng-if=\"!isSelected(option)\"\n" + 
"   ng-class=\"{disabled : selectionLimit && selectedOptions.length >= selectionLimit}\">\n" + 
"   <a class=\"item-unselected\" href=\"\" ng-click=\"toggleItem(option); $event.stopPropagation()\">\n" + 
"    {{getDisplay(option)}}\n" + 
"   </a>\n" + 
"  </li>\n" + 
"\n" + 
"  <li class=\"divider\" ng-show=\"selectionLimit > 1\"></li>\n" + 
"  <li role=\"presentation\" ng-show=\"selectionLimit > 1\">\n" + 
"   <a>{{selectedOptions.length || 0}}/{{selectionLimit}} selected</a>\n" + 
"  </li>\n" + 
"\n" + 
" </ul>\n" + 
"</div>"); 

}]);私のディレクティブコーディングを添付

は、ユーザーいったんプレースホルダを追加する方法を私に解決策を教えてください割り当てるhtmlタグでディレクティブコールのデフォルト・テキストまたは他のselectタグ

答えて

0

を与える私は、テンプレートファイルの読み込みに失敗したり、テンプレートのURLがかもしれないと思います違う。

あなたの質問は、ディレクティブコード他者と更新が簡単にあなたの応答のために...

+0

ありがとう答えることができ、プレースホルダ –

+0

を追加する方法テンプレートがなければ、私のためのテンプレートをロードする必要はありません

+0

アムを表示スクリプトsrc = "bower_components/angle-bootstrap-multiselect/dist/angel-bootstrap-multiselect.min.js">ディレクティブ –

関連する問題