wenlele
1 year ago
12 changed files with 343 additions and 26 deletions
@ -0,0 +1,90 @@ |
|||
'use strict' |
|||
|
|||
const request = require('superagent') |
|||
const moment = require('moment') |
|||
|
|||
|
|||
// function getFileCarImages (opts) {
|
|||
|
|||
// return async function (ctx, next) {
|
|||
// let error = { message: '文件夹名称更新失败' }
|
|||
// const models = ctx.fs.dc.models
|
|||
// const { page, limit, } = ctx.query
|
|||
// try {
|
|||
// let searchWhere = {}
|
|||
// let option = {
|
|||
// where: searchWhere,
|
|||
// order: [["id", "desc"]],
|
|||
// }
|
|||
|
|||
|
|||
// option.where = searchWhere
|
|||
|
|||
// let limit_ = limit || 10
|
|||
// let page_ = page || 1
|
|||
// let offset = (page_ - 1) * limit_
|
|||
// if (limit && page) {
|
|||
// option.limit = limit_
|
|||
// option.offset = offset
|
|||
// }
|
|||
|
|||
// const res = await models.CarImages.findAndCount(option)
|
|||
|
|||
// error = null
|
|||
// } catch (err) {
|
|||
// ctx.status = 500
|
|||
// ctx.body = { detail: err, ...error }
|
|||
// }
|
|||
|
|||
// if (error) {
|
|||
// ctx.status = 400
|
|||
// ctx.body = { ...error }
|
|||
// } else {
|
|||
// ctx.status = 200
|
|||
// ctx.body = { message: '文件夹名称更新成功' }
|
|||
// }
|
|||
// }
|
|||
// }
|
|||
|
|||
|
|||
|
|||
function getFileCarImages (opts) { |
|||
return async function (ctx, next) { |
|||
|
|||
const models = ctx.fs.dc.models |
|||
const { page, limit, } = ctx.query |
|||
const Op = ctx.fs.dc.ORM.Op |
|||
let errMsg = { message: '获取图片失败' } |
|||
try { |
|||
let searchWhere = {} |
|||
let option = { |
|||
where: searchWhere, |
|||
order: [["id", "ASC"]], |
|||
} |
|||
|
|||
|
|||
option.where = searchWhere |
|||
|
|||
let limit_ = limit || 10 |
|||
let page_ = page || 1 |
|||
let offset = (page_ - 1) * limit_ |
|||
if (limit && page) { |
|||
option.limit = limit_ |
|||
option.offset = offset |
|||
} |
|||
|
|||
const res = await models.CarImages.findAndCount(option) |
|||
ctx.status = 200 |
|||
ctx.body = res |
|||
} catch (error) { |
|||
|
|||
ctx.status = 400 |
|||
ctx.body = errMsg |
|||
} |
|||
} |
|||
} |
|||
|
|||
|
|||
module.exports = { |
|||
getFileCarImages |
|||
} |
@ -0,0 +1,44 @@ |
|||
/* eslint-disable*/ |
|||
|
|||
'use strict'; |
|||
|
|||
module.exports = dc => { |
|||
const DataTypes = dc.ORM; |
|||
const sequelize = dc.orm; |
|||
const CarImages = sequelize.define("carImages", { |
|||
id: { |
|||
type: DataTypes.INTEGER, |
|||
allowNull: false, |
|||
defaultValue: null, |
|||
comment: null, |
|||
primaryKey: true, |
|||
field: "id", |
|||
autoIncrement: true, |
|||
unique: "car_images_id_uindex" |
|||
}, |
|||
url: { |
|||
type: DataTypes.STRING, |
|||
allowNull: true, |
|||
defaultValue: null, |
|||
comment: "图片路径", |
|||
primaryKey: false, |
|||
field: "url", |
|||
autoIncrement: false |
|||
}, |
|||
time: { |
|||
type: DataTypes.DATE, |
|||
allowNull: true, |
|||
defaultValue: null, |
|||
comment: "时间", |
|||
primaryKey: false, |
|||
field: "time", |
|||
autoIncrement: false |
|||
} |
|||
}, { |
|||
tableName: "car_images", |
|||
comment: "", |
|||
indexes: [] |
|||
}); |
|||
dc.models.CarImages = CarImages; |
|||
return CarImages; |
|||
}; |
@ -0,0 +1,10 @@ |
|||
'use strict' |
|||
|
|||
const images = require('../../controllers/images') |
|||
|
|||
module.exports = function (app, router, opts, panCode) { |
|||
|
|||
router.get('/car/images', images.getFileCarImages(opts)) |
|||
|
|||
|
|||
} |
@ -0,0 +1,16 @@ |
|||
create table car_images |
|||
( |
|||
id serial |
|||
constraint car_images_pk |
|||
primary key, |
|||
url varchar, |
|||
time timestamptz |
|||
); |
|||
|
|||
comment on column car_images.url is '图片路径'; |
|||
|
|||
comment on column car_images.time is '时间'; |
|||
|
|||
create unique index car_images_id_uindex |
|||
on car_images (id); |
|||
|
@ -0,0 +1,15 @@ |
|||
import { basicAction } from '@peace/utils' |
|||
import { ApiTable } from '$utils' |
|||
|
|||
|
|||
export function getCarImages (query) { |
|||
return dispatch => basicAction({ |
|||
type: 'get', |
|||
dispatch: dispatch, |
|||
actionType: 'GET_CAR_IMAGES', |
|||
url: ApiTable.getCarImages, |
|||
query, |
|||
msg: { error: '获取图片失败' }, |
|||
reducer: { name: 'carimage' } |
|||
}) |
|||
} |
@ -0,0 +1,124 @@ |
|||
// import React, { useState, useEffect } from 'react'
|
|||
// import { connect } from 'react-redux'
|
|||
// import { getCarImages } from '../actions/carimages'
|
|||
// import ProTable from '@ant-design/pro-table'
|
|||
// import { Form, Space, DatePicker, Button, Select, Popconfirm, Image, Tooltip } from 'antd'
|
|||
// import moment from 'moment'
|
|||
|
|||
|
|||
// function Carimages (props) {
|
|||
// const { dispatch, assess, user } = props
|
|||
// const [query, setQuery] = useState({ page: 1, pageSize: 10, })
|
|||
// const [loading, setLoading] = useState(false)
|
|||
// const [datasource, setdatasource] = useState([])
|
|||
// const [dateRange, setDateRange] = useState(['1970-1-1', '2099-12-31'])
|
|||
// const { RangePicker } = DatePicker
|
|||
// const [total, settotal] = useState(0)
|
|||
// const [editAble, setEditAble] = useState(user?.username !== 'SuperAdmin' && user?.userResources?.find(i => i.resourceId === 'ASSESSMANAGE')?.isshow === "true" ? true : '')
|
|||
// useEffect(() => {
|
|||
|
|||
// return () => { }
|
|||
// }, [])
|
|||
|
|||
// useEffect(() => {
|
|||
// getData()
|
|||
// }, [query])
|
|||
|
|||
|
|||
|
|||
|
|||
// const getData = () => {
|
|||
// console.log(query, 'query')
|
|||
// dispatch(getCarImages({ ...query })).then(res => {
|
|||
// if (res?.success) {
|
|||
// setdatasource(res?.payload?.data?.rows)
|
|||
// settotal(res?.payload?.data?.count)
|
|||
// }
|
|||
// })
|
|||
// }
|
|||
|
|||
|
|||
// return (
|
|||
// <div>
|
|||
// <div style={{ marginBottom: '20px', display: 'flex', justifyContent: 'space-between' }}>
|
|||
// <Form layout="inline" onFinish={(v) => {
|
|||
|
|||
// setQuery({
|
|||
// ...query, page: 1, unit: v.unit, startTime: v?.time && moment(v?.time[0]).startOf('day').format('YYYY-MM-DD HH:mm:ss'),
|
|||
// endTime: v?.time && moment(v?.time[1]).add(1, 'days').endOf('day').format('YYYY-MM-DD HH:mm:ss')
|
|||
// })
|
|||
// }}>
|
|||
|
|||
// {/* <Form.Item>
|
|||
// <Button type="primary" htmlType="submit">搜索</Button>
|
|||
// </Form.Item> */}
|
|||
// </Form>
|
|||
|
|||
// {/* <Button type="primary" disabled={editAble}
|
|||
// onClick={() => {
|
|||
// setAssessModalVisible(true)
|
|||
// }}>新增</Button> */}
|
|||
// </div>
|
|||
// <ProTable
|
|||
// columns={[
|
|||
// {
|
|||
// title: '序号',
|
|||
// dataIndex: 'id',
|
|||
// key: 'id',
|
|||
// defaultSortOrder: 'ascend',
|
|||
// },
|
|||
// {
|
|||
// title: '抓拍图片',
|
|||
// dataIndex: 'url',
|
|||
// key: 'url',
|
|||
// render: (t, r) => {
|
|||
// if (r?.url && r?.id) {
|
|||
// return <span style={{ marginRight: 10 }}>
|
|||
// <Image src={r?.url} width={200} />
|
|||
// </span>
|
|||
// } else {
|
|||
// return '--'
|
|||
// }
|
|||
// }
|
|||
// },
|
|||
// {
|
|||
// title: '日期',
|
|||
// dataIndex: 'time',
|
|||
// key: 'time',
|
|||
// render: (t, r) => {
|
|||
// const localTime = moment.utc(r?.time).format('YYYY-MM-DD HH:mm:ss')
|
|||
// return r?.time ? localTime : '--'
|
|||
// }
|
|||
// },
|
|||
// ]}
|
|||
// dataSource={datasource || []}
|
|||
// loading={loading}
|
|||
// pagination={{
|
|||
// total: total || 0,
|
|||
// pageSize: 10,
|
|||
// defaultPageSize: 10,
|
|||
// showSizeChanger: false,
|
|||
// onChange: (page, pageSize) => {
|
|||
// setQuery({
|
|||
// ...query,
|
|||
// page,
|
|||
// limit: pageSize
|
|||
// })
|
|||
// }
|
|||
// }}
|
|||
// rowKey="key"
|
|||
// toolBarRender={false}
|
|||
// search={false}
|
|||
// />
|
|||
|
|||
// </div>
|
|||
// )
|
|||
// }
|
|||
// function mapStateToProps (state) {
|
|||
// const { auth, assess } = state
|
|||
// return {
|
|||
// user: auth.user,
|
|||
// assess: assess.data || [],
|
|||
// }
|
|||
// }
|
|||
// export default connect(mapStateToProps)(Carimages)
|
Loading…
Reference in new issue