12

Aktualnie dodaje kilka etykiet podpowiedzi bootstrap w mojej aplikacji.Etykieta Angular-ui z kodem HTML

Wszystkie "normalne" podpowiedzi są w porządku, ale kiedy chcę użyć tooltip-html-unsafe, wszystko, co mam, to pusta podpowiedź.

Moja podpowiedź:

<a><span tooltip-placement="right" tooltip-html-safe="{{myHTMLText}}"> Help </span></a>

w DOM, mam: Zawartość

<div class="tooltip-inner" ng-bind-html-unsafe="content"></div>

div wydaje się pusta, więc nie ma nic do pokazania w dymku. Próbowałem umieścić bezpośrednio w DOM jakiś tekst HTML, taki jak:

<div class="tooltip-inner" ng-bind-html-unsafe="content"><b>test</b></div> i to działa.

Masz pomysł?

Odpowiedz

23

Dyrektywa html-unsafe ma na celu wskazanie jej treści. Co na ten temat:

Następnie w SomeCtrl, uczynić zmienną trzymać HTML:

$scope.yourContent = "<b>my html, yay</b> 

jeśli chcesz zmodyfikować bootstrap do podjęcia treści z elementu, można to zrobić lubię to. Po pierwsze, trzeba zmienić szablon podpowiedzi tak, że wywołuje funkcję, aby uzyskać HTML:

angular.module("template/tooltip/tooltip-html-unsafe-popup.html", []).run(["$templateCache", function($templateCache) { 
    $templateCache.put("template/tooltip/tooltip-html-unsafe-popup.html", 
    "<div class=\"tooltip {{placement}}\" ng-class=\"{ in: isOpen(), fade: animation() }\">\n" + 
    " <div class=\"tooltip-arrow\"></div>\n" + 
    " <div class=\"tooltip-inner\" ng-bind-html-unsafe=\"getToolTipHtml()\"></div>\n" + 
    "</div>\n" + 
    ""); 
}]); 

, następnie wykonuje funkcję łącza dla tooltipHtmlUnsafePopup:

.directive('tooltipHtmlUnsafePopup', function() { 
    return { 
    restrict: 'E', 
    replace: true, 
    scope: { content: '@', placement: '@', animation: '&', isOpen: '&' }, 
    templateUrl: 'template/tooltip/tooltip-html-unsafe-popup.html', 
    link: function(scope, element, attrs) { 
     scope.getTooltipHtml = function() { 
      var elemId = '#' + scope.content; 
      var htmlContent = $rootElement.find(elemId).html(); 
      return htmlContent; 
     }; 
    } 
    }; 
}) 

EDIT: Później wyodrębniono dostosowane kod z ui-bootstrap, co jest dobre, ponieważ nie trzeba modyfikować interfejsu ui-bootstrap, aby go teraz użyć. Oto wyodrębniony kod, w module o nazwie "bootstrapx". To jest tylko dla popover (jako że nie używałem naprawdę podpowiedzi), ale uważam, że powinno to być łatwe do adaptacji także dla podpowiedzi.

angular.module("bootstrapx", ["bootstrapx.tpls","bootstrapx.popover","bootstrapx.popover.dismisser"]); 
angular.module("bootstrapx.tpls", ["template/popover/popover-html.html","template/popover/popover-html-unsafe.html","template/popover/popover-template.html"]); 


angular.module('bootstrapx.popover', [ 'ui.bootstrap.tooltip' ]) 
    .directive('popover', [ function() { 
     return { 
      restrict: 'EA', 
      priority: -1000, 
      link: function(scope, element) { 
       element.addClass('popover-link'); 
      } 
     }; 
    }]) 
    .directive('popoverHtml', [ function() { 
     return { 
      restrict: 'EA', 
      priority: -1000, 
      link: function(scope, element) { 
       element.addClass('popover-link'); 
      } 
     }; 
    }]) 
    .directive('popoverHtmlUnsafe', [ function() { 
     return { 
      restrict: 'EA', 
      priority: -1000, 
      link: function(scope, element) { 
       element.addClass('popover-link'); 
      } 
     }; 
    }]) 
    .directive('popoverTemplate', [ function() { 
     return { 
      restrict: 'EA', 
      priority: -1000, 
      link: function(scope, element) { 
       element.addClass('popover-link'); 
      } 
     }; 
    }]) 

    .directive('popoverHtmlPopup', [ function() { 
     return { 
      restrict: 'EA', 
      replace: true, 
      scope: { title: '@', content: '@', placement: '@', animation: '&', isOpen: '&' }, 
      templateUrl: 'template/popover/popover-html.html' 
     }; 
    }]) 
    .directive('popoverHtml', [ '$compile', '$timeout', '$parse', '$window', '$tooltip', function ($compile, $timeout, $parse, $window, $tooltip) { 
     return $tooltip('popoverHtml', 'popover', 'click'); 
    }]) 

    .directive('popoverHtmlUnsafePopup', [ '$rootElement', function ($rootElement) { 
     return { 
      restrict: 'EA', 
      replace: true, 
      scope: { title: '@', content: '@', placement: '@', animation: '&', isOpen: '&' }, 
      templateUrl: 'template/popover/popover-html-unsafe.html', 
      link: function(scope, element) { 
       var htmlContent = ''; 
       scope.$watch('content', function(value) { 
        if (!value) { 
         return; 
        } 
        var elemId = '#' + value; 
        htmlContent = $rootElement.find(elemId).html(); 
       }); 

       scope.getPopoverHtml = function() { 
        return htmlContent; 
       }; 
      } 
     }; 
    }]) 
    .directive('popoverHtmlUnsafe', [ '$compile', '$timeout', '$parse', '$window', '$tooltip', function ($compile, $timeout, $parse, $window, $tooltip) { 
     return $tooltip('popoverHtmlUnsafe', 'popover', 'click'); 
    }]) 

    .directive('popoverTemplatePopup', [ '$http', '$templateCache', '$compile', '$parse', function ($http, $templateCache, $compile, $parse) { 
     return { 
      restrict: 'EA', 
      replace: true, 
      scope: { title: '@', content: '@', placement: '@', animation: '&', isOpen: '&' }, 
      templateUrl: 'template/popover/popover-template.html', 
      link: function(scope, element, attrs) { 
       scope.getPopoverTemplate = function() { 
        var templateName = scope.content + '.html'; 
        return templateName; 
       }; 
      } 
     }; 
    }]) 
    .directive('popoverTemplate', [ '$compile', '$timeout', '$parse', '$window', '$tooltip', function ($compile, $timeout, $parse, $window, $tooltip) { 
     return $tooltip('popoverTemplate', 'popover', 'click'); 
    }]); 

    angular.module("template/popover/popover-html.html", []).run(["$templateCache", function($templateCache) { 
     $templateCache.put("template/popover/popover-html.html", 
      "<div class=\"popover {{placement}}\" ng-class=\"{ in: isOpen(), fade: animation() }\">\n" + 
      " <div class=\"arrow\"></div>\n" + 
      "\n" + 
      " <div class=\"popover-inner\">\n" + 
      "  <h3 class=\"popover-title\" ng-bind=\"title\" ng-show=\"title\"></h3>\n" + 
      "  <div class=\"popover-content\" ng-bind-html=\"content\"></div>\n" + 
      " </div>\n" + 
      "</div>\n" + 
      ""); 
     }]); 

    angular.module("template/popover/popover-html-unsafe.html", []).run(["$templateCache", function($templateCache) { 
     $templateCache.put("template/popover/popover-html-unsafe.html", 
      "<div class=\"popover {{placement}}\" ng-class=\"{ in: isOpen(), fade: animation() }\">\n" + 
      " <div class=\"arrow\"></div>\n" + 
      "\n" + 
      " <div class=\"popover-inner\">\n" + 
      "  <h3 class=\"popover-title\" ng-bind=\"title\" ng-show=\"title\"></h3>\n" + 
      "  <div class=\"popover-content\" ng-bind-html-unsafe=\"{{getPopoverHtml()}}\"></div>\n" + 
      " </div>\n" + 
      "</div>\n" + 
      ""); 
    }]); 

    angular.module("template/popover/popover-template.html", []).run(["$templateCache", function($templateCache) { 
    $templateCache.put("template/popover/popover-template.html", 
      "<div class=\"popover {{placement}}\" ng-class=\"{ in: isOpen(), fade: animation() }\">\n" + 
      " <div class=\"arrow\"></div>\n" + 
      "\n" + 
      " <div class=\"popover-inner\">\n" + 
      "  <h3 class=\"popover-title\" ng-bind=\"title\" ng-show=\"title\"></h3>\n" + 
      "  <div class=\"popover-content\" ng-include=\"getPopoverTemplate()\"></div>\n" + 
      " </div>\n" + 
      "</div>\n" + 
      ""); 
    }]); 


    angular.module('bootstrapx.popover.dismisser', []) 
     .directive('dismissPopovers', [ '$http', '$templateCache', '$compile', '$parse', function ($http, $templateCache, $compile, $parse) { 
      return { 
       restrict: 'A', 
       link: function(scope, element, attrs) { 
        element.bind('mouseup', function(e) { 
         var clickedOutside = true; 
         $('.popover-link').each(function() { 
          if ($(this).is(e.target) || $(this).has(e.target).length) { 
           clickedOutside = false; 
           return false; 
          } 
         }); 
         if ($('.popover').has(e.target).length) { 
          clickedOutside = false; 
         } 
         if (clickedOutside) { 
          $('.popover').prev().click(); 
         } 
        }); 
       } 
      }; 
     }]); 

mam dyrektywę dismissPopovers na tagu ciała (jest to prawdopodobnie dotyczy podpowiedzi też będzie po prostu trzeba zmodyfikować go do własnych potrzeb):

<body data-ng-controller="AppController" data-dismiss-popovers> 
+0

Accordi do wiki kątowego-ui, to jest poprawna składnia. [http://angular-ui.github.io/bootstrap/#/tooltip](http://angular-ui.github.io/bootstrap/#/tooltip) Próbowałem twojego, to nie zadziałało. – Mencls

+0

Oh crap! Masz rację, zapomniałem, zmodyfikowałem bootstrap, aby to wspierać. Normalnie chce rzeczywistej zawartości. – aet

+0

Dzięki za odpowiedź. Gdzie muszę umieścić funkcję łącza? – Mencls

6

Stworzyłem dyrektywa zwyczaj która pozwala w prosty sposób uzyskać etykietki narzędzi html dla bootrap. Nie ma potrzeby, aby zastąpić wszystkie szablony:

angular.module('vermouthApp.htmlTooltip', [ 
]) 
.directive('vaTooltip', ['$http', '$templateCache', '$compile', '$parse', '$timeout', function ($http, $templateCache, $compile, $parse, $timeout) 
{ 
    //va-tooltip = path to template or pure tooltip string 
    //tooltip-updater = scope item to watch for changes when template has to be reloaded [optional (only if template is dynamic)] 
    //All other attributes can be added for standart boostrap tooltip behavior (ex. tooltip-placement) 
    return { 
     restrict: 'A', 
     scope: true, 
     compile: function (tElem, tAttrs) 
     { 
      //Add bootstrap directive 
      if (!tElem.attr('tooltip-html-unsafe')) 
      { 
       tElem.attr('tooltip-html-unsafe', '{{tooltip}}'); 
      } 
      return function (scope, element, attrs) 
      { 
       scope.tooltip = attrs.vaTooltip; 
       var tplUrl = $parse(scope.tooltip)(scope); 
       function loadTemplate() 
       { 
        $http.get(tplUrl, { cache: $templateCache }).success(function (tplContent) 
        { 
         var container = $('<div/>'); 
         container.html($compile(tplContent.trim())(scope)); 
         $timeout(function() 
         { 
          scope.tooltip = container.html(); 
         }); 
        }); 
       } 
       //remove our direcive to avoid infinite loop 
       element.removeAttr('va-tooltip'); 
       //compile element to attach tooltip binding 
       $compile(element)(scope); 

       if (angular.isDefined(attrs.tooltipUpdater)) 
       { 
        scope.$watch(attrs.tooltipUpdater, function() 
        { 
         loadTemplate(); 
        }); 
       } else 
       { 
        loadTemplate(); 
       } 
      }; 
     } 
    }; 
}]); 

Ów jak to nazwać

<a va-tooltip="'tooltipContent.html'" tooltip-updater="item" tooltip-placement="bottom"> 
       <b><i>{{item.properties.length - propertyShowLimit + ' properties more...'}}</i></b> 
      </a> 

I matrycy może być tak:

<script id="tooltipContent.html" type="text/ng-template"> 
    <span ng-repeat="prop in item.properties> 
     <b>{{prop.name}}</b>: 
     <span ng-repeat="val in prop.values">{{val.value}}&nbsp;</span> 
     <br /> 
    </span> 
</script> 
+0

nie zadziałał dla mnie, ale był to świetny pomysł;). – botero

4

Obecnie buit w funkcjonalności szablonu: https://angular-ui.github.io/bootstrap/#tooltip

<a href="#" uib-tooltip-template="'myTooltipTemplate.html'">Custom template</a> 

<script type="text/ng-template" id="myTooltipTemplate.html"> 
    <span>Special Tooltip with <strong>markup</strong> and {{ dynamicTooltipText }}</span> 
</script>