summaryrefslogtreecommitdiffstats
path: root/ecomp-portal-FE-common/client/app/directives/right-click-menu/right-click-menu.directive.js
diff options
context:
space:
mode:
Diffstat (limited to 'ecomp-portal-FE-common/client/app/directives/right-click-menu/right-click-menu.directive.js')
-rw-r--r--ecomp-portal-FE-common/client/app/directives/right-click-menu/right-click-menu.directive.js41
1 files changed, 41 insertions, 0 deletions
diff --git a/ecomp-portal-FE-common/client/app/directives/right-click-menu/right-click-menu.directive.js b/ecomp-portal-FE-common/client/app/directives/right-click-menu/right-click-menu.directive.js
new file mode 100644
index 00000000..ff339322
--- /dev/null
+++ b/ecomp-portal-FE-common/client/app/directives/right-click-menu/right-click-menu.directive.js
@@ -0,0 +1,41 @@
+/*-
+ * ================================================================================
+ * eCOMP Portal
+ * ================================================================================
+ * Copyright (C) 2017 AT&T Intellectual Property
+ * ================================================================================
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ================================================================================
+ */
+'use strict';
+angular.module('ecompApp').directive( 'contextMenu', function($compile){
+ contextMenu = {};
+ contextMenu.restrict = 'AE';
+ contextMenu.link = function( lScope, lElem, lAttr ){
+ lElem.on('contextmenu', function (e) {
+ e.preventDefault(); // default context menu is disabled
+ // The customized context menu is defined in the main controller. To function the ng-click functions the, contextmenu HTML should be compiled.
+ lElem.append( $compile( lScope[ lAttr.contextMenu ])(lScope) );
+ // The location of the context menu is defined on the click position and the click position is catched by the right click event.
+ $('#contextmenu-node').css('left', e.clientX);
+ $('#contextmenu-node').css('top', e.clientY);
+ });
+ lElem.on('mouseleave', function(e){
+ console.log('Leaved the div');
+ // on mouse leave, the context menu is removed.
+ if($('#contextmenu-node') )
+ $('#contextmenu-node').remove();
+ });
+ };
+ return contextMenu;
+}); \ No newline at end of file