Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Solution #1734

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 4 additions & 5 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,13 +15,12 @@ package create modules:
that takes `product` - name of the product that customer wants
and `customer` - `Customer` instance, that means customer.
The `sell_product` method sells a product to the customer and displays which product was sold and to whom.



```python
cb = CinemaBar()
customer = Customer("Bob", "popcorn")
cb.sell_product(customer=customer, product=customer.food)
# Cinema bar sold popcorn to Bob.
customer = Customer("Bob", "popcorn")
cb.sell_product(cur_customer=, food=)
# Cinema bar sold popcorn to Bob.
```

- `hall.py` - inside this module create `CinemaHall`
Expand Down
Empty file added app/cinema/__init__.py
Empty file.
7 changes: 7 additions & 0 deletions app/cinema/bar.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
from app.people.customer import Customer


class CinemaBar:
@staticmethod
def sell_product(customer: Customer, product: str) -> None:
print(f"Cinema bar sold {product} to {customer.name}.")
17 changes: 17 additions & 0 deletions app/cinema/hall.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
from app.people.cinema_staff import Cleaner


class CinemaHall:
def __init__(self, number: int) -> None:
self.number = number

def movie_session(self,
movie_name: str,
customers: list,
cleaning_staff: Cleaner) -> None:

print(f'"{movie_name}" started in hall number {self.number}.')
for new_customer in customers:
new_customer.watch_movie(movie_name)
print(f'"{movie_name}" ended.')
cleaning_staff.clean_hall(self.number)
22 changes: 19 additions & 3 deletions app/main.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,22 @@
from app.cinema.hall import CinemaHall
from app.cinema.bar import CinemaBar
from app.people.customer import Customer
from app.people.cinema_staff import Cleaner
# write your imports here


def cinema_visit(customers: list, hall_number: int, cleaner: str, movie: str):
# write you code here
pass
def cinema_visit(customers: list,
hall_number: int,
cleaner: str,
movie: str) -> None:
customer_list = [Customer(new_customer.get("name"),
new_customer.get("food"))
for new_customer in customers]

for new_customer in customer_list:
product = new_customer.food
CinemaBar.sell_product(new_customer, product)

cinema_hall = CinemaHall(hall_number)
cleaner_work = Cleaner(cleaner)
cinema_hall.movie_session(movie, customer_list, cleaner_work)
Empty file added app/people/__init__.py
Empty file.
6 changes: 6 additions & 0 deletions app/people/cinema_staff.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
class Cleaner:
def __init__(self, name: str) -> None:
self.name = name

def clean_hall(self, hall_number: int) -> None:
print(f"Cleaner {self.name} is cleaning hall number {hall_number}.")
7 changes: 7 additions & 0 deletions app/people/customer.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
class Customer:
def __init__(self, name: str, food: str) -> None:
self.name = name
self.food = food

def watch_movie(self, movie: str) -> None:
print(f'{self.name} is watching "{movie}".')