nopaque/app/contributions/forms.py

76 lines
1.9 KiB
Python
Raw Normal View History

from flask_wtf import FlaskForm
from wtforms import (
BooleanField,
PasswordField,
StringField,
SubmitField,
SelectMultipleField,
ValidationError, FieldList, IntegerField
)
from wtforms.validators import InputRequired, Email, EqualTo, Length, Regexp
from app.models import User
class ContributionForm(FlaskForm):
# The id field will be generated on insert.
# The user_id will be retrieved from the user who is performing this operation.
# title = db.Column(db.String(64))
title = StringField(
'Title',
validators=[InputRequired(), Length(max=64)]
)
# description = db.Column(db.String(255))
description = StringField(
'Description',
validators=[InputRequired(), Length(max=255)]
)
# version = db.Column(db.String(16))
version = StringField(
'Version',
validators=[InputRequired(), Length(max=16)]
)
# compatible_service_versions = db.Column(ContainerColumn(list, 255))
compatible_service_versions = SelectMultipleField(
'Compatible Service Versions',
choices=["asd", "blub", "bla"]
)
# publisher = db.Column(db.String(128))
publisher = StringField(
'Publisher',
validators=[InputRequired(), Length(max=128)]
)
# publisher_url = db.Column(db.String(512))
publisher_url = StringField(
'Publisher URL',
validators=[InputRequired(), Length(max=512)]
)
# publishing_url = db.Column(db.String(512))
publishing_url = StringField(
'Publishing URL',
validators=[InputRequired(), Length(max=512)]
)
# publishing_year = db.Column(db.Integer)
publishing_year = IntegerField(
'Publishing year',
validators=[InputRequired()]
)
# shared = db.Column(db.Boolean, default=False)
shared = BooleanField(
'Shared',
validators=[InputRequired()]
)
submit = SubmitField()