0

我想更新ui-grid中的editableCellTemplate以包含ui-datepicker,所以我将允许用户有可能使用firefox或IE选择日期,但没有成功。 这里是plunker与我正在尝试做什么,使用editableCellTemplate: '<div style="display:inline-block; min-height:290px; position:absolute;"><div uib-datepicker class="well well-sm" datepicker-options="dateOptions" ng-focus="open()" style="background-color: #f5f5f5; border: 1px solid #e3e3e3; border-radius: 0; padding: 8px;" >'ui-datepicker与用户界面问题

+0

看看这个plunker:http://plnkr.co/edit/4mNr86cN6wFOLYQ02QND?p=preview – Yaser

+0

@Yaser非常感谢您为这次更新所做的很多,但是您是否知道在这种情况下如何处理日历选项?我的意思是如果我想改变最小和最大日期,你有什么想法吗? '$ scope.dateOptions = { formatYear:'yy', maxDate:new Date(2020,5,22), minDate:new Date(), startingDay:1 };' – Med

回答

2

这里是一个示例与具有所有细节和选项的ui-datepicker指令。 你可以找到在这个github linkplunker示例的详细信息,其中UI的日期选择器的指令看起来象下面这样:

var app = angular.module('ui.grid.edit'); 

app.directive('uiGridEditDatepicker', ['$timeout', '$document', 'uiGridConstants', 'uiGridEditConstants', function($timeout, $document, uiGridConstants, uiGridEditConstants) { 
return { 
    template: function(element, attrs) {  
     var html = '<div class="datepicker-wrapper" ><input type="text" uib-datepicker-popup datepicker-options="datepickerOptions" datepicker-append-to-body="true" is-open="isOpen" ng-model="datePickerValue" ng-change="changeDate($event)" popup-placement="auto top"/></div>'; 
     return html; 
    }, 
    require: ['?^uiGrid', '?^uiGridRenderContainer'], 
    scope: true, 
    compile: function() { 
     return { 
      pre: function($scope, $elm, $attrs) { 
       if ($attrs.datepickerOptions){ 
        if ($scope.col.grid.appScope[$attrs.datepickerOptions]){ 
         $scope.datepickerOptions = $scope.col.grid.appScope[$attrs.datepickerOptions]; 
        } 
       } 
      }, 
      post: function($scope, $elm, $attrs, controllers) { 
       var setCorrectPosition = function() { 
        var gridElement = $('.ui-grid-viewport'); 
        var gridPosition = { 
         width: gridElement.outerWidth(), 
         height: gridElement.outerHeight(), 
         offset: gridElement.offset() 
        }; 

        var cellElement = $($elm); 
        var cellPosition = { 
         width: cellElement.outerWidth(), 
         height: cellElement.outerHeight(), 
         offset: cellElement.offset() 
        }; 

        var datepickerElement = $('body > .dropdown-menu, body > div > .dropdown-menu'); 
        var datepickerPosition = { 
         width: datepickerElement.outerWidth(), 
         height: datepickerElement.outerHeight() 
        }; 

        var setCorrectTopPositionInGrid = function() { 
         var topPosition; 
         var freePixelsOnBottom = gridPosition.height - (cellPosition.offset.top - gridPosition.offset.top) - cellPosition.height; 
         var freePixelsOnTop = gridPosition.height - freePixelsOnBottom - cellPosition.height; 
         var requiredPixels = (datepickerPosition.height - cellPosition.height)/2; 
         if (freePixelsOnBottom >= requiredPixels && freePixelsOnTop >= requiredPixels) { 
          topPosition = cellPosition.offset.top - requiredPixels + 10; 
         } else if (freePixelsOnBottom >= requiredPixels && freePixelsOnTop < requiredPixels) { 
          topPosition = cellPosition.offset.top - freePixelsOnTop + 10; 
         } else { 
          topPosition = gridPosition.height - datepickerPosition.height + gridPosition.offset.top - 20; 
         } 
         return topPosition; 
        }; 

        var setCorrectTopPositionInWindow = function() { 
         var topPosition; 
         var windowHeight = window.innerHeight - 10; 

         var freePixelsOnBottom = windowHeight - cellPosition.offset.top; 
         var freePixelsOnTop = windowHeight - freePixelsOnBottom - cellPosition.height; 
         var requiredPixels = (datepickerPosition.height - cellPosition.height)/2; 
         if (freePixelsOnBottom >= requiredPixels && freePixelsOnTop >= requiredPixels) { 
          topPosition = cellPosition.offset.top - requiredPixels; 
         } else if (freePixelsOnBottom >= requiredPixels && freePixelsOnTop < requiredPixels) { 
          topPosition = cellPosition.offset.top - freePixelsOnTop; 
         } else { 
          topPosition = windowHeight - datepickerPosition.height - 10; 
         } 
         return topPosition; 
        }; 


        var newOffsetValues = {}; 

        var isFreeOnRight = (gridPosition.width - (cellPosition.offset.left - gridPosition.offset.left) - cellPosition.width) > datepickerPosition.width; 
        if (isFreeOnRight) { 
         newOffsetValues.left = cellPosition.offset.left + cellPosition.width; 
        } else { 
         newOffsetValues.left = cellPosition.offset.left - datepickerPosition.width; 
        } 

        if (datepickerPosition.height < gridPosition.height) { 
         newOffsetValues.top = setCorrectTopPositionInGrid(); 
        } else { 
         newOffsetValues.top = setCorrectTopPositionInWindow(); 
        } 

        datepickerElement.offset(newOffsetValues); 
        datepickerElement.css("visibility", "visible"); 
       }; 

       $timeout(function() { 
        setCorrectPosition(); 
       }, 0); 



       $scope.datePickerValue = new Date($scope.row.entity[$scope.col.field]); 
       $scope.isOpen = true; 
       var uiGridCtrl = controllers[0]; 
       var renderContainerCtrl = controllers[1]; 

       var onWindowClick = function (evt) { 
        var classNamed = angular.element(evt.target).attr('class'); 
        if (classNamed) { 
         var inDatepicker = (classNamed.indexOf('datepicker-calendar') > -1); 
         if (!inDatepicker && evt.target.nodeName !== "INPUT") { 
          $scope.stopEdit(evt); 
         } 
        } 
        else { 
         $scope.stopEdit(evt); 
        } 
       }; 

       var onCellClick = function (evt) { 
        angular.element(document.querySelectorAll('.ui-grid-cell-contents')).off('click', onCellClick); 
        $scope.stopEdit(evt); 
       }; 

       $scope.changeDate = function (evt) { 
        $scope.row.entity[$scope.col.field] = $scope.datePickerValue; 
        $scope.stopEdit(evt); 
       }; 

       $scope.$on(uiGridEditConstants.events.BEGIN_CELL_EDIT, function() { 
        if (uiGridCtrl.grid.api.cellNav) { 
         uiGridCtrl.grid.api.cellNav.on.navigate($scope, function (newRowCol, oldRowCol) { 
          $scope.stopEdit(); 
         }); 
        } else { 
         angular.element(document.querySelectorAll('.ui-grid-cell-contents')).on('click', onCellClick); 
        } 
        angular.element(window).on('click', onWindowClick); 
       }); 

       $scope.$on('$destroy', function() { 
        angular.element(window).off('click', onWindowClick); 
        $('body > .dropdown-menu, body > div > .dropdown-menu').remove(); 
       }); 

       $scope.stopEdit = function(evt) { 
        $scope.$emit(uiGridEditConstants.events.END_CELL_EDIT); 
       }; 

       $elm.on('keydown', function(evt) { 
        switch (evt.keyCode) { 
         case uiGridConstants.keymap.ESC: 
          evt.stopPropagation(); 
          $scope.$emit(uiGridEditConstants.events.CANCEL_CELL_EDIT); 
          break; 
        } 
        if (uiGridCtrl && uiGridCtrl.grid.api.cellNav) { 
         evt.uiGridTargetRenderContainerId = renderContainerCtrl.containerId; 
         if (uiGridCtrl.cellNav.handleKeyDown(evt) !== null) { 
          $scope.stopEdit(evt); 
         } 
        } else { 
         switch (evt.keyCode) { 
          case uiGridConstants.keymap.ENTER: 
          case uiGridConstants.keymap.TAB: 
           evt.stopPropagation(); 
           evt.preventDefault(); 
           $scope.stopEdit(evt); 
           break; 
         } 
        } 
        return true; 
       }); 
      } 
     }; 
    } 
}; 
}]);