feat: editor almost done.
This commit is contained in:
@@ -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();
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -175,7 +175,7 @@ class Scheme {
|
||||
'uploaded': uploaded,
|
||||
'name': name,
|
||||
'desc': description,
|
||||
'gestures': gestures,
|
||||
'gestures': gestures?.map((e) => e.toJson()).toList(),
|
||||
};
|
||||
}
|
||||
|
||||
|
||||
@@ -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,
|
||||
|
||||
@@ -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: () {
|
||||
|
||||
@@ -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);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user