ddei-editor/plugins/core/dialogs/TextAlignDialog.vue
2024-04-24 18:32:34 +08:00

207 lines
5.0 KiB
Vue

<template>
<div :id="editor?.id + '_' + dialogId" class="ddei-core-dialog-textalign"
v-if="forceRefresh">
<div class="content">
<div class="title">文本对齐</div>
<div class="group">
<div class="group_content">
<div :class="{ 'item': true, 'selected': value == 1 }" @click="changeAlign(1)" @dblclick="ok(1)">
左上
</div>
<div :class="{ 'item': true, 'selected': value == 2 }" @click="changeAlign(2)" @dblclick="ok(2)">
中上
</div>
<div :class="{ 'item': true, 'selected': value == 3 }" @click="changeAlign(3)" @dblclick="ok(3)">
右上
</div>
<div :class="{ 'item': true, 'selected': value == 4 }" @click="changeAlign(4)" @dblclick="ok(4)">
左中
</div>
<div :class="{ 'item': true, 'selected': value == 5 }" @click="changeAlign(5)" @dblclick="ok(5)">
正中
</div>
<div :class="{ 'item': true, 'selected': value == 6 }" @click="changeAlign(6)" @dblclick="ok(6)">
右中
</div>
<div :class="{ 'item': true, 'selected': value == 7 }" @click="changeAlign(7)" @dblclick="ok(7)">
左下
</div>
<div :class="{ 'item': true, 'selected': value == 8 }" @click="changeAlign(8)" @dblclick="ok(8)">
中下
</div>
<div :class="{ 'item': true, 'selected': value == 9 }" @click="changeAlign(9)" @dblclick="ok(9)">
右下
</div>
</div>
</div>
</div>
</div>
</template>
<script lang="ts">
import {DDeiEditor} from "ddei-framework";
import {DDeiEnumBusCommandType} from "ddei-framework";
import {DDeiEditorUtil} from "ddei-framework";
import DialogBase from "./dialog"
export default {
name: "ddei-core-dialog-textalign",
extends: null,
mixins: [DialogBase],
props: {
//外部传入的插件扩展参数
options: {
type: Object,
default: null
}
},
data() {
return {
dialogId: 'ddei-core-dialog-textalign',
value: 5,//当前选中值
};
},
computed: {},
components: {},
watch: {},
created() { },
mounted() {
this.refreshData();
},
methods: {
refreshData(){
let align = 2;
let valign = 2;
if (this.editor?.tempDialogData && this.editor?.tempDialogData[this.dialogId]) {
align = this.editor?.tempDialogData[this.dialogId].align
valign = this.editor?.tempDialogData[this.dialogId].valign
}
let value = 5;
switch (align) {
case 1:
switch (valign) {
case 1: value = 1; break;
case 2: value = 4; break;
case 3: value = 7; break;
}
break;
case 2:
switch (valign) {
case 1: value = 2; break;
case 2: value = 5; break;
case 3: value = 8; break;
}
break;
case 3:
switch (valign) {
case 1: value = 3; break;
case 2: value = 6; break;
case 3: value = 9; break;
}
break;
}
this.value = value;
},
/**
* 修改文本对齐方式
*/
changeAlign(v) {
this.value = v
if (this.editor?.tempDialogData[this.dialogId]?.callback?.ok) {
this.editor?.tempDialogData[this.dialogId]?.callback?.ok(this.value);
}
},
/**
* 修改文本对齐方式
*/
ok(v) {
this.changeAlign(v)
DDeiEditorUtil.closeDialog(this.editor, "ddei-core-dialog-textalign")
},
}
};
</script>
<style lang="less" scoped>
.ddei-core-dialog-textalign {
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: 240px;
position: absolute;
background-color: var(--panel-background);
height: 180px;
z-index: 999;
.content {
width: 100%;
max-height: 240px;
overflow-y: auto;
user-select: none;
.title {
color: var(--panel-title);
font-weight: bold;
flex: 0 0 30px;
width: 100%;
display: flex;
justify-content: center;
align-items: center;
font-size: 17px;
}
.group {
color: var(--panel-title);
flex: 1 1 40px;
width: 100%;
padding: 10px;
border-top: 1px solid var(--panel-border);
.group_content {
width: 96%;
display: grid;
gap: 5px;
grid-template-columns: 1fr 1fr 1fr;
.item {
outline: none;
width: 70px;
height: 40px;
margin: auto;
background: transparent;
border-radius: 4px;
display: flex;
justify-content: center;
align-items: center;
cursor: pointer;
border: 1px solid var(--panel-border);
}
.selected {
background-color: var(--panel-selected);
}
.item:hover {
background-color: var(--panel-hover);
}
.icon {
font-size: 28px;
}
}
}
}
}
</style>