123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432 |
- <template>
- <div class="jt-drawing-dialog">
- <el-dialog :modal="false" :destroy-on-close="false" v-model="dialogVisible" :title="title" :style="{ left: '10rem', background: 'rgb(0 44 126 / 68%)', height: 'calc(100% - 175rem)', width: '180rem', top: '125rem' }" @close="closeDialog" @open="openDialog" :show-close="false">
- <template #header>
- <div slot="title" class="header-title">
- <span style="line-height:24rem;font-size:16rem;color:#fff;font-family: 'Alimama_ShuHeiTi_Bold'">{{ title }}</span>
- </div>
- </template>
- <template #default>
- <div class="odin-dialog__content">
- <div class="jt-drawing-row">
- <div class="col-left">颜色</div>
- <div class="col-main">
- <el-config-provider :locale="locale">
- <el-color-picker v-model="color" show-alpha :predefine="predefineColors" label="12" />
- </el-config-provider>
- </div>
- </div>
- <!-- <div class="jt-drawing-row">
- <div class="col-left">是否边框</div>
- <div class="col-main">
- <el-switch v-model="isShowOutline" />
- </div>
- </div>
- <div class="jt-drawing-row" v-show="isShowOutline">
- <div class="col-left">描边宽度</div>
- <div class="col-main">
- <el-input-number v-model="outlineWidth" :min="0" :max="100" />
- </div>
- </div>
- <div class="jt-drawing-row" v-show="isShowOutline">
- <div class="col-left">描边颜色</div>
- <div class="col-main">
- <el-config-provider :locale="locale">
- <el-color-picker v-model="outlineColor" show-alpha :predefine="predefineColors" label="12" />
- </el-config-provider>
- </div>
- </div> -->
- <div class="el-body-foot">
- <el-button-group>
- <el-button type="primary" :icon="Edit" @click="submit()">修改</el-button>
- <el-button type="primary" style="background-color: rgb(222, 146, 47);" :icon="Delete" @click="remove()">删除</el-button>
- <el-button type="primary" style="background-color: rgb(126, 128, 135);" :icon="Close" @click="close()">关闭</el-button>
- </el-button-group>
- </div>
- </div>
- </template>
- </el-dialog>
- </div>
- </template>
- <script setup>
- /* 引入ref和reactive 其中ref用于简单类型 reactive用于复杂类型 */
- import {
- computed,
- ref,
- reactive,
- toRefs,
- watch,
- getCurrentInstance
- } from 'vue';
- /* 引入element-plus字体包 */
- import zhCn from 'element-plus/dist/locale/zh-cn.mjs';
- import en from 'element-plus/dist/locale/en.mjs';
- /* 引入element-plus组件 */
- import {
- ElDialog,
- ElInput,
- ElSelect,
- ElOption,
- ElSwitch,
- ElButtonGroup,
- ElConfigProvider,
- ElColorPicker,
- ElRadioButton,
- ElButton,
- ElRadioGroup,
- ElInputNumber,
- ElCollapse,
- ElCollapseItem,
- ElIcon
- } from 'element-plus';
- /* 引入element-plus字体 */
- import {
- ArrowLeft,
- ArrowRight,
- Delete,
- Edit,
- Share,
- Close
- } from '@element-plus/icons-vue';
- import {
- param,
- type
- } from 'jquery';
- import DrawMilitaryPlot from './DrawMilitaryPlot.js';
- const language = ref('zh-cn');
- const locale = computed(() => (language.value === 'zh-cn' ? zhCn : en));
- const {
- proxy
- } = getCurrentInstance();
- const props = defineProps({
- params: {
- id: {
- type: String,
- default: () => undefined
- },
- color: {
- type: String,
- default: () => '255,255,0,0.9'
- },
- outlineWidth: {
- type: Number,
- default: () => 0
- },
- outlineColor: {
- type: String,
- default: () => '255,255,0,0.9'
- },
- },
- showDialog: {
- type: Boolean,
- default: () => false
- }
- });
- const emit = defineEmits(['submit', 'update:showDialog', 'update:params', 'remove']);
- /* 默认颜色 */
- const predefineColors = ref([
- '#ff4500',
- '#ff8c00',
- '#ffd700',
- '#90ee90',
- '#00ced1',
- '#1e90ff',
- '#c71585',
- 'rgba(255, 69, 0, 0.68)',
- 'rgb(255, 120, 0)',
- 'hsv(51, 100, 98)',
- 'hsva(120, 40, 94, 0.5)',
- 'hsl(181, 100%, 37%)',
- 'hsla(209, 100%, 56%, 0.73)',
- '#c7158577'
- ]);
- /* 初始赋值 */
- const title = ref('属性编辑');
- const dialogVisible = ref(props.showDialog);
- const isShowOutline = ref(false);
- const color = ref(props.params.color);
- const outlineWidth = ref(0);
- const outlineColor = ref(props.params.outlineColor);
- /* 根据传递的属性更新 */
- updateParams(props.params);
- /**
- * 根据参数更新内容
- * @param {JSON} params 参数
- */
- function updateParams(params) {
- /* 保存到本地 */
- proxy._params = params;
- // _setShowControls(false);
- /* 根据参数的显示不同的内容 */
- switch (params.id) {
- case "DrawStraightArrow":
- title.value = '绘制直线箭头';
- break;
- case "DrawAttackArrow":
- title.value = '绘制攻击箭头';
- break;
- case "DrawPincerArrow":
- title.value = '绘制钳击箭头';
- break;
- case "DrawGatheringPlace":
- title.value = '绘制集结地';
- break;
- case "DrawClosedCurve":
- title.value = '绘制闭合曲面';
- break;
- case "DrawSector":
- title.value = '绘制扇形';
- break;
- case "DrawBowLine":
- title.value = '绘制弓形线';
- break;
- case "DrawLune":
- title.value = '绘制弓形面';
- break;
- case "DrawCurve":
- title.value = '绘制曲线';
- break;
- case "DrawCurveFlag":
- title.value = '绘制曲线旗帜';
- break;
- case "DrawRectFlag":
- title.value = '绘制矩形直角旗帜';
- break;
- case "DrawTriangleFlag":
- title.value = '绘制三角旗帜';
- break;
- }
- color.value = params.color;
- outlineColor.value = params.outlineColor;
- outlineWidth.value = params.outlineWidth;
- }
- /**
- * 显示控件设置
- * @param {Boolean} isShow 是否显示
- */
- function _setShowControls(isShow) {
- isShowColor.value = isShow;
- isShowOutlineColor.value = isShow;
- isShowOutlineWidth.value = isShow;
- }
- /**
- * 对外部公开的函数
- */
- defineExpose({
- // updateParams
- });
- /**
- * 提交更改
- */
- function submit() {
- let outParam = proxy._params;
- outParam.color = color.value;
- outParam.outlineColor = outlineColor.value;
- outParam.outlineWidth = outlineWidth.value;
- emit('submit', outParam);
- }
- /**
- * 关闭
- */
- function close() {
- dialogVisible.value = false;
- }
- /**
- * 提交删除
- */
- function remove() {
- emit('remove', {});
- dialogVisible.value = false;
- }
- /**
- * 窗口关闭,修改双向绑定值
- */
- function closeDialog() {
- emit('update:showDialog', false);
- }
- /**
- * 窗口打开
- */
- function openDialog() {
- updateParams(props.params);
- }
- </script>
- <style lang="scss">
- /* 引入element-plus的内部样式 必须在此处引入 否则无效 */
- /* 为了保证引入的样式文件起作用 必须保证文件名称以.ce.vue结束 */
- @import 'element-plus/theme-chalk/index.css';
- //组件内部样式
- .el-button {
- height: 32rem !important;
- padding: 8rem 15rem !important;
- font-size: 14rem !important;
- }
- .el-input__wrapper {
- padding: 1rem 11rem !important;
- }
- .el-input {
- height: 32rem !important;
- font-size: 14rem !important;
- }
- .jt-drawing-row .col-left {
- font-size: 14rem !important;
- }
- .el-color-picker__trigger {
- height: 32rem !important;
- padding: 4rem !important;
- }
- .el-radio-button__inner {
- padding: 8rem 15rem !important;
- font-size: 14rem;
- }
- .el-textarea__inner {
- padding: 5rem 11rem !important;
- font-size: 14rem;
- }
- .el-input__inner {
- height: 32rem !important;
- font-size: 14rem !important;
- }
- /* 墙对话框内容行样式 */
- .jt-drawing-row {
- display: flex;
- flex-direction: row;
- height: 40rem;
- align-items: center;
- /* 行左侧标题样式 */
- .col-left {
- display: flex;
- align-items: center;
- justify-content: right;
- width: 60rem;
- font-family: 'Alimama_ShuHeiTi_Bold';
- font-weight: bold;
- margin-right: 8rem;
- }
- /* 主要内容样式 */
- .col-main {
- flex: 1;
- display: flex;
- flex-direction: row;
- .el-input--suffix {
- background-color: rgba(255, 255, 255, 0);
- }
- .el-input--suffix * {
- background-color: rgba(255, 255, 255, 0);
- color: rgba(255, 255, 255, 1);
- }
- /* 数字组件按钮背景色 */
- .el-input-number__decrease,
- .el-input-number__increase {
- background-color: rgb(52, 137, 255);
- color: rgb(255, 255, 255);
- }
- }
- }
- /* 墙对话框整体样式 */
- .jt-drawing-dialog {
- pointer-events: none; // ***覆盖层元素增加可穿透点击事件***
- .el-dialog {
- pointer-events: auto; // ***弹窗层元素不可穿透点击事件(不影响弹窗层元素的点击事件)***
- position: absolute !important; //将通知框的position改成absolute,可以在某个div进行显示
- background: rgb(5 45 155 / 70%);
- min-width: 280rem;
- overflow: hidden;
- margin-top: 0rem;
- /* 对话框标题头样式 */
- .el-dialog__header {
- background: url() no-repeat;
- background-size: 100%;
- margin-right: 0rem;
- padding: 6rem;
- text-align: center;
- }
- /* 对话框关闭按钮的样式 */
- .el-dialog__headerbtn {
- height: 34rem;
- }
- /* 对话框主体的样式 */
- .el-dialog__body {
- padding: 10rem;
- color: #fff;
- }
- /* 颜色选择器的宽度 */
- .el-color-picker__trigger {
- width: 120rem;
- }
- /* 底部按钮容器样式 */
- .el-body-foot {
- position: absolute;
- bottom: 8rem;
- right: 8rem;
- width: calc(100% - 16rem);
- }
- /* 底部容器内分组容器样式 */
- .el-body-foot .el-button-group {
- display: flex;
- }
- /* 底部容器内按钮样式 */
- .el-body-foot .el-button-group .el-button {
- border: solid 0rem rgb(255, 0, 0);
- flex: 1;
- }
- }
- }
- </style>
|