|
@@ -25,6 +25,27 @@ const timeType = [
|
|
const timeTypeValue = ref('')
|
|
const timeTypeValue = ref('')
|
|
const selectDate = ref([])
|
|
const selectDate = ref([])
|
|
const selectBusinessValue=ref([])
|
|
const selectBusinessValue=ref([])
|
|
|
|
+// 获取选择的起止日期值
|
|
|
|
+function getStartAndEndDate(){
|
|
|
|
+ let StartDate=selectDate.value?.[0]||'',EndDate=selectDate.value?.[1]||'';
|
|
|
|
+ if(timeTypeValue.value==='今天'){
|
|
|
|
+ StartDate=moment().format('YYYY-MM-DD')
|
|
|
|
+ EndDate=moment().format('YYYY-MM-DD')
|
|
|
|
+ }else if(timeTypeValue.value==='过去3天'){
|
|
|
|
+ EndDate=moment().format('YYYY-MM-DD')
|
|
|
|
+ StartDate=moment().subtract(3,'days').format('YYYY-MM-DD')
|
|
|
|
+ }else if(timeTypeValue.value==='过去一周'){
|
|
|
|
+ EndDate=moment().format('YYYY-MM-DD')
|
|
|
|
+ StartDate=moment().subtract(7,'days').format('YYYY-MM-DD')
|
|
|
|
+ }else if(timeTypeValue.value==='过去一月'){
|
|
|
|
+ EndDate=moment().format('YYYY-MM-DD')
|
|
|
|
+ StartDate=moment().subtract(30,'days').format('YYYY-MM-DD')
|
|
|
|
+ }
|
|
|
|
+ return {
|
|
|
|
+ StartDate,
|
|
|
|
+ EndDate
|
|
|
|
+ }
|
|
|
|
+}
|
|
|
|
|
|
const tableData = ref([])
|
|
const tableData = ref([])
|
|
const columns = [
|
|
const columns = [
|
|
@@ -39,14 +60,17 @@ const tablePagination = ref({
|
|
total: 0,
|
|
total: 0,
|
|
showPageSize: false
|
|
showPageSize: false
|
|
})
|
|
})
|
|
|
|
+let SortParam='',SortType='';
|
|
async function getStatisticList(){
|
|
async function getStatisticList(){
|
|
- let StartDate='',EndDate='';
|
|
|
|
|
|
+
|
|
const res=await apiCustomerUser.getUserActionStatistic({
|
|
const res=await apiCustomerUser.getUserActionStatistic({
|
|
CurrentIndex:tablePagination.value.current,
|
|
CurrentIndex:tablePagination.value.current,
|
|
PageSize:tablePagination.value.pageSize,
|
|
PageSize:tablePagination.value.pageSize,
|
|
EtaBusinessIds:selectBusinessValue.value.join(','),
|
|
EtaBusinessIds:selectBusinessValue.value.join(','),
|
|
- StartDate:selectDate.value?.[0]||'',
|
|
|
|
- EndDate:selectDate.value?.[1]||'',
|
|
|
|
|
|
+ StartDate:getStartAndEndDate().StartDate,
|
|
|
|
+ EndDate:getStartAndEndDate().EndDate,
|
|
|
|
+ SortParam:SortParam,
|
|
|
|
+ SortType:SortType
|
|
})
|
|
})
|
|
if(res.Ret!==200) return
|
|
if(res.Ret!==200) return
|
|
tableData.value=res.Data.List||[]
|
|
tableData.value=res.Data.List||[]
|
|
@@ -54,6 +78,22 @@ async function getStatisticList(){
|
|
|
|
|
|
}
|
|
}
|
|
getStatisticList()
|
|
getStatisticList()
|
|
|
|
+function handlePageChange(e){
|
|
|
|
+ tablePagination.value.current=e.current
|
|
|
|
+ getStatisticList()
|
|
|
|
+}
|
|
|
|
+// 排序 sort undefined descending:true|false
|
|
|
|
+function handleSortChange(sort,options){
|
|
|
|
+ console.log(sort,options);
|
|
|
|
+ if(sort){
|
|
|
|
+ SortParam=sort.sortBy
|
|
|
|
+ SortType=sort.descending?'desc':'asc'
|
|
|
|
+ }else{
|
|
|
|
+ SortParam=''
|
|
|
|
+ SortType=''
|
|
|
|
+ }
|
|
|
|
+ refreshList()
|
|
|
|
+}
|
|
|
|
|
|
function refreshList(){
|
|
function refreshList(){
|
|
tablePagination.value.current=1
|
|
tablePagination.value.current=1
|
|
@@ -74,7 +114,13 @@ function handleSelectDate(){
|
|
}
|
|
}
|
|
|
|
|
|
const showFavChart=ref(false)
|
|
const showFavChart=ref(false)
|
|
-
|
|
|
|
|
|
+const activeUser=ref(null)
|
|
|
|
+const filterDate=ref(null)
|
|
|
|
+function handleShowDetail(item){
|
|
|
|
+ activeUser.value=item
|
|
|
|
+ filterDate.value=getStartAndEndDate()
|
|
|
|
+ showFavChart.value=true
|
|
|
|
+}
|
|
</script>
|
|
</script>
|
|
|
|
|
|
<template>
|
|
<template>
|
|
@@ -106,14 +152,20 @@ const showFavChart=ref(false)
|
|
:pagination="tablePagination"
|
|
:pagination="tablePagination"
|
|
show-header
|
|
show-header
|
|
resizable
|
|
resizable
|
|
|
|
+ @page-change="handlePageChange"
|
|
|
|
+ @sort-change="handleSortChange"
|
|
>
|
|
>
|
|
<template #CollectNum="{row}">
|
|
<template #CollectNum="{row}">
|
|
- <t-button size="small" theme="primary" variant="text">{{row.CollectNum}}</t-button>
|
|
|
|
|
|
+ <t-button size="small" theme="primary" variant="text" @click="handleShowDetail(row)">{{row.CollectNum}}</t-button>
|
|
</template>
|
|
</template>
|
|
</t-table>
|
|
</t-table>
|
|
|
|
|
|
<!-- 用户收藏图表 -->
|
|
<!-- 用户收藏图表 -->
|
|
- <FavChartStatistic v-model:show="showFavChart"/>
|
|
|
|
|
|
+ <FavChartStatistic
|
|
|
|
+ v-model:show="showFavChart"
|
|
|
|
+ :data="activeUser"
|
|
|
|
+ :filterDate="filterDate"
|
|
|
|
+ />
|
|
</template>
|
|
</template>
|
|
|
|
|
|
<style lang="scss" scoped>
|
|
<style lang="scss" scoped>
|