@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.
- package/README.en.md +2 -2
- package/README.md +2 -2
- package/dist/config/options.d.ts +1 -1
- package/dist/config/options.js +1 -1
- package/dist/contracts/types.d.ts +76 -1
- package/dist/headless.d.ts +3 -3
- package/dist/headless.js +2 -2
- package/dist/index.d.ts +10 -7
- package/dist/index.js +106 -49
- package/dist/lifecycle/operations.d.ts +1 -0
- package/dist/lifecycle/operations.js +65 -6
- package/dist/platform/assets.d.ts +3 -1
- package/dist/platform/assets.js +43 -6
- package/dist/registry/capabilities.d.ts +2 -2
- package/dist/registry/capabilities.js +2 -1
- package/dist/registry/formats.d.ts +20 -7
- package/dist/registry/formats.js +14 -5
- package/dist/registry/registry.d.ts +8 -1
- package/dist/registry/registry.js +29 -0
- package/dist/renderers/image.js +1 -10
- package/dist/renderers/index.d.ts +320 -2
- package/dist/renderers/index.js +27 -157
- package/dist/viewer/createViewer.js +86 -3
- package/package.json +17 -44
- package/dist/renderers/archive.d.ts +0 -2
- package/dist/renderers/archive.js +0 -547
- package/dist/renderers/archiveCache.d.ts +0 -10
- package/dist/renderers/archiveCache.js +0 -96
- package/dist/renderers/archiveFallback.d.ts +0 -7
- package/dist/renderers/archiveFallback.js +0 -166
- package/dist/renderers/archiveShared.d.ts +0 -23
- package/dist/renderers/archiveShared.js +0 -71
- package/dist/renderers/audio.d.ts +0 -8
- package/dist/renderers/audio.js +0 -219
- package/dist/renderers/cad.d.ts +0 -2
- package/dist/renderers/cad.js +0 -446
- package/dist/renderers/code.d.ts +0 -11
- package/dist/renderers/code.js +0 -233
- package/dist/renderers/data.d.ts +0 -7
- package/dist/renderers/data.js +0 -370
- package/dist/renderers/drawing.d.ts +0 -10
- package/dist/renderers/drawing.js +0 -882
- package/dist/renderers/eda.d.ts +0 -2
- package/dist/renderers/eda.js +0 -434
- package/dist/renderers/edaParser.d.ts +0 -77
- package/dist/renderers/edaParser.js +0 -569
- package/dist/renderers/email.d.ts +0 -2
- package/dist/renderers/email.js +0 -463
- package/dist/renderers/epub.d.ts +0 -2
- package/dist/renderers/epub.js +0 -331
- package/dist/renderers/geo.d.ts +0 -2
- package/dist/renderers/geo.js +0 -284
- package/dist/renderers/markdown.d.ts +0 -2
- package/dist/renderers/markdown.js +0 -83
- package/dist/renderers/model.d.ts +0 -2
- package/dist/renderers/model.js +0 -567
- package/dist/renderers/ofd.d.ts +0 -2
- package/dist/renderers/ofd.js +0 -256
- package/dist/renderers/openDocument.d.ts +0 -2
- package/dist/renderers/openDocument.js +0 -122
- package/dist/renderers/pdf.d.ts +0 -3
- package/dist/renderers/pdf.js +0 -1001
- package/dist/renderers/pdfStyles.d.ts +0 -1
- package/dist/renderers/pdfStyles.js +0 -1
- package/dist/renderers/pptx.d.ts +0 -2
- package/dist/renderers/pptx.js +0 -217
- package/dist/renderers/spreadsheet/state.d.ts +0 -80
- package/dist/renderers/spreadsheet/state.js +0 -96
- package/dist/renderers/spreadsheet/view.d.ts +0 -25
- package/dist/renderers/spreadsheet/view.js +0 -833
- package/dist/renderers/spreadsheet/worker/index.d.ts +0 -2
- package/dist/renderers/spreadsheet/worker/index.js +0 -1
- package/dist/renderers/spreadsheet/worker/sheetjs/SheetJsModel.d.ts +0 -73
- package/dist/renderers/spreadsheet/worker/sheetjs/SheetJsModel.js +0 -623
- package/dist/renderers/spreadsheet/worker/sheetjs/color.d.ts +0 -2
- package/dist/renderers/spreadsheet/worker/sheetjs/color.js +0 -73
- package/dist/renderers/spreadsheet/worker/sheetjs/index.d.ts +0 -1
- package/dist/renderers/spreadsheet/worker/sheetjs/index.js +0 -1
- package/dist/renderers/spreadsheet/worker/sheetjs/parser.d.ts +0 -18
- package/dist/renderers/spreadsheet/worker/sheetjs/parser.js +0 -106
- package/dist/renderers/spreadsheet/worker/sheetjs/sheet.worker.d.ts +0 -1
- package/dist/renderers/spreadsheet/worker/sheetjs/sheet.worker.js +0 -11
- package/dist/renderers/spreadsheet/worker/type.d.ts +0 -57
- package/dist/renderers/spreadsheet/worker/type.js +0 -1
- package/dist/renderers/spreadsheet.d.ts +0 -3
- package/dist/renderers/spreadsheet.js +0 -929
- package/dist/renderers/typst.d.ts +0 -8
- package/dist/renderers/typst.js +0 -547
- package/dist/renderers/umd/parser.d.ts +0 -30
- package/dist/renderers/umd/parser.js +0 -408
- package/dist/renderers/umd.d.ts +0 -2
- package/dist/renderers/umd.js +0 -297
- package/dist/renderers/video.d.ts +0 -8
- package/dist/renderers/video.js +0 -108
- package/dist/renderers/wordDoc.d.ts +0 -5
- package/dist/renderers/wordDoc.js +0 -284
- package/dist/renderers/wordDocx.d.ts +0 -5
- package/dist/renderers/wordDocx.js +0 -985
- package/dist/renderers/wordDocx.worker.d.ts +0 -1
- package/dist/renderers/wordDocx.worker.js +0 -96
- package/vendor/ofd/dltech/jbig2/arithmetic_decoder.js +0 -183
- package/vendor/ofd/dltech/jbig2/ccitt.js +0 -1070
- package/vendor/ofd/dltech/jbig2/compatibility.js +0 -12
- package/vendor/ofd/dltech/jbig2/core_utils.js +0 -180
- package/vendor/ofd/dltech/jbig2/is_node.js +0 -27
- package/vendor/ofd/dltech/jbig2/jbig2.js +0 -2589
- package/vendor/ofd/dltech/jbig2/jbig2_stream.js +0 -81
- package/vendor/ofd/dltech/jbig2/primitives.js +0 -387
- package/vendor/ofd/dltech/jbig2/stream.js +0 -1348
- package/vendor/ofd/dltech/jbig2/util.js +0 -972
- package/vendor/ofd/dltech/ofd/ofd.d.ts +0 -11
- package/vendor/ofd/dltech/ofd/ofd.js +0 -100
- package/vendor/ofd/dltech/ofd/ofd_parser.js +0 -395
- package/vendor/ofd/dltech/ofd/ofd_render.js +0 -473
- package/vendor/ofd/dltech/ofd/ofd_util.js +0 -350
- 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 +0,0 @@
|
|
|
1
|
-
export {};
|
|
@@ -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;
|