WTForm - QuerySelectField не принимает заданное значение / значение по умолчанию из базы данных. Настой - WTForms - Sqlalchemy - PullRequest
1 голос
/ 25 октября 2019

Я использую wtform как для добавления, так и для редактирования объекта, и я использую поле queryselect для внешних ключей. Поле queryselect всегда принимает первое значение в строке. Насколько я понимаю, правильное значение фактически передается правильно, просто по какой-то причине оно не принимается.

Модель, например:

class State(db.Model):
    __tablename__ = 'state'
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    country_id = db.Column(db.Integer, db.ForeignKey('country.id'))
    name = db.Column(db.String(150))
    factor = db.Column(db.Float)
    time_created = db.Column(DateTime(timezone=True),
                             server_default=func.now())
    time_updated = db.Column(DateTime(timezone=True), onupdate=func.now())

    def __init__(self, country_id, name, factor):
        self.country_id = country_id
        self.name = name
        self.factor = factor

    def __repr__(self):
        return '{} - {}'.format(self.country_id, self.name)

Модель Страна

class Country(db.Model):
    __tablename__ = 'country'
    id = db.Column(db.Integer, primary_key=True, autoincrement=True)
    name = db.Column(db.String(150))
    shortcut = db.Column(db.String(3))
    states = db.relationship('State', backref='country', lazy=True)
    time_created = db.Column(DateTime(timezone=True),
                             server_default=func.now())
    time_updated = db.Column(DateTime(timezone=True), onupdate=func.now())

    def __init__(self, name, shortcut):
        self.name = name
        self.shortcut = shortcut

    def __repr__(self):
        return '{} - {} - {}'.format(self.id, self.name, self.shortcut)

Вид:

@admin_blueprint.route('/admin/state/edit/<int:state_id>',
                       methods=['GET', 'POST'])
@login_required
def edit_state(state_id):
    """Edit state"""
    obj = State.query.filter_by(id=state_id).first_or_404()
    form = StateForm(obj=obj)
    if request.method == 'POST' and form.validate_on_submit:
        obj.country_id = form.country_id.data.id
        obj.name = form.name.data
        obj.factor = form.factor.data
        db.session.commit()
        log_entry_edit(State, obj)
        return redirect(url_for('admin.list_states'))
    return render_template('admin/state_form.html', form=form,
                           title='Edit State')

Форма:

def countries():
    return Country.query

class StateForm(FlaskForm):
    name = StringField('State Name')
    factor = FloatField('Factor')
    country_id = QuerySelectField('Country', query_factory=countries)
    submit = SubmitField('Save')

Шаблон:

    <div>
         {{ form.country_id.label }} 
         {{ form.country_id(class="form-control form-group") }}
         <output style="color: red;"  for="country_id" id="selected-country_id">
              ACTUAL ID: {{ form.country_id.data }}
         </output>
    </div>
    {% if form.country_id.errors %}
        <ul class="errors">
            {% for error in country_id.errors %}
                <li>{{ error }}</li>
            {% endfor %}
        </ul>
    {% endif %}

Как вы можете видеть на следующем рисунке, форма принимает первое значение, и она также перезапишет БД, если я не выберу снова значение, которое я хотел впервое место. Фактическое правильное значение прибывает в форму, хотя (идентификатор красного цвета):

снимок экрана вывода шаблона

Я только начал работать с колбой, wtforms и т. Д., И я честноне вижу, что я делаю не так. У кого-нибудь есть подсказка?

...