feat: editor almost done.

This commit is contained in:
2021-12-16 18:55:27 +08:00
parent 09a9275705
commit 8face6f724
8 changed files with 59 additions and 19 deletions
+6 -5
View File
@@ -49,15 +49,16 @@ class LocalSchemes implements LocalSchemesInterface<LocalSchemeEntryLinux> {
Future<LocalSchemeEntry> create() async {
var _supportDirectory = await getApplicationSupportDirectory();
return LocalSchemeEntryLinux(
path: join(_supportDirectory.path, 'schemes', '${Uuid().v1()}.json'),
scheme: Scheme.create(),
lastModifyTime: DateTime.now(),
);
path: join(_supportDirectory.path, 'schemes', '${Uuid().v1()}.json'),
scheme: Scheme.create(),
lastModifyTime: DateTime.now(),
);
}
@override
void remove(String path) {
File(path).delete();
var file = File(path);
if (file.existsSync()) file.delete();
}
}
+1 -1
View File
@@ -175,7 +175,7 @@ class Scheme {
'uploaded': uploaded,
'name': name,
'desc': description,
'gestures': gestures,
'gestures': gestures?.map((e) => e.toJson()).toList(),
};
}
+2 -2
View File
@@ -508,7 +508,7 @@ List<DDataCell> _buildRowCellsEditing(BuildContext context) {
_buildCommandCellsEditing(context),
TableCellTextField(
initText: gesture.remark,
hint: 'pls input cmd',
hint: LocaleKeys.gesture_editor_hints_remark.tr(),
onComplete: (value) => context.read<GesturePropProvider>().setProps(
remark: value,
editMode: true,
@@ -523,7 +523,7 @@ Widget _buildCommandCellsEditing(BuildContext context) {
case GestureType.commandline:
return TableCellTextField(
initText: gesture.command,
hint: 'pls input cmd',
hint: LocaleKeys.gesture_editor_hints_command.tr(),
onComplete: (value) => context.read<GesturePropProvider>().setProps(
command: value,
editMode: true,
+32 -6
View File
@@ -26,7 +26,7 @@ class LocalManager extends StatefulWidget {
class _LocalManagerState extends State<LocalManager> {
late ScrollController _scrollController;
String? _hoveringItem;
String? _hoveringItemPath;
late String _selectedItemPath;
@override
@@ -51,7 +51,7 @@ class _LocalManagerState extends State<LocalManager> {
Color _getItemBackgroundColor(int index, String itemPath) {
Color _color = index % 2 == 0 ? context.t.scaffoldBackgroundColor : context.t.backgroundColor;
if (itemPath == _hoveringItem) _color = context.t.dialogBackgroundColor;
if (itemPath == _hoveringItemPath) _color = context.t.dialogBackgroundColor;
if (itemPath == _selectedItemPath) _color = context.read<SettingsProvider>().currentActiveColor;
return _color;
}
@@ -144,7 +144,7 @@ class _LocalManagerState extends State<LocalManager> {
cursor: SystemMouseCursors.click,
onEnter: (_) {
setState(() {
_hoveringItem = localSchemes[index].path;
_hoveringItemPath = localSchemes[index].path;
});
},
child: Container(
@@ -196,8 +196,13 @@ class _LocalManagerState extends State<LocalManager> {
onTap: () async {
var localSchemesProvider = context.read<LocalSchemesProvider>();
var newSchemes = [...?localSchemesProvider.schemes];
newSchemes.add(await localSchemesProvider.create());
var newEntry = await localSchemesProvider.create();
newSchemes.add(newEntry);
localSchemesProvider.setProps(schemes: newSchemes..sort());
setState(() {
_selectedItemPath = newEntry.path;
});
_handleItemClick(context, newEntry);
},
),
DButton.delete(
@@ -209,12 +214,33 @@ class _LocalManagerState extends State<LocalManager> {
newSchemes.removeAt(index);
localSchemesProvider.setProps(schemes: newSchemes);
localSchemesProvider.remove(_selectedItemPath);
var newSelectedItem = newSchemes[(index - 1).clamp(1, newSchemes.length)];
setState(() {
_selectedItemPath = newSchemes[(index - 1).clamp(1, newSchemes.length)].path;
_selectedItemPath = newSelectedItem.path;
});
_handleItemClick(context, newSelectedItem);
},
),
DButton.duplicate(
enabled: _selectedItemPath.notNull,
onTap: () async {
var localSchemesProvider = context.read<LocalSchemesProvider>();
var newSchemes = [...?localSchemesProvider.schemes];
var index = newSchemes.indexWhere((element) => element.path == _selectedItemPath);
var newEntry = await localSchemesProvider.create();
newEntry.scheme = Scheme.parse(newSchemes[index].scheme.toJson());
newEntry.scheme.id = Uuid().v1();
newEntry.scheme.name = '${newEntry.scheme.name} (${LocaleKeys.str_copy.tr()})';
newEntry.scheme.fromMarket = false;
newEntry.scheme.uploaded = false;
newSchemes.add(newEntry);
localSchemesProvider.setProps(schemes: newSchemes..sort());
setState(() {
_selectedItemPath = newEntry.path;
});
_handleItemClick(context, newEntry);
},
),
DButton.duplicate(enabled: _selectedItemPath.notNull),
DButton.apply(
enabled: true,
onTap: () {
+4 -1
View File
@@ -2,7 +2,6 @@ import 'package:dde_gesture_manager/constants/constants.dart';
import 'package:dde_gesture_manager/extensions.dart';
import 'package:dde_gesture_manager/models/settings.provider.dart';
import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
class DTextField extends StatefulWidget {
final String? initText;
@@ -52,6 +51,10 @@ class _DTextFieldState extends State<DTextField> {
void didUpdateWidget(covariant DTextField oldWidget) {
if (oldWidget.initText != widget.initText) {
_controller.text = widget.initText ?? '';
if (widget.initText == LocaleKeys.str_new_scheme.tr() ||
(widget.initText ?? '').contains('(${LocaleKeys.str_copy.tr()})')) {
_focusNode.requestFocus();
}
}
super.didUpdateWidget(oldWidget);
}