-
Notifications
You must be signed in to change notification settings - Fork 53
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
Redo Conditional Formatting for #461 #701
base: master
Are you sure you want to change the base?
Conversation
between POI updates and this new attempt at pushing my local conditional formatting work, I have much more properly supported. Now, cells where a conditional rule applies, and that rule has a number format different than the original cell format, display using the conditional format. Also addresses the list of issues identified in bug vaadin#461 and bug vaadin#651. Having this in Spreadsheet master means I can next send a PR for bug vaadin#529, adding support for table styles, both built-in and custom themed. The Excel official sample file showing how to use conditional formatting, which is included in the unit tests, now passes for more sheets. I see excellent equivalence except for: Features Spreadsheet doesn't support yet: * icon sets (sheet Quarters, Bike Rating, FY Months, Regional Sales) * data bars (Mountains) * gradients (Category Sales) Likely POI bugs in conditional formatting evaluation when rule formulas have relative cell references (I can reproduce the first few I tried in POI unit tests): * something goes wrong with styles on Compare to Totals * Syle not updating when values change to match conditional rules on Products3 * all rows show as matching on Customers2, instead of only unique rows. Could be a formula evaluation bug, or Conditional Formatting evaluation bug.
Yes, these 3 sheets are all the same bug, due to a math error I made in POI. I've fixed POI bug #63264 in trunk. It will be fixed in the next dot release. Don't have a date for that yet, but if Vaadin wants it, I can start the process to get one out in the next few weeks. |
There will be a new POI release, 4.1, in the next couple weeks. We should take that. It includes my fixes for conditional formatting, my implementation of SUBTOTAL() variations that skip hidden rows, which trips up a lot of sample workbooks, and maybe most important, some fixes for working with POI in deployment environments with JDK 9+. Those are mostly in the underlying XMLBeans project POI has taken over, which is what is used to parse and manipulate the OOXML in XLSX files. I think I'll be the release manager for that, so I'll update this PR with a dependency update when it is publicly available. |
Released POI 4.1.0, will be available in the next day or two. At that point I'll commit a dependency update and we'll see where we are with these changes. |
|
between POI updates and this new attempt at pushing my local conditional
formatting work, I have much more properly supported. Note however I've identified at least one POI regression (which I apparently introduced), noted below.
Curious to see how the automated tests run for this, looks good on my end.
Now, cells where a conditional rule applies, and that rule has a number
format different than the original cell format, display using the
conditional format.
Also addresses the list of issues identified in bug #461 and bug #651. This incorporates work done in #640 but never finished and merged.
Having this in Spreadsheet master means I can next send a PR for bug
#529, adding support for table styles, both built-in and custom themed.
The Excel official sample file showing how to use conditional
formatting, which is included in the unit tests, now passes for more
sheets. I see excellent equivalence except for:
Features Spreadsheet doesn't support yet:
Likely POI bugs in conditional formatting evaluation when rule formulas
have relative cell references (I can reproduce the first few I tried in
POI unit tests):
something goes wrong with styles on Compare to Totals. This works on older POI versions, so I broke it in 4.0 somehow. I'll fix it. We are probably about to a patch release there anyway. Then Spreadsheet 3.0 can use the patched POI as its base version.
Style not updating when values change to match conditional rules on
Products3
all rows show as matching on Customers2, instead of only unique rows.
Could be a formula evaluation bug, or Conditional Formatting evaluation
bug.
This change isdata:image/s3,"s3://crabby-images/d0bb7/d0bb7f7625ca5bf5c3cf7a2b7a514cf841ab8395" alt="Reviewable"