2024-08-11 01:57:58 +08:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:get/get.dart';
|
|
|
|
import 'package:solian/controllers/post_editor_controller.dart';
|
|
|
|
import 'package:solian/widgets/attachments/attachment_editor.dart';
|
|
|
|
|
|
|
|
class PostEditorThumbnailDialog extends StatefulWidget {
|
|
|
|
final PostEditorController controller;
|
|
|
|
|
|
|
|
const PostEditorThumbnailDialog({super.key, required this.controller});
|
|
|
|
|
|
|
|
@override
|
|
|
|
State<PostEditorThumbnailDialog> createState() =>
|
|
|
|
_PostEditorThumbnailDialogState();
|
|
|
|
}
|
|
|
|
|
|
|
|
class _PostEditorThumbnailDialogState extends State<PostEditorThumbnailDialog> {
|
|
|
|
final TextEditingController _attachmentController = TextEditingController();
|
|
|
|
|
|
|
|
void _promptUploadNewAttachment() {
|
|
|
|
showModalBottomSheet(
|
|
|
|
context: context,
|
|
|
|
builder: (context) => AttachmentEditorPopup(
|
2024-08-18 22:51:52 +08:00
|
|
|
pool: 'interactive',
|
2024-08-11 01:57:58 +08:00
|
|
|
singleMode: true,
|
|
|
|
imageOnly: true,
|
|
|
|
autoUpload: true,
|
|
|
|
onAdd: (value) {
|
|
|
|
setState(() {
|
|
|
|
_attachmentController.text = value.toString();
|
|
|
|
});
|
|
|
|
|
|
|
|
widget.controller.thumbnail.value = value;
|
|
|
|
},
|
|
|
|
initialAttachments: const [],
|
|
|
|
onRemove: (_) {},
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
void initState() {
|
|
|
|
_attachmentController.text =
|
|
|
|
widget.controller.thumbnail.value?.toString() ?? '';
|
|
|
|
super.initState();
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
void dispose() {
|
|
|
|
_attachmentController.dispose();
|
|
|
|
super.dispose();
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return AlertDialog(
|
|
|
|
title: Text('postThumbnail'.tr),
|
|
|
|
content: Column(
|
|
|
|
mainAxisSize: MainAxisSize.min,
|
|
|
|
children: [
|
2024-09-16 20:33:34 +08:00
|
|
|
Card(
|
|
|
|
margin: EdgeInsets.zero,
|
|
|
|
child: ListTile(
|
|
|
|
title: Text('postThumbnailAttachmentNew'.tr),
|
|
|
|
contentPadding: const EdgeInsets.only(left: 12, right: 9),
|
|
|
|
trailing: const Icon(Icons.chevron_right),
|
|
|
|
shape: const RoundedRectangleBorder(
|
|
|
|
borderRadius: BorderRadius.all(Radius.circular(8)),
|
|
|
|
),
|
|
|
|
onTap: () {
|
|
|
|
_promptUploadNewAttachment();
|
|
|
|
},
|
2024-08-11 01:57:58 +08:00
|
|
|
),
|
|
|
|
),
|
2024-09-16 20:33:34 +08:00
|
|
|
const Row(children: <Widget>[
|
|
|
|
Expanded(child: Divider()),
|
|
|
|
Text('OR'),
|
|
|
|
Expanded(child: Divider()),
|
|
|
|
]).paddingOnly(top: 12, bottom: 16, left: 16, right: 16),
|
2024-08-11 01:57:58 +08:00
|
|
|
TextField(
|
|
|
|
controller: _attachmentController,
|
|
|
|
decoration: InputDecoration(
|
|
|
|
isDense: true,
|
|
|
|
border: const OutlineInputBorder(),
|
|
|
|
prefixText: '#',
|
|
|
|
labelText: 'postThumbnailAttachment'.tr,
|
|
|
|
),
|
|
|
|
onTapOutside: (_) => FocusManager.instance.primaryFocus?.unfocus(),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
actions: [
|
|
|
|
TextButton(
|
|
|
|
onPressed: () {
|
2024-08-18 22:51:52 +08:00
|
|
|
widget.controller.thumbnail.value = _attachmentController.text;
|
2024-08-11 01:57:58 +08:00
|
|
|
Navigator.pop(context);
|
|
|
|
},
|
|
|
|
child: Text('confirm'.tr),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|