修改
This commit is contained in:
parent
d45ca3942c
commit
50a17fed0c
9
src/api/system/Personalstatistics.js
Normal file
9
src/api/system/Personalstatistics.js
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
import request from '@/utils/request'
|
||||||
|
|
||||||
|
// 查询
|
||||||
|
export function appletPersonCount(pageNum, pageSize, parentInfoId, classId, startDate, endDate) {
|
||||||
|
return request({
|
||||||
|
url: `/system/appLogManage/appletPersonCount?pageNum=${pageNum}&pageSize=${pageSize}&parentInfoId=${parentInfoId}&classId=${classId}&startDate=${startDate}&endDate=${endDate}`,
|
||||||
|
method: 'get',
|
||||||
|
})
|
||||||
|
}
|
||||||
9
src/api/system/StatisticsArea.js
Normal file
9
src/api/system/StatisticsArea.js
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
import request from '@/utils/request'
|
||||||
|
|
||||||
|
// 查询
|
||||||
|
export function countyStatistic(pageNum, pageSize, areaId, startDate, endDate) {
|
||||||
|
return request({
|
||||||
|
url: `/system/appLogManage/countyStatistic?pageNum=${pageNum}&pageSize=${pageSize}&areaId=${areaId}&startDate=${startDate}&endDate=${endDate}`,
|
||||||
|
method: 'post'
|
||||||
|
})
|
||||||
|
}
|
||||||
9
src/api/system/StatisticsParent.js
Normal file
9
src/api/system/StatisticsParent.js
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
import request from '@/utils/request'
|
||||||
|
|
||||||
|
// 查询
|
||||||
|
export function clockStatistics(pageNum, pageSize, parentInfoId, classId, startDate, endDate) {
|
||||||
|
return request({
|
||||||
|
url: `/system/appLogManage/clockStatistics?pageNum=${pageNum}&pageSize=${pageSize}&parentInfoId=${parentInfoId}&classId=${classId}&startDate=${startDate}&endDate=${endDate}`,
|
||||||
|
method: 'post',
|
||||||
|
})
|
||||||
|
}
|
||||||
9
src/api/system/Statisticspark.js
Normal file
9
src/api/system/Statisticspark.js
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
import request from '@/utils/request'
|
||||||
|
|
||||||
|
// 查询
|
||||||
|
export function appletKindergartenCount(pageNum, pageSize, areaCode, kindergartenId, startDate, endDate) {
|
||||||
|
return request({
|
||||||
|
url: `/system/appLogManage/appletKindergartenCount?pageNum=${pageNum}&pageSize=${pageSize}&areaCode=${areaCode}&kindergartenId=${kindergartenId}&startDate=${startDate}&endDate=${endDate}`,
|
||||||
|
method: 'get',
|
||||||
|
})
|
||||||
|
}
|
||||||
@ -5,22 +5,10 @@
|
|||||||
<el-button
|
<el-button
|
||||||
@click="classshow = true"
|
@click="classshow = true"
|
||||||
v-if="className == '请选择班级'"
|
v-if="className == '请选择班级'"
|
||||||
style="
|
class="btn"
|
||||||
width: 230px;
|
style="color: #c0c4cc;"
|
||||||
text-align: left;
|
|
||||||
height: 32px;
|
|
||||||
color: #c0c4cc;
|
|
||||||
overflow: hidden;
|
|
||||||
white-space: nowrap;
|
|
||||||
text-overflow: ellipsis;
|
|
||||||
overflow: hidden;
|
|
||||||
"
|
|
||||||
>{{ className }}</el-button>
|
|
||||||
<el-button
|
|
||||||
@click="classshow = true"
|
|
||||||
style="width: 230px; text-align: left; height: 32px; overflow: hidden;white-space: nowrap;text-overflow: ellipsis;"
|
|
||||||
v-else
|
|
||||||
>{{ className }}</el-button>
|
>{{ className }}</el-button>
|
||||||
|
<el-button @click="classshow = true" class="btn" v-else>{{ className }}</el-button>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
<!-- //班级 -->
|
<!-- //班级 -->
|
||||||
@ -32,12 +20,14 @@
|
|||||||
:before-close="classcancel"
|
:before-close="classcancel"
|
||||||
>
|
>
|
||||||
<el-form ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="110px">
|
<el-form ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="110px">
|
||||||
<el-form-item label="幼儿园名称" prop="kindergartenName">
|
<el-form-item label="所属幼儿园" prop="kindergartenId">
|
||||||
<el-input
|
<treeselect
|
||||||
style="width: 200px"
|
:normalizer="normalizer"
|
||||||
v-model="classqueryParams.kindergartenName"
|
:options="kindergartenInfoList"
|
||||||
placeholder="请输入幼儿园名称"
|
placeholder="请选择所属幼儿园"
|
||||||
></el-input>
|
v-model="classqueryParams.kindergartenId"
|
||||||
|
style="width: 208px"
|
||||||
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="班级名称" prop="className">
|
<el-form-item label="班级名称" prop="className">
|
||||||
<el-input style="width: 200px" v-model="classqueryParams.className" placeholder="请输入班级名称"></el-input>
|
<el-input style="width: 200px" v-model="classqueryParams.className" placeholder="请输入班级名称"></el-input>
|
||||||
@ -90,10 +80,12 @@
|
|||||||
</template>
|
</template>
|
||||||
<script>
|
<script>
|
||||||
import { listClassinfo } from "@/api/system/classinfo";
|
import { listClassinfo } from "@/api/system/classinfo";
|
||||||
import { getRoleInfo } from "@/api/system/quality";
|
import Treeselect from "@riophae/vue-treeselect";
|
||||||
|
import "@riophae/vue-treeselect/dist/vue-treeselect.css";
|
||||||
|
import { listKindergartenInfo } from "@/api/system/kindergartenInfo";
|
||||||
export default {
|
export default {
|
||||||
|
components: { Treeselect },
|
||||||
name: "classe",
|
name: "classe",
|
||||||
components: {},
|
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
total1: 0,
|
total1: 0,
|
||||||
@ -103,14 +95,22 @@ export default {
|
|||||||
showSearch: true,
|
showSearch: true,
|
||||||
// 表单参数
|
// 表单参数
|
||||||
form: {},
|
form: {},
|
||||||
|
//幼儿园
|
||||||
|
kinqueryParams: {
|
||||||
|
pageNum: 1,
|
||||||
|
pageSize: 1000
|
||||||
|
},
|
||||||
//班级查询参数
|
//班级查询参数
|
||||||
classqueryParams: {
|
classqueryParams: {
|
||||||
pageNum: 1,
|
pageNum: 1,
|
||||||
pageSize: 10,
|
pageSize: 10,
|
||||||
className: null,
|
className: null,
|
||||||
kindergartenName: null,
|
kindergartenName: null,
|
||||||
|
kindergartenId: null,
|
||||||
phone: null
|
phone: null
|
||||||
},
|
},
|
||||||
|
//幼儿园list
|
||||||
|
kindergartenInfoList: [],
|
||||||
//班级list
|
//班级list
|
||||||
classList: [],
|
classList: [],
|
||||||
//班级名字
|
//班级名字
|
||||||
@ -121,6 +121,7 @@ export default {
|
|||||||
},
|
},
|
||||||
mounted() {},
|
mounted() {},
|
||||||
created() {
|
created() {
|
||||||
|
this.kingetlist();
|
||||||
this.getList();
|
this.getList();
|
||||||
this.onshow();
|
this.onshow();
|
||||||
},
|
},
|
||||||
@ -163,6 +164,12 @@ export default {
|
|||||||
};
|
};
|
||||||
this.classhandleQuery();
|
this.classhandleQuery();
|
||||||
},
|
},
|
||||||
|
//幼儿园list
|
||||||
|
kingetlist() {
|
||||||
|
listKindergartenInfo(this.kinqueryParams).then(response => {
|
||||||
|
this.kindergartenInfoList = response.rows;
|
||||||
|
});
|
||||||
|
},
|
||||||
getList() {
|
getList() {
|
||||||
//获取班级list
|
//获取班级list
|
||||||
listClassinfo(this.classqueryParams).then(response => {
|
listClassinfo(this.classqueryParams).then(response => {
|
||||||
@ -174,6 +181,16 @@ export default {
|
|||||||
reset() {
|
reset() {
|
||||||
this.className = "请选择班级";
|
this.className = "请选择班级";
|
||||||
this.classId = "";
|
this.classId = "";
|
||||||
|
},
|
||||||
|
normalizer(node) {
|
||||||
|
if (node.children && !node.children.length) {
|
||||||
|
delete node.children;
|
||||||
|
}
|
||||||
|
return {
|
||||||
|
kindergartenId: node.id,
|
||||||
|
label: node.kindergartenName,
|
||||||
|
children: node.children
|
||||||
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -182,4 +199,14 @@ export default {
|
|||||||
::v-deep .el-card__header {
|
::v-deep .el-card__header {
|
||||||
border: none;
|
border: none;
|
||||||
}
|
}
|
||||||
|
.btn {
|
||||||
|
width: 230px;
|
||||||
|
text-align: left;
|
||||||
|
height: 32px;
|
||||||
|
overflow: hidden;
|
||||||
|
white-space: nowrap;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
overflow: hidden;
|
||||||
|
font-size: 13px;
|
||||||
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|||||||
696
src/views/calendar.js
Normal file
696
src/views/calendar.js
Normal file
@ -0,0 +1,696 @@
|
|||||||
|
/**
|
||||||
|
* @1900-2100区间内的公历、农历互转
|
||||||
|
* @charset UTF-8
|
||||||
|
* @Author Jea杨(JJonline@JJonline.Cn)
|
||||||
|
* @Time 2014-7-21
|
||||||
|
* @Time 2016-8-13 Fixed 2033hex、Attribution Annals
|
||||||
|
* @Time 2016-9-25 Fixed lunar LeapMonth Param Bug
|
||||||
|
* @Time 2017-7-24 Fixed use getTerm Func Param Error.use solar year,NOT lunar year
|
||||||
|
* @Version 1.0.3
|
||||||
|
* @公历转农历:calendar.solar2lunar(1987,11,01); //[you can ignore params of prefix 0]
|
||||||
|
* @农历转公历:calendar.lunar2solar(1987,09,10); //[you can ignore params of prefix 0]
|
||||||
|
*/
|
||||||
|
const calendar = {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 农历1900-2100的润大小信息表
|
||||||
|
* @Array Of Property
|
||||||
|
* @return Hex
|
||||||
|
*/
|
||||||
|
lunarInfo: [0x04bd8, 0x04ae0, 0x0a570, 0x054d5, 0x0d260, 0x0d950, 0x16554, 0x056a0, 0x09ad0, 0x055d2, //1900-1909
|
||||||
|
0x04ae0, 0x0a5b6, 0x0a4d0, 0x0d250, 0x1d255, 0x0b540, 0x0d6a0, 0x0ada2, 0x095b0, 0x14977, //1910-1919
|
||||||
|
0x04970, 0x0a4b0, 0x0b4b5, 0x06a50, 0x06d40, 0x1ab54, 0x02b60, 0x09570, 0x052f2, 0x04970, //1920-1929
|
||||||
|
0x06566, 0x0d4a0, 0x0ea50, 0x16a95, 0x05ad0, 0x02b60, 0x186e3, 0x092e0, 0x1c8d7, 0x0c950, //1930-1939
|
||||||
|
0x0d4a0, 0x1d8a6, 0x0b550, 0x056a0, 0x1a5b4, 0x025d0, 0x092d0, 0x0d2b2, 0x0a950, 0x0b557, //1940-1949
|
||||||
|
0x06ca0, 0x0b550, 0x15355, 0x04da0, 0x0a5b0, 0x14573, 0x052b0, 0x0a9a8, 0x0e950, 0x06aa0, //1950-1959
|
||||||
|
0x0aea6, 0x0ab50, 0x04b60, 0x0aae4, 0x0a570, 0x05260, 0x0f263, 0x0d950, 0x05b57, 0x056a0, //1960-1969
|
||||||
|
0x096d0, 0x04dd5, 0x04ad0, 0x0a4d0, 0x0d4d4, 0x0d250, 0x0d558, 0x0b540, 0x0b6a0, 0x195a6, //1970-1979
|
||||||
|
0x095b0, 0x049b0, 0x0a974, 0x0a4b0, 0x0b27a, 0x06a50, 0x06d40, 0x0af46, 0x0ab60, 0x09570, //1980-1989
|
||||||
|
0x04af5, 0x04970, 0x064b0, 0x074a3, 0x0ea50, 0x06b58, 0x05ac0, 0x0ab60, 0x096d5, 0x092e0, //1990-1999
|
||||||
|
0x0c960, 0x0d954, 0x0d4a0, 0x0da50, 0x07552, 0x056a0, 0x0abb7, 0x025d0, 0x092d0, 0x0cab5, //2000-2009
|
||||||
|
0x0a950, 0x0b4a0, 0x0baa4, 0x0ad50, 0x055d9, 0x04ba0, 0x0a5b0, 0x15176, 0x052b0, 0x0a930, //2010-2019
|
||||||
|
0x07954, 0x06aa0, 0x0ad50, 0x05b52, 0x04b60, 0x0a6e6, 0x0a4e0, 0x0d260, 0x0ea65, 0x0d530, //2020-2029
|
||||||
|
0x05aa0, 0x076a3, 0x096d0, 0x04afb, 0x04ad0, 0x0a4d0, 0x1d0b6, 0x0d250, 0x0d520, 0x0dd45, //2030-2039
|
||||||
|
0x0b5a0, 0x056d0, 0x055b2, 0x049b0, 0x0a577, 0x0a4b0, 0x0aa50, 0x1b255, 0x06d20, 0x0ada0, //2040-2049
|
||||||
|
/**Add By JJonline@JJonline.Cn**/
|
||||||
|
0x14b63, 0x09370, 0x049f8, 0x04970, 0x064b0, 0x168a6, 0x0ea50, 0x06b20, 0x1a6c4, 0x0aae0, //2050-2059
|
||||||
|
0x092e0, 0x0d2e3, 0x0c960, 0x0d557, 0x0d4a0, 0x0da50, 0x05d55, 0x056a0, 0x0a6d0, 0x055d4, //2060-2069
|
||||||
|
0x052d0, 0x0a9b8, 0x0a950, 0x0b4a0, 0x0b6a6, 0x0ad50, 0x055a0, 0x0aba4, 0x0a5b0, 0x052b0, //2070-2079
|
||||||
|
0x0b273, 0x06930, 0x07337, 0x06aa0, 0x0ad50, 0x14b55, 0x04b60, 0x0a570, 0x054e4, 0x0d160, //2080-2089
|
||||||
|
0x0e968, 0x0d520, 0x0daa0, 0x16aa6, 0x056d0, 0x04ae0, 0x0a9d4, 0x0a2d0, 0x0d150, 0x0f252, //2090-2099
|
||||||
|
0x0d520
|
||||||
|
], //2100
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 公历每个月份的天数普通表
|
||||||
|
* @Array Of Property
|
||||||
|
* @return Number
|
||||||
|
*/
|
||||||
|
solarMonth: [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31],
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 天干地支之天干速查表
|
||||||
|
* @Array Of Property trans["甲","乙","丙","丁","戊","己","庚","辛","壬","癸"]
|
||||||
|
* @return Cn string
|
||||||
|
*/
|
||||||
|
Gan: ["\u7532", "\u4e59", "\u4e19", "\u4e01", "\u620a", "\u5df1", "\u5e9a", "\u8f9b", "\u58ec", "\u7678"],
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 天干地支之地支速查表
|
||||||
|
* @Array Of Property
|
||||||
|
* @trans["子","丑","寅","卯","辰","巳","午","未","申","酉","戌","亥"]
|
||||||
|
* @return Cn string
|
||||||
|
*/
|
||||||
|
Zhi: ["\u5b50", "\u4e11", "\u5bc5", "\u536f", "\u8fb0", "\u5df3", "\u5348", "\u672a", "\u7533", "\u9149", "\u620c", "\u4ea5"],
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 天干地支之地支速查表<=>生肖
|
||||||
|
* @Array Of Property
|
||||||
|
* @trans["鼠","牛","虎","兔","龙","蛇","马","羊","猴","鸡","狗","猪"]
|
||||||
|
* @return Cn string
|
||||||
|
*/
|
||||||
|
Animals: ["\u9f20", "\u725b", "\u864e", "\u5154", "\u9f99", "\u86c7", "\u9a6c", "\u7f8a", "\u7334", "\u9e21", "\u72d7", "\u732a"],
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 阳历节日
|
||||||
|
*/
|
||||||
|
festival: {
|
||||||
|
'1-1': { title: '元旦节' },
|
||||||
|
'2-14': { title: '情人节' },
|
||||||
|
'5-1': { title: '劳动节' },
|
||||||
|
'5-4': { title: '青年节' },
|
||||||
|
'6-1': { title: '儿童节' },
|
||||||
|
'9-10': { title: '教师节' },
|
||||||
|
'10-1': { title: '国庆节' },
|
||||||
|
'12-25': { title: '圣诞节' },
|
||||||
|
|
||||||
|
'3-8': { title: '妇女节' },
|
||||||
|
'3-12': { title: '植树节' },
|
||||||
|
'4-1': { title: '愚人节' },
|
||||||
|
'5-12': { title: '护士节' },
|
||||||
|
'7-1': { title: '建党节' },
|
||||||
|
'8-1': { title: '建军节' },
|
||||||
|
'12-24': { title: '平安夜' },
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 农历节日
|
||||||
|
*/
|
||||||
|
lFestival: {
|
||||||
|
'12-30': { title: '除夕' },
|
||||||
|
'1-1': { title: '春节' },
|
||||||
|
'1-15': { title: '元宵节' },
|
||||||
|
'2-2': { title: '龙抬头' },
|
||||||
|
'5-5': { title: '端午节' },
|
||||||
|
'7-7': { title: '七夕节' },
|
||||||
|
'7-15': { title: '中元节' },
|
||||||
|
'8-15': { title: '中秋节' },
|
||||||
|
'9-9': { title: '重阳节' },
|
||||||
|
'10-1': { title: '寒衣节' },
|
||||||
|
'10-15': { title: '下元节' },
|
||||||
|
'12-8': { title: '腊八节' },
|
||||||
|
'12-23': { title: '北方小年' },
|
||||||
|
'12-24': { title: '南方小年' },
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 返回默认定义的阳历节日
|
||||||
|
*/
|
||||||
|
getFestival() {
|
||||||
|
return this.festival
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 返回默认定义的内容里节日
|
||||||
|
*/
|
||||||
|
getLunarFestival() {
|
||||||
|
return this.lFestival
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param param {Object} 按照festival的格式输入数据,设置阳历节日
|
||||||
|
*/
|
||||||
|
setFestival(param = {}) {
|
||||||
|
this.festival = param
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param param {Object} 按照lFestival的格式输入数据,设置农历节日
|
||||||
|
*/
|
||||||
|
setLunarFestival(param = {}) {
|
||||||
|
this.lFestival = param
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 24节气速查表
|
||||||
|
* @Array Of Property
|
||||||
|
* @trans["小寒","大寒","立春","雨水","惊蛰","春分","清明","谷雨","立夏","小满","芒种","夏至","小暑","大暑","立秋","处暑","白露","秋分","寒露","霜降","立冬","小雪","大雪","冬至"]
|
||||||
|
* @return Cn string
|
||||||
|
*/
|
||||||
|
solarTerm: ["\u5c0f\u5bd2", "\u5927\u5bd2", "\u7acb\u6625", "\u96e8\u6c34", "\u60ca\u86f0", "\u6625\u5206", "\u6e05\u660e", "\u8c37\u96e8", "\u7acb\u590f", "\u5c0f\u6ee1", "\u8292\u79cd", "\u590f\u81f3", "\u5c0f\u6691", "\u5927\u6691", "\u7acb\u79cb", "\u5904\u6691", "\u767d\u9732", "\u79cb\u5206", "\u5bd2\u9732", "\u971c\u964d", "\u7acb\u51ac", "\u5c0f\u96ea", "\u5927\u96ea", "\u51ac\u81f3"],
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 1900-2100各年的24节气日期速查表
|
||||||
|
* @Array Of Property
|
||||||
|
* @return 0x string For splice
|
||||||
|
*/
|
||||||
|
sTermInfo: ['9778397bd097c36b0b6fc9274c91aa', '97b6b97bd19801ec9210c965cc920e', '97bcf97c3598082c95f8c965cc920f',
|
||||||
|
'97bd0b06bdb0722c965ce1cfcc920f', 'b027097bd097c36b0b6fc9274c91aa', '97b6b97bd19801ec9210c965cc920e',
|
||||||
|
'97bcf97c359801ec95f8c965cc920f', '97bd0b06bdb0722c965ce1cfcc920f', 'b027097bd097c36b0b6fc9274c91aa',
|
||||||
|
'97b6b97bd19801ec9210c965cc920e', '97bcf97c359801ec95f8c965cc920f', '97bd0b06bdb0722c965ce1cfcc920f',
|
||||||
|
'b027097bd097c36b0b6fc9274c91aa', '9778397bd19801ec9210c965cc920e', '97b6b97bd19801ec95f8c965cc920f',
|
||||||
|
'97bd09801d98082c95f8e1cfcc920f', '97bd097bd097c36b0b6fc9210c8dc2', '9778397bd197c36c9210c9274c91aa',
|
||||||
|
'97b6b97bd19801ec95f8c965cc920e', '97bd09801d98082c95f8e1cfcc920f', '97bd097bd097c36b0b6fc9210c8dc2',
|
||||||
|
'9778397bd097c36c9210c9274c91aa', '97b6b97bd19801ec95f8c965cc920e', '97bcf97c3598082c95f8e1cfcc920f',
|
||||||
|
'97bd097bd097c36b0b6fc9210c8dc2', '9778397bd097c36c9210c9274c91aa', '97b6b97bd19801ec9210c965cc920e',
|
||||||
|
'97bcf97c3598082c95f8c965cc920f', '97bd097bd097c35b0b6fc920fb0722', '9778397bd097c36b0b6fc9274c91aa',
|
||||||
|
'97b6b97bd19801ec9210c965cc920e', '97bcf97c3598082c95f8c965cc920f', '97bd097bd097c35b0b6fc920fb0722',
|
||||||
|
'9778397bd097c36b0b6fc9274c91aa', '97b6b97bd19801ec9210c965cc920e', '97bcf97c359801ec95f8c965cc920f',
|
||||||
|
'97bd097bd097c35b0b6fc920fb0722', '9778397bd097c36b0b6fc9274c91aa', '97b6b97bd19801ec9210c965cc920e',
|
||||||
|
'97bcf97c359801ec95f8c965cc920f', '97bd097bd097c35b0b6fc920fb0722', '9778397bd097c36b0b6fc9274c91aa',
|
||||||
|
'97b6b97bd19801ec9210c965cc920e', '97bcf97c359801ec95f8c965cc920f', '97bd097bd07f595b0b6fc920fb0722',
|
||||||
|
'9778397bd097c36b0b6fc9210c8dc2', '9778397bd19801ec9210c9274c920e', '97b6b97bd19801ec95f8c965cc920f',
|
||||||
|
'97bd07f5307f595b0b0bc920fb0722', '7f0e397bd097c36b0b6fc9210c8dc2', '9778397bd097c36c9210c9274c920e',
|
||||||
|
'97b6b97bd19801ec95f8c965cc920f', '97bd07f5307f595b0b0bc920fb0722', '7f0e397bd097c36b0b6fc9210c8dc2',
|
||||||
|
'9778397bd097c36c9210c9274c91aa', '97b6b97bd19801ec9210c965cc920e', '97bd07f1487f595b0b0bc920fb0722',
|
||||||
|
'7f0e397bd097c36b0b6fc9210c8dc2', '9778397bd097c36b0b6fc9274c91aa', '97b6b97bd19801ec9210c965cc920e',
|
||||||
|
'97bcf7f1487f595b0b0bb0b6fb0722', '7f0e397bd097c35b0b6fc920fb0722', '9778397bd097c36b0b6fc9274c91aa',
|
||||||
|
'97b6b97bd19801ec9210c965cc920e', '97bcf7f1487f595b0b0bb0b6fb0722', '7f0e397bd097c35b0b6fc920fb0722',
|
||||||
|
'9778397bd097c36b0b6fc9274c91aa', '97b6b97bd19801ec9210c965cc920e', '97bcf7f1487f531b0b0bb0b6fb0722',
|
||||||
|
'7f0e397bd097c35b0b6fc920fb0722', '9778397bd097c36b0b6fc9274c91aa', '97b6b97bd19801ec9210c965cc920e',
|
||||||
|
'97bcf7f1487f531b0b0bb0b6fb0722', '7f0e397bd07f595b0b6fc920fb0722', '9778397bd097c36b0b6fc9274c91aa',
|
||||||
|
'97b6b97bd19801ec9210c9274c920e', '97bcf7f0e47f531b0b0bb0b6fb0722', '7f0e397bd07f595b0b0bc920fb0722',
|
||||||
|
'9778397bd097c36b0b6fc9210c91aa', '97b6b97bd197c36c9210c9274c920e', '97bcf7f0e47f531b0b0bb0b6fb0722',
|
||||||
|
'7f0e397bd07f595b0b0bc920fb0722', '9778397bd097c36b0b6fc9210c8dc2', '9778397bd097c36c9210c9274c920e',
|
||||||
|
'97b6b7f0e47f531b0723b0b6fb0722', '7f0e37f5307f595b0b0bc920fb0722', '7f0e397bd097c36b0b6fc9210c8dc2',
|
||||||
|
'9778397bd097c36b0b70c9274c91aa', '97b6b7f0e47f531b0723b0b6fb0721', '7f0e37f1487f595b0b0bb0b6fb0722',
|
||||||
|
'7f0e397bd097c35b0b6fc9210c8dc2', '9778397bd097c36b0b6fc9274c91aa', '97b6b7f0e47f531b0723b0b6fb0721',
|
||||||
|
'7f0e27f1487f595b0b0bb0b6fb0722', '7f0e397bd097c35b0b6fc920fb0722', '9778397bd097c36b0b6fc9274c91aa',
|
||||||
|
'97b6b7f0e47f531b0723b0b6fb0721', '7f0e27f1487f531b0b0bb0b6fb0722', '7f0e397bd097c35b0b6fc920fb0722',
|
||||||
|
'9778397bd097c36b0b6fc9274c91aa', '97b6b7f0e47f531b0723b0b6fb0721', '7f0e27f1487f531b0b0bb0b6fb0722',
|
||||||
|
'7f0e397bd097c35b0b6fc920fb0722', '9778397bd097c36b0b6fc9274c91aa', '97b6b7f0e47f531b0723b0b6fb0721',
|
||||||
|
'7f0e27f1487f531b0b0bb0b6fb0722', '7f0e397bd07f595b0b0bc920fb0722', '9778397bd097c36b0b6fc9274c91aa',
|
||||||
|
'97b6b7f0e47f531b0723b0787b0721', '7f0e27f0e47f531b0b0bb0b6fb0722', '7f0e397bd07f595b0b0bc920fb0722',
|
||||||
|
'9778397bd097c36b0b6fc9210c91aa', '97b6b7f0e47f149b0723b0787b0721', '7f0e27f0e47f531b0723b0b6fb0722',
|
||||||
|
'7f0e397bd07f595b0b0bc920fb0722', '9778397bd097c36b0b6fc9210c8dc2', '977837f0e37f149b0723b0787b0721',
|
||||||
|
'7f07e7f0e47f531b0723b0b6fb0722', '7f0e37f5307f595b0b0bc920fb0722', '7f0e397bd097c35b0b6fc9210c8dc2',
|
||||||
|
'977837f0e37f14998082b0787b0721', '7f07e7f0e47f531b0723b0b6fb0721', '7f0e37f1487f595b0b0bb0b6fb0722',
|
||||||
|
'7f0e397bd097c35b0b6fc9210c8dc2', '977837f0e37f14998082b0787b06bd', '7f07e7f0e47f531b0723b0b6fb0721',
|
||||||
|
'7f0e27f1487f531b0b0bb0b6fb0722', '7f0e397bd097c35b0b6fc920fb0722', '977837f0e37f14998082b0787b06bd',
|
||||||
|
'7f07e7f0e47f531b0723b0b6fb0721', '7f0e27f1487f531b0b0bb0b6fb0722', '7f0e397bd097c35b0b6fc920fb0722',
|
||||||
|
'977837f0e37f14998082b0787b06bd', '7f07e7f0e47f531b0723b0b6fb0721', '7f0e27f1487f531b0b0bb0b6fb0722',
|
||||||
|
'7f0e397bd07f595b0b0bc920fb0722', '977837f0e37f14998082b0787b06bd', '7f07e7f0e47f531b0723b0b6fb0721',
|
||||||
|
'7f0e27f1487f531b0b0bb0b6fb0722', '7f0e397bd07f595b0b0bc920fb0722', '977837f0e37f14998082b0787b06bd',
|
||||||
|
'7f07e7f0e47f149b0723b0787b0721', '7f0e27f0e47f531b0b0bb0b6fb0722', '7f0e397bd07f595b0b0bc920fb0722',
|
||||||
|
'977837f0e37f14998082b0723b06bd', '7f07e7f0e37f149b0723b0787b0721', '7f0e27f0e47f531b0723b0b6fb0722',
|
||||||
|
'7f0e397bd07f595b0b0bc920fb0722', '977837f0e37f14898082b0723b02d5', '7ec967f0e37f14998082b0787b0721',
|
||||||
|
'7f07e7f0e47f531b0723b0b6fb0722', '7f0e37f1487f595b0b0bb0b6fb0722', '7f0e37f0e37f14898082b0723b02d5',
|
||||||
|
'7ec967f0e37f14998082b0787b0721', '7f07e7f0e47f531b0723b0b6fb0722', '7f0e37f1487f531b0b0bb0b6fb0722',
|
||||||
|
'7f0e37f0e37f14898082b0723b02d5', '7ec967f0e37f14998082b0787b06bd', '7f07e7f0e47f531b0723b0b6fb0721',
|
||||||
|
'7f0e37f1487f531b0b0bb0b6fb0722', '7f0e37f0e37f14898082b072297c35', '7ec967f0e37f14998082b0787b06bd',
|
||||||
|
'7f07e7f0e47f531b0723b0b6fb0721', '7f0e27f1487f531b0b0bb0b6fb0722', '7f0e37f0e37f14898082b072297c35',
|
||||||
|
'7ec967f0e37f14998082b0787b06bd', '7f07e7f0e47f531b0723b0b6fb0721', '7f0e27f1487f531b0b0bb0b6fb0722',
|
||||||
|
'7f0e37f0e366aa89801eb072297c35', '7ec967f0e37f14998082b0787b06bd', '7f07e7f0e47f149b0723b0787b0721',
|
||||||
|
'7f0e27f1487f531b0b0bb0b6fb0722', '7f0e37f0e366aa89801eb072297c35', '7ec967f0e37f14998082b0723b06bd',
|
||||||
|
'7f07e7f0e47f149b0723b0787b0721', '7f0e27f0e47f531b0723b0b6fb0722', '7f0e37f0e366aa89801eb072297c35',
|
||||||
|
'7ec967f0e37f14998082b0723b06bd', '7f07e7f0e37f14998083b0787b0721', '7f0e27f0e47f531b0723b0b6fb0722',
|
||||||
|
'7f0e37f0e366aa89801eb072297c35', '7ec967f0e37f14898082b0723b02d5', '7f07e7f0e37f14998082b0787b0721',
|
||||||
|
'7f07e7f0e47f531b0723b0b6fb0722', '7f0e36665b66aa89801e9808297c35', '665f67f0e37f14898082b0723b02d5',
|
||||||
|
'7ec967f0e37f14998082b0787b0721', '7f07e7f0e47f531b0723b0b6fb0722', '7f0e36665b66a449801e9808297c35',
|
||||||
|
'665f67f0e37f14898082b0723b02d5', '7ec967f0e37f14998082b0787b06bd', '7f07e7f0e47f531b0723b0b6fb0721',
|
||||||
|
'7f0e36665b66a449801e9808297c35', '665f67f0e37f14898082b072297c35', '7ec967f0e37f14998082b0787b06bd',
|
||||||
|
'7f07e7f0e47f531b0723b0b6fb0721', '7f0e26665b66a449801e9808297c35', '665f67f0e37f1489801eb072297c35',
|
||||||
|
'7ec967f0e37f14998082b0787b06bd', '7f07e7f0e47f531b0723b0b6fb0721', '7f0e27f1487f531b0b0bb0b6fb0722'
|
||||||
|
],
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 数字转中文速查表
|
||||||
|
* @Array Of Property
|
||||||
|
* @trans ['日','一','二','三','四','五','六','七','八','九','十']
|
||||||
|
* @return Cn string
|
||||||
|
*/
|
||||||
|
nStr1: ["\u65e5", "\u4e00", "\u4e8c", "\u4e09", "\u56db", "\u4e94", "\u516d", "\u4e03", "\u516b", "\u4e5d", "\u5341"],
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 日期转农历称呼速查表
|
||||||
|
* @Array Of Property
|
||||||
|
* @trans ['初','十','廿','卅']
|
||||||
|
* @return Cn string
|
||||||
|
*/
|
||||||
|
nStr2: ["\u521d", "\u5341", "\u5eff", "\u5345"],
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 月份转农历称呼速查表
|
||||||
|
* @Array Of Property
|
||||||
|
* @trans ['正','一','二','三','四','五','六','七','八','九','十','冬','腊']
|
||||||
|
* @return Cn string
|
||||||
|
*/
|
||||||
|
nStr3: ["\u6b63", "\u4e8c", "\u4e09", "\u56db", "\u4e94", "\u516d", "\u4e03", "\u516b", "\u4e5d", "\u5341", "\u51ac", "\u814a"],
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 返回农历y年一整年的总天数
|
||||||
|
* @param y lunar Year
|
||||||
|
* @return Number
|
||||||
|
* @eg:var count = calendar.lYearDays(1987) ;//count=387
|
||||||
|
*/
|
||||||
|
lYearDays: function(y) {
|
||||||
|
let i, sum = 348;
|
||||||
|
for (i = 0x8000; i > 0x8; i >>= 1) {
|
||||||
|
sum += (this.lunarInfo[y - 1900] & i) ? 1 : 0;
|
||||||
|
}
|
||||||
|
return (sum + this.leapDays(y));
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 返回农历y年闰月是哪个月;若y年没有闰月 则返回0
|
||||||
|
* @param y lunar Year
|
||||||
|
* @return Number (0-12)
|
||||||
|
* @eg:var leapMonth = calendar.leapMonth(1987) ;//leapMonth=6
|
||||||
|
*/
|
||||||
|
leapMonth: function(y) { //闰字编码 \u95f0
|
||||||
|
return (this.lunarInfo[y - 1900] & 0xf);
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 返回农历y年闰月的天数 若该年没有闰月则返回0
|
||||||
|
* @param y lunar Year
|
||||||
|
* @return Number (0、29、30)
|
||||||
|
* @eg:var leapMonthDay = calendar.leapDays(1987) ;//leapMonthDay=29
|
||||||
|
*/
|
||||||
|
leapDays: function(y) {
|
||||||
|
if (this.leapMonth(y)) {
|
||||||
|
return ((this.lunarInfo[y - 1900] & 0x10000) ? 30 : 29);
|
||||||
|
}
|
||||||
|
return (0);
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 返回农历y年m月(非闰月)的总天数,计算m为闰月时的天数请使用leapDays方法
|
||||||
|
* @param y lunar Year
|
||||||
|
* @param m lunar Month
|
||||||
|
* @return Number (-1、29、30)
|
||||||
|
* @eg:var MonthDay = calendar.monthDays(1987,9) ;//MonthDay=29
|
||||||
|
*/
|
||||||
|
monthDays: function(y, m) {
|
||||||
|
if (m > 12 || m < 1) {
|
||||||
|
return -1
|
||||||
|
} //月份参数从1至12,参数错误返回-1
|
||||||
|
return ((this.lunarInfo[y - 1900] & (0x10000 >> m)) ? 30 : 29);
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 返回公历(!)y年m月的天数
|
||||||
|
* @param y solar Year
|
||||||
|
* @param m solar Month
|
||||||
|
* @return Number (-1、28、29、30、31)
|
||||||
|
* @eg:var solarMonthDay = calendar.leapDays(1987) ;//solarMonthDay=30
|
||||||
|
*/
|
||||||
|
solarDays: function(y, m) {
|
||||||
|
if (m > 12 || m < 1) {
|
||||||
|
return -1
|
||||||
|
} //若参数错误 返回-1
|
||||||
|
const ms = m - 1;
|
||||||
|
if (ms === 1) { //2月份的闰平规律测算后确认返回28或29
|
||||||
|
return (((y % 4 === 0) && (y % 100 !== 0) || (y % 400 === 0)) ? 29 : 28);
|
||||||
|
} else {
|
||||||
|
return (this.solarMonth[ms]);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 农历年份转换为干支纪年
|
||||||
|
* @param lYear 农历年的年份数
|
||||||
|
* @return Cn string
|
||||||
|
*/
|
||||||
|
toGanZhiYear: function(lYear) {
|
||||||
|
var ganKey = (lYear - 3) % 10;
|
||||||
|
var zhiKey = (lYear - 3) % 12;
|
||||||
|
if (ganKey === 0) ganKey = 10; //如果余数为0则为最后一个天干
|
||||||
|
if (zhiKey === 0) zhiKey = 12; //如果余数为0则为最后一个地支
|
||||||
|
return this.Gan[ganKey - 1] + this.Zhi[zhiKey - 1];
|
||||||
|
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 公历月、日判断所属星座
|
||||||
|
* @param cMonth [description]
|
||||||
|
* @param cDay [description]
|
||||||
|
* @return Cn string
|
||||||
|
*/
|
||||||
|
toAstro: function(cMonth, cDay) {
|
||||||
|
const s = "\u9b54\u7faf\u6c34\u74f6\u53cc\u9c7c\u767d\u7f8a\u91d1\u725b\u53cc\u5b50\u5de8\u87f9\u72ee\u5b50\u5904\u5973\u5929\u79e4\u5929\u874e\u5c04\u624b\u9b54\u7faf";
|
||||||
|
const arr = [20, 19, 21, 21, 21, 22, 23, 23, 23, 23, 22, 22];
|
||||||
|
return s.substr(cMonth * 2 - (cDay < arr[cMonth - 1] ? 2 : 0), 2) + "\u5ea7"; //座
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 传入offset偏移量返回干支
|
||||||
|
* @param offset 相对甲子的偏移量
|
||||||
|
* @return Cn string
|
||||||
|
*/
|
||||||
|
toGanZhi: function(offset) {
|
||||||
|
return this.Gan[offset % 10] + this.Zhi[offset % 12];
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 传入公历(!)y年获得该年第n个节气的公历日期
|
||||||
|
* @param y y公历年(1900-2100)
|
||||||
|
* @param n n二十四节气中的第几个节气(1~24);从n=1(小寒)算起
|
||||||
|
* @return day Number
|
||||||
|
* @eg:var _24 = calendar.getTerm(1987,3) ;//_24=4;意即1987年2月4日立春
|
||||||
|
*/
|
||||||
|
getTerm: function(y, n) {
|
||||||
|
if (y < 1900 || y > 2100) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
if (n < 1 || n > 24) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
const _table = this.sTermInfo[y - 1900];
|
||||||
|
const _info = [
|
||||||
|
parseInt('0x' + _table.substr(0, 5)).toString(),
|
||||||
|
parseInt('0x' + _table.substr(5, 5)).toString(),
|
||||||
|
parseInt('0x' + _table.substr(10, 5)).toString(),
|
||||||
|
parseInt('0x' + _table.substr(15, 5)).toString(),
|
||||||
|
parseInt('0x' + _table.substr(20, 5)).toString(),
|
||||||
|
parseInt('0x' + _table.substr(25, 5)).toString()
|
||||||
|
];
|
||||||
|
const _calcDay = [
|
||||||
|
_info[0].substr(0, 1),
|
||||||
|
_info[0].substr(1, 2),
|
||||||
|
_info[0].substr(3, 1),
|
||||||
|
_info[0].substr(4, 2),
|
||||||
|
|
||||||
|
_info[1].substr(0, 1),
|
||||||
|
_info[1].substr(1, 2),
|
||||||
|
_info[1].substr(3, 1),
|
||||||
|
_info[1].substr(4, 2),
|
||||||
|
|
||||||
|
_info[2].substr(0, 1),
|
||||||
|
_info[2].substr(1, 2),
|
||||||
|
_info[2].substr(3, 1),
|
||||||
|
_info[2].substr(4, 2),
|
||||||
|
|
||||||
|
_info[3].substr(0, 1),
|
||||||
|
_info[3].substr(1, 2),
|
||||||
|
_info[3].substr(3, 1),
|
||||||
|
_info[3].substr(4, 2),
|
||||||
|
|
||||||
|
_info[4].substr(0, 1),
|
||||||
|
_info[4].substr(1, 2),
|
||||||
|
_info[4].substr(3, 1),
|
||||||
|
_info[4].substr(4, 2),
|
||||||
|
|
||||||
|
_info[5].substr(0, 1),
|
||||||
|
_info[5].substr(1, 2),
|
||||||
|
_info[5].substr(3, 1),
|
||||||
|
_info[5].substr(4, 2),
|
||||||
|
];
|
||||||
|
return parseInt(_calcDay[n - 1]);
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 传入农历数字月份返回汉语通俗表示法
|
||||||
|
* @param m lunar month
|
||||||
|
* @return Cn string
|
||||||
|
* @eg:var cnMonth = calendar.toChinaMonth(12) ;//cnMonth='腊月'
|
||||||
|
*/
|
||||||
|
toChinaMonth: function(m) { // 月 => \u6708
|
||||||
|
if (m > 12 || m < 1) {
|
||||||
|
return -1
|
||||||
|
} //若参数错误 返回-1
|
||||||
|
let s = this.nStr3[m - 1];
|
||||||
|
s += "\u6708"; //加上月字
|
||||||
|
return s;
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 传入农历日期数字返回汉字表示法
|
||||||
|
* @param d lunar day
|
||||||
|
* @return Cn string
|
||||||
|
* @eg:var cnDay = calendar.toChinaDay(21) ;//cnMonth='廿一'
|
||||||
|
*/
|
||||||
|
toChinaDay: function(d) { //日 => \u65e5
|
||||||
|
let s;
|
||||||
|
switch (d) {
|
||||||
|
case 10:
|
||||||
|
s = '\u521d\u5341';
|
||||||
|
break;
|
||||||
|
case 20:
|
||||||
|
s = '\u4e8c\u5341';
|
||||||
|
break;
|
||||||
|
case 30:
|
||||||
|
s = '\u4e09\u5341';
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
s = this.nStr2[Math.floor(d / 10)];
|
||||||
|
s += this.nStr1[d % 10];
|
||||||
|
}
|
||||||
|
return (s);
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 年份转生肖[!仅能大致转换] => 精确划分生肖分界线是“立春”
|
||||||
|
* @param y year
|
||||||
|
* @return Cn string
|
||||||
|
* @eg:var animal = calendar.getAnimal(1987) ;//animal='兔'
|
||||||
|
*/
|
||||||
|
getAnimal: function(y) {
|
||||||
|
return this.Animals[(y - 4) % 12]
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 传入阳历年月日获得详细的公历、农历object信息 <=>JSON
|
||||||
|
* !important! 公历参数区间1900.1.31~2100.12.31
|
||||||
|
* @param yPara solar year
|
||||||
|
* @param mPara solar month
|
||||||
|
* @param dPara solar day
|
||||||
|
* @return JSON object
|
||||||
|
* @eg:console.log(calendar.solar2lunar(1987,11,01));
|
||||||
|
*/
|
||||||
|
solar2lunar: function(yPara, mPara, dPara) {
|
||||||
|
let y = parseInt(yPara);
|
||||||
|
let m = parseInt(mPara);
|
||||||
|
let d = parseInt(dPara);
|
||||||
|
//年份限定、上限
|
||||||
|
if (y < 1900 || y > 2100) {
|
||||||
|
return -1; // undefined转换为数字变为NaN
|
||||||
|
}
|
||||||
|
//公历传参最下限
|
||||||
|
if (y === 1900 && m === 1 && d < 31) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
//未传参 获得当天
|
||||||
|
let objDate;
|
||||||
|
if (!y) {
|
||||||
|
objDate = new Date();
|
||||||
|
} else {
|
||||||
|
objDate = new Date(y, parseInt(m) - 1, d);
|
||||||
|
}
|
||||||
|
let i, leap = 0,
|
||||||
|
temp = 0;
|
||||||
|
//修正ymd参数
|
||||||
|
y = objDate.getFullYear();
|
||||||
|
m = objDate.getMonth() + 1;
|
||||||
|
d = objDate.getDate();
|
||||||
|
let offset = (Date.UTC(objDate.getFullYear(), objDate.getMonth(), objDate.getDate()) - Date.UTC(1900, 0, 31)) / 86400000;
|
||||||
|
for (i = 1900; i < 2101 && offset > 0; i++) {
|
||||||
|
temp = this.lYearDays(i);
|
||||||
|
offset -= temp;
|
||||||
|
}
|
||||||
|
if (offset < 0) {
|
||||||
|
offset += temp;
|
||||||
|
i--;
|
||||||
|
}
|
||||||
|
|
||||||
|
//是否今天
|
||||||
|
let isTodayObj = new Date(),
|
||||||
|
isToday = false;
|
||||||
|
if (isTodayObj.getFullYear() === y && isTodayObj.getMonth() + 1 === m && isTodayObj.getDate() === d) {
|
||||||
|
isToday = true;
|
||||||
|
}
|
||||||
|
//星期几
|
||||||
|
let nWeek = objDate.getDay(),
|
||||||
|
cWeek = this.nStr1[nWeek];
|
||||||
|
//数字表示周几顺应天朝周一开始的惯例
|
||||||
|
if (nWeek === 0) {
|
||||||
|
nWeek = 7;
|
||||||
|
}
|
||||||
|
//农历年
|
||||||
|
const year = i;
|
||||||
|
leap = this.leapMonth(i); //闰哪个月
|
||||||
|
let isLeap = false;
|
||||||
|
|
||||||
|
//效验闰月
|
||||||
|
for (i = 1; i < 13 && offset > 0; i++) {
|
||||||
|
//闰月
|
||||||
|
if (leap > 0 && i === (leap + 1) && isLeap === false) {
|
||||||
|
--i;
|
||||||
|
isLeap = true;
|
||||||
|
temp = this.leapDays(year); //计算农历闰月天数
|
||||||
|
} else {
|
||||||
|
temp = this.monthDays(year, i); //计算农历普通月天数
|
||||||
|
}
|
||||||
|
//解除闰月
|
||||||
|
if (isLeap === true && i === (leap + 1)) {
|
||||||
|
isLeap = false;
|
||||||
|
}
|
||||||
|
offset -= temp;
|
||||||
|
}
|
||||||
|
// 闰月导致数组下标重叠取反
|
||||||
|
if (offset === 0 && leap > 0 && i === leap + 1) {
|
||||||
|
if (isLeap) {
|
||||||
|
isLeap = false;
|
||||||
|
} else {
|
||||||
|
isLeap = true;
|
||||||
|
--i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (offset < 0) {
|
||||||
|
offset += temp;
|
||||||
|
--i;
|
||||||
|
}
|
||||||
|
//农历月
|
||||||
|
const month = i;
|
||||||
|
//农历日
|
||||||
|
const day = offset + 1;
|
||||||
|
//天干地支处理
|
||||||
|
const sm = m - 1;
|
||||||
|
const gzY = this.toGanZhiYear(year);
|
||||||
|
|
||||||
|
// 当月的两个节气
|
||||||
|
// bugfix-2017-7-24 11:03:38 use lunar Year Param `y` Not `year`
|
||||||
|
const firstNode = this.getTerm(y, (m * 2 - 1)); //返回当月「节」为几日开始
|
||||||
|
const secondNode = this.getTerm(y, (m * 2)); //返回当月「节」为几日开始
|
||||||
|
|
||||||
|
// 依据12节气修正干支月
|
||||||
|
let gzM = this.toGanZhi((y - 1900) * 12 + m + 11);
|
||||||
|
if (d >= firstNode) {
|
||||||
|
gzM = this.toGanZhi((y - 1900) * 12 + m + 12);
|
||||||
|
}
|
||||||
|
|
||||||
|
//传入的日期的节气与否
|
||||||
|
let isTerm = false;
|
||||||
|
let Term = null;
|
||||||
|
if (firstNode === d) {
|
||||||
|
isTerm = true;
|
||||||
|
Term = this.solarTerm[m * 2 - 2];
|
||||||
|
}
|
||||||
|
if (secondNode === d) {
|
||||||
|
isTerm = true;
|
||||||
|
Term = this.solarTerm[m * 2 - 1];
|
||||||
|
}
|
||||||
|
//日柱 当月一日与 1900/1/1 相差天数
|
||||||
|
const dayCyclical = Date.UTC(y, sm, 1, 0, 0, 0, 0) / 86400000 + 25567 + 10;
|
||||||
|
const gzD = this.toGanZhi(dayCyclical + d - 1);
|
||||||
|
//该日期所属的星座
|
||||||
|
const astro = this.toAstro(m, d);
|
||||||
|
|
||||||
|
const solarDate = y + '-' + m + '-' + d;
|
||||||
|
const lunarDate = year + '-' + month + '-' + day;
|
||||||
|
|
||||||
|
const festival = this.festival;
|
||||||
|
const lFestival = this.lFestival;
|
||||||
|
|
||||||
|
const festivalDate = m + '-' + d;
|
||||||
|
const lunarFestivalDate = month + '-' + day;
|
||||||
|
|
||||||
|
return {
|
||||||
|
date: solarDate,
|
||||||
|
lunarDate: lunarDate,
|
||||||
|
festival: festival[festivalDate] ? festival[festivalDate].title : null,
|
||||||
|
lunarFestival: lFestival[lunarFestivalDate] ? lFestival[lunarFestivalDate].title : null,
|
||||||
|
'lYear': year,
|
||||||
|
'lMonth': month,
|
||||||
|
'lDay': day,
|
||||||
|
'Animal': this.getAnimal(year),
|
||||||
|
'IMonthCn': (isLeap ? "\u95f0" : '') + this.toChinaMonth(month),
|
||||||
|
'IDayCn': this.toChinaDay(day),
|
||||||
|
'cYear': y,
|
||||||
|
'cMonth': m,
|
||||||
|
'cDay': d,
|
||||||
|
'gzYear': gzY,
|
||||||
|
'gzMonth': gzM,
|
||||||
|
'gzDay': gzD,
|
||||||
|
'isToday': isToday,
|
||||||
|
'isLeap': isLeap,
|
||||||
|
'nWeek': nWeek,
|
||||||
|
'ncWeek': "\u661f\u671f" + cWeek,
|
||||||
|
'isTerm': isTerm,
|
||||||
|
'Term': Term,
|
||||||
|
'astro': astro
|
||||||
|
};
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 传入农历年月日以及传入的月份是否闰月获得详细的公历、农历object信息 <=>JSON
|
||||||
|
* !important! 参数区间1900.1.31~2100.12.1
|
||||||
|
* @param y lunar year
|
||||||
|
* @param m lunar month
|
||||||
|
* @param d lunar day
|
||||||
|
* @param isLeapMonth lunar month is leap or not.[如果是农历闰月第四个参数赋值true即可]
|
||||||
|
* @return JSON object
|
||||||
|
* @eg:console.log(calendar.lunar2solar(1987,9,10));
|
||||||
|
*/
|
||||||
|
lunar2solar: function(y, m, d, isLeapMonth) {
|
||||||
|
y = parseInt(y)
|
||||||
|
m = parseInt(m)
|
||||||
|
d = parseInt(d)
|
||||||
|
isLeapMonth = !!isLeapMonth;
|
||||||
|
const leapOffset = 0;
|
||||||
|
const leapMonth = this.leapMonth(y);
|
||||||
|
const leapDay = this.leapDays(y);
|
||||||
|
if (isLeapMonth && (leapMonth !== m)) {
|
||||||
|
return -1;
|
||||||
|
} //传参要求计算该闰月公历 但该年得出的闰月与传参的月份并不同
|
||||||
|
if (y === 2100 && m === 12 && d > 1 || y === 1900 && m === 1 && d < 31) {
|
||||||
|
return -1;
|
||||||
|
} //超出了最大极限值
|
||||||
|
const day = this.monthDays(y, m);
|
||||||
|
let _day = day;
|
||||||
|
//bugFix 2016-9-25
|
||||||
|
//if month is leap, _day use leapDays method
|
||||||
|
if (isLeapMonth) {
|
||||||
|
_day = this.leapDays(y, m);
|
||||||
|
}
|
||||||
|
if (y < 1900 || y > 2100 || d > _day) {
|
||||||
|
return -1;
|
||||||
|
} //参数合法性效验
|
||||||
|
|
||||||
|
//计算农历的时间差
|
||||||
|
let offset = 0;
|
||||||
|
let i;
|
||||||
|
for (i = 1900; i < y; i++) {
|
||||||
|
offset += this.lYearDays(i);
|
||||||
|
}
|
||||||
|
let leap = 0,
|
||||||
|
isAdd = false;
|
||||||
|
for (i = 1; i < m; i++) {
|
||||||
|
leap = this.leapMonth(y);
|
||||||
|
if (!isAdd) { //处理闰月
|
||||||
|
if (leap <= i && leap > 0) {
|
||||||
|
offset += this.leapDays(y);
|
||||||
|
isAdd = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
offset += this.monthDays(y, i);
|
||||||
|
}
|
||||||
|
//转换闰月农历 需补充该年闰月的前一个月的时差
|
||||||
|
if (isLeapMonth) {
|
||||||
|
offset += day;
|
||||||
|
}
|
||||||
|
//1900年农历正月一日的公历时间为1900年1月30日0时0分0秒(该时间也是本农历的最开始起始点)
|
||||||
|
const strap = Date.UTC(1900, 1, 30, 0, 0, 0);
|
||||||
|
const calObj = new Date((offset + d - 31) * 86400000 + strap);
|
||||||
|
const cY = calObj.getUTCFullYear();
|
||||||
|
const cM = calObj.getUTCMonth() + 1;
|
||||||
|
const cD = calObj.getUTCDate();
|
||||||
|
|
||||||
|
return this.solar2lunar(cY, cM, cD);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export default calendar
|
||||||
@ -18,7 +18,7 @@
|
|||||||
></el-date-picker>
|
></el-date-picker>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="操作类型" prop="patientName" label-width="80px">
|
<el-form-item label="操作类型" prop="patientName" label-width="80px">
|
||||||
<el-select v-model="loginType" placeholder="请选择订单状态" clearable>
|
<el-select v-model="loginType" placeholder="请选择操作类型" clearable>
|
||||||
<el-option
|
<el-option
|
||||||
v-for="item in loginTypelist"
|
v-for="item in loginTypelist"
|
||||||
:key="item.value"
|
:key="item.value"
|
||||||
@ -54,7 +54,6 @@
|
|||||||
:limit.sync="pageSize"
|
:limit.sync="pageSize"
|
||||||
@pagination="getlist"
|
@pagination="getlist"
|
||||||
/>
|
/>
|
||||||
|
|
||||||
<el-dialog width="900px" title="学生信息" :visible.sync="studentInfoshow" append-to-body>
|
<el-dialog width="900px" title="学生信息" :visible.sync="studentInfoshow" append-to-body>
|
||||||
<el-table :data="studentInfoList">
|
<el-table :data="studentInfoList">
|
||||||
<el-table-column property="kindergartenName" label="幼儿园名称" align="center"></el-table-column>
|
<el-table-column property="kindergartenName" label="幼儿园名称" align="center"></el-table-column>
|
||||||
@ -140,8 +139,8 @@ export default {
|
|||||||
pageSize: 10,
|
pageSize: 10,
|
||||||
parentInfoId: "",
|
parentInfoId: "",
|
||||||
classId: "",
|
classId: "",
|
||||||
startDate: null,
|
startDate: "",
|
||||||
endDate: null,
|
endDate: "",
|
||||||
loginType: "",
|
loginType: "",
|
||||||
list: [],
|
list: [],
|
||||||
total: 0,
|
total: 0,
|
||||||
@ -164,20 +163,20 @@ export default {
|
|||||||
date: nowDate.getDate() //获取当前日期
|
date: nowDate.getDate() //获取当前日期
|
||||||
};
|
};
|
||||||
//拼接
|
//拼接
|
||||||
if (dates.month < 10) {
|
// if (dates.month < 10) {
|
||||||
this.startDate = dates.year + "-0" + dates.month;
|
// this.startDate = dates.year + "-0" + dates.month;
|
||||||
this.endDate = dates.year + "-0" + dates.month;
|
// this.endDate = dates.year + "-0" + dates.month;
|
||||||
} else {
|
// } else {
|
||||||
this.startDate = dates.year + "." + dates.month;
|
// this.startDate = dates.year + "." + dates.month;
|
||||||
this.endDate = dates.year + "-" + dates.month;
|
// this.endDate = dates.year + "-" + dates.month;
|
||||||
}
|
// }
|
||||||
if (dates.date < 10) {
|
// if (dates.date < 10) {
|
||||||
this.startDate = this.startDate + "-0" + dates.date;
|
// this.startDate = this.startDate + "-0" + dates.date;
|
||||||
this.endDate = this.endDate + "-0" + dates.date;
|
// this.endDate = this.endDate + "-0" + dates.date;
|
||||||
} else {
|
// } else {
|
||||||
this.startDate = this.startDate + "-" + dates.date;
|
// this.startDate = this.startDate + "-" + dates.date;
|
||||||
this.endDate = this.endDate + "-" + dates.date;
|
// this.endDate = this.endDate + "-" + dates.date;
|
||||||
}
|
// }
|
||||||
},
|
},
|
||||||
//名下学生
|
//名下学生
|
||||||
getStudent(e) {
|
getStudent(e) {
|
||||||
@ -210,7 +209,6 @@ export default {
|
|||||||
this.loginType = "";
|
this.loginType = "";
|
||||||
this.valuetime = "";
|
this.valuetime = "";
|
||||||
this.$refs.resets.reset();
|
this.$refs.resets.reset();
|
||||||
this.$refs.kinresets.reset();
|
|
||||||
this.$refs.classe.reset();
|
this.$refs.classe.reset();
|
||||||
this.getlist();
|
this.getlist();
|
||||||
},
|
},
|
||||||
|
|||||||
223
src/views/system/Personalstatistics/index.vue
Normal file
223
src/views/system/Personalstatistics/index.vue
Normal file
@ -0,0 +1,223 @@
|
|||||||
|
<template>
|
||||||
|
<div class="app-container">
|
||||||
|
<!-- <kindergarlog @kinbatlist="kinbatlist" style="width: 500px; display: inline;" ref="kinresets"></kindergarlog> -->
|
||||||
|
<classe @classelist="classelist" style="width: 500px; display: inline;" ref="classe"></classe>
|
||||||
|
<parent @parentlist="parentlist" style="width: 500px; display: inline;" ref="resets"></parent>
|
||||||
|
<el-form size="small" :inline="true" v-show="showSearch">
|
||||||
|
<el-form-item label="日期" prop="orderStatus" label-width="60px">
|
||||||
|
<el-date-picker
|
||||||
|
v-model="valuetime"
|
||||||
|
type="daterange"
|
||||||
|
align="right"
|
||||||
|
@change="monthStartEndTimechange"
|
||||||
|
unlink-panels
|
||||||
|
range-separator="至"
|
||||||
|
start-placeholder="开始日期"
|
||||||
|
end-placeholder="结束日期"
|
||||||
|
:picker-options="pickerOptions"
|
||||||
|
></el-date-picker>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item>
|
||||||
|
<el-button type="primary" icon="el-icon-search" size="mini" @click="getlist">搜索</el-button>
|
||||||
|
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
|
||||||
|
</el-form-item>
|
||||||
|
</el-form>
|
||||||
|
<el-table v-loading="loading" :data="list">
|
||||||
|
<el-table-column label="家长姓名" align="center" prop="parentName">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<el-button type="text" @click="getStudent(scope.row)">{{scope.row.parentName}}</el-button>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
<el-table-column label="登录次数" align="center" prop="loginCount" />
|
||||||
|
<el-table-column label="运动处方查看次数" align="center" prop="prescriptionCount" />
|
||||||
|
<el-table-column label="处方视频查看次数" align="center" prop="prescriptionVideoCount" />
|
||||||
|
</el-table>
|
||||||
|
<pagination
|
||||||
|
v-show="total > 0"
|
||||||
|
:total="total"
|
||||||
|
:page.sync="pageNum"
|
||||||
|
:limit.sync="pageSize"
|
||||||
|
@pagination="getlist"
|
||||||
|
/>
|
||||||
|
<el-dialog width="900px" title="学生信息" :visible.sync="studentInfoshow" append-to-body>
|
||||||
|
<el-table :data="studentInfoList">
|
||||||
|
<el-table-column property="kindergartenName" label="幼儿园名称" align="center"></el-table-column>
|
||||||
|
<el-table-column property="className" label="班级名称" align="center"></el-table-column>
|
||||||
|
<el-table-column property="classTeacher" label="班主任姓名" align="center"></el-table-column>
|
||||||
|
<el-table-column property="classPhone" label="联系电话" align="center"></el-table-column>
|
||||||
|
<el-table-column property="studentName" label="学生姓名" align="center"></el-table-column>
|
||||||
|
<el-table-column property="studentAge" label="学生年龄" align="center"></el-table-column>
|
||||||
|
<el-table-column property="studentSex" label="学生性别" align="center">
|
||||||
|
<template slot-scope="scope">
|
||||||
|
{{scope.row.studentSex=='MALE'?'男':''}}
|
||||||
|
{{scope.row.studentSex=='FEMALE'?'女':''}}
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
</el-table>
|
||||||
|
<div slot="footer" class="dialog-footer">
|
||||||
|
<el-button type="primary" @click="studentInfoshow=false">确 定</el-button>
|
||||||
|
</div>
|
||||||
|
</el-dialog>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
<script>
|
||||||
|
import { appletPersonCount } from "@/api/system/Personalstatistics";
|
||||||
|
import { getParentAndStudentInfo } from "@/api/system/AppletAccessLog";
|
||||||
|
import kindergarlog from "../../assembly/kindergarlog.vue";
|
||||||
|
import classe from "../../assembly/classe.vue";
|
||||||
|
import parent from "../../assembly/parent.vue";
|
||||||
|
export default {
|
||||||
|
name: "Personalstatistics",
|
||||||
|
components: { kindergarlog, classe, parent },
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
pickerOptions: {
|
||||||
|
shortcuts: [
|
||||||
|
{
|
||||||
|
text: "最近一周",
|
||||||
|
onClick(picker) {
|
||||||
|
const end = new Date();
|
||||||
|
const start = new Date();
|
||||||
|
start.setTime(start.getTime() - 3600 * 1000 * 24 * 7);
|
||||||
|
picker.$emit("pick", [start, end]);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
text: "最近一个月",
|
||||||
|
onClick(picker) {
|
||||||
|
const end = new Date();
|
||||||
|
const start = new Date();
|
||||||
|
start.setTime(start.getTime() - 3600 * 1000 * 24 * 30);
|
||||||
|
picker.$emit("pick", [start, end]);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
text: "最近三个月",
|
||||||
|
onClick(picker) {
|
||||||
|
const end = new Date();
|
||||||
|
const start = new Date();
|
||||||
|
start.setTime(start.getTime() - 3600 * 1000 * 24 * 90);
|
||||||
|
picker.$emit("pick", [start, end]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
valuetime: "",
|
||||||
|
loading: false,
|
||||||
|
showSearch: true, // 显示搜索条件
|
||||||
|
pageNum: 1,
|
||||||
|
pageSize: 10,
|
||||||
|
parentInfoId: "",
|
||||||
|
classId: "",
|
||||||
|
startDate: "",
|
||||||
|
endDate: "",
|
||||||
|
list: [],
|
||||||
|
total: 0,
|
||||||
|
studentInfoList: [], //名下幼儿园
|
||||||
|
studentInfoshow: false
|
||||||
|
};
|
||||||
|
},
|
||||||
|
created() {
|
||||||
|
this.newtime();
|
||||||
|
this.getlist();
|
||||||
|
},
|
||||||
|
mounted() {},
|
||||||
|
methods: {
|
||||||
|
//名下学生
|
||||||
|
getStudent(e) {
|
||||||
|
this.studentInfoList = [];
|
||||||
|
getParentAndStudentInfo(e.parentInfoId).then(res => {
|
||||||
|
this.studentInfoList = res.data.studentInfoList;
|
||||||
|
this.studentInfoshow = true;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
//获取list
|
||||||
|
getlist() {
|
||||||
|
appletPersonCount(
|
||||||
|
this.pageNum,
|
||||||
|
this.pageSize,
|
||||||
|
this.parentInfoId,
|
||||||
|
this.classId,
|
||||||
|
this.startDate,
|
||||||
|
this.endDate
|
||||||
|
).then(res => {
|
||||||
|
this.list = res.rows;
|
||||||
|
this.total = res.total;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
//重置
|
||||||
|
resetQuery() {
|
||||||
|
this.newtime();
|
||||||
|
this.parentInfoId = "";
|
||||||
|
this.classId = "";
|
||||||
|
this.valuetime = "";
|
||||||
|
this.$refs.resets.reset();
|
||||||
|
this.$refs.classe.reset();
|
||||||
|
this.getlist();
|
||||||
|
},
|
||||||
|
//选择时期区间
|
||||||
|
monthStartEndTimechange(e) {
|
||||||
|
this.startDate = this.formatDate(new Date(e[0]).getTime());
|
||||||
|
this.endDate = this.formatDate(new Date(e[1]).getTime());
|
||||||
|
},
|
||||||
|
//幼儿园
|
||||||
|
kinbatlist(e) {
|
||||||
|
console.log(e);
|
||||||
|
},
|
||||||
|
//家长
|
||||||
|
parentlist(e) {
|
||||||
|
this.parentInfoId = e;
|
||||||
|
},
|
||||||
|
//班级
|
||||||
|
classelist(e) {
|
||||||
|
this.classId = e;
|
||||||
|
},
|
||||||
|
//今天的时间
|
||||||
|
newtime() {
|
||||||
|
let nowDate = new Date();
|
||||||
|
let dates = {
|
||||||
|
year: nowDate.getFullYear(), // 获取当前年份
|
||||||
|
month: nowDate.getMonth() + 1, //获取当前月份
|
||||||
|
date: nowDate.getDate() //获取当前日期
|
||||||
|
};
|
||||||
|
// //拼接
|
||||||
|
// if (dates.month < 10) {
|
||||||
|
// this.startDate = dates.year + "-0" + dates.month;
|
||||||
|
// this.endDate = dates.year + "-0" + dates.month;
|
||||||
|
// } else {
|
||||||
|
// this.startDate = dates.year + "." + dates.month;
|
||||||
|
// this.endDate = dates.year + "-" + dates.month;
|
||||||
|
// }
|
||||||
|
// if (dates.date < 10) {
|
||||||
|
// this.startDate = this.startDate + "-0" + dates.date;
|
||||||
|
// this.endDate = this.endDate + "-0" + dates.date;
|
||||||
|
// } else {
|
||||||
|
// this.startDate = this.startDate + "-" + dates.date;
|
||||||
|
// this.endDate = this.endDate + "-" + dates.date;
|
||||||
|
// }
|
||||||
|
},
|
||||||
|
formatDate(time, timetype) {
|
||||||
|
let date = new Date(time); //13位时间戳
|
||||||
|
//let date = new Date(parseInt(time) * 1000); //10位时间戳
|
||||||
|
let y = date.getFullYear();
|
||||||
|
let MM = date.getMonth() + 1;
|
||||||
|
MM = MM < 10 ? "0" + MM : MM;
|
||||||
|
let d = date.getDate();
|
||||||
|
d = d < 10 ? "0" + d : d;
|
||||||
|
return y + "-" + MM + "-" + d;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
<style lang='scss' scoped>
|
||||||
|
.app-container {
|
||||||
|
padding: 20px 0 20px 10px;
|
||||||
|
}
|
||||||
|
::v-deep .el-card__header {
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
::v-deep .el-form {
|
||||||
|
display: inline;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
176
src/views/system/StatisticsArea/index.vue
Normal file
176
src/views/system/StatisticsArea/index.vue
Normal file
@ -0,0 +1,176 @@
|
|||||||
|
<template>
|
||||||
|
<div class="app-container">
|
||||||
|
<el-form size="small" :inline="true" v-show="showSearch">
|
||||||
|
<el-form-item label="日期" prop="orderStatus" label-width="60px">
|
||||||
|
<el-date-picker
|
||||||
|
v-model="valuetime"
|
||||||
|
type="daterange"
|
||||||
|
align="right"
|
||||||
|
@change="monthStartEndTimechange"
|
||||||
|
unlink-panels
|
||||||
|
range-separator="至"
|
||||||
|
start-placeholder="开始日期"
|
||||||
|
end-placeholder="结束日期"
|
||||||
|
:picker-options="pickerOptions"
|
||||||
|
></el-date-picker>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item>
|
||||||
|
<el-button type="primary" icon="el-icon-search" size="mini" @click="getlist">搜索</el-button>
|
||||||
|
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
|
||||||
|
</el-form-item>
|
||||||
|
</el-form>
|
||||||
|
<el-table v-loading="loading" :data="list">
|
||||||
|
<el-table-column label="区县名称" align="center" prop="areaName"></el-table-column>
|
||||||
|
<el-table-column label="登录次数" align="center" prop="loginCount" />
|
||||||
|
<el-table-column label="运动处方查看次数" align="center" prop="prescriptionCount" />
|
||||||
|
<el-table-column label="处方视频查看次数" align="center" prop="prescriptionVideoCount" />
|
||||||
|
</el-table>
|
||||||
|
<pagination
|
||||||
|
v-show="total > 0"
|
||||||
|
:total="total"
|
||||||
|
:page.sync="query.pageNum"
|
||||||
|
:limit.sync="query.pageSize"
|
||||||
|
@pagination="getlist"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
<script>
|
||||||
|
import { countyStatistic } from "@/api/system/StatisticsArea";
|
||||||
|
import { getInfo } from "@/api/login";
|
||||||
|
export default {
|
||||||
|
name: "StatisticsArea",
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
pickerOptions: {
|
||||||
|
shortcuts: [
|
||||||
|
{
|
||||||
|
text: "最近一周",
|
||||||
|
onClick(picker) {
|
||||||
|
const end = new Date();
|
||||||
|
const start = new Date();
|
||||||
|
start.setTime(start.getTime() - 3600 * 1000 * 24 * 7);
|
||||||
|
picker.$emit("pick", [start, end]);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
text: "最近一个月",
|
||||||
|
onClick(picker) {
|
||||||
|
const end = new Date();
|
||||||
|
const start = new Date();
|
||||||
|
start.setTime(start.getTime() - 3600 * 1000 * 24 * 30);
|
||||||
|
picker.$emit("pick", [start, end]);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
text: "最近三个月",
|
||||||
|
onClick(picker) {
|
||||||
|
const end = new Date();
|
||||||
|
const start = new Date();
|
||||||
|
start.setTime(start.getTime() - 3600 * 1000 * 24 * 90);
|
||||||
|
picker.$emit("pick", [start, end]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
valuetime: "",
|
||||||
|
loading: false,
|
||||||
|
showSearch: true, // 显示搜索条件
|
||||||
|
list: [],
|
||||||
|
total: 0,
|
||||||
|
query: {
|
||||||
|
pageNum: 1,
|
||||||
|
pageSize: 10,
|
||||||
|
areaId: "",
|
||||||
|
startDate: "",
|
||||||
|
endDate: ""
|
||||||
|
}
|
||||||
|
};
|
||||||
|
},
|
||||||
|
created() {
|
||||||
|
this.newtime();
|
||||||
|
this.Userinfo();
|
||||||
|
},
|
||||||
|
mounted() {},
|
||||||
|
methods: {
|
||||||
|
//获取list
|
||||||
|
getlist() {
|
||||||
|
countyStatistic(
|
||||||
|
this.query.pageNum,
|
||||||
|
this.query.pageSize,
|
||||||
|
this.query.areaId,
|
||||||
|
this.query.startDate,
|
||||||
|
this.query.endDate
|
||||||
|
).then(res => {
|
||||||
|
this.list = res.rows;
|
||||||
|
this.total = res.total;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
//用户信息
|
||||||
|
Userinfo() {
|
||||||
|
getInfo().then(res => {
|
||||||
|
if (res.user.areaId) {
|
||||||
|
this.query.areaId = res.user.areaId;
|
||||||
|
}
|
||||||
|
this.getlist();
|
||||||
|
});
|
||||||
|
},
|
||||||
|
//今天的时间
|
||||||
|
newtime() {
|
||||||
|
let nowDate = new Date();
|
||||||
|
let dates = {
|
||||||
|
year: nowDate.getFullYear(), // 获取当前年份
|
||||||
|
month: nowDate.getMonth() + 1, //获取当前月份
|
||||||
|
date: nowDate.getDate() //获取当前日期
|
||||||
|
};
|
||||||
|
// //拼接
|
||||||
|
// if (dates.month < 10) {
|
||||||
|
// this.query.startDate = dates.year + "-0" + dates.month;
|
||||||
|
// this.query.endDate = dates.year + "-0" + dates.month;
|
||||||
|
// } else {
|
||||||
|
// this.query.startDate = dates.year + "." + dates.month;
|
||||||
|
// this.query.endDate = dates.year + "-" + dates.month;
|
||||||
|
// }
|
||||||
|
// if (dates.date < 10) {
|
||||||
|
// this.query.startDate = this.startDate + "-0" + dates.date;
|
||||||
|
// this.query.endDate = this.endDate + "-0" + dates.date;
|
||||||
|
// } else {
|
||||||
|
// this.query.startDate = this.startDate + "-" + dates.date;
|
||||||
|
// this.query.endDate = this.endDate + "-" + dates.date;
|
||||||
|
// }
|
||||||
|
},
|
||||||
|
//重置
|
||||||
|
resetQuery() {
|
||||||
|
this.newtime();
|
||||||
|
this.valuetime = "";
|
||||||
|
this.getlist();
|
||||||
|
},
|
||||||
|
//选择时期区间
|
||||||
|
monthStartEndTimechange(e) {
|
||||||
|
this.query.startDate = this.formatDate(new Date(e[0]).getTime());
|
||||||
|
this.query.endDate = this.formatDate(new Date(e[1]).getTime());
|
||||||
|
},
|
||||||
|
formatDate(time, timetype) {
|
||||||
|
let date = new Date(time); //13位时间戳
|
||||||
|
//let date = new Date(parseInt(time) * 1000); //10位时间戳
|
||||||
|
let y = date.getFullYear();
|
||||||
|
let MM = date.getMonth() + 1;
|
||||||
|
MM = MM < 10 ? "0" + MM : MM;
|
||||||
|
let d = date.getDate();
|
||||||
|
d = d < 10 ? "0" + d : d;
|
||||||
|
return y + "-" + MM + "-" + d;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
<style lang='scss' scoped>
|
||||||
|
.app-container {
|
||||||
|
padding: 20px 0 20px 10px;
|
||||||
|
}
|
||||||
|
::v-deep .el-card__header {
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
::v-deep .el-form {
|
||||||
|
display: inline;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
531
src/views/system/StatisticsParent/index.vue
Normal file
531
src/views/system/StatisticsParent/index.vue
Normal file
@ -0,0 +1,531 @@
|
|||||||
|
<template>
|
||||||
|
<div class="app-container">
|
||||||
|
<classe @classelist="classelist" style="width: 500px; display: inline;" ref="classe"></classe>
|
||||||
|
<parent @parentlist="parentlist" style="width: 500px; display: inline;" ref="resets"></parent>
|
||||||
|
<el-form size="small" :inline="true" v-show="showSearch">
|
||||||
|
<el-form-item label="日期" prop="orderStatus" label-width="60px">
|
||||||
|
<el-date-picker
|
||||||
|
v-model="valuetime"
|
||||||
|
type="daterange"
|
||||||
|
align="right"
|
||||||
|
@change="monthStartEndTimechange"
|
||||||
|
unlink-panels
|
||||||
|
range-separator="至"
|
||||||
|
start-placeholder="开始日期"
|
||||||
|
end-placeholder="结束日期"
|
||||||
|
:picker-options="pickerOptions"
|
||||||
|
></el-date-picker>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item>
|
||||||
|
<el-button type="primary" icon="el-icon-search" size="mini" @click="getlist">搜索</el-button>
|
||||||
|
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
|
||||||
|
</el-form-item>
|
||||||
|
</el-form>
|
||||||
|
<el-table v-loading="loading" :data="list">
|
||||||
|
<el-table-column label="家长姓名" align="center" prop="parentName" />
|
||||||
|
<el-table-column label="打卡天数" align="center" prop="loginCount" />
|
||||||
|
<el-table-column label="查看打卡日历" align="center" prop>
|
||||||
|
<template slot-scope="scope">
|
||||||
|
<el-button type="text" @click="look(scope.row)">查看</el-button>
|
||||||
|
</template>
|
||||||
|
</el-table-column>
|
||||||
|
</el-table>
|
||||||
|
<pagination
|
||||||
|
v-show="total > 0"
|
||||||
|
:total="total"
|
||||||
|
:page.sync="query.pageNum"
|
||||||
|
:limit.sync="query.pageSize"
|
||||||
|
@pagination="getlist"
|
||||||
|
/>
|
||||||
|
<el-dialog width="1600px" title="打卡统计" :visible.sync="loginCountshow" append-to-body>
|
||||||
|
<div class="picker">
|
||||||
|
年度:
|
||||||
|
<el-date-picker
|
||||||
|
v-model="year"
|
||||||
|
type="year"
|
||||||
|
placeholder="选择年"
|
||||||
|
format="yyyy"
|
||||||
|
value-format="yyyy"
|
||||||
|
></el-date-picker>
|
||||||
|
</div>
|
||||||
|
<div class="dio" @click="false">
|
||||||
|
<el-calendar v-model="yearmonths[0]" style="width:380px">
|
||||||
|
<template slot="dateCell" slot-scope="{date, data}">
|
||||||
|
<div :class="{ selected : isSelected(date, data) }" style="font-size:14px">
|
||||||
|
<div class="solar" style="font-size:14px">{{ data.day.split('-')[2] }}</div>
|
||||||
|
<div
|
||||||
|
class="lunar"
|
||||||
|
style="font-size:2px"
|
||||||
|
:class="{ festival : isFestival(date, data) }"
|
||||||
|
>{{ solarToLunar(date, data) }}</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-calendar>
|
||||||
|
<el-calendar v-model="yearmonths[1]" style="width:380px">
|
||||||
|
<template slot="dateCell" slot-scope="{date, data}">
|
||||||
|
<div :class="{ selected : isSelected(date, data) }" style="font-size:14px">
|
||||||
|
<div class="solar" style="font-size:14px">{{ data.day.split('-')[2] }}</div>
|
||||||
|
<div
|
||||||
|
class="lunar"
|
||||||
|
style="font-size:2px"
|
||||||
|
:class="{ festival : isFestival(date, data) }"
|
||||||
|
>{{ solarToLunar(date, data) }}</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-calendar>
|
||||||
|
<el-calendar v-model="yearmonths[2]" style="width:380px">
|
||||||
|
<template slot="dateCell" slot-scope="{date, data}">
|
||||||
|
<div :class="{ selected : isSelected(date, data) }" style="font-size:14px">
|
||||||
|
<div class="solar" style="font-size:14px">{{ data.day.split('-')[2] }}</div>
|
||||||
|
<div
|
||||||
|
class="lunar"
|
||||||
|
style="font-size:2px"
|
||||||
|
:class="{ festival : isFestival(date, data) }"
|
||||||
|
>{{ solarToLunar(date, data) }}</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-calendar>
|
||||||
|
<el-calendar v-model="yearmonths[3]" style="width:380px">
|
||||||
|
<template slot="dateCell" slot-scope="{date, data}">
|
||||||
|
<div :class="{ selected : isSelected(date, data) }" style="font-size:14px">
|
||||||
|
<div class="solar" style="font-size:14px">{{ data.day.split('-')[2] }}</div>
|
||||||
|
<div
|
||||||
|
class="lunar"
|
||||||
|
style="font-size:2px"
|
||||||
|
:class="{ festival : isFestival(date, data) }"
|
||||||
|
>{{ solarToLunar(date, data) }}</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-calendar>
|
||||||
|
<el-calendar v-model="yearmonths[4]" style="width:380px">
|
||||||
|
<template slot="dateCell" slot-scope="{date, data}">
|
||||||
|
<div :class="{ selected : isSelected(date, data) }" style="font-size:14px">
|
||||||
|
<div class="solar" style="font-size:14px">{{ data.day.split('-')[2] }}</div>
|
||||||
|
<div
|
||||||
|
class="lunar"
|
||||||
|
style="font-size:2px"
|
||||||
|
:class="{ festival : isFestival(date, data) }"
|
||||||
|
>{{ solarToLunar(date, data) }}</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-calendar>
|
||||||
|
<el-calendar v-model="yearmonths[5]" style="width:380px">
|
||||||
|
<template slot="dateCell" slot-scope="{date, data}">
|
||||||
|
<div :class="{ selected : isSelected(date, data) }" style="font-size:14px">
|
||||||
|
<div class="solar" style="font-size:14px">{{ data.day.split('-')[2] }}</div>
|
||||||
|
<div
|
||||||
|
class="lunar"
|
||||||
|
style="font-size:2px"
|
||||||
|
:class="{ festival : isFestival(date, data) }"
|
||||||
|
>{{ solarToLunar(date, data) }}</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-calendar>
|
||||||
|
<el-calendar v-model="yearmonths[6]" style="width:380px">
|
||||||
|
<template slot="dateCell" slot-scope="{date, data}">
|
||||||
|
<div :class="{ selected : isSelected(date, data) }" style="font-size:14px">
|
||||||
|
<div class="solar" style="font-size:14px">{{ data.day.split('-')[2] }}</div>
|
||||||
|
<div
|
||||||
|
class="lunar"
|
||||||
|
style="font-size:2px"
|
||||||
|
:class="{ festival : isFestival(date, data) }"
|
||||||
|
>{{ solarToLunar(date, data) }}</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-calendar>
|
||||||
|
<el-calendar v-model="yearmonths[7]" style="width:380px">
|
||||||
|
<template slot="dateCell" slot-scope="{date, data}">
|
||||||
|
<div :class="{ selected : isSelected(date, data) }" style="font-size:14px">
|
||||||
|
<div class="solar" style="font-size:14px">{{ data.day.split('-')[2] }}</div>
|
||||||
|
<div
|
||||||
|
class="lunar"
|
||||||
|
style="font-size:2px"
|
||||||
|
:class="{ festival : isFestival(date, data) }"
|
||||||
|
>{{ solarToLunar(date, data) }}</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-calendar>
|
||||||
|
<el-calendar v-model="yearmonths[8]" style="width:380px">
|
||||||
|
<template slot="dateCell" slot-scope="{date, data}">
|
||||||
|
<div :class="{ selected : isSelected(date, data) }" style="font-size:14px">
|
||||||
|
<div class="solar" style="font-size:14px">{{ data.day.split('-')[2] }}</div>
|
||||||
|
<div
|
||||||
|
class="lunar"
|
||||||
|
style="font-size:2px"
|
||||||
|
:class="{ festival : isFestival(date, data) }"
|
||||||
|
>{{ solarToLunar(date, data) }}</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-calendar>
|
||||||
|
<el-calendar v-model="yearmonths[9]" style="width:380px">
|
||||||
|
<template slot="dateCell" slot-scope="{date, data}">
|
||||||
|
<div :class="{ selected : isSelected(date, data) }" style="font-size:14px">
|
||||||
|
<div class="solar" style="font-size:14px">{{ data.day.split('-')[2] }}</div>
|
||||||
|
<div
|
||||||
|
class="lunar"
|
||||||
|
style="font-size:2px"
|
||||||
|
:class="{ festival : isFestival(date, data) }"
|
||||||
|
>{{ solarToLunar(date, data) }}</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-calendar>
|
||||||
|
<el-calendar v-model="yearmonths[10]" style="width:380px">
|
||||||
|
<template slot="dateCell" slot-scope="{date, data}">
|
||||||
|
<div :class="{ selected : isSelected(date, data) }" style="font-size:14px">
|
||||||
|
<div class="solar" style="font-size:14px">{{ data.day.split('-')[2] }}</div>
|
||||||
|
<div
|
||||||
|
class="lunar"
|
||||||
|
style="font-size:2px"
|
||||||
|
:class="{ festival : isFestival(date, data) }"
|
||||||
|
>{{ solarToLunar(date, data) }}</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-calendar>
|
||||||
|
<el-calendar v-model="yearmonths[11]" style="width:380px">
|
||||||
|
<template slot="dateCell" slot-scope="{date, data}">
|
||||||
|
<div :class="{ selected : isSelected(date, data) }" style="font-size:14px">
|
||||||
|
<div class="solar" style="font-size:14px">{{ data.day.split('-')[2] }}</div>
|
||||||
|
<div
|
||||||
|
class="lunar"
|
||||||
|
style="font-size:2px"
|
||||||
|
:class="{ festival : isFestival(date, data) }"
|
||||||
|
>{{ solarToLunar(date, data) }}</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
</el-calendar>
|
||||||
|
</div>
|
||||||
|
</el-dialog>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
<script>
|
||||||
|
import { clockStatistics } from "@/api/system/StatisticsParent";
|
||||||
|
import classe from "../../assembly/classe.vue";
|
||||||
|
import parent from "../../assembly/parent.vue";
|
||||||
|
import calendar from "../../calendar.js";
|
||||||
|
export default {
|
||||||
|
name: "StatisticsParent",
|
||||||
|
components: { classe, parent },
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
loginCountshow: false,
|
||||||
|
pickerOptions: {
|
||||||
|
shortcuts: [
|
||||||
|
{
|
||||||
|
text: "最近一周",
|
||||||
|
onClick(picker) {
|
||||||
|
const end = new Date();
|
||||||
|
const start = new Date();
|
||||||
|
start.setTime(start.getTime() - 3600 * 1000 * 24 * 7);
|
||||||
|
picker.$emit("pick", [start, end]);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
text: "最近一个月",
|
||||||
|
onClick(picker) {
|
||||||
|
const end = new Date();
|
||||||
|
const start = new Date();
|
||||||
|
start.setTime(start.getTime() - 3600 * 1000 * 24 * 30);
|
||||||
|
picker.$emit("pick", [start, end]);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
text: "最近三个月",
|
||||||
|
onClick(picker) {
|
||||||
|
const end = new Date();
|
||||||
|
const start = new Date();
|
||||||
|
start.setTime(start.getTime() - 3600 * 1000 * 24 * 90);
|
||||||
|
picker.$emit("pick", [start, end]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
valuetime: "",
|
||||||
|
loading: false,
|
||||||
|
showSearch: true, // 显示搜索条件
|
||||||
|
list: [],
|
||||||
|
total: 0,
|
||||||
|
query: {
|
||||||
|
pageNum: 1,
|
||||||
|
pageSize: 10,
|
||||||
|
parentInfoId: "",
|
||||||
|
classId: "",
|
||||||
|
startDate: "",
|
||||||
|
endDate: ""
|
||||||
|
},
|
||||||
|
selectedDates: ["2023-03-12", "2023-04-12", "2023-04-15", "2023-04-24"],
|
||||||
|
date: new Date(),
|
||||||
|
yearmonths: [],
|
||||||
|
year: "2023"
|
||||||
|
};
|
||||||
|
},
|
||||||
|
created() {
|
||||||
|
this.newtime();
|
||||||
|
this.getlist();
|
||||||
|
},
|
||||||
|
mounted() {},
|
||||||
|
watch: {
|
||||||
|
year() {
|
||||||
|
this.yearmonths = [
|
||||||
|
this.year + "-01",
|
||||||
|
this.year + "-02",
|
||||||
|
this.year + "-03",
|
||||||
|
this.year + "-04",
|
||||||
|
this.year + "-05",
|
||||||
|
this.year + "-06",
|
||||||
|
this.year + "-07",
|
||||||
|
this.year + "-08",
|
||||||
|
this.year + "-09",
|
||||||
|
this.year + "-10",
|
||||||
|
this.year + "-11",
|
||||||
|
this.year + "-12"
|
||||||
|
];
|
||||||
|
}
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
// 是否选中日期
|
||||||
|
isSelected: function(slotDate, slotData) {
|
||||||
|
return this.selectedDates.includes(slotData.day);
|
||||||
|
},
|
||||||
|
// 是否节假日
|
||||||
|
isFestival(slotDate, slotData) {
|
||||||
|
let solarDayArr = slotData.day.split("-");
|
||||||
|
let lunarDay = calendar.solar2lunar(
|
||||||
|
solarDayArr[0],
|
||||||
|
solarDayArr[1],
|
||||||
|
solarDayArr[2]
|
||||||
|
);
|
||||||
|
// 公历节日\农历节日\农历节气
|
||||||
|
let festAndTerm = [];
|
||||||
|
festAndTerm.push(
|
||||||
|
lunarDay.festival == null ? "" : " " + lunarDay.festival
|
||||||
|
);
|
||||||
|
festAndTerm.push(
|
||||||
|
lunarDay.lunarFestival == null ? "" : "" + lunarDay.lunarFestival
|
||||||
|
);
|
||||||
|
festAndTerm.push(lunarDay.Term == null ? "" : "" + lunarDay.Term);
|
||||||
|
festAndTerm = festAndTerm.join("");
|
||||||
|
return festAndTerm != "";
|
||||||
|
},
|
||||||
|
// 公历转农历
|
||||||
|
solarToLunar(slotDate, slotData) {
|
||||||
|
let solarDayArr = slotData.day.split("-");
|
||||||
|
let lunarDay = calendar.solar2lunar(
|
||||||
|
solarDayArr[0],
|
||||||
|
solarDayArr[1],
|
||||||
|
solarDayArr[2]
|
||||||
|
);
|
||||||
|
// 农历日期
|
||||||
|
let lunarMD = lunarDay.IMonthCn + lunarDay.IDayCn;
|
||||||
|
// 公历节日\农历节日\农历节气
|
||||||
|
let festAndTerm = [];
|
||||||
|
festAndTerm.push(
|
||||||
|
lunarDay.festival == null ? "" : " " + lunarDay.festival
|
||||||
|
);
|
||||||
|
festAndTerm.push(
|
||||||
|
lunarDay.lunarFestival == null ? "" : "" + lunarDay.lunarFestival
|
||||||
|
);
|
||||||
|
festAndTerm.push(lunarDay.Term == null ? "" : "" + lunarDay.Term);
|
||||||
|
festAndTerm = festAndTerm.join("");
|
||||||
|
|
||||||
|
return festAndTerm == "" ? lunarMD : festAndTerm;
|
||||||
|
},
|
||||||
|
//获取list
|
||||||
|
getlist() {
|
||||||
|
clockStatistics(
|
||||||
|
this.query.pageNum,
|
||||||
|
this.query.pageSize,
|
||||||
|
this.query.parentInfoId,
|
||||||
|
this.query.classId,
|
||||||
|
this.query.startDate,
|
||||||
|
this.query.endDate
|
||||||
|
).then(res => {
|
||||||
|
this.list = res.rows;
|
||||||
|
this.total = res.total;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
//今天的时间
|
||||||
|
newtime() {
|
||||||
|
let nowDate = new Date();
|
||||||
|
let dates = {
|
||||||
|
year: nowDate.getFullYear(), // 获取当前年份
|
||||||
|
month: nowDate.getMonth() + 1, //获取当前月份
|
||||||
|
date: nowDate.getDate() //获取当前日期
|
||||||
|
};
|
||||||
|
this.yearmonths = [
|
||||||
|
dates.year + "-01",
|
||||||
|
dates.year + "-02",
|
||||||
|
dates.year + "-03",
|
||||||
|
dates.year + "-04",
|
||||||
|
dates.year + "-05",
|
||||||
|
dates.year + "-06",
|
||||||
|
dates.year + "-07",
|
||||||
|
dates.year + "-08",
|
||||||
|
dates.year + "-09",
|
||||||
|
dates.year + "-10",
|
||||||
|
dates.year + "-11",
|
||||||
|
dates.year + "-12"
|
||||||
|
];
|
||||||
|
console.log(this.year);
|
||||||
|
// //拼接
|
||||||
|
// if (dates.month < 10) {
|
||||||
|
// this.query.startDate = dates.year + "-0" + dates.month;
|
||||||
|
// this.query.endDate = dates.year + "-0" + dates.month;
|
||||||
|
// } else {
|
||||||
|
// this.query.startDate = dates.year + "." + dates.month;
|
||||||
|
// this.query.endDate = dates.year + "-" + dates.month;
|
||||||
|
// }
|
||||||
|
// if (dates.date < 10) {
|
||||||
|
// this.query.startDate = this.startDate + "-0" + dates.date;
|
||||||
|
// this.query.endDate = this.endDate + "-0" + dates.date;
|
||||||
|
// } else {
|
||||||
|
// this.query.startDate = this.startDate + "-" + dates.date;
|
||||||
|
// this.query.endDate = this.endDate + "-" + dates.date;
|
||||||
|
// }
|
||||||
|
},
|
||||||
|
look() {
|
||||||
|
this.loginCountshow = true;
|
||||||
|
},
|
||||||
|
//家长
|
||||||
|
parentlist(e) {
|
||||||
|
this.query.parentInfoId = e;
|
||||||
|
},
|
||||||
|
//班级
|
||||||
|
classelist(e) {
|
||||||
|
this.query.classId = e;
|
||||||
|
},
|
||||||
|
//重置
|
||||||
|
resetQuery() {
|
||||||
|
this.newtime();
|
||||||
|
this.valuetime = "";
|
||||||
|
this.getlist();
|
||||||
|
},
|
||||||
|
//选择时期区间
|
||||||
|
monthStartEndTimechange(e) {
|
||||||
|
this.query.startDate = this.formatDate(new Date(e[0]).getTime());
|
||||||
|
this.query.endDate = this.formatDate(new Date(e[1]).getTime());
|
||||||
|
},
|
||||||
|
formatDate(time, timetype) {
|
||||||
|
let date = new Date(time); //13位时间戳
|
||||||
|
//let date = new Date(parseInt(time) * 1000); //10位时间戳
|
||||||
|
let y = date.getFullYear();
|
||||||
|
let MM = date.getMonth() + 1;
|
||||||
|
MM = MM < 10 ? "0" + MM : MM;
|
||||||
|
let d = date.getDate();
|
||||||
|
d = d < 10 ? "0" + d : d;
|
||||||
|
return y + "-" + MM + "-" + d;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
<style lang='scss' scoped>
|
||||||
|
::v-deep .el-calendar__button-group .el-button-group {
|
||||||
|
width: 0;
|
||||||
|
height: 0;
|
||||||
|
overflow: hidden;
|
||||||
|
.el-button {
|
||||||
|
overflow: hidden;
|
||||||
|
width: 0 !important;
|
||||||
|
height: 0 !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
::v-deep .el-calendar-table .el-calendar-day {
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
::v-deep .el-calendar-table .el-calendar-day {
|
||||||
|
height: 65px;
|
||||||
|
}
|
||||||
|
.app-container {
|
||||||
|
padding: 20px 0 20px 10px;
|
||||||
|
}
|
||||||
|
::v-deep .el-card__header {
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
::v-deep .el-form {
|
||||||
|
display: inline;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**隐藏上一月、本月、下一月*/
|
||||||
|
.el-calendar__button-group {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
/**月份居中*/
|
||||||
|
.el-calendar__title {
|
||||||
|
width: 100%;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
/**日期div的样式*/
|
||||||
|
.el-calendar-table tr td:first-child {
|
||||||
|
border-left: 0px;
|
||||||
|
}
|
||||||
|
.el-calendar-table td {
|
||||||
|
min-height: 110px;
|
||||||
|
min-width: 110px;
|
||||||
|
border-right: 0px;
|
||||||
|
}
|
||||||
|
.el-calendar-table td.is-selected {
|
||||||
|
background-color: white;
|
||||||
|
}
|
||||||
|
.el-calendar-table .el-calendar-day {
|
||||||
|
height: 100%;
|
||||||
|
padding: 0px;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
.el-calendar-table .el-calendar-day > div {
|
||||||
|
height: 65px;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
/**日期div的样式-公历*/
|
||||||
|
.el-calendar-table .el-calendar-day > div .solar {
|
||||||
|
text-align: center;
|
||||||
|
padding-top: 5px;
|
||||||
|
}
|
||||||
|
/**日期div的样式-农历*/
|
||||||
|
.el-calendar-table .el-calendar-day > div .lunar {
|
||||||
|
padding-top: 5px;
|
||||||
|
width: 100%;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
/**日期div的样式-选中*/
|
||||||
|
.el-calendar-table .el-calendar-day > div.selected {
|
||||||
|
background-color: #fef2f2;
|
||||||
|
border: 3px solid #fb0;
|
||||||
|
border-radius: 10px;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**本月周末设置为红色*/
|
||||||
|
.el-calendar-table .current:nth-last-child(-n + 2) .solar {
|
||||||
|
color: red;
|
||||||
|
}
|
||||||
|
/**本月农历设置为灰色*/
|
||||||
|
.el-calendar-table .current .lunar {
|
||||||
|
color: #606266;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
/**本月农历节日设置为红色*/
|
||||||
|
.el-calendar-table .current .lunar.festival {
|
||||||
|
color: red;
|
||||||
|
}
|
||||||
|
/**禁用点击效果*/
|
||||||
|
/*.el-calendar-table td {*/
|
||||||
|
/*pointer-events: none;*/
|
||||||
|
/*}*/
|
||||||
|
.dio {
|
||||||
|
display: flex;
|
||||||
|
flex-wrap: wrap;
|
||||||
|
margin: 0 0 0 0;
|
||||||
|
}
|
||||||
|
.picker {
|
||||||
|
display: inline-block;
|
||||||
|
position: absolute;
|
||||||
|
right: 80px;
|
||||||
|
top: 20px;
|
||||||
|
padding-right: 80px;
|
||||||
|
font-size: 18px;
|
||||||
|
font-weight: 600;
|
||||||
|
}
|
||||||
|
::v-deep .el-input--medium .el-input__inner {
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
213
src/views/system/Statisticspark/index.vue
Normal file
213
src/views/system/Statisticspark/index.vue
Normal file
@ -0,0 +1,213 @@
|
|||||||
|
<template>
|
||||||
|
<div class="app-container">
|
||||||
|
<el-form size="small" :inline="true" v-show="showSearch">
|
||||||
|
<el-form-item label="所属区县" prop="orderStatus" label-width="80px">
|
||||||
|
<treeselect
|
||||||
|
:normalizer="normalizer"
|
||||||
|
:options="areaList"
|
||||||
|
placeholder="请选择所属区县"
|
||||||
|
v-model="areaCode2"
|
||||||
|
style="width: 230px"
|
||||||
|
/>
|
||||||
|
</el-form-item>
|
||||||
|
</el-form>
|
||||||
|
<kindergarlog @kinbatlist="kinbatlist" style="width: 500px; display: inline;" ref="kinresets"></kindergarlog>
|
||||||
|
<el-form size="small" :inline="true" v-show="showSearch">
|
||||||
|
<el-form-item label="日期" prop="orderStatus" label-width="60px">
|
||||||
|
<el-date-picker
|
||||||
|
v-model="valuetime"
|
||||||
|
type="daterange"
|
||||||
|
align="right"
|
||||||
|
@change="monthStartEndTimechange"
|
||||||
|
unlink-panels
|
||||||
|
range-separator="至"
|
||||||
|
start-placeholder="开始日期"
|
||||||
|
end-placeholder="结束日期"
|
||||||
|
:picker-options="pickerOptions"
|
||||||
|
></el-date-picker>
|
||||||
|
</el-form-item>
|
||||||
|
<el-form-item>
|
||||||
|
<el-button type="primary" icon="el-icon-search" size="mini" @click="getlist">搜索</el-button>
|
||||||
|
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
|
||||||
|
</el-form-item>
|
||||||
|
</el-form>
|
||||||
|
<el-table v-loading="loading" :data="list">
|
||||||
|
<el-table-column label="幼儿园名称" align="center" prop="kindergartenName"></el-table-column>
|
||||||
|
<el-table-column label="登录次数" align="center" prop="loginCount" />
|
||||||
|
<el-table-column label="运动处方查看次数" align="center" prop="prescriptionCount" />
|
||||||
|
<el-table-column label="处方视频查看次数" align="center" prop="prescriptionVideoCount" />
|
||||||
|
</el-table>
|
||||||
|
<pagination
|
||||||
|
v-show="total > 0"
|
||||||
|
:total="total"
|
||||||
|
:page.sync="pageNum"
|
||||||
|
:limit.sync="pageSize"
|
||||||
|
@pagination="getlist"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
<script>
|
||||||
|
import { appletKindergartenCount } from "@/api/system/Statisticspark";
|
||||||
|
import { listArea } from "@/api/system/area.js";
|
||||||
|
import kindergarlog from "../../assembly/kindergarlog.vue";
|
||||||
|
import Treeselect from "@riophae/vue-treeselect";
|
||||||
|
import "@riophae/vue-treeselect/dist/vue-treeselect.css";
|
||||||
|
export default {
|
||||||
|
name: "Statisticspark",
|
||||||
|
components: { kindergarlog, Treeselect },
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
pickerOptions: {
|
||||||
|
shortcuts: [
|
||||||
|
{
|
||||||
|
text: "最近一周",
|
||||||
|
onClick(picker) {
|
||||||
|
const end = new Date();
|
||||||
|
const start = new Date();
|
||||||
|
start.setTime(start.getTime() - 3600 * 1000 * 24 * 7);
|
||||||
|
picker.$emit("pick", [start, end]);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
text: "最近一个月",
|
||||||
|
onClick(picker) {
|
||||||
|
const end = new Date();
|
||||||
|
const start = new Date();
|
||||||
|
start.setTime(start.getTime() - 3600 * 1000 * 24 * 30);
|
||||||
|
picker.$emit("pick", [start, end]);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
text: "最近三个月",
|
||||||
|
onClick(picker) {
|
||||||
|
const end = new Date();
|
||||||
|
const start = new Date();
|
||||||
|
start.setTime(start.getTime() - 3600 * 1000 * 24 * 90);
|
||||||
|
picker.$emit("pick", [start, end]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
valuetime: "",
|
||||||
|
loading: false,
|
||||||
|
showSearch: true, // 显示搜索条件
|
||||||
|
pageNum: 1,
|
||||||
|
pageSize: 10,
|
||||||
|
startDate: "",
|
||||||
|
endDate: "",
|
||||||
|
list: [],
|
||||||
|
total: 0,
|
||||||
|
areaCode: "",
|
||||||
|
areaCode2: null,
|
||||||
|
kindergartenId: "",
|
||||||
|
areaList: []
|
||||||
|
};
|
||||||
|
},
|
||||||
|
created() {
|
||||||
|
this.areainfo();
|
||||||
|
this.newtime();
|
||||||
|
this.getlist();
|
||||||
|
},
|
||||||
|
mounted() {},
|
||||||
|
methods: {
|
||||||
|
//幼儿园传值
|
||||||
|
kinbatlist(e) {
|
||||||
|
this.kindergartenId = e;
|
||||||
|
},
|
||||||
|
//获取list
|
||||||
|
getlist() {
|
||||||
|
if (this.areaCode2) {
|
||||||
|
this.areaCode = this.areaCode2;
|
||||||
|
}
|
||||||
|
appletKindergartenCount(
|
||||||
|
this.pageNum,
|
||||||
|
this.pageSize,
|
||||||
|
this.areaCode,
|
||||||
|
this.kindergartenId,
|
||||||
|
this.startDate,
|
||||||
|
this.endDate
|
||||||
|
).then(res => {
|
||||||
|
this.list = res.rows;
|
||||||
|
this.total = res.total;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
//区县list
|
||||||
|
areainfo() {
|
||||||
|
listArea().then(response => {
|
||||||
|
this.areaList = this.handleTree(response.data);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
//今天的时间
|
||||||
|
newtime() {
|
||||||
|
let nowDate = new Date();
|
||||||
|
let dates = {
|
||||||
|
year: nowDate.getFullYear(), // 获取当前年份
|
||||||
|
month: nowDate.getMonth() + 1, //获取当前月份
|
||||||
|
date: nowDate.getDate() //获取当前日期
|
||||||
|
};
|
||||||
|
// //拼接
|
||||||
|
// if (dates.month < 10) {
|
||||||
|
// this.startDate = dates.year + "-0" + dates.month;
|
||||||
|
// this.endDate = dates.year + "-0" + dates.month;
|
||||||
|
// } else {
|
||||||
|
// this.startDate = dates.year + "." + dates.month;
|
||||||
|
// this.endDate = dates.year + "-" + dates.month;
|
||||||
|
// }
|
||||||
|
// if (dates.date < 10) {
|
||||||
|
// this.startDate = this.startDate + "-0" + dates.date;
|
||||||
|
// this.endDate = this.endDate + "-0" + dates.date;
|
||||||
|
// } else {
|
||||||
|
// this.startDate = this.startDate + "-" + dates.date;
|
||||||
|
// this.endDate = this.endDate + "-" + dates.date;
|
||||||
|
// }
|
||||||
|
},
|
||||||
|
//重置
|
||||||
|
resetQuery() {
|
||||||
|
this.newtime();
|
||||||
|
this.areaCode = "";
|
||||||
|
this.areaCode2 = null;
|
||||||
|
this.valuetime = "";
|
||||||
|
this.kindergartenId = "";
|
||||||
|
this.$refs.kinresets.reset();
|
||||||
|
this.getlist();
|
||||||
|
},
|
||||||
|
//选择时期区间
|
||||||
|
monthStartEndTimechange(e) {
|
||||||
|
this.startDate = this.formatDate(new Date(e[0]).getTime());
|
||||||
|
this.endDate = this.formatDate(new Date(e[1]).getTime());
|
||||||
|
},
|
||||||
|
formatDate(time, timetype) {
|
||||||
|
let date = new Date(time); //13位时间戳
|
||||||
|
//let date = new Date(parseInt(time) * 1000); //10位时间戳
|
||||||
|
let y = date.getFullYear();
|
||||||
|
let MM = date.getMonth() + 1;
|
||||||
|
MM = MM < 10 ? "0" + MM : MM;
|
||||||
|
let d = date.getDate();
|
||||||
|
d = d < 10 ? "0" + d : d;
|
||||||
|
return y + "-" + MM + "-" + d;
|
||||||
|
},
|
||||||
|
normalizer(node) {
|
||||||
|
if (node.children && !node.children.length) {
|
||||||
|
delete node.children;
|
||||||
|
}
|
||||||
|
return {
|
||||||
|
id: node.code,
|
||||||
|
label: node.name,
|
||||||
|
children: node.children
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
<style lang='scss' scoped>
|
||||||
|
.app-container {
|
||||||
|
padding: 20px 0 20px 10px;
|
||||||
|
}
|
||||||
|
::v-deep .el-card__header {
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
::v-deep .el-form {
|
||||||
|
display: inline;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
||||||
@ -43,16 +43,8 @@
|
|||||||
/>
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item>
|
<el-form-item>
|
||||||
<el-button
|
<el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
|
||||||
type="primary"
|
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
|
||||||
icon="el-icon-search"
|
|
||||||
size="mini"
|
|
||||||
@click="handleQuery"
|
|
||||||
>搜索</el-button
|
|
||||||
>
|
|
||||||
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery"
|
|
||||||
>重置</el-button
|
|
||||||
>
|
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
|
|
||||||
@ -65,8 +57,7 @@
|
|||||||
size="mini"
|
size="mini"
|
||||||
@click="handleAdd"
|
@click="handleAdd"
|
||||||
v-hasPermi="['system:classinfo:add']"
|
v-hasPermi="['system:classinfo:add']"
|
||||||
>新增</el-button
|
>新增</el-button>
|
||||||
>
|
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="1.5">
|
<el-col :span="1.5">
|
||||||
<el-button
|
<el-button
|
||||||
@ -77,8 +68,7 @@
|
|||||||
:disabled="single"
|
:disabled="single"
|
||||||
@click="handleUpdate"
|
@click="handleUpdate"
|
||||||
v-hasPermi="['system:classinfo:edit']"
|
v-hasPermi="['system:classinfo:edit']"
|
||||||
>修改</el-button
|
>修改</el-button>
|
||||||
>
|
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="1.5">
|
<el-col :span="1.5">
|
||||||
<el-button
|
<el-button
|
||||||
@ -89,8 +79,7 @@
|
|||||||
:disabled="multiple"
|
:disabled="multiple"
|
||||||
@click="handleDelete"
|
@click="handleDelete"
|
||||||
v-hasPermi="['system:classinfo:remove']"
|
v-hasPermi="['system:classinfo:remove']"
|
||||||
>删除</el-button
|
>删除</el-button>
|
||||||
>
|
|
||||||
</el-col>
|
</el-col>
|
||||||
<!-- <el-col :span="1.5">
|
<!-- <el-col :span="1.5">
|
||||||
<el-button
|
<el-button
|
||||||
@ -103,23 +92,12 @@
|
|||||||
>导出</el-button
|
>导出</el-button
|
||||||
>
|
>
|
||||||
</el-col>-->
|
</el-col>-->
|
||||||
<right-toolbar
|
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
|
||||||
:showSearch.sync="showSearch"
|
|
||||||
@queryTable="getList"
|
|
||||||
></right-toolbar>
|
|
||||||
</el-row>
|
</el-row>
|
||||||
|
|
||||||
<el-table
|
<el-table v-loading="loading" :data="classinfoList" @selection-change="handleSelectionChange">
|
||||||
v-loading="loading"
|
|
||||||
:data="classinfoList"
|
|
||||||
@selection-change="handleSelectionChange"
|
|
||||||
>
|
|
||||||
<el-table-column type="selection" width="55" align="center" />
|
<el-table-column type="selection" width="55" align="center" />
|
||||||
<el-table-column
|
<el-table-column label="所属幼儿园" align="center" prop="kindergartenName" />
|
||||||
label="所属幼儿园"
|
|
||||||
align="center"
|
|
||||||
prop="kindergartenName"
|
|
||||||
/>
|
|
||||||
<el-table-column label="班级名称" align="center" prop="className" />
|
<el-table-column label="班级名称" align="center" prop="className" />
|
||||||
<el-table-column label="班级类型" align="center" prop="classType">
|
<el-table-column label="班级类型" align="center" prop="classType">
|
||||||
<template slot-scope="scope">
|
<template slot-scope="scope">
|
||||||
@ -132,23 +110,13 @@
|
|||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column label="班主任姓名" align="center" prop="classTeacher" />
|
<el-table-column label="班主任姓名" align="center" prop="classTeacher" />
|
||||||
|
|
||||||
<el-table-column
|
<el-table-column label="入学日期" clearable align="center" prop="entranceYear" width="180">
|
||||||
label="入学日期"
|
|
||||||
clearable
|
|
||||||
align="center"
|
|
||||||
prop="entranceYear"
|
|
||||||
width="180"
|
|
||||||
>
|
|
||||||
<template slot-scope="scope">
|
<template slot-scope="scope">
|
||||||
<span>{{ scope.row.entranceYear }}年</span>
|
<span>{{ scope.row.entranceYear }}年</span>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
<el-table-column label="联系电话" align="center" prop="phone" />
|
<el-table-column label="联系电话" align="center" prop="phone" />
|
||||||
<el-table-column
|
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
||||||
label="操作"
|
|
||||||
align="center"
|
|
||||||
class-name="small-padding fixed-width"
|
|
||||||
>
|
|
||||||
<template slot-scope="scope">
|
<template slot-scope="scope">
|
||||||
<el-button
|
<el-button
|
||||||
size="mini"
|
size="mini"
|
||||||
@ -156,16 +124,14 @@
|
|||||||
icon="el-icon-edit"
|
icon="el-icon-edit"
|
||||||
@click="handleUpdate(scope.row)"
|
@click="handleUpdate(scope.row)"
|
||||||
v-hasPermi="['system:classinfo:edit']"
|
v-hasPermi="['system:classinfo:edit']"
|
||||||
>修改</el-button
|
>修改</el-button>
|
||||||
>
|
|
||||||
<el-button
|
<el-button
|
||||||
size="mini"
|
size="mini"
|
||||||
type="text"
|
type="text"
|
||||||
icon="el-icon-delete"
|
icon="el-icon-delete"
|
||||||
@click="handleDelete(scope.row)"
|
@click="handleDelete(scope.row)"
|
||||||
v-hasPermi="['system:classinfo:remove']"
|
v-hasPermi="['system:classinfo:remove']"
|
||||||
>删除</el-button
|
>删除</el-button>
|
||||||
>
|
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
</el-table>
|
</el-table>
|
||||||
@ -183,7 +149,7 @@
|
|||||||
<el-form ref="form" :model="form" :rules="rules" label-width="100px">
|
<el-form ref="form" :model="form" :rules="rules" label-width="100px">
|
||||||
<el-form-item label="所属幼儿园" prop="kindergartenId">
|
<el-form-item label="所属幼儿园" prop="kindergartenId">
|
||||||
<el-button
|
<el-button
|
||||||
type=""
|
type
|
||||||
@click="innerVisible = true"
|
@click="innerVisible = true"
|
||||||
style="
|
style="
|
||||||
width: 360px;
|
width: 360px;
|
||||||
@ -193,16 +159,14 @@
|
|||||||
padding-left: -10px;
|
padding-left: -10px;
|
||||||
"
|
"
|
||||||
v-if="kindergartenName == '请选择所在幼儿园'"
|
v-if="kindergartenName == '请选择所在幼儿园'"
|
||||||
>{{ kindergartenName }}</el-button
|
>{{ kindergartenName }}</el-button>
|
||||||
>
|
|
||||||
|
|
||||||
<el-button
|
<el-button
|
||||||
type=""
|
type
|
||||||
@click="innerVisible = true"
|
@click="innerVisible = true"
|
||||||
style="width: 360px; text-align: left; height: 36px"
|
style="width: 360px; text-align: left; height: 36px"
|
||||||
v-else
|
v-else
|
||||||
>{{ kindergartenName }}</el-button
|
>{{ kindergartenName }}</el-button>
|
||||||
>
|
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="班级名称" prop="className">
|
<el-form-item label="班级名称" prop="className">
|
||||||
<el-input v-model="form.className" placeholder="请输入班级名称" maxlength="40" />
|
<el-input v-model="form.className" placeholder="请输入班级名称" maxlength="40" />
|
||||||
@ -218,11 +182,7 @@
|
|||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
|
||||||
<el-form-item label="班主任姓名" prop="classTeacher">
|
<el-form-item label="班主任姓名" prop="classTeacher">
|
||||||
<el-input
|
<el-input v-model="form.classTeacher" placeholder="请输入班主任姓名" maxlength="10" />
|
||||||
v-model="form.classTeacher"
|
|
||||||
placeholder="请输入班主任姓名"
|
|
||||||
maxlength="10"
|
|
||||||
/>
|
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
|
|
||||||
<el-form-item label="入学日期" prop="entranceDateStr">
|
<el-form-item label="入学日期" prop="entranceDateStr">
|
||||||
@ -232,30 +192,18 @@
|
|||||||
v-model="form.entranceDateStr"
|
v-model="form.entranceDateStr"
|
||||||
value-format="yyyy-MM-dd"
|
value-format="yyyy-MM-dd"
|
||||||
placeholder="请选择入学日期"
|
placeholder="请选择入学日期"
|
||||||
>
|
></el-date-picker>
|
||||||
</el-date-picker>
|
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item label="联系电话" prop="phone">
|
<el-form-item label="联系电话" prop="phone">
|
||||||
<el-input
|
<el-input v-model="form.phone" placeholder="请输入联系电话" maxlength="11" />
|
||||||
v-model="form.phone"
|
|
||||||
placeholder="请输入联系电话"
|
|
||||||
maxlength="11"
|
|
||||||
/>
|
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
<div slot="footer" class="dialog-footer">
|
<div slot="footer" class="dialog-footer">
|
||||||
<el-button type="primary" @click="submitForm">确 定</el-button>
|
<el-button type="primary" @click="submitForm">确 定</el-button>
|
||||||
<el-button @click="cancel">取 消</el-button>
|
<el-button @click="cancel">取 消</el-button>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
<el-dialog
|
<el-dialog width="850px" title="选择所属幼儿园" :visible.sync="innerVisible" append-to-body>
|
||||||
width="850px"
|
|
||||||
title="选择所属幼儿园"
|
|
||||||
:visible.sync="innerVisible"
|
|
||||||
append-to-body
|
|
||||||
>
|
|
||||||
<el-form
|
<el-form
|
||||||
:model="queryParams2"
|
:model="queryParams2"
|
||||||
ref="queryForm"
|
ref="queryForm"
|
||||||
@ -281,23 +229,11 @@
|
|||||||
/>
|
/>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
<el-form-item>
|
<el-form-item>
|
||||||
<el-button
|
<el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery2">搜索</el-button>
|
||||||
type="primary"
|
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
|
||||||
icon="el-icon-search"
|
|
||||||
size="mini"
|
|
||||||
@click="handleQuery2"
|
|
||||||
>搜索</el-button
|
|
||||||
>
|
|
||||||
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery"
|
|
||||||
>重置</el-button
|
|
||||||
>
|
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-form>
|
</el-form>
|
||||||
|
<el-table :data="kindergartenInfoList" @cell-dblclick="kindergartenNameclick">
|
||||||
<el-table
|
|
||||||
:data="kindergartenInfoList"
|
|
||||||
@cell-dblclick="kindergartenNameclick"
|
|
||||||
>
|
|
||||||
<el-table-column label="请选择" width="70" align="center">
|
<el-table-column label="请选择" width="70" align="center">
|
||||||
<template slot-scope="scope">
|
<template slot-scope="scope">
|
||||||
<el-button
|
<el-button
|
||||||
@ -316,44 +252,12 @@
|
|||||||
></el-button>
|
></el-button>
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
|
<el-table-column property="kindergartenName" label="幼儿园名字" width="150" align="center"></el-table-column>
|
||||||
<el-table-column
|
<el-table-column property="kindergartenAddress" label="幼儿园地址" width="150" align="center"></el-table-column>
|
||||||
property="kindergartenName"
|
<el-table-column label="幼儿园所在组织" align="center" prop="organizeName" width="150"></el-table-column>
|
||||||
label="幼儿园名字"
|
<el-table-column property="contacts" label="联系人" width="150" align="center"></el-table-column>
|
||||||
width="150"
|
<el-table-column property="phone" label="联系电话" width="150" align="center"></el-table-column>
|
||||||
align="center"
|
|
||||||
>
|
|
||||||
</el-table-column>
|
|
||||||
<el-table-column
|
|
||||||
property="kindergartenAddress"
|
|
||||||
label="幼儿园地址"
|
|
||||||
width="150"
|
|
||||||
align="center"
|
|
||||||
>
|
|
||||||
</el-table-column>
|
|
||||||
<el-table-column
|
|
||||||
label="幼儿园所在组织"
|
|
||||||
align="center"
|
|
||||||
prop="organizeName"
|
|
||||||
width="150"
|
|
||||||
>
|
|
||||||
</el-table-column>
|
|
||||||
<el-table-column
|
|
||||||
property="contacts"
|
|
||||||
label="联系人"
|
|
||||||
width="150"
|
|
||||||
align="center"
|
|
||||||
>
|
|
||||||
</el-table-column>
|
|
||||||
<el-table-column
|
|
||||||
property="phone"
|
|
||||||
label="联系电话"
|
|
||||||
width="150"
|
|
||||||
align="center"
|
|
||||||
>
|
|
||||||
</el-table-column>
|
|
||||||
</el-table>
|
</el-table>
|
||||||
|
|
||||||
<pagination
|
<pagination
|
||||||
v-show="total2 > 0"
|
v-show="total2 > 0"
|
||||||
:total="total2"
|
:total="total2"
|
||||||
@ -371,11 +275,11 @@ import {
|
|||||||
getClassinfo,
|
getClassinfo,
|
||||||
delClassinfo,
|
delClassinfo,
|
||||||
addClassinfo,
|
addClassinfo,
|
||||||
updateClassinfo,
|
updateClassinfo
|
||||||
} from "@/api/system/classinfo";
|
} from "@/api/system/classinfo";
|
||||||
import {
|
import {
|
||||||
listKindergartenInfo,
|
listKindergartenInfo,
|
||||||
tKindergartenInfo,
|
tKindergartenInfo
|
||||||
} from "@/api/system/kindergartenInfo";
|
} from "@/api/system/kindergartenInfo";
|
||||||
import Treeselect from "@riophae/vue-treeselect";
|
import Treeselect from "@riophae/vue-treeselect";
|
||||||
import "@riophae/vue-treeselect/dist/vue-treeselect.css";
|
import "@riophae/vue-treeselect/dist/vue-treeselect.css";
|
||||||
@ -387,8 +291,7 @@ export default {
|
|||||||
var checkMobile = (rule, value, cb) => {
|
var checkMobile = (rule, value, cb) => {
|
||||||
var str = String(value);
|
var str = String(value);
|
||||||
// 验证手机号的正则表达式
|
// 验证手机号的正则表达式
|
||||||
const regMobile =
|
const regMobile = /^1(3[0-9]|4[01456879]|5[0-35-9]|6[2567]|7[0-8]|8[0-9]|9[0-35-9])\d{8}$/;
|
||||||
/^1(3[0-9]|4[01456879]|5[0-35-9]|6[2567]|7[0-8]|8[0-9]|9[0-35-9])\d{8}$/
|
|
||||||
// /^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])\d{8}$/;
|
// /^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])\d{8}$/;
|
||||||
// /^(?:(?:\+|0086))?1(?:(?:3[\d])|(?:4[5-79])|(?:5[0-35-9])|(?:6[5-7])|(?:7[0-8])|(?:8[\d])|(?:9[0-9]))\d{8}$/;
|
// /^(?:(?:\+|0086))?1(?:(?:3[\d])|(?:4[5-79])|(?:5[0-35-9])|(?:6[5-7])|(?:7[0-8])|(?:8[\d])|(?:9[0-9]))\d{8}$/;
|
||||||
const reg = /^(0[0-9]{2,3}\-)([2-9][0-9]{6,7})+(\-[0-9]{1,4})?$/;
|
const reg = /^(0[0-9]{2,3}\-)([2-9][0-9]{6,7})+(\-[0-9]{1,4})?$/;
|
||||||
@ -440,14 +343,14 @@ export default {
|
|||||||
kindergartenId: null,
|
kindergartenId: null,
|
||||||
className: null,
|
className: null,
|
||||||
classType: null,
|
classType: null,
|
||||||
entranceDateStr: null,
|
entranceDateStr: null
|
||||||
},
|
},
|
||||||
queryParams2: {
|
queryParams2: {
|
||||||
pageNum: 1,
|
pageNum: 1,
|
||||||
pageSize: 100,
|
pageSize: 1000,
|
||||||
kindergartenId: null,
|
kindergartenId: null,
|
||||||
className: null,
|
className: null,
|
||||||
classType: null,
|
classType: null
|
||||||
},
|
},
|
||||||
time: "",
|
time: "",
|
||||||
// 表单参数
|
// 表单参数
|
||||||
@ -459,22 +362,22 @@ export default {
|
|||||||
required: true,
|
required: true,
|
||||||
validator: checkMobile,
|
validator: checkMobile,
|
||||||
trigger: "blur",
|
trigger: "blur",
|
||||||
message: "",
|
message: ""
|
||||||
},
|
}
|
||||||
],
|
],
|
||||||
kindergartenId: [{ required: true, message: "请选择所属幼儿园" }],
|
kindergartenId: [{ required: true, message: "请选择所属幼儿园" }],
|
||||||
className: [
|
className: [
|
||||||
{ required: true, message: "请输入班级名称", trigger: "blur" },
|
{ required: true, message: "请输入班级名称", trigger: "blur" }
|
||||||
],
|
],
|
||||||
classType: [{ required: true, message: "请选择幼儿园类型" }],
|
classType: [{ required: true, message: "请选择幼儿园类型" }],
|
||||||
|
|
||||||
classTeacher: [
|
classTeacher: [
|
||||||
{ required: true, message: "请输入班主任姓名", trigger: "blur" },
|
{ required: true, message: "请输入班主任姓名", trigger: "blur" }
|
||||||
],
|
],
|
||||||
entranceDateStr: [
|
entranceDateStr: [
|
||||||
{ required: true, message: "请选择日期", trigger: "change" },
|
{ required: true, message: "请选择日期", trigger: "change" }
|
||||||
],
|
]
|
||||||
},
|
}
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
created() {
|
created() {
|
||||||
@ -494,7 +397,7 @@ export default {
|
|||||||
return {
|
return {
|
||||||
kindergartenId: node.id,
|
kindergartenId: node.id,
|
||||||
label: node.kindergartenName,
|
label: node.kindergartenName,
|
||||||
children: node.children,
|
children: node.children
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
//信息表ID
|
//信息表ID
|
||||||
@ -503,16 +406,16 @@ export default {
|
|||||||
|
|
||||||
getList() {
|
getList() {
|
||||||
this.loading = true;
|
this.loading = true;
|
||||||
listKindergartenInfo(this.queryParams2).then((response) => {
|
listKindergartenInfo(this.queryParams2).then(response => {
|
||||||
this.kindergartenInfoList = response.rows;
|
this.kindergartenInfoList = response.rows;
|
||||||
this.total2 = response.total;
|
this.total2 = response.total;
|
||||||
});
|
});
|
||||||
listClassinfo(this.queryParams).then((response) => {
|
listClassinfo(this.queryParams).then(response => {
|
||||||
this.classinfoList = response.rows;
|
this.classinfoList = response.rows;
|
||||||
this.total = response.total;
|
this.total = response.total;
|
||||||
this.loading = false;
|
this.loading = false;
|
||||||
});
|
});
|
||||||
tKindergartenInfo(this.ClassType).then((res) => {
|
tKindergartenInfo(this.ClassType).then(res => {
|
||||||
this.dictValue1 = res.data[0].dictValue;
|
this.dictValue1 = res.data[0].dictValue;
|
||||||
this.dictValue2 = res.data[1].dictValue;
|
this.dictValue2 = res.data[1].dictValue;
|
||||||
this.dictValue3 = res.data[2].dictValue;
|
this.dictValue3 = res.data[2].dictValue;
|
||||||
@ -535,7 +438,7 @@ export default {
|
|||||||
classTeacher: null,
|
classTeacher: null,
|
||||||
entranceDateStr: "",
|
entranceDateStr: "",
|
||||||
phone: undefined,
|
phone: undefined,
|
||||||
kindergartenName: null,
|
kindergartenName: null
|
||||||
};
|
};
|
||||||
|
|
||||||
this.resetForm("form");
|
this.resetForm("form");
|
||||||
@ -543,14 +446,14 @@ export default {
|
|||||||
/** 搜索按钮操作 */
|
/** 搜索按钮操作 */
|
||||||
handleQuery2() {
|
handleQuery2() {
|
||||||
this.queryParams2.pageNum = 1;
|
this.queryParams2.pageNum = 1;
|
||||||
listKindergartenInfo(this.queryParams2).then((response) => {
|
listKindergartenInfo(this.queryParams2).then(response => {
|
||||||
this.kindergartenInfoList = response.rows;
|
this.kindergartenInfoList = response.rows;
|
||||||
this.total2 = response.total;
|
this.total2 = response.total;
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
handleQuery() {
|
handleQuery() {
|
||||||
this.queryParams.pageNum = 1;
|
this.queryParams.pageNum = 1;
|
||||||
listClassinfo(this.queryParams).then((response) => {
|
listClassinfo(this.queryParams).then(response => {
|
||||||
this.classinfoList = response.rows;
|
this.classinfoList = response.rows;
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
@ -561,21 +464,21 @@ export default {
|
|||||||
pageSize: 10,
|
pageSize: 10,
|
||||||
kindergartenId: null,
|
kindergartenId: null,
|
||||||
className: null,
|
className: null,
|
||||||
classType: null,
|
classType: null
|
||||||
};
|
};
|
||||||
this.queryParams2 = {
|
this.queryParams2 = {
|
||||||
pageNum: 1,
|
pageNum: 1,
|
||||||
pageSize: 10,
|
pageSize: 10,
|
||||||
kindergartenId: null,
|
kindergartenId: null,
|
||||||
className: null,
|
className: null,
|
||||||
classType: null,
|
classType: null
|
||||||
};
|
};
|
||||||
this.handleQuery();
|
this.handleQuery();
|
||||||
this.handleQuery2();
|
this.handleQuery2();
|
||||||
},
|
},
|
||||||
// 多选框选中数据
|
// 多选框选中数据
|
||||||
handleSelectionChange(selection) {
|
handleSelectionChange(selection) {
|
||||||
this.ids = selection.map((item) => item.id);
|
this.ids = selection.map(item => item.id);
|
||||||
this.single = selection.length !== 1;
|
this.single = selection.length !== 1;
|
||||||
this.multiple = !selection.length;
|
this.multiple = !selection.length;
|
||||||
},
|
},
|
||||||
@ -592,7 +495,7 @@ export default {
|
|||||||
this.kindergartenid2 = row.kindergartenId;
|
this.kindergartenid2 = row.kindergartenId;
|
||||||
this.reset();
|
this.reset();
|
||||||
const id = row.id || this.ids;
|
const id = row.id || this.ids;
|
||||||
getClassinfo(id).then((response) => {
|
getClassinfo(id).then(response => {
|
||||||
response.data.phone = Number(response.data.phone);
|
response.data.phone = Number(response.data.phone);
|
||||||
this.form = response.data;
|
this.form = response.data;
|
||||||
this.kindergartenName = this.form.kindergartenName;
|
this.kindergartenName = this.form.kindergartenName;
|
||||||
@ -602,16 +505,16 @@ export default {
|
|||||||
},
|
},
|
||||||
/** 提交按钮 */
|
/** 提交按钮 */
|
||||||
submitForm() {
|
submitForm() {
|
||||||
this.$refs["form"].validate((valid) => {
|
this.$refs["form"].validate(valid => {
|
||||||
if (valid) {
|
if (valid) {
|
||||||
if (this.form.id != null) {
|
if (this.form.id != null) {
|
||||||
updateClassinfo(this.form).then((response) => {
|
updateClassinfo(this.form).then(response => {
|
||||||
this.$modal.msgSuccess("修改成功");
|
this.$modal.msgSuccess("修改成功");
|
||||||
this.open = false;
|
this.open = false;
|
||||||
this.getList();
|
this.getList();
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
addClassinfo(this.form).then((response) => {
|
addClassinfo(this.form).then(response => {
|
||||||
this.$modal.msgSuccess("新增成功");
|
this.$modal.msgSuccess("新增成功");
|
||||||
this.open = false;
|
this.open = false;
|
||||||
this.getList();
|
this.getList();
|
||||||
@ -634,7 +537,7 @@ export default {
|
|||||||
this.$modal.msgSuccess("删除成功");
|
this.$modal.msgSuccess("删除成功");
|
||||||
})
|
})
|
||||||
.catch(() => {});
|
.catch(() => {});
|
||||||
},
|
}
|
||||||
/** 导出按钮操作 */
|
/** 导出按钮操作 */
|
||||||
// handleExport() {
|
// handleExport() {
|
||||||
// this.download(
|
// this.download(
|
||||||
@ -645,6 +548,6 @@ export default {
|
|||||||
// `classinfo_${new Date().getTime()}.xlsx`
|
// `classinfo_${new Date().getTime()}.xlsx`
|
||||||
// );
|
// );
|
||||||
// },
|
// },
|
||||||
},
|
}
|
||||||
};
|
};
|
||||||
</script>
|
</script>
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user