mirror of
https://gitee.com/hoslay/ddei-editor.git
synced 2025-12-07 01:28:28 +08:00
207 lines
4.7 KiB
Vue
207 lines
4.7 KiB
Vue
<template>
|
|
<div :id="editor?.id + '_' + dialogId" class="ddei-core-dialog-selectborderdash" v-if="forceRefresh">
|
|
<div class="content">
|
|
<div class="group">
|
|
<div class="title">选择线段类型</div>
|
|
<div class="group_content">
|
|
<div :class="{ 'item': true, 'item-selected': JSON.stringify(value) == JSON.stringify(data.value) }"
|
|
v-for="data in dataSource" @click="select(data.value)" @dblclick="selectAndConfirm(data.value)">
|
|
<svg class="div_input">
|
|
<line x1=0 y1=0 x2="100%" y2=0 stroke-width="3" :stroke-dasharray="data.value">
|
|
</line>
|
|
</svg>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="tail">
|
|
<div class="button button-main" @click="ok">确定</div>
|
|
<div class="button" @click="cancel">取消</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
import {DDeiEditorUtil} from "ddei-framework";
|
|
import DialogBase from "./dialog"
|
|
|
|
export default {
|
|
name: "ddei-core-dialog-selectborderdash",
|
|
extends: null,
|
|
mixins: [DialogBase],
|
|
props: {
|
|
//外部传入的插件扩展参数
|
|
options: {
|
|
type: Object,
|
|
default: null
|
|
}
|
|
},
|
|
data() {
|
|
return {
|
|
dialogId: 'ddei-core-dialog-selectborderdash',
|
|
value: [],
|
|
//最近使用的颜色
|
|
dataSource: null
|
|
}
|
|
},
|
|
computed: {},
|
|
components: {},
|
|
watch: {},
|
|
created() { },
|
|
mounted() {
|
|
this.refreshData()
|
|
},
|
|
methods: {
|
|
refreshData(){
|
|
if (this.editor?.tempDialogData && this.editor?.tempDialogData[this.dialogId]?.value) {
|
|
this.value = this.editor?.tempDialogData[this.dialogId].value
|
|
}
|
|
if (this.editor?.tempDialogData && this.editor?.tempDialogData[this.dialogId]?.dataSource) {
|
|
this.dataSource = this.editor?.tempDialogData[this.dialogId].dataSource
|
|
}
|
|
},
|
|
|
|
select(value) {
|
|
this.value = value
|
|
},
|
|
selectAndConfirm(value) {
|
|
this.value = value
|
|
this.ok()
|
|
},
|
|
|
|
ok() {
|
|
if (this.value) {
|
|
if (this.editor?.tempDialogData[this.dialogId]?.callback?.ok) {
|
|
this.editor?.tempDialogData[this.dialogId]?.callback?.ok(this.value);
|
|
}
|
|
}
|
|
DDeiEditorUtil.closeDialog(this.editor, 'ddei-core-dialog-selectborderdash');
|
|
},
|
|
|
|
cancel() {
|
|
DDeiEditorUtil.closeDialog(this.editor, 'ddei-core-dialog-selectborderdash');
|
|
},
|
|
}
|
|
};
|
|
</script>
|
|
|
|
<style lang="less" scoped>
|
|
/**以下是选择颜色的弹出框 */
|
|
.ddei-core-dialog-selectborderdash {
|
|
|
|
border: 1px solid var(--panel-border);
|
|
box-shadow: 0px 2px 24px 0px hsl(0deg 0% 0% /0.25);
|
|
border-radius: 6px;
|
|
display: none;
|
|
overflow: hidden;
|
|
width: 290px;
|
|
position: absolute;
|
|
background-color: var(--panel-background);
|
|
height: 250px;
|
|
z-index: 999;
|
|
user-select: none;
|
|
|
|
.content {
|
|
width: 100%;
|
|
max-height: 250px;
|
|
overflow-y: auto;
|
|
|
|
.group {
|
|
color: var(--panel-title);
|
|
width: 100%;
|
|
|
|
.title {
|
|
color: var(--panel-title);
|
|
flex: 0 0 30px;
|
|
width: 100%;
|
|
display: flex;
|
|
justify-content: start;
|
|
align-items: center;
|
|
padding-left: 10px;
|
|
font-size: 15px;
|
|
border: none;
|
|
margin-top: 5px;
|
|
margin-bottom: 5px;
|
|
}
|
|
|
|
.group_content {
|
|
width: 100%;
|
|
padding: 0px 15px;
|
|
display: grid;
|
|
gap: 5px;
|
|
grid-template-columns: 1fr 1fr;
|
|
}
|
|
|
|
.item {
|
|
height: 24px;
|
|
margin: 0px 2px;
|
|
margin: auto;
|
|
background: transparent;
|
|
display: flex;
|
|
justify-content: center;
|
|
align-items: center;
|
|
cursor: pointer;
|
|
border: 0.5px solid var(--panel-title);
|
|
|
|
.div_input {
|
|
width: calc(100% - 10px);
|
|
height: 3px;
|
|
|
|
>*{
|
|
stroke: var(--panel-title);
|
|
fill: var(--panel-background);
|
|
}
|
|
}
|
|
}
|
|
|
|
.item:hover {
|
|
outline: 1px solid var(--dot);
|
|
}
|
|
|
|
.item-selected {
|
|
outline: 1px solid var(--dot);
|
|
}
|
|
}
|
|
}
|
|
|
|
.tail {
|
|
margin-top: 5px;
|
|
flex: 0 0 55px;
|
|
display: flex;
|
|
align-items: center;
|
|
text-align: center;
|
|
padding: 0 15px;
|
|
justify-content: end;
|
|
}
|
|
|
|
.button {
|
|
flex: 0 0 70px;
|
|
height: 32px;
|
|
background: var(--panel-background);
|
|
border: 1px solid var(--panel-title);
|
|
border-radius: 6px;
|
|
font-size: 16px;
|
|
font-weight: 400;
|
|
color: var(--panel-title);
|
|
margin-left: 13px;
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
|
|
}
|
|
|
|
.button:hover {
|
|
color: white;
|
|
background: var(--dot);
|
|
cursor: pointer;
|
|
}
|
|
|
|
.button-main {
|
|
color: white;
|
|
border: 1px solid var(--panel-background);
|
|
background: var(--dot);
|
|
|
|
}
|
|
}
|
|
</style>
|