angular-tribute
Version:
An AngularJS wrapper for ZURB's Tribute library for native @mentions
54 lines (45 loc) • 1.46 kB
JavaScript
'use strict';
function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; }
var Tribute = _interopDefault(require('tributejs/src'));
if (typeof Tribute === 'undefined') {
throw new Error('[AngularTribute] cannot locate tributejs!');
}
var AngularTribute = function AngularTribute($timeout) {
return {
restrict: 'A',
scope: {
values: '=',
options: '=',
onReplaced: '&',
onNoMatch: '&'
},
controller: function controller($scope) {
this.$onDestroy = function () {
$scope.tribute.hideMenu();
};
},
compile: function compile($element, $attrs) {
var _this = this;
return function ($scope, $element, $attrs) {
if (typeof $scope.options === 'array') {
$scope.tribute = new Tribute({
collection: $scope.options
});
} else {
$scope.tribute = new Tribute(angular.merge({
values: $scope.values
}, $scope.options || {}));
}
$scope.tribute.attach($element[0]);
$element[0].addEventListener("tribute-replaced", function (e) {
$timeout($scope.onReplaced.apply(_this));
});
$element[0].addEventListener("tribute-no-match", function (e) {
$timeout($scope.onReplaced.apply(_this));
});
};
}
};
};
AngularTribute.$inject = ['$timeout'];
module.exports = AngularTribute;