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.

questionAnswers(2)

yourAnswerToTheQuestion