Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix multi lvl categories in embedded .xlsx #1330

Open
wants to merge 3 commits into
base: master
Choose a base branch
from

Conversation

MariusOpeepl
Copy link
Contributor

@MariusOpeepl MariusOpeepl commented May 7, 2024

Change Summary

A key/value object was added for shared strings so that it can be used to fetch the sharedString index of category axes and removed an unneeded summand when calculating a label's column.

Change Description

Calculating the col and row position of the category labels

getExcelColName(idx + 1 + idy) did not need idx, and caused each subsequent row of labels to be shifted one more column to the right from the previous row.

Calculating the category label indexes in sharedStrings.xml

I could not find a fix for the calculation, so I instead create a key/value object (e.g. { 'Category Label': 4 }) that maps strings to their respective indexes in sharedStrings.xml, and use it to get the correct index of any given string.

Other

There is at least one WIP: FIXME: note around this code; I did not remove it, as I wasn't sure if the note was referencing this issue in particular.

Lastly, I only updated the accessing of shared strings for IS_MULTI_CAT_AXES, as I'm not too familiar with the other chart types and I'd risk introducing more bugs. The dictionary object should get correctly populated by all chart types, though.

Change Type

  • Bug fix
  • New feature
  • Documentation update

Motivation and Context

While the PPTX charts with multiple category axes looked fine, their embedded Excel contained malformed data, and upon opening the Excel, the related chart would also break.

Checklist before requesting a review

  • If it is a core feature, I have added new code under /demos/modules/
  • My code follows the style guidelines of this project
  • My changes generate no new eslint warnings
  • I have performed a self-review of my code
  • I have commented my code, particularly in hard-to-understand areas
  • I have included code/tests that prove my fix is effective or that my feature works
    • The existing demos can be run to see that the fix works
  • I have used the "Run All Demos" feature on the browser demo and no errors were found
    • I couldn't get the browser demos to run, so I ran the node demos instead

Screenshots / Sample Code (if appropriate)

Before After
Microsoft_Excel_Worksheet64_broken Microsoft_Excel_Worksheet64

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant