riku
2023-07-20 d22ce1ad1c4656f5c2212bbabb35ba498300aced
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
<template>
  <div>
    <el-button type="primary" @click="createGrid">新建网格</el-button>
  </div>
  <el-dialog v-model="dialogVisible" title="Tips" width="30%">
    <el-form
      :inline="false"
      :model="formObj"
      ref="formRef"
      :rules="rules"
      label-position="right"
      label-width="150px"
    >
      <el-form-item label="网格名称" prop="gName">
        <el-input
          clearable
          show-word-limit
          v-model="formObj.gName"
          placeholder="网格名称"
        />
      </el-form-item>
      <el-form-item>
        <el-button
          :disabled="!edit"
          type="primary"
          @click="onSubmit"
          :loading="loading"
          >提交</el-button
        >
        <el-button @click="onCancel">取消</el-button>
      </el-form-item>
    </el-form>
  </el-dialog>
</template>
 
<script setup>
import { reactive, ref, watch } from 'vue';
import { useFormConfirm } from '@/composables/formConfirm';
import { useGridStore } from '@/stores/grid';
import mapGrid from '@/components/map/mapGrid';
import baseMapUtil from '@/components/map/baseMapUtil';
 
const gridStore = useGridStore();
 
// 网格绘制确认对话框
const dialogVisible = ref(false);
// 临时网格覆盖物
let tempOverlays;
 
// 新建网格
const createGrid = function () {
  mapGrid.mouseDrawPolygon((event) => {
    tempOverlays = event.obj;
    dialogVisible.value = true;
  });
};
 
const props = defineProps({
  //基本信息
  formInfo: Object,
  //是创建或者更新
  isCreate: Boolean,
  //
  isActive: Boolean
});
 
const emit = defineEmits(['onSubmit', 'onCancel']);
 
const { formObj, formRef, edit, active, onSubmit, onCancel } =
  useFormConfirm({
    submit: {
      do: submit
    },
    cancel: {
      do: cancel
    }
  });
 
const loading = ref(false);
 
const rules = reactive({
  gName: [
    {
      required: true,
      message: '网格名称不能为空',
      trigger: 'blur'
    }
  ]
});
 
// 创建
async function create() {
  // loading.value = true;
  // return sceneApi
  //   .createScene(formObj.value)
  //   .then((res) => {
  //     console.log(res);
  //   })
  //   .finally(() => {
  //     loading.value = false;
  //   });
}
 
// 更新
async function update() {
  // loading.value = true;
  // return sceneApi
  //   .updateScene(formObj.value)
  //   .then((res) => {
  //     console.log(res);
  //   })
  //   .finally(() => {
  //     loading.value = false;
  //   });
}
 
function submit() {
  const newRecord = {
    gId: '1',
    gType: 0,
    gName: formObj.value.gName,
    gSide: tempOverlays.getPath(),
    overlays: tempOverlays
  };
 
  gridStore.addGrid(newRecord);
  emit('onSubmit', newRecord);
  dialogVisible.value = false;
 
  return props.isCreate ? create() : update();
}
function cancel() {
  emit('onCancel');
  baseMapUtil.removeView(tempOverlays);
  dialogVisible.value = false;
}
 
watch(
  () => props.formInfo,
  (nValue) => {
    formObj.value = nValue;
  },
  { immediate: false }
);
 
watch(dialogVisible, (nValue) => {
  active.value = nValue;
});
</script>