feat: add dde_button widget.
This commit is contained in:
@@ -1,8 +1,10 @@
|
||||
import 'package:flutter/cupertino.dart';
|
||||
|
||||
const double localManagerPanelWidth = 200;
|
||||
/// [UOS设计指南](https://docs.uniontech.com/zh/content/t_dbG3kBK9iDf9B963ok)
|
||||
|
||||
const double marketPanelWidth = 200;
|
||||
const double localManagerPanelWidth = 260;
|
||||
|
||||
const double marketPanelWidth = 300;
|
||||
|
||||
const shortDuration = const Duration(milliseconds: 100);
|
||||
|
||||
@@ -12,6 +14,10 @@ const longDuration = const Duration(milliseconds: 500);
|
||||
|
||||
const minWindowSize = const Size(800, 600);
|
||||
|
||||
const double defaultBorderRadius = 8;
|
||||
|
||||
const double defaultButtonHeight = 36;
|
||||
|
||||
enum PanelType {
|
||||
local_manager,
|
||||
market,
|
||||
|
||||
@@ -1,4 +1,5 @@
|
||||
import 'package:dde_gesture_manager/extensions.dart';
|
||||
import 'package:dde_gesture_manager/widgets/help_button.dart';
|
||||
import 'package:dde_gesture_manager/widgets/language_switcher.dart';
|
||||
import 'package:dde_gesture_manager/widgets/theme_switcher.dart';
|
||||
import 'package:dde_gesture_manager/widgets/version_checker.dart';
|
||||
@@ -27,9 +28,9 @@ class _FooterState extends State<Footer> {
|
||||
Row(
|
||||
children: [
|
||||
LanguageSwitcher(),
|
||||
Container(width: 6),
|
||||
ThemeSwitcher(),
|
||||
],
|
||||
HelpButton(),
|
||||
].map((e) => Padding(padding: EdgeInsets.only(right: 6), child: e)).toList(),
|
||||
)
|
||||
],
|
||||
),
|
||||
|
||||
@@ -1,9 +1,10 @@
|
||||
import 'package:dde_gesture_manager/constants/constants.dart';
|
||||
import 'package:dde_gesture_manager/extensions.dart';
|
||||
import 'package:dde_gesture_manager/models/content_layout.provider.dart';
|
||||
import 'package:dde_gesture_manager/utils/helper.dart';
|
||||
import 'package:dde_gesture_manager/widgets/dde_button.dart';
|
||||
import 'package:flutter/cupertino.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:dde_gesture_manager/extensions.dart';
|
||||
|
||||
class GestureEditor extends StatelessWidget {
|
||||
const GestureEditor({Key? key}) : super(key: key);
|
||||
@@ -19,42 +20,47 @@ class GestureEditor extends StatelessWidget {
|
||||
color: context.t.backgroundColor,
|
||||
borderRadius: BorderRadius.circular(10),
|
||||
),
|
||||
child: Column(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
Visibility(
|
||||
visible: layoutProvider.localManagerOpened == false,
|
||||
child: IconButton(
|
||||
onPressed: () => H.openPanel(context, PanelType.local_manager),
|
||||
icon: Icon(
|
||||
CupertinoIcons.square_list,
|
||||
),
|
||||
),
|
||||
),
|
||||
Visibility(
|
||||
visible: layoutProvider.marketOpened == false,
|
||||
child: IconButton(
|
||||
onPressed: () => H.openPanel(context, PanelType.market),
|
||||
icon: Icon(
|
||||
CupertinoIcons.cart,
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
Container(
|
||||
child: Row(
|
||||
child: Padding(
|
||||
padding: const EdgeInsets.all(8.0),
|
||||
child: Column(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
Text("<编辑器区域"),
|
||||
Text("编辑器区域>"),
|
||||
Visibility(
|
||||
visible: layoutProvider.localManagerOpened == false,
|
||||
child: DButton(
|
||||
width: defaultButtonHeight,
|
||||
onTap: () => H.openPanel(context, PanelType.local_manager),
|
||||
child: Icon(
|
||||
CupertinoIcons.square_list,
|
||||
),
|
||||
),
|
||||
),
|
||||
Visibility(
|
||||
visible: layoutProvider.marketOpened == false,
|
||||
child: DButton(
|
||||
width: defaultButtonHeight,
|
||||
onTap: () => H.openPanel(context, PanelType.market),
|
||||
child: Icon(
|
||||
CupertinoIcons.cart,
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
],
|
||||
Container(
|
||||
child: Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
Text("<编辑器区域"),
|
||||
Text("编辑器区域>"),
|
||||
],
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
|
||||
@@ -1,9 +1,11 @@
|
||||
import 'package:dde_gesture_manager/constants/constants.dart';
|
||||
import 'package:dde_gesture_manager/extensions.dart';
|
||||
import 'package:dde_gesture_manager/models/content_layout.provider.dart';
|
||||
import 'package:dde_gesture_manager/widgets/dde_button.dart';
|
||||
import 'package:flutter/animation.dart';
|
||||
import 'package:flutter/cupertino.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:dde_gesture_manager/extensions.dart';
|
||||
import 'package:dde_gesture_manager/constants/constants.dart';
|
||||
import 'package:flutter/painting.dart';
|
||||
|
||||
class LocalManager extends StatelessWidget {
|
||||
const LocalManager({
|
||||
@@ -24,29 +26,39 @@ class LocalManager extends StatelessWidget {
|
||||
child: Material(
|
||||
color: context.t.backgroundColor,
|
||||
elevation: isOpen ? 10 : 0,
|
||||
child: Column(
|
||||
mainAxisAlignment: MainAxisAlignment.start,
|
||||
children: [
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
Flexible(
|
||||
child: Center(
|
||||
child: Text(
|
||||
"本地配置",
|
||||
textAlign: TextAlign.center,
|
||||
child: Padding(
|
||||
padding: const EdgeInsets.all(8.0),
|
||||
child: Column(
|
||||
mainAxisAlignment: MainAxisAlignment.start,
|
||||
children: [
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
Container(width: defaultButtonHeight),
|
||||
Flexible(
|
||||
child: Center(
|
||||
child: Text(
|
||||
"本地方案管理",
|
||||
textAlign: TextAlign.center,
|
||||
style: TextStyle(
|
||||
fontWeight: FontWeight.bold,
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
IconButton(
|
||||
onPressed: () => context.read<ContentLayoutProvider>().setProps(localManagerOpened: !isOpen),
|
||||
icon: Icon(
|
||||
CupertinoIcons.chevron_left_2,
|
||||
DButton(
|
||||
width: defaultButtonHeight - 2,
|
||||
height: defaultButtonHeight - 2,
|
||||
onTap: () => context.read<ContentLayoutProvider>().setProps(localManagerOpened: !isOpen),
|
||||
child: Icon(
|
||||
CupertinoIcons.chevron_left_2,
|
||||
size: 20,
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
],
|
||||
],
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
|
||||
+33
-22
@@ -1,8 +1,9 @@
|
||||
import 'package:dde_gesture_manager/constants/constants.dart';
|
||||
import 'package:dde_gesture_manager/extensions.dart';
|
||||
import 'package:dde_gesture_manager/models/content_layout.provider.dart';
|
||||
import 'package:dde_gesture_manager/widgets/dde_button.dart';
|
||||
import 'package:flutter/cupertino.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:dde_gesture_manager/extensions.dart';
|
||||
|
||||
class Market extends StatelessWidget {
|
||||
const Market({
|
||||
@@ -23,29 +24,39 @@ class Market extends StatelessWidget {
|
||||
child: Material(
|
||||
color: context.t.backgroundColor,
|
||||
elevation: isOpen ? 10 : 0,
|
||||
child: Column(
|
||||
mainAxisAlignment: MainAxisAlignment.start,
|
||||
children: [
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
IconButton(
|
||||
onPressed: () => context.read<ContentLayoutProvider>().setProps(marketOpened: !isOpen),
|
||||
icon: Icon(
|
||||
CupertinoIcons.chevron_right_2,
|
||||
),
|
||||
),
|
||||
Flexible(
|
||||
child: Center(
|
||||
child: Text(
|
||||
"配置市场",
|
||||
textAlign: TextAlign.center,
|
||||
child: Padding(
|
||||
padding: const EdgeInsets.all(8.0),
|
||||
child: Column(
|
||||
mainAxisAlignment: MainAxisAlignment.start,
|
||||
children: [
|
||||
Row(
|
||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
children: [
|
||||
DButton(
|
||||
width: defaultButtonHeight - 2,
|
||||
height: defaultButtonHeight - 2,
|
||||
onTap: () => context.read<ContentLayoutProvider>().setProps(marketOpened: !isOpen),
|
||||
child: Icon(
|
||||
CupertinoIcons.chevron_right_2,
|
||||
size: 20,
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
],
|
||||
Flexible(
|
||||
child: Center(
|
||||
child: Text(
|
||||
"方案市场",
|
||||
textAlign: TextAlign.center,
|
||||
style: TextStyle(
|
||||
fontWeight: FontWeight.bold,
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
Container(width: defaultButtonHeight),
|
||||
],
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
|
||||
@@ -4,4 +4,15 @@ var darkTheme = ThemeData.dark().copyWith(
|
||||
primaryColor: Colors.grey,
|
||||
scaffoldBackgroundColor: Color(0xff252525),
|
||||
backgroundColor: Color(0xff282828),
|
||||
iconTheme: IconThemeData(
|
||||
color: Color(0xffc0c6d4),
|
||||
),
|
||||
textTheme: ThemeData.dark().textTheme.copyWith(
|
||||
headline1: TextStyle(
|
||||
color: Color(0xffc0c6d4),
|
||||
),
|
||||
bodyText2: TextStyle(
|
||||
color: Color(0xffc0c6d4),
|
||||
),
|
||||
),
|
||||
);
|
||||
|
||||
@@ -4,4 +4,15 @@ var lightTheme = ThemeData.light().copyWith(
|
||||
primaryColor: Colors.blue,
|
||||
scaffoldBackgroundColor: Color(0xfff8f8f8),
|
||||
backgroundColor: Color(0xffffffff),
|
||||
iconTheme: IconThemeData(
|
||||
color: Color(0xff414d68),
|
||||
),
|
||||
textTheme: ThemeData.light().textTheme.copyWith(
|
||||
headline1: TextStyle(
|
||||
color: Color(0xff414d68),
|
||||
),
|
||||
bodyText2: TextStyle(
|
||||
color: Color(0xff414d68),
|
||||
),
|
||||
),
|
||||
);
|
||||
|
||||
@@ -0,0 +1,54 @@
|
||||
import 'package:dde_gesture_manager/constants/constants.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:glass_kit/glass_kit.dart';
|
||||
|
||||
class DButton extends StatefulWidget {
|
||||
final double width;
|
||||
final double height;
|
||||
final Widget child;
|
||||
final GestureTapCallback? onTap;
|
||||
|
||||
const DButton({
|
||||
Key? key,
|
||||
required this.width,
|
||||
this.height = defaultButtonHeight,
|
||||
required this.child,
|
||||
this.onTap,
|
||||
}) : super(key: key);
|
||||
|
||||
@override
|
||||
State<DButton> createState() => _DButtonState();
|
||||
}
|
||||
|
||||
class _DButtonState extends State<DButton> {
|
||||
bool _hovering = false;
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return GestureDetector(
|
||||
onTap: widget.onTap,
|
||||
child: GlassContainer(
|
||||
width: widget.width,
|
||||
height: widget.height,
|
||||
gradient: LinearGradient(
|
||||
colors: [Colors.white.withOpacity(_hovering ? 0.1 : 0.15), Colors.white.withOpacity(0.1)],
|
||||
begin: Alignment.topCenter,
|
||||
end: Alignment.bottomCenter,
|
||||
),
|
||||
borderColor: Color(0xff565656),
|
||||
borderWidth: 1,
|
||||
borderRadius: BorderRadius.circular(defaultBorderRadius),
|
||||
child: MouseRegion(
|
||||
onEnter: (event) => setState(() {
|
||||
_hovering = true;
|
||||
}),
|
||||
onExit: (event) => setState(() {
|
||||
_hovering = false;
|
||||
}),
|
||||
cursor: SystemMouseCursors.click,
|
||||
child: Center(child: widget.child),
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,28 @@
|
||||
import 'package:dde_gesture_manager/extensions.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
|
||||
class HelpButton extends StatelessWidget {
|
||||
const HelpButton({Key? key}) : super(key: key);
|
||||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return GestureDetector(
|
||||
onTap: () {},
|
||||
child: MouseRegion(
|
||||
cursor: SystemMouseCursors.click,
|
||||
child: Tooltip(
|
||||
message: LocaleKeys.help_tip.tr(),
|
||||
child: Row(
|
||||
children: [
|
||||
Icon(Icons.help_outline, size: 20),
|
||||
Padding(
|
||||
padding: const EdgeInsets.symmetric(horizontal: 3),
|
||||
child: Text(LocaleKeys.help_label).tr(),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
}
|
||||
@@ -1,3 +1,4 @@
|
||||
import 'package:collection/collection.dart';
|
||||
import 'package:dde_gesture_manager/constants/sp_keys.dart';
|
||||
import 'package:dde_gesture_manager/constants/supported_locales.dart';
|
||||
import 'package:dde_gesture_manager/extensions.dart';
|
||||
@@ -6,7 +7,6 @@ import 'package:dde_gesture_manager/utils/helper.dart';
|
||||
import 'package:flutter/cupertino.dart';
|
||||
import 'package:flutter/foundation.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:collection/collection.dart';
|
||||
import 'package:window_manager/window_manager.dart';
|
||||
|
||||
class LanguageSwitcher extends StatelessWidget {
|
||||
@@ -18,6 +18,7 @@ class LanguageSwitcher extends StatelessWidget {
|
||||
var _supportedLocale = supportedLocales.firstWhereOrNull((element) => element == _locale);
|
||||
|
||||
return PopupMenuButton<SupportedLocale>(
|
||||
tooltip: LocaleKeys.language_tip.tr(),
|
||||
child: Row(
|
||||
children: [
|
||||
Icon(Icons.language_outlined, size: 20),
|
||||
|
||||
@@ -1,9 +1,9 @@
|
||||
import 'package:dde_gesture_manager/extensions.dart';
|
||||
import 'package:dde_gesture_manager/generated/locale_keys.g.dart';
|
||||
import 'package:dde_gesture_manager/models/configs.dart';
|
||||
import 'package:dde_gesture_manager/models/configs.provider.dart';
|
||||
import 'package:flutter/cupertino.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:dde_gesture_manager/extensions.dart';
|
||||
|
||||
class ThemeSwitcher extends StatelessWidget {
|
||||
const ThemeSwitcher({Key? key}) : super(key: key);
|
||||
@@ -23,7 +23,7 @@ class ThemeSwitcher extends StatelessWidget {
|
||||
],
|
||||
),
|
||||
padding: EdgeInsets.zero,
|
||||
tooltip: LocaleKeys.theme_label.tr(),
|
||||
tooltip: LocaleKeys.theme_tip.tr(),
|
||||
itemBuilder: (BuildContext context) => [
|
||||
PopupMenuItem<BrightnessMode>(
|
||||
child: ListTile(
|
||||
|
||||
@@ -36,6 +36,7 @@ dependencies:
|
||||
xdg_directories_web:
|
||||
path: 3rd_party/xdg_directories_web
|
||||
easy_localization: ^3.0.0
|
||||
glass_kit: ^2.0.1
|
||||
|
||||
dev_dependencies:
|
||||
flutter_test:
|
||||
|
||||
@@ -3,7 +3,8 @@
|
||||
"label": "Theme",
|
||||
"dark": "Dark",
|
||||
"light": "Light",
|
||||
"system": "System"
|
||||
"system": "System",
|
||||
"tip": "Choose a theme"
|
||||
},
|
||||
"version": {
|
||||
"current": "current version",
|
||||
@@ -11,6 +12,11 @@
|
||||
},
|
||||
"app_name": "Gesture Manager for DDE",
|
||||
"language": {
|
||||
"label": "Language"
|
||||
"label": "Language",
|
||||
"tip": "Choose a language"
|
||||
},
|
||||
"help": {
|
||||
"label": "Help",
|
||||
"tip": "Display help documentation"
|
||||
}
|
||||
}
|
||||
@@ -3,7 +3,8 @@
|
||||
"label": "主题",
|
||||
"dark": "深色",
|
||||
"light": "浅色",
|
||||
"system": "跟随系统"
|
||||
"system": "跟随系统",
|
||||
"tip": "选择界面主题"
|
||||
},
|
||||
"version": {
|
||||
"current": "当前版本",
|
||||
@@ -11,6 +12,11 @@
|
||||
},
|
||||
"app_name": "DDE手势管理器",
|
||||
"language": {
|
||||
"label": "语言"
|
||||
"label": "语言",
|
||||
"tip": "选择语言"
|
||||
},
|
||||
"help": {
|
||||
"label": "帮助",
|
||||
"tip": "显示帮助文档"
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user