mirror of
https://github.com/RGBCube/serenity
synced 2025-07-27 13:57:35 +00:00
Spreadsheet: Add an import wizard, and add support for custom CSV files
Fixes the import half of #4269.
This commit is contained in:
parent
3bbcde9192
commit
3c151b3de6
7 changed files with 601 additions and 52 deletions
75
Userland/Applications/Spreadsheet/ImportDialog.h
Normal file
75
Userland/Applications/Spreadsheet/ImportDialog.h
Normal file
|
@ -0,0 +1,75 @@
|
|||
/*
|
||||
* Copyright (c) 2020-2021, the SerenityOS developers.
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
*
|
||||
* 1. Redistributions of source code must retain the above copyright notice, this
|
||||
* list of conditions and the following disclaimer.
|
||||
*
|
||||
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
|
||||
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
||||
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
|
||||
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
|
||||
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include "Readers/XSV.h"
|
||||
#include <AK/Result.h>
|
||||
#include <AK/StringView.h>
|
||||
#include <LibGUI/Forward.h>
|
||||
#include <LibGUI/Wizards/WizardPage.h>
|
||||
|
||||
namespace Spreadsheet {
|
||||
|
||||
class Sheet;
|
||||
class Workbook;
|
||||
|
||||
struct CSVImportDialogPage {
|
||||
explicit CSVImportDialogPage(StringView csv);
|
||||
|
||||
NonnullRefPtr<GUI::WizardPage> page() { return *m_page; }
|
||||
Optional<Reader::XSV>& reader() { return m_previously_made_reader; }
|
||||
|
||||
protected:
|
||||
void update_preview();
|
||||
Optional<Reader::XSV> make_reader();
|
||||
|
||||
private:
|
||||
StringView m_csv;
|
||||
Optional<Reader::XSV> m_previously_made_reader;
|
||||
RefPtr<GUI::WizardPage> m_page;
|
||||
RefPtr<GUI::RadioButton> m_delimiter_comma_radio;
|
||||
RefPtr<GUI::RadioButton> m_delimiter_semicolon_radio;
|
||||
RefPtr<GUI::RadioButton> m_delimiter_tab_radio;
|
||||
RefPtr<GUI::RadioButton> m_delimiter_space_radio;
|
||||
RefPtr<GUI::RadioButton> m_delimiter_other_radio;
|
||||
RefPtr<GUI::TextBox> m_delimiter_other_text_box;
|
||||
RefPtr<GUI::RadioButton> m_quote_single_radio;
|
||||
RefPtr<GUI::RadioButton> m_quote_double_radio;
|
||||
RefPtr<GUI::RadioButton> m_quote_other_radio;
|
||||
RefPtr<GUI::TextBox> m_quote_other_text_box;
|
||||
RefPtr<GUI::ComboBox> m_quote_escape_combo_box;
|
||||
RefPtr<GUI::CheckBox> m_read_header_check_box;
|
||||
RefPtr<GUI::CheckBox> m_trim_leading_field_spaces_check_box;
|
||||
RefPtr<GUI::CheckBox> m_trim_trailing_field_spaces_check_box;
|
||||
RefPtr<GUI::TableView> m_data_preview_table_view;
|
||||
};
|
||||
|
||||
struct ImportDialog {
|
||||
static Result<NonnullRefPtrVector<Sheet>, String> make_and_run_for(StringView mime, Core::File& file, Workbook&);
|
||||
};
|
||||
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue