|
33 | 33 | dynSrc: '=?',
|
34 | 34 | dynIcon: '=?',
|
35 | 35 | size: '@?',
|
36 |
| - icon: '@' |
| 36 | + icon: '@', |
| 37 | + iconDir: '@?' |
37 | 38 | },
|
38 | 39 | compile: compile
|
39 | 40 | };
|
40 | 41 |
|
41 | 42 | return directive;
|
42 | 43 |
|
43 | 44 | function compile() {
|
44 |
| - var contents, assetPath = 'assets/img/iconic/'; |
| 45 | + var contents, assetPath; |
45 | 46 |
|
46 | 47 | return {
|
47 | 48 | pre: preLink,
|
48 | 49 | post: postLink
|
49 | 50 | };
|
50 | 51 |
|
51 |
| - function preLink(scope, iElement, iAttrs, ctrl, transclude) { |
| 52 | + function preLink(scope, element, attrs, ctrl, transclude) { |
| 53 | + if (scope.iconDir) { |
| 54 | + // make sure ends with / |
| 55 | + assetPath = scope.iconDir; |
| 56 | + if (assetPath.charAt(assetPath.length - 1) !== '/') { |
| 57 | + assetPath += '/'; |
| 58 | + } |
| 59 | + } else { |
| 60 | + // default path |
| 61 | + assetPath = 'assets/img/iconic/'; |
| 62 | + } |
| 63 | + |
52 | 64 | if(scope.dynSrc) {
|
53 |
| - iAttrs.$set('data-src', scope.dynSrc); |
| 65 | + attrs.$set('data-src', scope.dynSrc); |
54 | 66 | } else if(scope.dynIcon) {
|
55 |
| - iAttrs.$set('data-src', assetPath + scope.dynIcon + '.svg'); |
| 67 | + attrs.$set('data-src', assetPath + scope.dynIcon + '.svg'); |
56 | 68 | } else {
|
57 | 69 | if (scope.icon) {
|
58 |
| - iAttrs.$set('data-src', assetPath + scope.icon + '.svg'); |
| 70 | + attrs.$set('data-src', assetPath + scope.icon + '.svg'); |
59 | 71 | } else {
|
60 | 72 | // To support expressions on data-src
|
61 |
| - iAttrs.$set('data-src', iAttrs.src); |
| 73 | + attrs.$set('data-src', attrs.src); |
62 | 74 | }
|
63 | 75 | }
|
64 | 76 |
|
65 |
| - var iconicClass; |
66 |
| - switch (scope.size) { |
67 |
| - case 'small': |
68 |
| - iconicClass = 'iconic-sm' |
69 |
| - break; |
70 |
| - case 'medium': |
71 |
| - iconicClass = 'iconic-md' |
72 |
| - break; |
73 |
| - case 'large': |
74 |
| - iconicClass = 'iconic-lg' |
75 |
| - break; |
76 |
| - default: |
77 |
| - iconicClass = 'iconic-fluid' |
| 77 | + // check if size already added as class |
| 78 | + if (!element.hasClass('iconic-sm') && |
| 79 | + !element.hasClass('iconic-md') && |
| 80 | + !element.hasClass('iconic-lg')) { |
| 81 | + var iconicClass; |
| 82 | + switch (scope.size) { |
| 83 | + case 'small': |
| 84 | + iconicClass = 'iconic-sm' |
| 85 | + break; |
| 86 | + case 'medium': |
| 87 | + iconicClass = 'iconic-md' |
| 88 | + break; |
| 89 | + case 'large': |
| 90 | + iconicClass = 'iconic-lg' |
| 91 | + break; |
| 92 | + default: |
| 93 | + iconicClass = 'iconic-fluid' |
| 94 | + } |
| 95 | + element.addClass(iconicClass); |
78 | 96 | }
|
79 |
| - angular.element(iElement).addClass(iconicClass); |
80 | 97 |
|
81 | 98 | // save contents of un-inject html, to use for dynamic re-injection
|
82 |
| - contents = iElement[0].outerHTML; |
| 99 | + contents = element[0].outerHTML; |
83 | 100 | }
|
84 | 101 |
|
85 | 102 | function postLink(scope, element, attrs) {
|
|
91 | 108 | // only run update on current element
|
92 | 109 | ico.update(element[0]);
|
93 | 110 | });
|
94 |
| - |
95 |
| - // handle dynamic updating of icon |
| 111 | + |
| 112 | + // handle dynamic updating of src |
96 | 113 | if(scope.dynSrc) {
|
97 | 114 | scope.$watch('dynSrc', function(newVal, oldVal) {
|
98 | 115 | if (newVal && newVal != oldVal) {
|
99 | 116 | reinjectSvg(scope.dynSrc);
|
100 | 117 | }
|
101 | 118 | });
|
102 | 119 | }
|
| 120 | + // handle dynamic updating of icon |
103 | 121 | if (scope.dynIcon) {
|
104 | 122 | scope.$watch('dynIcon', function(newVal, oldVal) {
|
105 | 123 | if (newVal && newVal != oldVal) {
|
|
125 | 143 | function injectSvg(element) {
|
126 | 144 | ico.inject(element, {
|
127 | 145 | each: function(injectedElem) {
|
| 146 | + // compile injected svg |
128 | 147 | var angElem = angular.element(injectedElem);
|
129 | 148 | svgElement = $compile(angElem)(angElem.scope());
|
130 | 149 | }
|
|
0 commit comments