Exemple #1
0
        public static async Task UpdateTripAsync(Trip trip)
        {
            var travelContext = new TravelContext();

            travelContext.Update(trip);
            await travelContext.SaveChangesAsync();
        }
Exemple #2
0
        public static async Task DeleteItemAsync(Item item)
        {
            var travelContext = new TravelContext();

            travelContext.ChecklistItems.Remove(item);
            await travelContext.SaveChangesAsync();
        }
Exemple #3
0
        public static async Task UpdateItemAsync(Item item)
        {
            var travelContext = new TravelContext();

            travelContext.Update(item);
            await travelContext.SaveChangesAsync();
        }
Exemple #4
0
        public static async Task AddItemAsync(string categoryId, Item item)
        {
            var travelContext  = new TravelContext();
            var targetCategory = await travelContext.Checklists.FindAsync(categoryId);

            targetCategory.Items.Add(item);
            travelContext.Update(targetCategory);
            await travelContext.SaveChangesAsync();
        }
Exemple #5
0
        public static async Task DeleteChecklistAsync(string id)
        {
            var travelContext = new TravelContext();
            var toDelete      = travelContext.Checklists
                                .Where(c => c.Id.Equals(id))
                                .Include(i => i.Items)
                                .SingleOrDefault();

            travelContext.Checklists.Remove(toDelete);
            await travelContext.SaveChangesAsync();
        }
Exemple #6
0
        public static async Task <IEnumerable <Trip> > GetTripsAsync()
        {
            var travelContext = new TravelContext();
            var storedTrips   = travelContext.Trips
                                .Include(t => t.Categories)
                                .ThenInclude(c => c.Items)
                                .AsNoTracking()
                                .ToList();

            return(await Task.FromResult(storedTrips));
        }
Exemple #7
0
        public static async Task <IEnumerable <ItemCategory> > GetItemCategoriesAsync(string id)
        {
            var travelContext    = new TravelContext();
            var storedChecklists = travelContext.Trips
                                   .AsNoTracking()
                                   .Where(x => x.Id.Equals(id))
                                   .Include(y => y.Categories)
                                   .ThenInclude(z => z.Items)
                                   .Select(c => c.Categories).SingleOrDefault();

            return(await Task.FromResult(storedChecklists));
        }
Exemple #8
0
        public static async Task DeleteTripAsync(string id)
        {
            var travelContext = new TravelContext();
            var toDelete      = travelContext.Trips
                                .Where(x => x.Id.Equals(id))
                                .Include(y => y.Categories)
                                .ThenInclude(z => z.Items)
                                .SingleOrDefault();

            travelContext.Trips.RemoveRange(toDelete);
            await travelContext.SaveChangesAsync();
        }
Exemple #9
0
        public static async Task UpdateTripChecklistsAsync(Trip trip)
        {
            var travelContext = new TravelContext();
            var targetTrip    = await travelContext.Trips.FindAsync(trip.Id);

            var targetCategories = await GetItemCategoriesAsync(trip.Id);

            foreach (var category in trip.Categories)
            {
                if (!targetCategories.Any(x => x.Name.Equals(category.Name)))
                {
                    targetTrip.Categories.Add(category);
                }
            }
            travelContext.Update(targetTrip);
            await travelContext.SaveChangesAsync();
        }
Exemple #10
0
 public static async Task AddTripAsync(Trip trip)
 {
     await using var tripContext = new TravelContext();
     tripContext.Add(trip);
     await tripContext.SaveChangesAsync();
 }