forked from ClickerMonkey/SemanticUI-Angular
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsm-modal.js
114 lines (94 loc) · 2.72 KB
/
sm-modal.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
(function(app)
{
app
.factory('SemanticModalLink', ['SemanticUI', SemanticModalLink])
.directive('smModalBind', ['SemanticUI', SemanticModalBind])
.directive('smModal', ['SemanticModalLink', SemanticModal])
;
var BEHAVIORS = {
smModalShow: 'show',
smModalHide: 'hide',
smModalToggle: 'toggle',
smModalRefresh: 'refresh',
smModalShowDimmer: 'show dimmer',
smModalHideDimmer: 'hide dimmer',
smModalHideOthers: 'hide others',
smModalHideAll: 'hide all',
smModalCacheSizes: 'cache sizes',
smModalSetActive: 'set active'
};
angular.forEach( BEHAVIORS, function(method, directive)
{
app.directive( directive, ['SemanticUI', function(SemanticUI)
{
return SemanticUI.createBehavior( directive, 'modal', method );
}]);
});
function SemanticModalBind(SemanticUI)
{
return SemanticUI.createBind( 'smModalBind', 'modal' );
}
function SemanticModal(SemanticModalLink)
{
return {
restrict: 'E',
replace: true,
transclude: true,
scope: {
/* Optional */
visible: '=',
settings: '=',
onInit: '=',
/* Events */
onShow: '=',
onVisible: '=',
onHide: '=',
onHidden: '=',
onApprove: '=',
onDeny: '='
},
template: '<div class="ui modal" ng-transclude></div>',
link: SemanticModalLink
}
}
function SemanticModalLink(SemanticUI)
{
return function(scope, element, attributes)
{
var settings = scope.settings || {};
SemanticUI.linkSettings( scope, element, attributes, 'modal' );
// If the visible attribute is specified, listen to onHide and update modal when variable changes.
if ( attributes.visible )
{
var visibleWatcher = SemanticUI.watcher( scope, 'visible',
function(updated) {
element.modal( updated ? 'show' : 'hide' );
}
);
SemanticUI.onEvent( settings, 'onHide',
function() {
visibleWatcher.set( false );
}
);
SemanticUI.onEvent( settings, 'onShow',
function() {
visibleWatcher.set( true );
}
);
}
SemanticUI.linkEvents( scope, settings, $.fn.modal.settings, {
onShow: 'onShow',
onVisible: 'onVisible',
onHide: 'onHide',
onHidden: 'onHidden',
onApprove: 'onApprove',
onDeny: 'onDeny'
});
// Initialize the element with the given settings.
element.modal( settings );
if ( angular.isFunction( scope.onInit ) ) {
scope.onInit( element );
}
};
}
})( angular.module('semantic-ui-modal', ['semantic-ui-core']) );