AngularJS ui-grid для экспорта таблицы со стилем ячейки - PullRequest
0 голосов
/ 28 июня 2019

Я использую ui-grid в angularjs для создания таблицы на моем сайте.Я могу экспортировать данные своей таблицы в Excel без стилей без проблем.Я также нашел код, который экспортирует данные с некоторыми пользовательскими стилями (просто объединяет ячейки B1 и C1 и выделяет их жирным шрифтом).

Ниже приведен код для вашей справки: -

HTML-код: -

<div ui-grid="gridOptions2" ui-grid-pagination ui-grid-selection ui-grid-exporter class="myGrid"></div>

AngularJS код: -

$scope.gridOptions2 = {
    paginationPageSizes: [25, 50, 75],
    paginationPageSize: 25,
    enableGridMenu: true,
    enableSelectAll: true,
    exporterCsvFilename: 'myFile.csv',
    exporterPdfDefaultStyle: {fontSize: 9},
    exporterPdfTableStyle: {margin: [30, 30, 30, 30]},
    exporterPdfTableHeaderStyle: {fontSize: 10, bold: true, italics: true, color: 'red'},
    exporterPdfHeader: { text: "My Header", style: 'headerStyle' },
    exporterPdfFooter: function ( currentPage, pageCount ) {
      return { text: currentPage.toString() + ' of ' + pageCount.toString(), style: 'footerStyle' };
    },
    exporterPdfCustomFormatter: function ( grid, workbook, docDefinition ) {

      var stylesheet = workbook.getStyleSheet();
      var stdStyle = stylesheet.createFontStyle({
        size: 9, fontName: 'Calibri'
      });
      var boldStyle = stylesheet.createFontStyle({
        size: 9, fontName: 'Calibri', bold: true
      });
      var aFormatDefn = {
        "font": boldStyle.id,
        "alignment": { "wrapText": true }
      };
      var formatter = stylesheet.createFormat(aFormatDefn);
      // save the formatter
      $scope.formatters['bold'] = formatter;
      var dateFormatter = stylesheet.createSimpleFormatter('date');
      $scope.formatters['date'] = dateFormatter;

      aFormatDefn = {
        "font": stdStyle.id,
        "fill": { "type": "pattern", "patternType": "solid", "fgColor": "FFFFC7CE" },
        "alignment": { "wrapText": true }
      };
      var singleDefn = {
        font: stdStyle.id,
        format: '#,##0.0'
      };
      formatter = stylesheet.createFormat(aFormatDefn);
      // save the formatter
      $scope.formatters['red'] = formatter;

      Object.assign(docDefinition.styles , $scope.formatters);

      return docDefinition;
    },
    exporterExcelHeader: function (grid, workbook, sheet, docDefinition) {
        // this can be defined outside this method
        var stylesheet = workbook.getStyleSheet();
        var aFormatDefn = {
          "font": { "size": 11, "fontName": "Calibri", "bold": true },
          "alignment": { "wrapText": true }
        };
        var formatterId = stylesheet.createFormat(aFormatDefn);

        // excel cells start with A1 which is upper left corner
        sheet.mergeCells('B1', 'C1');
        var cols = [];
        // push empty data
        cols.push({ value: '' });
        // push data in B1 cell with metadata formatter
        cols.push({ value: 'My header that is long enough to wrap', metadata: {style: formatterId.id} });
        sheet.data.push(cols);
    },
    exporterFieldFormatCallback: function(grid, row, gridCol, cellValue) {
     // set metadata on export data to set format id. See exportExcelHeader config above for example of creating
     // a formatter and obtaining the id
     var formatterId = null;
     if (gridCol.field === 'name' && cellValue && cellValue.startsWith('W')) {
       formatterId = $scope.formatters['red'].id;
     }

     if (gridCol.field === 'updatedDate') {
       formatterId = $scope.formatters['date'].id;
     }

     if (formatterId) {
       return {metadata: {style: formatterId}};
     } else {
       return null;
     }
    },
    exporterColumnScaleFactor: 4.5,
    exporterFieldApplyFilters: true,
    onRegisterApi: function(gridApi){
      $scope.gridApi = gridApi;
    },
    onRegisterApi: function(gridApi){
      $scope.gridApi = gridApi;
    }
  };

Я хотел экспортировать данные сетки с некоторыми пользовательскими стилями, например: - сделать заголовки таблицы жирным шрифтом и изменить цвет фона при экспорте в excel.

Я пробовал искать, но не смог 'Я не нашел решения или подсказки.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...