library universal_ui; import 'package:flutter/cupertino.dart'; import 'package:flutter/foundation.dart'; import 'package:flutter_quill/flutter_quill.dart'; import 'package:universal_html/html.dart' as html; import '../widgets/responsive_widget.dart'; import 'fake_ui.dart' if (dart.library.html) 'real_ui.dart' as ui_instance; class PlatformViewRegistryFix { void registerViewFactory(dynamic x, dynamic y) { if (kIsWeb) { ui_instance.PlatformViewRegistry.registerViewFactory( x, y, ); } } } class UniversalUI { PlatformViewRegistryFix platformViewRegistry = PlatformViewRegistryFix(); } var ui = UniversalUI(); Widget defaultEmbedBuilderWeb(BuildContext context, Embed node, bool readOnly) { switch (node.value.type) { case 'image': final imageUrl = node.value.data; final size = MediaQuery.of(context).size; UniversalUI().platformViewRegistry.registerViewFactory( imageUrl, (viewId) => html.ImageElement()..src = imageUrl); return Padding( padding: EdgeInsets.only( right: ResponsiveWidget.isMediumScreen(context) ? size.width * 0.5 : (ResponsiveWidget.isLargeScreen(context)) ? size.width * 0.75 : size.width * 0.2, ), child: SizedBox( height: MediaQuery.of(context).size.height * 0.45, child: HtmlElementView( viewType: imageUrl, ), ), ); default: throw UnimplementedError( 'Embeddable type "${node.value.type}" is not supported by default ' 'embed builder of QuillEditor. You must pass your own builder function ' 'to embedBuilder property of QuillEditor or QuillField widgets.', ); } }