Этот репозиторий содержит Flutter плагины для платформы ОС Аврора.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

127 lines
4.0 KiB

/*
* Copyright (C) 2023 Open Mobile Platform LLC.
* Contact: https://community.omprussia.ru/open-source
*
* This file is part of the Aurora OS Application Template project.
*
* Redistribution and use in source and binary forms,
* with or without modification, are permitted provided
* that the following conditions are met:
*
* * Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer
* in the documentation and/or other materials provided with the distribution.
* * Neither the name of the copyright holder nor the names of its contributors
* may be used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
* IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
* OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS;
* OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
* EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
import 'package:flutter/material.dart';
import 'package:flutter_example_packages/widgets/base/export.dart';
import 'package:flutter_example_packages/widgets/texts/export.dart';
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
/// Block list item
class BlockItem<T> extends AppStatelessWidget {
const BlockItem({
super.key,
this.title,
this.desc,
this.value,
this.future,
this.stream,
this.builder,
});
final String? title;
final String? desc;
final T? value;
final Stream<T>? stream;
final Future<T>? future;
final Function(T)? builder;
AsyncWidgetBuilder<T?> get widgetBuilder =>
(BuildContext context, AsyncSnapshot<T?> snapshot) {
return Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Visibility(
visible: title != null,
child: Column(
children: [
TextTitleLarge(title ?? ''),
const SizedBox(height: 8),
],
),
),
Visibility(
visible: desc != null,
child: Column(
children: [
TextBodyMedium(desc ?? ''),
const SizedBox(height: 8),
],
),
),
if (snapshot.hasData)
TextBodyMedium(
builder == null
? snapshot.data.toString()
: builder?.call(snapshot.data as T),
fontWeight: FontWeight.bold,
),
if (!snapshot.hasData)
const SizedBox(
width: 16,
height: 16,
child: CircularProgressIndicator(
color: Colors.blueAccent,
strokeWidth: 2,
),
),
const SizedBox(height: 20),
],
);
};
@override
Widget buildWide(
BuildContext context,
MediaQueryData media,
AppLocalizations l10n,
) {
if (stream != null) {
return StreamBuilder(
stream: stream,
builder: widgetBuilder,
);
}
if (future != null) {
return FutureBuilder(
future: future,
builder: widgetBuilder,
);
}
return FutureBuilder(
future: Future.value(value),
builder: widgetBuilder,
);
}
}