Struct relm4::factory::AsyncFactoryVecDeque
source · pub struct AsyncFactoryVecDeque<C: AsyncFactoryComponent>where
<C::ParentWidget as FactoryView>::ReturnedWidget: Clone,{ /* private fields */ }
Expand description
A container similar to VecDeque
that can be used to store
data associated with components that implement AsyncFactoryComponent
.
To access mutable methods of the factory, create a guard using Self::guard
.
Implementations§
source§impl<C: AsyncFactoryComponent> AsyncFactoryVecDeque<C>where
<C::ParentWidget as FactoryView>::ReturnedWidget: Clone,
impl<C: AsyncFactoryComponent> AsyncFactoryVecDeque<C>where <C::ParentWidget as FactoryView>::ReturnedWidget: Clone,
sourcepub fn new(
widget: C::ParentWidget,
parent_sender: &Sender<C::ParentInput>
) -> Self
pub fn new( widget: C::ParentWidget, parent_sender: &Sender<C::ParentInput> ) -> Self
Creates a new AsyncFactoryVecDeque
.
Examples found in repository?
197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212
fn init(
counter: Self::Init,
root: &Self::Root,
sender: ComponentSender<Self>,
) -> ComponentParts<Self> {
let counters = AsyncFactoryVecDeque::new(gtk::Box::default(), sender.input_sender());
let model = App {
created_widgets: counter,
counters,
};
let counter_box = model.counters.widget();
let widgets = view_output!();
ComponentParts { model, widgets }
}
sourcepub fn guard(&mut self) -> AsyncFactoryVecDequeGuard<'_, C>
pub fn guard(&mut self) -> AsyncFactoryVecDequeGuard<'_, C>
Provides a AsyncFactoryVecDequeGuard
that can be used to edit the factory.
The changes will be rendered on the widgets after the guard goes out of scope.
Examples found in repository?
214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246
fn update(&mut self, msg: Self::Input, _sender: ComponentSender<Self>) {
let mut counters_guard = self.counters.guard();
match msg {
AppMsg::AddCounter => {
counters_guard.push_back(self.created_widgets);
self.created_widgets = self.created_widgets.wrapping_add(1);
}
AppMsg::RemoveCounter => {
counters_guard.pop_back();
}
AppMsg::SendFront(index) => {
counters_guard.move_front(index.current_index());
}
AppMsg::MoveDown(index) => {
let index = index.current_index();
let new_index = index + 1;
// Already at the end?
if new_index < counters_guard.len() {
counters_guard.move_to(index, new_index);
}
}
AppMsg::MoveUp(index) => {
let index = index.current_index();
// Already at the start?
if index != 0 {
counters_guard.move_to(index, index - 1);
}
}
AppMsg::Remove(index) => {
counters_guard.remove(index.current_index());
}
}
}
sourcepub fn len(&self) -> usize
pub fn len(&self) -> usize
Returns the number of elements in the AsyncFactoryVecDeque
.
Examples found in repository?
214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246
fn update(&mut self, msg: Self::Input, _sender: ComponentSender<Self>) {
let mut counters_guard = self.counters.guard();
match msg {
AppMsg::AddCounter => {
counters_guard.push_back(self.created_widgets);
self.created_widgets = self.created_widgets.wrapping_add(1);
}
AppMsg::RemoveCounter => {
counters_guard.pop_back();
}
AppMsg::SendFront(index) => {
counters_guard.move_front(index.current_index());
}
AppMsg::MoveDown(index) => {
let index = index.current_index();
let new_index = index + 1;
// Already at the end?
if new_index < counters_guard.len() {
counters_guard.move_to(index, new_index);
}
}
AppMsg::MoveUp(index) => {
let index = index.current_index();
// Already at the start?
if index != 0 {
counters_guard.move_to(index, index - 1);
}
}
AppMsg::Remove(index) => {
counters_guard.remove(index.current_index());
}
}
}
sourcepub fn is_empty(&self) -> bool
pub fn is_empty(&self) -> bool
Returns true if the AsyncFactoryVecDeque
is empty.
sourcepub fn broadcast(&self, msg: C::Input)where
C::Input: Clone,
pub fn broadcast(&self, msg: C::Input)where C::Input: Clone,
Send clone of a message to all of the elements.
sourcepub fn get(&self, index: usize) -> Option<&C>
pub fn get(&self, index: usize) -> Option<&C>
Tries to get an immutable reference to the model of one element.
Returns None
if index
is invalid or the async init_model()
method
hasn’t returned yet.
sourcepub fn back(&self) -> Option<&C>
pub fn back(&self) -> Option<&C>
Provides a reference to the model of the back element.
Returns None
if index
is invalid or the async init_model()
method
of the last element hasn’t returned yet.
sourcepub fn front(&self) -> Option<&C>
pub fn front(&self) -> Option<&C>
Provides a reference to the model of the front element.
Returns None
if index
is invalid or the async init_model()
method
of the first element hasn’t returned yet.
sourcepub const fn widget(&self) -> &C::ParentWidget
pub const fn widget(&self) -> &C::ParentWidget
Returns the widget all components are attached to.
Examples found in repository?
197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212
fn init(
counter: Self::Init,
root: &Self::Root,
sender: ComponentSender<Self>,
) -> ComponentParts<Self> {
let counters = AsyncFactoryVecDeque::new(gtk::Box::default(), sender.input_sender());
let model = App {
created_widgets: counter,
counters,
};
let counter_box = model.counters.widget();
let widgets = view_output!();
ComponentParts { model, widgets }
}
sourcepub fn iter(
&self
) -> impl Iterator<Item = Option<&C>> + DoubleEndedIterator + ExactSizeIterator + FusedIterator
pub fn iter( &self ) -> impl Iterator<Item = Option<&C>> + DoubleEndedIterator + ExactSizeIterator + FusedIterator
Returns an iterator over the components.
Each item will be Some
if the async init_model()
method
of the item returned and otherwise None
.