Skip to content
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

Component Group View with static header and without icons #3373

Merged
merged 165 commits into from
Apr 14, 2022
Merged
Show file tree
Hide file tree
Changes from 129 commits
Commits
Show all changes
165 commits
Select commit Hold shift + click to select a range
60ce484
WIP component_group debug scene w/scroll-area
akavel Mar 30, 2022
9e7ff75
remove scroll_area
akavel Mar 30, 2022
91fb726
WIP start adding files for CGV in lib/rust/ensogl/
akavel Mar 30, 2022
eb8606d
WIP plugging CGV into example scene
akavel Mar 30, 2022
b1d5ef9
use simple Label entries in the example
akavel Mar 30, 2022
6baab5e
compiles but does not show in the example
akavel Mar 30, 2022
06f1ec7
connect set_entries & resize
akavel Mar 30, 2022
2d9daef
style: no spaces in FRP of ListView
akavel Mar 30, 2022
d680f66
add ListView::frp::background_visible(bool)
akavel Mar 30, 2022
3977a59
WIP trying to disable ListView background for CGV
akavel Mar 30, 2022
5a2db45
WIP unexpectedly, effect seems reversed
akavel Mar 30, 2022
3785ab8
fix background visibility setting
akavel Mar 30, 2022
9dbd3bc
s/background_visibility/show_background/
akavel Mar 30, 2022
4fead21
s//show_background_shadow/
akavel Mar 30, 2022
b6e36db
parametrize listview bg corners radius
akavel Mar 30, 2022
66b0069
WIP starting to impl custom color for ListView bg
akavel Mar 31, 2022
caecd7b
set_background_color in LV
akavel Mar 31, 2022
a9382bd
make LV setters private
akavel Mar 31, 2022
e79a3de
use set_background_color in LV.init
akavel Mar 31, 2022
9373fa8
add empty TextArea to CGV
akavel Mar 31, 2022
c3ef542
allow setting the header text; currently badly positioned
akavel Mar 31, 2022
8b0475e
comments tweaks
akavel Mar 31, 2022
5a42e8a
const HEADER_HEIGHT
akavel Mar 31, 2022
349fd8b
CGV::resize() impl.
akavel Mar 31, 2022
d475a92
improve doc comment in shapes_order_dependencies!
akavel Mar 31, 2022
338d1eb
WIP adding header_background; bad z-order
akavel Mar 31, 2022
08cd066
CLEANUP some comment
akavel Mar 31, 2022
fb23962
TRY shapes_order_dependencies!; did not help
akavel Mar 31, 2022
49b8442
show header text above header_background
akavel Mar 31, 2022
ed123bb
shorter group name for now
akavel Mar 31, 2022
8e3ecd6
small tweaks
akavel Mar 31, 2022
c6a2cce
DEBUG mcdbg::View
akavel Mar 31, 2022
18fd311
fix LV position
akavel Apr 1, 2022
a7ca8c2
HEADER_LEFT_PADDING
akavel Apr 1, 2022
b7324f2
HACK lv_padding
akavel Apr 1, 2022
8f5c4b4
tweak FRP init variable location
akavel Apr 1, 2022
df31d31
CLEANUP mcdbg
akavel Apr 1, 2022
24d277f
fix vertical position of group name
akavel Apr 1, 2022
fe27711
WIP adding set_font function in text::Area
akavel Apr 1, 2022
aeca296
first TA.set_font working attempt
akavel Apr 1, 2022
61971f8
WIP start working on TA::clip_line_to_width
akavel Apr 1, 2022
6eb7476
WIP quick & dirty PoC of ellipse truncating
akavel Apr 1, 2022
cc87551
pass String to clip_line_to_width
akavel Apr 1, 2022
8e60d5f
use unicode ellipsis
akavel Apr 1, 2022
381249d
s/clip/clip_at/
akavel Apr 1, 2022
2db798d
real width of ellipsis
akavel Apr 1, 2022
f4294ea
use find_map and ignore width of ellipsis for now
akavel Apr 1, 2022
cb07cee
rename func
akavel Apr 1, 2022
28416d4
account for width of ellipsis
akavel Apr 1, 2022
cf06630
set_truncation_width FRP
akavel Apr 1, 2022
bb13896
use short header text for now
akavel Apr 4, 2022
5162f67
add CGV::set_background_color FRP input
akavel Apr 4, 2022
0acd66a
CLEANUP debug color setting
akavel Apr 4, 2022
17bba18
tweak header text vertical alignment
akavel Apr 4, 2022
8a2faed
delete unused import of "shadow"
akavel Apr 5, 2022
8b8260a
some cleanups
akavel Apr 5, 2022
78b6a75
more cleanups
akavel Apr 5, 2022
a61ebe5
cargo fmt
akavel Apr 5, 2022
0cd89e9
glyph_system_borrowed
akavel Apr 5, 2022
b9fb33a
Revert "glyph_system_borrowed"
akavel Apr 5, 2022
544c3ad
cleanup around truncation_width
akavel Apr 5, 2022
0e5f89d
add & use DejaVuSans-Bold for CGV header
akavel Apr 7, 2022
f02de48
start adding theme for CGV
akavel Apr 7, 2022
16fc80c
draft stylesheet for CGV
akavel Apr 7, 2022
2ad4c2a
del obsolete dependency
akavel Apr 7, 2022
22eed46
start using init source in LV FRP for defaults
akavel Apr 7, 2022
1a2ce68
LV: use init source for default_background_color
akavel Apr 7, 2022
edaf6ee
WIP set_style_path
akavel Apr 7, 2022
be3afdf
DEBUG set_style_path etc.
akavel Apr 7, 2022
678b180
update_entries_style_prefix
akavel Apr 7, 2022
4bbe73d
style_path -> style_prefix & some cleanups & updates
akavel Apr 7, 2022
fb41ef1
fix init source in CGV FRP
akavel Apr 7, 2022
f75c082
use proper styles path in CGV
akavel Apr 7, 2022
8a516cc
del obsolete TODO
akavel Apr 7, 2022
ee0739f
HeaderGeometry
akavel Apr 7, 2022
7e03d97
WIP start adding support for Text styles
akavel Apr 8, 2022
b6d3fe4
WIP style Data: TryFrom->FromStr
akavel Apr 8, 2022
5ecddba
added Text() variant in styles
akavel Apr 8, 2022
64d68d1
set CGV header font from styles
akavel Apr 8, 2022
540de0a
load font for ListView entries from styles
akavel Apr 8, 2022
7d73016
improve theme name
akavel Apr 8, 2022
ce840c9
cargo fmt
akavel Apr 8, 2022
68d05aa
cargo clippy fixes
akavel Apr 8, 2022
64db7c5
comment & resize->set_size
akavel Apr 8, 2022
4209782
more comments + fix vertical positioning calculations
akavel Apr 8, 2022
f87fe82
tweak CGV::new body
akavel Apr 8, 2022
2bced50
add comment
akavel Apr 8, 2022
15a0a3e
del unused import from LV entry
akavel Apr 8, 2022
9bbb9b4
LV: show_shadow->shadow_alpha, drop some funcs
akavel Apr 8, 2022
4001a37
set_custom_bg_color -> set_bg_color
akavel Apr 8, 2022
e5ea02f
simplify & reformat LV Frp::set_style_prefix handling
akavel Apr 8, 2022
ab1f6bb
trunc w/ellipsis naming tweak
akavel Apr 8, 2022
65dd4fc
trunc w/ellipsis naming tweak
akavel Apr 8, 2022
1413ced
trunc w/ellipsis naming tweak
akavel Apr 8, 2022
048cfd8
trunc w/ellipsis naming tweak
akavel Apr 8, 2022
aa892f6
trunc w/ellipsis naming tweak
akavel Apr 8, 2022
9c374f5
more trunc_w_ellipsis tweaks
akavel Apr 8, 2022
1ede1fa
trunc. tweaks
akavel Apr 8, 2022
6a683d0
cargo fmt
akavel Apr 8, 2022
60622a1
comment tweaks
akavel Apr 8, 2022
f3c2409
example w/texts
akavel Apr 8, 2022
b4d1508
example text tweak
akavel Apr 8, 2022
be4f01f
sample texts
akavel Apr 8, 2022
ab2b98d
truncate overwidth list_view entries
akavel Apr 8, 2022
2cb584b
tweak
akavel Apr 8, 2022
2e90072
add parser for Data::Text from_str
akavel Apr 8, 2022
fc20bcf
Merge remote-tracking branch 'origin/develop' into wip/akavel/cgv-sta…
akavel Apr 8, 2022
e859e5c
pragmas cleanup
akavel Apr 8, 2022
9c485ab
fix for CI
akavel Apr 8, 2022
68fb971
changelog
akavel Apr 8, 2022
51c722c
fix clippy
akavel Apr 8, 2022
a622ed4
cargo fmt
akavel Apr 8, 2022
5c2cb86
remove unused fonts
akavel Apr 11, 2022
ad33d98
lower the WASM binary size limit
akavel Apr 11, 2022
9a4a203
cargo fmt
akavel Apr 11, 2022
3eb469e
tweak whitespace
akavel Apr 11, 2022
1786520
more whitespace tweaks
akavel Apr 11, 2022
ea2f9f0
tweak module docs
akavel Apr 11, 2022
0a963b7
edit module doc again
akavel Apr 11, 2022
3e2ea92
restore comment
akavel Apr 11, 2022
32e80ec
Merge branch 'develop' into wip/akavel/cgv-static-181724889
akavel Apr 11, 2022
8775396
pull back support for Text values in styles
akavel Apr 11, 2022
35744df
pull back support for custom styles for ListView entries
akavel Apr 11, 2022
2c6a604
cargo fmt
akavel Apr 11, 2022
e1d3ac0
del spurious empty line
akavel Apr 11, 2022
7b5fe8f
change truncation_width from refcell to just cell
akavel Apr 12, 2022
a26d544
move CGV to app/gui/view/component-browser/
akavel Apr 12, 2022
5ce05c6
cargo fmt
akavel Apr 13, 2022
1054e3f
fix visual glitch
akavel Apr 13, 2022
4760977
WIP; LV trims too much, Searcher too slow
akavel Apr 13, 2022
39def4b
WIP fix LV debug scene
akavel Apr 13, 2022
363eaa9
fix perf. regression
akavel Apr 13, 2022
ef406c1
review: use color from Design Doc in debug scene
akavel Apr 13, 2022
017fdb1
review: move HeaderGeometry above FRP
akavel Apr 13, 2022
4b135af
review: put font name in constant
akavel Apr 13, 2022
aa043dc
review: Entry::resize(width)->set_max_width(max_width)
akavel Apr 13, 2022
6df9b78
cleanup some commented lines
akavel Apr 13, 2022
74c94d0
review: drop import of ensogl_list_view::entry
akavel Apr 13, 2022
284466e
drop more imports
akavel Apr 13, 2022
dd8c60c
review: rename CGV to drop "View" suffix
akavel Apr 13, 2022
2f7e90e
review: del recursion_limit
akavel Apr 13, 2022
1efcf7f
review: use and improve entry_point attribute for debug scn
akavel Apr 13, 2022
d3465c9
review: tweaks
akavel Apr 13, 2022
4469aeb
review: improve formatting to better match rustfmt
akavel Apr 13, 2022
57d0830
refactor entry_width calc
akavel Apr 13, 2022
5c04403
Merge remote-tracking branch 'origin/develop' into wip/akavel/cgv-sta…
akavel Apr 13, 2022
4f386d2
Merge remote-tracking branch 'origin/develop' into wip/akavel/cgv-sta…
akavel Apr 13, 2022
cd3490c
review: revert recursion_limit increase
akavel Apr 13, 2022
766c16b
review: set_header_text -> set_header
akavel Apr 13, 2022
bf2f9ea
review: rustfmt-like formatting in macro
akavel Apr 13, 2022
bd0f655
update_header_with instead of full resize() in CGV
akavel Apr 13, 2022
7d706d7
fix clippy
akavel Apr 13, 2022
74d8280
review: add comment about max_width_px
akavel Apr 13, 2022
2f456f4
add comment to set_content_truncated FRP
akavel Apr 13, 2022
61b546b
review: expand the comment in shapes_order_dependencies
akavel Apr 13, 2022
bc33013
review: tweak docs
akavel Apr 13, 2022
8f2fc4a
link design doc in module doc
akavel Apr 13, 2022
d0a13e3
fix for cargo fmt
akavel Apr 13, 2022
8046891
tweak spacing in macro
akavel Apr 13, 2022
1be87d2
use HOVER_COLOR
akavel Apr 13, 2022
bd0abc0
drop View from comp. name in label()
akavel Apr 13, 2022
e19329c
update name
akavel Apr 13, 2022
33ecb43
delete duplicate set_font evaluation after merge
akavel Apr 13, 2022
0a191c8
review: final minor tweaks
akavel Apr 14, 2022
3930773
Merge branch 'develop' into wip/akavel/cgv-static-181724889
mergify[bot] Apr 14, 2022
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,9 @@

#### Visual Environment

- [Long names on the Node Searcher's list are truncated.][3373] The part of the
name that doesn't fit in the Searcher's window is replaced with an ellipsis
character ("…").
- [Magnet Alignment algorithm is used while placing new nodes][3366]. When we
find an available free space for a new node, the node gets aligned with the
surrounding nodes horizontally and vertically. This helps to preserve a nice
Expand Down Expand Up @@ -145,6 +148,7 @@
[3349]: https://github.com/enso-org/enso/pull/3349
[3361]: https://github.com/enso-org/enso/pull/3361
[3364]: https://github.com/enso-org/enso/pull/3364
[3373]: https://github.com/enso-org/enso/pull/3373
[3377]: https://github.com/enso-org/enso/pull/3377
[3366]: https://github.com/enso-org/enso/pull/3366
[3379]: https://github.com/enso-org/enso/pull/3379
Expand Down
27 changes: 26 additions & 1 deletion Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

11 changes: 11 additions & 0 deletions app/gui/view/component-browser/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
[package]
name = "ide-view-component-browser"
version = "0.1.0"
authors = ["Enso Team <[email protected]>"]
edition = "2021"

[lib]
crate-type = ["cdylib", "rlib"]

[dependencies]
ide-view-component-group = { path = "component-group-view" }
17 changes: 17 additions & 0 deletions app/gui/view/component-browser/component-group-view/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
[package]
name = "ide-view-component-group"
version = "0.1.0"
authors = ["Enso Team <[email protected]>"]
edition = "2021"

[lib]
crate-type = ["cdylib", "rlib"]

[dependencies]
enso-frp = { version = "0.1.0", path = "../../../../../lib/rust/frp" }
ensogl-core = { version = "0.1.0", path = "../../../../../lib/rust/ensogl/core" }
ensogl-gui-component = { version = "0.1.0", path = "../../../../../lib/rust/ensogl/component/gui" }
ensogl-hardcoded-theme = { version = "0.1.0", path = "../../../../../lib/rust/ensogl/app/theme/hardcoded" }
ensogl-list-view = { version = "0.1.0", path = "../../../../../lib/rust/ensogl/component/list-view" }
ensogl-text = { version = "0.1.0", path = "../../../../../lib/rust/ensogl/component/text" }

223 changes: 223 additions & 0 deletions app/gui/view/component-browser/component-group-view/src/lib.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,223 @@
//! An EnsoGL implementation of a Component Group View.
//!
//! A Component Group View is displayed as a header (containing the name of a group of Enso
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why this thing is called "Component Group View" instead of just "Component Group"? I know that we have "List View", but this is because "List" is a data structure. Other components, like "Text Area" are not named "Text Area View". @farmaazon, what do you think of it?

//! components) and a list of entries below it (names of the components belonging to that group).
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We try not to repeat the names in the docs. The names such as "Enso" or "EnsoGL" do not have to appear here. It makes it easier in the future to refactor these names. Also:

  1. "An EnsoGL implementation of a Component Group View." – this sounds like there was a non-EnsoGL implementation of "Component Group View". If so, where it is? Also, the first paragraph should explain what this file is about, but it does not. After reading it, I don't know what "Component Group View" really is.
  2. "header (containing the name of a group of Enso components)", what else the header contains?
  3. "[...] it (names of the components belonging to that group)", this sounds like the explanation is connected with "it", but it is not.
  4. This docs should be linked to our design document.


#![recursion_limit = "512"]
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

why is this needed?

// === Standard Linter Configuration ===
#![deny(non_ascii_idents)]
#![warn(unsafe_code)]
// === Non-Standard Linter Configuration ===
#![warn(missing_copy_implementations)]
#![warn(missing_debug_implementations)]
#![warn(missing_docs)]
#![warn(trivial_casts)]
#![warn(trivial_numeric_casts)]
#![warn(unused_import_braces)]
#![warn(unused_qualifications)]

use ensogl_core::prelude::*;

use enso_frp as frp;
use ensogl_core::application::Application;
use ensogl_core::data::color::Rgba;
use ensogl_core::display;
use ensogl_core::display::shape::*;
use ensogl_gui_component::component;
use ensogl_gui_component::component::ComponentView;
use ensogl_hardcoded_theme::application::component_browser::component_group as theme;
use ensogl_list_view as list_view;
use ensogl_list_view::entry;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Instead of too many imports, you should use list_view::entry in code.

use ensogl_list_view::ListView;
use ensogl_text as text;



// ==========================
// === Shapes Definitions ===
// ==========================


// === Background ===

/// The background of the Component Group View.
pub mod background {
use super::*;

ensogl_core::define_shape_system! {
below = [list_view::background];
(style:Style, color:Vector4) {
let sprite_width: Var<Pixels> = "input_size.x".into();
let sprite_height: Var<Pixels> = "input_size.y".into();
let color = Var::<Rgba>::from(color);
let shape = Rect((&sprite_width, &sprite_height)).fill(color);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

if this is just a rect with not rounded corners, why dont you use plane instead? Plane is faster to render

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For some reason I don't understand, changing this line to use Plane instead:

            let shape = Plane().fill(color);

results in the component rendering with wrong colors - specifically, the color behind the ListView is correct, but the one in the header area is not:

Screenshot 2022-04-13 at 20 47 29

Would you have some idea or hint as to what could be the reason for this? I checked what will happen if I use Plane in the shape_system debug scene, by changing the shape() function as below:

pub fn shape() -> AnyShape {
    let shape = Plane().fill(color::Rgba(0.927, 0.937, 0.913, 1.0));
    shape.into()
}

and I also got a rectangle of a different color than expected:
Screenshot 2022-04-13 at 21 04 53

Whereas if I restore the shape() function to its original content, then change only the color, as below:

pub fn shape() -> AnyShape {
    let circle1 = Circle(50.px());
    let circle_bg = circle1.translate_x(-(50.0.px()));
    let circle_sub = circle1.translate_y(-(50.0.px()));
    let rect = Rect((100.0.px(), 100.0.px()));
    let shape = circle_bg + rect - circle_sub;
    let shape = shape.fill(color::Rgba::new(0.927, 0.937, 0.913, 1.0));
    shape.into()
}

then I can see the expected color:
Screenshot 2022-04-13 at 21 10 45

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Interesting. Seems like a bug. I will investigate that. But let's use rectangle now + create comment that it will be better to use plane, but there is some colouring bug. May be related to: #3384

shape.into()
}
}
}



// ===========
// === FRP ===
// ===========

ensogl_core::define_endpoints_2! {
Input {
set_header_text(String),
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

what else you can set in header? IMO this should be called "set_header" instead.

set_entries(entry::AnyModelProvider<entry::Label>),
set_background_color(Rgba),
set_size(Vector2),
}
Output {}
}

impl component::Frp<Model> for Frp {
fn init(api: &Self::Private, _app: &Application, model: &Model, style: &StyleWatchFrp) {
let network = &api.network;
let input = &api.input;
let header_text_size = style.get_number(theme::header::text::size);
frp::extend! { network

// === Geometry ===

let header_geometry = HeaderGeometry::from_style(style, network);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please, try making the file readable from top-to-bottom. HeaderGeometry was not introduced yet. Move it above these definitions, if possible, please.

size_and_header_geometry <- all(&input.set_size, &header_geometry);
eval size_and_header_geometry(((size, hdr_geom)) model.resize(*size, *hdr_geom));


// === Header ===

init <- source_();
header_text_size <- all(&header_text_size, &init)._0();
model.header.set_default_text_size <+ header_text_size.map(|v| text::Size(*v));
model.header.set_content <+ input.set_header_text;
eval input.set_background_color((c)
model.background.color.set(c.into()));


// === Entries ===

model.entries.set_background_color(Rgba(1.0, 1.0, 1.0, 0.0));
model.entries.show_background_shadow(false);
model.entries.set_background_corners_radius(0.0);
model.entries.set_background_color <+ input.set_background_color;
model.entries.set_entries <+ input.set_entries;
}
init.emit(());
}
}



// =======================
// === Header Geometry ===
// =======================

#[derive(Debug, Copy, Clone, Default)]
struct HeaderGeometry {
height: f32,
padding_left: f32,
padding_right: f32,
padding_bottom: f32,
}

impl HeaderGeometry {
fn from_style(style: &StyleWatchFrp, network: &frp::Network) -> frp::Sampler<Self> {
let height = style.get_number(theme::header::height);
let padding_left = style.get_number(theme::header::padding::left);
let padding_right = style.get_number(theme::header::padding::right);
let padding_bottom = style.get_number(theme::header::padding::bottom);

frp::extend! { network
init <- source_();
theme <- all_with5(&init,&height,&padding_left,&padding_right,&padding_bottom,
|_,&height,&padding_left,&padding_right,&padding_bottom|
Self{height,padding_left,padding_right,padding_bottom}
);
theme_sampler <- theme.sampler();
}
init.emit(());
theme_sampler
}
}



// =============
// === Model ===
// =============

/// The Model of the [`View`] component.
#[derive(Clone, CloneRef, Debug)]
pub struct Model {
display_object: display::object::Instance,
header: text::Area,
background: background::View,
entries: ListView<entry::Label>,
}

impl display::Object for Model {
fn display_object(&self) -> &display::object::Instance {
&self.display_object
}
}

impl component::Model for Model {
fn label() -> &'static str {
"ComponentGroupView"
}

fn new(app: &Application, logger: &Logger) -> Self {
let display_object = display::object::Instance::new(&logger);
let background = background::View::new(&logger);
let header = text::Area::new(app);
let entries = ListView::new(app);
display_object.add_child(&background);
display_object.add_child(&header);
display_object.add_child(&entries);

header.set_font("DejaVuSans-Bold");
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this should not be hardcoded here.

let label_layer = &app.display.default_scene.layers.label;
header.add_to_scene_layer(label_layer);

Model { display_object, header, background, entries }
}
}

impl Model {
fn resize(&self, size: Vector2, header_geometry: HeaderGeometry) {
// === Background ===

self.background.size.set(size);


// === Header Text ===

let header_padding_left = header_geometry.padding_left;
let header_text_x = -size.x / 2.0 + header_padding_left;
let header_text_height = self.header.height.value();
let header_padding_bottom = header_geometry.padding_bottom;
let header_height = header_geometry.height;
let header_bottom_y = size.y / 2.0 - header_height;
let header_text_y = header_bottom_y + header_text_height + header_padding_bottom;
self.header.set_position_xy(Vector2(header_text_x, header_text_y));
let header_padding_right = header_geometry.padding_right;
self.header.set_truncation_width(size.x - header_padding_left - header_padding_right);


// === Entries ===

self.entries.resize(size - Vector2(0.0, header_height));
self.entries.set_position_y(-header_height / 2.0);
}
}



// ============
// === View ===
// ============

/// The implementation of the visual component described in the module's documentation.
pub type View = ComponentView<Model, Frp>;
20 changes: 20 additions & 0 deletions app/gui/view/component-browser/src/lib.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
#![recursion_limit = "1024"]
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

why is this needed?

// === Standard Linter Configuration ===
#![deny(non_ascii_idents)]
#![warn(unsafe_code)]
// === Non-Standard Linter Configuration ===
#![warn(missing_copy_implementations)]
#![warn(missing_debug_implementations)]
#![warn(missing_docs)]
#![warn(trivial_casts)]
#![warn(trivial_numeric_casts)]
#![warn(unused_import_braces)]
#![warn(unused_qualifications)]


// ==============
// === Export ===
// ==============

pub use ide_view_component_group as component_group_view;

1 change: 1 addition & 0 deletions app/gui/view/debug_scene/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -8,5 +8,6 @@ edition = "2021"
crate-type = ["cdylib", "rlib"]

[dependencies]
debug-scene-component-group = { path = "component-group" }
debug-scene-interface = { path = "interface" }
debug-scene-visualization = { path = "visualization" }
17 changes: 17 additions & 0 deletions app/gui/view/debug_scene/component-group/Cargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
[package]
name = "debug-scene-component-group"
version = "0.1.0"
authors = ["Enso Team <[email protected]>"]
edition = "2021"

[lib]
crate-type = ["cdylib", "rlib"]

[dependencies]
enso-frp = { path = "../../../../../lib/rust/frp" }
ensogl-core = { path = "../../../../../lib/rust/ensogl/core" }
ensogl-hardcoded-theme = { path = "../../../../../lib/rust/ensogl/app/theme/hardcoded" }
ensogl-list-view = { path = "../../../../../lib/rust/ensogl/component/list-view" }
ensogl-text-msdf-sys = { path = "../../../../../lib/rust/ensogl/component/text/msdf-sys" }
ide-view-component-group = { path = "../../component-browser/component-group-view" }
wasm-bindgen = { version = "0.2.78", features = ["nightly"] }
Loading