1
Fork 0
mirror of https://github.com/RGBCube/serenity synced 2025-10-26 17:32:37 +00:00
serenity/Userland/Libraries/LibGUI/Breadcrumbbar.h
Linus Groh 6e19ab2bbc AK+Everywhere: Rename String to DeprecatedString
We have a new, improved string type coming up in AK (OOM aware, no null
state), and while it's going to use UTF-8, the name UTF8String is a
mouthful - so let's free up the String name by renaming the existing
class.
Making the old one have an annoying name will hopefully also help with
quick adoption :^)
2022-12-06 08:54:33 +01:00

58 lines
1.7 KiB
C++

/*
* Copyright (c) 2020, Andreas Kling <kling@serenityos.org>
* Copyright (c) 2022, the SerenityOS developers.
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#pragma once
#include <LibGUI/Widget.h>
namespace GUI {
class Breadcrumbbar : public GUI::Widget {
C_OBJECT(Breadcrumbbar);
public:
virtual ~Breadcrumbbar() override = default;
void clear_segments();
void append_segment(DeprecatedString text, Gfx::Bitmap const* icon = nullptr, DeprecatedString data = {}, DeprecatedString tooltip = {});
void remove_end_segments(size_t segment_index);
void relayout();
size_t segment_count() const { return m_segments.size(); }
DeprecatedString segment_data(size_t index) const { return m_segments[index].data; }
Optional<size_t> find_segment_with_data(DeprecatedString const& data);
void set_selected_segment(Optional<size_t> index);
Optional<size_t> selected_segment() const { return m_selected_segment; }
Function<void(Optional<size_t> index)> on_segment_change;
Function<void(size_t index)> on_segment_click;
Function<void(size_t index, DropEvent&)> on_segment_drop;
Function<void(size_t index, DragEvent&)> on_segment_drag_enter;
Function<void(MouseEvent& event)> on_doubleclick;
private:
Breadcrumbbar();
virtual void resize_event(ResizeEvent&) override;
struct Segment {
RefPtr<const Gfx::Bitmap> icon;
DeprecatedString text;
DeprecatedString data;
int width { 0 };
int shrunken_width { 0 };
WeakPtr<GUI::Button> button;
};
Vector<Segment> m_segments;
Optional<size_t> m_selected_segment;
virtual void doubleclick_event(GUI::MouseEvent&) override;
};
}