This commit is contained in:
曹辉 2023-04-17 18:48:39 +08:00
parent d45ca3942c
commit 50a17fed0c
12 changed files with 2054 additions and 251 deletions

View 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',
})
}

View 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'
})
}

View 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',
})
}

View 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',
})
}

View File

@ -5,22 +5,10 @@
<el-button
@click="classshow = true"
v-if="className == '请选择班级'"
style="
width: 230px;
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
class="btn"
style="color: #c0c4cc;"
>{{ className }}</el-button>
<el-button @click="classshow = true" class="btn" v-else>{{ className }}</el-button>
</el-form-item>
</el-form>
<!-- // -->
@ -32,12 +20,14 @@
:before-close="classcancel"
>
<el-form ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="110px">
<el-form-item label="幼儿园名称" prop="kindergartenName">
<el-input
style="width: 200px"
v-model="classqueryParams.kindergartenName"
placeholder="请输入幼儿园名称"
></el-input>
<el-form-item label="所属幼儿园" prop="kindergartenId">
<treeselect
:normalizer="normalizer"
:options="kindergartenInfoList"
placeholder="请选择所属幼儿园"
v-model="classqueryParams.kindergartenId"
style="width: 208px"
/>
</el-form-item>
<el-form-item label="班级名称" prop="className">
<el-input style="width: 200px" v-model="classqueryParams.className" placeholder="请输入班级名称"></el-input>
@ -90,10 +80,12 @@
</template>
<script>
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 {
components: { Treeselect },
name: "classe",
components: {},
data() {
return {
total1: 0,
@ -103,14 +95,22 @@ export default {
showSearch: true,
//
form: {},
//
kinqueryParams: {
pageNum: 1,
pageSize: 1000
},
//
classqueryParams: {
pageNum: 1,
pageSize: 10,
className: null,
kindergartenName: null,
kindergartenId: null,
phone: null
},
//list
kindergartenInfoList: [],
//list
classList: [],
//
@ -121,6 +121,7 @@ export default {
},
mounted() {},
created() {
this.kingetlist();
this.getList();
this.onshow();
},
@ -163,6 +164,12 @@ export default {
};
this.classhandleQuery();
},
//list
kingetlist() {
listKindergartenInfo(this.kinqueryParams).then(response => {
this.kindergartenInfoList = response.rows;
});
},
getList() {
//list
listClassinfo(this.classqueryParams).then(response => {
@ -174,6 +181,16 @@ export default {
reset() {
this.className = "请选择班级";
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 {
border: none;
}
.btn {
width: 230px;
text-align: left;
height: 32px;
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
overflow: hidden;
font-size: 13px;
}
</style>

696
src/views/calendar.js Normal file
View File

@ -0,0 +1,696 @@
/**
* @1900-2100区间内的公历农历互转
* @charset UTF-8
* @Author Jea杨(JJonline@JJonline.Cn)
* @Time 2014-7-21
* @Time 2016-8-13 Fixed 2033hexAttribution 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 (02930)
* @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 (-12930)
* @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 (-128293031)
* @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

View File

@ -18,7 +18,7 @@
></el-date-picker>
</el-form-item>
<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
v-for="item in loginTypelist"
:key="item.value"
@ -54,7 +54,6 @@
: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>
@ -140,8 +139,8 @@ export default {
pageSize: 10,
parentInfoId: "",
classId: "",
startDate: null,
endDate: null,
startDate: "",
endDate: "",
loginType: "",
list: [],
total: 0,
@ -164,20 +163,20 @@ export default {
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;
}
// 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;
// }
},
//
getStudent(e) {
@ -210,7 +209,6 @@ export default {
this.loginType = "";
this.valuetime = "";
this.$refs.resets.reset();
this.$refs.kinresets.reset();
this.$refs.classe.reset();
this.getlist();
},

View 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>

View 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>

View 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>

View 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>

View File

@ -43,16 +43,8 @@
/>
</el-form-item>
<el-form-item>
<el-button
type="primary"
icon="el-icon-search"
size="mini"
@click="handleQuery"
>搜索</el-button
>
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery"
>重置</el-button
>
<el-button type="primary" 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>
@ -65,8 +57,7 @@
size="mini"
@click="handleAdd"
v-hasPermi="['system:classinfo:add']"
>新增</el-button
>
>新增</el-button>
</el-col>
<el-col :span="1.5">
<el-button
@ -77,8 +68,7 @@
:disabled="single"
@click="handleUpdate"
v-hasPermi="['system:classinfo:edit']"
>修改</el-button
>
>修改</el-button>
</el-col>
<el-col :span="1.5">
<el-button
@ -89,8 +79,7 @@
:disabled="multiple"
@click="handleDelete"
v-hasPermi="['system:classinfo:remove']"
>删除</el-button
>
>删除</el-button>
</el-col>
<!-- <el-col :span="1.5">
<el-button
@ -102,24 +91,13 @@
v-hasPermi="['system:classinfo:export']"
>导出</el-button
>
</el-col> -->
<right-toolbar
:showSearch.sync="showSearch"
@queryTable="getList"
></right-toolbar>
</el-col>-->
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
</el-row>
<el-table
v-loading="loading"
:data="classinfoList"
@selection-change="handleSelectionChange"
>
<el-table v-loading="loading" :data="classinfoList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center" />
<el-table-column
label="所属幼儿园"
align="center"
prop="kindergartenName"
/>
<el-table-column label="所属幼儿园" align="center" prop="kindergartenName" />
<el-table-column label="班级名称" align="center" prop="className" />
<el-table-column label="班级类型" align="center" prop="classType">
<template slot-scope="scope">
@ -132,23 +110,13 @@
</el-table-column>
<el-table-column label="班主任姓名" align="center" prop="classTeacher" />
<el-table-column
label="入学日期"
clearable
align="center"
prop="entranceYear"
width="180"
>
<el-table-column label="入学日期" clearable align="center" prop="entranceYear" width="180">
<template slot-scope="scope">
<span>{{ scope.row.entranceYear }}</span>
</template>
</el-table-column>
<el-table-column label="联系电话" align="center" prop="phone" />
<el-table-column
label="操作"
align="center"
class-name="small-padding fixed-width"
>
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
<template slot-scope="scope">
<el-button
size="mini"
@ -156,16 +124,14 @@
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
v-hasPermi="['system:classinfo:edit']"
>修改</el-button
>
>修改</el-button>
<el-button
size="mini"
type="text"
icon="el-icon-delete"
@click="handleDelete(scope.row)"
v-hasPermi="['system:classinfo:remove']"
>删除</el-button
>
>删除</el-button>
</template>
</el-table-column>
</el-table>
@ -183,7 +149,7 @@
<el-form ref="form" :model="form" :rules="rules" label-width="100px">
<el-form-item label="所属幼儿园" prop="kindergartenId">
<el-button
type=""
type
@click="innerVisible = true"
style="
width: 360px;
@ -193,19 +159,17 @@
padding-left: -10px;
"
v-if="kindergartenName == '请选择所在幼儿园'"
>{{ kindergartenName }}</el-button
>
>{{ kindergartenName }}</el-button>
<el-button
type=""
type
@click="innerVisible = true"
style="width: 360px; text-align: left; height: 36px"
v-else
>{{ kindergartenName }}</el-button
>
>{{ kindergartenName }}</el-button>
</el-form-item>
<el-form-item label="班级名称" prop="className">
<el-input v-model="form.className" placeholder="请输入班级名称" maxlength="40"/>
<el-input v-model="form.className" placeholder="请输入班级名称" maxlength="40" />
</el-form-item>
<el-form-item label="班级类型" prop="classType">
@ -218,11 +182,7 @@
</el-form-item>
<el-form-item label="班主任姓名" prop="classTeacher">
<el-input
v-model="form.classTeacher"
placeholder="请输入班主任姓名"
maxlength="10"
/>
<el-input v-model="form.classTeacher" placeholder="请输入班主任姓名" maxlength="10" />
</el-form-item>
<el-form-item label="入学日期" prop="entranceDateStr">
@ -232,136 +192,80 @@
v-model="form.entranceDateStr"
value-format="yyyy-MM-dd"
placeholder="请选择入学日期"
>
</el-date-picker>
></el-date-picker>
</el-form-item>
<el-form-item label="联系电话" prop="phone">
<el-input
v-model="form.phone"
placeholder="请输入联系电话"
maxlength="11"
/>
<el-input v-model="form.phone" placeholder="请输入联系电话" maxlength="11" />
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm"> </el-button>
<el-button @click="cancel"> </el-button>
</div>
</el-dialog>
<el-dialog
width="850px"
title="选择所属幼儿园"
:visible.sync="innerVisible"
append-to-body
<el-dialog width="850px" title="选择所属幼儿园" :visible.sync="innerVisible" append-to-body>
<el-form
:model="queryParams2"
ref="queryForm"
size="small"
:inline="true"
v-show="showSearch"
label-width="90px"
>
<el-form
:model="queryParams2"
ref="queryForm"
size="small"
:inline="true"
v-show="showSearch"
label-width="90px"
>
<el-form-item label="幼儿园名称" prop="kindergartenName">
<el-input
v-model="queryParams2.kindergartenName"
placeholder="请输入幼儿园名称"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="幼儿园地址" prop="kindergartenAddress">
<el-input
v-model="queryParams2.kindergartenAddress"
placeholder="请输入幼儿园地址"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item>
<el-form-item label="幼儿园名称" prop="kindergartenName">
<el-input
v-model="queryParams2.kindergartenName"
placeholder="请输入幼儿园名称"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="幼儿园地址" prop="kindergartenAddress">
<el-input
v-model="queryParams2.kindergartenAddress"
placeholder="请输入幼儿园地址"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item>
<el-button type="primary" 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>
<el-table :data="kindergartenInfoList" @cell-dblclick="kindergartenNameclick">
<el-table-column label="请选择" width="70" align="center">
<template slot-scope="scope">
<el-button
type="primary"
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>
v-if="kindergartenid2 == scope.row.id"
style="width: 15px; height: 15px"
circle
@click="kindergartenNameclick(scope.row)"
></el-button>
<el-table
:data="kindergartenInfoList"
@cell-dblclick="kindergartenNameclick"
>
<el-table-column label="请选择" width="70" align="center">
<template slot-scope="scope">
<el-button
type="primary"
v-if="kindergartenid2 == scope.row.id"
style="width: 15px; height: 15px"
circle
@click="kindergartenNameclick(scope.row)"
></el-button>
<el-button
v-else
style="width: 15px; height: 15px"
circle
@click="kindergartenNameclick(scope.row)"
></el-button>
</template>
</el-table-column>
<el-table-column
property="kindergartenName"
label="幼儿园名字"
width="150"
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>
<pagination
v-show="total2 > 0"
:total="total2"
:page.sync="queryParams2.pageNum"
:limit.sync="queryParams2.pageSize"
@pagination="getList"
/>
</el-dialog>
<el-button
v-else
style="width: 15px; height: 15px"
circle
@click="kindergartenNameclick(scope.row)"
></el-button>
</template>
</el-table-column>
<el-table-column property="kindergartenName" label="幼儿园名字" width="150" 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>
<pagination
v-show="total2 > 0"
:total="total2"
:page.sync="queryParams2.pageNum"
:limit.sync="queryParams2.pageSize"
@pagination="getList"
/>
</el-dialog>
</div>
</template>
@ -371,11 +275,11 @@ import {
getClassinfo,
delClassinfo,
addClassinfo,
updateClassinfo,
updateClassinfo
} from "@/api/system/classinfo";
import {
listKindergartenInfo,
tKindergartenInfo,
tKindergartenInfo
} from "@/api/system/kindergartenInfo";
import Treeselect from "@riophae/vue-treeselect";
import "@riophae/vue-treeselect/dist/vue-treeselect.css";
@ -387,10 +291,9 @@ export default {
var checkMobile = (rule, value, cb) => {
var str = String(value);
//
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}$/
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}$/;
// /^(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 isTel = reg.test(value);
if (str.length == 11) {
@ -440,14 +343,14 @@ export default {
kindergartenId: null,
className: null,
classType: null,
entranceDateStr: null,
entranceDateStr: null
},
queryParams2: {
pageNum: 1,
pageSize: 100,
pageSize: 1000,
kindergartenId: null,
className: null,
classType: null,
classType: null
},
time: "",
//
@ -459,22 +362,22 @@ export default {
required: true,
validator: checkMobile,
trigger: "blur",
message: "",
},
message: ""
}
],
kindergartenId: [{ required: true, message: "请选择所属幼儿园" }],
className: [
{ required: true, message: "请输入班级名称", trigger: "blur" },
{ required: true, message: "请输入班级名称", trigger: "blur" }
],
classType: [{ required: true, message: "请选择幼儿园类型" }],
classTeacher: [
{ required: true, message: "请输入班主任姓名", trigger: "blur" },
{ required: true, message: "请输入班主任姓名", trigger: "blur" }
],
entranceDateStr: [
{ required: true, message: "请选择日期", trigger: "change" },
],
},
{ required: true, message: "请选择日期", trigger: "change" }
]
}
};
},
created() {
@ -494,7 +397,7 @@ export default {
return {
kindergartenId: node.id,
label: node.kindergartenName,
children: node.children,
children: node.children
};
},
//ID
@ -503,16 +406,16 @@ export default {
getList() {
this.loading = true;
listKindergartenInfo(this.queryParams2).then((response) => {
listKindergartenInfo(this.queryParams2).then(response => {
this.kindergartenInfoList = response.rows;
this.total2 = response.total;
});
listClassinfo(this.queryParams).then((response) => {
listClassinfo(this.queryParams).then(response => {
this.classinfoList = response.rows;
this.total = response.total;
this.loading = false;
});
tKindergartenInfo(this.ClassType).then((res) => {
tKindergartenInfo(this.ClassType).then(res => {
this.dictValue1 = res.data[0].dictValue;
this.dictValue2 = res.data[1].dictValue;
this.dictValue3 = res.data[2].dictValue;
@ -535,7 +438,7 @@ export default {
classTeacher: null,
entranceDateStr: "",
phone: undefined,
kindergartenName: null,
kindergartenName: null
};
this.resetForm("form");
@ -543,14 +446,14 @@ export default {
/** 搜索按钮操作 */
handleQuery2() {
this.queryParams2.pageNum = 1;
listKindergartenInfo(this.queryParams2).then((response) => {
listKindergartenInfo(this.queryParams2).then(response => {
this.kindergartenInfoList = response.rows;
this.total2 = response.total;
});
},
handleQuery() {
this.queryParams.pageNum = 1;
listClassinfo(this.queryParams).then((response) => {
listClassinfo(this.queryParams).then(response => {
this.classinfoList = response.rows;
});
},
@ -561,21 +464,21 @@ export default {
pageSize: 10,
kindergartenId: null,
className: null,
classType: null,
classType: null
};
this.queryParams2 = {
pageNum: 1,
pageSize: 10,
kindergartenId: null,
className: null,
classType: null,
classType: null
};
this.handleQuery();
this.handleQuery2();
},
//
handleSelectionChange(selection) {
this.ids = selection.map((item) => item.id);
this.ids = selection.map(item => item.id);
this.single = selection.length !== 1;
this.multiple = !selection.length;
},
@ -592,7 +495,7 @@ export default {
this.kindergartenid2 = row.kindergartenId;
this.reset();
const id = row.id || this.ids;
getClassinfo(id).then((response) => {
getClassinfo(id).then(response => {
response.data.phone = Number(response.data.phone);
this.form = response.data;
this.kindergartenName = this.form.kindergartenName;
@ -602,16 +505,16 @@ export default {
},
/** 提交按钮 */
submitForm() {
this.$refs["form"].validate((valid) => {
this.$refs["form"].validate(valid => {
if (valid) {
if (this.form.id != null) {
updateClassinfo(this.form).then((response) => {
updateClassinfo(this.form).then(response => {
this.$modal.msgSuccess("修改成功");
this.open = false;
this.getList();
});
} else {
addClassinfo(this.form).then((response) => {
addClassinfo(this.form).then(response => {
this.$modal.msgSuccess("新增成功");
this.open = false;
this.getList();
@ -626,7 +529,7 @@ export default {
const ids = row.id || this.ids;
this.$modal
.confirm("是否确认删除数据?")
.then(function () {
.then(function() {
return delClassinfo(ids);
})
.then(() => {
@ -634,7 +537,7 @@ export default {
this.$modal.msgSuccess("删除成功");
})
.catch(() => {});
},
}
/** 导出按钮操作 */
// handleExport() {
// this.download(
@ -645,6 +548,6 @@ export default {
// `classinfo_${new Date().getTime()}.xlsx`
// );
// },
},
}
};
</script>