@trebco/treb 37.0.0 → 37.0.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/build/package.json +119 -0
- package/build/treb-base-types/src/api_types.d.ts +11 -0
- package/build/treb-base-types/src/api_types.js +22 -0
- package/build/treb-base-types/src/api_types.js.map +1 -0
- package/build/treb-base-types/src/area-utils.d.ts +9 -0
- package/build/treb-base-types/src/area-utils.js +50 -0
- package/build/treb-base-types/src/area-utils.js.map +1 -0
- package/build/treb-base-types/src/area.d.ts +182 -0
- package/build/treb-base-types/src/area.js +715 -0
- package/build/treb-base-types/src/area.js.map +1 -0
- package/build/treb-base-types/src/basic_types.d.ts +20 -0
- package/build/treb-base-types/src/basic_types.js +22 -0
- package/build/treb-base-types/src/basic_types.js.map +1 -0
- package/build/treb-base-types/src/cell.d.ts +167 -0
- package/build/treb-base-types/src/cell.js +432 -0
- package/build/treb-base-types/src/cell.js.map +1 -0
- package/build/treb-base-types/src/cells.d.ts +251 -0
- package/build/treb-base-types/src/cells.js +1136 -0
- package/build/treb-base-types/src/cells.js.map +1 -0
- package/build/treb-base-types/src/color.d.ts +35 -0
- package/build/treb-base-types/src/color.js +162 -0
- package/build/treb-base-types/src/color.js.map +1 -0
- package/build/treb-base-types/src/dom-utilities.d.ts +70 -0
- package/build/treb-base-types/src/dom-utilities.js +144 -0
- package/build/treb-base-types/src/dom-utilities.js.map +1 -0
- package/build/treb-base-types/src/evaluate-options.d.ts +35 -0
- package/build/treb-base-types/src/evaluate-options.js +22 -0
- package/build/treb-base-types/src/evaluate-options.js.map +1 -0
- package/build/treb-base-types/src/font-stack.d.ts +37 -0
- package/build/treb-base-types/src/font-stack.js +93 -0
- package/build/treb-base-types/src/font-stack.js.map +1 -0
- package/build/treb-base-types/src/gradient.d.ts +18 -0
- package/build/treb-base-types/src/gradient.js +86 -0
- package/build/treb-base-types/src/gradient.js.map +1 -0
- package/build/treb-base-types/src/import.d.ts +48 -0
- package/build/treb-base-types/src/import.js +22 -0
- package/build/treb-base-types/src/import.js.map +1 -0
- package/build/treb-base-types/src/index-standalone.d.ts +6 -0
- package/build/treb-base-types/src/index-standalone.js +27 -0
- package/build/treb-base-types/src/index-standalone.js.map +1 -0
- package/build/treb-base-types/src/index.d.ts +22 -0
- package/build/treb-base-types/src/index.js +45 -0
- package/build/treb-base-types/src/index.js.map +1 -0
- package/build/treb-base-types/src/layout.d.ts +22 -0
- package/build/treb-base-types/src/layout.js +22 -0
- package/build/treb-base-types/src/layout.js.map +1 -0
- package/build/treb-base-types/src/localization.d.ts +37 -0
- package/build/treb-base-types/src/localization.js +157 -0
- package/build/treb-base-types/src/localization.js.map +1 -0
- package/build/treb-base-types/src/rectangle.d.ts +51 -0
- package/build/treb-base-types/src/rectangle.js +123 -0
- package/build/treb-base-types/src/rectangle.js.map +1 -0
- package/build/treb-base-types/src/render_text.d.ts +34 -0
- package/build/treb-base-types/src/render_text.js +22 -0
- package/build/treb-base-types/src/render_text.js.map +1 -0
- package/build/treb-base-types/src/style.d.ts +214 -0
- package/build/treb-base-types/src/style.js +373 -0
- package/build/treb-base-types/src/style.js.map +1 -0
- package/build/treb-base-types/src/table.d.ts +58 -0
- package/build/treb-base-types/src/table.js +27 -0
- package/build/treb-base-types/src/table.js.map +1 -0
- package/build/treb-base-types/src/text_part.d.ts +26 -0
- package/build/treb-base-types/src/text_part.js +47 -0
- package/build/treb-base-types/src/text_part.js.map +1 -0
- package/build/treb-base-types/src/theme.d.ts +120 -0
- package/build/treb-base-types/src/theme.js +460 -0
- package/build/treb-base-types/src/theme.js.map +1 -0
- package/build/treb-base-types/src/union.d.ts +73 -0
- package/build/treb-base-types/src/union.js +61 -0
- package/build/treb-base-types/src/union.js.map +1 -0
- package/build/treb-base-types/src/value-type.d.ts +86 -0
- package/build/treb-base-types/src/value-type.js +168 -0
- package/build/treb-base-types/src/value-type.js.map +1 -0
- package/build/treb-base-types/src/worker-proxy.d.ts +95 -0
- package/build/treb-base-types/src/worker-proxy.js +221 -0
- package/build/treb-base-types/src/worker-proxy.js.map +1 -0
- package/build/treb-calculator/src/calculator.d.ts +249 -0
- package/build/treb-calculator/src/calculator.js +2755 -0
- package/build/treb-calculator/src/calculator.js.map +1 -0
- package/build/treb-calculator/src/complex-math.d.ts +75 -0
- package/build/treb-calculator/src/complex-math.js +559 -0
- package/build/treb-calculator/src/complex-math.js.map +1 -0
- package/build/treb-calculator/src/dag/array-vertex.d.ts +71 -0
- package/build/treb-calculator/src/dag/array-vertex.js +156 -0
- package/build/treb-calculator/src/dag/array-vertex.js.map +1 -0
- package/build/treb-calculator/src/dag/calculation_leaf_vertex.d.ts +48 -0
- package/build/treb-calculator/src/dag/calculation_leaf_vertex.js +84 -0
- package/build/treb-calculator/src/dag/calculation_leaf_vertex.js.map +1 -0
- package/build/treb-calculator/src/dag/graph.d.ts +134 -0
- package/build/treb-calculator/src/dag/graph.js +842 -0
- package/build/treb-calculator/src/dag/graph.js.map +1 -0
- package/build/treb-calculator/src/dag/spreadsheet_vertex.d.ts +58 -0
- package/build/treb-calculator/src/dag/spreadsheet_vertex.js +232 -0
- package/build/treb-calculator/src/dag/spreadsheet_vertex.js.map +1 -0
- package/build/treb-calculator/src/dag/spreadsheet_vertex_base.d.ts +20 -0
- package/build/treb-calculator/src/dag/spreadsheet_vertex_base.js +25 -0
- package/build/treb-calculator/src/dag/spreadsheet_vertex_base.js.map +1 -0
- package/build/treb-calculator/src/dag/state_leaf_vertex.d.ts +43 -0
- package/build/treb-calculator/src/dag/state_leaf_vertex.js +81 -0
- package/build/treb-calculator/src/dag/state_leaf_vertex.js.map +1 -0
- package/build/treb-calculator/src/dag/vertex.d.ts +71 -0
- package/build/treb-calculator/src/dag/vertex.js +274 -0
- package/build/treb-calculator/src/dag/vertex.js.map +1 -0
- package/build/treb-calculator/src/descriptors.d.ts +189 -0
- package/build/treb-calculator/src/descriptors.js +22 -0
- package/build/treb-calculator/src/descriptors.js.map +1 -0
- package/build/treb-calculator/src/expression-calculator.d.ts +127 -0
- package/build/treb-calculator/src/expression-calculator.js +1033 -0
- package/build/treb-calculator/src/expression-calculator.js.map +1 -0
- package/build/treb-calculator/src/function-error.d.ts +35 -0
- package/build/treb-calculator/src/function-error.js +85 -0
- package/build/treb-calculator/src/function-error.js.map +1 -0
- package/build/treb-calculator/src/function-library.d.ts +22 -0
- package/build/treb-calculator/src/function-library.js +96 -0
- package/build/treb-calculator/src/function-library.js.map +1 -0
- package/build/treb-calculator/src/functions/base-functions.d.ts +7 -0
- package/build/treb-calculator/src/functions/base-functions.js +2611 -0
- package/build/treb-calculator/src/functions/base-functions.js.map +1 -0
- package/build/treb-calculator/src/functions/beta.d.ts +17 -0
- package/build/treb-calculator/src/functions/beta.js +201 -0
- package/build/treb-calculator/src/functions/beta.js.map +1 -0
- package/build/treb-calculator/src/functions/checkbox.d.ts +3 -0
- package/build/treb-calculator/src/functions/checkbox.js +128 -0
- package/build/treb-calculator/src/functions/checkbox.js.map +1 -0
- package/build/treb-calculator/src/functions/complex-functions.d.ts +2 -0
- package/build/treb-calculator/src/functions/complex-functions.js +217 -0
- package/build/treb-calculator/src/functions/complex-functions.js.map +1 -0
- package/build/treb-calculator/src/functions/date-utils.d.ts +3 -0
- package/build/treb-calculator/src/functions/date-utils.js +59 -0
- package/build/treb-calculator/src/functions/date-utils.js.map +1 -0
- package/build/treb-calculator/src/functions/finance-functions.d.ts +2 -0
- package/build/treb-calculator/src/functions/finance-functions.js +547 -0
- package/build/treb-calculator/src/functions/finance-functions.js.map +1 -0
- package/build/treb-calculator/src/functions/fp.d.ts +2 -0
- package/build/treb-calculator/src/functions/fp.js +463 -0
- package/build/treb-calculator/src/functions/fp.js.map +1 -0
- package/build/treb-calculator/src/functions/function-utilities.d.ts +2 -0
- package/build/treb-calculator/src/functions/function-utilities.js +36 -0
- package/build/treb-calculator/src/functions/function-utilities.js.map +1 -0
- package/build/treb-calculator/src/functions/gamma.d.ts +20 -0
- package/build/treb-calculator/src/functions/gamma.js +142 -0
- package/build/treb-calculator/src/functions/gamma.js.map +1 -0
- package/build/treb-calculator/src/functions/information-functions.d.ts +2 -0
- package/build/treb-calculator/src/functions/information-functions.js +71 -0
- package/build/treb-calculator/src/functions/information-functions.js.map +1 -0
- package/build/treb-calculator/src/functions/lambda-functions.d.ts +2 -0
- package/build/treb-calculator/src/functions/lambda-functions.js +85 -0
- package/build/treb-calculator/src/functions/lambda-functions.js.map +1 -0
- package/build/treb-calculator/src/functions/matrix-functions.d.ts +2 -0
- package/build/treb-calculator/src/functions/matrix-functions.js +144 -0
- package/build/treb-calculator/src/functions/matrix-functions.js.map +1 -0
- package/build/treb-calculator/src/functions/normal.d.ts +2 -0
- package/build/treb-calculator/src/functions/normal.js +32 -0
- package/build/treb-calculator/src/functions/normal.js.map +1 -0
- package/build/treb-calculator/src/functions/regex-functions.d.ts +2 -0
- package/build/treb-calculator/src/functions/regex-functions.js +188 -0
- package/build/treb-calculator/src/functions/regex-functions.js.map +1 -0
- package/build/treb-calculator/src/functions/sparkline.d.ts +37 -0
- package/build/treb-calculator/src/functions/sparkline.js +264 -0
- package/build/treb-calculator/src/functions/sparkline.js.map +1 -0
- package/build/treb-calculator/src/functions/statistics-functions.d.ts +6 -0
- package/build/treb-calculator/src/functions/statistics-functions.js +989 -0
- package/build/treb-calculator/src/functions/statistics-functions.js.map +1 -0
- package/build/treb-calculator/src/functions/students-t.d.ts +3 -0
- package/build/treb-calculator/src/functions/students-t.js +64 -0
- package/build/treb-calculator/src/functions/students-t.js.map +1 -0
- package/build/treb-calculator/src/functions/text-functions.d.ts +3 -0
- package/build/treb-calculator/src/functions/text-functions.js +320 -0
- package/build/treb-calculator/src/functions/text-functions.js.map +1 -0
- package/build/treb-calculator/src/index.d.ts +2 -0
- package/build/treb-calculator/src/index.js +22 -0
- package/build/treb-calculator/src/index.js.map +1 -0
- package/build/treb-calculator/src/notifier-types.d.ts +26 -0
- package/build/treb-calculator/src/notifier-types.js +22 -0
- package/build/treb-calculator/src/notifier-types.js.map +1 -0
- package/build/treb-calculator/src/primitives.d.ts +15 -0
- package/build/treb-calculator/src/primitives.js +398 -0
- package/build/treb-calculator/src/primitives.js.map +1 -0
- package/build/treb-calculator/src/utilities.d.ts +68 -0
- package/build/treb-calculator/src/utilities.js +324 -0
- package/build/treb-calculator/src/utilities.js.map +1 -0
- package/build/treb-charts/src/chart-functions.d.ts +8 -0
- package/build/treb-charts/src/chart-functions.js +209 -0
- package/build/treb-charts/src/chart-functions.js.map +1 -0
- package/build/treb-charts/src/chart-types.d.ts +233 -0
- package/build/treb-charts/src/chart-types.js +57 -0
- package/build/treb-charts/src/chart-types.js.map +1 -0
- package/build/treb-charts/src/chart-utils.d.ts +106 -0
- package/build/treb-charts/src/chart-utils.js +1060 -0
- package/build/treb-charts/src/chart-utils.js.map +1 -0
- package/build/treb-charts/src/chart.d.ts +23 -0
- package/build/treb-charts/src/chart.js +94 -0
- package/build/treb-charts/src/chart.js.map +1 -0
- package/build/treb-charts/src/default-chart-renderer.d.ts +16 -0
- package/build/treb-charts/src/default-chart-renderer.js +533 -0
- package/build/treb-charts/src/default-chart-renderer.js.map +1 -0
- package/build/treb-charts/src/index.d.ts +5 -0
- package/build/treb-charts/src/index.js +24 -0
- package/build/treb-charts/src/index.js.map +1 -0
- package/build/treb-charts/src/main.d.ts +1 -0
- package/build/treb-charts/src/main.js +34 -0
- package/build/treb-charts/src/main.js.map +1 -0
- package/build/treb-charts/src/quicksort.d.ts +1 -0
- package/build/treb-charts/src/quicksort.js +49 -0
- package/build/treb-charts/src/quicksort.js.map +1 -0
- package/build/treb-charts/src/rectangle.d.ts +18 -0
- package/build/treb-charts/src/rectangle.js +41 -0
- package/build/treb-charts/src/rectangle.js.map +1 -0
- package/build/treb-charts/src/renderer-type.d.ts +24 -0
- package/build/treb-charts/src/renderer-type.js +22 -0
- package/build/treb-charts/src/renderer-type.js.map +1 -0
- package/build/treb-charts/src/renderer.d.ts +127 -0
- package/build/treb-charts/src/renderer.js +1518 -0
- package/build/treb-charts/src/renderer.js.map +1 -0
- package/build/treb-charts/src/util.d.ts +18 -0
- package/build/treb-charts/src/util.js +71 -0
- package/build/treb-charts/src/util.js.map +1 -0
- package/build/treb-data-model/src/annotation.d.ts +167 -0
- package/build/treb-data-model/src/annotation.js +120 -0
- package/build/treb-data-model/src/annotation.js.map +1 -0
- package/build/treb-data-model/src/conditional_format.d.ts +155 -0
- package/build/treb-data-model/src/conditional_format.js +62 -0
- package/build/treb-data-model/src/conditional_format.js.map +1 -0
- package/build/treb-data-model/src/data-validation.d.ts +28 -0
- package/build/treb-data-model/src/data-validation.js +22 -0
- package/build/treb-data-model/src/data-validation.js.map +1 -0
- package/build/treb-data-model/src/data_model.d.ts +173 -0
- package/build/treb-data-model/src/data_model.js +637 -0
- package/build/treb-data-model/src/data_model.js.map +1 -0
- package/build/treb-data-model/src/index.d.ts +13 -0
- package/build/treb-data-model/src/index.js +28 -0
- package/build/treb-data-model/src/index.js.map +1 -0
- package/build/treb-data-model/src/language-model.d.ts +22 -0
- package/build/treb-data-model/src/language-model.js +22 -0
- package/build/treb-data-model/src/language-model.js.map +1 -0
- package/build/treb-data-model/src/named.d.ts +124 -0
- package/build/treb-data-model/src/named.js +372 -0
- package/build/treb-data-model/src/named.js.map +1 -0
- package/build/treb-data-model/src/serialize_options.d.ts +49 -0
- package/build/treb-data-model/src/serialize_options.js +22 -0
- package/build/treb-data-model/src/serialize_options.js.map +1 -0
- package/build/treb-data-model/src/sheet.d.ts +499 -0
- package/build/treb-data-model/src/sheet.js +2904 -0
- package/build/treb-data-model/src/sheet.js.map +1 -0
- package/build/treb-data-model/src/sheet_collection.d.ts +58 -0
- package/build/treb-data-model/src/sheet_collection.js +112 -0
- package/build/treb-data-model/src/sheet_collection.js.map +1 -0
- package/build/treb-data-model/src/sheet_selection.d.ts +42 -0
- package/build/treb-data-model/src/sheet_selection.js +39 -0
- package/build/treb-data-model/src/sheet_selection.js.map +1 -0
- package/build/treb-data-model/src/sheet_types.d.ts +104 -0
- package/build/treb-data-model/src/sheet_types.js +22 -0
- package/build/treb-data-model/src/sheet_types.js.map +1 -0
- package/build/treb-data-model/src/types.d.ts +59 -0
- package/build/treb-data-model/src/types.js +22 -0
- package/build/treb-data-model/src/types.js.map +1 -0
- package/build/treb-embed/src/custom-element/spreadsheet-constructor.d.ts +75 -0
- package/build/treb-embed/src/custom-element/spreadsheet-constructor.js +1144 -0
- package/build/treb-embed/src/custom-element/spreadsheet-constructor.js.map +1 -0
- package/build/treb-embed/src/custom-element/treb-global.d.ts +36 -0
- package/build/treb-embed/src/custom-element/treb-global.js +64 -0
- package/build/treb-embed/src/custom-element/treb-global.js.map +1 -0
- package/build/treb-embed/src/custom-element/treb-spreadsheet-element.d.ts +1 -0
- package/build/treb-embed/src/custom-element/treb-spreadsheet-element.js +61 -0
- package/build/treb-embed/src/custom-element/treb-spreadsheet-element.js.map +1 -0
- package/build/treb-embed/src/embedded-spreadsheet.d.ts +1358 -0
- package/build/treb-embed/src/embedded-spreadsheet.js +5205 -0
- package/build/treb-embed/src/embedded-spreadsheet.js.map +1 -0
- package/build/treb-embed/src/index.d.ts +12 -0
- package/build/treb-embed/src/index.js +34 -0
- package/build/treb-embed/src/index.js.map +1 -0
- package/build/treb-embed/src/options.d.ts +266 -0
- package/build/treb-embed/src/options.js +56 -0
- package/build/treb-embed/src/options.js.map +1 -0
- package/build/treb-embed/src/plugin.d.ts +9 -0
- package/build/treb-embed/src/plugin.js +22 -0
- package/build/treb-embed/src/plugin.js.map +1 -0
- package/build/treb-embed/src/progress-dialog.d.ts +49 -0
- package/build/treb-embed/src/progress-dialog.js +178 -0
- package/build/treb-embed/src/progress-dialog.js.map +1 -0
- package/build/treb-embed/src/selection-state.d.ts +15 -0
- package/build/treb-embed/src/selection-state.js +22 -0
- package/build/treb-embed/src/selection-state.js.map +1 -0
- package/build/treb-embed/src/spinner.d.ts +8 -0
- package/build/treb-embed/src/spinner.js +40 -0
- package/build/treb-embed/src/spinner.js.map +1 -0
- package/build/treb-embed/src/toolbar-message.d.ts +72 -0
- package/build/treb-embed/src/toolbar-message.js +22 -0
- package/build/treb-embed/src/toolbar-message.js.map +1 -0
- package/build/treb-embed/src/types.d.ts +185 -0
- package/build/treb-embed/src/types.js +45 -0
- package/build/treb-embed/src/types.js.map +1 -0
- package/build/treb-embed/tsconfig.tsbuildinfo +1 -0
- package/build/treb-export/src/address-type.d.ts +34 -0
- package/build/treb-export/src/address-type.js +53 -0
- package/build/treb-export/src/address-type.js.map +1 -0
- package/build/treb-export/src/base-template.d.ts +1 -0
- package/build/treb-export/src/base-template.js +22 -0
- package/build/treb-export/src/base-template.js.map +1 -0
- package/build/treb-export/src/column-width.d.ts +2 -0
- package/build/treb-export/src/column-width.js +80 -0
- package/build/treb-export/src/column-width.js.map +1 -0
- package/build/treb-export/src/drawing/bubble-chart-template.d.ts +514 -0
- package/build/treb-export/src/drawing/bubble-chart-template.js +544 -0
- package/build/treb-export/src/drawing/bubble-chart-template.js.map +1 -0
- package/build/treb-export/src/drawing/chart-template-components2.d.ts +365 -0
- package/build/treb-export/src/drawing/chart-template-components2.js +386 -0
- package/build/treb-export/src/drawing/chart-template-components2.js.map +1 -0
- package/build/treb-export/src/drawing/chart.d.ts +26 -0
- package/build/treb-export/src/drawing/chart.js +247 -0
- package/build/treb-export/src/drawing/chart.js.map +1 -0
- package/build/treb-export/src/drawing/column-chart-template2.d.ts +490 -0
- package/build/treb-export/src/drawing/column-chart-template2.js +518 -0
- package/build/treb-export/src/drawing/column-chart-template2.js.map +1 -0
- package/build/treb-export/src/drawing/donut-chart-template2.d.ts +272 -0
- package/build/treb-export/src/drawing/donut-chart-template2.js +293 -0
- package/build/treb-export/src/drawing/donut-chart-template2.js.map +1 -0
- package/build/treb-export/src/drawing/drawing.d.ts +49 -0
- package/build/treb-export/src/drawing/drawing.js +193 -0
- package/build/treb-export/src/drawing/drawing.js.map +1 -0
- package/build/treb-export/src/drawing/embedded-image.d.ts +12 -0
- package/build/treb-export/src/drawing/embedded-image.js +54 -0
- package/build/treb-export/src/drawing/embedded-image.js.map +1 -0
- package/build/treb-export/src/drawing/scatter-chart-template2.d.ts +520 -0
- package/build/treb-export/src/drawing/scatter-chart-template2.js +551 -0
- package/build/treb-export/src/drawing/scatter-chart-template2.js.map +1 -0
- package/build/treb-export/src/export.d.ts +72 -0
- package/build/treb-export/src/export.js +2039 -0
- package/build/treb-export/src/export.js.map +1 -0
- package/build/treb-export/src/import-export-messages.d.ts +31 -0
- package/build/treb-export/src/import-export-messages.js +22 -0
- package/build/treb-export/src/import-export-messages.js.map +1 -0
- package/build/treb-export/src/import.d.ts +33 -0
- package/build/treb-export/src/import.js +1258 -0
- package/build/treb-export/src/import.js.map +1 -0
- package/build/treb-export/src/index.worker.d.ts +1 -0
- package/build/treb-export/src/index.worker.js +93 -0
- package/build/treb-export/src/index.worker.js.map +1 -0
- package/build/treb-export/src/metadata.d.ts +51 -0
- package/build/treb-export/src/metadata.js +153 -0
- package/build/treb-export/src/metadata.js.map +1 -0
- package/build/treb-export/src/ooxml.d.ts +7 -0
- package/build/treb-export/src/ooxml.js +41 -0
- package/build/treb-export/src/ooxml.js.map +1 -0
- package/build/treb-export/src/relationship.d.ts +8 -0
- package/build/treb-export/src/relationship.js +27 -0
- package/build/treb-export/src/relationship.js.map +1 -0
- package/build/treb-export/src/shared-strings.d.ts +11 -0
- package/build/treb-export/src/shared-strings.js +105 -0
- package/build/treb-export/src/shared-strings.js.map +1 -0
- package/build/treb-export/src/template-2.d.ts +1 -0
- package/build/treb-export/src/template-2.js +22 -0
- package/build/treb-export/src/template-2.js.map +1 -0
- package/build/treb-export/src/unescape_xml.d.ts +1 -0
- package/build/treb-export/src/unescape_xml.js +61 -0
- package/build/treb-export/src/unescape_xml.js.map +1 -0
- package/build/treb-export/src/workbook-sheet.d.ts +75 -0
- package/build/treb-export/src/workbook-sheet.js +128 -0
- package/build/treb-export/src/workbook-sheet.js.map +1 -0
- package/build/treb-export/src/workbook-style.d.ts +110 -0
- package/build/treb-export/src/workbook-style.js +1134 -0
- package/build/treb-export/src/workbook-style.js.map +1 -0
- package/build/treb-export/src/workbook-theme.d.ts +13 -0
- package/build/treb-export/src/workbook-theme.js +85 -0
- package/build/treb-export/src/workbook-theme.js.map +1 -0
- package/build/treb-export/src/workbook.d.ts +123 -0
- package/build/treb-export/src/workbook.js +644 -0
- package/build/treb-export/src/workbook.js.map +1 -0
- package/build/treb-export/src/xml-test.d.ts +9 -0
- package/build/treb-export/src/xml-test.js +52 -0
- package/build/treb-export/src/xml-test.js.map +1 -0
- package/build/treb-export/src/xml-utils.d.ts +76 -0
- package/build/treb-export/src/xml-utils.js +223 -0
- package/build/treb-export/src/xml-utils.js.map +1 -0
- package/build/treb-export/src/zip-wrapper.d.ts +22 -0
- package/build/treb-export/src/zip-wrapper.js +93 -0
- package/build/treb-export/src/zip-wrapper.js.map +1 -0
- package/build/treb-format/src/format.d.ts +130 -0
- package/build/treb-format/src/format.js +805 -0
- package/build/treb-format/src/format.js.map +1 -0
- package/build/treb-format/src/format_cache.d.ts +55 -0
- package/build/treb-format/src/format_cache.js +166 -0
- package/build/treb-format/src/format_cache.js.map +1 -0
- package/build/treb-format/src/format_parser.d.ts +70 -0
- package/build/treb-format/src/format_parser.js +618 -0
- package/build/treb-format/src/format_parser.js.map +1 -0
- package/build/treb-format/src/index.d.ts +4 -0
- package/build/treb-format/src/index.js +25 -0
- package/build/treb-format/src/index.js.map +1 -0
- package/build/treb-format/src/number_format_section.d.ts +58 -0
- package/build/treb-format/src/number_format_section.js +78 -0
- package/build/treb-format/src/number_format_section.js.map +1 -0
- package/build/treb-format/src/value_parser.d.ts +48 -0
- package/build/treb-format/src/value_parser.js +244 -0
- package/build/treb-format/src/value_parser.js.map +1 -0
- package/build/treb-grid/src/editors/autocomplete.d.ts +39 -0
- package/build/treb-grid/src/editors/autocomplete.js +316 -0
- package/build/treb-grid/src/editors/autocomplete.js.map +1 -0
- package/build/treb-grid/src/editors/autocomplete_matcher.d.ts +74 -0
- package/build/treb-grid/src/editors/autocomplete_matcher.js +212 -0
- package/build/treb-grid/src/editors/autocomplete_matcher.js.map +1 -0
- package/build/treb-grid/src/editors/editor.d.ts +214 -0
- package/build/treb-grid/src/editors/editor.js +879 -0
- package/build/treb-grid/src/editors/editor.js.map +1 -0
- package/build/treb-grid/src/editors/external_editor.d.ts +11 -0
- package/build/treb-grid/src/editors/external_editor.js +118 -0
- package/build/treb-grid/src/editors/external_editor.js.map +1 -0
- package/build/treb-grid/src/editors/formula_bar.d.ts +85 -0
- package/build/treb-grid/src/editors/formula_bar.js +444 -0
- package/build/treb-grid/src/editors/formula_bar.js.map +1 -0
- package/build/treb-grid/src/editors/overlay_editor.d.ts +85 -0
- package/build/treb-grid/src/editors/overlay_editor.js +353 -0
- package/build/treb-grid/src/editors/overlay_editor.js.map +1 -0
- package/build/treb-grid/src/index.d.ts +12 -0
- package/build/treb-grid/src/index.js +28 -0
- package/build/treb-grid/src/index.js.map +1 -0
- package/build/treb-grid/src/layout/base_layout.d.ts +346 -0
- package/build/treb-grid/src/layout/base_layout.js +2050 -0
- package/build/treb-grid/src/layout/base_layout.js.map +1 -0
- package/build/treb-grid/src/layout/grid_layout.d.ts +19 -0
- package/build/treb-grid/src/layout/grid_layout.js +235 -0
- package/build/treb-grid/src/layout/grid_layout.js.map +1 -0
- package/build/treb-grid/src/layout/mock-layout.d.ts +10 -0
- package/build/treb-grid/src/layout/mock-layout.js +37 -0
- package/build/treb-grid/src/layout/mock-layout.js.map +1 -0
- package/build/treb-grid/src/render/selection-renderer.d.ts +97 -0
- package/build/treb-grid/src/render/selection-renderer.js +315 -0
- package/build/treb-grid/src/render/selection-renderer.js.map +1 -0
- package/build/treb-grid/src/render/svg_header_overlay.d.ts +20 -0
- package/build/treb-grid/src/render/svg_header_overlay.js +76 -0
- package/build/treb-grid/src/render/svg_header_overlay.js.map +1 -0
- package/build/treb-grid/src/render/svg_selection_block.d.ts +27 -0
- package/build/treb-grid/src/render/svg_selection_block.js +106 -0
- package/build/treb-grid/src/render/svg_selection_block.js.map +1 -0
- package/build/treb-grid/src/render/tile_renderer.d.ts +121 -0
- package/build/treb-grid/src/render/tile_renderer.js +1609 -0
- package/build/treb-grid/src/render/tile_renderer.js.map +1 -0
- package/build/treb-grid/src/types/border_constants.d.ts +9 -0
- package/build/treb-grid/src/types/border_constants.js +34 -0
- package/build/treb-grid/src/types/border_constants.js.map +1 -0
- package/build/treb-grid/src/types/clipboard_data.d.ts +11 -0
- package/build/treb-grid/src/types/clipboard_data.js +22 -0
- package/build/treb-grid/src/types/clipboard_data.js.map +1 -0
- package/build/treb-grid/src/types/clipboard_data2.d.ts +46 -0
- package/build/treb-grid/src/types/clipboard_data2.js +22 -0
- package/build/treb-grid/src/types/clipboard_data2.js.map +1 -0
- package/build/treb-grid/src/types/drag_mask.d.ts +10 -0
- package/build/treb-grid/src/types/drag_mask.js +78 -0
- package/build/treb-grid/src/types/drag_mask.js.map +1 -0
- package/build/treb-grid/src/types/external_editor_config.d.ts +33 -0
- package/build/treb-grid/src/types/external_editor_config.js +22 -0
- package/build/treb-grid/src/types/external_editor_config.js.map +1 -0
- package/build/treb-grid/src/types/grid.d.ts +806 -0
- package/build/treb-grid/src/types/grid.js +6410 -0
- package/build/treb-grid/src/types/grid.js.map +1 -0
- package/build/treb-grid/src/types/grid_base.d.ts +442 -0
- package/build/treb-grid/src/types/grid_base.js +3523 -0
- package/build/treb-grid/src/types/grid_base.js.map +1 -0
- package/build/treb-grid/src/types/grid_command.d.ts +408 -0
- package/build/treb-grid/src/types/grid_command.js +75 -0
- package/build/treb-grid/src/types/grid_command.js.map +1 -0
- package/build/treb-grid/src/types/grid_events.d.ts +93 -0
- package/build/treb-grid/src/types/grid_events.js +36 -0
- package/build/treb-grid/src/types/grid_events.js.map +1 -0
- package/build/treb-grid/src/types/grid_options.d.ts +50 -0
- package/build/treb-grid/src/types/grid_options.js +34 -0
- package/build/treb-grid/src/types/grid_options.js.map +1 -0
- package/build/treb-grid/src/types/scale-control.d.ts +21 -0
- package/build/treb-grid/src/types/scale-control.js +148 -0
- package/build/treb-grid/src/types/scale-control.js.map +1 -0
- package/build/treb-grid/src/types/set_range_options.d.ts +24 -0
- package/build/treb-grid/src/types/set_range_options.js +22 -0
- package/build/treb-grid/src/types/set_range_options.js.map +1 -0
- package/build/treb-grid/src/types/tab_bar.d.ts +84 -0
- package/build/treb-grid/src/types/tab_bar.js +426 -0
- package/build/treb-grid/src/types/tab_bar.js.map +1 -0
- package/build/treb-grid/src/types/tile.d.ts +29 -0
- package/build/treb-grid/src/types/tile.js +22 -0
- package/build/treb-grid/src/types/tile.js.map +1 -0
- package/build/treb-grid/src/types/update_flags.d.ts +48 -0
- package/build/treb-grid/src/types/update_flags.js +22 -0
- package/build/treb-grid/src/types/update_flags.js.map +1 -0
- package/build/treb-grid/src/util/fontmetrics.d.ts +21 -0
- package/build/treb-grid/src/util/fontmetrics.js +82 -0
- package/build/treb-grid/src/util/fontmetrics.js.map +1 -0
- package/build/treb-grid/src/util/ua.d.ts +33 -0
- package/build/treb-grid/src/util/ua.js +86 -0
- package/build/treb-grid/src/util/ua.js.map +1 -0
- package/build/treb-parser/src/csv-parser.d.ts +13 -0
- package/build/treb-parser/src/csv-parser.js +107 -0
- package/build/treb-parser/src/csv-parser.js.map +1 -0
- package/build/treb-parser/src/index.d.ts +4 -0
- package/build/treb-parser/src/index.js +25 -0
- package/build/treb-parser/src/index.js.map +1 -0
- package/build/treb-parser/src/md-parser.d.ts +97 -0
- package/build/treb-parser/src/md-parser.js +403 -0
- package/build/treb-parser/src/md-parser.js.map +1 -0
- package/build/treb-parser/src/parser-types.d.ts +345 -0
- package/build/treb-parser/src/parser-types.js +53 -0
- package/build/treb-parser/src/parser-types.js.map +1 -0
- package/build/treb-parser/src/parser.d.ts +422 -0
- package/build/treb-parser/src/parser.js +2418 -0
- package/build/treb-parser/src/parser.js.map +1 -0
- package/build/treb-utils/src/event_source.d.ts +34 -0
- package/build/treb-utils/src/event_source.js +110 -0
- package/build/treb-utils/src/event_source.js.map +1 -0
- package/build/treb-utils/src/ievent_source.d.ts +9 -0
- package/build/treb-utils/src/ievent_source.js +22 -0
- package/build/treb-utils/src/ievent_source.js.map +1 -0
- package/build/treb-utils/src/index.d.ts +6 -0
- package/build/treb-utils/src/index.js +30 -0
- package/build/treb-utils/src/index.js.map +1 -0
- package/build/treb-utils/src/measurement.d.ts +42 -0
- package/build/treb-utils/src/measurement.js +145 -0
- package/build/treb-utils/src/measurement.js.map +1 -0
- package/build/treb-utils/src/scale.d.ts +16 -0
- package/build/treb-utils/src/scale.js +106 -0
- package/build/treb-utils/src/scale.js.map +1 -0
- package/build/treb-utils/src/serialize_html.d.ts +5 -0
- package/build/treb-utils/src/serialize_html.js +128 -0
- package/build/treb-utils/src/serialize_html.js.map +1 -0
- package/build/treb-utils/src/validate_uri.d.ts +20 -0
- package/build/treb-utils/src/validate_uri.js +55 -0
- package/build/treb-utils/src/validate_uri.js.map +1 -0
- package/dist/{chunk-XD5PEZBZ.mjs → chunk-E35ONJUS.mjs} +1 -1
- package/dist/treb-export-worker.mjs +2 -2
- package/dist/treb-spreadsheet.mjs +4 -4
- package/package.json +1 -1
|
@@ -0,0 +1,644 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* This file is part of TREB.
|
|
3
|
+
*
|
|
4
|
+
* TREB is free software: you can redistribute it and/or modify it under the
|
|
5
|
+
* terms of the GNU General Public License as published by the Free Software
|
|
6
|
+
* Foundation, either version 3 of the License, or (at your option) any
|
|
7
|
+
* later version.
|
|
8
|
+
*
|
|
9
|
+
* TREB is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
10
|
+
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
11
|
+
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
12
|
+
* details.
|
|
13
|
+
*
|
|
14
|
+
* You should have received a copy of the GNU General Public License along
|
|
15
|
+
* with TREB. If not, see <https://www.gnu.org/licenses/>.
|
|
16
|
+
*
|
|
17
|
+
* Copyright 2022-2026 trebco, llc.
|
|
18
|
+
* info@treb.app
|
|
19
|
+
*
|
|
20
|
+
*/
|
|
21
|
+
import { XMLParser } from 'fast-xml-parser';
|
|
22
|
+
import { XMLUtils, XMLOptions2 } from './xml-utils';
|
|
23
|
+
// const xmlparser = new XMLParser();
|
|
24
|
+
// const xmlparser1 = new XMLParser(XMLOptions);
|
|
25
|
+
const xmlparser2 = new XMLParser(XMLOptions2);
|
|
26
|
+
import { SharedStrings } from './shared-strings';
|
|
27
|
+
import { StyleCache } from './workbook-style';
|
|
28
|
+
import { Theme } from './workbook-theme';
|
|
29
|
+
import { Sheet, VisibleState } from './workbook-sheet';
|
|
30
|
+
import { ZipWrapper } from './zip-wrapper';
|
|
31
|
+
import { ParseMetadataXML } from './metadata';
|
|
32
|
+
///////////////
|
|
33
|
+
import * as OOXML from 'ooxml-types';
|
|
34
|
+
import { ooxml_parser, IterateTags, MapTags, FirstTag } from './ooxml';
|
|
35
|
+
///////////////
|
|
36
|
+
/**
|
|
37
|
+
* @privateRemarks -- FIXME: not sure about the equal/equals thing. need to check.
|
|
38
|
+
*/
|
|
39
|
+
export const ConditionalFormatOperators = {
|
|
40
|
+
greaterThan: '>',
|
|
41
|
+
greaterThanOrEqual: '>=',
|
|
42
|
+
// greaterThanOrEquals: '>=',
|
|
43
|
+
lessThan: '<',
|
|
44
|
+
lessThanOrEqual: '<=',
|
|
45
|
+
// lessThanOrEquals: '<=',
|
|
46
|
+
equal: '=',
|
|
47
|
+
notEqual: '<>',
|
|
48
|
+
};
|
|
49
|
+
//
|
|
50
|
+
// enums? really? in 2025? FIXME
|
|
51
|
+
//
|
|
52
|
+
export var ChartType;
|
|
53
|
+
(function (ChartType) {
|
|
54
|
+
ChartType[ChartType["Null"] = 0] = "Null";
|
|
55
|
+
ChartType[ChartType["Column"] = 1] = "Column";
|
|
56
|
+
ChartType[ChartType["Bar"] = 2] = "Bar";
|
|
57
|
+
ChartType[ChartType["Line"] = 3] = "Line";
|
|
58
|
+
ChartType[ChartType["Scatter"] = 4] = "Scatter";
|
|
59
|
+
ChartType[ChartType["Donut"] = 5] = "Donut";
|
|
60
|
+
ChartType[ChartType["Pie"] = 6] = "Pie";
|
|
61
|
+
ChartType[ChartType["Bubble"] = 7] = "Bubble";
|
|
62
|
+
ChartType[ChartType["Box"] = 8] = "Box";
|
|
63
|
+
ChartType[ChartType["Histogram"] = 9] = "Histogram";
|
|
64
|
+
ChartType[ChartType["Unknown"] = 10] = "Unknown";
|
|
65
|
+
})(ChartType || (ChartType = {}));
|
|
66
|
+
export class Workbook {
|
|
67
|
+
zip;
|
|
68
|
+
xml = {};
|
|
69
|
+
/** start with an empty strings table, if we load a file we will update it */
|
|
70
|
+
shared_strings = new SharedStrings();
|
|
71
|
+
/** document styles */
|
|
72
|
+
style_cache = new StyleCache(); // public temp
|
|
73
|
+
/** theme */
|
|
74
|
+
theme = new Theme();
|
|
75
|
+
/* * defined names. these can be ranges or expressions. */
|
|
76
|
+
// public defined_names: Record<string, string> = {};
|
|
77
|
+
named = [];
|
|
78
|
+
/** the workbook "rels" */
|
|
79
|
+
rels = {};
|
|
80
|
+
/** metadata reference; new and WIP */
|
|
81
|
+
metadata;
|
|
82
|
+
sheets = [];
|
|
83
|
+
active_tab = 0;
|
|
84
|
+
get sheet_count() {
|
|
85
|
+
return this.sheets.length;
|
|
86
|
+
}
|
|
87
|
+
constructor(zip) {
|
|
88
|
+
this.zip = zip;
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* given a path in the zip file, read and parse the rels file
|
|
92
|
+
*/
|
|
93
|
+
ReadRels(path) {
|
|
94
|
+
const rels = {};
|
|
95
|
+
const data = this.zip.Has(path) ? this.zip.Get(path) : '';
|
|
96
|
+
const root = ooxml_parser.parse(data);
|
|
97
|
+
if (root.Relationships) {
|
|
98
|
+
const relationships = root.Relationships;
|
|
99
|
+
IterateTags(relationships.Relationship, (relationship) => {
|
|
100
|
+
const id = relationship.$attributes?.Id;
|
|
101
|
+
if (id) {
|
|
102
|
+
rels[id] = {
|
|
103
|
+
id,
|
|
104
|
+
type: relationship.$attributes?.Type || '',
|
|
105
|
+
target: relationship.$attributes?.Target || '',
|
|
106
|
+
};
|
|
107
|
+
}
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
// console.info({rels});
|
|
111
|
+
return rels;
|
|
112
|
+
}
|
|
113
|
+
Init() {
|
|
114
|
+
// read workbook rels
|
|
115
|
+
this.rels = this.ReadRels('xl/_rels/workbook.xml.rels');
|
|
116
|
+
// shared strings
|
|
117
|
+
let data = this.zip.Has('xl/sharedStrings.xml') ? this.zip.Get('xl/sharedStrings.xml') : '';
|
|
118
|
+
let parsed = ooxml_parser.parse(data || '');
|
|
119
|
+
if (parsed.sst) {
|
|
120
|
+
this.shared_strings.FromXML(parsed.sst);
|
|
121
|
+
}
|
|
122
|
+
// metadata
|
|
123
|
+
if (this.zip.Has('xl/metadata.xml')) {
|
|
124
|
+
data = this.zip.Get('xl/metadata.xml');
|
|
125
|
+
parsed = ooxml_parser.parse(data || '');
|
|
126
|
+
if (parsed.metadata) {
|
|
127
|
+
this.metadata = ParseMetadataXML(parsed.metadata);
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
// theme
|
|
131
|
+
data = this.zip.Get('xl/theme/theme1.xml');
|
|
132
|
+
parsed = ooxml_parser.parse(data);
|
|
133
|
+
if (parsed.theme) {
|
|
134
|
+
this.theme.FromXML(parsed.theme);
|
|
135
|
+
}
|
|
136
|
+
// styles
|
|
137
|
+
data = this.zip.Get('xl/styles.xml');
|
|
138
|
+
parsed = ooxml_parser.parse(data);
|
|
139
|
+
if (parsed.styleSheet) {
|
|
140
|
+
this.style_cache.FromXML(parsed.styleSheet, this.theme);
|
|
141
|
+
}
|
|
142
|
+
// read workbook
|
|
143
|
+
data = this.zip.Get('xl/workbook.xml');
|
|
144
|
+
parsed = ooxml_parser.parse(data);
|
|
145
|
+
// defined names
|
|
146
|
+
if (parsed.workbook) {
|
|
147
|
+
const wb = parsed.workbook;
|
|
148
|
+
this.named = MapTags(wb.definedNames?.definedName, defined_name => {
|
|
149
|
+
return {
|
|
150
|
+
name: defined_name.$attributes?.name || '',
|
|
151
|
+
expression: defined_name.$text || '',
|
|
152
|
+
local_scope: defined_name.$attributes?.localSheetId,
|
|
153
|
+
};
|
|
154
|
+
});
|
|
155
|
+
const view = FirstTag(wb.bookViews?.workbookView);
|
|
156
|
+
this.active_tab = view?.$attributes?.activeTab ?? 0;
|
|
157
|
+
IterateTags(wb.sheets.sheet, element => {
|
|
158
|
+
const name = element.$attributes?.name;
|
|
159
|
+
if (name) {
|
|
160
|
+
const state = element.$attributes?.state;
|
|
161
|
+
const rid = element.$attributes?.id ?? '';
|
|
162
|
+
const id = element.$attributes?.sheetId;
|
|
163
|
+
const worksheet_path = `xl/${this.rels[rid].target}`;
|
|
164
|
+
data = this.zip.Get(worksheet_path);
|
|
165
|
+
parsed = ooxml_parser.parse(data);
|
|
166
|
+
if (parsed.worksheet) {
|
|
167
|
+
const root = parsed.worksheet;
|
|
168
|
+
const worksheet = new Sheet({
|
|
169
|
+
name, rid, id,
|
|
170
|
+
}, root);
|
|
171
|
+
switch (state) {
|
|
172
|
+
case 'hidden':
|
|
173
|
+
worksheet.visible_state = VisibleState.hidden;
|
|
174
|
+
break;
|
|
175
|
+
case 'veryHidden':
|
|
176
|
+
worksheet.visible_state = VisibleState.hidden;
|
|
177
|
+
break;
|
|
178
|
+
}
|
|
179
|
+
worksheet.shared_strings = this.shared_strings;
|
|
180
|
+
worksheet.path = worksheet_path;
|
|
181
|
+
worksheet.rels_path = worksheet.path.replace('worksheets', 'worksheets/_rels') + '.rels';
|
|
182
|
+
worksheet.rels = this.ReadRels(worksheet.rels_path);
|
|
183
|
+
worksheet.Parse();
|
|
184
|
+
this.sheets.push(worksheet);
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
});
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
ReadTable(reference) {
|
|
191
|
+
const data = this.zip.Get(reference.replace(/^../, 'xl'));
|
|
192
|
+
if (!data) {
|
|
193
|
+
return undefined;
|
|
194
|
+
}
|
|
195
|
+
const xml = xmlparser2.parse(data);
|
|
196
|
+
const name = xml.table?.a$?.name || '';
|
|
197
|
+
const table = {
|
|
198
|
+
name,
|
|
199
|
+
display_name: xml.table?.a$?.displayName || name,
|
|
200
|
+
ref: xml.table?.a$.ref || '',
|
|
201
|
+
totals_row_shown: Number(xml.table?.a$.totalsRowShown || '0') || 0,
|
|
202
|
+
totals_row_count: Number(xml.table?.a$.totalsRowCount || '0') || 0,
|
|
203
|
+
};
|
|
204
|
+
return table;
|
|
205
|
+
}
|
|
206
|
+
ReadDrawing(reference) {
|
|
207
|
+
const data = this.zip.Get(reference.replace(/^../, 'xl'));
|
|
208
|
+
if (!data) {
|
|
209
|
+
return undefined;
|
|
210
|
+
}
|
|
211
|
+
const xml = xmlparser2.parse(data);
|
|
212
|
+
const drawing_rels = this.ReadRels(reference.replace(/^..\/drawings/, 'xl/drawings/_rels') + '.rels');
|
|
213
|
+
const results = [];
|
|
214
|
+
const anchor_nodes = XMLUtils.FindAll(xml, 'xdr:wsDr/xdr:twoCellAnchor');
|
|
215
|
+
/* FIXME: move to drawing? */
|
|
216
|
+
const ParseAnchor = (node = {}) => {
|
|
217
|
+
const anchor = {
|
|
218
|
+
column: node['xdr:col'] || 0,
|
|
219
|
+
column_offset: node['xdr:colOff'] || 0,
|
|
220
|
+
row: node['xdr:row'] || 0,
|
|
221
|
+
row_offset: node['xdr:rowOff'] || 0,
|
|
222
|
+
};
|
|
223
|
+
return anchor;
|
|
224
|
+
};
|
|
225
|
+
for (const anchor_node of anchor_nodes) {
|
|
226
|
+
const anchor = {
|
|
227
|
+
from: ParseAnchor(anchor_node['xdr:from']),
|
|
228
|
+
to: ParseAnchor(anchor_node['xdr:to']),
|
|
229
|
+
};
|
|
230
|
+
let chart_reference = XMLUtils.FindAll(anchor_node, `xdr:graphicFrame/a:graphic/a:graphicData/c:chart`)[0];
|
|
231
|
+
// check for an "alternate content" chart/chartex (wtf ms). we're
|
|
232
|
+
// supporting this for box charts only (atm)
|
|
233
|
+
if (!chart_reference) {
|
|
234
|
+
chart_reference = XMLUtils.FindAll(anchor_node, `mc:AlternateContent/mc:Choice/xdr:graphicFrame/a:graphic/a:graphicData/cx:chart`)[0];
|
|
235
|
+
}
|
|
236
|
+
if (chart_reference && chart_reference.a$ && chart_reference.a$['r:id']) {
|
|
237
|
+
const result = { type: 'chart', anchor };
|
|
238
|
+
const chart_rel = drawing_rels[chart_reference.a$['r:id']];
|
|
239
|
+
if (chart_rel && chart_rel.target) {
|
|
240
|
+
result.chart = this.ReadChart(chart_rel.target);
|
|
241
|
+
}
|
|
242
|
+
results.push(result);
|
|
243
|
+
}
|
|
244
|
+
else {
|
|
245
|
+
const media_reference = XMLUtils.FindAll(anchor_node, `xdr:pic/xdr:blipFill/a:blip`)[0];
|
|
246
|
+
if (media_reference && media_reference.a$['r:embed']) {
|
|
247
|
+
const media_rel = drawing_rels[media_reference.a$['r:embed']];
|
|
248
|
+
// const chart_rel = drawing_rels[chart_reference.a$['r:id']];
|
|
249
|
+
// console.info("Maybe an image?", media_reference, media_rel)
|
|
250
|
+
if (media_rel && media_rel.target) {
|
|
251
|
+
if (/(?:jpg|jpeg|png|gif)$/i.test(media_rel.target)) {
|
|
252
|
+
// const result: AnchoredImageDescription = { type: 'image' };
|
|
253
|
+
const path = media_rel.target.replace(/^\.\./, 'xl');
|
|
254
|
+
const filename = path.replace(/^.*\//, '');
|
|
255
|
+
const result = {
|
|
256
|
+
type: 'image', anchor, image: this.zip.GetBinary(path), filename
|
|
257
|
+
};
|
|
258
|
+
results.push(result);
|
|
259
|
+
}
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
else {
|
|
263
|
+
let style;
|
|
264
|
+
const sp = XMLUtils.FindAll(anchor_node, 'xdr:sp')[0];
|
|
265
|
+
if (sp) {
|
|
266
|
+
const reference = sp.a$?.textlink || undefined;
|
|
267
|
+
const sppr = XMLUtils.FindAll(sp, 'xdr:spPr')[0];
|
|
268
|
+
if (sppr) {
|
|
269
|
+
style = {};
|
|
270
|
+
const fill = sppr['a:solidFill'];
|
|
271
|
+
if (fill) {
|
|
272
|
+
if (fill['a:schemeClr']?.a$?.val) {
|
|
273
|
+
const m = (fill['a:schemeClr'].a$.val).match(/accent(\d+)/);
|
|
274
|
+
if (m) {
|
|
275
|
+
style.fill = { theme: Number(m[1]) + 3 };
|
|
276
|
+
if (fill['a:schemeClr']['a:lumOff']?.a$?.val) {
|
|
277
|
+
const num = Number(fill['a:schemeClr']['a:lumOff'].a$.val);
|
|
278
|
+
if (!isNaN(num)) {
|
|
279
|
+
style.fill.tint = num / 1e5;
|
|
280
|
+
}
|
|
281
|
+
}
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
}
|
|
285
|
+
}
|
|
286
|
+
const tx = XMLUtils.FindAll(sp, 'xdr:txBody')[0];
|
|
287
|
+
if (tx) {
|
|
288
|
+
const paragraphs = [];
|
|
289
|
+
const p_list = XMLUtils.FindAll(tx, 'a:p');
|
|
290
|
+
for (const paragraph of p_list) {
|
|
291
|
+
const para = [];
|
|
292
|
+
let style;
|
|
293
|
+
const fld = paragraph['a:fld'];
|
|
294
|
+
if (fld) {
|
|
295
|
+
if (fld.a$?.type === 'TxLink') {
|
|
296
|
+
const entry = { text: `{${reference}}`, reference: true };
|
|
297
|
+
// format
|
|
298
|
+
const fmt = fld['a:rPr'];
|
|
299
|
+
if (fmt) {
|
|
300
|
+
entry.style = {};
|
|
301
|
+
if (fmt.a$?.b === '1') {
|
|
302
|
+
entry.style.bold = true;
|
|
303
|
+
}
|
|
304
|
+
if (fmt.a$?.i === '1') {
|
|
305
|
+
entry.style.italic = true;
|
|
306
|
+
}
|
|
307
|
+
}
|
|
308
|
+
para.push(entry);
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
const appr = paragraph['a:pPr'];
|
|
312
|
+
if (appr) {
|
|
313
|
+
style = {};
|
|
314
|
+
if (appr.a$?.algn === 'r') {
|
|
315
|
+
style.horizontal_align = 'right';
|
|
316
|
+
}
|
|
317
|
+
else if (appr.a$?.algn === 'ctr') {
|
|
318
|
+
style.horizontal_align = 'center';
|
|
319
|
+
}
|
|
320
|
+
}
|
|
321
|
+
let ar = paragraph['a:r'];
|
|
322
|
+
if (ar) {
|
|
323
|
+
if (!Array.isArray(ar)) {
|
|
324
|
+
ar = [ar];
|
|
325
|
+
}
|
|
326
|
+
for (const line of ar) {
|
|
327
|
+
const entry = {
|
|
328
|
+
text: line['a:t'] || '',
|
|
329
|
+
};
|
|
330
|
+
// format
|
|
331
|
+
const fmt = line['a:rPr'];
|
|
332
|
+
if (fmt) {
|
|
333
|
+
entry.style = {};
|
|
334
|
+
if (fmt.a$?.b === '1') {
|
|
335
|
+
entry.style.bold = true;
|
|
336
|
+
}
|
|
337
|
+
if (fmt.a$?.i === '1') {
|
|
338
|
+
entry.style.italic = true;
|
|
339
|
+
}
|
|
340
|
+
}
|
|
341
|
+
para.push(entry);
|
|
342
|
+
}
|
|
343
|
+
}
|
|
344
|
+
paragraphs.push({ content: para, style });
|
|
345
|
+
}
|
|
346
|
+
results.push({
|
|
347
|
+
type: 'textbox',
|
|
348
|
+
style,
|
|
349
|
+
paragraphs,
|
|
350
|
+
anchor,
|
|
351
|
+
reference,
|
|
352
|
+
});
|
|
353
|
+
}
|
|
354
|
+
}
|
|
355
|
+
}
|
|
356
|
+
}
|
|
357
|
+
}
|
|
358
|
+
return results;
|
|
359
|
+
}
|
|
360
|
+
/**
|
|
361
|
+
*
|
|
362
|
+
* FIXME: this is using the old options with old structure, just have
|
|
363
|
+
* not updated it yet
|
|
364
|
+
*/
|
|
365
|
+
ReadChart(reference) {
|
|
366
|
+
const data = this.zip.Get(reference.replace(/^../, 'xl'));
|
|
367
|
+
if (!data) {
|
|
368
|
+
return undefined;
|
|
369
|
+
}
|
|
370
|
+
// const xml = xmlparser1.parse(data);
|
|
371
|
+
const xml = xmlparser2.parse(data);
|
|
372
|
+
const result = {
|
|
373
|
+
type: ChartType.Null
|
|
374
|
+
};
|
|
375
|
+
// console.info("RC", xml);
|
|
376
|
+
const title_node = XMLUtils.FindChild(xml, 'c:chartSpace/c:chart/c:title');
|
|
377
|
+
if (title_node) {
|
|
378
|
+
// FIXME: other types of title? (...)
|
|
379
|
+
const node = XMLUtils.FindChild(title_node, 'c:tx/c:strRef/c:f');
|
|
380
|
+
if (node) {
|
|
381
|
+
if (typeof node === 'string') {
|
|
382
|
+
result.title = node;
|
|
383
|
+
}
|
|
384
|
+
else if (node.t$) {
|
|
385
|
+
result.title = node.t$; // why is this not quoted, if the later one is quoted? is this a reference?
|
|
386
|
+
}
|
|
387
|
+
}
|
|
388
|
+
else {
|
|
389
|
+
// there's a bug in FindAll -- seems to have to do with the nodes
|
|
390
|
+
// here being strings
|
|
391
|
+
const nodes = [];
|
|
392
|
+
const parents = XMLUtils.FindAll(title_node, 'c:tx/c:rich/a:p/a:r');
|
|
393
|
+
for (const entry of parents) {
|
|
394
|
+
if (entry['a:t']) {
|
|
395
|
+
nodes.push(entry['a:t']);
|
|
396
|
+
}
|
|
397
|
+
}
|
|
398
|
+
/*
|
|
399
|
+
const xx = XMLUtils.FindAll(title_node, 'c:tx/c:rich/a:p/a:r');
|
|
400
|
+
const yy = XMLUtils.FindAll(title_node, 'c:tx/c:rich/a:p/a:r/a:t');
|
|
401
|
+
console.info({xx, yy});
|
|
402
|
+
|
|
403
|
+
const nodes = XMLUtils.FindAll(title_node, 'c:tx/c:rich/a:p/a:r/a:t');
|
|
404
|
+
*/
|
|
405
|
+
result.title = '"' + nodes.map(node => {
|
|
406
|
+
return typeof node === 'string' ? node : (node.t$ || '');
|
|
407
|
+
}).join('') + '"';
|
|
408
|
+
}
|
|
409
|
+
}
|
|
410
|
+
const ParseSeries = (node, type) => {
|
|
411
|
+
const series = [];
|
|
412
|
+
// const series_nodes = node.findall('./c:ser');
|
|
413
|
+
let series_nodes = node['c:ser'] || [];
|
|
414
|
+
if (!Array.isArray(series_nodes)) {
|
|
415
|
+
series_nodes = [series_nodes];
|
|
416
|
+
}
|
|
417
|
+
// console.info({SN: series_nodes});
|
|
418
|
+
for (const series_node of series_nodes) {
|
|
419
|
+
let index = series.length;
|
|
420
|
+
const order_node = series_node['c:order'];
|
|
421
|
+
if (order_node) {
|
|
422
|
+
index = Number(order_node.a$?.val || 0) || 0;
|
|
423
|
+
}
|
|
424
|
+
const series_data = {};
|
|
425
|
+
let title_node = XMLUtils.FindChild(series_node, 'c:tx/c:v');
|
|
426
|
+
if (title_node) {
|
|
427
|
+
const title = title_node;
|
|
428
|
+
if (title) {
|
|
429
|
+
series_data.title = `"${title}"`;
|
|
430
|
+
}
|
|
431
|
+
}
|
|
432
|
+
else {
|
|
433
|
+
title_node = XMLUtils.FindChild(series_node, 'c:tx/c:strRef/c:f');
|
|
434
|
+
if (title_node) {
|
|
435
|
+
series_data.title = title_node;
|
|
436
|
+
}
|
|
437
|
+
}
|
|
438
|
+
if (type === ChartType.Scatter || type === ChartType.Bubble) {
|
|
439
|
+
const x = XMLUtils.FindChild(series_node, 'c:xVal/c:numRef/c:f');
|
|
440
|
+
if (x) {
|
|
441
|
+
series_data.categories = x; // .text?.toString();
|
|
442
|
+
}
|
|
443
|
+
const y = XMLUtils.FindChild(series_node, 'c:yVal/c:numRef/c:f');
|
|
444
|
+
if (y) {
|
|
445
|
+
series_data.values = y; // .text?.toString();
|
|
446
|
+
}
|
|
447
|
+
if (type === ChartType.Bubble) {
|
|
448
|
+
const z = XMLUtils.FindChild(series_node, 'c:bubbleSize/c:numRef/c:f');
|
|
449
|
+
if (z) {
|
|
450
|
+
series_data.bubble_size = z; // .text?.toString();
|
|
451
|
+
}
|
|
452
|
+
}
|
|
453
|
+
}
|
|
454
|
+
else {
|
|
455
|
+
const value_node = XMLUtils.FindChild(series_node, 'c:val/c:numRef/c:f');
|
|
456
|
+
if (value_node) {
|
|
457
|
+
series_data.values = value_node; // .text?.toString();
|
|
458
|
+
}
|
|
459
|
+
let cat_node = XMLUtils.FindChild(series_node, 'c:cat/c:strRef/c:f');
|
|
460
|
+
if (!cat_node) {
|
|
461
|
+
cat_node = XMLUtils.FindChild(series_node, 'c:cat/c:numRef/c:f');
|
|
462
|
+
}
|
|
463
|
+
if (cat_node) {
|
|
464
|
+
series_data.categories = cat_node; // .text?.toString();
|
|
465
|
+
}
|
|
466
|
+
}
|
|
467
|
+
series[index] = series_data;
|
|
468
|
+
}
|
|
469
|
+
return series;
|
|
470
|
+
};
|
|
471
|
+
let node = XMLUtils.FindChild(xml, 'c:chartSpace/c:chart/c:plotArea/c:barChart');
|
|
472
|
+
if (node) {
|
|
473
|
+
result.type = ChartType.Bar;
|
|
474
|
+
// console.info("BD", node);
|
|
475
|
+
if (node['c:barDir']) {
|
|
476
|
+
if (node['c:barDir'].a$?.val === 'col') {
|
|
477
|
+
result.type = ChartType.Column;
|
|
478
|
+
if (node['c:grouping']?.a$?.val === 'stacked') {
|
|
479
|
+
if (!result.flags) {
|
|
480
|
+
result.flags = [];
|
|
481
|
+
}
|
|
482
|
+
result.flags.push('stacked');
|
|
483
|
+
}
|
|
484
|
+
}
|
|
485
|
+
}
|
|
486
|
+
result.series = ParseSeries(node);
|
|
487
|
+
}
|
|
488
|
+
if (!node) {
|
|
489
|
+
node = XMLUtils.FindChild(xml, 'c:chartSpace/c:chart/c:plotArea/c:lineChart');
|
|
490
|
+
if (node) {
|
|
491
|
+
result.type = ChartType.Line;
|
|
492
|
+
result.series = ParseSeries(node);
|
|
493
|
+
}
|
|
494
|
+
}
|
|
495
|
+
if (!node) {
|
|
496
|
+
node = XMLUtils.FindChild(xml, 'c:chartSpace/c:chart/c:plotArea/c:doughnutChart');
|
|
497
|
+
if (node) {
|
|
498
|
+
result.type = ChartType.Donut;
|
|
499
|
+
result.series = ParseSeries(node);
|
|
500
|
+
}
|
|
501
|
+
}
|
|
502
|
+
if (!node) {
|
|
503
|
+
node = XMLUtils.FindChild(xml, 'c:chartSpace/c:chart/c:plotArea/c:pieChart');
|
|
504
|
+
if (node) {
|
|
505
|
+
result.type = ChartType.Pie;
|
|
506
|
+
result.series = ParseSeries(node);
|
|
507
|
+
}
|
|
508
|
+
}
|
|
509
|
+
if (!node) {
|
|
510
|
+
node = XMLUtils.FindChild(xml, 'c:chartSpace/c:chart/c:plotArea/c:scatterChart');
|
|
511
|
+
if (node) {
|
|
512
|
+
result.type = ChartType.Scatter;
|
|
513
|
+
result.series = ParseSeries(node, ChartType.Scatter);
|
|
514
|
+
}
|
|
515
|
+
}
|
|
516
|
+
if (!node) {
|
|
517
|
+
node = XMLUtils.FindChild(xml, 'c:chartSpace/c:chart/c:plotArea/c:bubbleChart');
|
|
518
|
+
if (node) {
|
|
519
|
+
result.type = ChartType.Bubble;
|
|
520
|
+
result.series = ParseSeries(node, ChartType.Bubble);
|
|
521
|
+
// console.info("Bubble series?", result.series);
|
|
522
|
+
}
|
|
523
|
+
}
|
|
524
|
+
if (!node) {
|
|
525
|
+
// box plot uses "extended chart" which is totally different... but we
|
|
526
|
+
// might need it again later? for the time being it's just inlined
|
|
527
|
+
// hmmm also used for histogram... histograms aren't named, they are
|
|
528
|
+
// clustered column type with a binning element, which has some attributes
|
|
529
|
+
const ex_series = XMLUtils.FindAll(xml, 'cx:chartSpace/cx:chart/cx:plotArea/cx:plotAreaRegion/cx:series');
|
|
530
|
+
if (ex_series?.length) {
|
|
531
|
+
// testing seems to require looping, so let's try to merge loops
|
|
532
|
+
let clustered_column = true;
|
|
533
|
+
let histogram = true;
|
|
534
|
+
let box_whisker = true;
|
|
535
|
+
for (const series of ex_series) {
|
|
536
|
+
const layout = series.a$?.layoutId;
|
|
537
|
+
if (clustered_column && layout !== 'clusteredColumn') {
|
|
538
|
+
clustered_column = false;
|
|
539
|
+
}
|
|
540
|
+
if (box_whisker && layout !== 'boxWhisker') {
|
|
541
|
+
box_whisker = false;
|
|
542
|
+
}
|
|
543
|
+
if (clustered_column && histogram) {
|
|
544
|
+
const binning = XMLUtils.FindAll(series, `cx:layoutPr/cx:binning`);
|
|
545
|
+
if (!binning.length) {
|
|
546
|
+
histogram = false;
|
|
547
|
+
}
|
|
548
|
+
}
|
|
549
|
+
}
|
|
550
|
+
// ok that's what we know so far...
|
|
551
|
+
if (histogram) {
|
|
552
|
+
result.type = ChartType.Histogram;
|
|
553
|
+
result.series = [];
|
|
554
|
+
for (const series_entry of ex_series) {
|
|
555
|
+
if (series_entry.a$?.hidden === '1') {
|
|
556
|
+
continue;
|
|
557
|
+
}
|
|
558
|
+
const series = {};
|
|
559
|
+
const data = XMLUtils.FindAll(xml, 'cx:chartSpace/cx:chartData/cx:data');
|
|
560
|
+
// so there are multiple series, and multiple datasets,
|
|
561
|
+
// but they are all merged together? no idea how this design
|
|
562
|
+
// works
|
|
563
|
+
const values_list = [];
|
|
564
|
+
for (const data_series of data) {
|
|
565
|
+
values_list.push(data_series['cx:numDim']?.['cx:f'] || '');
|
|
566
|
+
}
|
|
567
|
+
series.values = values_list.join(',');
|
|
568
|
+
const bin_count = XMLUtils.FindAll(series_entry, `cx:layoutPr/cx:binning/cx:binCount`);
|
|
569
|
+
if (bin_count[0]) {
|
|
570
|
+
const count = Number(bin_count[0].a$?.val || 0);
|
|
571
|
+
if (count) {
|
|
572
|
+
series.bin_count = count;
|
|
573
|
+
}
|
|
574
|
+
}
|
|
575
|
+
result.series.push(series);
|
|
576
|
+
}
|
|
577
|
+
const title = XMLUtils.FindAll(xml, 'cx:chartSpace/cx:chart/cx:title/cx:tx/cx:txData');
|
|
578
|
+
if (title) {
|
|
579
|
+
if (title[0]?.['cx:f']) {
|
|
580
|
+
result.title = title[0]['cx:f'];
|
|
581
|
+
}
|
|
582
|
+
else if (title[0]?.['cx:v']) {
|
|
583
|
+
result.title = '"' + title[0]['cx:v'] + '"';
|
|
584
|
+
}
|
|
585
|
+
}
|
|
586
|
+
console.info("histogram", result);
|
|
587
|
+
return result;
|
|
588
|
+
}
|
|
589
|
+
if (box_whisker) {
|
|
590
|
+
result.type = ChartType.Box;
|
|
591
|
+
result.series = [];
|
|
592
|
+
const data = XMLUtils.FindAll(xml, 'cx:chartSpace/cx:chartData/cx:data'); // /cx:data/cx:numDim/cx:f');
|
|
593
|
+
// console.info({ex_series, data})
|
|
594
|
+
for (const entry of ex_series) {
|
|
595
|
+
const series = {};
|
|
596
|
+
const id = Number(entry['cx:dataId']?.a$?.val);
|
|
597
|
+
for (const data_series of data) {
|
|
598
|
+
if (Number(data_series.a$?.id) === id) {
|
|
599
|
+
series.values = data_series['cx:numDim']?.['cx:f'] || '';
|
|
600
|
+
break;
|
|
601
|
+
}
|
|
602
|
+
}
|
|
603
|
+
const label = XMLUtils.FindAll(entry, 'cx:tx/cx:txData');
|
|
604
|
+
if (label) {
|
|
605
|
+
if (label[0]?.['cx:f']) {
|
|
606
|
+
series.title = label[0]['cx:f'];
|
|
607
|
+
}
|
|
608
|
+
else if (label[0]?.['cx:v']) {
|
|
609
|
+
series.title = '"' + label[0]['cx:v'] + '"';
|
|
610
|
+
}
|
|
611
|
+
}
|
|
612
|
+
const title = XMLUtils.FindAll(xml, 'cx:chartSpace/cx:chart/cx:title/cx:tx/cx:txData');
|
|
613
|
+
if (title) {
|
|
614
|
+
if (title[0]?.['cx:f']) {
|
|
615
|
+
result.title = title[0]['cx:f'];
|
|
616
|
+
}
|
|
617
|
+
else if (title[0]?.['cx:v']) {
|
|
618
|
+
result.title = '"' + title[0]['cx:v'] + '"';
|
|
619
|
+
}
|
|
620
|
+
}
|
|
621
|
+
result.series.push(series);
|
|
622
|
+
}
|
|
623
|
+
// console.info({result});
|
|
624
|
+
return result;
|
|
625
|
+
}
|
|
626
|
+
}
|
|
627
|
+
}
|
|
628
|
+
if (!node) {
|
|
629
|
+
console.info("Chart type not handled", { xml });
|
|
630
|
+
result.type = ChartType.Unknown;
|
|
631
|
+
}
|
|
632
|
+
// console.info("RX?", result);
|
|
633
|
+
return result;
|
|
634
|
+
}
|
|
635
|
+
/** FIXME: accessor */
|
|
636
|
+
GetNamedRanges() {
|
|
637
|
+
// ... what does this do, not do, or what is it supposed to do?
|
|
638
|
+
// note that this is called by the import routine, so it probably
|
|
639
|
+
// expects to do something
|
|
640
|
+
// return this.defined_names;
|
|
641
|
+
return this.named;
|
|
642
|
+
}
|
|
643
|
+
}
|
|
644
|
+
//# sourceMappingURL=workbook.js.map
|