mirror of
https://github.com/foss42/apidash.git
synced 2025-05-27 19:57:03 +08:00
Update widgets
This commit is contained in:
@ -37,8 +37,14 @@ class CollectionPane extends ConsumerWidget {
|
|||||||
},
|
},
|
||||||
onImport: () {
|
onImport: () {
|
||||||
showImportDialog(
|
showImportDialog(
|
||||||
context,
|
context: context,
|
||||||
(file) {
|
importFormat: ref.watch(importFormatStateProvider),
|
||||||
|
onImportFormatChange: (format) {
|
||||||
|
if (format != null) {
|
||||||
|
ref.read(importFormatStateProvider.notifier).state = format;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
onFileDropped: (file) {
|
||||||
final importFormatType = ref.read(importFormatStateProvider);
|
final importFormatType = ref.read(importFormatStateProvider);
|
||||||
file.readAsString().then((content) {
|
file.readAsString().then((content) {
|
||||||
kImporter
|
kImporter
|
||||||
|
@ -1,19 +1,38 @@
|
|||||||
|
import 'package:apidash/consts.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:file_selector/file_selector.dart';
|
import 'package:file_selector/file_selector.dart';
|
||||||
import 'drag_and_drop_area.dart';
|
import 'drag_and_drop_area.dart';
|
||||||
|
import 'dropdown_import_format.dart';
|
||||||
|
|
||||||
showImportDialog(
|
showImportDialog({
|
||||||
BuildContext context,
|
required BuildContext context,
|
||||||
Function(XFile) onFileDropped,
|
required ImportFormat importFormat,
|
||||||
) {
|
Function(ImportFormat?)? onImportFormatChange,
|
||||||
|
Function(XFile)? onFileDropped,
|
||||||
|
}) {
|
||||||
showDialog(
|
showDialog(
|
||||||
context: context,
|
context: context,
|
||||||
builder: (context) {
|
builder: (context) {
|
||||||
return AlertDialog(
|
return AlertDialog(
|
||||||
contentPadding: const EdgeInsets.all(12),
|
contentPadding: const EdgeInsets.all(12),
|
||||||
content: DragAndDropArea(
|
content: Column(
|
||||||
|
mainAxisSize: MainAxisSize.min,
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.center,
|
||||||
|
children: [
|
||||||
|
const Text("Import "),
|
||||||
|
DropdownButtonImportFormat(
|
||||||
|
importFormat: importFormat,
|
||||||
|
onChanged: onImportFormatChange,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
DragAndDropArea(
|
||||||
onFileDropped: onFileDropped,
|
onFileDropped: onFileDropped,
|
||||||
),
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
|
@ -1,11 +1,16 @@
|
|||||||
|
import 'package:flutter/material.dart';
|
||||||
import 'package:desktop_drop/desktop_drop.dart';
|
import 'package:desktop_drop/desktop_drop.dart';
|
||||||
import 'package:file_selector/file_selector.dart';
|
import 'package:file_selector/file_selector.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:apidash/utils/utils.dart';
|
||||||
|
import 'package:apidash/consts.dart';
|
||||||
|
|
||||||
class DragAndDropArea extends StatefulWidget {
|
class DragAndDropArea extends StatefulWidget {
|
||||||
final Function(XFile) onFileDropped;
|
final Function(XFile)? onFileDropped;
|
||||||
|
|
||||||
const DragAndDropArea({super.key, required this.onFileDropped});
|
const DragAndDropArea({
|
||||||
|
super.key,
|
||||||
|
this.onFileDropped,
|
||||||
|
});
|
||||||
|
|
||||||
@override
|
@override
|
||||||
State<DragAndDropArea> createState() => _DragAndDropAreaState();
|
State<DragAndDropArea> createState() => _DragAndDropAreaState();
|
||||||
@ -22,7 +27,7 @@ class _DragAndDropAreaState extends State<DragAndDropArea> {
|
|||||||
setState(() {
|
setState(() {
|
||||||
_list.addAll(detail.files);
|
_list.addAll(detail.files);
|
||||||
});
|
});
|
||||||
widget.onFileDropped(detail.files[0]);
|
widget.onFileDropped?.call(detail.files[0]);
|
||||||
},
|
},
|
||||||
onDragEntered: (detail) {
|
onDragEntered: (detail) {
|
||||||
setState(() {
|
setState(() {
|
||||||
@ -47,7 +52,41 @@ class _DragAndDropAreaState extends State<DragAndDropArea> {
|
|||||||
width: 600,
|
width: 600,
|
||||||
height: 400,
|
height: 400,
|
||||||
child: _list.isEmpty
|
child: _list.isEmpty
|
||||||
? const Center(child: Text("Select or drop the file here"))
|
? Center(
|
||||||
|
child: Column(
|
||||||
|
mainAxisSize: MainAxisSize.min,
|
||||||
|
children: [
|
||||||
|
SizedBox(
|
||||||
|
width: 150,
|
||||||
|
child: ElevatedButton.icon(
|
||||||
|
icon: const Icon(
|
||||||
|
Icons.snippet_folder_rounded,
|
||||||
|
size: 20,
|
||||||
|
),
|
||||||
|
style: ElevatedButton.styleFrom(
|
||||||
|
minimumSize: const Size.fromHeight(kDataTableRowHeight),
|
||||||
|
shape: RoundedRectangleBorder(
|
||||||
|
borderRadius: BorderRadius.circular(6),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
onPressed: () async {
|
||||||
|
var pickedResult = await pickFile();
|
||||||
|
if (pickedResult != null &&
|
||||||
|
pickedResult.path.isNotEmpty) {
|
||||||
|
widget.onFileDropped?.call(pickedResult);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
label: const Text(
|
||||||
|
kLabelSelectFile,
|
||||||
|
overflow: TextOverflow.ellipsis,
|
||||||
|
style: kFormDataButtonLabelTextStyle,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
kVSpacer10,
|
||||||
|
const Text("Select or drop the file here"),
|
||||||
|
],
|
||||||
|
))
|
||||||
: Text(_list.map((e) => e.path).join("\n")),
|
: Text(_list.map((e) => e.path).join("\n")),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
51
lib/widgets/dropdown_import_format.dart
Normal file
51
lib/widgets/dropdown_import_format.dart
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:apidash/consts.dart';
|
||||||
|
|
||||||
|
class DropdownButtonImportFormat extends StatelessWidget {
|
||||||
|
const DropdownButtonImportFormat({
|
||||||
|
super.key,
|
||||||
|
required this.importFormat,
|
||||||
|
this.onChanged,
|
||||||
|
});
|
||||||
|
|
||||||
|
final ImportFormat importFormat;
|
||||||
|
final void Function(ImportFormat?)? onChanged;
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
final surfaceColor = Theme.of(context).colorScheme.surface;
|
||||||
|
return DropdownButton<ImportFormat>(
|
||||||
|
isExpanded: false,
|
||||||
|
focusColor: surfaceColor,
|
||||||
|
value: importFormat,
|
||||||
|
icon: const Icon(
|
||||||
|
Icons.unfold_more_rounded,
|
||||||
|
size: 16,
|
||||||
|
),
|
||||||
|
elevation: 4,
|
||||||
|
style: kCodeStyle.copyWith(
|
||||||
|
color: Theme.of(context).colorScheme.primary,
|
||||||
|
),
|
||||||
|
underline: Container(
|
||||||
|
height: 0,
|
||||||
|
),
|
||||||
|
onChanged: onChanged,
|
||||||
|
borderRadius: kBorderRadius12,
|
||||||
|
items: ImportFormat.values
|
||||||
|
.map<DropdownMenuItem<ImportFormat>>((ImportFormat value) {
|
||||||
|
return DropdownMenuItem<ImportFormat>(
|
||||||
|
value: value,
|
||||||
|
child: Padding(
|
||||||
|
padding: kPs8,
|
||||||
|
child: Text(
|
||||||
|
value.label,
|
||||||
|
style: kTextStyleButton,
|
||||||
|
overflow: TextOverflow.ellipsis,
|
||||||
|
maxLines: 1,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}).toList(),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
@ -18,6 +18,7 @@ export 'dropdown_codegen.dart';
|
|||||||
export 'dropdown_content_type.dart';
|
export 'dropdown_content_type.dart';
|
||||||
export 'dropdown_formdata.dart';
|
export 'dropdown_formdata.dart';
|
||||||
export 'dropdown_http_method.dart';
|
export 'dropdown_http_method.dart';
|
||||||
|
export 'dropdown_import_format.dart';
|
||||||
export 'editor_json.dart';
|
export 'editor_json.dart';
|
||||||
export 'editor.dart';
|
export 'editor.dart';
|
||||||
export 'error_message.dart';
|
export 'error_message.dart';
|
||||||
|
@ -32,7 +32,7 @@ void main() {
|
|||||||
|
|
||||||
// Since we can't actually perform drag-and-drop in a unit test,
|
// Since we can't actually perform drag-and-drop in a unit test,
|
||||||
// we'll call the onDragDone callback directly
|
// we'll call the onDragDone callback directly
|
||||||
dragAndDropArea.onFileDropped(testFile);
|
dragAndDropArea.onFileDropped?.call(testFile);
|
||||||
|
|
||||||
await tester.pump();
|
await tester.pump();
|
||||||
|
|
||||||
@ -42,4 +42,3 @@ void main() {
|
|||||||
expect(droppedFile?.path, 'test.curl');
|
expect(droppedFile?.path, 'test.curl');
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user