diff --git a/src/app.rs b/src/app.rs index 8836085..147a740 100644 --- a/src/app.rs +++ b/src/app.rs @@ -1,14 +1,11 @@ // Copyright 2023 System76 // SPDX-License-Identifier: GPL-3.0-only -use cosmic::iced::clipboard::dnd::DndAction; -use cosmic::widget::dnd_destination::DragId; -use cosmic::widget::menu::action::MenuAction; -use cosmic::widget::menu::key_bind::KeyBind; use cosmic::{ app::{message, Command, Core}, cosmic_config, cosmic_theme, executor, iced::{ + clipboard::dnd::DndAction, event, futures::{self, SinkExt}, keyboard::{Event as KeyEvent, Key, Modifiers}, @@ -20,6 +17,8 @@ use cosmic::{ style, theme, widget::{ self, + dnd_destination::DragId, + menu::{action::MenuAction, key_bind::KeyBind}, segmented_button::{self, Entity}, }, Application, ApplicationExt, Element, @@ -42,18 +41,17 @@ use std::{ }; use tokio::sync::mpsc; -use crate::localize::LANGUAGE_SORTER; -use crate::tab::HOVER_DURATION; use crate::{ clipboard::{ClipboardCopy, ClipboardKind, ClipboardPaste}, config::{AppTheme, Config, Favorite, IconSizes, TabConfig, CONFIG_VERSION}, fl, home_dir, key_bind::key_binds, + localize::LANGUAGE_SORTER, menu, mime_app, mounter::{mounters, MounterItem, MounterItems, MounterKey, Mounters}, operation::{Operation, ReplaceResult}, spawn_detached::spawn_detached, - tab::{self, HeadingOptions, ItemMetadata, Location, Tab}, + tab::{self, HeadingOptions, ItemMetadata, Location, Tab, HOVER_DURATION}, }; #[derive(Clone, Debug)] diff --git a/src/key_bind.rs b/src/key_bind.rs index b8a2b35..2070e00 100644 --- a/src/key_bind.rs +++ b/src/key_bind.rs @@ -1,9 +1,11 @@ -use cosmic::widget::menu::key_bind::KeyBind; -use cosmic::{iced::keyboard::Key, iced_core::keyboard::key::Named}; +use cosmic::{ + iced::keyboard::Key, + iced_core::keyboard::key::Named, + widget::menu::key_bind::{KeyBind, Modifier}, +}; use std::collections::HashMap; use crate::app::Action; -use cosmic::widget::menu::key_bind::Modifier; //TODO: load from config pub fn key_binds() -> HashMap { diff --git a/src/menu.rs b/src/menu.rs index 33460c0..f916b7a 100644 --- a/src/menu.rs +++ b/src/menu.rs @@ -1,22 +1,20 @@ // SPDX-License-Identifier: GPL-3.0-only -use cosmic::widget::menu::key_bind::KeyBind; -use cosmic::widget::menu::{self, ItemHeight, ItemWidth, MenuBar}; use cosmic::{ //TODO: export iced::widget::horizontal_rule in cosmic::widget iced::{widget::horizontal_rule, Alignment, Background, Border, Length}, theme, widget, + widget::menu::{self, key_bind::KeyBind, ItemHeight, ItemWidth, MenuBar}, Element, }; use std::collections::HashMap; -use crate::tab::LocationMenuAction; use crate::{ app::{Action, Message}, config::TabConfig, fl, - tab::{self, HeadingOptions, Location, Tab}, + tab::{self, HeadingOptions, Location, LocationMenuAction, Tab}, }; macro_rules! menu_button { diff --git a/src/tab.rs b/src/tab.rs index 0181436..beeee4c 100644 --- a/src/tab.rs +++ b/src/tab.rs @@ -1,9 +1,3 @@ -use cosmic::iced::clipboard::dnd::DndAction; -use cosmic::iced::Border; -use cosmic::iced_core::widget::tree; -use cosmic::widget::menu::action::MenuAction; -use cosmic::widget::menu::key_bind::KeyBind; -use cosmic::widget::{vertical_space, Id, Widget}; use cosmic::{ cosmic_theme, font, iced::{ @@ -12,6 +6,7 @@ use cosmic::{ text::{self, Paragraph}, }, alignment::{Horizontal, Vertical}, + clipboard::dnd::DndAction, futures::SinkExt, keyboard::Modifiers, subscription::{self, Subscription}, @@ -21,6 +16,7 @@ use cosmic::{ scrollable::{AbsoluteOffset, Viewport}, }, Alignment, + Border, Color, ContentFit, Length, @@ -28,36 +24,42 @@ use cosmic::{ Rectangle, Size, }, - theme, widget, Element, + iced_core::widget::tree, + theme, widget, + widget::{ + menu::{action::MenuAction, key_bind::KeyBind}, + vertical_space, DndDestination, DndSource, Id, Widget, + }, + Element, }; + use mime_guess::{mime, Mime}; use once_cell::sync::Lazy; use serde::{Deserialize, Serialize}; -use std::cell::RefCell; -use std::sync::{Arc, Mutex}; use std::{ - cell::Cell, + cell::{Cell, RefCell}, cmp::Ordering, collections::HashMap, fmt, fs::{self, Metadata}, num::NonZeroU16, path::PathBuf, + sync::{Arc, Mutex}, time::{Duration, Instant}, }; -use crate::clipboard::{ClipboardCopy, ClipboardKind, ClipboardPaste}; -use crate::localize::LANGUAGE_SORTER; use crate::{ app::{self, Action}, + clipboard::{ClipboardCopy, ClipboardKind, ClipboardPaste}, config::{IconSizes, TabConfig, ICON_SCALE_MAX, ICON_SIZE_GRID}, dialog::DialogKind, - fl, menu, + fl, + localize::LANGUAGE_SORTER, + menu, mime_app::{mime_apps, MimeApp}, mime_icon::{mime_for_path, mime_icon}, mouse_area, }; -use cosmic::widget::{DndDestination, DndSource}; pub const DOUBLE_CLICK_DURATION: Duration = Duration::from_millis(500); pub const HOVER_DURATION: Duration = Duration::from_millis(1600); @@ -1920,7 +1922,9 @@ impl Tab { } = theme::active().cosmic().spacing; let size = self.size_opt.get().unwrap_or(Size::new(0.0, 0.0)); - let mut row = widget::row::with_capacity(5).align_items(Alignment::Center).padding([0, space_m]); + let mut row = widget::row::with_capacity(5) + .align_items(Alignment::Center) + .padding([0, space_m]); let mut w = 0.0; let mut prev_button = @@ -2632,7 +2636,7 @@ impl Tab { .width(Length::Fill) .height(Length::Fixed(row_height as f32)) .id(item.button_id.clone()) - .padding(space_xxs) + .padding(if icon_size < 24 { 7 } else { space_xxs }) .style(button_style(item.selected, true, false)), ) .on_press(move |_| Message::Click(Some(i)))