mirror of
https://github.com/spiral-project/ihatemoney.git
synced 2025-05-14 08:21:49 +02:00
Compare commits
7 commits
0714ebb474
...
bd6d645cee
Author | SHA1 | Date | |
---|---|---|---|
![]() |
bd6d645cee | ||
![]() |
61ea1f54d2 | ||
![]() |
299c384908 | ||
![]() |
4e9ff9b1ac | ||
![]() |
2aa410c68f | ||
![]() |
9b514ca7c7 | ||
![]() |
9433b7de92 |
4 changed files with 54 additions and 17 deletions
|
@ -264,6 +264,12 @@ class Project(db.Model):
|
|||
.order_by(Bill.id.desc())
|
||||
)
|
||||
|
||||
@staticmethod
|
||||
def filter(query, start_date, end_date):
|
||||
return (
|
||||
query.filter(Bill.date >= start_date, Bill.date <= end_date)
|
||||
)
|
||||
|
||||
def get_bill_weights(self):
|
||||
"""
|
||||
Return all bills for this project, along with the sum of weight for each bill.
|
||||
|
@ -285,6 +291,9 @@ class Project(db.Model):
|
|||
"""Ordered version of get_bill_weights"""
|
||||
return self.order_bills(self.get_bill_weights())
|
||||
|
||||
def get_filtered_bill_weights_ordered(self, start_date, end_date):
|
||||
return self.filter(self.get_bill_weights_ordered(), start_date, end_date)
|
||||
|
||||
def get_member_bills(self, member_id):
|
||||
"""Return the list of bills related to a specific member"""
|
||||
return (
|
||||
|
|
|
@ -105,6 +105,16 @@
|
|||
<li class="page-item {% if bills.page == bills.pages %}disabled{% endif %}"><a class="page-link" href="{{ url_for('main.list_bills', page=bills.next_num) }}">{{ _("Older bills") }} »</a></li>
|
||||
</ul>
|
||||
{% endif %}
|
||||
<form action="{{ url_for(".list_bills") }}" method="post">
|
||||
{{ csrf_form.csrf_token }}
|
||||
<label for="start_date">Start Date:</label>
|
||||
<input type="date" id="start_date" name="start_date" value="{{ start_date if start_date else '' }}">
|
||||
|
||||
<label for="end_date">End Date:</label>
|
||||
<input type="date" id="end_date" name="end_date" value="{{ end_date if end_date else '' }}">
|
||||
|
||||
<input type="submit" value="Filter">
|
||||
</form>
|
||||
<span id="new-bill" class="ml-auto pb-2" {% if not g.project.members %} data-toggle="tooltip" title="{{_('You should start by adding participants')}}" {% endif %}>
|
||||
<a href="{{ url_for('.add_bill') }}" class="btn btn-primary {% if not g.project.members %} disabled {% endif %}" data-toggle="modal" data-keyboard="true" data-target="#bill-form" autofocus>
|
||||
<i class="icon icon-white before-text">{{ static_include("images/plus.svg") | safe }}</i>
|
||||
|
|
|
@ -648,7 +648,7 @@ def invite():
|
|||
return render_template("send_invites.html", form=form, qrcode=qrcode_svg)
|
||||
|
||||
|
||||
@main.route("/<project_id>/")
|
||||
@main.route("/<project_id>/", methods=["GET", "POST"])
|
||||
def list_bills():
|
||||
bill_form = get_billform_for(g.project)
|
||||
# Used for CSRF validation
|
||||
|
@ -672,19 +672,37 @@ def list_bills():
|
|||
# Each item will be a (weight_sum, Bill) tuple.
|
||||
# TODO: improve this awkward result using column_property:
|
||||
# https://docs.sqlalchemy.org/en/14/orm/mapped_sql_expr.html.
|
||||
weighted_bills = g.project.get_bill_weights_ordered().paginate(
|
||||
per_page=100, error_out=True
|
||||
)
|
||||
if request.method == "GET":
|
||||
weighted_bills = g.project.get_bill_weights_ordered().paginate(
|
||||
per_page=100, error_out=True
|
||||
)
|
||||
return render_template(
|
||||
"list_bills.html",
|
||||
bills=weighted_bills,
|
||||
member_form=MemberForm(g.project),
|
||||
bill_form=bill_form,
|
||||
csrf_form=csrf_form,
|
||||
add_bill=request.values.get("add_bill", False),
|
||||
current_view="list_bills",
|
||||
)
|
||||
if request.method == "POST":
|
||||
start_date = request.form['start_date']
|
||||
end_date = request.form['end_date']
|
||||
weighted_bills = g.project.get_filtered_bill_weights_ordered(start_date, end_date).paginate(
|
||||
per_page=100, error_out=True
|
||||
)
|
||||
return render_template(
|
||||
"list_bills.html",
|
||||
bills=weighted_bills,
|
||||
member_form=MemberForm(g.project),
|
||||
bill_form=bill_form,
|
||||
csrf_form=csrf_form,
|
||||
add_bill=request.values.get("add_bill", False),
|
||||
current_view="list_bills",
|
||||
start_date=start_date,
|
||||
end_date=end_date,
|
||||
)
|
||||
|
||||
return render_template(
|
||||
"list_bills.html",
|
||||
bills=weighted_bills,
|
||||
member_form=MemberForm(g.project),
|
||||
bill_form=bill_form,
|
||||
csrf_form=csrf_form,
|
||||
add_bill=request.values.get("add_bill", False),
|
||||
current_view="list_bills",
|
||||
)
|
||||
|
||||
|
||||
@main.route("/<project_id>/members/add", methods=["GET", "POST"])
|
||||
|
|
|
@ -27,7 +27,7 @@ classifiers = [
|
|||
|
||||
dependencies = [
|
||||
"blinker>=1.4,<2",
|
||||
"cachetools>=4.1,<5",
|
||||
"cachetools>=4.1,<6",
|
||||
"debts>=0.5,<1",
|
||||
"email_validator>=1.0,<3",
|
||||
"Flask>=2,<4",
|
||||
|
@ -43,7 +43,7 @@ dependencies = [
|
|||
"itsdangerous>=2,<3",
|
||||
"Jinja2>=3,<4",
|
||||
"python-dateutil",
|
||||
"qrcode>=7.1,<8",
|
||||
"qrcode>=7.1,<9",
|
||||
"requests>=2.25,<3",
|
||||
"SQLAlchemy>=1.3.0,<1.5",
|
||||
"SQLAlchemy-Continuum>=1.3.12,<2", # New 1.4 changes API, see #728
|
||||
|
@ -53,11 +53,11 @@ dependencies = [
|
|||
[project.optional-dependencies]
|
||||
database = [
|
||||
# Python 3.11 support starts in 2.9.2
|
||||
"psycopg2-binary>=2.9.2,<2.9.9",
|
||||
"psycopg2-binary>=2.9.2,<2.9.11",
|
||||
"PyMySQL>=0.9,<1.2",
|
||||
]
|
||||
dev = [
|
||||
"ruff==0.6.8",
|
||||
"ruff==0.8.4",
|
||||
"flake8==5.0.4",
|
||||
"isort==5.11.5",
|
||||
"vermin==1.6.0",
|
||||
|
|
Loading…
Reference in a new issue