import OHeader from '@/components/o-header' import OQrcode from '@/components/o-qrcode' import OSearch from '@/components/o-search' import OSticky from '@/components/o-sticky' import { ActionSheet, Cell, closeToast, Grid, GridItem, Icon, Image, List, Popup, showFailToast, showLoadingToast, showSuccessToast, showToast } from 'vant' import { defineComponent, onMounted, reactive } from 'vue' import styles from './index.module.less' import iconSaveImage from '@/school/orchestra/images/icon-save-image.png' import iconWechat from '@/school/orchestra/images/icon-wechat.png' import iconTeacher from '@common/images/icon_teacher.png' import { useRouter } from 'vue-router' import request from '@/helpers/request' import { state } from '@/state' import OEmpty from '@/components/o-empty' import OFullRefresh from '@/components/o-full-refresh' import { manageTeacherType } from '@/constant' import html2canvas from 'html2canvas' import { promisefiyPostMessage, postMessage } from '@/helpers/native-message' export default defineComponent({ name: 'companion-teacher', setup() { const router = useRouter() const form = reactive({ oPopover: false, list: [] as any, listState: { dataShow: true, // 判断是否有数据 loading: false, finished: false, refreshing: false, height: 0 // 页面头部高度,为了处理下拉刷新用的 }, statusText: '状态', params: { keyword: null, status: null, page: 1, rows: 20 }, isClick: false }) const getList = async () => { try { if (form.isClick) return form.isClick = true const res = await request.post('/api-school/schoolStaff/page', { data: { ...form.params, schoolId: state.user.data.school.id } }) form.listState.loading = false form.listState.refreshing = false const result = res.data || {} // 处理重复请求数据 if (form.list.length > 0 && result.current === 1) { return } form.list = form.list.concat(result.rows || []) form.listState.finished = result.current >= result.pages form.params.page = result.current + 1 form.listState.dataShow = form.list.length > 0 form.isClick = false } catch { form.listState.dataShow = false form.listState.finished = true form.listState.refreshing = false form.isClick = false } } const onSearch = () => { form.params.page = 1 form.list = [] form.listState.dataShow = true // 判断是否有数据 form.listState.loading = false form.listState.finished = false getList() } const onDetail = (item: any) => { router.push({ path: '/manage-teacher-detail', query: { id: item.id } }) } onMounted(async () => { getList() }) return () => (
{item.nickname}
{item.phone}