21 changed files with 998 additions and 307 deletions
@ -0,0 +1,192 @@ |
|||||
|
<template> |
||||
|
<div class="from-content" style="width: 100%"> |
||||
|
<div class="InputSearch input" v-if="params && types == 'input'"> |
||||
|
<ElInput |
||||
|
style="width: 100%" |
||||
|
v-model="value" |
||||
|
:placeholder="placeholder" |
||||
|
@change="handleSearch" |
||||
|
></ElInput> |
||||
|
<img src="./search.svg" @click="handleFormShow" /> |
||||
|
</div> |
||||
|
<ElPopover |
||||
|
v-else |
||||
|
ref="PopoverRef" |
||||
|
placement="bottom" |
||||
|
popper-class="global-input-search-popover" |
||||
|
:popperOptions="popperOptions" |
||||
|
:visibleArrow="false" |
||||
|
:width="this.width" |
||||
|
trigger="click" |
||||
|
@show="handleShow" |
||||
|
style="width: 100%" |
||||
|
> |
||||
|
<div class="InputSearch" slot="reference" ref="ReferenceInputRef"> |
||||
|
<span>{{ placeholder }}</span> |
||||
|
<img src="./search.svg" @click="handleFormShow" /> |
||||
|
</div> |
||||
|
|
||||
|
<div style="width: 100%; max-height: 360px"> |
||||
|
<slot> |
||||
|
<Form |
||||
|
v-if="formList && formList.length" |
||||
|
class="form" |
||||
|
ref="FormConfigRef" |
||||
|
:formList="formList" |
||||
|
v-bind="getFormConfigOptions" |
||||
|
/> |
||||
|
<!-- <ElEmpty v-else description="暂无搜索内容"></ElEmpty> --> |
||||
|
<div v-else class="no-data">暂无数据</div> |
||||
|
</slot> |
||||
|
|
||||
|
<div class="footer"> |
||||
|
<Button |
||||
|
style="background-color: rgba(0, 179, 204, 0.3)" |
||||
|
@click.native="handleResetForm" |
||||
|
> |
||||
|
重置 |
||||
|
</Button> |
||||
|
<Button @click.native="handleSearch"> 搜索 </Button> |
||||
|
</div> |
||||
|
</div> |
||||
|
</ElPopover> |
||||
|
</div> |
||||
|
</template> |
||||
|
|
||||
|
<script> |
||||
|
import Button from "@screen/components/Buttons/Button.vue"; |
||||
|
import Form from "@screen/components/FormConfig"; |
||||
|
import { cloneDeep } from "lodash"; |
||||
|
|
||||
|
export default { |
||||
|
name: "InputSearch", |
||||
|
components: { |
||||
|
Button, |
||||
|
Form, |
||||
|
}, |
||||
|
props: { |
||||
|
type: { |
||||
|
type: String, |
||||
|
default: "form", |
||||
|
}, |
||||
|
placeholder: { |
||||
|
type: String, |
||||
|
default: "请点击右侧图标筛选", |
||||
|
}, |
||||
|
valueData: { |
||||
|
type: String, |
||||
|
}, |
||||
|
params: { |
||||
|
type: String, |
||||
|
}, |
||||
|
queryParams: { |
||||
|
type: Array, |
||||
|
}, |
||||
|
formConfigOptions: { |
||||
|
type: Object, |
||||
|
default: null, |
||||
|
}, |
||||
|
formList: { |
||||
|
type: Array, |
||||
|
default: () => [], |
||||
|
}, |
||||
|
}, |
||||
|
data() { |
||||
|
return { |
||||
|
types: this.type, |
||||
|
value: this.valueData, |
||||
|
width: null, |
||||
|
popperOptions: { |
||||
|
popHideCallBack: () => { |
||||
|
// console.log("---") |
||||
|
}, |
||||
|
}, |
||||
|
}; |
||||
|
}, |
||||
|
emit: ["handleSearch"], |
||||
|
computed: { |
||||
|
getFormConfigOptions() { |
||||
|
return { |
||||
|
column: "1", |
||||
|
labelWidth: "120px", |
||||
|
...this.formConfigOptions, |
||||
|
}; |
||||
|
}, |
||||
|
}, |
||||
|
methods: { |
||||
|
handleFormShow() { |
||||
|
console.log(this.params, this.types); |
||||
|
if (this.params) { |
||||
|
if (this.types == "form") { |
||||
|
this.types = "input"; |
||||
|
} else { |
||||
|
this.types = "form"; |
||||
|
} |
||||
|
} else { |
||||
|
this.types = "form"; |
||||
|
} |
||||
|
console.log(this.params, this.types); |
||||
|
}, |
||||
|
handleShow() { |
||||
|
if (this.width) return; |
||||
|
|
||||
|
this.width = this.$refs.ReferenceInputRef.getBoundingClientRect().width; |
||||
|
}, |
||||
|
handleResetForm() { |
||||
|
this.$refs.FormConfigRef?.reset(); |
||||
|
|
||||
|
this.$refs.PopoverRef.doClose(); |
||||
|
|
||||
|
this.$emit("handleSearch", cloneDeep(this.$refs.FormConfigRef?.formData)); |
||||
|
}, |
||||
|
handleSearch() { |
||||
|
if (this.types == "form") { |
||||
|
this.$refs.FormConfigRef.validate() |
||||
|
.then((result) => { |
||||
|
this.$refs.PopoverRef.doClose(); |
||||
|
this.$emit("handleSearch", result); |
||||
|
}) |
||||
|
.catch((err) => { |
||||
|
console.log("catch"); |
||||
|
}); |
||||
|
} else { |
||||
|
let params = {}; |
||||
|
params[this.params] = this.value; |
||||
|
this.$emit("handleSearch", params); |
||||
|
} |
||||
|
}, |
||||
|
}, |
||||
|
}; |
||||
|
</script> |
||||
|
|
||||
|
<style lang="scss" scoped> |
||||
|
.InputSearch { |
||||
|
width: 100%; |
||||
|
height: 26px; |
||||
|
background: linear-gradient(180deg, #005c79 0%, #009bcc 100%) !important; |
||||
|
color: #fff; |
||||
|
border-radius: 2px; |
||||
|
display: flex; |
||||
|
align-items: center; |
||||
|
justify-content: space-between; |
||||
|
padding: 3px 15px; |
||||
|
padding-right: 9px; |
||||
|
cursor: pointer; |
||||
|
|
||||
|
font-size: 12px; |
||||
|
font-family: PingFang SC, PingFang SC; |
||||
|
font-weight: 400; |
||||
|
color: #ffffff; |
||||
|
line-height: 14px; |
||||
|
} |
||||
|
.input ::v-deep .el-input__inner { |
||||
|
background: none; |
||||
|
height: auto !important; |
||||
|
font-size: 12px; |
||||
|
padding: 0px 0; |
||||
|
line-height: 14px; |
||||
|
} |
||||
|
::v-deep .el-input__inner::placeholder { |
||||
|
font-size: 12px; |
||||
|
} |
||||
|
</style> |
@ -1,124 +1,124 @@ |
|||||
let chartIcon = ``; |
let chartIcon = ``; |
||||
let xdata = { |
let xdata = { |
||||
value: ['平阴停车区'] |
value: ["平阴停车区"], |
||||
}; |
}; |
||||
let sdata = { |
let sdata = { |
||||
value: [32774] |
value: [32774], |
||||
} |
}; |
||||
|
|
||||
let dataZoomMove = { |
let dataZoomMove = { |
||||
start: 0, |
start: 0, |
||||
end: 4 |
end: 4, |
||||
} |
}; |
||||
var options = { |
var options = { |
||||
grid: { |
grid: { |
||||
containLabel: true, |
containLabel: true, |
||||
// 边距自行修改
|
// 边距自行修改
|
||||
bottom: '0%', |
bottom: "0%", |
||||
left: '0%', |
left: "0%", |
||||
top: '2%', |
top: "2%", |
||||
right: '15%', |
right: "15%", |
||||
}, |
}, |
||||
xAxis: { |
xAxis: { |
||||
type: 'value', |
type: "value", |
||||
|
axisLabel: { |
||||
|
show: false, |
||||
|
}, |
||||
|
axisLine: { |
||||
|
show: false, |
||||
|
}, |
||||
|
axisTick: { |
||||
|
show: false, |
||||
|
}, |
||||
|
splitLine: { |
||||
|
show: false, |
||||
|
}, |
||||
|
}, |
||||
|
yAxis: [ |
||||
|
{ |
||||
|
type: "category", |
||||
|
data: xdata.value, |
||||
|
inverse: true, |
||||
axisLabel: { |
axisLabel: { |
||||
show: false |
fontSize: "14px", |
||||
|
inside: true, |
||||
|
verticalAlign: "bottom", |
||||
|
color: "#fff", |
||||
|
padding: 10, |
||||
|
margin: -5, |
||||
|
formatter: function (value, index) { |
||||
|
// let index = xdata.value.indexOf(value);
|
||||
|
return `{a|Top${index + 1}} {b|${value}}`; |
||||
|
}, |
||||
|
rich: { |
||||
|
a: { |
||||
|
fontSize: "14px", |
||||
|
}, |
||||
|
|
||||
|
b: { |
||||
|
fontSize: "14px", |
||||
|
padding: [0, 0, 0, 70], |
||||
|
}, |
||||
|
}, |
||||
}, |
}, |
||||
axisLine: { |
axisLine: { |
||||
show: false, |
show: false, |
||||
}, |
}, |
||||
axisTick: { |
axisTick: { |
||||
show: false, |
show: false, |
||||
}, |
|
||||
splitLine: { |
|
||||
show: false, |
|
||||
}, |
}, |
||||
}, |
}, |
||||
yAxis: [ |
], |
||||
{ |
series: [ |
||||
type: 'category', |
{ |
||||
data: xdata.value, |
data: sdata.value, |
||||
inverse: true, |
type: "bar", |
||||
axisLabel: { |
barWidth: 8, |
||||
fontSize: '14px', |
itemStyle: { |
||||
inside: true, |
borderRadius: 40, |
||||
verticalAlign: 'bottom', |
color: { |
||||
color: '#fff', |
type: "linear", |
||||
padding: 10, |
x: 0, |
||||
margin: -5, |
y: 0, |
||||
formatter: function (value, index) { |
x2: 1, |
||||
// let index = xdata.value.indexOf(value);
|
y2: 0, |
||||
return `{a|Top${index + 1}} {b|${value}}` |
colorStops: [ |
||||
|
{ |
||||
|
offset: 0, |
||||
|
color: "#1cd0f000", // 0% 处的颜色
|
||||
}, |
}, |
||||
rich: { |
{ |
||||
a: { |
offset: 1, |
||||
fontSize: '14px', |
color: "#1cd0f0", // 100% 处的颜色
|
||||
}, |
|
||||
|
|
||||
b: { |
|
||||
fontSize: '14px', |
|
||||
padding: [0, 0, 0, 70], |
|
||||
} |
|
||||
}, |
}, |
||||
}, |
], |
||||
axisLine: { |
global: false, // 缺省为 false
|
||||
show: false, |
}, |
||||
}, |
}, |
||||
axisTick: { |
label: { |
||||
show: false, |
show: true, |
||||
} |
position: "right", |
||||
} |
distance: -10, |
||||
], |
data: sdata, |
||||
series: [ |
color: "#fff", |
||||
{ |
formatter: (c) => { |
||||
data: sdata.value, |
return `{a|}{b|${c.value}起}`; |
||||
type: 'bar', |
}, |
||||
barWidth: 8, |
rich: { |
||||
itemStyle: { |
a: { |
||||
borderRadius: 40, |
widht: 20, |
||||
color: { |
height: 20, |
||||
type: 'linear', |
backgroundColor: { |
||||
x: 0, |
image: chartIcon, |
||||
y: 0, |
|
||||
x2: 1, |
|
||||
y2: 0, |
|
||||
colorStops: [ |
|
||||
{ |
|
||||
offset: 0, |
|
||||
color: '#1cd0f000', // 0% 处的颜色
|
|
||||
}, |
|
||||
{ |
|
||||
offset: 1, |
|
||||
color: '#1cd0f0', // 100% 处的颜色
|
|
||||
}, |
|
||||
], |
|
||||
global: false, // 缺省为 false
|
|
||||
} |
|
||||
}, |
|
||||
label: { |
|
||||
show: true, |
|
||||
position: 'right', |
|
||||
distance: -10, |
|
||||
data: sdata, |
|
||||
color: '#fff', |
|
||||
formatter: (c) => { |
|
||||
return `{a|}{b|${c.value}件}` |
|
||||
}, |
}, |
||||
rich: { |
}, |
||||
a: { |
b: { |
||||
widht: 20, |
padding: [0, 0, 0, 10], |
||||
height: 20, |
}, |
||||
backgroundColor: { |
}, |
||||
image: chartIcon |
}, |
||||
}, |
}, |
||||
}, |
], |
||||
b: { |
}; |
||||
padding: [0, 0, 0, 10] |
|
||||
} |
|
||||
} |
|
||||
} |
|
||||
} |
|
||||
] |
|
||||
} |
|
||||
|
|
||||
export default options; |
export default options; |
||||
|
Loading…
Reference in new issue