mirror of
				https://github.com/grafana/grafana.git
				synced 2025-02-25 18:55:37 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			69 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import _ from 'lodash';
 | |
| import coreModule from 'app/core/core_module';
 | |
| // @ts-ignore
 | |
| import Drop from 'tether-drop';
 | |
| 
 | |
| export function infoPopover() {
 | |
|   return {
 | |
|     restrict: 'E',
 | |
|     template: '<i class="fa fa-info-circle"></i>',
 | |
|     transclude: true,
 | |
|     link: (scope: any, elem: any, attrs: any, ctrl: any, transclude: any) => {
 | |
|       const offset = attrs.offset || '0 -10px';
 | |
|       const position = attrs.position || 'right middle';
 | |
|       let classes = 'drop-help drop-hide-out-of-bounds';
 | |
|       const openOn = 'hover';
 | |
| 
 | |
|       elem.addClass('gf-form-help-icon');
 | |
| 
 | |
|       if (attrs.wide) {
 | |
|         classes += ' drop-wide';
 | |
|       }
 | |
| 
 | |
|       if (attrs.mode) {
 | |
|         elem.addClass('gf-form-help-icon--' + attrs.mode);
 | |
|       }
 | |
| 
 | |
|       transclude((clone: any, newScope: any) => {
 | |
|         const content = document.createElement('div');
 | |
|         content.className = 'markdown-html';
 | |
| 
 | |
|         _.each(clone, node => {
 | |
|           content.appendChild(node);
 | |
|         });
 | |
| 
 | |
|         const dropOptions = {
 | |
|           target: elem[0],
 | |
|           content: content,
 | |
|           position: position,
 | |
|           classes: classes,
 | |
|           openOn: openOn,
 | |
|           hoverOpenDelay: 400,
 | |
|           tetherOptions: {
 | |
|             offset: offset,
 | |
|             constraints: [
 | |
|               {
 | |
|                 to: 'window',
 | |
|                 attachment: 'together',
 | |
|                 pin: true,
 | |
|               },
 | |
|             ],
 | |
|           },
 | |
|         };
 | |
| 
 | |
|         // Create drop in next digest after directive content is rendered.
 | |
|         scope.$applyAsync(() => {
 | |
|           const drop = new Drop(dropOptions);
 | |
| 
 | |
|           const unbind = scope.$on('$destroy', () => {
 | |
|             drop.destroy();
 | |
|             unbind();
 | |
|           });
 | |
|         });
 | |
|       });
 | |
|     },
 | |
|   };
 | |
| }
 | |
| 
 | |
| coreModule.directive('infoPopover', infoPopover);
 |