import 'dart:convert'; import 'package:flutter/services.dart' show rootBundle; import 'package:intl/intl.dart'; import 'package:pizzaplanner/entities/PizzaRecipe/PizzaRecipe.dart'; Future> getRecipes() async { final manifestContent = await rootBundle.loadString('AssetManifest.json'); final Map manifestMap = json.decode(manifestContent); final List fileList = manifestMap.keys.toList(); final List pizzaRecipes = []; for (var filePath in fileList) { if (filePath.startsWith("assets/recipes") && filePath.endsWith(".yaml")) { PizzaRecipe pizzaRecipe = await PizzaRecipe.fromYaml(filePath); pizzaRecipes.add(pizzaRecipe); } } return pizzaRecipes; } Future loadAsset(String path) async { return await rootBundle.loadString(path); } extension StringExtensions on String { String capitalize() { return this[0].toUpperCase() + this.substring(1); } } DateFormat getDateFormat(){ return DateFormat("yyyy-MM-dd H:mm"); } String getTimeRemainingString(DateTime other, {DateTime? now}){ now = now ?? DateTime.now(); Duration duration = other.difference(now); Duration absDuration = duration.abs(); String durationString = ""; if (absDuration.inHours <= 0 && absDuration.inMinutes > 0) { durationString = "${absDuration.inMinutes} minute" + (absDuration.inMinutes > 1 ? "s" : ""); } else if (absDuration.inDays <= 0 && absDuration.inHours > 0) { durationString = "${absDuration.inHours} hours"; } else if (absDuration.inDays <= 31) { durationString = "${absDuration.inDays} day" + (absDuration.inDays > 1 ? "s" : ""); } else { durationString = "${(absDuration.inDays / 7).floor()} week" + (absDuration.inDays >= 14 ? "s" : ""); } return duration.isNegative ? "$durationString ago" : "In $durationString"; }