4 angular.module('foundation.accordion', [])
5 .controller('ZfAccordionController', zfAccordionController)
6 .directive('zfAccordion', zfAccordion)
7 .directive('zfAccordionItem', zfAccordionItem)
10 zfAccordionController.$inject = ['$scope'];
12 function zfAccordionController($scope) {
13 var controller = this;
14 var sections = controller.sections = $scope.sections = [];
15 var multiOpen = controller.multiOpen = $scope.multiOpen = $scope.multiOpen || false;
16 var collapsible = controller.collapsible = $scope.collapsible = $scope.multiOpen || $scope.collapsible || true; //multi open infers a collapsible true
17 var autoOpen = controller.autoOpen = $scope.autoOpen = $scope.autoOpen || true; //auto open opens first tab on render
19 controller.select = function(selectSection) {
20 sections.forEach(function(section) {
21 //if multi open is allowed, toggle a tab
22 if(controller.multiOpen) {
23 if(section.scope === selectSection) {
24 section.scope.active = !section.scope.active;
27 //non multi open will close all tabs and open one
28 if(section.scope === selectSection) {
29 //if collapsible is allowed, a tab will toggle
30 section.scope.active = collapsible ? !section.scope.active : true;
32 section.scope.active = false;
39 controller.addSection = function addsection(sectionScope) {
40 sections.push({ scope: sectionScope });
42 if(sections.length === 1 && autoOpen === true) {
43 sections[0].active = true;
44 sections[0].scope.active = true;
48 controller.closeAll = function() {
49 sections.forEach(function(section) {
50 section.scope.active = false;
55 function zfAccordion() {
60 templateUrl: 'components/accordion/accordion.html',
61 controller: 'ZfAccordionController',
72 function link(scope, element, attrs, controller) {
73 scope.multiOpen = controller.multiOpen = scope.multiOpen === "true" ? true : false;
74 scope.collapsible = controller.collapsible = scope.collapsible === "true" ? true : false;
75 scope.autoOpen = controller.autoOpen = scope.autoOpen === "true" ? true : false;
80 function zfAccordionItem() {
83 templateUrl: 'components/accordion/accordion-item.html',
88 require: '^zfAccordion',
90 controller: function() {},
96 function link(scope, element, attrs, controller, transclude) {
98 controller.addSection(scope);
100 scope.activate = function() {
101 controller.select(scope);