|
@@ -1,5 +1,198 @@
|
|
|
<template>
|
|
|
- <div> 设备管理 </div>
|
|
|
+ <div class="p-4">
|
|
|
+ <BasicTable @register="registerTable">
|
|
|
+ <template #toolbar> </template>
|
|
|
+
|
|
|
+ <template #cameraType="{ record }">
|
|
|
+ <Tag color="green">{{ rendercameraTypeLabel(record.cameraType) }} </Tag></template
|
|
|
+ >
|
|
|
+ <template #own="{ record }">
|
|
|
+ {{ renderOwnTypeLabel(record.own) }}
|
|
|
+ </template>
|
|
|
+
|
|
|
+ <template #action>
|
|
|
+ <TableAction
|
|
|
+ :actions="[
|
|
|
+ {
|
|
|
+ icon: 'clarity:note-edit-line',
|
|
|
+ label: '编辑',
|
|
|
+ onClick: () => {
|
|
|
+ createMessage.info(`暂未接入`);
|
|
|
+ },
|
|
|
+ },
|
|
|
+ {
|
|
|
+ icon: 'ant-design:delete-outlined',
|
|
|
+ color: 'error',
|
|
|
+ label: '删除',
|
|
|
+ popConfirm: {
|
|
|
+ title: '是否确认删除',
|
|
|
+ confirm: () => {
|
|
|
+ createMessage.info(`暂未接入`);
|
|
|
+ },
|
|
|
+ },
|
|
|
+ },
|
|
|
+ ]"
|
|
|
+ />
|
|
|
+ </template>
|
|
|
+ </BasicTable>
|
|
|
+ </div>
|
|
|
</template>
|
|
|
+<script lang="ts">
|
|
|
+ import { defineComponent } from 'vue';
|
|
|
+ import { BasicTable, useTable, BasicColumn, FormProps, TableAction } from '/@/components/Table';
|
|
|
+ import { useMessage } from '/@/hooks/web/useMessage';
|
|
|
+ import { Tag } from 'ant-design-vue';
|
|
|
+ import { ListApi } from '/@/api/device/list';
|
|
|
+ // param type 0
|
|
|
+ export default defineComponent({
|
|
|
+ components: { BasicTable, TableAction, Tag },
|
|
|
+ setup() {
|
|
|
+ const { createMessage } = useMessage();
|
|
|
+ const columns: BasicColumn[] = [
|
|
|
+ {
|
|
|
+ title: '设备ID',
|
|
|
+ dataIndex: 'id',
|
|
|
+ fixed: 'left',
|
|
|
+ width: 100,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ title: '手机号(用户名)',
|
|
|
+ dataIndex: 'userName',
|
|
|
+ width: 230,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ title: '设备类型',
|
|
|
+ dataIndex: 'cameraType',
|
|
|
+ width: 230,
|
|
|
+ slots: { customRender: 'cameraType' },
|
|
|
+ },
|
|
|
+ {
|
|
|
+ title: 'sn码',
|
|
|
+ dataIndex: 'snCode',
|
|
|
+ width: 120,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ title: 'wifi',
|
|
|
+ dataIndex: 'wifiName',
|
|
|
+ width: 180,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ title: '激活时间',
|
|
|
+ dataIndex: 'activatedTime',
|
|
|
+ width: 150,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ title: '出货类型',
|
|
|
+ dataIndex: 'own',
|
|
|
+ slots: { customRender: 'own' },
|
|
|
+ width: 120,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ title: '客户名称',
|
|
|
+ dataIndex: 'companyName',
|
|
|
+ width: 120,
|
|
|
+ },
|
|
|
+ ];
|
|
|
+
|
|
|
+ const searchForm: Partial<FormProps> = {
|
|
|
+ labelWidth: 100,
|
|
|
+ schemas: [
|
|
|
+ {
|
|
|
+ field: 'part',
|
|
|
+ component: 'Select',
|
|
|
+ label: '选择',
|
|
|
+ defaultValue: '1',
|
|
|
+ colProps: {
|
|
|
+ span: 4,
|
|
|
+ },
|
|
|
+ componentProps: {
|
|
|
+ options: [
|
|
|
+ {
|
|
|
+ label: '全部',
|
|
|
+ value: '1',
|
|
|
+ key: '1',
|
|
|
+ },
|
|
|
+ {
|
|
|
+ label: '正常',
|
|
|
+ value: '2',
|
|
|
+ key: '2',
|
|
|
+ },
|
|
|
+ {
|
|
|
+ label: '已关闭',
|
|
|
+ value: '2',
|
|
|
+ key: '2',
|
|
|
+ },
|
|
|
+ ],
|
|
|
+ },
|
|
|
+ },
|
|
|
+ {
|
|
|
+ field: 'phone',
|
|
|
+ label: '手机号',
|
|
|
+ component: 'Input',
|
|
|
+ colProps: {
|
|
|
+ span: 6,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ {
|
|
|
+ field: 'fieldTime',
|
|
|
+ component: 'RangePicker',
|
|
|
+ label: '时间字段',
|
|
|
+ colProps: {
|
|
|
+ span: 8,
|
|
|
+ },
|
|
|
+ },
|
|
|
+ ],
|
|
|
+ };
|
|
|
+ // { getForm }
|
|
|
+ const [registerTable] = useTable({
|
|
|
+ title: '设备列表',
|
|
|
+ api: ListApi,
|
|
|
+ columns: columns,
|
|
|
+ useSearchForm: true,
|
|
|
+ formConfig: searchForm,
|
|
|
+ showTableSetting: true,
|
|
|
+ tableSetting: { fullScreen: true },
|
|
|
+ showIndexColumn: false,
|
|
|
+ rowKey: 'id',
|
|
|
+ });
|
|
|
+ // pagination.value = { pageSize: 20 };
|
|
|
+ function rendercameraTypeLabel(cameraType: number): string {
|
|
|
+ switch (cameraType) {
|
|
|
+ case 4:
|
|
|
+ return '四维看看Pro八目相机';
|
|
|
+ case 1:
|
|
|
+ return '四维看看Lite双目相机';
|
|
|
+ case 9:
|
|
|
+ return '四维看看双目转台相机';
|
|
|
+ case 10:
|
|
|
+ return '四维看看激光相机';
|
|
|
+ case 6:
|
|
|
+ return '第三方相机';
|
|
|
+ default:
|
|
|
+ return '';
|
|
|
+ }
|
|
|
+ }
|
|
|
+ function renderOwnTypeLabel(type: number): string {
|
|
|
+ switch (type) {
|
|
|
+ case 0:
|
|
|
+ return '正常销售';
|
|
|
+ case 2:
|
|
|
+ return '礼品赠送';
|
|
|
+ case 1:
|
|
|
+ return '员工自用';
|
|
|
+ case 3:
|
|
|
+ return '其它';
|
|
|
+ default:
|
|
|
+ return '';
|
|
|
+ }
|
|
|
+ }
|
|
|
|
|
|
-<script lang="ts" setup></script>
|
|
|
+ return {
|
|
|
+ registerTable,
|
|
|
+ createMessage,
|
|
|
+ rendercameraTypeLabel,
|
|
|
+ renderOwnTypeLabel,
|
|
|
+ };
|
|
|
+ },
|
|
|
+ });
|
|
|
+</script>
|