Skip to content
Snippets Groups Projects
This project is mirrored from https://github.com/metabase/metabase. Pull mirroring updated .
  1. Jan 04, 2024
    • Chris Truter's avatar
    • Mark Bastian's avatar
      Consistent formatting of all columns in Excel exports (#37208) · 055561b4
      Mark Bastian authored
      * Removing Time portion of Timestamp when formatted as Date in Excel
      
      This is a starting changeset for fixing the issue "Timestamp is always present in dates when exporting to Excel in the embedded application. #14393", which demonstrates a failure mode in applying column-formatting to Excel downloads. This commit should fix the underlying issue as well as update formatting for remaining CSV file download discrepancies.
      
      The goal of this commit is to get us to a baseline state for some small refactorings to combine our formatting paths for CSV, JSON, and Excel exports.
      
      * Updating common logic and tests to reflect how global settings are passed in and applied to format-temporal-str
      
      * Updating `number-format-strings` to not need semantic type.
      
      * Adding tests for new Excel-export logic.
      
      * Fixing cases for currency where we must specify that `::mb.viz/currency-in-header` is false.
      
      * Fixing formatting tests
      
      * Updating unit test to reflect a global abbreviated dates preference.
      
      * Adding column type defaults for certain test cases.
      
      * Updating logic and tests in xlsx exports
      
      Logic in `metabase.query-processor.streaming.common` further unifies the idea of merging all settings first, then making decisions based on that. It also makes the downstream code more functional, as that code doesn't repeatedly reach for global settings.
      
      `metabase.query-processor.streaming.xlsx-test` has been updated to reflect this change. In particular, the helper function `format-string` now builds the right input settings rather than passing settings through to be accumulated later.
      
      * Fixing two more tests.
      
      * Fixing remaining unit tests
      
      - Update `metabase.api.card-test` with multiple test cases for different formats.
      - Update `export-format-test` to lock temporary settings for consistency.
      - `default-number-format?` to `unformatted-number?` and include "currency" as a potential unformatted type.
      
      * Consistent application of global viz settings
      
      This PR adds a function that will inject the global viz settings into `viz-settings-for-col` if not provided by the query processor. This also simplifies the `xslx-test` ns.
      
      * Treating :default unit as no unit.
      Unverified
      055561b4
  2. Jan 03, 2024
  3. Jan 02, 2024
  4. Jan 01, 2024
Loading