예제 #1
0
        public async Task Update(AreaDto entity)
        {
            if (entity == null)
            {
                throw new ArgumentNullException();
            }

            if (entity.LayoutId <= 0)
            {
                throw new AreaException("LayoutId is invalid");
            }

            if (!IsDescriptionUnique(entity, false))
            {
                throw new AreaException("Area description isn't unique");
            }

            if (entity.SeatList == null || !entity.SeatList.Any())
            {
                throw new AreaException("Incorrect state of area. An area must have atleast one seat");
            }

            using (var transaction = CustomTransactionScope.GetTransactionScope())
            {
                var delete = await _context.AreaRepository.GetAsync(entity.Id);

                _context.AreaRepository.Delete(delete);
                var createNew = AreaParser.MapToArea(entity);
                _context.AreaRepository.Create(createNew);
                await _context.SaveAsync();

                foreach (var seat in entity.SeatList)
                {
                    seat.AreaId = createNew.Id;

                    if (!IsSeatUnique(seat, false))
                    {
                        throw new SeatException("Seat already exists");
                    }

                    var seatAdd = SeatParser.MapToSeat(seat);
                    _context.SeatRepository.Create(seatAdd);
                }
                await _context.SaveAsync();

                transaction.Complete();
            }
        }
예제 #2
0
        public Task <VenueDto> GetFullModel(int id)
        {
            var data = (from venues in _context.VenueRepository.GetList()
                        join layotus in _context.LayoutRepository.GetList() on venues.Id equals layotus.VenueId
                        join areas in _context.AreaRepository.GetList() on layotus.Id equals areas.LayoutId
                        join seats in _context.SeatRepository.GetList() on areas.Id equals seats.AreaId
                        where venues.Id == id
                        select new { Venue = venues, Layout = layotus, Area = areas, Seat = seats }).ToList();

            if (!data.Any())
            {
                return(null);
            }

            var venue  = data.FirstOrDefault().Venue;
            var result = VenueParser.MapToVenueDto(venue);

            foreach (var row in data)
            {
                var layout = result.LayoutList.SingleOrDefault(x => x.Id == row.Layout.Id);
                //add layout if it isn't exist in a result
                if (layout is null)
                {
                    layout = LayoutParser.MapToLayoutDto(row.Layout);
                    result.LayoutList.Add(layout);
                }

                var area = layout.AreaList.SingleOrDefault(x => x.Id == row.Area.Id);
                //add area if it isn't exist in a result
                if (area is null)
                {
                    area = AreaParser.MapToAreaDto(row.Area);
                    layout.AreaList.Add(area);
                }

                area.SeatList.Add(SeatParser.MapToSeatDto(row.Seat));
            }

            return(Task.FromResult(result));
        }
예제 #3
0
        public async Task <IEnumerable <AreaDto> > GetList()
        {
            var temp = await _context.AreaRepository.GetListAsync();

            return(temp.Select(x => AreaParser.MapToAreaDto(x)));
        }
예제 #4
0
        public async Task <AreaDto> Get(int id)
        {
            var area = await _context.AreaRepository.GetAsync(id);

            return(area == null? null: AreaParser.MapToAreaDto(area));
        }