/* * Copyright (c) 2018-2020, Andreas Kling * 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. */ #include #include #include namespace GUI { void JsonArrayModel::update() { auto file = Core::File::construct(m_json_path); if (!file->open(Core::IODevice::ReadOnly)) { dbg() << "Unable to open " << file->filename(); m_array.clear(); did_update(); return; } auto json = JsonValue::from_string(file->read_all()); ASSERT(json.has_value()); ASSERT(json.value().is_array()); m_array = json.value().as_array(); did_update(); } bool JsonArrayModel::store() { auto file = Core::File::construct(m_json_path); if (!file->open(Core::IODevice::WriteOnly)) { dbg() << "Unable to open " << file->filename(); return false; } file->write(m_array.to_string()); file->close(); return true; } bool JsonArrayModel::add(const Vector&& values) { ASSERT(values.size() == m_fields.size()); JsonObject obj; for (size_t i = 0; i < m_fields.size(); ++i) { auto& field_spec = m_fields[i]; obj.set(field_spec.json_field_name, values.at(i)); } m_array.append(move(obj)); did_update(); return true; } bool JsonArrayModel::remove(int row) { if (row >= m_array.size()) return false; JsonArray new_array; for (int i = 0; i < m_array.size(); ++i) if (i != row) new_array.append(m_array.at(i)); m_array = new_array; did_update(); return true; } Variant JsonArrayModel::data(const ModelIndex& index, ModelRole role) const { auto& field_spec = m_fields[index.column()]; auto& object = m_array.at(index.row()).as_object(); if (role == ModelRole::TextAlignment) { return field_spec.text_alignment; } if (role == ModelRole::Display) { auto& json_field_name = field_spec.json_field_name; auto data = object.get(json_field_name); if (field_spec.massage_for_display) return field_spec.massage_for_display(object); if (data.is_number()) return data.to_i32(); return object.get(json_field_name).to_string(); } if (role == ModelRole::Sort) { if (field_spec.massage_for_sort) return field_spec.massage_for_sort(object); return data(index, ModelRole::Display); } if (role == ModelRole::Custom) { if (field_spec.massage_for_custom) return field_spec.massage_for_custom(object); return {}; } return {}; } void JsonArrayModel::set_json_path(const String& json_path) { if (m_json_path == json_path) return; m_json_path = json_path; update(); } }