uninav/lib/components/colorful_chips.dart
2024-04-21 02:22:53 +02:00

58 lines
1.5 KiB
Dart

import 'package:flutter/material.dart';
class ColorfulChip extends StatelessWidget {
final String label;
const ColorfulChip({Key? key, required this.label}) : super(key: key);
@override
Widget build(BuildContext context) {
final color = Color(((label.hashCode) & 0xFFFFFF) | 0xFF000000);
return Chip(
label: Text(label),
backgroundColor: color,
labelStyle: TextStyle(
color: color.computeLuminance() > 0.5 ? Colors.black : Colors.white,
),
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(8),
side: BorderSide.none,
),
);
}
}
class ColorfulActionChip extends StatelessWidget {
final String label;
final VoidCallback onPressed;
final double? size;
const ColorfulActionChip({
Key? key,
required this.label,
required this.onPressed,
this.size,
}) : super(key: key);
@override
Widget build(BuildContext context) {
final color = Color(
((label.hashCode - 5 /* randomness - */) & 0xFFFFFF) | 0xFF000000);
return ActionChip(
label: Text(label),
backgroundColor: color,
labelStyle: TextStyle(
color: color.computeLuminance() > 0.5 ? Colors.black : Colors.white,
fontSize: size,
),
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(8),
side: BorderSide.none,
),
onPressed: onPressed,
padding: EdgeInsets.symmetric(
horizontal: (size ?? 16) / 2, vertical: (size ?? 8.0) / 2),
);
}
}