limitng 0.21.73 → 0.21.75

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -7,6 +7,120 @@ import ExcelJS from 'exceljs';
7
7
  import { NumberFormatlar, FontStyle } from 'limitng/api/models/fourDConstants';
8
8
  import { XLHAlign, XLVAlign } from 'limitng/api/models/xl/xlConstants';
9
9
 
10
+ class ExcelRaporuSonuc {
11
+ constructor() {
12
+ this.book = {
13
+ author: 'MedPlan',
14
+ activeSheetNo: 1
15
+ };
16
+ this.defaultFont = {
17
+ name: 'Calibri',
18
+ size: 11
19
+ };
20
+ this.currentTableStyle = '';
21
+ this.sifirlariBasmaSayi = false;
22
+ this.sifirlariBasmaTarih = false;
23
+ // Yeni format: her sheet kendi tablolarını, üst bilgilerini ve notlarını taşır
24
+ this.sheets = [];
25
+ this.window = {
26
+ displayGridLines: false
27
+ };
28
+ }
29
+ }
30
+
31
+ class JsonToExcelTableBuilder {
32
+ constructor(table) {
33
+ this.table = table;
34
+ }
35
+ addColumn(column) {
36
+ this.table.columns.push(column);
37
+ return this;
38
+ }
39
+ setRows(rows) {
40
+ this.table.collection = rows;
41
+ return this;
42
+ }
43
+ setStartColumn(sol) {
44
+ this.table.sol = sol;
45
+ return this;
46
+ }
47
+ setStartRow(ust) {
48
+ this.table.ust = ust;
49
+ return this;
50
+ }
51
+ getColumnSayisi() {
52
+ return this.table.columns.length;
53
+ }
54
+ }
55
+ class JsonToExcelSheetBuilder {
56
+ constructor(sheet) {
57
+ this.sheet = sheet;
58
+ }
59
+ addTable(rows, options = {}) {
60
+ const table = {
61
+ collection: rows,
62
+ columns: [],
63
+ ...(options.autoFit !== undefined && { autoFit: options.autoFit }),
64
+ ...(options.data && { data: options.data }),
65
+ ...(options.footer && { footer: options.footer }),
66
+ ...(options.header && { header: options.header }),
67
+ ...(options.sol !== undefined && { sol: options.sol }),
68
+ ...(options.ust !== undefined && { ust: options.ust })
69
+ };
70
+ this.sheet.tables ??= [];
71
+ this.sheet.tables.push(table);
72
+ return new JsonToExcelTableBuilder(table);
73
+ }
74
+ addUstBilgi(ustBilgi, font) {
75
+ this.sheet.ustBilgiler ??= [];
76
+ this.sheet.ustBilgiler.push(JsonToExcelParser.ustBilgiEkle(ustBilgi, font));
77
+ return this;
78
+ }
79
+ getUstBilgiSayisi() {
80
+ return this.sheet.ustBilgiler?.length ?? 0;
81
+ }
82
+ getSheetNo() {
83
+ return this.sheet.sheetNo;
84
+ }
85
+ setSheetName(sheetName) {
86
+ this.sheet.sheetName = sheetName;
87
+ return this;
88
+ }
89
+ setZoom(zoom) {
90
+ this.sheet.zoom = zoom;
91
+ return this;
92
+ }
93
+ }
94
+ class JsonToExcelReportBuilder {
95
+ constructor() {
96
+ this.sonuc = new ExcelRaporuSonuc();
97
+ }
98
+ addSheet(sheetName, options = {}) {
99
+ const sheet = {
100
+ sheetName,
101
+ sheetNo: this.sonuc.sheets.length + 1,
102
+ ...(options.pageSetup && { pageSetup: options.pageSetup }),
103
+ ...(options.zoom !== undefined && { zoom: options.zoom })
104
+ };
105
+ this.sonuc.sheets.push(sheet);
106
+ return new JsonToExcelSheetBuilder(sheet);
107
+ }
108
+ build() {
109
+ return this.sonuc;
110
+ }
111
+ setAuthor(author) {
112
+ this.sonuc.book.author = author;
113
+ return this;
114
+ }
115
+ setCurrentTableStyle(currentTableStyle) {
116
+ this.sonuc.currentTableStyle = currentTableStyle;
117
+ return this;
118
+ }
119
+ setSubject(subject) {
120
+ this.sonuc.book.subject = subject;
121
+ return this;
122
+ }
123
+ }
10
124
  class JsonToExcelParser {
11
125
  static async indir(sonuc, dosyaAdi) {
12
126
  const blob = await this.blobOlustur(sonuc);
@@ -36,6 +150,9 @@ class JsonToExcelParser {
36
150
  static ustBilgiEkle(ustBilgi, font) {
37
151
  return font ? { font, ustBilgi } : { ustBilgi };
38
152
  }
153
+ static raporOlustur() {
154
+ return new JsonToExcelReportBuilder();
155
+ }
39
156
  static workbookOlustur(sonuc) {
40
157
  const workbook = new ExcelJS.Workbook();
41
158
  workbook.created = new Date();
@@ -544,7 +661,7 @@ class JsonToExcelParser {
544
661
  if (value === null || value === undefined) {
545
662
  return { deger: '' };
546
663
  }
547
- const htmlHucre = typeof value === 'string' ? this.htmlHucreIceriginiHazirla(value) : undefined;
664
+ const htmlHucre = (column.htmlKoduGelebilir === true) && typeof value === 'string' ? this.htmlHucreIceriginiHazirla(value) : undefined;
548
665
  const normallesenDeger = htmlHucre?.deger ?? value;
549
666
  if ((typeof normallesenDeger === 'string') && normallesenDeger.startsWith('=')) {
550
667
  return this.hazirHucreDegeriOlustur({ formula: this.excelFormuluneDonustur(normallesenDeger) }, htmlHucre?.fontColorArgb);
@@ -955,30 +1072,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.2.15", ngImpo
955
1072
  args: [{ providedIn: 'root' }]
956
1073
  }] });
957
1074
 
958
- class ExcelRaporuSonuc {
959
- constructor() {
960
- this.book = {
961
- author: 'MedPlan',
962
- activeSheetNo: 1
963
- };
964
- this.defaultFont = {
965
- name: 'Calibri',
966
- size: 11
967
- };
968
- this.currentTableStyle = '';
969
- this.sifirlariBasmaSayi = false;
970
- this.sifirlariBasmaTarih = false;
971
- // Yeni format: her sheet kendi tablolarını, üst bilgilerini ve notlarını taşır
972
- this.sheets = [];
973
- this.window = {
974
- displayGridLines: false
975
- };
976
- }
977
- }
978
-
979
1075
  /**
980
1076
  * Generated bundle index. Do not edit.
981
1077
  */
982
1078
 
983
- export { BlobResponseHandlerService, ExcelRaporuSonuc, JsonToExcelParser };
1079
+ export { BlobResponseHandlerService, ExcelRaporuSonuc, JsonToExcelParser, JsonToExcelReportBuilder, JsonToExcelSheetBuilder, JsonToExcelTableBuilder };
984
1080
  //# sourceMappingURL=limitng-blob-response-handler.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"limitng-blob-response-handler.mjs","sources":["../../src/app/components/blob-response-handler/models/jsonToExcelParser.ts","../../src/app/components/blob-response-handler/blob-response-handler.service.ts","../../src/app/components/blob-response-handler/models/excelRaporuSonuc.ts","../../src/app/components/blob-response-handler/limitng-blob-response-handler.ts"],"sourcesContent":["import ExcelJS from 'exceljs';\r\nimport saveAs from 'file-saver';\r\nimport { FontStyle, NumberFormatlar } from 'limitng/api/models/fourDConstants';\r\nimport { XLHAlign, XLVAlign } from 'limitng/api/models/xl/xlConstants';\r\nimport { ExcelRaporuSonuc } from './excelRaporuSonuc';\r\n\r\ntype TExcelTable = NonNullable<ExcelRaporuSonuc['tables']>[number];\r\ntype TExcelBook = ExcelRaporuSonuc['book'];\r\ntype TExcelTableColumn = TExcelTable['columns'][number];\r\ntype TExcelTableRow = TExcelTable['collection'][number];\r\ntype TExcelSheet = ExcelRaporuSonuc['sheets'][number];\r\ntype TExcelPageSetup = NonNullable<TExcelSheet['pageSetup']>;\r\ntype TExcelUstBilgi = NonNullable<ExcelRaporuSonuc['ustBilgiler']>[number];\r\ntype TDefaultFont = ExcelRaporuSonuc['defaultFont'];\r\n\r\ninterface IExcelFont {\r\n color?: string;\r\n name?: string;\r\n size?: number;\r\n style?: number;\r\n}\r\n\r\ninterface ISheetGrup {\n sheetName: string;\n sheetNo?: number;\n tables: TExcelTable[];\n}\n\ninterface IHazirHucreDegeri {\n deger: ExcelJS.CellValue;\n fontColorArgb?: string;\n}\n\nexport class JsonToExcelParser {\n static async indir(sonuc: ExcelRaporuSonuc, dosyaAdi: string): Promise<void> {\r\n const blob = await this.blobOlustur(sonuc);\r\n const normalizeDosyaAdi = this.dosyaAdiDuzenle(dosyaAdi);\r\n saveAs(blob, `${normalizeDosyaAdi}.xlsx`);\r\n }\r\n\r\n static async blobOlustur(sonuc: ExcelRaporuSonuc): Promise<Blob> {\r\n const workbook = this.workbookOlustur(sonuc);\r\n const buffer = await workbook.xlsx.writeBuffer();\r\n\r\n return new Blob([buffer], {\r\n type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'\r\n });\r\n }\r\n\r\n static standartPageSetupOlustur(): TExcelPageSetup {\r\n return {\r\n bottomMargin: 1,\r\n centerHorizontally: true,\r\n centerVertically: true,\r\n fitToPagesTall: 1,\r\n fitToPagesWide: 1,\r\n leftMargin: 1,\r\n orientation: 2,\r\n rightMargin: 1,\r\n topMargin: 1\r\n };\r\n }\r\n\r\n static ustBilgiEkle(ustBilgi: string, font?: TExcelUstBilgi['font']): TExcelUstBilgi {\r\n return font ? { font, ustBilgi } : { ustBilgi };\r\n }\r\n\r\n private static workbookOlustur(sonuc: ExcelRaporuSonuc): ExcelJS.Workbook {\r\n const workbook = new ExcelJS.Workbook();\r\n workbook.created = new Date();\r\n workbook.calcProperties.fullCalcOnLoad = true;\r\n\r\n const gridLinesGorunur = sonuc.window.displayGridLines;\r\n\r\n if (this.yeniYapiMi(sonuc)) {\r\n workbook.creator = sonuc.book.author || 'MedPlan';\r\n workbook.subject = '';\r\n workbook.description = '';\r\n this.yeniFormatSheetsYaz(workbook, sonuc, gridLinesGorunur);\r\n } else {\r\n workbook.creator = sonuc.book.author || 'MedPlan';\r\n workbook.subject = this.konuVer(sonuc.book, sonuc.ustBilgiler?.[0]?.ustBilgi);\r\n workbook.description = sonuc.book.comments || '';\r\n this.eskiFormatSheetsYaz(workbook, sonuc, gridLinesGorunur);\r\n }\r\n\r\n this.aktifSayfayiAyarla(workbook, sonuc.book.activeSheetNo, workbook.worksheets.length);\r\n\r\n return workbook;\r\n }\r\n\r\n private static yeniYapiMi(sonuc: ExcelRaporuSonuc): boolean {\r\n const ilkSheet = sonuc.sheets[0] as unknown as { tables?: unknown };\r\n if (Array.isArray(ilkSheet?.tables)) {\r\n return true;\r\n }\r\n\r\n const runtimeSonuc = sonuc as unknown as { tables?: unknown };\r\n\r\n return !Array.isArray(runtimeSonuc.tables);\r\n }\r\n\r\n private static yeniFormatSheetsYaz(workbook: ExcelJS.Workbook, sonuc: ExcelRaporuSonuc, gridLinesGorunur: boolean): void {\r\n for (let index = 0; index < sonuc.sheets.length; index++) {\r\n const sheet = sonuc.sheets[index]!;\r\n const sheetAdi = this.sayfaAdiDuzenle(sheet.sheetName || 'Rapor', index + 1);\r\n const worksheet = workbook.addWorksheet(sheetAdi);\r\n const zoomScale = sheet.zoom && sheet.zoom > 0 ? sheet.zoom : undefined;\r\n worksheet.views = [{ showGridLines: gridLinesGorunur, ...(zoomScale !== undefined && { zoomScale }) }];\r\n this.sayfaDuzeniniBelirle(worksheet, sheet);\r\n\r\n const ustBilgiler = sheet.ustBilgiler ?? [];\r\n this.yeniFormatUstBilgileriYaz(worksheet, ustBilgiler, sonuc.defaultFont);\r\n\r\n let sonSatir = ustBilgiler.length + 1;\r\n for (const table of sheet.tables ?? []) {\r\n sonSatir = Math.max(sonSatir, this.tabloyuYaz(worksheet, sonuc, table));\r\n }\r\n\r\n if (sheet.notlar?.length) {\r\n this.notlariYazList(worksheet, sheet.notlar, sheet.not?.font, sonSatir + 2, sonuc.defaultFont);\r\n }\r\n }\r\n\r\n if (sonuc.sheets.length === 0) {\r\n const worksheet = workbook.addWorksheet('Rapor');\r\n worksheet.views = [{ showGridLines: gridLinesGorunur }];\r\n }\r\n }\r\n\r\n private static eskiFormatSheetsYaz(workbook: ExcelJS.Workbook, sonuc: ExcelRaporuSonuc, gridLinesGorunur: boolean): void {\r\n const tablesBySheet = this.sheetBazliTablolar(sonuc);\r\n const ustBilgiler = sonuc.ustBilgiler ?? [];\r\n const notlar = sonuc.notlar ?? [];\r\n\r\n for (const sheetGrup of tablesBySheet) {\r\n const worksheet = workbook.addWorksheet(sheetGrup.sheetName);\r\n worksheet.views = [{ showGridLines: gridLinesGorunur }];\r\n\r\n this.ustBilgileriYaz(worksheet, ustBilgiler, sonuc.defaultFont);\r\n\r\n let sonSatir = 1;\r\n for (const table of sheetGrup.tables) {\r\n sonSatir = Math.max(sonSatir, this.tabloyuYaz(worksheet, sonuc, table));\r\n }\r\n\r\n this.notlariYazList(worksheet, notlar, sonuc.not?.font, sonSatir + 2, sonuc.defaultFont);\r\n }\r\n\r\n if (tablesBySheet.length === 0) {\r\n const worksheet = workbook.addWorksheet(this.bosRaporSheetAdiniVer(sonuc));\r\n worksheet.views = [{ showGridLines: gridLinesGorunur }];\r\n this.ustBilgileriYaz(worksheet, ustBilgiler, sonuc.defaultFont);\r\n this.notlariYazList(worksheet, notlar, sonuc.not?.font, ustBilgiler.length + 2, sonuc.defaultFont);\r\n }\r\n }\r\n\r\n private static sheetBazliTablolar(sonuc: ExcelRaporuSonuc): ISheetGrup[] {\r\n const grouped = new Map<string, ISheetGrup>();\r\n\r\n for (const table of sonuc.tables ?? []) {\r\n const sheetNo = this.tableSheetNoVer(table);\r\n const sheetKey = this.sheetKeyVer(table, sheetNo, grouped.size + 1);\r\n const existing = grouped.get(sheetKey);\r\n\r\n if (existing) {\r\n existing.tables.push(table);\r\n continue;\r\n }\r\n\r\n grouped.set(sheetKey, {\r\n sheetName: this.sheetAdiniBelirle(sonuc, table, grouped.size + 1, sheetNo),\r\n ...(sheetNo !== undefined && { sheetNo }),\r\n tables: [table]\r\n });\r\n }\r\n\r\n return Array.from(grouped.values()).sort((a, b) => this.sheetGrupSirasiVer(a) - this.sheetGrupSirasiVer(b));\r\n }\r\n\r\n private static tableSheetNoVer(table: TExcelTable): number | undefined {\r\n const runtimeTable = table as TExcelTable & { sheetNo?: number };\r\n\r\n return runtimeTable.sheetNo;\r\n }\r\n\r\n private static sheetKeyVer(table: TExcelTable, sheetNo: number | undefined, index: number): string {\r\n if (sheetNo !== undefined) {\r\n return `sheet-no-${sheetNo}`;\r\n }\r\n\r\n const eskiSheetName = table.sheetName?.trim();\r\n if (eskiSheetName) {\r\n return `sheet-name-${eskiSheetName}`;\r\n }\r\n\r\n return `sheet-index-${index}`;\r\n }\r\n\r\n private static sheetAdiniBelirle(\r\n sonuc: ExcelRaporuSonuc,\r\n table: TExcelTable,\r\n index: number,\r\n sheetNo: number | undefined\r\n ): string {\r\n const jsonSheet = this.jsonSheetBul(sonuc.sheets, sheetNo, index);\r\n if (jsonSheet?.sheetName?.trim()) {\r\n return this.sayfaAdiDuzenle(jsonSheet.sheetName, index);\r\n }\r\n\r\n return this.sayfaAdiDuzenle(table.sheetName || 'Rapor', index);\r\n }\r\n\r\n private static jsonSheetBul(\r\n sheets: TExcelSheet[],\r\n sheetNo: number | undefined,\r\n index: number\r\n ): TExcelSheet | undefined {\r\n if (sheetNo !== undefined) {\r\n return sheets.find(sheet => sheet.sheetNo === sheetNo);\r\n }\r\n\r\n return sheets.find(sheet => sheet.sheetNo === index) ?? sheets[index - 1];\r\n }\r\n\r\n private static konuVer(book: TExcelBook, ilkUstBilgi: string | undefined): string {\r\n return book.subject || ilkUstBilgi || 'Rapor';\r\n }\r\n\r\n private static bosRaporSheetAdiniVer(sonuc: ExcelRaporuSonuc): string {\r\n const ilkSheetAdi = sonuc.sheets[0]?.sheetName;\r\n\r\n return this.sayfaAdiDuzenle(ilkSheetAdi || 'Rapor', 1);\r\n }\r\n\r\n private static aktifSayfayiAyarla(workbook: ExcelJS.Workbook, activeSheetNo: number, toplamSheetSayisi: number) {\r\n const aktifTab = this.aktifTabNoVer(activeSheetNo, toplamSheetSayisi);\r\n if (aktifTab === undefined) {\r\n return;\r\n }\r\n\r\n workbook.views = [{\r\n activeTab: aktifTab,\r\n firstSheet: aktifTab,\r\n height: 20000,\r\n visibility: 'visible',\r\n width: 20000,\r\n x: 0,\r\n y: 0\r\n }];\r\n }\r\n\r\n private static aktifTabNoVer(activeSheetNo: number, toplamSheetSayisi: number): number | undefined {\r\n if (toplamSheetSayisi <= 0) {\r\n return undefined;\r\n }\r\n\r\n const aktifSheetNo = Number.isFinite(activeSheetNo) && activeSheetNo > 0 ? activeSheetNo : 1;\r\n\r\n return Math.min(aktifSheetNo - 1, toplamSheetSayisi - 1);\r\n }\r\n\r\n private static sheetGrupSirasiVer(sheetGrup: ISheetGrup): number {\r\n return sheetGrup.sheetNo ?? Number.MAX_SAFE_INTEGER;\r\n }\r\n\r\n private static yeniFormatUstBilgileriYaz(\r\n worksheet: ExcelJS.Worksheet,\r\n ustBilgiler: TExcelUstBilgi[],\r\n defaultFont: TDefaultFont\r\n ): void {\r\n for (let index = 0; index < ustBilgiler.length; index++) {\r\n const ustBilgi = ustBilgiler[index]!;\r\n const hucre = worksheet.getCell(index + 1, 1);\r\n hucre.value = ustBilgi.ustBilgi;\r\n this.hucreFontunuUygula(hucre, ustBilgi.font, defaultFont);\r\n hucre.alignment = { horizontal: 'left', vertical: 'middle', wrapText: false };\r\n }\r\n }\r\n\r\n private static ustBilgileriYaz(\r\n worksheet: ExcelJS.Worksheet,\r\n ustBilgiler: TExcelUstBilgi[],\r\n defaultFont: TDefaultFont\r\n ): void {\r\n for (const ustBilgi of ustBilgiler) {\r\n const hucre = worksheet.getCell(ustBilgi.rowNo ?? 1, 1);\r\n hucre.value = ustBilgi.ustBilgi;\r\n this.hucreFontunuUygula(hucre, ustBilgi.font, defaultFont);\r\n hucre.alignment = { horizontal: 'left', vertical: 'middle', wrapText: false };\r\n }\r\n }\r\n\r\n private static notlariYazList(\r\n worksheet: ExcelJS.Worksheet,\r\n notlar: string[],\r\n notFont: IExcelFont | undefined,\r\n baslangicSatiri: number,\r\n defaultFont: TDefaultFont\r\n ): void {\r\n let satirNo = baslangicSatiri;\r\n for (const not of notlar) {\r\n const cell = worksheet.getCell(satirNo, 1);\r\n cell.value = not;\r\n this.hucreFontunuUygula(cell, notFont, defaultFont);\r\n cell.alignment = { vertical: 'middle', wrapText: true };\r\n satirNo++;\r\n }\r\n }\r\n\r\n private static sayfaDuzeniniBelirle(worksheet: ExcelJS.Worksheet, sheet: TExcelSheet): void {\r\n const { pageSetup } = sheet;\r\n if (!pageSetup) {\r\n return;\r\n }\r\n\r\n if (pageSetup.orientation === 2) {\r\n worksheet.pageSetup.orientation = 'landscape';\r\n } else if (pageSetup.orientation === 1) {\r\n worksheet.pageSetup.orientation = 'portrait';\r\n }\r\n\r\n const hasMargin =\r\n pageSetup.leftMargin !== undefined ||\r\n pageSetup.rightMargin !== undefined ||\r\n pageSetup.topMargin !== undefined ||\r\n pageSetup.bottomMargin !== undefined ||\r\n pageSetup.headerMargin !== undefined ||\r\n pageSetup.footerMargin !== undefined;\r\n\r\n if (hasMargin) {\r\n worksheet.pageSetup.margins = {\r\n left: pageSetup.leftMargin ?? 0.7,\r\n right: pageSetup.rightMargin ?? 0.7,\r\n top: pageSetup.topMargin ?? 0.75,\r\n bottom: pageSetup.bottomMargin ?? 0.75,\r\n header: pageSetup.headerMargin ?? 0.3,\r\n footer: pageSetup.footerMargin ?? 0.3\r\n };\r\n }\r\n\r\n if (pageSetup.centerHorizontally !== undefined) {\r\n worksheet.pageSetup.horizontalCentered = pageSetup.centerHorizontally;\r\n }\r\n if (pageSetup.centerVertically !== undefined) {\r\n worksheet.pageSetup.verticalCentered = pageSetup.centerVertically;\r\n }\r\n\r\n const fitTall = pageSetup.fitToPagesTall;\r\n const fitWide = pageSetup.fitToPagesWide;\r\n if (fitTall !== undefined || fitWide !== undefined || pageSetup.fitToPagesTAut || pageSetup.fitToPagesWAut) {\r\n worksheet.pageSetup.fitToPage = true;\r\n worksheet.pageSetup.fitToHeight = pageSetup.fitToPagesTAut ? 0 : (fitTall ?? 1);\r\n worksheet.pageSetup.fitToWidth = pageSetup.fitToPagesWAut ? 0 : (fitWide ?? 1);\r\n }\r\n\r\n if (typeof pageSetup.zoom === 'number' && pageSetup.zoom > 0) {\r\n worksheet.pageSetup.scale = pageSetup.zoom;\r\n }\r\n\r\n if (pageSetup.printArea) {\r\n worksheet.pageSetup.printArea = pageSetup.printArea;\r\n }\r\n\r\n const pageHeader = this.baslikAltbilgiMetniOlustur(pageSetup.leftHeader, pageSetup.centerHeader, pageSetup.rightHeader);\r\n const pageFooter = this.baslikAltbilgiMetniOlustur(pageSetup.leftFooter, pageSetup.centerFooter, pageSetup.rightFooter);\r\n if (pageHeader) {\r\n worksheet.headerFooter.oddHeader = pageHeader;\r\n }\r\n if (pageFooter) {\r\n worksheet.headerFooter.oddFooter = pageFooter;\r\n }\r\n }\r\n\r\n private static baslikAltbilgiMetniOlustur(sol?: string, orta?: string, sag?: string): string | undefined {\r\n const parcalar: string[] = [];\r\n if (sol) {\r\n parcalar.push(`&L${sol}`);\r\n }\r\n if (orta) {\r\n parcalar.push(`&C${orta}`);\r\n }\r\n if (sag) {\r\n parcalar.push(`&R${sag}`);\r\n }\r\n return parcalar.length ? parcalar.join('') : undefined;\r\n }\r\n\r\n private static tabloyuYaz(worksheet: ExcelJS.Worksheet, sonuc: ExcelRaporuSonuc, table: TExcelTable): number {\r\n if (!table.columns.length) {\r\n return table.ust ?? 1;\r\n }\r\n\r\n const startRow = Math.max(1, table.ust ?? 1);\r\n const startCol = Math.max(1, table.sol ?? 1);\r\n const gecerliTableStyle = this.gecerliTableStyleVer(sonuc.currentTableStyle);\r\n const headerTitlelari = table.columns.map(column => this.baslikMetniniHazirla(column.header.title || ''));\r\n const gorunenBaslikMetinleri = headerTitlelari.map(title => title.replaceAll('\\n', ' '));\r\n const tabloKolonAdlari = this.benzersizKolonAdlariOlustur(gorunenBaslikMetinleri);\r\n\r\n const headerFont = table.header?.font;\r\n const uygulanacakHeaderFont = headerFont?.color ? headerFont : {\r\n ...headerFont,\r\n color: 'FFFFFFFF'\r\n };\r\n const dataFont = table.data?.font;\r\n const hiddenRowSet = new Set(table.hiddenRows ?? []);\r\n\r\n const formulCeller: Array<{\n colIndex: number;\n column: TExcelTableColumn;\n formula: ExcelJS.CellFormulaValue;\n rowIndex: number;\n }> = [];\n const hucreFontRenkleri: Array<Array<string | undefined>> = [];\n const satirlar = table.collection.map((rowData, rowIndex) =>\n table.columns.map((column, colIndex) => {\n const hazirHucre = this.hucreDegeriniHazirla(rowData, column, sonuc.sifirlariBasmaSayi);\n hucreFontRenkleri[rowIndex] ??= [];\n hucreFontRenkleri[rowIndex]![colIndex] = hazirHucre.fontColorArgb;\n\n if (hazirHucre.deger !== null && typeof hazirHucre.deger === 'object' && 'formula' in hazirHucre.deger) {\n formulCeller.push({ rowIndex, colIndex, column, formula: hazirHucre.deger as ExcelJS.CellFormulaValue });\n return '' as ExcelJS.CellValue;\n }\n return hazirHucre.deger;\n })\n );\n\r\n this.kolonGrubuYaz(worksheet, startRow, startCol, table);\r\n\r\n const tableStyle = this.tableStyleDonustur(gecerliTableStyle);\r\n worksheet.addTable({\r\n name: this.tabloAdiOlustur(worksheet.name, startRow, startCol),\r\n ref: worksheet.getCell(startRow, startCol).address,\r\n headerRow: true,\r\n totalsRow: false,\r\n ...(tableStyle && { style: tableStyle }),\r\n columns: tabloKolonAdlari.map(ad => ({ name: ad, filterButton: true })),\r\n rows: satirlar\r\n });\r\n\r\n this.kolonGenislikleriniUygula(worksheet, startCol, table.columns, satirlar);\r\n\r\n const headerRow = worksheet.getRow(startRow);\r\n for (let colIndex = 0; colIndex < table.columns.length; colIndex++) {\r\n const column = table.columns[colIndex]!;\r\n const cell = headerRow.getCell(startCol + colIndex);\r\n cell.alignment = {\r\n horizontal: this.yatayHizaDonustur(column.header.horizontalAlignment),\r\n vertical: 'bottom',\r\n wrapText: false\r\n };\r\n this.hucreFontunuUygula(cell, uygulanacakHeaderFont, sonuc.defaultFont);\r\n }\r\n\r\n for (let rowIndex = 0; rowIndex < table.collection.length; rowIndex++) {\r\n const wsRow = worksheet.getRow(startRow + 1 + rowIndex);\r\n const satir1Bazli = rowIndex + 1;\r\n\r\n if (hiddenRowSet.has(satir1Bazli)) {\r\n wsRow.hidden = true;\r\n }\r\n\r\n const rowHeight = table.rowHeights?.find(rh => rh.rowNo === satir1Bazli);\r\n if (rowHeight?.height) {\r\n wsRow.height = rowHeight.height;\r\n }\r\n\r\n for (let colIndex = 0; colIndex < table.columns.length; colIndex++) {\r\n const column = table.columns[colIndex]!;\r\n const cell = wsRow.getCell(startCol + colIndex);\n const hucreDegeri = satirlar[rowIndex]![colIndex]!;\n cell.value = hucreDegeri;\n this.hucreFontunuUygula(cell, dataFont, sonuc.defaultFont);\n const hucreFontRengi = hucreFontRenkleri[rowIndex]?.[colIndex];\n if (hucreFontRengi) {\n cell.font = { ...(cell.font ?? {}), color: { argb: hucreFontRengi } };\n }\n const numFmt = this.numberFormatDonustur(column.format);\n if (numFmt) {\n cell.numFmt = numFmt;\n } else if (hucreDegeri instanceof Date) {\n cell.numFmt = this.varsayilanTarihFormatiniVer();\n }\n cell.alignment = {\n horizontal: this.hucreYatayHizasiniBelirle(hucreDegeri, column),\n vertical: this.dikeyHizaDonustur(column.verticalAlignment),\n wrapText: false\n };\r\n\r\n // Sütun rengi\r\n const colFontColor = table.columnFontColors?.[colIndex];\r\n if (colFontColor) {\r\n const argb = this.argbDonustur(colFontColor);\r\n if (argb) {\r\n cell.font = { ...(cell.font ?? {}), color: { argb } };\r\n }\r\n }\r\n const colIntColor = table.columnInteriorColors?.[colIndex];\r\n if (colIntColor) {\r\n const argb = this.argbDonustur(colIntColor);\r\n if (argb) {\r\n cell.fill = { type: 'pattern', pattern: 'solid', fgColor: { argb } };\r\n }\r\n }\r\n\r\n // Satır rengi (sütun rengini ezer)\r\n const rowFontColor = table.rowFontColors?.find(rc => rc.rowNo === satir1Bazli);\r\n if (rowFontColor) {\r\n const argb = this.argbDonustur(rowFontColor.color);\r\n if (argb) {\r\n cell.font = { ...(cell.font ?? {}), color: { argb } };\r\n }\r\n }\r\n const rowIntColor = table.rowInteriorColors?.find(rc => rc.rowNo === satir1Bazli);\r\n if (rowIntColor) {\r\n const argb = this.argbDonustur(rowIntColor.color);\r\n if (argb) {\r\n cell.fill = { type: 'pattern', pattern: 'solid', fgColor: { argb } };\r\n }\r\n }\r\n }\r\n }\r\n\r\n for (const { rowIndex, colIndex, column, formula } of formulCeller) {\r\n const cell = worksheet.getRow(startRow + 1 + rowIndex).getCell(startCol + colIndex);\r\n cell.value = formula;\r\n cell.alignment = {\r\n ...(cell.alignment ?? {}),\r\n horizontal: this.hucreYatayHizasiniBelirle(formula, column)\r\n };\r\n }\r\n\r\n let sonSatir = startRow + table.collection.length;\r\n\r\n // Footer satırları\r\n const footer = table.footer;\r\n if (footer?.basilacak) {\r\n const ustBosluk = footer.ustBosluk ?? 0;\r\n const satirSayisi = footer.satirSayisi ?? 1;\r\n const footerBasSatir = sonSatir + 1 + ustBosluk;\r\n\r\n for (let fi = 0; fi < satirSayisi; fi++) {\r\n const footerRow = worksheet.getRow(footerBasSatir + fi);\r\n for (let colIndex = 0; colIndex < table.columns.length; colIndex++) {\r\n const column = table.columns[colIndex]!;\r\n const cell = footerRow.getCell(startCol + colIndex);\r\n this.hucreFontunuUygula(cell, footer.font, sonuc.defaultFont);\r\n\r\n const colFooter = column.footer;\r\n if (!colFooter?.isFunction && colFooter?.title) {\r\n cell.value = colFooter.title;\r\n }\r\n cell.alignment = {\r\n horizontal: this.yatayHizaDonustur(colFooter?.horizontalAlignment),\r\n vertical: 'middle',\r\n wrapText: false\r\n };\r\n }\r\n }\r\n\r\n sonSatir = footerBasSatir + satirSayisi - 1;\r\n }\r\n\r\n return sonSatir;\r\n }\r\n\r\n private static kolonGenislikleriniUygula(\r\n worksheet: ExcelJS.Worksheet,\r\n startCol: number,\r\n columns: TExcelTableColumn[],\r\n satirlar: ExcelJS.CellValue[][]\r\n ): void {\r\n const filtreButonuBoslukPayi = 1.25;\r\n const veriSagBoslukPayi = 1;\r\n\r\n for (let index = 0; index < columns.length; index++) {\r\n const worksheetColumn = worksheet.getColumn(startCol + index);\r\n const baslikUzunlugu = this.metinUzunlugu(this.baslikMetniniHazirla(columns[index]!.header.title));\r\n const veriUzunlugu = satirlar.reduce((max, satir) => Math.max(max, this.hucreMetinUzunlugu(satir[index]!)), 0);\r\n const tasarimGenisligi = (columns[index]!.width ?? 0) > 0 ? Math.round(columns[index]!.width! / 7) : 0;\r\n worksheetColumn.width = Math.max(\r\n 10,\r\n tasarimGenisligi,\r\n baslikUzunlugu + 2 + filtreButonuBoslukPayi,\r\n veriUzunlugu + 2 + veriSagBoslukPayi\r\n );\r\n }\r\n }\r\n\r\n private static baslikMetniniHazirla(metin: string): string {\r\n return metin\r\n .replaceAll('\\r\\n', ' ')\r\n .replaceAll('\\r', ' ')\r\n .replaceAll('\\n', ' ')\r\n .trim();\r\n }\r\n\r\n private static hucreMetinUzunlugu(deger: ExcelJS.CellValue): number {\r\n if (deger === null || deger === undefined) {\r\n return 0;\r\n }\r\n\r\n if (typeof deger === 'string') {\r\n return this.metinUzunlugu(deger);\r\n }\r\n\r\n if (typeof deger === 'number' || typeof deger === 'boolean') {\r\n return String(deger).length;\r\n }\r\n\r\n if (deger instanceof Date) {\r\n return '14.05.2026 09:13:29'.length;\r\n }\r\n\r\n if (typeof deger === 'object' && 'formula' in deger) {\r\n return this.metinUzunlugu(String(deger.formula));\r\n }\r\n\r\n return this.metinUzunlugu(String(deger));\r\n }\r\n\r\n private static hucreYatayHizasiniBelirle(\r\n deger: ExcelJS.CellValue,\r\n column: TExcelTableColumn\r\n ): ExcelJS.Alignment['horizontal'] {\r\n if (typeof deger === 'number') {\r\n return 'right';\r\n }\r\n\r\n if (typeof deger === 'object' && deger !== null && 'formula' in deger && this.sayisalFormatMi(column.format)) {\r\n return 'right';\r\n }\r\n\r\n return this.yatayHizaDonustur(column.horizontalAlignment);\r\n }\r\n\r\n private static sayisalFormatMi(format: number | undefined): boolean {\r\n switch (format) {\r\n case NumberFormatlar.long:\r\n case NumberFormatlar.real:\r\n case NumberFormatlar.yuzde_BirHane:\r\n case 2:\r\n case 5:\r\n case 7:\r\n case 11:\r\n case 12:\r\n return true;\r\n\r\n default:\r\n return false;\r\n }\r\n }\r\n\r\n private static metinUzunlugu(metin: string): number {\r\n return metin\r\n .replaceAll('\\r', '')\r\n .split('\\n')\r\n .reduce((max, parca) => Math.max(max, parca.trim().length), 0);\r\n }\r\n\r\n private static kolonGrubuYaz(\r\n worksheet: ExcelJS.Worksheet,\r\n startRow: number,\r\n startCol: number,\r\n table: TExcelTable\r\n ): void {\r\n const columnGroups = table.columnGroup;\r\n if (!columnGroups?.length || startRow <= 1) {\r\n return;\r\n }\r\n\r\n const grupSatiri = startRow - 1;\r\n for (const columnGroup of columnGroups) {\r\n const baslangicIndex = table.columns.findIndex(column => column.property === columnGroup.groupStart);\r\n const bitisIndex = table.columns.findIndex(column => column.property === columnGroup.groupEnd);\r\n const baslangicKolonu = baslangicIndex >= 0 ? startCol + baslangicIndex : undefined;\r\n const bitisKolonu = bitisIndex >= 0 ? startCol + bitisIndex : undefined;\r\n if (!baslangicKolonu || !bitisKolonu || bitisKolonu < baslangicKolonu) {\r\n continue;\r\n }\r\n\r\n worksheet.mergeCells(grupSatiri, baslangicKolonu, grupSatiri, bitisKolonu);\r\n\r\n const grupHucre = worksheet.getCell(grupSatiri, baslangicKolonu);\r\n grupHucre.value = columnGroup.groupName;\r\n grupHucre.alignment = { horizontal: 'center', vertical: 'middle' };\r\n grupHucre.font = { bold: true, size: 11, color: { argb: 'FFF79646' } };\r\n grupHucre.fill = {\r\n type: 'pattern',\r\n pattern: 'solid',\r\n fgColor: { argb: 'FFFFFFFF' }\r\n };\r\n\r\n for (let col = baslangicKolonu; col <= bitisKolonu; col++) {\r\n const hucre = worksheet.getCell(grupSatiri, col);\r\n hucre.border = {\r\n ...hucre.border,\r\n top: { style: 'medium', color: { argb: 'FFF79646' } },\r\n ...(col === baslangicKolonu ? { left: { style: 'medium', color: { argb: 'FFF79646' } } } : (hucre.border?.left ? { left: hucre.border.left } : {})),\r\n ...(col === bitisKolonu ? { right: { style: 'medium', color: { argb: 'FFF79646' } } } : (hucre.border?.right ? { right: hucre.border.right } : {}))\r\n };\r\n }\r\n }\r\n }\r\n\r\n private static hucreDegeriniHazirla(\n row: TExcelTableRow,\n column: TExcelTableColumn,\n sifirlariBasmaSayi: boolean\n ): IHazirHucreDegeri {\n const value = row[column.property];\n\n if ((typeof value === 'string') && value.startsWith('=')) {\n return { deger: { formula: this.excelFormuluneDonustur(value) } };\n }\n\n if ((typeof value === 'number') && sifirlariBasmaSayi && (value === 0)) {\n return { deger: '' };\n }\n\n if (value === null || value === undefined) {\n return { deger: '' };\n }\n\n const htmlHucre = typeof value === 'string' ? this.htmlHucreIceriginiHazirla(value) : undefined;\n const normallesenDeger = htmlHucre?.deger ?? value;\n\n if ((typeof normallesenDeger === 'string') && normallesenDeger.startsWith('=')) {\n return this.hazirHucreDegeriOlustur(\n { formula: this.excelFormuluneDonustur(normallesenDeger) },\n htmlHucre?.fontColorArgb\n );\n }\n\n if ((typeof value === 'string') && (typeof normallesenDeger === 'string')) {\n const tarihDegeri = this.tarihStringiniDateeDonustur(normallesenDeger);\n if (tarihDegeri) {\n return this.hazirHucreDegeriOlustur(tarihDegeri, htmlHucre?.fontColorArgb);\n }\n }\n\n if (normallesenDeger instanceof Date) {\n return this.hazirHucreDegeriOlustur(\n this.excelIcinTarihiNormalizeEt(normallesenDeger),\n htmlHucre?.fontColorArgb\n );\n }\n\n if (typeof normallesenDeger === 'boolean') {\n return this.hazirHucreDegeriOlustur(normallesenDeger ? '+' : '', htmlHucre?.fontColorArgb);\n }\n\n if ((typeof normallesenDeger === 'number') || (typeof normallesenDeger === 'string')) {\n return this.hazirHucreDegeriOlustur(normallesenDeger, htmlHucre?.fontColorArgb);\n }\n\n return this.hazirHucreDegeriOlustur(String(normallesenDeger), htmlHucre?.fontColorArgb);\n }\n\n private static hazirHucreDegeriOlustur(deger: ExcelJS.CellValue, fontColorArgb?: string): IHazirHucreDegeri {\n return {\n deger,\n ...(fontColorArgb ? { fontColorArgb } : {})\n };\n }\n\n private static htmlHucreIceriginiHazirla(value: string): { deger: string; fontColorArgb?: string } | undefined {\n if (!/[<>]/.test(value)) {\n return undefined;\n }\n\n const deger = value\n .replaceAll(/<br\\s*\\/?>/gi, '\\n')\n .replaceAll(/<\\/p\\s*>/gi, '\\n')\n .replaceAll(/<p\\b[^>]*>/gi, '')\n .replaceAll(/<\\/div\\s*>/gi, '\\n')\n .replaceAll(/<div\\b[^>]*>/gi, '')\n .replaceAll(/<[^>]+>/g, '')\n .replaceAll(/&nbsp;/gi, ' ')\n .trim();\n\n const colorValue = this.htmlFontRenginiBul(value);\n const fontColorArgb = this.argbDonustur(colorValue);\n\n if ((deger === value) && !fontColorArgb) {\n return undefined;\n }\n\n return { deger, ...(fontColorArgb && { fontColorArgb }) };\n }\n\n private static htmlFontRenginiBul(value: string): string | undefined {\n const fontColorMatch = /<font\\b[^>]*\\bcolor\\s*=\\s*[\"']?([^\"' >]+)[\"']?[^>]*>/i.exec(value);\n if (fontColorMatch?.[1]) {\n return fontColorMatch[1].trim();\n }\n\n const styleColorMatch = /<(?:font|span)\\b[^>]*\\bstyle\\s*=\\s*[\"'][^\"']*\\bcolor\\s*:\\s*([^;\"']+)/i.exec(value);\n if (styleColorMatch?.[1]) {\n return styleColorMatch[1].trim();\n }\n\n return undefined;\n }\n\n private static tarihStringiniDateeDonustur(value: string): Date | undefined {\n const trimmedValue = value.trim();\n const isoDateMatch = /^(\\d{4})-(\\d{2})-(\\d{2})(?:$|[T\\s])/.exec(trimmedValue);\n\n if (!isoDateMatch) {\n return undefined;\n }\n\n const year = Number(isoDateMatch[1]);\n const month = Number(isoDateMatch[2]);\n const day = Number(isoDateMatch[3]);\n\n if (!Number.isInteger(year) || !Number.isInteger(month) || !Number.isInteger(day)) {\n return undefined;\n }\n\n const date = new Date(year, month - 1, day);\n if (date.getFullYear() !== year || date.getMonth() !== (month - 1) || date.getDate() !== day) {\n return undefined;\n }\n\n return new Date(Date.UTC(year, month - 1, day, 12, 0, 0, 0));\n }\n\n private static excelIcinTarihiNormalizeEt(value: Date): Date {\n if (value.getHours() !== 0 || value.getMinutes() !== 0 || value.getSeconds() !== 0 || value.getMilliseconds() !== 0) {\n return value;\n }\n\n return new Date(Date.UTC(value.getFullYear(), value.getMonth(), value.getDate(), 12, 0, 0, 0));\n }\n\n private static varsayilanTarihFormatiniVer(): string {\n return 'dd.mm.yyyy';\n }\n\n private static benzersizKolonAdlariOlustur(adlar: string[]): string[] {\n const sayaclar = new Map<string, number>();\n return adlar.map(ad => {\n const temelAd = ad || ' ';\n const sayi = sayaclar.get(temelAd) ?? 0;\r\n sayaclar.set(temelAd, sayi + 1);\r\n return sayi === 0 ? temelAd : `${temelAd}_${sayi}`;\r\n });\r\n }\r\n\r\n private static hucreFontunuUygula(\r\n cell: ExcelJS.Cell,\r\n font: IExcelFont | undefined,\r\n defaultFont?: TDefaultFont\r\n ): void {\r\n const style = font?.style ?? 0;\r\n const excelFont: Partial<ExcelJS.Font> = {};\r\n\r\n const fontName = font?.name || defaultFont?.name;\r\n if (fontName) {\r\n excelFont.name = fontName;\r\n }\r\n\r\n const fontSize = (font?.size && font.size > 0) ? font.size : defaultFont?.size;\r\n if (fontSize && fontSize > 0) {\r\n excelFont.size = fontSize;\r\n }\r\n\r\n if (font?.color) {\r\n const color = this.argbDonustur(font.color);\r\n if (color) {\r\n excelFont.color = { argb: color };\r\n }\r\n }\r\n\r\n excelFont.bold = Boolean(style & FontStyle.bold);\r\n excelFont.italic = Boolean(style & FontStyle.italic);\r\n excelFont.underline = Boolean(style & FontStyle.underline);\r\n\r\n cell.font = excelFont;\r\n }\r\n\r\n private static gecerliTableStyleVer(tableStyle: string | undefined): string | undefined {\r\n if (!tableStyle) {\r\n return undefined;\r\n }\r\n\r\n const style = tableStyle.trim();\r\n if (/^TableStyleLight([1-9]|1\\d|2[0-1])$/.test(style)) {\r\n return style;\r\n }\r\n if (/^TableStyleMedium([1-9]|1\\d|2[0-1])$/.test(style)) {\r\n return style;\r\n }\r\n if (/^TableStyleDark([1-9]|10|11)$/.test(style)) {\r\n return style;\r\n }\r\n\r\n return undefined;\r\n }\r\n\r\n private static tableStyleDonustur(theme: string | undefined): ExcelJS.TableStyleProperties | undefined {\r\n if (!theme) {\r\n return undefined;\r\n }\r\n\r\n return {\r\n theme: theme as NonNullable<ExcelJS.TableStyleProperties['theme']>,\r\n showRowStripes: true\r\n };\r\n }\r\n\r\n private static tabloAdiOlustur(sheetName: string, startRow: number, startCol: number): string {\r\n const temizSheetName = sheetName.replaceAll(/[^A-Za-z0-9]/g, '_');\r\n return `T_${temizSheetName}_R${startRow}C${startCol}`;\r\n }\r\n\r\n private static yatayHizaDonustur(value: XLHAlign | undefined): ExcelJS.Alignment['horizontal'] {\r\n switch (value) {\r\n case XLHAlign.xlHAlignCenter: return 'center';\r\n case XLHAlign.xlHAlignCenterAcrossSelection: return 'centerContinuous';\r\n case XLHAlign.xlHAlignDistributed: return 'distributed';\r\n case XLHAlign.xlHAlignFill: return 'fill';\r\n case XLHAlign.xlHAlignGeneral: return 'left';\r\n case XLHAlign.xlHAlignJustify: return 'justify';\r\n case XLHAlign.xlHAlignLeft: return 'left';\r\n case XLHAlign.xlHAlignRight: return 'right';\r\n default: return 'left';\r\n }\r\n }\r\n\r\n private static dikeyHizaDonustur(value: XLVAlign | undefined): ExcelJS.Alignment['vertical'] {\r\n switch (value) {\r\n case XLVAlign.xlVAlignTop: return 'top';\r\n case XLVAlign.xlVAlignBottom: return 'bottom';\r\n case XLVAlign.xlVAlignDistributed: return 'distributed';\r\n case XLVAlign.xlVAlignJustify: return 'justify';\r\n default: return 'middle';\r\n }\r\n }\r\n\r\n private static argbDonustur(color: string | undefined): string | undefined {\n if (!color) {\n return undefined;\n }\n\n const cssColor = color.trim().toLowerCase();\n const namedColors: Record<string, string> = {\n black: 'FF000000',\n blue: 'FF0000FF',\n cyan: 'FF00FFFF',\n gray: 'FF808080',\n green: 'FF008000',\n grey: 'FF808080',\n magenta: 'FFFF00FF',\n orange: 'FFFFA500',\n purple: 'FF800080',\n red: 'FFFF0000',\n white: 'FFFFFFFF',\n yellow: 'FFFFFF00'\n };\n if (namedColors[cssColor]) {\n return namedColors[cssColor];\n }\n\n const hexColor = cssColor.replace('#', '');\n if (/^[0-9a-f]{6}$/i.test(hexColor)) {\n return `FF${hexColor.toUpperCase()}`;\n }\n\n if (/^[0-9A-Fa-f]{8}$/.test(color)) {\n return color.toUpperCase();\n }\n\r\n const numericColor = Number(color);\r\n if (!Number.isFinite(numericColor)) {\r\n return undefined;\r\n }\r\n\r\n const r = numericColor & 255;\r\n const g = (numericColor >> 8) & 255;\r\n const b = (numericColor >> 16) & 255;\r\n\r\n return `FF${[r, g, b].map(value => value.toString(16).padStart(2, '0')).join('').toUpperCase()}`;\r\n }\r\n\r\n private static excelFormuluneDonustur(formul: string): string {\r\n const ceviriler: Record<string, string> = {\r\n 'TOPLA': 'SUM',\r\n 'EĞER': 'IF',\r\n 'VE': 'AND',\r\n 'VEYA': 'OR',\r\n 'YUVARLA': 'ROUND',\r\n 'EĞERSAY': 'COUNTIF',\r\n 'ETOPLA': 'SUMIF',\r\n 'ORTALAMA': 'AVERAGE',\r\n 'MİN': 'MIN',\r\n 'MAK': 'MAX'\r\n };\r\n\r\n let sonuc = formul.slice(1).replaceAll(';', ',');\r\n\r\n for (const [kaynak, hedef] of Object.entries(ceviriler)) {\r\n const pattern = new RegExp(`\\\\b${kaynak}\\\\b`, 'g');\r\n sonuc = sonuc.replace(pattern, hedef);\r\n }\r\n\r\n return sonuc;\r\n }\r\n\r\n private static sayfaAdiDuzenle(sheetName: string, index: number): string {\r\n const temizAd = sheetName\r\n .replaceAll(/[\\\\/*?:[\\]]/g, ' ')\r\n .trim()\r\n .slice(0, 31);\r\n\r\n if (temizAd) {\r\n return temizAd;\r\n }\r\n\r\n return `Sheet${index}`;\r\n }\r\n\r\n private static dosyaAdiDuzenle(dosyaAdi: string): string {\r\n const temizAd = dosyaAdi\r\n .replaceAll(/[<>:\"/\\\\|?*]/g, ' ')\r\n .trim()\r\n .replaceAll(/\\s+/g, ' ');\r\n\r\n if (temizAd) {\r\n return temizAd;\r\n }\r\n\r\n return 'Rapor';\r\n }\r\n\r\n private static numberFormatDonustur(format: number | undefined): string | undefined {\r\n switch (format) {\r\n case NumberFormatlar.long:\r\n case 2:\r\n case 5:\r\n case 11:\r\n return '#,##0';\r\n\r\n case NumberFormatlar.real:\r\n case 7:\r\n case 12:\r\n return '#,##0.00';\r\n\r\n case 8:\r\n return 'hh:mm';\r\n\r\n case NumberFormatlar.tarih:\r\n return 'dd.mm.yyyy';\r\n\r\n case NumberFormatlar.tarih_yyyymmdd_tireli:\r\n return 'yyyy-mm-dd';\r\n\r\n case NumberFormatlar.tarih_AAAAYYYY:\r\n return 'mmmm yyyy';\r\n\r\n case NumberFormatlar.tarih_GGAAAAYYYY:\r\n return 'dd mmmm yyyy';\r\n\r\n case NumberFormatlar.tarih_YYYYMMDD:\r\n return 'yyyy/mm/dd';\r\n\r\n case NumberFormatlar.tarih_LongDate:\r\n return 'dd mmmm yyyy dddd';\r\n\r\n case NumberFormatlar.tarih_ga:\r\n return 'd.m;@';\r\n\r\n case NumberFormatlar.tarih_ggaa:\r\n return 'dd.mm';\r\n\r\n case NumberFormatlar.tarih_gaaaa:\r\n return 'd.mmmm';\r\n\r\n case NumberFormatlar.tarih_ggaaa:\r\n return 'dd.mmm';\r\n\r\n case NumberFormatlar.tarih_ggaaaa:\r\n return 'dd.mmmm';\r\n\r\n case NumberFormatlar.yuzde_BirHane:\r\n return '0.0%';\r\n\r\n case NumberFormatlar.genel:\r\n return 'General';\r\n\r\n case NumberFormatlar.metin:\r\n return '@';\r\n\r\n case NumberFormatlar.imp:\r\n return '#,##0 \"imp\"';\r\n\r\n case NumberFormatlar.clicks:\r\n return '#,##0 \"Clicks\"';\r\n\r\n case NumberFormatlar.gun:\r\n return '#,##0 \"Gün\"';\r\n\r\n case NumberFormatlar.view:\r\n return '#,##0 \"View\"';\r\n\r\n case NumberFormatlar.session:\r\n return '#,##0 \"Session\"';\r\n\r\n case NumberFormatlar.kisi:\r\n return '#,##0 \"Kişi\"';\r\n\r\n case NumberFormatlar.okunma:\r\n return '#,##0 \"Okunma\"';\r\n\r\n case NumberFormatlar.dinlenme:\r\n return '#,##0 \"Dinlenme\"';\r\n\r\n case NumberFormatlar.lead:\r\n return '#,##0 \"Lead\"';\r\n\r\n case NumberFormatlar.gizli:\r\n return ';;;';\r\n\r\n default:\r\n return undefined;\r\n }\r\n }\r\n}\r\n","import { HttpResponse } from '@angular/common/http';\r\nimport { inject, Injectable } from '@angular/core';\r\n\r\nimport saveAs from 'file-saver';\r\n\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { GlobalFunctions } from 'limitng/api';\r\nimport { ToastMessageOptions } from 'primeng/api';\r\nimport { ExcelRaporuSonuc } from './models/excelRaporuSonuc';\r\nimport { JsonToExcelParser } from './models/jsonToExcelParser';\r\n\r\ninterface JsonExcelResponseOptions<T extends ExcelRaporuSonuc> {\r\n createResult: () => T;\r\n errorLogMessage: string;\r\n fileName?: string;\r\n getFileName?: (result: T) => string;\r\n successDetail?: string;\r\n successDetailKey?: string;\r\n}\r\n\r\n@Injectable({ providedIn: 'root' })\r\nexport class BlobResponseHandlerService {\r\n private readonly translateService = inject(TranslateService);\r\n\r\n handleReportResponse(\r\n response: HttpResponse<Blob>,\r\n successDetailKey: string,\r\n htmlTitle = 'Rapor Sonucu'\r\n ): ToastMessageOptions | null {\r\n const body = response.body;\r\n\r\n if (!body) {\r\n return null;\r\n }\r\n\r\n const contentDisposition = response.headers.get('content-disposition');\r\n const contentType = response.headers.get('Content-Type') ?? body.type;\r\n\r\n if (contentDisposition) {\r\n return this.handleDownload(body, contentDisposition, contentType, successDetailKey);\r\n }\r\n\r\n this.handleViewHtml(body, htmlTitle);\r\n return null;\r\n }\r\n\r\n downloadResponse(response: HttpResponse<Blob | string>): boolean {\r\n const body = response.body;\r\n\r\n if (!body) {\r\n return false;\r\n }\r\n\r\n const contentDisposition = response.headers.get('content-disposition');\r\n\r\n if (!contentDisposition) {\r\n return false;\r\n }\r\n\r\n const contentType = response.headers.get('Content-Type') ?? (body instanceof Blob ? body.type : 'application/octet-stream');\r\n\r\n this.downloadBlob(body, contentDisposition, contentType);\r\n return true;\r\n }\r\n\r\n viewHtmlBody(body: Blob | null, htmlTitle = 'Rapor Sonucu'): void {\r\n if (!body) {\r\n return;\r\n }\r\n\r\n this.handleViewHtml(body, htmlTitle);\r\n }\r\n\r\n async handleJsonExcelResponse<T extends ExcelRaporuSonuc>(\r\n body: Blob | null,\r\n options: JsonExcelResponseOptions<T>\r\n ): Promise<ToastMessageOptions | null> {\r\n if (!body) {\r\n return null;\r\n }\r\n\r\n try {\r\n const jsonStr = await body.text();\r\n const result = Object.assign(options.createResult(), JSON.parse(jsonStr) as T);\r\n const fileName = options.getFileName?.(result) ?? options.fileName;\r\n\r\n if (!fileName) {\r\n return null;\r\n }\r\n\r\n await JsonToExcelParser.indir(result, fileName);\r\n\r\n return {\r\n severity: 'success',\r\n summary: this.translateService.instant('genel.bilgi'),\r\n detail: options.successDetail ?? this.translateService.instant(options.successDetailKey ?? '')\r\n };\r\n } catch (error) {\r\n console.error(options.errorLogMessage, error);\r\n return null;\r\n }\r\n }\r\n\r\n private handleDownload(body: BlobPart, contentDisposition: string, contentType: string, successDetailKey: string): ToastMessageOptions {\r\n this.downloadBlob(body, contentDisposition, contentType);\r\n\r\n return {\r\n severity: 'success',\r\n summary: this.translateService.instant('genel.bilgi'),\r\n detail: this.translateService.instant(successDetailKey)\r\n };\r\n }\r\n\r\n private downloadBlob(body: BlobPart, contentDisposition: string, contentType: string): void {\r\n const decodedContentDisposition = contentDisposition.replaceAll(\r\n /\\\\u([0-9A-Fa-f]{4})/g,\r\n (_, code: string) => String.fromCodePoint(Number.parseInt(code, 16))\r\n );\r\n const filename = GlobalFunctions.getFilenameFromContentDisposition(decodedContentDisposition);\r\n const blob = new Blob([body], { type: contentType });\r\n\r\n saveAs(blob, filename);\r\n }\r\n\r\n private handleViewHtml(body: Blob, htmlTitle: string): void {\r\n body.text().then((html: string) => {\r\n const wnd = window.open('', '_blank');\r\n\r\n if (!wnd) {\r\n return;\r\n }\r\n\r\n wnd.document.title = htmlTitle;\r\n\r\n const iframe = wnd.document.createElement('iframe');\r\n iframe.style.width = '100%';\r\n iframe.style.height = '100%';\r\n iframe.style.border = 'none';\r\n iframe.setAttribute('srcdoc', html);\r\n\r\n wnd.document.body.style.margin = '0';\r\n wnd.document.body.style.padding = '0';\r\n wnd.document.body.appendChild(iframe);\r\n });\r\n }\r\n}\r\n","import { XLHAlign, XLVAlign } from 'limitng/api/models/xl/xlConstants';\n\nexport type ExcelHucreDegeri = boolean | Date | number | string | null | undefined;\n\nexport class ExcelRaporuSonuc {\n book: IExcelRaporuBook = {\n author: 'MedPlan',\n activeSheetNo: 1\n };\n\n logo?: IExcelRaporuLogo;\n\n defaultFont: IExcelRaporuDefaultFont = {\n name: 'Calibri',\n size: 11\n };\n\n currentTableStyle = '';\n currentTable?: number;\n dosyaAdi?: string;\n sifirlariBasmaSayi = false;\n sifirlariBasmaTarih = false;\n\n // Eski format: üst bilgiler, notlar ve tablolar üst seviyede gelir\n ustBilgiler?: IExcelRaporuUstBilgiSatiri[];\n ustBilgi?: IExcelRaporuUstBilgiAyari;\n not?: IExcelRaporuNotAyari;\n notlar?: string[];\n tables?: IExcelRaporuTable[];\n\n // Yeni format: her sheet kendi tablolarını, üst bilgilerini ve notlarını taşır\n sheets: IExcelRaporuSheet[] = [];\n\n window: IExcelRaporuWindow = {\n displayGridLines: false\n };\n}\n\ninterface IExcelRaporuFont {\n name?: string;\n size?: number;\n color?: string;\n style?: number;\n}\n\ninterface IExcelRaporuDefaultFont {\n name: string;\n size: number;\n}\n\ninterface IExcelRaporuLogo {\n genislik?: number;\n yukseklik?: number;\n ustMarjin?: number;\n solMarjin?: number;\n ebatPixelmi?: boolean;\n ebat?: string;\n konum?: string;\n}\n\ninterface IExcelRaporuBook {\n author: string;\n activeSheetNo: number;\n subject?: string;\n comments?: string;\n}\n\ninterface IExcelRaporuWindow {\n displayGridLines: boolean;\n}\n\ninterface IExcelRaporuUstBilgiSatiri {\n rowNo?: number;\n ustBilgi: string;\n font?: IExcelRaporuFont;\n}\n\ninterface IExcelRaporuUstBilgiAyari {\n font?: IExcelRaporuFont;\n columnFontColors?: string[];\n columnFontStyles?: string[];\n}\n\ninterface IExcelRaporuNotAyari {\n font?: IExcelRaporuFont;\n}\n\ninterface IExcelRaporuBorder {\n type: string;\n lineStyle: string;\n weight: string;\n color: string;\n}\n\ninterface IExcelRaporuInterior {\n color: string;\n}\n\ninterface IExcelRaporuTableBand {\n basilacak?: boolean;\n satirSayisi?: number;\n ustBosluk?: number;\n font?: IExcelRaporuFont;\n interior?: IExcelRaporuInterior;\n border?: IExcelRaporuBorder;\n}\n\ninterface IExcelRaporuTableData {\n font?: IExcelRaporuFont;\n interior?: IExcelRaporuInterior;\n border?: IExcelRaporuBorder;\n}\n\ninterface IExcelRaporuColumnGroup {\n groupEnd: string;\n groupName: string;\n groupStart: string;\n}\n\ninterface IExcelRaporuTableColumnHeader {\n title: string;\n horizontalAlignment?: XLHAlign;\n verticalAlignment?: XLVAlign;\n}\n\ninterface IExcelRaporuTableColumnFooter {\n isFunction?: boolean;\n function?: number;\n title?: string;\n horizontalAlignment?: XLHAlign;\n verticalAlignment?: XLVAlign;\n}\n\ninterface IExcelRaporuTableColumn {\n property: string;\n arrayType: number;\n header: IExcelRaporuTableColumnHeader;\n footer?: IExcelRaporuTableColumnFooter;\n horizontalAlignment?: XLHAlign;\n verticalAlignment?: XLVAlign;\n format?: number;\n width?: number;\n columnNo?: number;\n}\n\ninterface IExcelRaporuSatirRenkBilgisi {\n color: string;\n rowNo: number;\n}\n\ninterface IExcelRaporuSatirYuksekligi {\n height: number;\n rowNo: number;\n}\n\ninterface IExcelRaporuTable {\n columns: IExcelRaporuTableColumn[];\n columnGroup?: IExcelRaporuColumnGroup[];\n header?: IExcelRaporuTableBand;\n data?: IExcelRaporuTableData;\n footer?: IExcelRaporuTableBand;\n tableNo?: number;\n collection: Record<string, ExcelHucreDegeri>[];\n sol?: number;\n ust?: number;\n veriKaynagi?: string;\n sheetName?: string;\n hiddenRows?: number[];\n sort?: number[];\n rows?: string[];\n autoFit?: boolean;\n columnFontNames?: string[];\n columnFontSizes?: number[];\n columnFontColors?: string[];\n columnFontStyles?: number[];\n columnInteriorColors?: string[];\n columnHeaderFontNames?: string[];\n columnHeaderFontSizes?: number[];\n columnHeaderFontColors?: string[];\n columnHeaderFontStyles?: number[];\n columnHeaderInteriorColors?: string[];\n columnFooterFontNames?: string[];\n columnFooterFontSizes?: number[];\n columnFooterFontColors?: string[];\n columnFooterFontStyles?: number[];\n columnFooterInteriorColors?: string[];\n rowFontNames?: string[];\n rowFontSizes?: number[];\n rowFontColors?: IExcelRaporuSatirRenkBilgisi[];\n rowFontStyles?: number[];\n rowInteriorColors?: IExcelRaporuSatirRenkBilgisi[];\n rowHeights?: IExcelRaporuSatirYuksekligi[];\n rowFormats?: string[];\n rowHorizontalAlignments?: XLHAlign[];\n rowVerticalAlignments?: XLVAlign[];\n cellFontNames?: string[];\n cellFontSizes?: number[];\n cellFontColors?: string[];\n cellFontStyles?: number[];\n cellInteriorColors?: string[];\n cellFormats?: string[];\n cellHorizontalAlignments?: XLHAlign[];\n cellVerticalAlignments?: XLVAlign[];\n rangeFontNames?: string[];\n rangeFontSizes?: number[];\n rangeFontColors?: string[];\n rangeFontStyles?: number[];\n rangeInteriorColors?: string[];\n rangeFormats?: string[];\n rangeHorizontalAlignments?: XLHAlign[];\n rangeVerticalAlignments?: XLVAlign[];\n}\n\ninterface IExcelRaporuPageSetup {\n orientation?: number;\n leftMargin?: number;\n topMargin?: number;\n bottomMargin?: number;\n rightMargin?: number;\n headerMargin?: number;\n footerMargin?: number;\n centerHorizontally?: boolean;\n centerVertically?: boolean;\n centerHeader?: string;\n leftHeader?: string;\n rightHeader?: string;\n centerFooter?: string;\n leftFooter?: string;\n rightFooter?: string;\n fitToPagesTall?: number;\n fitToPagesWide?: number;\n fitToPagesTAut?: boolean;\n fitToPagesWAut?: boolean;\n zoom?: boolean | number;\n printArea?: string;\n printAreaVar?: string;\n}\n\ninterface IExcelRaporuSheet {\n sheetNo?: number;\n sheetName?: string;\n zoom?: number;\n tables?: IExcelRaporuTable[];\n ustBilgi?: IExcelRaporuUstBilgiAyari;\n ustBilgiler?: IExcelRaporuUstBilgiSatiri[];\n notlar?: string[];\n not?: IExcelRaporuNotAyari;\n pageSetup?: IExcelRaporuPageSetup;\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public_api';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"limitng-blob-response-handler.mjs","sources":["../../src/app/components/blob-response-handler/models/excelRaporuSonuc.ts","../../src/app/components/blob-response-handler/models/jsonToExcelParser.ts","../../src/app/components/blob-response-handler/blob-response-handler.service.ts","../../src/app/components/blob-response-handler/limitng-blob-response-handler.ts"],"sourcesContent":["import { XLHAlign, XLVAlign } from 'limitng/api/models/xl/xlConstants';\n\nexport type ExcelHucreDegeri = boolean | Date | number | string | null | undefined;\n\nexport class ExcelRaporuSonuc {\n book: IExcelRaporuBook = {\n author: 'MedPlan',\n activeSheetNo: 1\n };\n\n logo?: IExcelRaporuLogo;\n\n defaultFont: IExcelRaporuDefaultFont = {\n name: 'Calibri',\n size: 11\n };\n\n currentTableStyle = '';\n currentTable?: number;\n dosyaAdi?: string;\n sifirlariBasmaSayi = false;\n sifirlariBasmaTarih = false;\n\n // Eski format: üst bilgiler, notlar ve tablolar üst seviyede gelir\n ustBilgiler?: IExcelRaporuUstBilgiSatiri[];\n ustBilgi?: IExcelRaporuUstBilgiAyari;\n not?: IExcelRaporuNotAyari;\n notlar?: string[];\n tables?: IExcelRaporuTable[];\n\n // Yeni format: her sheet kendi tablolarını, üst bilgilerini ve notlarını taşır\n sheets: IExcelRaporuSheet[] = [];\n\n window: IExcelRaporuWindow = {\n displayGridLines: false\n };\n}\n\ninterface IExcelRaporuFont {\n name?: string;\n size?: number;\n color?: string;\n style?: number;\n}\n\ninterface IExcelRaporuDefaultFont {\n name: string;\n size: number;\n}\n\ninterface IExcelRaporuLogo {\n genislik?: number;\n yukseklik?: number;\n ustMarjin?: number;\n solMarjin?: number;\n ebatPixelmi?: boolean;\n ebat?: string;\n konum?: string;\n}\n\ninterface IExcelRaporuBook {\n author: string;\n activeSheetNo: number;\n subject?: string;\n comments?: string;\n}\n\ninterface IExcelRaporuWindow {\n displayGridLines: boolean;\n}\n\ninterface IExcelRaporuUstBilgiSatiri {\n rowNo?: number;\n ustBilgi: string;\n font?: IExcelRaporuFont;\n}\n\ninterface IExcelRaporuUstBilgiAyari {\n font?: IExcelRaporuFont;\n columnFontColors?: string[];\n columnFontStyles?: string[];\n}\n\ninterface IExcelRaporuNotAyari {\n font?: IExcelRaporuFont;\n}\n\ninterface IExcelRaporuBorder {\n type: string;\n lineStyle: string;\n weight: string;\n color: string;\n}\n\ninterface IExcelRaporuInterior {\n color: string;\n}\n\ninterface IExcelRaporuTableBand {\n basilacak?: boolean;\n satirSayisi?: number;\n ustBosluk?: number;\n font?: IExcelRaporuFont;\n interior?: IExcelRaporuInterior;\n border?: IExcelRaporuBorder;\n}\n\ninterface IExcelRaporuTableData {\n font?: IExcelRaporuFont;\n interior?: IExcelRaporuInterior;\n border?: IExcelRaporuBorder;\n}\n\ninterface IExcelRaporuColumnGroup {\n groupEnd: string;\n groupName: string;\n groupStart: string;\n}\n\ninterface IExcelRaporuTableColumnHeader {\n title: string;\n horizontalAlignment?: XLHAlign;\n verticalAlignment?: XLVAlign;\n}\n\ninterface IExcelRaporuTableColumnFooter {\n isFunction?: boolean;\n function?: number;\n title?: string;\n horizontalAlignment?: XLHAlign;\n verticalAlignment?: XLVAlign;\n}\n\ninterface IExcelRaporuTableColumn {\n property: string;\n arrayType: number;\n header: IExcelRaporuTableColumnHeader;\n footer?: IExcelRaporuTableColumnFooter;\n horizontalAlignment?: XLHAlign;\n verticalAlignment?: XLVAlign;\n format?: number;\n width?: number;\n columnNo?: number;\n htmlKoduGelebilir?: boolean;\n}\n\ninterface IExcelRaporuSatirRenkBilgisi {\n color: string;\n rowNo: number;\n}\n\ninterface IExcelRaporuSatirYuksekligi {\n height: number;\n rowNo: number;\n}\n\ninterface IExcelRaporuTable {\n columns: IExcelRaporuTableColumn[];\n columnGroup?: IExcelRaporuColumnGroup[];\n header?: IExcelRaporuTableBand;\n data?: IExcelRaporuTableData;\n footer?: IExcelRaporuTableBand;\n tableNo?: number;\n collection: Record<string, ExcelHucreDegeri>[];\n sol?: number;\n ust?: number;\n veriKaynagi?: string;\n sheetName?: string;\n hiddenRows?: number[];\n sort?: number[];\n rows?: string[];\n autoFit?: boolean;\n columnFontNames?: string[];\n columnFontSizes?: number[];\n columnFontColors?: string[];\n columnFontStyles?: number[];\n columnInteriorColors?: string[];\n columnHeaderFontNames?: string[];\n columnHeaderFontSizes?: number[];\n columnHeaderFontColors?: string[];\n columnHeaderFontStyles?: number[];\n columnHeaderInteriorColors?: string[];\n columnFooterFontNames?: string[];\n columnFooterFontSizes?: number[];\n columnFooterFontColors?: string[];\n columnFooterFontStyles?: number[];\n columnFooterInteriorColors?: string[];\n rowFontNames?: string[];\n rowFontSizes?: number[];\n rowFontColors?: IExcelRaporuSatirRenkBilgisi[];\n rowFontStyles?: number[];\n rowInteriorColors?: IExcelRaporuSatirRenkBilgisi[];\n rowHeights?: IExcelRaporuSatirYuksekligi[];\n rowFormats?: string[];\n rowHorizontalAlignments?: XLHAlign[];\n rowVerticalAlignments?: XLVAlign[];\n cellFontNames?: string[];\n cellFontSizes?: number[];\n cellFontColors?: string[];\n cellFontStyles?: number[];\n cellInteriorColors?: string[];\n cellFormats?: string[];\n cellHorizontalAlignments?: XLHAlign[];\n cellVerticalAlignments?: XLVAlign[];\n rangeFontNames?: string[];\n rangeFontSizes?: number[];\n rangeFontColors?: string[];\n rangeFontStyles?: number[];\n rangeInteriorColors?: string[];\n rangeFormats?: string[];\n rangeHorizontalAlignments?: XLHAlign[];\n rangeVerticalAlignments?: XLVAlign[];\n}\n\ninterface IExcelRaporuPageSetup {\n orientation?: number;\n leftMargin?: number;\n topMargin?: number;\n bottomMargin?: number;\n rightMargin?: number;\n headerMargin?: number;\n footerMargin?: number;\n centerHorizontally?: boolean;\n centerVertically?: boolean;\n centerHeader?: string;\n leftHeader?: string;\n rightHeader?: string;\n centerFooter?: string;\n leftFooter?: string;\n rightFooter?: string;\n fitToPagesTall?: number;\n fitToPagesWide?: number;\n fitToPagesTAut?: boolean;\n fitToPagesWAut?: boolean;\n zoom?: boolean | number;\n printArea?: string;\n printAreaVar?: string;\n}\n\ninterface IExcelRaporuSheet {\n sheetNo?: number;\n sheetName?: string;\n zoom?: number;\n tables?: IExcelRaporuTable[];\n ustBilgi?: IExcelRaporuUstBilgiAyari;\n ustBilgiler?: IExcelRaporuUstBilgiSatiri[];\n notlar?: string[];\n not?: IExcelRaporuNotAyari;\n pageSetup?: IExcelRaporuPageSetup;\n}\n","import ExcelJS from 'exceljs';\nimport saveAs from 'file-saver';\nimport { FontStyle, NumberFormatlar } from 'limitng/api/models/fourDConstants';\nimport { XLHAlign, XLVAlign } from 'limitng/api/models/xl/xlConstants';\nimport { ExcelRaporuSonuc } from './excelRaporuSonuc';\n\ntype TExcelTable = NonNullable<ExcelRaporuSonuc['tables']>[number];\ntype TExcelBook = ExcelRaporuSonuc['book'];\ntype TExcelTableColumn = TExcelTable['columns'][number];\ntype TExcelTableRow = TExcelTable['collection'][number];\ntype TExcelSheet = ExcelRaporuSonuc['sheets'][number];\ntype TExcelPageSetup = NonNullable<TExcelSheet['pageSetup']>;\ntype TExcelUstBilgi = NonNullable<ExcelRaporuSonuc['ustBilgiler']>[number];\ntype TDefaultFont = ExcelRaporuSonuc['defaultFont'];\n\ninterface IExcelFont {\n color?: string;\n name?: string;\n size?: number;\n style?: number;\n}\n\ninterface ISheetGrup {\n sheetName: string;\n sheetNo?: number;\n tables: TExcelTable[];\n}\n\ninterface IHazirHucreDegeri {\n deger: ExcelJS.CellValue;\n fontColorArgb?: string;\n}\n\nexport interface IJsonToExcelSheetOptions {\n pageSetup?: TExcelSheet['pageSetup'];\n zoom?: number;\n}\n\nexport interface IJsonToExcelTableOptions {\n autoFit?: TExcelTable['autoFit'];\n data?: TExcelTable['data'];\n footer?: TExcelTable['footer'];\n header?: TExcelTable['header'];\n sol?: TExcelTable['sol'];\n ust?: TExcelTable['ust'];\n}\n\nexport class JsonToExcelTableBuilder<TRow extends TExcelTableRow = TExcelTableRow> {\n constructor(private readonly table: TExcelTable) {}\n\n addColumn(column: TExcelTableColumn): this {\n this.table.columns.push(column);\n return this;\n }\n\n setRows(rows: TRow[]): this {\n this.table.collection = rows;\n return this;\n }\n\n setStartColumn(sol: number): this {\n this.table.sol = sol;\n return this;\n }\n\n setStartRow(ust: number): this {\n this.table.ust = ust;\n return this;\n }\n\n getColumnSayisi(): number {\n return this.table.columns.length;\n }\n}\n\nexport class JsonToExcelSheetBuilder {\n constructor(private readonly sheet: TExcelSheet) {}\n\n addTable<TRow extends TExcelTableRow = TExcelTableRow>(\n rows: TRow[],\n options: IJsonToExcelTableOptions = {}\n ): JsonToExcelTableBuilder<TRow> {\n const table: TExcelTable = {\n collection: rows,\n columns: [],\n ...(options.autoFit !== undefined && { autoFit: options.autoFit }),\n ...(options.data && { data: options.data }),\n ...(options.footer && { footer: options.footer }),\n ...(options.header && { header: options.header }),\n ...(options.sol !== undefined && { sol: options.sol }),\n ...(options.ust !== undefined && { ust: options.ust })\n };\n\n this.sheet.tables ??= [];\n this.sheet.tables.push(table);\n\n return new JsonToExcelTableBuilder<TRow>(table);\n }\n\n addUstBilgi(ustBilgi: string, font?: TExcelUstBilgi['font']): this {\n this.sheet.ustBilgiler ??= [];\n this.sheet.ustBilgiler.push(JsonToExcelParser.ustBilgiEkle(ustBilgi, font));\n return this;\n }\n\n getUstBilgiSayisi(): number {\n return this.sheet.ustBilgiler?.length ?? 0;\n }\n\n getSheetNo(): number | undefined {\n return this.sheet.sheetNo;\n }\n\n setSheetName(sheetName: string): this {\n this.sheet.sheetName = sheetName;\n return this;\n }\n\n setZoom(zoom: number): this {\n this.sheet.zoom = zoom;\n return this;\n }\n}\n\nexport class JsonToExcelReportBuilder {\n private readonly sonuc = new ExcelRaporuSonuc();\n\n addSheet(sheetName: string, options: IJsonToExcelSheetOptions = {}): JsonToExcelSheetBuilder {\n const sheet: TExcelSheet = {\n sheetName,\n sheetNo: this.sonuc.sheets.length + 1,\n ...(options.pageSetup && { pageSetup: options.pageSetup }),\n ...(options.zoom !== undefined && { zoom: options.zoom })\n };\n\n this.sonuc.sheets.push(sheet);\n\n return new JsonToExcelSheetBuilder(sheet);\n }\n\n build(): ExcelRaporuSonuc {\n return this.sonuc;\n }\n\n setAuthor(author: string): this {\n this.sonuc.book.author = author;\n return this;\n }\n\n setCurrentTableStyle(currentTableStyle: string): this {\n this.sonuc.currentTableStyle = currentTableStyle;\n return this;\n }\n\n setSubject(subject: string): this {\n this.sonuc.book.subject = subject;\n return this;\n }\n}\n\nexport class JsonToExcelParser {\n static async indir(sonuc: ExcelRaporuSonuc, dosyaAdi: string): Promise<void> {\n const blob = await this.blobOlustur(sonuc);\n const normalizeDosyaAdi = this.dosyaAdiDuzenle(dosyaAdi);\n saveAs(blob, `${normalizeDosyaAdi}.xlsx`);\n }\n\n static async blobOlustur(sonuc: ExcelRaporuSonuc): Promise<Blob> {\n const workbook = this.workbookOlustur(sonuc);\n const buffer = await workbook.xlsx.writeBuffer();\n\n return new Blob([buffer], {\n type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'\n });\n }\n\n static standartPageSetupOlustur(): TExcelPageSetup {\n return {\n bottomMargin: 1,\n centerHorizontally: true,\n centerVertically: true,\n fitToPagesTall: 1,\n fitToPagesWide: 1,\n leftMargin: 1,\n orientation: 2,\n rightMargin: 1,\n topMargin: 1\n };\n }\n\n static ustBilgiEkle(ustBilgi: string, font?: TExcelUstBilgi['font']): TExcelUstBilgi {\n return font ? { font, ustBilgi } : { ustBilgi };\n }\n\n static raporOlustur(): JsonToExcelReportBuilder {\n return new JsonToExcelReportBuilder();\n }\n\n private static workbookOlustur(sonuc: ExcelRaporuSonuc): ExcelJS.Workbook {\n const workbook = new ExcelJS.Workbook();\n workbook.created = new Date();\n workbook.calcProperties.fullCalcOnLoad = true;\n\n const gridLinesGorunur = sonuc.window.displayGridLines;\n\n if (this.yeniYapiMi(sonuc)) {\n workbook.creator = sonuc.book.author || 'MedPlan';\n workbook.subject = '';\n workbook.description = '';\n this.yeniFormatSheetsYaz(workbook, sonuc, gridLinesGorunur);\n } else {\n workbook.creator = sonuc.book.author || 'MedPlan';\n workbook.subject = this.konuVer(sonuc.book, sonuc.ustBilgiler?.[0]?.ustBilgi);\n workbook.description = sonuc.book.comments || '';\n this.eskiFormatSheetsYaz(workbook, sonuc, gridLinesGorunur);\n }\n\n this.aktifSayfayiAyarla(workbook, sonuc.book.activeSheetNo, workbook.worksheets.length);\n\n return workbook;\n }\n\n private static yeniYapiMi(sonuc: ExcelRaporuSonuc): boolean {\n const ilkSheet = sonuc.sheets[0] as unknown as { tables?: unknown };\n if (Array.isArray(ilkSheet?.tables)) {\n return true;\n }\n\n const runtimeSonuc = sonuc as unknown as { tables?: unknown };\n\n return !Array.isArray(runtimeSonuc.tables);\n }\n\n private static yeniFormatSheetsYaz(workbook: ExcelJS.Workbook, sonuc: ExcelRaporuSonuc, gridLinesGorunur: boolean): void {\n for (let index = 0; index < sonuc.sheets.length; index++) {\n const sheet = sonuc.sheets[index]!;\n const sheetAdi = this.sayfaAdiDuzenle(sheet.sheetName || 'Rapor', index + 1);\n const worksheet = workbook.addWorksheet(sheetAdi);\n const zoomScale = sheet.zoom && sheet.zoom > 0 ? sheet.zoom : undefined;\n worksheet.views = [{ showGridLines: gridLinesGorunur, ...(zoomScale !== undefined && { zoomScale }) }];\n this.sayfaDuzeniniBelirle(worksheet, sheet);\n\n const ustBilgiler = sheet.ustBilgiler ?? [];\n this.yeniFormatUstBilgileriYaz(worksheet, ustBilgiler, sonuc.defaultFont);\n\n let sonSatir = ustBilgiler.length + 1;\n for (const table of sheet.tables ?? []) {\n sonSatir = Math.max(sonSatir, this.tabloyuYaz(worksheet, sonuc, table));\n }\n\n if (sheet.notlar?.length) {\n this.notlariYazList(worksheet, sheet.notlar, sheet.not?.font, sonSatir + 2, sonuc.defaultFont);\n }\n }\n\n if (sonuc.sheets.length === 0) {\n const worksheet = workbook.addWorksheet('Rapor');\n worksheet.views = [{ showGridLines: gridLinesGorunur }];\n }\n }\n\n private static eskiFormatSheetsYaz(workbook: ExcelJS.Workbook, sonuc: ExcelRaporuSonuc, gridLinesGorunur: boolean): void {\n const tablesBySheet = this.sheetBazliTablolar(sonuc);\n const ustBilgiler = sonuc.ustBilgiler ?? [];\n const notlar = sonuc.notlar ?? [];\n\n for (const sheetGrup of tablesBySheet) {\n const worksheet = workbook.addWorksheet(sheetGrup.sheetName);\n worksheet.views = [{ showGridLines: gridLinesGorunur }];\n\n this.ustBilgileriYaz(worksheet, ustBilgiler, sonuc.defaultFont);\n\n let sonSatir = 1;\n for (const table of sheetGrup.tables) {\n sonSatir = Math.max(sonSatir, this.tabloyuYaz(worksheet, sonuc, table));\n }\n\n this.notlariYazList(worksheet, notlar, sonuc.not?.font, sonSatir + 2, sonuc.defaultFont);\n }\n\n if (tablesBySheet.length === 0) {\n const worksheet = workbook.addWorksheet(this.bosRaporSheetAdiniVer(sonuc));\n worksheet.views = [{ showGridLines: gridLinesGorunur }];\n this.ustBilgileriYaz(worksheet, ustBilgiler, sonuc.defaultFont);\n this.notlariYazList(worksheet, notlar, sonuc.not?.font, ustBilgiler.length + 2, sonuc.defaultFont);\n }\n }\n\n private static sheetBazliTablolar(sonuc: ExcelRaporuSonuc): ISheetGrup[] {\n const grouped = new Map<string, ISheetGrup>();\n\n for (const table of sonuc.tables ?? []) {\n const sheetNo = this.tableSheetNoVer(table);\n const sheetKey = this.sheetKeyVer(table, sheetNo, grouped.size + 1);\n const existing = grouped.get(sheetKey);\n\n if (existing) {\n existing.tables.push(table);\n continue;\n }\n\n grouped.set(sheetKey, {\n sheetName: this.sheetAdiniBelirle(sonuc, table, grouped.size + 1, sheetNo),\n ...(sheetNo !== undefined && { sheetNo }),\n tables: [table]\n });\n }\n\n return Array.from(grouped.values()).sort((a, b) => this.sheetGrupSirasiVer(a) - this.sheetGrupSirasiVer(b));\n }\n\n private static tableSheetNoVer(table: TExcelTable): number | undefined {\n const runtimeTable = table as TExcelTable & { sheetNo?: number };\n\n return runtimeTable.sheetNo;\n }\n\n private static sheetKeyVer(table: TExcelTable, sheetNo: number | undefined, index: number): string {\n if (sheetNo !== undefined) {\n return `sheet-no-${sheetNo}`;\n }\n\n const eskiSheetName = table.sheetName?.trim();\n if (eskiSheetName) {\n return `sheet-name-${eskiSheetName}`;\n }\n\n return `sheet-index-${index}`;\n }\n\n private static sheetAdiniBelirle(\n sonuc: ExcelRaporuSonuc,\n table: TExcelTable,\n index: number,\n sheetNo: number | undefined\n ): string {\n const jsonSheet = this.jsonSheetBul(sonuc.sheets, sheetNo, index);\n if (jsonSheet?.sheetName?.trim()) {\n return this.sayfaAdiDuzenle(jsonSheet.sheetName, index);\n }\n\n return this.sayfaAdiDuzenle(table.sheetName || 'Rapor', index);\n }\n\n private static jsonSheetBul(\n sheets: TExcelSheet[],\n sheetNo: number | undefined,\n index: number\n ): TExcelSheet | undefined {\n if (sheetNo !== undefined) {\n return sheets.find(sheet => sheet.sheetNo === sheetNo);\n }\n\n return sheets.find(sheet => sheet.sheetNo === index) ?? sheets[index - 1];\n }\n\n private static konuVer(book: TExcelBook, ilkUstBilgi: string | undefined): string {\n return book.subject || ilkUstBilgi || 'Rapor';\n }\n\n private static bosRaporSheetAdiniVer(sonuc: ExcelRaporuSonuc): string {\n const ilkSheetAdi = sonuc.sheets[0]?.sheetName;\n\n return this.sayfaAdiDuzenle(ilkSheetAdi || 'Rapor', 1);\n }\n\n private static aktifSayfayiAyarla(workbook: ExcelJS.Workbook, activeSheetNo: number, toplamSheetSayisi: number) {\n const aktifTab = this.aktifTabNoVer(activeSheetNo, toplamSheetSayisi);\n if (aktifTab === undefined) {\n return;\n }\n\n workbook.views = [{\n activeTab: aktifTab,\n firstSheet: aktifTab,\n height: 20000,\n visibility: 'visible',\n width: 20000,\n x: 0,\n y: 0\n }];\n }\n\n private static aktifTabNoVer(activeSheetNo: number, toplamSheetSayisi: number): number | undefined {\n if (toplamSheetSayisi <= 0) {\n return undefined;\n }\n\n const aktifSheetNo = Number.isFinite(activeSheetNo) && activeSheetNo > 0 ? activeSheetNo : 1;\n\n return Math.min(aktifSheetNo - 1, toplamSheetSayisi - 1);\n }\n\n private static sheetGrupSirasiVer(sheetGrup: ISheetGrup): number {\n return sheetGrup.sheetNo ?? Number.MAX_SAFE_INTEGER;\n }\n\n private static yeniFormatUstBilgileriYaz(\n worksheet: ExcelJS.Worksheet,\n ustBilgiler: TExcelUstBilgi[],\n defaultFont: TDefaultFont\n ): void {\n for (let index = 0; index < ustBilgiler.length; index++) {\n const ustBilgi = ustBilgiler[index]!;\n const hucre = worksheet.getCell(index + 1, 1);\n hucre.value = ustBilgi.ustBilgi;\n this.hucreFontunuUygula(hucre, ustBilgi.font, defaultFont);\n hucre.alignment = { horizontal: 'left', vertical: 'middle', wrapText: false };\n }\n }\n\n private static ustBilgileriYaz(\n worksheet: ExcelJS.Worksheet,\n ustBilgiler: TExcelUstBilgi[],\n defaultFont: TDefaultFont\n ): void {\n for (const ustBilgi of ustBilgiler) {\n const hucre = worksheet.getCell(ustBilgi.rowNo ?? 1, 1);\n hucre.value = ustBilgi.ustBilgi;\n this.hucreFontunuUygula(hucre, ustBilgi.font, defaultFont);\n hucre.alignment = { horizontal: 'left', vertical: 'middle', wrapText: false };\n }\n }\n\n private static notlariYazList(\n worksheet: ExcelJS.Worksheet,\n notlar: string[],\n notFont: IExcelFont | undefined,\n baslangicSatiri: number,\n defaultFont: TDefaultFont\n ): void {\n let satirNo = baslangicSatiri;\n for (const not of notlar) {\n const cell = worksheet.getCell(satirNo, 1);\n cell.value = not;\n this.hucreFontunuUygula(cell, notFont, defaultFont);\n cell.alignment = { vertical: 'middle', wrapText: true };\n satirNo++;\n }\n }\n\n private static sayfaDuzeniniBelirle(worksheet: ExcelJS.Worksheet, sheet: TExcelSheet): void {\n const { pageSetup } = sheet;\n if (!pageSetup) {\n return;\n }\n\n if (pageSetup.orientation === 2) {\n worksheet.pageSetup.orientation = 'landscape';\n } else if (pageSetup.orientation === 1) {\n worksheet.pageSetup.orientation = 'portrait';\n }\n\n const hasMargin =\n pageSetup.leftMargin !== undefined ||\n pageSetup.rightMargin !== undefined ||\n pageSetup.topMargin !== undefined ||\n pageSetup.bottomMargin !== undefined ||\n pageSetup.headerMargin !== undefined ||\n pageSetup.footerMargin !== undefined;\n\n if (hasMargin) {\n worksheet.pageSetup.margins = {\n left: pageSetup.leftMargin ?? 0.7,\n right: pageSetup.rightMargin ?? 0.7,\n top: pageSetup.topMargin ?? 0.75,\n bottom: pageSetup.bottomMargin ?? 0.75,\n header: pageSetup.headerMargin ?? 0.3,\n footer: pageSetup.footerMargin ?? 0.3\n };\n }\n\n if (pageSetup.centerHorizontally !== undefined) {\n worksheet.pageSetup.horizontalCentered = pageSetup.centerHorizontally;\n }\n if (pageSetup.centerVertically !== undefined) {\n worksheet.pageSetup.verticalCentered = pageSetup.centerVertically;\n }\n\n const fitTall = pageSetup.fitToPagesTall;\n const fitWide = pageSetup.fitToPagesWide;\n if (fitTall !== undefined || fitWide !== undefined || pageSetup.fitToPagesTAut || pageSetup.fitToPagesWAut) {\n worksheet.pageSetup.fitToPage = true;\n worksheet.pageSetup.fitToHeight = pageSetup.fitToPagesTAut ? 0 : (fitTall ?? 1);\n worksheet.pageSetup.fitToWidth = pageSetup.fitToPagesWAut ? 0 : (fitWide ?? 1);\n }\n\n if (typeof pageSetup.zoom === 'number' && pageSetup.zoom > 0) {\n worksheet.pageSetup.scale = pageSetup.zoom;\n }\n\n if (pageSetup.printArea) {\n worksheet.pageSetup.printArea = pageSetup.printArea;\n }\n\n const pageHeader = this.baslikAltbilgiMetniOlustur(pageSetup.leftHeader, pageSetup.centerHeader, pageSetup.rightHeader);\n const pageFooter = this.baslikAltbilgiMetniOlustur(pageSetup.leftFooter, pageSetup.centerFooter, pageSetup.rightFooter);\n if (pageHeader) {\n worksheet.headerFooter.oddHeader = pageHeader;\n }\n if (pageFooter) {\n worksheet.headerFooter.oddFooter = pageFooter;\n }\n }\n\n private static baslikAltbilgiMetniOlustur(sol?: string, orta?: string, sag?: string): string | undefined {\n const parcalar: string[] = [];\n if (sol) {\n parcalar.push(`&L${sol}`);\n }\n if (orta) {\n parcalar.push(`&C${orta}`);\n }\n if (sag) {\n parcalar.push(`&R${sag}`);\n }\n return parcalar.length ? parcalar.join('') : undefined;\n }\n\n private static tabloyuYaz(worksheet: ExcelJS.Worksheet, sonuc: ExcelRaporuSonuc, table: TExcelTable): number {\n if (!table.columns.length) {\n return table.ust ?? 1;\n }\n\n const startRow = Math.max(1, table.ust ?? 1);\n const startCol = Math.max(1, table.sol ?? 1);\n const gecerliTableStyle = this.gecerliTableStyleVer(sonuc.currentTableStyle);\n const headerTitlelari = table.columns.map(column => this.baslikMetniniHazirla(column.header.title || ''));\n const gorunenBaslikMetinleri = headerTitlelari.map(title => title.replaceAll('\\n', ' '));\n const tabloKolonAdlari = this.benzersizKolonAdlariOlustur(gorunenBaslikMetinleri);\n\n const headerFont = table.header?.font;\n const uygulanacakHeaderFont = headerFont?.color ? headerFont : {\n ...headerFont,\n color: 'FFFFFFFF'\n };\n const dataFont = table.data?.font;\n const hiddenRowSet = new Set(table.hiddenRows ?? []);\n\n const formulCeller: Array<{\n colIndex: number;\n column: TExcelTableColumn;\n formula: ExcelJS.CellFormulaValue;\n rowIndex: number;\n }> = [];\n const hucreFontRenkleri: Array<Array<string | undefined>> = [];\n const satirlar = table.collection.map((rowData, rowIndex) =>\n table.columns.map((column, colIndex) => {\n const hazirHucre = this.hucreDegeriniHazirla(rowData, column, sonuc.sifirlariBasmaSayi);\n hucreFontRenkleri[rowIndex] ??= [];\n hucreFontRenkleri[rowIndex]![colIndex] = hazirHucre.fontColorArgb;\n\n if (hazirHucre.deger !== null && typeof hazirHucre.deger === 'object' && 'formula' in hazirHucre.deger) {\n formulCeller.push({ rowIndex, colIndex, column, formula: hazirHucre.deger as ExcelJS.CellFormulaValue });\n return '' as ExcelJS.CellValue;\n }\n return hazirHucre.deger;\n })\n );\n\n this.kolonGrubuYaz(worksheet, startRow, startCol, table);\n\n const tableStyle = this.tableStyleDonustur(gecerliTableStyle);\n worksheet.addTable({\n name: this.tabloAdiOlustur(worksheet.name, startRow, startCol),\n ref: worksheet.getCell(startRow, startCol).address,\n headerRow: true,\n totalsRow: false,\n ...(tableStyle && { style: tableStyle }),\n columns: tabloKolonAdlari.map(ad => ({ name: ad, filterButton: true })),\n rows: satirlar\n });\n\n this.kolonGenislikleriniUygula(worksheet, startCol, table.columns, satirlar);\n\n const headerRow = worksheet.getRow(startRow);\n for (let colIndex = 0; colIndex < table.columns.length; colIndex++) {\n const column = table.columns[colIndex]!;\n const cell = headerRow.getCell(startCol + colIndex);\n cell.alignment = {\n horizontal: this.yatayHizaDonustur(column.header.horizontalAlignment),\n vertical: 'bottom',\n wrapText: false\n };\n this.hucreFontunuUygula(cell, uygulanacakHeaderFont, sonuc.defaultFont);\n }\n\n for (let rowIndex = 0; rowIndex < table.collection.length; rowIndex++) {\n const wsRow = worksheet.getRow(startRow + 1 + rowIndex);\n const satir1Bazli = rowIndex + 1;\n\n if (hiddenRowSet.has(satir1Bazli)) {\n wsRow.hidden = true;\n }\n\n const rowHeight = table.rowHeights?.find(rh => rh.rowNo === satir1Bazli);\n if (rowHeight?.height) {\n wsRow.height = rowHeight.height;\n }\n\n for (let colIndex = 0; colIndex < table.columns.length; colIndex++) {\n const column = table.columns[colIndex]!;\n const cell = wsRow.getCell(startCol + colIndex);\n const hucreDegeri = satirlar[rowIndex]![colIndex]!;\n cell.value = hucreDegeri;\n this.hucreFontunuUygula(cell, dataFont, sonuc.defaultFont);\n const hucreFontRengi = hucreFontRenkleri[rowIndex]?.[colIndex];\n if (hucreFontRengi) {\n cell.font = { ...(cell.font ?? {}), color: { argb: hucreFontRengi } };\n }\n const numFmt = this.numberFormatDonustur(column.format);\n if (numFmt) {\n cell.numFmt = numFmt;\n } else if (hucreDegeri instanceof Date) {\n cell.numFmt = this.varsayilanTarihFormatiniVer();\n }\n cell.alignment = {\n horizontal: this.hucreYatayHizasiniBelirle(hucreDegeri, column),\n vertical: this.dikeyHizaDonustur(column.verticalAlignment),\n wrapText: false\n };\n\n // Sütun rengi\n const colFontColor = table.columnFontColors?.[colIndex];\n if (colFontColor) {\n const argb = this.argbDonustur(colFontColor);\n if (argb) {\n cell.font = { ...(cell.font ?? {}), color: { argb } };\n }\n }\n const colIntColor = table.columnInteriorColors?.[colIndex];\n if (colIntColor) {\n const argb = this.argbDonustur(colIntColor);\n if (argb) {\n cell.fill = { type: 'pattern', pattern: 'solid', fgColor: { argb } };\n }\n }\n\n // Satır rengi (sütun rengini ezer)\n const rowFontColor = table.rowFontColors?.find(rc => rc.rowNo === satir1Bazli);\n if (rowFontColor) {\n const argb = this.argbDonustur(rowFontColor.color);\n if (argb) {\n cell.font = { ...(cell.font ?? {}), color: { argb } };\n }\n }\n const rowIntColor = table.rowInteriorColors?.find(rc => rc.rowNo === satir1Bazli);\n if (rowIntColor) {\n const argb = this.argbDonustur(rowIntColor.color);\n if (argb) {\n cell.fill = { type: 'pattern', pattern: 'solid', fgColor: { argb } };\n }\n }\n }\n }\n\n for (const { rowIndex, colIndex, column, formula } of formulCeller) {\n const cell = worksheet.getRow(startRow + 1 + rowIndex).getCell(startCol + colIndex);\n cell.value = formula;\n cell.alignment = {\n ...(cell.alignment ?? {}),\n horizontal: this.hucreYatayHizasiniBelirle(formula, column)\n };\n }\n\n let sonSatir = startRow + table.collection.length;\n\n // Footer satırları\n const footer = table.footer;\n if (footer?.basilacak) {\n const ustBosluk = footer.ustBosluk ?? 0;\n const satirSayisi = footer.satirSayisi ?? 1;\n const footerBasSatir = sonSatir + 1 + ustBosluk;\n\n for (let fi = 0; fi < satirSayisi; fi++) {\n const footerRow = worksheet.getRow(footerBasSatir + fi);\n for (let colIndex = 0; colIndex < table.columns.length; colIndex++) {\n const column = table.columns[colIndex]!;\n const cell = footerRow.getCell(startCol + colIndex);\n this.hucreFontunuUygula(cell, footer.font, sonuc.defaultFont);\n\n const colFooter = column.footer;\n if (!colFooter?.isFunction && colFooter?.title) {\n cell.value = colFooter.title;\n }\n cell.alignment = {\n horizontal: this.yatayHizaDonustur(colFooter?.horizontalAlignment),\n vertical: 'middle',\n wrapText: false\n };\n }\n }\n\n sonSatir = footerBasSatir + satirSayisi - 1;\n }\n\n return sonSatir;\n }\n\n private static kolonGenislikleriniUygula(\n worksheet: ExcelJS.Worksheet,\n startCol: number,\n columns: TExcelTableColumn[],\n satirlar: ExcelJS.CellValue[][]\n ): void {\n const filtreButonuBoslukPayi = 1.25;\n const veriSagBoslukPayi = 1;\n\n for (let index = 0; index < columns.length; index++) {\n const worksheetColumn = worksheet.getColumn(startCol + index);\n const baslikUzunlugu = this.metinUzunlugu(this.baslikMetniniHazirla(columns[index]!.header.title));\n const veriUzunlugu = satirlar.reduce((max, satir) => Math.max(max, this.hucreMetinUzunlugu(satir[index]!)), 0);\n const tasarimGenisligi = (columns[index]!.width ?? 0) > 0 ? Math.round(columns[index]!.width! / 7) : 0;\n worksheetColumn.width = Math.max(\n 10,\n tasarimGenisligi,\n baslikUzunlugu + 2 + filtreButonuBoslukPayi,\n veriUzunlugu + 2 + veriSagBoslukPayi\n );\n }\n }\n\n private static baslikMetniniHazirla(metin: string): string {\n return metin\n .replaceAll('\\r\\n', ' ')\n .replaceAll('\\r', ' ')\n .replaceAll('\\n', ' ')\n .trim();\n }\n\n private static hucreMetinUzunlugu(deger: ExcelJS.CellValue): number {\n if (deger === null || deger === undefined) {\n return 0;\n }\n\n if (typeof deger === 'string') {\n return this.metinUzunlugu(deger);\n }\n\n if (typeof deger === 'number' || typeof deger === 'boolean') {\n return String(deger).length;\n }\n\n if (deger instanceof Date) {\n return '14.05.2026 09:13:29'.length;\n }\n\n if (typeof deger === 'object' && 'formula' in deger) {\n return this.metinUzunlugu(String(deger.formula));\n }\n\n return this.metinUzunlugu(String(deger));\n }\n\n private static hucreYatayHizasiniBelirle(\n deger: ExcelJS.CellValue,\n column: TExcelTableColumn\n ): ExcelJS.Alignment['horizontal'] {\n if (typeof deger === 'number') {\n return 'right';\n }\n\n if (typeof deger === 'object' && deger !== null && 'formula' in deger && this.sayisalFormatMi(column.format)) {\n return 'right';\n }\n\n return this.yatayHizaDonustur(column.horizontalAlignment);\n }\n\n private static sayisalFormatMi(format: number | undefined): boolean {\n switch (format) {\n case NumberFormatlar.long:\n case NumberFormatlar.real:\n case NumberFormatlar.yuzde_BirHane:\n case 2:\n case 5:\n case 7:\n case 11:\n case 12:\n return true;\n\n default:\n return false;\n }\n }\n\n private static metinUzunlugu(metin: string): number {\n return metin\n .replaceAll('\\r', '')\n .split('\\n')\n .reduce((max, parca) => Math.max(max, parca.trim().length), 0);\n }\n\n private static kolonGrubuYaz(\n worksheet: ExcelJS.Worksheet,\n startRow: number,\n startCol: number,\n table: TExcelTable\n ): void {\n const columnGroups = table.columnGroup;\n if (!columnGroups?.length || startRow <= 1) {\n return;\n }\n\n const grupSatiri = startRow - 1;\n for (const columnGroup of columnGroups) {\n const baslangicIndex = table.columns.findIndex(column => column.property === columnGroup.groupStart);\n const bitisIndex = table.columns.findIndex(column => column.property === columnGroup.groupEnd);\n const baslangicKolonu = baslangicIndex >= 0 ? startCol + baslangicIndex : undefined;\n const bitisKolonu = bitisIndex >= 0 ? startCol + bitisIndex : undefined;\n if (!baslangicKolonu || !bitisKolonu || bitisKolonu < baslangicKolonu) {\n continue;\n }\n\n worksheet.mergeCells(grupSatiri, baslangicKolonu, grupSatiri, bitisKolonu);\n\n const grupHucre = worksheet.getCell(grupSatiri, baslangicKolonu);\n grupHucre.value = columnGroup.groupName;\n grupHucre.alignment = { horizontal: 'center', vertical: 'middle' };\n grupHucre.font = { bold: true, size: 11, color: { argb: 'FFF79646' } };\n grupHucre.fill = {\n type: 'pattern',\n pattern: 'solid',\n fgColor: { argb: 'FFFFFFFF' }\n };\n\n for (let col = baslangicKolonu; col <= bitisKolonu; col++) {\n const hucre = worksheet.getCell(grupSatiri, col);\n hucre.border = {\n ...hucre.border,\n top: { style: 'medium', color: { argb: 'FFF79646' } },\n ...(col === baslangicKolonu ? { left: { style: 'medium', color: { argb: 'FFF79646' } } } : (hucre.border?.left ? { left: hucre.border.left } : {})),\n ...(col === bitisKolonu ? { right: { style: 'medium', color: { argb: 'FFF79646' } } } : (hucre.border?.right ? { right: hucre.border.right } : {}))\n };\n }\n }\n }\n\n private static hucreDegeriniHazirla(\n row: TExcelTableRow,\n column: TExcelTableColumn,\n sifirlariBasmaSayi: boolean\n ): IHazirHucreDegeri {\n const value = row[column.property];\n\n if ((typeof value === 'string') && value.startsWith('=')) {\n return { deger: { formula: this.excelFormuluneDonustur(value) } };\n }\n\n if ((typeof value === 'number') && sifirlariBasmaSayi && (value === 0)) {\n return { deger: '' };\n }\n\n if (value === null || value === undefined) {\n return { deger: '' };\n }\n\n const htmlHucre = (column.htmlKoduGelebilir === true) && typeof value === 'string' ? this.htmlHucreIceriginiHazirla(value) : undefined;\n const normallesenDeger = htmlHucre?.deger ?? value;\n\n if ((typeof normallesenDeger === 'string') && normallesenDeger.startsWith('=')) {\n return this.hazirHucreDegeriOlustur(\n { formula: this.excelFormuluneDonustur(normallesenDeger) },\n htmlHucre?.fontColorArgb\n );\n }\n\n if ((typeof value === 'string') && (typeof normallesenDeger === 'string')) {\n const tarihDegeri = this.tarihStringiniDateeDonustur(normallesenDeger);\n if (tarihDegeri) {\n return this.hazirHucreDegeriOlustur(tarihDegeri, htmlHucre?.fontColorArgb);\n }\n }\n\n if (normallesenDeger instanceof Date) {\n return this.hazirHucreDegeriOlustur(\n this.excelIcinTarihiNormalizeEt(normallesenDeger),\n htmlHucre?.fontColorArgb\n );\n }\n\n if (typeof normallesenDeger === 'boolean') {\n return this.hazirHucreDegeriOlustur(normallesenDeger ? '+' : '', htmlHucre?.fontColorArgb);\n }\n\n if ((typeof normallesenDeger === 'number') || (typeof normallesenDeger === 'string')) {\n return this.hazirHucreDegeriOlustur(normallesenDeger, htmlHucre?.fontColorArgb);\n }\n\n return this.hazirHucreDegeriOlustur(String(normallesenDeger), htmlHucre?.fontColorArgb);\n }\n\n private static hazirHucreDegeriOlustur(deger: ExcelJS.CellValue, fontColorArgb?: string): IHazirHucreDegeri {\n return {\n deger,\n ...(fontColorArgb ? { fontColorArgb } : {})\n };\n }\n\n private static htmlHucreIceriginiHazirla(value: string): { deger: string; fontColorArgb?: string } | undefined {\n if (!/[<>]/.test(value)) {\n return undefined;\n }\n\n const deger = value\n .replaceAll(/<br\\s*\\/?>/gi, '\\n')\n .replaceAll(/<\\/p\\s*>/gi, '\\n')\n .replaceAll(/<p\\b[^>]*>/gi, '')\n .replaceAll(/<\\/div\\s*>/gi, '\\n')\n .replaceAll(/<div\\b[^>]*>/gi, '')\n .replaceAll(/<[^>]+>/g, '')\n .replaceAll(/&nbsp;/gi, ' ')\n .trim();\n\n const colorValue = this.htmlFontRenginiBul(value);\n const fontColorArgb = this.argbDonustur(colorValue);\n\n if ((deger === value) && !fontColorArgb) {\n return undefined;\n }\n\n return { deger, ...(fontColorArgb && { fontColorArgb }) };\n }\n\n private static htmlFontRenginiBul(value: string): string | undefined {\n const fontColorMatch = /<font\\b[^>]*\\bcolor\\s*=\\s*[\"']?([^\"' >]+)[\"']?[^>]*>/i.exec(value);\n if (fontColorMatch?.[1]) {\n return fontColorMatch[1].trim();\n }\n\n const styleColorMatch = /<(?:font|span)\\b[^>]*\\bstyle\\s*=\\s*[\"'][^\"']*\\bcolor\\s*:\\s*([^;\"']+)/i.exec(value);\n if (styleColorMatch?.[1]) {\n return styleColorMatch[1].trim();\n }\n\n return undefined;\n }\n\n private static tarihStringiniDateeDonustur(value: string): Date | undefined {\n const trimmedValue = value.trim();\n const isoDateMatch = /^(\\d{4})-(\\d{2})-(\\d{2})(?:$|[T\\s])/.exec(trimmedValue);\n\n if (!isoDateMatch) {\n return undefined;\n }\n\n const year = Number(isoDateMatch[1]);\n const month = Number(isoDateMatch[2]);\n const day = Number(isoDateMatch[3]);\n\n if (!Number.isInteger(year) || !Number.isInteger(month) || !Number.isInteger(day)) {\n return undefined;\n }\n\n const date = new Date(year, month - 1, day);\n if (date.getFullYear() !== year || date.getMonth() !== (month - 1) || date.getDate() !== day) {\n return undefined;\n }\n\n return new Date(Date.UTC(year, month - 1, day, 12, 0, 0, 0));\n }\n\n private static excelIcinTarihiNormalizeEt(value: Date): Date {\n if (value.getHours() !== 0 || value.getMinutes() !== 0 || value.getSeconds() !== 0 || value.getMilliseconds() !== 0) {\n return value;\n }\n\n return new Date(Date.UTC(value.getFullYear(), value.getMonth(), value.getDate(), 12, 0, 0, 0));\n }\n\n private static varsayilanTarihFormatiniVer(): string {\n return 'dd.mm.yyyy';\n }\n\n private static benzersizKolonAdlariOlustur(adlar: string[]): string[] {\n const sayaclar = new Map<string, number>();\n return adlar.map(ad => {\n const temelAd = ad || ' ';\n const sayi = sayaclar.get(temelAd) ?? 0;\n sayaclar.set(temelAd, sayi + 1);\n return sayi === 0 ? temelAd : `${temelAd}_${sayi}`;\n });\n }\n\n private static hucreFontunuUygula(\n cell: ExcelJS.Cell,\n font: IExcelFont | undefined,\n defaultFont?: TDefaultFont\n ): void {\n const style = font?.style ?? 0;\n const excelFont: Partial<ExcelJS.Font> = {};\n\n const fontName = font?.name || defaultFont?.name;\n if (fontName) {\n excelFont.name = fontName;\n }\n\n const fontSize = (font?.size && font.size > 0) ? font.size : defaultFont?.size;\n if (fontSize && fontSize > 0) {\n excelFont.size = fontSize;\n }\n\n if (font?.color) {\n const color = this.argbDonustur(font.color);\n if (color) {\n excelFont.color = { argb: color };\n }\n }\n\n excelFont.bold = Boolean(style & FontStyle.bold);\n excelFont.italic = Boolean(style & FontStyle.italic);\n excelFont.underline = Boolean(style & FontStyle.underline);\n\n cell.font = excelFont;\n }\n\n private static gecerliTableStyleVer(tableStyle: string | undefined): string | undefined {\n if (!tableStyle) {\n return undefined;\n }\n\n const style = tableStyle.trim();\n if (/^TableStyleLight([1-9]|1\\d|2[0-1])$/.test(style)) {\n return style;\n }\n if (/^TableStyleMedium([1-9]|1\\d|2[0-1])$/.test(style)) {\n return style;\n }\n if (/^TableStyleDark([1-9]|10|11)$/.test(style)) {\n return style;\n }\n\n return undefined;\n }\n\n private static tableStyleDonustur(theme: string | undefined): ExcelJS.TableStyleProperties | undefined {\n if (!theme) {\n return undefined;\n }\n\n return {\n theme: theme as NonNullable<ExcelJS.TableStyleProperties['theme']>,\n showRowStripes: true\n };\n }\n\n private static tabloAdiOlustur(sheetName: string, startRow: number, startCol: number): string {\n const temizSheetName = sheetName.replaceAll(/[^A-Za-z0-9]/g, '_');\n return `T_${temizSheetName}_R${startRow}C${startCol}`;\n }\n\n private static yatayHizaDonustur(value: XLHAlign | undefined): ExcelJS.Alignment['horizontal'] {\n switch (value) {\n case XLHAlign.xlHAlignCenter: return 'center';\n case XLHAlign.xlHAlignCenterAcrossSelection: return 'centerContinuous';\n case XLHAlign.xlHAlignDistributed: return 'distributed';\n case XLHAlign.xlHAlignFill: return 'fill';\n case XLHAlign.xlHAlignGeneral: return 'left';\n case XLHAlign.xlHAlignJustify: return 'justify';\n case XLHAlign.xlHAlignLeft: return 'left';\n case XLHAlign.xlHAlignRight: return 'right';\n default: return 'left';\n }\n }\n\n private static dikeyHizaDonustur(value: XLVAlign | undefined): ExcelJS.Alignment['vertical'] {\n switch (value) {\n case XLVAlign.xlVAlignTop: return 'top';\n case XLVAlign.xlVAlignBottom: return 'bottom';\n case XLVAlign.xlVAlignDistributed: return 'distributed';\n case XLVAlign.xlVAlignJustify: return 'justify';\n default: return 'middle';\n }\n }\n\n private static argbDonustur(color: string | undefined): string | undefined {\n if (!color) {\n return undefined;\n }\n\n const cssColor = color.trim().toLowerCase();\n const namedColors: Record<string, string> = {\n black: 'FF000000',\n blue: 'FF0000FF',\n cyan: 'FF00FFFF',\n gray: 'FF808080',\n green: 'FF008000',\n grey: 'FF808080',\n magenta: 'FFFF00FF',\n orange: 'FFFFA500',\n purple: 'FF800080',\n red: 'FFFF0000',\n white: 'FFFFFFFF',\n yellow: 'FFFFFF00'\n };\n if (namedColors[cssColor]) {\n return namedColors[cssColor];\n }\n\n const hexColor = cssColor.replace('#', '');\n if (/^[0-9a-f]{6}$/i.test(hexColor)) {\n return `FF${hexColor.toUpperCase()}`;\n }\n\n if (/^[0-9A-Fa-f]{8}$/.test(color)) {\n return color.toUpperCase();\n }\n\n const numericColor = Number(color);\n if (!Number.isFinite(numericColor)) {\n return undefined;\n }\n\n const r = numericColor & 255;\n const g = (numericColor >> 8) & 255;\n const b = (numericColor >> 16) & 255;\n\n return `FF${[r, g, b].map(value => value.toString(16).padStart(2, '0')).join('').toUpperCase()}`;\n }\n\n private static excelFormuluneDonustur(formul: string): string {\n const ceviriler: Record<string, string> = {\n 'TOPLA': 'SUM',\n 'EĞER': 'IF',\n 'VE': 'AND',\n 'VEYA': 'OR',\n 'YUVARLA': 'ROUND',\n 'EĞERSAY': 'COUNTIF',\n 'ETOPLA': 'SUMIF',\n 'ORTALAMA': 'AVERAGE',\n 'MİN': 'MIN',\n 'MAK': 'MAX'\n };\n\n let sonuc = formul.slice(1).replaceAll(';', ',');\n\n for (const [kaynak, hedef] of Object.entries(ceviriler)) {\n const pattern = new RegExp(`\\\\b${kaynak}\\\\b`, 'g');\n sonuc = sonuc.replace(pattern, hedef);\n }\n\n return sonuc;\n }\n\n private static sayfaAdiDuzenle(sheetName: string, index: number): string {\n const temizAd = sheetName\n .replaceAll(/[\\\\/*?:[\\]]/g, ' ')\n .trim()\n .slice(0, 31);\n\n if (temizAd) {\n return temizAd;\n }\n\n return `Sheet${index}`;\n }\n\n private static dosyaAdiDuzenle(dosyaAdi: string): string {\n const temizAd = dosyaAdi\n .replaceAll(/[<>:\"/\\\\|?*]/g, ' ')\n .trim()\n .replaceAll(/\\s+/g, ' ');\n\n if (temizAd) {\n return temizAd;\n }\n\n return 'Rapor';\n }\n\n private static numberFormatDonustur(format: number | undefined): string | undefined {\n switch (format) {\n case NumberFormatlar.long:\n case 2:\n case 5:\n case 11:\n return '#,##0';\n\n case NumberFormatlar.real:\n case 7:\n case 12:\n return '#,##0.00';\n\n case 8:\n return 'hh:mm';\n\n case NumberFormatlar.tarih:\n return 'dd.mm.yyyy';\n\n case NumberFormatlar.tarih_yyyymmdd_tireli:\n return 'yyyy-mm-dd';\n\n case NumberFormatlar.tarih_AAAAYYYY:\n return 'mmmm yyyy';\n\n case NumberFormatlar.tarih_GGAAAAYYYY:\n return 'dd mmmm yyyy';\n\n case NumberFormatlar.tarih_YYYYMMDD:\n return 'yyyy/mm/dd';\n\n case NumberFormatlar.tarih_LongDate:\n return 'dd mmmm yyyy dddd';\n\n case NumberFormatlar.tarih_ga:\n return 'd.m;@';\n\n case NumberFormatlar.tarih_ggaa:\n return 'dd.mm';\n\n case NumberFormatlar.tarih_gaaaa:\n return 'd.mmmm';\n\n case NumberFormatlar.tarih_ggaaa:\n return 'dd.mmm';\n\n case NumberFormatlar.tarih_ggaaaa:\n return 'dd.mmmm';\n\n case NumberFormatlar.yuzde_BirHane:\n return '0.0%';\n\n case NumberFormatlar.genel:\n return 'General';\n\n case NumberFormatlar.metin:\n return '@';\n\n case NumberFormatlar.imp:\n return '#,##0 \"imp\"';\n\n case NumberFormatlar.clicks:\n return '#,##0 \"Clicks\"';\n\n case NumberFormatlar.gun:\n return '#,##0 \"Gün\"';\n\n case NumberFormatlar.view:\n return '#,##0 \"View\"';\n\n case NumberFormatlar.session:\n return '#,##0 \"Session\"';\n\n case NumberFormatlar.kisi:\n return '#,##0 \"Kişi\"';\n\n case NumberFormatlar.okunma:\n return '#,##0 \"Okunma\"';\n\n case NumberFormatlar.dinlenme:\n return '#,##0 \"Dinlenme\"';\n\n case NumberFormatlar.lead:\n return '#,##0 \"Lead\"';\n\n case NumberFormatlar.gizli:\n return ';;;';\n\n default:\n return undefined;\n }\n }\n}\n","import { HttpResponse } from '@angular/common/http';\r\nimport { inject, Injectable } from '@angular/core';\r\n\r\nimport saveAs from 'file-saver';\r\n\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { GlobalFunctions } from 'limitng/api';\r\nimport { ToastMessageOptions } from 'primeng/api';\r\nimport { ExcelRaporuSonuc } from './models/excelRaporuSonuc';\r\nimport { JsonToExcelParser } from './models/jsonToExcelParser';\r\n\r\ninterface JsonExcelResponseOptions<T extends ExcelRaporuSonuc> {\r\n createResult: () => T;\r\n errorLogMessage: string;\r\n fileName?: string;\r\n getFileName?: (result: T) => string;\r\n successDetail?: string;\r\n successDetailKey?: string;\r\n}\r\n\r\n@Injectable({ providedIn: 'root' })\r\nexport class BlobResponseHandlerService {\r\n private readonly translateService = inject(TranslateService);\r\n\r\n handleReportResponse(\r\n response: HttpResponse<Blob>,\r\n successDetailKey: string,\r\n htmlTitle = 'Rapor Sonucu'\r\n ): ToastMessageOptions | null {\r\n const body = response.body;\r\n\r\n if (!body) {\r\n return null;\r\n }\r\n\r\n const contentDisposition = response.headers.get('content-disposition');\r\n const contentType = response.headers.get('Content-Type') ?? body.type;\r\n\r\n if (contentDisposition) {\r\n return this.handleDownload(body, contentDisposition, contentType, successDetailKey);\r\n }\r\n\r\n this.handleViewHtml(body, htmlTitle);\r\n return null;\r\n }\r\n\r\n downloadResponse(response: HttpResponse<Blob | string>): boolean {\r\n const body = response.body;\r\n\r\n if (!body) {\r\n return false;\r\n }\r\n\r\n const contentDisposition = response.headers.get('content-disposition');\r\n\r\n if (!contentDisposition) {\r\n return false;\r\n }\r\n\r\n const contentType = response.headers.get('Content-Type') ?? (body instanceof Blob ? body.type : 'application/octet-stream');\r\n\r\n this.downloadBlob(body, contentDisposition, contentType);\r\n return true;\r\n }\r\n\r\n viewHtmlBody(body: Blob | null, htmlTitle = 'Rapor Sonucu'): void {\r\n if (!body) {\r\n return;\r\n }\r\n\r\n this.handleViewHtml(body, htmlTitle);\r\n }\r\n\r\n async handleJsonExcelResponse<T extends ExcelRaporuSonuc>(\r\n body: Blob | null,\r\n options: JsonExcelResponseOptions<T>\r\n ): Promise<ToastMessageOptions | null> {\r\n if (!body) {\r\n return null;\r\n }\r\n\r\n try {\r\n const jsonStr = await body.text();\r\n const result = Object.assign(options.createResult(), JSON.parse(jsonStr) as T);\r\n const fileName = options.getFileName?.(result) ?? options.fileName;\r\n\r\n if (!fileName) {\r\n return null;\r\n }\r\n\r\n await JsonToExcelParser.indir(result, fileName);\r\n\r\n return {\r\n severity: 'success',\r\n summary: this.translateService.instant('genel.bilgi'),\r\n detail: options.successDetail ?? this.translateService.instant(options.successDetailKey ?? '')\r\n };\r\n } catch (error) {\r\n console.error(options.errorLogMessage, error);\r\n return null;\r\n }\r\n }\r\n\r\n private handleDownload(body: BlobPart, contentDisposition: string, contentType: string, successDetailKey: string): ToastMessageOptions {\r\n this.downloadBlob(body, contentDisposition, contentType);\r\n\r\n return {\r\n severity: 'success',\r\n summary: this.translateService.instant('genel.bilgi'),\r\n detail: this.translateService.instant(successDetailKey)\r\n };\r\n }\r\n\r\n private downloadBlob(body: BlobPart, contentDisposition: string, contentType: string): void {\r\n const decodedContentDisposition = contentDisposition.replaceAll(\r\n /\\\\u([0-9A-Fa-f]{4})/g,\r\n (_, code: string) => String.fromCodePoint(Number.parseInt(code, 16))\r\n );\r\n const filename = GlobalFunctions.getFilenameFromContentDisposition(decodedContentDisposition);\r\n const blob = new Blob([body], { type: contentType });\r\n\r\n saveAs(blob, filename);\r\n }\r\n\r\n private handleViewHtml(body: Blob, htmlTitle: string): void {\r\n body.text().then((html: string) => {\r\n const wnd = window.open('', '_blank');\r\n\r\n if (!wnd) {\r\n return;\r\n }\r\n\r\n wnd.document.title = htmlTitle;\r\n\r\n const iframe = wnd.document.createElement('iframe');\r\n iframe.style.width = '100%';\r\n iframe.style.height = '100%';\r\n iframe.style.border = 'none';\r\n iframe.setAttribute('srcdoc', html);\r\n\r\n wnd.document.body.style.margin = '0';\r\n wnd.document.body.style.padding = '0';\r\n wnd.document.body.appendChild(iframe);\r\n });\r\n }\r\n}\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public_api';\n"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "limitng",
3
- "version": "0.21.73",
3
+ "version": "0.21.75",
4
4
  "repository": {
5
5
  "type": "git",
6
6
  "url": "http://limitdestek.com:3000/Limit/LimitNG"
@@ -111,6 +111,7 @@ interface IExcelRaporuTableColumn {
111
111
  format?: number;
112
112
  width?: number;
113
113
  columnNo?: number;
114
+ htmlKoduGelebilir?: boolean;
114
115
  }
115
116
  interface IExcelRaporuSatirRenkBilgisi {
116
117
  color: string;
@@ -234,14 +235,57 @@ declare class BlobResponseHandlerService {
234
235
  static ɵprov: i0.ɵɵInjectableDeclaration<BlobResponseHandlerService>;
235
236
  }
236
237
 
238
+ type TExcelTable = NonNullable<ExcelRaporuSonuc['tables']>[number];
239
+ type TExcelTableColumn = TExcelTable['columns'][number];
240
+ type TExcelTableRow = TExcelTable['collection'][number];
237
241
  type TExcelSheet = ExcelRaporuSonuc['sheets'][number];
238
242
  type TExcelPageSetup = NonNullable<TExcelSheet['pageSetup']>;
239
243
  type TExcelUstBilgi = NonNullable<ExcelRaporuSonuc['ustBilgiler']>[number];
244
+ interface IJsonToExcelSheetOptions {
245
+ pageSetup?: TExcelSheet['pageSetup'];
246
+ zoom?: number;
247
+ }
248
+ interface IJsonToExcelTableOptions {
249
+ autoFit?: TExcelTable['autoFit'];
250
+ data?: TExcelTable['data'];
251
+ footer?: TExcelTable['footer'];
252
+ header?: TExcelTable['header'];
253
+ sol?: TExcelTable['sol'];
254
+ ust?: TExcelTable['ust'];
255
+ }
256
+ declare class JsonToExcelTableBuilder<TRow extends TExcelTableRow = TExcelTableRow> {
257
+ private readonly table;
258
+ constructor(table: TExcelTable);
259
+ addColumn(column: TExcelTableColumn): this;
260
+ setRows(rows: TRow[]): this;
261
+ setStartColumn(sol: number): this;
262
+ setStartRow(ust: number): this;
263
+ getColumnSayisi(): number;
264
+ }
265
+ declare class JsonToExcelSheetBuilder {
266
+ private readonly sheet;
267
+ constructor(sheet: TExcelSheet);
268
+ addTable<TRow extends TExcelTableRow = TExcelTableRow>(rows: TRow[], options?: IJsonToExcelTableOptions): JsonToExcelTableBuilder<TRow>;
269
+ addUstBilgi(ustBilgi: string, font?: TExcelUstBilgi['font']): this;
270
+ getUstBilgiSayisi(): number;
271
+ getSheetNo(): number | undefined;
272
+ setSheetName(sheetName: string): this;
273
+ setZoom(zoom: number): this;
274
+ }
275
+ declare class JsonToExcelReportBuilder {
276
+ private readonly sonuc;
277
+ addSheet(sheetName: string, options?: IJsonToExcelSheetOptions): JsonToExcelSheetBuilder;
278
+ build(): ExcelRaporuSonuc;
279
+ setAuthor(author: string): this;
280
+ setCurrentTableStyle(currentTableStyle: string): this;
281
+ setSubject(subject: string): this;
282
+ }
240
283
  declare class JsonToExcelParser {
241
284
  static indir(sonuc: ExcelRaporuSonuc, dosyaAdi: string): Promise<void>;
242
285
  static blobOlustur(sonuc: ExcelRaporuSonuc): Promise<Blob>;
243
286
  static standartPageSetupOlustur(): TExcelPageSetup;
244
287
  static ustBilgiEkle(ustBilgi: string, font?: TExcelUstBilgi['font']): TExcelUstBilgi;
288
+ static raporOlustur(): JsonToExcelReportBuilder;
245
289
  private static workbookOlustur;
246
290
  private static yeniYapiMi;
247
291
  private static yeniFormatSheetsYaz;
@@ -290,6 +334,6 @@ declare class JsonToExcelParser {
290
334
  private static numberFormatDonustur;
291
335
  }
292
336
 
293
- export { BlobResponseHandlerService, ExcelRaporuSonuc, JsonToExcelParser };
294
- export type { ExcelHucreDegeri };
337
+ export { BlobResponseHandlerService, ExcelRaporuSonuc, JsonToExcelParser, JsonToExcelReportBuilder, JsonToExcelSheetBuilder, JsonToExcelTableBuilder };
338
+ export type { ExcelHucreDegeri, IJsonToExcelSheetOptions, IJsonToExcelTableOptions };
295
339
  //# sourceMappingURL=limitng-blob-response-handler.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"limitng-blob-response-handler.d.ts","sources":["../../src/app/components/blob-response-handler/models/excelRaporuSonuc.ts","../../src/app/components/blob-response-handler/blob-response-handler.service.ts","../../src/app/components/blob-response-handler/models/jsonToExcelParser.ts"],"mappings":"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","names":[]}
1
+ {"version":3,"file":"limitng-blob-response-handler.d.ts","sources":["../../src/app/components/blob-response-handler/models/excelRaporuSonuc.ts","../../src/app/components/blob-response-handler/blob-response-handler.service.ts","../../src/app/components/blob-response-handler/models/jsonToExcelParser.ts"],"mappings":"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","names":[]}