Ag-Grid标头组件添加自定义标头模板

时间:2017-02-22 22:44:55

标签: angularjs angular-ui-bootstrap ag-grid

我仍在使用Angular 1.x和ag-Grid(非企业)。

但我正在尝试从角度ui-bootstrap中添加工具提示。所以我需要在所有标题中添加一个属性:“uib-tooltip ='headerValue'”

问题在于它要我实现一个全新的组件。但是他们在ag-grid网站上放置的示例组件非常复杂,与默认功能不同。为什么没有一种简单的方法来做这些事情?

为什么弃用headerTemplate?

所以即使我想从默认标题稍微改变一下,我基本上也需要接管所有内容的责任。我甚至没有头部组件的原始版本作为示例代码。

我只是想在标题中添加一些新的HTML,不涉及对排序,字段,菜单等负责。

1 个答案:

答案 0 :(得分:1)

我知道这已经过时了但是...我处于这种情况,我想知道为什么没有提供......我继续建造我自己的并不是非常难的。因为我认为有人可能会发现一个有用的默认标头组件:这是一个基本上是默认的

请注意,图标需要字体很棒,并确保在列选项中使用自定义组件。

    function customHeaderComponent() {
    }

    customHeaderComponent.prototype.init = function (agParams) {
        this.agParams = agParams;
        this.eGui = document.createElement('div');
        this.eGui.innerHTML = '' +
            '<span class="customHeaderLabel">' + this.agParams.displayName + '</span> ' +
            '<span class="customSortDownLabel inactive"><i class="fa fa-caret-down""></i> </span>' +
            '<span class="customSortUpLabel inactive"><i class="fa fa-caret-up""></i> </span>'+
            '<span class="customFilterLabel inactive"><i class="fa fa-filter"></i> </span>'+
            '<span class="customHeaderMenuButton"><i class="fa fa-tasks""></i></span>'
        ;

        this.eMenuButton = this.eGui.querySelector(".customHeaderMenuButton");
        this.eLabel = this.eGui.querySelector(".customHeaderLabel");
        this.eSortDownButton = this.eGui.querySelector(".customSortDownLabel");
        this.eSortUpButton = this.eGui.querySelector(".customSortUpLabel");
        this.eFilterInd = this.eGui.querySelector(".customFilterLabel");


        if (this.agParams.enableMenu) {
            this.onMenuClickListener = this.onMenuClick.bind(this);
            this.eMenuButton.addEventListener('click', this.onMenuClickListener);
        } else {
            this.eGui.removeChild(this.eMenuButton);
        }

        if (this.agParams.enableSorting) {
            this.eLabel.addEventListener('click', this.changeSort.bind(this));

            this.onSortChangedListener = this.onSortChanged.bind(this);
            this.agParams.column.addEventListener('sortChanged', this.onSortChangedListener);
            this.onSortChanged();
        }
        var self = this;
        self.eFilterInd.hidden = !self.agParams.column.isFilterActive();
        this.agParams.column.addEventListener('filterChanged', function() {
            self.eFilterInd.hidden = !self.agParams.column.isFilterActive();
        });

    };

    customHeaderComponent.prototype.changeSort = function (event) {
        this.agParams.progressSort(event);
    }


    customHeaderComponent.prototype.onSortChanged = function () {
        function deactivate(toDeactivateItems) {
            toDeactivateItems.forEach(function (toDeactivate) {
                toDeactivate.hidden = true;
            });
        }

        function activate(toActivate) {
            toActivate.hidden = false;
        }

        if (this.agParams.column.isSortAscending()) {
            deactivate([this.eSortUpButton]);
            activate(this.eSortDownButton)
        } else if (this.agParams.column.isSortDescending()) {
            deactivate([this.eSortDownButton]);
            activate(this.eSortUpButton)
        } else {
            deactivate([this.eSortUpButton, this.eSortDownButton]);
        }
    };

    customHeaderComponent.prototype.getGui = function () {
        return this.eGui;
    };

    customHeaderComponent.prototype.onMenuClick = function () {
        this.agParams.showColumnMenu(this.eMenuButton);
    };

    customHeaderComponent.prototype.onSortRequested = function (order, event) {
        this.agParams.setSort(order, event.shiftKey);
    };

    customHeaderComponent.prototype.destroy = function () {
        if (this.onMenuClickListener) {
            this.eMenuButton.removeEventListener('click', this.onMenuClickListener)
        }
    };