@file-viewer/core 2.0.10 → 2.1.0

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.
Files changed (114) hide show
  1. package/README.en.md +2 -2
  2. package/README.md +2 -2
  3. package/dist/config/options.d.ts +1 -1
  4. package/dist/config/options.js +1 -1
  5. package/dist/contracts/types.d.ts +71 -1
  6. package/dist/headless.d.ts +2 -2
  7. package/dist/headless.js +1 -1
  8. package/dist/index.d.ts +9 -6
  9. package/dist/index.js +105 -48
  10. package/dist/platform/assets.d.ts +3 -1
  11. package/dist/platform/assets.js +18 -2
  12. package/dist/registry/capabilities.d.ts +2 -2
  13. package/dist/registry/capabilities.js +2 -1
  14. package/dist/registry/formats.d.ts +20 -7
  15. package/dist/registry/formats.js +14 -5
  16. package/dist/registry/registry.d.ts +8 -1
  17. package/dist/registry/registry.js +29 -0
  18. package/dist/renderers/image.js +1 -10
  19. package/dist/renderers/index.d.ts +320 -2
  20. package/dist/renderers/index.js +27 -157
  21. package/dist/viewer/createViewer.js +86 -3
  22. package/package.json +17 -44
  23. package/dist/renderers/archive.d.ts +0 -2
  24. package/dist/renderers/archive.js +0 -547
  25. package/dist/renderers/archiveCache.d.ts +0 -10
  26. package/dist/renderers/archiveCache.js +0 -96
  27. package/dist/renderers/archiveFallback.d.ts +0 -7
  28. package/dist/renderers/archiveFallback.js +0 -166
  29. package/dist/renderers/archiveShared.d.ts +0 -23
  30. package/dist/renderers/archiveShared.js +0 -71
  31. package/dist/renderers/audio.d.ts +0 -8
  32. package/dist/renderers/audio.js +0 -219
  33. package/dist/renderers/cad.d.ts +0 -2
  34. package/dist/renderers/cad.js +0 -446
  35. package/dist/renderers/code.d.ts +0 -11
  36. package/dist/renderers/code.js +0 -233
  37. package/dist/renderers/data.d.ts +0 -7
  38. package/dist/renderers/data.js +0 -370
  39. package/dist/renderers/drawing.d.ts +0 -10
  40. package/dist/renderers/drawing.js +0 -882
  41. package/dist/renderers/eda.d.ts +0 -2
  42. package/dist/renderers/eda.js +0 -434
  43. package/dist/renderers/edaParser.d.ts +0 -77
  44. package/dist/renderers/edaParser.js +0 -569
  45. package/dist/renderers/email.d.ts +0 -2
  46. package/dist/renderers/email.js +0 -463
  47. package/dist/renderers/epub.d.ts +0 -2
  48. package/dist/renderers/epub.js +0 -331
  49. package/dist/renderers/geo.d.ts +0 -2
  50. package/dist/renderers/geo.js +0 -284
  51. package/dist/renderers/markdown.d.ts +0 -2
  52. package/dist/renderers/markdown.js +0 -83
  53. package/dist/renderers/model.d.ts +0 -2
  54. package/dist/renderers/model.js +0 -567
  55. package/dist/renderers/ofd.d.ts +0 -2
  56. package/dist/renderers/ofd.js +0 -256
  57. package/dist/renderers/openDocument.d.ts +0 -2
  58. package/dist/renderers/openDocument.js +0 -122
  59. package/dist/renderers/pdf.d.ts +0 -3
  60. package/dist/renderers/pdf.js +0 -1001
  61. package/dist/renderers/pdfStyles.d.ts +0 -1
  62. package/dist/renderers/pdfStyles.js +0 -1
  63. package/dist/renderers/pptx.d.ts +0 -2
  64. package/dist/renderers/pptx.js +0 -217
  65. package/dist/renderers/spreadsheet/state.d.ts +0 -80
  66. package/dist/renderers/spreadsheet/state.js +0 -96
  67. package/dist/renderers/spreadsheet/view.d.ts +0 -25
  68. package/dist/renderers/spreadsheet/view.js +0 -833
  69. package/dist/renderers/spreadsheet/worker/index.d.ts +0 -2
  70. package/dist/renderers/spreadsheet/worker/index.js +0 -1
  71. package/dist/renderers/spreadsheet/worker/sheetjs/SheetJsModel.d.ts +0 -73
  72. package/dist/renderers/spreadsheet/worker/sheetjs/SheetJsModel.js +0 -623
  73. package/dist/renderers/spreadsheet/worker/sheetjs/color.d.ts +0 -2
  74. package/dist/renderers/spreadsheet/worker/sheetjs/color.js +0 -73
  75. package/dist/renderers/spreadsheet/worker/sheetjs/index.d.ts +0 -1
  76. package/dist/renderers/spreadsheet/worker/sheetjs/index.js +0 -1
  77. package/dist/renderers/spreadsheet/worker/sheetjs/parser.d.ts +0 -18
  78. package/dist/renderers/spreadsheet/worker/sheetjs/parser.js +0 -106
  79. package/dist/renderers/spreadsheet/worker/sheetjs/sheet.worker.d.ts +0 -1
  80. package/dist/renderers/spreadsheet/worker/sheetjs/sheet.worker.js +0 -11
  81. package/dist/renderers/spreadsheet/worker/type.d.ts +0 -57
  82. package/dist/renderers/spreadsheet/worker/type.js +0 -1
  83. package/dist/renderers/spreadsheet.d.ts +0 -3
  84. package/dist/renderers/spreadsheet.js +0 -929
  85. package/dist/renderers/typst.d.ts +0 -8
  86. package/dist/renderers/typst.js +0 -547
  87. package/dist/renderers/umd/parser.d.ts +0 -30
  88. package/dist/renderers/umd/parser.js +0 -408
  89. package/dist/renderers/umd.d.ts +0 -2
  90. package/dist/renderers/umd.js +0 -297
  91. package/dist/renderers/video.d.ts +0 -8
  92. package/dist/renderers/video.js +0 -108
  93. package/dist/renderers/wordDoc.d.ts +0 -5
  94. package/dist/renderers/wordDoc.js +0 -284
  95. package/dist/renderers/wordDocx.d.ts +0 -5
  96. package/dist/renderers/wordDocx.js +0 -985
  97. package/dist/renderers/wordDocx.worker.d.ts +0 -1
  98. package/dist/renderers/wordDocx.worker.js +0 -96
  99. package/vendor/ofd/dltech/jbig2/arithmetic_decoder.js +0 -183
  100. package/vendor/ofd/dltech/jbig2/ccitt.js +0 -1070
  101. package/vendor/ofd/dltech/jbig2/compatibility.js +0 -12
  102. package/vendor/ofd/dltech/jbig2/core_utils.js +0 -180
  103. package/vendor/ofd/dltech/jbig2/is_node.js +0 -27
  104. package/vendor/ofd/dltech/jbig2/jbig2.js +0 -2589
  105. package/vendor/ofd/dltech/jbig2/jbig2_stream.js +0 -81
  106. package/vendor/ofd/dltech/jbig2/primitives.js +0 -387
  107. package/vendor/ofd/dltech/jbig2/stream.js +0 -1348
  108. package/vendor/ofd/dltech/jbig2/util.js +0 -972
  109. package/vendor/ofd/dltech/ofd/ofd.d.ts +0 -11
  110. package/vendor/ofd/dltech/ofd/ofd.js +0 -100
  111. package/vendor/ofd/dltech/ofd/ofd_parser.js +0 -395
  112. package/vendor/ofd/dltech/ofd/ofd_render.js +0 -473
  113. package/vendor/ofd/dltech/ofd/ofd_util.js +0 -350
  114. package/vendor/ofd/dltech/ofd/pipeline.js +0 -26
@@ -1,73 +0,0 @@
1
- import tinycolor from 'tinycolor2';
2
- export const indexedColors = [
3
- 'FF000000', 'FFFFFFFF', 'FFFF0000', 'FF00FF00', 'FF0000FF', 'FFFFFF00', 'FFFF00FF', 'FF00FFFF', // 0-7
4
- 'FF000000', 'FFFFFFFF', 'FFFF0000', 'FF00FF00', 'FF0000FF', 'FFFFFF00', 'FFFF00FF', 'FF00FFFF', // 8-15
5
- 'FF800000', 'FF008000', 'FF000080', 'FF808000', 'FF800080', 'FF008080', 'FFC0C0C0', 'FF808080', // 16-23
6
- 'FF9999FF', 'FF993366', 'FFFFFFCC', 'FFCCFFFF', 'FF660066', 'FFFF8080', 'FF0066CC', 'FFCCCCFF', // 24-31
7
- 'FF000080', 'FFFF00FF', 'FFFFFF00', 'FF00FFFF', 'FF800080', 'FF800000', 'FF008080', 'FF0000FF', // 32-39
8
- 'FF00CCFF', 'FFCCFFFF', 'FFCCFFCC', 'FFFFFF99', 'FF99CCFF', 'FFFF99CC', 'FFCC99FF', 'FFFFCC99', // 40-47
9
- 'FF3366FF', 'FF33CCCC', 'FF99CC00', 'FFFFCC00', 'FFFF9900', 'FFFF6600', 'FF666699', 'FF969696', // 48-55
10
- 'FF003366', 'FF339966', 'FF003300', 'FF333300', 'FF993300', 'FF993366', 'FF333399', 'FF333333' // 56-63
11
- ];
12
- const HLSMAX = 240;
13
- const RGBMAX = 0xFF;
14
- // Excel 主题色的 tint 计算使用微软 HLS 取值范围,和浏览器 HSL 不是同一套刻度。
15
- function rgb2hls(r, g, b) {
16
- const maxc = Math.max(r, g, b);
17
- const minc = Math.min(r, g, b);
18
- const sumc = maxc + minc;
19
- const rangec = maxc - minc;
20
- const l = sumc / 2.0;
21
- let h, s;
22
- if (minc == maxc) {
23
- return [0.0, l, 0.0];
24
- }
25
- if (l <= 0.5) {
26
- s = rangec / sumc;
27
- }
28
- else {
29
- s = rangec / (2.0 - sumc);
30
- }
31
- const rc = (maxc - r) / rangec;
32
- const gc = (maxc - g) / rangec;
33
- const bc = (maxc - b) / rangec;
34
- if (r == maxc) {
35
- h = bc - gc;
36
- }
37
- else if (g === maxc) {
38
- h = 2.0 + rc - bc;
39
- }
40
- else {
41
- h = 4.0 + gc - rc;
42
- }
43
- h = (h / 6.0) % 1.0;
44
- return [h, l, s];
45
- }
46
- function rgb2MsHls(hex) {
47
- if (hex.length > 6) {
48
- hex = hex.substring(2);
49
- }
50
- const red = parseInt(hex.slice(0, 2), 16) / RGBMAX;
51
- const green = parseInt(hex.slice(2, 4), 16) / RGBMAX;
52
- const blue = parseInt(hex.slice(4, 6), 16) / RGBMAX;
53
- const [h, l, s] = rgb2hls(red, green, blue);
54
- return [Math.round(h * HLSMAX), Math.round(l * HLSMAX), Math.round(s * HLSMAX)];
55
- }
56
- function msHls2Rgb(hue, lightness, saturation) {
57
- const color = tinycolor({ h: hue / HLSMAX * 360, s: saturation / HLSMAX, l: lightness / HLSMAX });
58
- return color.toHex().toUpperCase();
59
- }
60
- function tintLuminance(tint, lum) {
61
- if (tint <= 0) {
62
- return Math.round(lum * (1.0 + tint));
63
- }
64
- return Math.round(lum * (1.0 - tint) + (HLSMAX - HLSMAX * (1.0 - tint)));
65
- }
66
- // 根据主题原始色和 tint 还原 Excel 实际显示色。
67
- export function getTintColor(hex, tint) {
68
- if (!hex) {
69
- return hex;
70
- }
71
- const [h, l, s] = rgb2MsHls(hex);
72
- return `FF${msHls2Rgb(h, tintLuminance(tint, l), s)}`;
73
- }
@@ -1 +0,0 @@
1
- export { createSpreadsheetParserContext, handleSpreadsheetWorkerRequest } from './parser';
@@ -1 +0,0 @@
1
- export { createSpreadsheetParserContext, handleSpreadsheetWorkerRequest } from './parser.js';
@@ -1,18 +0,0 @@
1
- import type { WorkBook } from 'styled-exceljs';
2
- import type { SheetDefinition } from '../type';
3
- export interface SpreadsheetParserContext {
4
- workbook: WorkBook | null;
5
- sheets: SheetDefinition[];
6
- }
7
- export interface SpreadsheetWorkerRequest {
8
- type: string;
9
- payload?: Record<string, any>;
10
- }
11
- export interface SpreadsheetWorkerResponse {
12
- type: string;
13
- payload?: Record<string, any>;
14
- }
15
- export declare const createSpreadsheetParserContext: () => SpreadsheetParserContext;
16
- export declare const parseSpreadsheetWorkbook: (context: SpreadsheetParserContext, data: ArrayBuffer) => SpreadsheetWorkerResponse[];
17
- export declare const parseSpreadsheetSheet: (context: SpreadsheetParserContext, payload?: Record<string, any>) => SpreadsheetWorkerResponse[];
18
- export declare const handleSpreadsheetWorkerRequest: (context: SpreadsheetParserContext, request: SpreadsheetWorkerRequest) => SpreadsheetWorkerResponse[];
@@ -1,106 +0,0 @@
1
- import { read, utils } from 'styled-exceljs';
2
- import SheetJsModel from './SheetJsModel.js';
3
- const readOptions = {
4
- type: 'array',
5
- dense: true,
6
- cellDates: true,
7
- cellStyles: true,
8
- browserPixels: true,
9
- drawings: true,
10
- validateMerges: true,
11
- };
12
- export const createSpreadsheetParserContext = () => ({
13
- workbook: null,
14
- sheets: [],
15
- });
16
- const toErrorResponse = (error, payload = {}) => ({
17
- type: 'parseError',
18
- payload: {
19
- ...payload,
20
- message: error instanceof Error ? error.message : String(error),
21
- },
22
- });
23
- const parseSheets = (context) => {
24
- var _a;
25
- const workbook = context.workbook;
26
- if (!(workbook === null || workbook === void 0 ? void 0 : workbook.SheetNames)) {
27
- return [];
28
- }
29
- const workbookSheets = ((_a = workbook.Workbook) === null || _a === void 0 ? void 0 : _a.Sheets) || [];
30
- context.sheets = workbook.SheetNames.reduce((result, name, sourceIndex) => {
31
- var _a;
32
- const worksheet = workbook.Sheets[name];
33
- const ref = worksheet === null || worksheet === void 0 ? void 0 : worksheet['!ref'];
34
- if (!ref) {
35
- return result;
36
- }
37
- const range = utils.decode_range(ref);
38
- result.push({
39
- id: result.length,
40
- name,
41
- hidden: !!((_a = workbookSheets[sourceIndex]) === null || _a === void 0 ? void 0 : _a.Hidden),
42
- rowCount: range.e.r + 1,
43
- colCount: range.e.c + 1,
44
- });
45
- return result;
46
- }, []);
47
- return [{ type: 'sheets', payload: { sheets: context.sheets } }];
48
- };
49
- export const parseSpreadsheetWorkbook = (context, data) => {
50
- try {
51
- context.workbook = read(data, readOptions);
52
- return parseSheets(context);
53
- }
54
- catch (error) {
55
- return [toErrorResponse(error)];
56
- }
57
- };
58
- export const parseSpreadsheetSheet = (context, payload = {}) => {
59
- var _a;
60
- const { sheet, startRow = 0, pageSize = 500, sessionId = 0, } = payload;
61
- try {
62
- const workbook = context.workbook;
63
- const sheetName = (_a = context.sheets.find(item => item.id === sheet)) === null || _a === void 0 ? void 0 : _a.name;
64
- if (!(workbook === null || workbook === void 0 ? void 0 : workbook.Sheets) || !sheetName) {
65
- return [];
66
- }
67
- const worksheet = workbook.Sheets[sheetName];
68
- if (!worksheet) {
69
- return [];
70
- }
71
- const sheetMeta = context.sheets.find(item => item.id === sheet);
72
- const sheetModel = SheetJsModel.create(worksheet, {
73
- startRow,
74
- pageSize,
75
- totalRows: sheetMeta === null || sheetMeta === void 0 ? void 0 : sheetMeta.rowCount,
76
- totalCols: sheetMeta === null || sheetMeta === void 0 ? void 0 : sheetMeta.colCount,
77
- });
78
- const windowData = sheetModel.toObject();
79
- const structure = startRow === 0 ? sheetModel.structure : undefined;
80
- return [{
81
- type: 'parseSheet',
82
- payload: {
83
- sessionId,
84
- sheet,
85
- sheetData: structure ? {
86
- ...windowData,
87
- structure,
88
- } : windowData,
89
- },
90
- }];
91
- }
92
- catch (error) {
93
- return [toErrorResponse(error, { sessionId, startRow })];
94
- }
95
- };
96
- export const handleSpreadsheetWorkerRequest = (context, request) => {
97
- var _a;
98
- switch (request.type) {
99
- case 'parseWorkbook':
100
- return parseSpreadsheetWorkbook(context, (_a = request.payload) === null || _a === void 0 ? void 0 : _a.workbook);
101
- case 'parseSheet':
102
- return parseSpreadsheetSheet(context, request.payload);
103
- default:
104
- return [];
105
- }
106
- };
@@ -1,11 +0,0 @@
1
- import { createSpreadsheetParserContext, handleSpreadsheetWorkerRequest } from './parser.js';
2
- const ctx = self;
3
- const context = createSpreadsheetParserContext();
4
- ctx.onmessage = async (message) => {
5
- handleSpreadsheetWorkerRequest(context, message.data).forEach(response => {
6
- ctx.postMessage(response);
7
- });
8
- };
9
- ctx.onerror = (err) => {
10
- console.error(err);
11
- };
@@ -1,57 +0,0 @@
1
- export interface CellMerge {
2
- row: number;
3
- col: number;
4
- rowspan: number;
5
- colspan: number;
6
- }
7
- export interface SheetImage {
8
- id: string;
9
- src: string;
10
- contentType?: string;
11
- left: number;
12
- top: number;
13
- width: number;
14
- height: number;
15
- row: number;
16
- col: number;
17
- }
18
- export interface SheetStructure {
19
- merge?: CellMerge[];
20
- colWidths?: number | number[];
21
- rowHeights?: number | number[];
22
- columns?: SheetColumn[];
23
- images?: SheetImage[];
24
- }
25
- export interface SheetColumn {
26
- key: number;
27
- title: string;
28
- hidden?: boolean;
29
- editor: false;
30
- className: string;
31
- renderer: 'styleRender';
32
- }
33
- export interface SheetDefinition {
34
- id: number;
35
- name: string;
36
- hidden?: boolean;
37
- rowCount?: number;
38
- colCount?: number;
39
- }
40
- export interface SheetWindow {
41
- startRow: number;
42
- endRow: number;
43
- pageSize: number;
44
- totalRows: number;
45
- totalCols: number;
46
- }
47
- export interface SheetModel {
48
- get defaults(): any;
49
- get data(): string[][];
50
- get cell(): Record<string, unknown>;
51
- get merge(): CellMerge[];
52
- get rowHeights(): number | number[];
53
- get colWidths(): number | number[];
54
- get columns(): SheetColumn[];
55
- readonly structure?: SheetStructure;
56
- readonly meta?: SheetWindow;
57
- }
@@ -1 +0,0 @@
1
- export {};
@@ -1,3 +0,0 @@
1
- import type { FileRenderContext, FileViewerRenderedInstance as AppWrapper } from '../contracts/types';
2
- declare const renderFileViewerSpreadsheet: (buffer: ArrayBuffer, target: HTMLDivElement, _type?: string, context?: FileRenderContext) => Promise<AppWrapper>;
3
- export default renderFileViewerSpreadsheet;