Как сделать нумерацию страниц в jqGrid? - PullRequest
0 голосов
/ 01 апреля 2019

Я хочу выполнить разбиение на страницы с jqGrid, я использую массив json, который уже загружен с сервера ранее, поэтому я не делаю вызов на сервер.Я использую Jade и Angularjs.следующий код, который я использую.Jade:

 .col-md-12.grid     
        div(mp-grid="gridControlesTecnicos",
            mp-grid-pager="grid_pager_controlestecnicos",
            mp-grid-model="modDCT.grid.model",
            mp-grid-data="modDCT.grid.data",
            mp-grid-options="modDCT.grid.options")

JS код:

  /*global appModule */
"use strict";
(appModule.lazy || appModule).controller("DetalleControlesTecnicos", ["$scope", "GridControlesTecnicosSrv", "$modalInstance", "$translate", "datosModal", "$rootScope",
    function($scope, GridControlesTecnicosSrv, $modalInstance, $translate, datosModal, $rootScope) {
        var modDCT = this;
        this.paginacion = {
            pageSize: 5,
            page: 1
        };
        console.log(modDCT.paginacion.page);
        datosModal = datosModal || {};
        modDCT.controlesTecnicos = datosModal.controlesTecnicos;

        function Cancelar() {
            $modalInstance.dismiss();
        }

    function updateDatosPaginacion(newPag, oldPag) {
        if (angular.isObject(newPag) && angular.isObject(oldPag)) {
            modDCT.paginacion = angular.copy(newPag);
            var grid = angular.element("#gridControlesTecnicos");
            if (newPag.page !== oldPag.page) {
                grid.setGridParam("page", newPag.page);
            }
            if (newPag.pageSize !== oldPag.pageSize) {
                grid.setGridParam("rowNum", newPag.pageSize);
            }
        }
    }

    function refrescar() {
        var grid = angular.element("#gridControlesTecnicos");
        var rowNum = grid.getGridParam("rowNum");
        var page = grid.getGridParam("page");
        modDCT.paginacion.page = Number(page);
        modDCT.paginacion.pageSize = Number(rowNum);
    }

    function onInit() {
        modDCT.titulo = "Controles técnicos";
        modDCT.buttonCancelar = datosModal.buttonCancelar || $translate("EmisionHogar.ModalControlesTecnicos.ControlesTecnicosButtonCancelar");
        modDCT.close = Cancelar;
        modDCT.grid = {
            model: undefined,
            data: [],
            options: GridControlesTecnicosSrv.getOptions(refrescar, modDCT)
        };
        modDCT.reloadGrid = true;
    }
    onInit();
}
]);

Служба:

  /*global appModule, JSON */
"use strict";
(appModule.lazy || appModule).service("GridControlesTecnicosSrv", ["$filter", "$translate", "$timeout",
    function($filter, $translate, $timeout) {
        function emptyFormatter(val) {
            if (val === undefined || val === null || val === "" || (angular.isString(val) && val.trim() === "")) {
                return "-";
            } else {
                return $filter("uppercase")(val);
            }
        }
    function getOptions(refrescar, modDCT) {
        return {
            colModel: [{
                label: "Codigo", //$translate("ControlesTecnicos.columnas.codigo"),
                name: "codigo",
                index: "codigo",
                width: "150",
                sortable: true,
                formatter: emptyFormatter
            }, {
                label: "Tipo", //$translate("ControlesTecnicos.columnas.tipo"),
                name: "tipo",
                index: "tipo",
                width: "200",
                sortable: true,
                formatter: emptyFormatter
            }, {
                label: "Descripcion", //$translate("ControlesTecnicos.columnas.descripcion"),
                name: "descripcion",
                index: "descripcion",
                width: "200",
                sortable: true,
                formatter: emptyFormatter
            }],
            viewrecords: false,
            rowNum: modDCT.paginacion.pageSize,
            rowList: [5, 10, 15],
            autoencode: true,
            refresh: true,
            datatype: function(postdata) {
                if (modDCT.reloadGrid) {
                    modDCT.reloadGrid = false;
                    var jsonData = {
                        page: modDCT.paginacion.page || 1,
                        total: Math.ceil((modDCT.controlesTecnicos.length || 0) / (modDCT.paginacion.pageSize || 10)) || 1,
                        records: modDCT.controlesTecnicos.length || 0,
                        rows: modDCT.controlesTecnicos || []
                    };
                    angular.element("#gridControlesTecnicos")[0].addJSONData(jsonData);
                }
            },
            autowidth: true,
            height: "auto",
            shrinkToFit: false,
            emptyRecords: $translate("ControlesTecnicos.sinResultados"),
            pagerpos: "left",
            pgtext: "<span>{0}/{1}</span>",
            onSortCol: function() {
                $timeout(function() {
                    refrescar();
                });
            },
            onPaging: function() {
                $timeout(function() {
                    refrescar();
                });
            },
            gridComplete: function() {
                var firstPager = angular.element("#first_grid_pager_controlestecnicos")
                if (firstPager && firstPager.length > 0) {
                    angular.element("#first_grid_pager_controlestecnicos").remove();
                    angular.element("#last_grid_pager_controlestecnicos").remove();
                    angular.element("#prev_grid_pager_controlestecnicos").before(angular.element("#next_grid_pager_controlestecnicos"))
                    angular.element(".ui-separator").remove();
                }
            }
        };
    }
    return {
        getOptions: getOptions
    };
}
]);

Таблица заполнена записями, но нумерация страниц не работает.Вот изображение таблицы: enter image description here

1 Ответ

0 голосов
/ 02 апреля 2019

Мне просто нужно было добавить modDCT.reloadGrid = true; после refrescar() и updateDatosPaginacion.

...