<template>
    <div>
        <el-form ref="form" :model="form" :rules="rules" label-width="160px">
            <div class="inputBox flexBox">
                <span class="label">传感器ID</span>
                <div>{{ form.sensorCode }}</div>
            </div>
            <el-form-item label="传感器名称:" prop="sensorName">
                <el-input
                    placeholder="请输入"
                    maxlength="60"
                    v-autoTrim="{ obj: form, key: 'sensorName' }"
                    v-model="form.sensorName"
                >
                </el-input>
            </el-form-item>
            <el-form-item label="传感器描述:" prop="description">
                <el-input
                    v-autoTrim="{
                        obj: form,
                        key: 'description',
                    }"
                    v-model="form.description"
                    type="textarea"
                    placeholder="请输入传感器描述"
                    :autosize="{ minRows: 4, maxRows: 4 }"
                    maxlength="200"
                ></el-input>
            </el-form-item>

            <div class="titlePanel">
                <div class="titlePanelBor">内参</div>
            </div>
            <el-form-item label="盲区距离(m):" prop="nearDistance">
                <el-input
                    placeholder="请输入"
                    maxlength="15"
                    v-autoTrim="{ obj: form, key: 'nearDistance' }"
                    v-model="form.nearDistance"
                >
                </el-input>
            </el-form-item>
            <el-form-item label="探测距离(m):" prop="farDistance">
                <el-input
                    placeholder="请输入"
                    maxlength="15"
                    v-autoTrim="{ obj: form, key: 'farDistance' }"
                    v-model="form.farDistance"
                    @input="inputChange"
                >
                </el-input>
            </el-form-item>
            <el-form-item label="水平视场角左(deg):" prop="fovHLeft">
                <el-input
                    placeholder="请输入"
                    maxlength="15"
                    v-autoTrim="{ obj: form, key: 'fovHLeft' }"
                    v-model="form.fovHLeft"
                    @input="inputChange"
                >
                </el-input>
            </el-form-item>
            <el-form-item label="水平视场角右(deg):" prop="fovHRight">
                <el-input
                    placeholder="请输入"
                    maxlength="15"
                    v-autoTrim="{ obj: form, key: 'fovHRight' }"
                    v-model="form.fovHRight"
                    @input="inputChange"
                >
                </el-input>
            </el-form-item>
            <el-form-item label="垂直视场角顶(deg):" prop="fovVTop">
                <el-input
                    placeholder="请输入"
                    maxlength="15"
                    v-autoTrim="{ obj: form, key: 'fovVTop' }"
                    v-model="form.fovVTop"
                >
                </el-input>
            </el-form-item>
            <el-form-item label="垂直视场角底(deg):" prop="fovVBottom">
                <el-input
                    placeholder="请输入"
                    maxlength="15"
                    v-autoTrim="{ obj: form, key: 'fovVBottom' }"
                    v-model="form.fovVBottom"
                >
                </el-input>
            </el-form-item>

            <div class="titlePanel">
                <div class="titlePanelBor">其他</div>
            </div>
            <el-form-item label="显示探测锥:" prop="rangeDisplay">
                <el-radio v-model="form.rangeDisplay" label="1">是</el-radio>
                <el-radio v-model="form.rangeDisplay" label="0">否</el-radio>
            </el-form-item>
            <el-form-item label="最大目标物数量(个):" prop="maxObjects">
                <el-input
                    placeholder="请输入"
                    maxlength="10"
                    v-autoTrim="{ obj: form, key: 'maxObjects' }"
                    v-model="form.maxObjects"
                >
                </el-input>
            </el-form-item>
            <el-form-item label="坐标系:" prop="coordinateSystem">
                <el-select v-model="form.coordinateSystem">
                    <el-option
                        v-for="item in coordinateSystemList"
                        :label="item.caption"
                        :value="item.code"
                        :key="item.code"
                    ></el-option>
                </el-select>
            </el-form-item>
            <el-form-item label="目标物筛选:" prop="targetFilter">
                <el-checkbox
                    :indeterminate="isIndeterminate"
                    v-model="checkAll"
                    @change="handleCheckAllChange"
                    >全选</el-checkbox
                >
                <el-checkbox-group
                    v-model="form.targetFilter"
                    @change="handleCheckedTargetChange"
                >
                    <el-checkbox
                        v-for="target in targetOptions"
                        :label="target.code"
                        :key="target.code"
                        >{{ target.caption }}</el-checkbox
                    >
                </el-checkbox-group>
            </el-form-item>
        </el-form>
    </div>
</template>

<script>
//import  from '';

export default {
    name: "formPerfectSensor", // form-完美传感器
    components: {},
    data() {
        return {
            coordinateSystemList: [],
            checkAll: false,
            isIndeterminate: false,
            targetOptions: [],
            form: {
                id: "", // id
                sensorCode: "", // 传感器编码
                sensorName: "", // 传感器名称
                description: "", // 传感器描述
                nearDistance: "", // 盲区距离
                farDistance: "", // 探测距离
                fovHLeft: "", // 水平现场角左
                fovHRight: "", // 水平现场角右
                fovVTop: "", // 垂直现场角顶
                fovVBottom: "", // 垂直现场角底
                rangeDisplay: "1", // 显示探测锥
                maxObjects: "", // 最大目标物个数
                coordinateSystem: "", // 坐标系
                targetFilter: [], // 目标物筛选
                share: "", // 是否分享
            },
            rules: {
                sensorName: [
                    { required: true, message: "请输入", trigger: "blur" },
                ],
                description: [
                    { required: true, message: "请输入", trigger: "blur" },
                ],
                nearDistance: [
                    { required: true, message: "请输入", trigger: "blur" },
                ],
                farDistance: [
                    { required: true, message: "请输入", trigger: "blur" },
                ],
                fovHLeft: [
                    { required: true, message: "请输入", trigger: "blur" },
                ],
                fovHRight: [
                    { required: true, message: "请输入", trigger: "blur" },
                ],
                fovVTop: [
                    { required: true, message: "请输入", trigger: "blur" },
                ],
                fovVBottom: [
                    { required: true, message: "请输入", trigger: "blur" },
                ],
                rangeDisplay: [
                    { required: true, message: "请选择", trigger: "change" },
                ],
                maxObjects: [
                    { required: true, message: "请输入", trigger: "blur" },
                ],
                coordinateSystem: [
                    { required: true, message: "请选择", trigger: "change" },
                ],
                targetFilter: [
                    { required: true, message: "请选择", trigger: "change" },
                ],
            },
        };
    },

    computed: {},

    methods: {
        showInfo(id) {
            this.$axios({
                method: "post",
                url: this.$api.modelLibrary.getOgtInfo,
                data: {
                    id,
                },
            }).then((res) => {
                if (res.code == 200 && res.info) {
                    this.$refs.form.clearValidate();
                    this.form = res.info;
                    this.form.targetFilter = res.info.targetFilter.split(",");
                    // 传回当前展示form的share,从而改变按钮的展示
                    this.$emit("changeShare", this.form.share);
                    // 数据加载完毕,可展示canvas
                    this.$emit("showDone");
                } else {
                    this.$message.error(res.message || "获取失败");
                }
            });
        },
        save(isAdd = false) {
            this.$refs.form.validate((valid) => {
                if (valid) {
                    // 判断是否新增
                    if (isAdd) {
                        this.form.id = "";
                    }

                    let data = {
                        ...this.form,
                        targetFilter: this.form.targetFilter.join(","),
                    };

                    this.$axios({
                        method: "post",
                        url: this.$api.modelLibrary.saveOgt,
                        data,
                    }).then((res) => {
                        if (res.code == 200 && res.info) {
                            this.form.id = res.info.id;
                            this.form.share = res.info.share;
                            this.$message.success("保存成功");
                            this.$emit("changeShare", this.form.share);
                            this.$emit("getList");
                        } else {
                            this.$message.error(res.message || "保存失败");
                        }
                    });
                }
            });
        },
        share() {
            let data = {
                ...this.form,
                targetFilter: this.form.targetFilter.join(","),
            };

            this.$axios({
                method: "post",
                url: this.$api.modelLibrary.shareOgt,
                data,
            }).then((res) => {
                if (res.code == 200) {
                    this.$message.success("分享成功");
                    this.$emit("getList");
                } else {
                    this.$message.error(res.message || "分享失败");
                }
            });
        },
        cancel() {
            if (this.form.id) {
                // 取消时有id则重新请求表单
                this.showInfo(this.form.id);
            } else {
                // 清空
                this.$emit("clearForm");
            }
        },
        handleCheckAllChange(val) {
            this.form.targetFilter = val
                ? this.targetOptions.map((i) => i.code)
                : [];
            this.isIndeterminate = false;
        },
        handleCheckedTargetChange(value) {
            let checkedCount = value.length;
            this.checkAll = checkedCount === this.form.targetFilter.length;
            this.isIndeterminate =
                checkedCount > 0 && checkedCount < this.targetOptions.length;
        },
        inputChange() {
            if (
                this.form.farDistance === "" ||
                this.form.fovHLeft === "" ||
                this.form.fovHRight === ""
            )
                return;
            this.$emit("inputChange", {
                r: this.form.farDistance,
                hl: this.form.fovHLeft,
                hr: this.form.fovHRight,
            });
        },
    },

    async mounted() {
        await this.$dicsListsInit({
            coordinateSystemList: "coordinate",
            targetOptions: "targetFilter",
        });
    },
};
</script>

<style lang='less' scoped>
@import "../common/util.less";
</style>