@file-viewer/core 2.0.11 → 2.1.1

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 (116) 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 +76 -1
  6. package/dist/headless.d.ts +3 -3
  7. package/dist/headless.js +2 -2
  8. package/dist/index.d.ts +10 -7
  9. package/dist/index.js +106 -49
  10. package/dist/lifecycle/operations.d.ts +1 -0
  11. package/dist/lifecycle/operations.js +65 -6
  12. package/dist/platform/assets.d.ts +3 -1
  13. package/dist/platform/assets.js +43 -6
  14. package/dist/registry/capabilities.d.ts +2 -2
  15. package/dist/registry/capabilities.js +2 -1
  16. package/dist/registry/formats.d.ts +20 -7
  17. package/dist/registry/formats.js +14 -5
  18. package/dist/registry/registry.d.ts +8 -1
  19. package/dist/registry/registry.js +29 -0
  20. package/dist/renderers/image.js +1 -10
  21. package/dist/renderers/index.d.ts +320 -2
  22. package/dist/renderers/index.js +27 -157
  23. package/dist/viewer/createViewer.js +86 -3
  24. package/package.json +17 -44
  25. package/dist/renderers/archive.d.ts +0 -2
  26. package/dist/renderers/archive.js +0 -547
  27. package/dist/renderers/archiveCache.d.ts +0 -10
  28. package/dist/renderers/archiveCache.js +0 -96
  29. package/dist/renderers/archiveFallback.d.ts +0 -7
  30. package/dist/renderers/archiveFallback.js +0 -166
  31. package/dist/renderers/archiveShared.d.ts +0 -23
  32. package/dist/renderers/archiveShared.js +0 -71
  33. package/dist/renderers/audio.d.ts +0 -8
  34. package/dist/renderers/audio.js +0 -219
  35. package/dist/renderers/cad.d.ts +0 -2
  36. package/dist/renderers/cad.js +0 -446
  37. package/dist/renderers/code.d.ts +0 -11
  38. package/dist/renderers/code.js +0 -233
  39. package/dist/renderers/data.d.ts +0 -7
  40. package/dist/renderers/data.js +0 -370
  41. package/dist/renderers/drawing.d.ts +0 -10
  42. package/dist/renderers/drawing.js +0 -882
  43. package/dist/renderers/eda.d.ts +0 -2
  44. package/dist/renderers/eda.js +0 -434
  45. package/dist/renderers/edaParser.d.ts +0 -77
  46. package/dist/renderers/edaParser.js +0 -569
  47. package/dist/renderers/email.d.ts +0 -2
  48. package/dist/renderers/email.js +0 -463
  49. package/dist/renderers/epub.d.ts +0 -2
  50. package/dist/renderers/epub.js +0 -331
  51. package/dist/renderers/geo.d.ts +0 -2
  52. package/dist/renderers/geo.js +0 -284
  53. package/dist/renderers/markdown.d.ts +0 -2
  54. package/dist/renderers/markdown.js +0 -83
  55. package/dist/renderers/model.d.ts +0 -2
  56. package/dist/renderers/model.js +0 -567
  57. package/dist/renderers/ofd.d.ts +0 -2
  58. package/dist/renderers/ofd.js +0 -256
  59. package/dist/renderers/openDocument.d.ts +0 -2
  60. package/dist/renderers/openDocument.js +0 -122
  61. package/dist/renderers/pdf.d.ts +0 -3
  62. package/dist/renderers/pdf.js +0 -1001
  63. package/dist/renderers/pdfStyles.d.ts +0 -1
  64. package/dist/renderers/pdfStyles.js +0 -1
  65. package/dist/renderers/pptx.d.ts +0 -2
  66. package/dist/renderers/pptx.js +0 -217
  67. package/dist/renderers/spreadsheet/state.d.ts +0 -80
  68. package/dist/renderers/spreadsheet/state.js +0 -96
  69. package/dist/renderers/spreadsheet/view.d.ts +0 -25
  70. package/dist/renderers/spreadsheet/view.js +0 -833
  71. package/dist/renderers/spreadsheet/worker/index.d.ts +0 -2
  72. package/dist/renderers/spreadsheet/worker/index.js +0 -1
  73. package/dist/renderers/spreadsheet/worker/sheetjs/SheetJsModel.d.ts +0 -73
  74. package/dist/renderers/spreadsheet/worker/sheetjs/SheetJsModel.js +0 -623
  75. package/dist/renderers/spreadsheet/worker/sheetjs/color.d.ts +0 -2
  76. package/dist/renderers/spreadsheet/worker/sheetjs/color.js +0 -73
  77. package/dist/renderers/spreadsheet/worker/sheetjs/index.d.ts +0 -1
  78. package/dist/renderers/spreadsheet/worker/sheetjs/index.js +0 -1
  79. package/dist/renderers/spreadsheet/worker/sheetjs/parser.d.ts +0 -18
  80. package/dist/renderers/spreadsheet/worker/sheetjs/parser.js +0 -106
  81. package/dist/renderers/spreadsheet/worker/sheetjs/sheet.worker.d.ts +0 -1
  82. package/dist/renderers/spreadsheet/worker/sheetjs/sheet.worker.js +0 -11
  83. package/dist/renderers/spreadsheet/worker/type.d.ts +0 -57
  84. package/dist/renderers/spreadsheet/worker/type.js +0 -1
  85. package/dist/renderers/spreadsheet.d.ts +0 -3
  86. package/dist/renderers/spreadsheet.js +0 -929
  87. package/dist/renderers/typst.d.ts +0 -8
  88. package/dist/renderers/typst.js +0 -547
  89. package/dist/renderers/umd/parser.d.ts +0 -30
  90. package/dist/renderers/umd/parser.js +0 -408
  91. package/dist/renderers/umd.d.ts +0 -2
  92. package/dist/renderers/umd.js +0 -297
  93. package/dist/renderers/video.d.ts +0 -8
  94. package/dist/renderers/video.js +0 -108
  95. package/dist/renderers/wordDoc.d.ts +0 -5
  96. package/dist/renderers/wordDoc.js +0 -284
  97. package/dist/renderers/wordDocx.d.ts +0 -5
  98. package/dist/renderers/wordDocx.js +0 -985
  99. package/dist/renderers/wordDocx.worker.d.ts +0 -1
  100. package/dist/renderers/wordDocx.worker.js +0 -96
  101. package/vendor/ofd/dltech/jbig2/arithmetic_decoder.js +0 -183
  102. package/vendor/ofd/dltech/jbig2/ccitt.js +0 -1070
  103. package/vendor/ofd/dltech/jbig2/compatibility.js +0 -12
  104. package/vendor/ofd/dltech/jbig2/core_utils.js +0 -180
  105. package/vendor/ofd/dltech/jbig2/is_node.js +0 -27
  106. package/vendor/ofd/dltech/jbig2/jbig2.js +0 -2589
  107. package/vendor/ofd/dltech/jbig2/jbig2_stream.js +0 -81
  108. package/vendor/ofd/dltech/jbig2/primitives.js +0 -387
  109. package/vendor/ofd/dltech/jbig2/stream.js +0 -1348
  110. package/vendor/ofd/dltech/jbig2/util.js +0 -972
  111. package/vendor/ofd/dltech/ofd/ofd.d.ts +0 -11
  112. package/vendor/ofd/dltech/ofd/ofd.js +0 -100
  113. package/vendor/ofd/dltech/ofd/ofd_parser.js +0 -395
  114. package/vendor/ofd/dltech/ofd/ofd_render.js +0 -473
  115. package/vendor/ofd/dltech/ofd/ofd_util.js +0 -350
  116. 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;