dictdata.py 3.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. from datetime import datetime
  2. from flask_login import current_user
  3. from ..base import base
  4. from ..models import DictData, DictType
  5. from flask import render_template, request, jsonify
  6. from sqlalchemy import asc
  7. from sqlalchemy import desc
  8. from .. import db
  9. @base.route('/system/dict/data/type/<dictType>', methods=['GET'])
  10. def sysdictdata_get_by_type(dictType):
  11. data_list = DictData.query.filter(DictData.dict_type == dictType)
  12. return jsonify({'msg': '操作成功', 'code': 200, 'data': [data.to_json() for data in data_list]})
  13. @base.route('/system/dict/data/list', methods=['GET'])
  14. def sysdict_data_list():
  15. filters = []
  16. if 'dictLabel' in request.args:
  17. filters.append(DictData.dict_label.like('%' + request.args['dictLabel'] + '%'))
  18. if 'dictType' in request.args:
  19. filters.append(DictData.dict_type.like('%' + request.args['dictType'] + '%'))
  20. if 'status' in request.args:
  21. filters.append(DictData.status == request.args['status'])
  22. page = request.args.get('pageNum', 1, type=int)
  23. rows = request.args.get('pageSize', 10, type=int)
  24. pagination = DictData.query.filter(*filters).paginate(
  25. page, per_page=rows, error_out=False)
  26. data_list = pagination.items
  27. return jsonify({'msg': '操作成功', 'code': 200, 'rows': [data.to_json() for data in data_list], 'total': pagination.total})
  28. @base.route('/system/dict/data/<id>', methods=['GET'])
  29. def sysdict_data_get_by_id(id):
  30. data = DictData.query.get(id)
  31. return jsonify({'msg': '操作成功', 'code': 200, 'data': data.to_json()})
  32. @base.route('/system/dict/data', methods=['POST'])
  33. def sysdict_data_add():
  34. dictData = DictData()
  35. if 'dictLabel' in request.json: dictData.dict_label = request.json['dictLabel']
  36. if 'dictSort' in request.json: dictData.dict_sort = request.json['dictSort']
  37. if 'dictType' in request.json: dictData.dict_type = request.json['dictType']
  38. if 'dictValue' in request.json: dictData.dict_value = request.json['dictValue']
  39. if 'listClass' in request.json: dictData.list_class = request.json['listClass']
  40. if 'status' in request.json: dictData.status = request.json['status']
  41. dictData.create_time = datetime.now()
  42. dictData.create_by = current_user.NAME
  43. db.session.add(dictData)
  44. return jsonify({'code': 200, 'msg': '操作成功'})
  45. @base.route('/system/dict/data', methods=['PUT'])
  46. def sysdict_data_update():
  47. dictData = DictData.query.get(request.json['dictCode'])
  48. if 'dictLabel' in request.json: dictData.dict_label = request.json['dictLabel']
  49. if 'dictSort' in request.json: dictData.dict_sort = request.json['dictSort']
  50. if 'dictType' in request.json: dictData.dict_type = request.json['dictType']
  51. if 'dictValue' in request.json: dictData.dict_value = request.json['dictValue']
  52. if 'listClass' in request.json: dictData.list_class = request.json['listClass']
  53. if 'status' in request.json: dictData.status = request.json['status']
  54. if 'remark' in request.json: dictData.remark = request.json['remark']
  55. if 'isDefault' in request.json: dictData.is_default = request.json['isDefault']
  56. dictData.update_time = datetime.now()
  57. dictData.update_by = current_user.NAME
  58. db.session.add(dictData)
  59. return jsonify({'msg': '操作成功', 'code': 200})
  60. @base.route('/system/dict/data/<string:ids>', methods=['DELETE'])
  61. def sydata_delete(ids):
  62. idList = ids.split(',')
  63. for id in idList:
  64. dictData = DictData.query.get(id)
  65. if dictData:
  66. db.session.delete(dictData)
  67. return jsonify({'code': 200, 'msg': '操作成功'})