187 lines
5.4 KiB
Dart
187 lines
5.4 KiB
Dart
import 'dart:ui';
|
|
|
|
import 'package:aitrainer_app/model/cache.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:bloc/bloc.dart';
|
|
import 'package:google_fonts/google_fonts.dart';
|
|
|
|
// ignore: must_be_immutable
|
|
class ImageButton extends StatelessWidget {
|
|
final String text;
|
|
TextStyle? style = TextStyle(fontSize: 14);
|
|
final String? image;
|
|
double? top;
|
|
final double left;
|
|
double? height;
|
|
double? width;
|
|
bool? isShape;
|
|
final Bloc? bloc;
|
|
final Alignment textAlignment;
|
|
final VoidCallback? onTap;
|
|
final bool? isLocked;
|
|
bool? isMarked;
|
|
int? buttonIndex;
|
|
Color? textColor;
|
|
|
|
ImageButton(
|
|
{required this.text,
|
|
this.style,
|
|
required this.image,
|
|
this.top,
|
|
required this.left,
|
|
this.height,
|
|
this.width,
|
|
this.bloc,
|
|
this.isShape,
|
|
required this.textAlignment,
|
|
this.onTap,
|
|
this.buttonIndex,
|
|
this.isMarked,
|
|
required this.isLocked,
|
|
this.textColor}) {
|
|
width = width ?? 180;
|
|
height = height ?? 180;
|
|
isMarked = isMarked ?? false;
|
|
isShape = isShape ?? false;
|
|
textColor = textColor ?? Colors.white;
|
|
style = style ??
|
|
GoogleFonts.archivoBlack(
|
|
fontSize: 14,
|
|
);
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
if (top == null) {
|
|
top = height! - (style!.fontSize! - 5) * text.length - 2 * left < 0
|
|
? height! - 2 * style!.fontSize! - 22
|
|
: height! - style!.fontSize! - 37;
|
|
}
|
|
final double width = MediaQuery.of(context).size.width;
|
|
|
|
return Stack(alignment: AlignmentDirectional.bottomStart, children: [
|
|
TextButton(
|
|
style: TextButton.styleFrom(
|
|
padding: EdgeInsets.only(left: 0.0, bottom: 0),
|
|
shape: getShape(isShape!),
|
|
),
|
|
child: image == null
|
|
? _getButtonImage("asset/image/WT_menu_dark.jpg")
|
|
: isMarked!
|
|
? Stack(
|
|
children: [
|
|
_getButtonImage(image!),
|
|
Container(
|
|
width: width,
|
|
height: height,
|
|
child: BackdropFilter(
|
|
filter: ImageFilter.blur(sigmaX: 1, sigmaY: 1),
|
|
child: Container(
|
|
color: Colors.black.withOpacity(0.3),
|
|
),
|
|
),
|
|
)
|
|
],
|
|
)
|
|
: _getButtonImage(image!),
|
|
onPressed: onTap ?? onTap,
|
|
),
|
|
Container(
|
|
padding: EdgeInsets.all(4),
|
|
child: InkWell(
|
|
onTap: onTap ?? onTap,
|
|
child: Text(text,
|
|
maxLines: 2,
|
|
style: GoogleFonts.archivoBlack(
|
|
fontSize: 15,
|
|
color: textColor,
|
|
shadows: <Shadow>[
|
|
Shadow(
|
|
offset: Offset(2.0, 2.0),
|
|
blurRadius: 6.0,
|
|
color: Colors.black54,
|
|
),
|
|
Shadow(
|
|
offset: Offset(-3.0, 3.0),
|
|
blurRadius: 12.0,
|
|
color: Colors.black54,
|
|
),
|
|
],
|
|
)),
|
|
)),
|
|
isMarked == null || Cache().hasPurchased
|
|
? Offstage()
|
|
: Stack(alignment: Alignment.center, children: [
|
|
Positioned(
|
|
top: 10,
|
|
left: (width / 2 - 30) / 2 - 25,
|
|
child: !isLocked!
|
|
? Offstage()
|
|
: GestureDetector(
|
|
child: Image.asset(
|
|
'asset/image/lock.png',
|
|
height: 50,
|
|
width: 50,
|
|
),
|
|
onTap: onTap ?? onTap,
|
|
))
|
|
]),
|
|
isLocked == null
|
|
? Offstage()
|
|
: Stack(alignment: Alignment.topCenter, children: [
|
|
Positioned(
|
|
top: 10,
|
|
left: (width / 2 - 30) / 2 - 75,
|
|
child: isMarked!
|
|
? GestureDetector(
|
|
child: Image.asset(
|
|
'asset/image/haken.png',
|
|
height: 70,
|
|
width: 70,
|
|
),
|
|
onTap: onTap ?? onTap,
|
|
)
|
|
: Offstage(),
|
|
)
|
|
]),
|
|
]
|
|
//)
|
|
// )
|
|
);
|
|
}
|
|
|
|
dynamic getShape(bool isShape) {
|
|
dynamic returnCode = (isShape == true)
|
|
? RoundedRectangleBorder(
|
|
side: BorderSide(width: 4, color: Colors.orangeAccent),
|
|
)
|
|
: null;
|
|
return returnCode;
|
|
}
|
|
|
|
dynamic _getButtonImage(String imageName) {
|
|
dynamic image;
|
|
try {
|
|
image = Image.asset(
|
|
imageName,
|
|
fit: BoxFit.fitWidth,
|
|
alignment: Alignment.center,
|
|
/* errorBuilder: (context, error, stackTrace) {
|
|
String url = Cache.mediaUrl + imageName; //.substring(11);
|
|
Widget image = FadeInImage.assetNetwork(placeholder: 'asset/image/dots.gif', image: url, height: this.height);
|
|
return image;
|
|
}, */
|
|
);
|
|
} on Exception catch (_) {
|
|
String url = Cache.mediaUrl + '/images/' + imageName;
|
|
image = FadeInImage.assetNetwork(
|
|
placeholder: 'asset/image/dots.gif',
|
|
image: url,
|
|
height: 50,
|
|
);
|
|
}
|
|
|
|
return image;
|
|
}
|
|
}
|