2023-04-24 09:57:38 +03:00
|
|
|
from flask_wtf import FlaskForm
|
2023-05-02 09:48:10 +03:00
|
|
|
from wtforms import StringField, SubmitField, ValidationError
|
2023-04-24 09:57:38 +03:00
|
|
|
from wtforms.validators import DataRequired, Length
|
2023-05-02 09:48:10 +03:00
|
|
|
|
2023-05-11 14:28:45 +03:00
|
|
|
from app import models as m
|
2023-05-02 09:48:10 +03:00
|
|
|
from app.logger import log
|
2023-04-24 09:57:38 +03:00
|
|
|
|
|
|
|
|
2023-05-01 18:17:46 +03:00
|
|
|
class BaseBookForm(FlaskForm):
|
2023-04-27 16:17:25 +03:00
|
|
|
label = StringField("Label", [DataRequired(), Length(6, 256)])
|
2023-05-11 12:10:51 +03:00
|
|
|
about = StringField("About")
|
2023-05-16 13:27:19 +03:00
|
|
|
tags = StringField("Tags")
|
2023-05-01 18:17:46 +03:00
|
|
|
|
|
|
|
|
|
|
|
class CreateBookForm(BaseBookForm):
|
2023-04-24 09:57:38 +03:00
|
|
|
submit = SubmitField("Add new book")
|
2023-05-01 18:17:46 +03:00
|
|
|
|
|
|
|
|
|
|
|
class EditBookForm(BaseBookForm):
|
2023-05-02 09:48:10 +03:00
|
|
|
book_id = StringField("User ID", [DataRequired()])
|
2023-05-01 18:17:46 +03:00
|
|
|
submit = SubmitField("Edit book")
|
2023-05-02 09:48:10 +03:00
|
|
|
|
|
|
|
def validate_label(self, field):
|
|
|
|
label = field.data
|
|
|
|
book_id = self.book_id.data
|
|
|
|
|
2023-05-11 12:10:51 +03:00
|
|
|
existing_book: m.Book = (
|
|
|
|
m.Book.query.filter_by(
|
|
|
|
is_deleted=False,
|
|
|
|
label=label,
|
|
|
|
)
|
|
|
|
.filter(m.Book.id != book_id)
|
|
|
|
.first()
|
|
|
|
)
|
2023-05-02 09:48:10 +03:00
|
|
|
if existing_book:
|
|
|
|
log(
|
|
|
|
log.WARNING, "Book with label [%s] already exists: [%s]", label, book_id
|
|
|
|
)
|
|
|
|
raise ValidationError("Book label must be unique!")
|