Transcluindo ng-click em uma diretiva
Estou construindo uma diretiva AngularJS. Eu quero que essa diretiva envolva outros conteúdos que tenham um ng-clique dentro dela. O botão resultante não faz nada quando clicado. Aqui está uma versão simplificada do código que eu tentei:
(HTML)
<div ng-app="someapp">
<div ng-controller="Ctrl1">
<h2>Example</h2>
<my-dir data-x="1">
<button ng-click="refresh()" id="refresh1">Refresh</button>
</my-dir>
<my-dir data-x="2">
<button ng-click="refresh()" id="refresh2">Refresh</button>
</my-dir>
</div>
</div>
(JavaScript)
var app = angular.module('someapp', []);
app.controller('Ctrl1', function($scope){ });
app.directive('myDir', function(){
return {
restrict: 'E',
scope: {},
template: '<div><p>Directive contents:</p><div ng-transclude></div></div>',
transclude: true,
link: function(scope, element, attrs){
$scope.y = attrs.x+1;
scope.refresh = function(){
console.log("Refresh Called, y = ", $scope.y);
}
}
};
});
Como posso alterá-lo para que o botão realmente ative a função $ scope.refresh ()?
Esclarecimento extra:
Preciso de informações sobre objetos locais para a diretiva (pode haver várias dessa diretiva no controlador único), portanto, crio um novo escopo.