def ajax_delete(): """ 银行删除 :return: """ ajax_success_msg = AJAX_SUCCESS_MSG.copy() ajax_failure_msg = AJAX_FAILURE_MSG.copy() # 检查删除权限 if not permission_account_section_del.can(): ext_msg = _('Permission Denied') ajax_failure_msg['msg'] = _('Del Failure, %(ext_msg)s', ext_msg=ext_msg) return jsonify(ajax_failure_msg) # 检查请求方法 if not (request.method == 'GET' and request.is_xhr): ext_msg = _('Method Not Allowed') ajax_failure_msg['msg'] = _('Del Failure, %(ext_msg)s', ext_msg=ext_msg) return jsonify(ajax_failure_msg) # 检查请求参数 bank_id = request.args.get('bank_id', 0, type=int) if not bank_id: ext_msg = _('ID does not exist') ajax_failure_msg['msg'] = _('Del Failure, %(ext_msg)s', ext_msg=ext_msg) return jsonify(ajax_failure_msg) bank_info = get_bank_row_by_id(bank_id) # 检查资源是否存在 if not bank_info: ext_msg = _('ID does not exist') ajax_failure_msg['msg'] = _('Del Failure, %(ext_msg)s', ext_msg=ext_msg) return jsonify(ajax_failure_msg) # 检查资源是否删除 if bank_info.status_delete == STATUS_DEL_OK: ext_msg = _('Already deleted') ajax_failure_msg['msg'] = _('Del Failure, %(ext_msg)s', ext_msg=ext_msg) return jsonify(ajax_failure_msg) # 检查是否正在使用 # 银行流水 TODO # if count_inventory(**{'bank_id': bank_id, 'status_delete': STATUS_DEL_NO}): # ext_msg = _('Currently In Use') # ajax_failure_msg['msg'] = _('Del Failure, %(ext_msg)s', ext_msg=ext_msg) # return jsonify(ajax_failure_msg) current_time = datetime.utcnow() bank_data = { 'status_delete': STATUS_DEL_OK, 'delete_time': current_time, 'update_time': current_time, } result = edit_bank(bank_id, bank_data) if result: ajax_success_msg['msg'] = _('Del Success') return jsonify(ajax_success_msg) else: ajax_failure_msg['msg'] = _('Del Failure') return jsonify(ajax_failure_msg)
def lists(): """ 银行列表 :return: """ template_name = 'bank/lists.html' # 文档信息 document_info = DOCUMENT_INFO.copy() document_info['TITLE'] = _('bank lists') # 搜索条件 form = BankSearchForm(request.form) form.id.choices = get_bank_choices() # app.logger.info('') search_condition = [ Bank.status_delete == STATUS_DEL_NO, ] if request.method == 'POST': # 表单校验失败 if not form.validate_on_submit(): flash(_('Search Failure'), 'danger') # 单独处理csrf_token if hasattr(form, 'csrf_token') and getattr(form, 'csrf_token').errors: map(lambda x: flash(x, 'danger'), form.csrf_token.errors) else: if form.id.data != DEFAULT_SEARCH_CHOICES_INT_OPTION: search_condition.append(Bank.id == form.id.data) if form.type_bank.data != DEFAULT_SEARCH_CHOICES_INT_OPTION: search_condition.append(Bank.type_bank == form.type_bank.data) # 处理导出 if form.op.data == 1: # 检查导出权限 if not permission_account_section_export.can(): abort(403) column_names = Bank.__table__.columns.keys() query_sets = get_bank_rows(*search_condition) return excel.make_response_from_query_sets( query_sets=query_sets, column_names=column_names, file_type='csv', file_name='%s.csv' % _('bank lists')) # 批量删除 if form.op.data == 2: bank_ids = request.form.getlist('bank_id') # 检查删除权限 if not (permission_role_administrator.can() or permission_role_stock_keeper.can()): ext_msg = _('Permission Denied') flash(_('Del Failure, %(ext_msg)s', ext_msg=ext_msg), 'danger') else: permitted = True for bank_id in bank_ids: # 检查是否正在使用 # 库存、货架 if count_inventory(**{ 'bank_id': bank_id, 'status_delete': STATUS_DEL_NO }): ext_msg = _('Currently In Use') flash(_('Del Failure, %(ext_msg)s', ext_msg=ext_msg), 'danger') permitted = False break if count_rack(**{ 'bank_id': bank_id, 'status_delete': STATUS_DEL_NO }): ext_msg = _('Currently In Use') flash(_('Del Failure, %(ext_msg)s', ext_msg=ext_msg), 'danger') permitted = False break if permitted: result_total = True for bank_id in bank_ids: current_time = datetime.utcnow() bank_data = { 'status_delete': STATUS_DEL_OK, 'delete_time': current_time, 'update_time': current_time, } result = edit_bank(bank_id, bank_data) result_total = result_total and result if result_total: flash(_('Del Success'), 'success') else: flash(_('Del Failure'), 'danger') # 翻页数据 pagination = get_bank_pagination(form.page.data, PER_PAGE_BACKEND, *search_condition) # 渲染模板 return render_template(template_name, form=form, pagination=pagination, **document_info)
def edit(bank_id): """ 银行编辑 """ bank_info = get_bank_row_by_id(bank_id) # 检查资源是否存在 if not bank_info: abort(404) # 检查资源是否删除 if bank_info.status_delete == STATUS_DEL_OK: abort(410) template_name = 'bank/edit.html' # 加载编辑表单 form = BankEditForm(request.form) # 文档信息 document_info = DOCUMENT_INFO.copy() document_info['TITLE'] = _('bank edit') # 进入编辑页面 if request.method == 'GET': # 表单赋值 form.bank_name.data = bank_info.bank_name form.type_bank.data = bank_info.type_bank form.initial_balance.data = bank_info.initial_balance form.closing_balance.data = bank_info.closing_balance form.note.data = bank_info.note # form.create_time.data = bank_info.create_time # form.update_time.data = bank_info.update_time # 渲染页面 return render_template(template_name, bank_id=bank_id, form=form, **document_info) # 处理编辑请求 if request.method == 'POST': # 表单校验失败 if not form.validate_on_submit(): flash(_('Edit Failure'), 'danger') return render_template(template_name, bank_id=bank_id, form=form, **document_info) # 表单校验成功 current_time = datetime.utcnow() bank_data = { 'bank_name': form.bank_name.data, 'type_bank': form.type_bank.data, 'initial_balance': form.initial_balance.data, 'closing_balance': form.closing_balance.data, 'note': form.note.data, 'update_time': current_time, } result = edit_bank(bank_id, bank_data) # 编辑操作成功 if result: flash(_('Edit Success'), 'success') return redirect(request.args.get('next') or url_for('bank.lists')) # 编辑操作失败 else: flash(_('Edit Failure'), 'danger') return render_template(template_name, bank_id=bank_id, form=form, **document_info)